kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
115 lines (99 loc) • 13.2 kB
JavaScript
;
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 _styledComponents = require("../common/styled-components");
var _icons = require("../common/icons");
var _mapLayerSelector = _interopRequireDefault(require("../common/map-layer-selector"));
var _mapControlTooltip = _interopRequireDefault(require("./map-control-tooltip"));
var _mapControlPanel = _interopRequireDefault(require("./map-control-panel"));
// 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.
LayerSelectorPanelFactory.deps = [_mapControlTooltip["default"], _mapControlPanel["default"]];
function LayerSelectorPanelFactory(MapControlTooltip, MapControlPanel) {
/** @type {import('./layer-selector-panel').LayerSelectorPanelComponent} */
var LayerSelectorPanel = function LayerSelectorPanel(_ref) {
var onMapToggleLayer = _ref.onMapToggleLayer,
onToggleMapControl = _ref.onToggleMapControl,
layers = _ref.layers,
layersToRender = _ref.layersToRender,
isSplit = _ref.isSplit,
mapControls = _ref.mapControls,
readOnly = _ref.readOnly;
var visibleLayers = (mapControls === null || mapControls === void 0 ? void 0 : mapControls.visibleLayers) || {};
var _ref2 = visibleLayers || {},
isActive = _ref2.active,
show = _ref2.show,
disableClose = _ref2.disableClose;
var legendLayers = (0, _react.useMemo)(function () {
return layers.filter(function (_ref3) {
var config = _ref3.config;
return config.isVisible;
}).map(function (_ref4) {
var id = _ref4.id,
config = _ref4.config;
return {
id: id,
name: config.label,
// layer
isVisible: layersToRender[id]
};
});
}, [layers, layersToRender]);
var isVisible = (0, _react.useMemo)(function () {
return isSplit && show && readOnly !== true;
}, [isSplit, show, readOnly]);
var onToggleMenuPanel = (0, _react.useCallback)(function (event) {
event.preventDefault();
onToggleMapControl('visibleLayers');
}, [onToggleMapControl]);
return isVisible ? !isActive ? /*#__PURE__*/_react["default"].createElement(_styledComponents.MapControlButton, {
key: 1,
onClick: onToggleMenuPanel,
className: (0, _classnames["default"])('map-control-button', 'toggle-layer', {
isActive: isActive
}),
"data-tip": true,
"data-for": "toggle-layer"
}, /*#__PURE__*/_react["default"].createElement(_icons.Layers, {
height: "22px"
}), /*#__PURE__*/_react["default"].createElement(MapControlTooltip, {
id: "toggle-layer",
message: isActive ? 'tooltip.hideLayerPanel' : 'tooltip.showLayerPanel'
})) : /*#__PURE__*/_react["default"].createElement(MapControlPanel, {
header: "header.visibleLayers",
onClick: onToggleMenuPanel,
disableClose: disableClose
}, /*#__PURE__*/_react["default"].createElement(_mapLayerSelector["default"], {
layers: legendLayers,
onMapToggleLayer: onMapToggleLayer
})) : null;
};
LayerSelectorPanel.displayName = 'LayerSelectorPanel';
return /*#__PURE__*/_react["default"].memo(LayerSelectorPanel);
}
var _default = LayerSelectorPanelFactory;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/map/layer-selector-panel.js"],"names":["LayerSelectorPanelFactory","deps","MapControlTooltipFactory","MapControlPanelFactory","MapControlTooltip","MapControlPanel","LayerSelectorPanel","onMapToggleLayer","onToggleMapControl","layers","layersToRender","isSplit","mapControls","readOnly","visibleLayers","isActive","active","show","disableClose","legendLayers","filter","config","isVisible","map","id","name","label","onToggleMenuPanel","event","preventDefault","displayName","React","memo"],"mappings":"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","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, useMemo} from 'react';\nimport classnames from 'classnames';\n\nimport {MapControlButton} from 'components/common/styled-components';\nimport {Layers} from '../common/icons';\nimport MapLayerSelector from '../common/map-layer-selector';\nimport MapControlTooltipFactory from './map-control-tooltip';\nimport MapControlPanelFactory from './map-control-panel';\n\nLayerSelectorPanelFactory.deps = [MapControlTooltipFactory, MapControlPanelFactory];\n\nfunction LayerSelectorPanelFactory(MapControlTooltip, MapControlPanel) {\n  /** @type {import('./layer-selector-panel').LayerSelectorPanelComponent} */\n  const LayerSelectorPanel = ({\n    onMapToggleLayer,\n    onToggleMapControl,\n    layers,\n    layersToRender,\n    isSplit,\n    mapControls,\n    readOnly\n  }) => {\n    const visibleLayers = mapControls?.visibleLayers || {};\n    const {active: isActive, show, disableClose} = visibleLayers || {};\n\n    const legendLayers = useMemo(\n      () =>\n        layers\n          .filter(({config}) => config.isVisible)\n          .map(({id, config}) => ({\n            id,\n            name: config.label,\n            // layer\n            isVisible: layersToRender[id]\n          })),\n      [layers, layersToRender]\n    );\n\n    const isVisible = useMemo(() => isSplit && show && readOnly !== true, [\n      isSplit,\n      show,\n      readOnly\n    ]);\n\n    const onToggleMenuPanel = useCallback(\n      event => {\n        event.preventDefault();\n        onToggleMapControl('visibleLayers');\n      },\n      [onToggleMapControl]\n    );\n\n    return isVisible ? (\n      (!isActive ? (\n        <MapControlButton\n          key={1}\n          onClick={onToggleMenuPanel}\n          className={classnames('map-control-button', 'toggle-layer', {isActive})}\n          data-tip\n          data-for=\"toggle-layer\"\n        >\n          <Layers height=\"22px\" />\n          <MapControlTooltip\n            id=\"toggle-layer\"\n            message={isActive ? 'tooltip.hideLayerPanel' : 'tooltip.showLayerPanel'}\n          />\n        </MapControlButton>\n      ) : (\n        <MapControlPanel\n          header=\"header.visibleLayers\"\n          onClick={onToggleMenuPanel}\n          disableClose={disableClose}\n        >\n          <MapLayerSelector layers={legendLayers} onMapToggleLayer={onMapToggleLayer} />\n        </MapControlPanel>\n      ))\n    ) : null;\n  };\n\n  LayerSelectorPanel.displayName = 'LayerSelectorPanel';\n\n  return React.memo(LayerSelectorPanel);\n}\n\nexport default LayerSelectorPanelFactory;\n"]}