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
JavaScript
"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"]}