kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
77 lines (75 loc) • 12.9 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _react = _interopRequireWildcard(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var _toolbarItem = _interopRequireDefault(require("../common/toolbar-item"));
var _styledComponents = require("../common/styled-components");
var _mapControlTooltip = _interopRequireDefault(require("./map-control-tooltip"));
var _mapControlToolbar = _interopRequireDefault(require("./map-control-toolbar"));
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
// SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
LocalePanelFactory.deps = [_mapControlTooltip["default"], _mapControlToolbar["default"]];
function LocalePanelFactory(MapControlTooltip, MapControlToolbar) {
var LocalePanel = /*#__PURE__*/_react["default"].memo(function (_ref) {
var availableLocales = _ref.availableLocales,
onToggleMapControl = _ref.onToggleMapControl,
onSetLocale = _ref.onSetLocale,
currentLocal = _ref.locale,
mapControls = _ref.mapControls;
var _ref2 = mapControls.mapLocale || {},
isActive = _ref2.active,
show = _ref2.show;
var onClickItem = (0, _react.useCallback)(function (locale) {
onSetLocale(locale);
}, [onSetLocale]);
var onClickButton = (0, _react.useCallback)(function (e) {
e.preventDefault();
onToggleMapControl('mapLocale');
}, [onToggleMapControl]);
var getLabel = (0, _react.useCallback)(function (locale) {
return "toolbar.".concat(locale);
}, []);
if (!show) {
return null;
}
return /*#__PURE__*/_react["default"].createElement("div", {
className: "locale-panel-controls",
style: {
position: 'relative'
}
}, isActive ? /*#__PURE__*/_react["default"].createElement(MapControlToolbar, {
show: isActive
}, availableLocales.map(function (locale) {
return /*#__PURE__*/_react["default"].createElement(_toolbarItem["default"], {
key: locale,
onClick: function onClick() {
return onClickItem(locale);
},
label: getLabel(locale),
active: currentLocal === locale
});
})) : null, /*#__PURE__*/_react["default"].createElement(MapControlTooltip, {
id: "locale",
message: "tooltip.selectLocale"
}, /*#__PURE__*/_react["default"].createElement(_styledComponents.MapControlButton, {
className: (0, _classnames["default"])('map-control-button', 'locale-panel', {
isActive: isActive
}),
onClick: onClickButton,
active: isActive
}, /*#__PURE__*/_react["default"].createElement("span", {
className: "map-control-button__locale"
}, currentLocal.toUpperCase()))));
});
LocalePanel.displayName = 'LocalePanel';
return LocalePanel;
}
var _default = exports["default"] = LocalePanelFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_toolbarItem","_styledComponents","_mapControlTooltip","_mapControlToolbar","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","LocalePanelFactory","deps","MapControlTooltipFactory","MapControlToolbarFactory","MapControlTooltip","MapControlToolbar","LocalePanel","React","memo","_ref","availableLocales","onToggleMapControl","onSetLocale","currentLocal","locale","mapControls","_ref2","mapLocale","isActive","active","show","onClickItem","useCallback","onClickButton","preventDefault","getLabel","concat","createElement","className","style","position","map","key","onClick","label","id","message","MapControlButton","classnames","toUpperCase","displayName","_default","exports"],"sources":["../../src/map/locale-panel.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback} from 'react';\nimport classnames from 'classnames';\n\nimport ToolbarItem from '../common/toolbar-item';\nimport {MapControlButton} from '../common/styled-components';\nimport MapControlTooltipFactory from './map-control-tooltip';\nimport MapControlToolbarFactory from './map-control-toolbar';\nimport {MapControls} from '@kepler.gl/types';\n\nLocalePanelFactory.deps = [MapControlTooltipFactory, MapControlToolbarFactory];\n\nexport type LocalePanelProps = {\n  availableLocales: ReadonlyArray<string>;\n  onSetLocale: (locale: string) => void;\n  locale: string;\n  onToggleMapControl: (control: string) => void;\n  mapControls: MapControls;\n};\n\nfunction LocalePanelFactory(\n  MapControlTooltip: ReturnType<typeof MapControlTooltipFactory>,\n  MapControlToolbar: ReturnType<typeof MapControlToolbarFactory>\n) {\n  const LocalePanel: React.FC<LocalePanelProps> = React.memo(\n    ({availableLocales, onToggleMapControl, onSetLocale, locale: currentLocal, mapControls}) => {\n      const {active: isActive, show} = mapControls.mapLocale || {};\n\n      const onClickItem = useCallback(\n        locale => {\n          onSetLocale(locale);\n        },\n        [onSetLocale]\n      );\n\n      const onClickButton = useCallback(\n        e => {\n          e.preventDefault();\n          onToggleMapControl('mapLocale');\n        },\n        [onToggleMapControl]\n      );\n      const getLabel = useCallback(locale => `toolbar.${locale}`, []);\n\n      if (!show) {\n        return null;\n      }\n      return (\n        <div className=\"locale-panel-controls\" style={{position: 'relative'}}>\n          {isActive ? (\n            <MapControlToolbar show={isActive}>\n              {availableLocales.map(locale => (\n                <ToolbarItem\n                  key={locale}\n                  onClick={() => onClickItem(locale)}\n                  label={getLabel(locale)}\n                  active={currentLocal === locale}\n                />\n              ))}\n            </MapControlToolbar>\n          ) : null}\n          <MapControlTooltip id=\"locale\" message=\"tooltip.selectLocale\">\n            <MapControlButton\n              className={classnames('map-control-button', 'locale-panel', {isActive})}\n              onClick={onClickButton}\n              active={isActive}\n            >\n              <span className=\"map-control-button__locale\">{currentLocal.toUpperCase()}</span>\n            </MapControlButton>\n          </MapControlTooltip>\n        </div>\n      );\n    }\n  );\n\n  LocalePanel.displayName = 'LocalePanel';\n\n  return LocalePanel;\n}\n\nexport default LocalePanelFactory;\n"],"mappings":"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","ignoreList":[]}
;