UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

124 lines (103 loc) 12.9 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _react = _interopRequireWildcard(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _icons = require("../common/icons"); var _localization = require("../../localization"); var _styledComponents = require("../common/styled-components"); var _mapControlTooltip = _interopRequireDefault(require("./map-control-tooltip")); var _mapControlPanel = _interopRequireDefault(require("./map-control-panel")); var _mapLegend = _interopRequireDefault(require("./map-legend")); // Copyright (c) 2021 Uber Technologies, Inc. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. var MapLegendTooltip = function MapLegendTooltip(_ref) { var id = _ref.id, message = _ref.message; return /*#__PURE__*/_react["default"].createElement(_styledComponents.Tooltip, { id: id, place: "left", effect: "solid" }, /*#__PURE__*/_react["default"].createElement("span", null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: message }))); }; MapLegendPanelFactory.deps = [_mapControlTooltip["default"], _mapControlPanel["default"], _mapLegend["default"]]; function MapLegendPanelFactory(MapControlTooltip, MapControlPanel, MapLegend) { var defaultActionIcons = { legend: _icons.Legend }; /** @type {import('./map-legend-panel').MapLegendPanelComponent} */ var MapLegendPanel = function MapLegendPanel(_ref2) { var layers = _ref2.layers, mapControls = _ref2.mapControls, scale = _ref2.scale, onToggleMapControl = _ref2.onToggleMapControl, isExport = _ref2.isExport, logoComponent = _ref2.logoComponent, _ref2$actionIcons = _ref2.actionIcons, actionIcons = _ref2$actionIcons === void 0 ? defaultActionIcons : _ref2$actionIcons; var mapLegend = (mapControls === null || mapControls === void 0 ? void 0 : mapControls.mapLegend) || {}; var _ref3 = mapLegend || {}, isActive = _ref3.active, disableClose = _ref3.disableClose; var onToggleMenuPanel = (0, _react.useCallback)(function () { return onToggleMapControl('mapLegend'); }, [onToggleMapControl]); var onClick = (0, _react.useCallback)(function (e) { e.preventDefault(); onToggleMenuPanel(); }, [onToggleMenuPanel]); if (!mapLegend.show) { return null; } return !isActive ? /*#__PURE__*/_react["default"].createElement(_styledComponents.MapControlButton, { "data-tip": true, "data-for": "show-legend", className: (0, _classnames["default"])('map-control-button', 'show-legend', { isActive: isActive }), onClick: onClick }, /*#__PURE__*/_react["default"].createElement(actionIcons.legend, { height: "22px" }), /*#__PURE__*/_react["default"].createElement(MapLegendTooltip, { id: "show-legend", message: 'tooltip.showLegend' })) : /*#__PURE__*/_react["default"].createElement(MapControlPanel, { scale: scale, header: 'header.layerLegend', onClick: onToggleMenuPanel, isExport: isExport, disableClose: disableClose, logoComponent: logoComponent }, /*#__PURE__*/_react["default"].createElement(MapLegend, { layers: layers })); }; MapLegendPanel.displayName = 'MapLegendPanel'; return MapLegendPanel; } var _default = MapLegendPanelFactory; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/map/map-legend-panel.js"],"names":["MapLegendTooltip","id","message","MapLegendPanelFactory","deps","MapControlTooltipFactory","MapControlPanelFactory","MapLegendFactory","MapControlTooltip","MapControlPanel","MapLegend","defaultActionIcons","legend","Legend","MapLegendPanel","layers","mapControls","scale","onToggleMapControl","isExport","logoComponent","actionIcons","mapLegend","isActive","active","disableClose","onToggleMenuPanel","onClick","e","preventDefault","show","displayName"],"mappings":";;;;;;;;;;;AAoBA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AA3BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAWA,IAAMA,gBAAgB,GAAG,SAAnBA,gBAAmB;AAAA,MAAEC,EAAF,QAAEA,EAAF;AAAA,MAAMC,OAAN,QAAMA,OAAN;AAAA,sBACvB,gCAAC,yBAAD;AAAS,IAAA,EAAE,EAAED,EAAb;AAAiB,IAAA,KAAK,EAAC,MAAvB;AAA8B,IAAA,MAAM,EAAC;AAArC,kBACE,2DACE,gCAAC,8BAAD;AAAkB,IAAA,EAAE,EAAEC;AAAtB,IADF,CADF,CADuB;AAAA,CAAzB;;AAQAC,qBAAqB,CAACC,IAAtB,GAA6B,CAACC,6BAAD,EAA2BC,2BAA3B,EAAmDC,qBAAnD,CAA7B;;AAEA,SAASJ,qBAAT,CAA+BK,iBAA/B,EAAkDC,eAAlD,EAAmEC,SAAnE,EAA8E;AAC5E,MAAMC,kBAAkB,GAAG;AACzBC,IAAAA,MAAM,EAAEC;AADiB,GAA3B;AAIA;;AACA,MAAMC,cAAc,GAAG,SAAjBA,cAAiB,QAQjB;AAAA,QAPJC,MAOI,SAPJA,MAOI;AAAA,QANJC,WAMI,SANJA,WAMI;AAAA,QALJC,KAKI,SALJA,KAKI;AAAA,QAJJC,kBAII,SAJJA,kBAII;AAAA,QAHJC,QAGI,SAHJA,QAGI;AAAA,QAFJC,aAEI,SAFJA,aAEI;AAAA,kCADJC,WACI;AAAA,QADJA,WACI,kCADUV,kBACV;AACJ,QAAMW,SAAS,GAAG,CAAAN,WAAW,SAAX,IAAAA,WAAW,WAAX,YAAAA,WAAW,CAAEM,SAAb,KAA0B,EAA5C;;AADI,gBAEqCA,SAAS,IAAI,EAFlD;AAAA,QAEWC,QAFX,SAEGC,MAFH;AAAA,QAEqBC,YAFrB,SAEqBA,YAFrB;;AAGJ,QAAMC,iBAAiB,GAAG,wBAAY;AAAA,aAAMR,kBAAkB,CAAC,WAAD,CAAxB;AAAA,KAAZ,EAAmD,CAC3EA,kBAD2E,CAAnD,CAA1B;AAIA,QAAMS,OAAO,GAAG,wBACd,UAAAC,CAAC,EAAI;AACHA,MAAAA,CAAC,CAACC,cAAF;AACAH,MAAAA,iBAAiB;AAClB,KAJa,EAKd,CAACA,iBAAD,CALc,CAAhB;;AAQA,QAAI,CAACJ,SAAS,CAACQ,IAAf,EAAqB;AACnB,aAAO,IAAP;AACD;;AACD,WAAO,CAACP,QAAD,gBACJ,gCAAC,kCAAD;AACC,sBADD;AAEC,kBAAS,aAFV;AAGC,MAAA,SAAS,EAAE,4BAAW,oBAAX,EAAiC,aAAjC,EAAgD;AAACA,QAAAA,QAAQ,EAARA;AAAD,OAAhD,CAHZ;AAIC,MAAA,OAAO,EAAEI;AAJV,oBAMC,gCAAC,WAAD,CAAa,MAAb;AAAoB,MAAA,MAAM,EAAC;AAA3B,MAND,eAOC,gCAAC,gBAAD;AAAkB,MAAA,EAAE,EAAC,aAArB;AAAmC,MAAA,OAAO,EAAE;AAA5C,MAPD,CADI,gBAWJ,gCAAC,eAAD;AACC,MAAA,KAAK,EAAEV,KADR;AAEC,MAAA,MAAM,EAAE,oBAFT;AAGC,MAAA,OAAO,EAAES,iBAHV;AAIC,MAAA,QAAQ,EAAEP,QAJX;AAKC,MAAA,YAAY,EAAEM,YALf;AAMC,MAAA,aAAa,EAAEL;AANhB,oBAQC,gCAAC,SAAD;AAAW,MAAA,MAAM,EAAEL;AAAnB,MARD,CAXH;AAsBD,GAhDD;;AAkDAD,EAAAA,cAAc,CAACiB,WAAf,GAA6B,gBAA7B;AACA,SAAOjB,cAAP;AACD;;eAEcX,qB","sourcesContent":["// Copyright (c) 2021 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport React, {useCallback} from 'react';\nimport classnames from 'classnames';\nimport {Legend} from 'components/common/icons';\nimport {FormattedMessage} from 'localization';\nimport {MapControlButton, Tooltip} from 'components/common/styled-components';\nimport MapControlTooltipFactory from './map-control-tooltip';\nimport MapControlPanelFactory from './map-control-panel';\nimport MapLegendFactory from './map-legend';\n\nconst MapLegendTooltip = ({id, message}) => (\n  <Tooltip id={id} place=\"left\" effect=\"solid\">\n    <span>\n      <FormattedMessage id={message} />\n    </span>\n  </Tooltip>\n);\n\nMapLegendPanelFactory.deps = [MapControlTooltipFactory, MapControlPanelFactory, MapLegendFactory];\n\nfunction MapLegendPanelFactory(MapControlTooltip, MapControlPanel, MapLegend) {\n  const defaultActionIcons = {\n    legend: Legend\n  };\n\n  /** @type {import('./map-legend-panel').MapLegendPanelComponent} */\n  const MapLegendPanel = ({\n    layers,\n    mapControls,\n    scale,\n    onToggleMapControl,\n    isExport,\n    logoComponent,\n    actionIcons = defaultActionIcons\n  }) => {\n    const mapLegend = mapControls?.mapLegend || {};\n    const {active: isActive, disableClose} = mapLegend || {};\n    const onToggleMenuPanel = useCallback(() => onToggleMapControl('mapLegend'), [\n      onToggleMapControl\n    ]);\n\n    const onClick = useCallback(\n      e => {\n        e.preventDefault();\n        onToggleMenuPanel();\n      },\n      [onToggleMenuPanel]\n    );\n\n    if (!mapLegend.show) {\n      return null;\n    }\n    return !isActive ? (\n      (<MapControlButton\n        data-tip\n        data-for=\"show-legend\"\n        className={classnames('map-control-button', 'show-legend', {isActive})}\n        onClick={onClick}\n      >\n        <actionIcons.legend height=\"22px\" />\n        <MapLegendTooltip id=\"show-legend\" message={'tooltip.showLegend'} />\n      </MapControlButton>)\n    ) : (\n      (<MapControlPanel\n        scale={scale}\n        header={'header.layerLegend'}\n        onClick={onToggleMenuPanel}\n        isExport={isExport}\n        disableClose={disableClose}\n        logoComponent={logoComponent}\n      >\n        <MapLegend layers={layers} />\n      </MapControlPanel>)\n    );\n  };\n\n  MapLegendPanel.displayName = 'MapLegendPanel';\n  return MapLegendPanel;\n}\n\nexport default MapLegendPanelFactory;\n"]}