UNPKG

kepler.gl

Version:

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

187 lines (186 loc) 38.8 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = exports.LayerBlendingSelector = void 0; var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireWildcard(require("react")); var _reactIntl = require("react-intl"); var _styledComponents = _interopRequireDefault(require("styled-components")); var _localization = require("@kepler.gl/localization"); var _layerList = _interopRequireDefault(require("./layer-panel/layer-list")); var _datasetLayerGroup = _interopRequireDefault(require("./layer-panel/dataset-layer-group")); var _panelViewListToggle = _interopRequireDefault(require("./panel-view-list-toggle")); var _panelTitle = _interopRequireDefault(require("./panel-title")); var _datasetSection = _interopRequireDefault(require("./layer-panel/dataset-section")); var _addLayerButton = _interopRequireDefault(require("./layer-panel/add-layer-button")); var _itemSelector = _interopRequireDefault(require("../common/item-selector/item-selector")); var _styledComponents2 = require("../common/styled-components"); var _infoHelper = _interopRequireDefault(require("../common/info-helper")); var _constants = require("@kepler.gl/constants"); var _utils = require("@kepler.gl/utils"); var _excluded = ["rasterTile"]; var _templateObject, _templateObject2; 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; } function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project var LayerBlendingSelector = exports.LayerBlendingSelector = /*#__PURE__*/_react["default"].memo(function (_ref) { var layerBlending = _ref.layerBlending, updateLayerBlending = _ref.updateLayerBlending, intl = _ref.intl, className = _ref.className; var labeledLayerBlendings = Object.keys(_constants.LAYER_BLENDINGS).reduce(function (acc, current) { return _objectSpread(_objectSpread({}, acc), {}, (0, _defineProperty2["default"])({}, intl.formatMessage({ id: _constants.LAYER_BLENDINGS[current].label }), current)); }, {}); var onChange = (0, _react.useCallback)(function (blending) { return updateLayerBlending(labeledLayerBlendings[blending]); }, [updateLayerBlending, labeledLayerBlendings]); return /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, { className: className }, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: "layerBlending.title" })), /*#__PURE__*/_react["default"].createElement(_itemSelector["default"], { selectedItems: intl.formatMessage({ id: _constants.LAYER_BLENDINGS[layerBlending].label }), options: Object.keys(labeledLayerBlendings), multiSelect: false, searchable: false, onChange: onChange })); }); LayerBlendingSelector.displayName = 'LayerBlendingSelector'; var InfoHelperWrapper = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n float: right;\n"]))); var OverlayBlendingSelectorTitleRow = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: row;\n align-items: center;\n"]))); var OverlayBlendingSelector = /*#__PURE__*/_react["default"].memo(function (_ref2) { var overlayBlending = _ref2.overlayBlending, updateOverlayBlending = _ref2.updateOverlayBlending, intl = _ref2.intl, infoHelper = _ref2.infoHelper; var labeledOverlayBlendings = Object.keys(_constants.OVERLAY_BLENDINGS).reduce(function (acc, current) { return _objectSpread(_objectSpread({}, acc), {}, (0, _defineProperty2["default"])({}, intl.formatMessage({ id: _constants.OVERLAY_BLENDINGS[current].label }), current)); }, {}); var onChange = (0, _react.useCallback)(function (blending) { return updateOverlayBlending(labeledOverlayBlendings[blending]); }, [updateOverlayBlending, labeledOverlayBlendings]); return /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(OverlayBlendingSelectorTitleRow, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: "overlayBlending.title" })), /*#__PURE__*/_react["default"].createElement(InfoHelperWrapper, null, infoHelper)), /*#__PURE__*/_react["default"].createElement(_itemSelector["default"], { selectedItems: intl.formatMessage({ id: _constants.OVERLAY_BLENDINGS[overlayBlending].label }), options: Object.keys(labeledOverlayBlendings), multiSelect: false, searchable: false, onChange: onChange })); }); OverlayBlendingSelector.displayName = 'OverlayBlendingSelector'; LayerManagerFactory.deps = [_layerList["default"], _datasetLayerGroup["default"], _panelViewListToggle["default"], _panelTitle["default"], _datasetSection["default"], _addLayerButton["default"], _infoHelper["default"]]; function LayerManagerFactory(LayerList, DatasetLayerGroup, PanelViewListToggle, PanelTitle, DatasetSection, AddLayerButton, InfoHelper) { var LayerManager = function LayerManager(_ref3) { var layers = _ref3.layers, datasets = _ref3.datasets, intl = _ref3.intl, layerOrder = _ref3.layerOrder, panelListView = _ref3.panelListView, panelMetadata = _ref3.panelMetadata, layerClasses = _ref3.layerClasses, layerBlending = _ref3.layerBlending, overlayBlending = _ref3.overlayBlending, showAddDataModal = _ref3.showAddDataModal, updateTableColor = _ref3.updateTableColor, showDatasetTable = _ref3.showDatasetTable, removeDataset = _ref3.removeDataset, uiStateActions = _ref3.uiStateActions, visStateActions = _ref3.visStateActions, mapStateActions = _ref3.mapStateActions; var addLayer = visStateActions.addLayer; var togglePanelListView = uiStateActions.togglePanelListView; var onAddLayer = (0, _react.useCallback)(function (dataset) { addLayer(undefined, dataset); }, [addLayer]); var onTogglePanelListView = (0, _react.useCallback)(function (listView) { togglePanelListView({ panelId: 'layer', listView: listView }); }, [togglePanelListView]); var isSortByDatasetMode = panelListView === _constants.PANEL_VIEW_TOGGLES.byDataset; var enableRasterTileLayer = (0, _utils.getApplicationConfig)().enableRasterTileLayer; var filteredLayerClasses = (0, _react.useMemo)(function () { if (enableRasterTileLayer) return layerClasses; /* eslint-disable @typescript-eslint/no-unused-vars */ var rasterTile = layerClasses.rasterTile, restClasses = (0, _objectWithoutProperties2["default"])(layerClasses, _excluded); return restClasses; }, [enableRasterTileLayer, layerClasses]); return /*#__PURE__*/_react["default"].createElement("div", { className: "layer-manager" }, /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(PanelViewListToggle, { togglePanelListView: onTogglePanelListView, mode: panelListView })), /*#__PURE__*/_react["default"].createElement(DatasetSection, { datasets: datasets, showDatasetTable: showDatasetTable, updateTableColor: updateTableColor, removeDataset: removeDataset, showDeleteDataset: true, showDatasetList: !isSortByDatasetMode, showAddDataModal: showAddDataModal }), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelDivider, null), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(PanelTitle, { className: "layer-manager-title", title: intl.formatMessage({ id: panelMetadata.label }) }, /*#__PURE__*/_react["default"].createElement(AddLayerButton, { datasets: datasets, onAdd: onAddLayer }))), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, isSortByDatasetMode ? /*#__PURE__*/_react["default"].createElement(DatasetLayerGroup, { datasets: datasets, showDatasetTable: showDatasetTable, layers: layers, updateTableColor: updateTableColor, removeDataset: removeDataset, layerOrder: layerOrder, layerClasses: filteredLayerClasses, uiStateActions: uiStateActions, visStateActions: visStateActions, mapStateActions: mapStateActions, showDeleteDataset: true }) : /*#__PURE__*/_react["default"].createElement(LayerList, { layers: layers, datasets: datasets, layerOrder: layerOrder, uiStateActions: uiStateActions, visStateActions: visStateActions, mapStateActions: mapStateActions, layerClasses: filteredLayerClasses })), /*#__PURE__*/_react["default"].createElement(LayerBlendingSelector, { layerBlending: layerBlending, updateLayerBlending: visStateActions.updateLayerBlending, intl: intl }), /*#__PURE__*/_react["default"].createElement(OverlayBlendingSelector, { overlayBlending: overlayBlending, updateOverlayBlending: visStateActions.updateOverlayBlending, intl: intl, infoHelper: /*#__PURE__*/_react["default"].createElement(InfoHelper, { id: "overlayBlending-description", description: 'overlayBlending.description' }) })); }; return (0, _reactIntl.injectIntl)(LayerManager); } var _default = exports["default"] = LayerManagerFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactIntl","_styledComponents","_interopRequireDefault","_localization","_layerList","_datasetLayerGroup","_panelViewListToggle","_panelTitle","_datasetSection","_addLayerButton","_itemSelector","_styledComponents2","_infoHelper","_constants","_utils","_excluded","_templateObject","_templateObject2","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","LayerBlendingSelector","exports","React","memo","_ref","layerBlending","updateLayerBlending","intl","className","labeledLayerBlendings","LAYER_BLENDINGS","reduce","acc","current","formatMessage","id","label","onChange","useCallback","blending","createElement","SidePanelSection","PanelLabel","FormattedMessage","selectedItems","options","multiSelect","searchable","displayName","InfoHelperWrapper","styled","div","_taggedTemplateLiteral2","OverlayBlendingSelectorTitleRow","OverlayBlendingSelector","_ref2","overlayBlending","updateOverlayBlending","infoHelper","labeledOverlayBlendings","OVERLAY_BLENDINGS","LayerManagerFactory","deps","LayerListFactory","DatasetLayerGroupFactory","PanelViewListToggleFactory","PanelTitleFactory","DatasetSectionFactory","AddLayerButtonFactory","InfoHelperFactory","LayerList","DatasetLayerGroup","PanelViewListToggle","PanelTitle","DatasetSection","AddLayerButton","InfoHelper","LayerManager","_ref3","layers","datasets","layerOrder","panelListView","panelMetadata","layerClasses","showAddDataModal","updateTableColor","showDatasetTable","removeDataset","uiStateActions","visStateActions","mapStateActions","addLayer","togglePanelListView","onAddLayer","dataset","undefined","onTogglePanelListView","listView","panelId","isSortByDatasetMode","PANEL_VIEW_TOGGLES","byDataset","enableRasterTileLayer","getApplicationConfig","filteredLayerClasses","useMemo","rasterTile","restClasses","_objectWithoutProperties2","mode","showDeleteDataset","showDatasetList","SidePanelDivider","title","onAdd","description","injectIntl","_default"],"sources":["../../src/side-panel/layer-manager.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useMemo} from 'react';\n\nimport {injectIntl, WrappedComponentProps} from 'react-intl';\nimport styled from 'styled-components';\nimport {FormattedMessage} from '@kepler.gl/localization';\n\nimport LayerListFactory from './layer-panel/layer-list';\nimport DatasetLayerGroupFactory from './layer-panel/dataset-layer-group';\nimport PanelViewListToggleFactory from './panel-view-list-toggle';\nimport PanelTitleFactory from './panel-title';\nimport DatasetSectionFactory from './layer-panel/dataset-section';\nimport AddLayerButtonFactory from './layer-panel/add-layer-button';\n\nimport ItemSelector from '../common/item-selector/item-selector';\nimport {PanelLabel, SidePanelDivider, SidePanelSection} from '../common/styled-components';\nimport InfoHelperFactory from '../common/info-helper';\n\nimport {LAYER_BLENDINGS, OVERLAY_BLENDINGS, PANEL_VIEW_TOGGLES} from '@kepler.gl/constants';\nimport {Layer, LayerClassesType} from '@kepler.gl/layers';\nimport {UIStateActions, VisStateActions, MapStateActions, ActionHandler} from '@kepler.gl/actions';\nimport {SidePanelItem} from '../types';\nimport {PanelListView} from '@kepler.gl/types';\nimport {Datasets} from '@kepler.gl/table';\nimport {getApplicationConfig} from '@kepler.gl/utils';\n\ntype LayerBlendingSelectorProps = {\n  layerBlending: string;\n  updateLayerBlending: ActionHandler<typeof VisStateActions.updateLayerBlending>;\n  className?: string;\n} & WrappedComponentProps;\n\ntype OverlayBlendingSelectorProps = {\n  overlayBlending: string;\n  updateOverlayBlending: ActionHandler<typeof VisStateActions.updateOverlayBlending>;\n  infoHelper: React.ReactNode;\n} & WrappedComponentProps;\n\ntype LayerManagerProps = {\n  datasets: Datasets;\n  layers: Layer[];\n  layerOrder: string[];\n  layerClasses: LayerClassesType;\n  layerBlending: string;\n  overlayBlending: string;\n  uiStateActions: typeof UIStateActions;\n  visStateActions: typeof VisStateActions;\n  mapStateActions: typeof MapStateActions;\n  showAddDataModal: () => void;\n  removeDataset: ActionHandler<typeof UIStateActions.openDeleteModal>;\n  showDatasetTable: ActionHandler<typeof VisStateActions.showDatasetTable>;\n  updateTableColor: ActionHandler<typeof VisStateActions.updateTableColor>;\n  panelListView: PanelListView;\n  panelMetadata: SidePanelItem;\n} & WrappedComponentProps;\n\nexport const LayerBlendingSelector = React.memo(\n  ({layerBlending, updateLayerBlending, intl, className}: LayerBlendingSelectorProps) => {\n    const labeledLayerBlendings = Object.keys(LAYER_BLENDINGS).reduce(\n      (acc, current) => ({\n        ...acc,\n        [intl.formatMessage({id: LAYER_BLENDINGS[current].label})]: current\n      }),\n      {}\n    );\n\n    const onChange = useCallback(\n      blending => updateLayerBlending(labeledLayerBlendings[blending]),\n      [updateLayerBlending, labeledLayerBlendings]\n    );\n\n    return (\n      <SidePanelSection className={className}>\n        <PanelLabel>\n          <FormattedMessage id=\"layerBlending.title\" />\n        </PanelLabel>\n        <ItemSelector\n          selectedItems={intl.formatMessage({id: LAYER_BLENDINGS[layerBlending].label})}\n          options={Object.keys(labeledLayerBlendings)}\n          multiSelect={false}\n          searchable={false}\n          onChange={onChange}\n        />\n      </SidePanelSection>\n    );\n  }\n);\nLayerBlendingSelector.displayName = 'LayerBlendingSelector';\n\nconst InfoHelperWrapper = styled.div`\n  float: right;\n`;\n\nconst OverlayBlendingSelectorTitleRow = styled.div`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n`;\n\nconst OverlayBlendingSelector = React.memo(\n  ({overlayBlending, updateOverlayBlending, intl, infoHelper}: OverlayBlendingSelectorProps) => {\n    const labeledOverlayBlendings = Object.keys(OVERLAY_BLENDINGS).reduce(\n      (acc, current) => ({\n        ...acc,\n        [intl.formatMessage({id: OVERLAY_BLENDINGS[current].label})]: current\n      }),\n      {}\n    );\n\n    const onChange = useCallback(\n      blending => updateOverlayBlending(labeledOverlayBlendings[blending]),\n      [updateOverlayBlending, labeledOverlayBlendings]\n    );\n\n    return (\n      <SidePanelSection>\n        <OverlayBlendingSelectorTitleRow>\n          <PanelLabel>\n            <FormattedMessage id=\"overlayBlending.title\" />\n          </PanelLabel>\n          <InfoHelperWrapper>{infoHelper}</InfoHelperWrapper>\n        </OverlayBlendingSelectorTitleRow>\n        <ItemSelector\n          selectedItems={intl.formatMessage({id: OVERLAY_BLENDINGS[overlayBlending].label})}\n          options={Object.keys(labeledOverlayBlendings)}\n          multiSelect={false}\n          searchable={false}\n          onChange={onChange}\n        />\n      </SidePanelSection>\n    );\n  }\n);\nOverlayBlendingSelector.displayName = 'OverlayBlendingSelector';\n\nLayerManagerFactory.deps = [\n  LayerListFactory,\n  DatasetLayerGroupFactory,\n  PanelViewListToggleFactory,\n  PanelTitleFactory,\n  DatasetSectionFactory,\n  AddLayerButtonFactory,\n  InfoHelperFactory\n];\n\nfunction LayerManagerFactory(\n  LayerList: ReturnType<typeof LayerListFactory>,\n  DatasetLayerGroup: ReturnType<typeof DatasetLayerGroupFactory>,\n  PanelViewListToggle: ReturnType<typeof PanelViewListToggleFactory>,\n  PanelTitle: ReturnType<typeof PanelTitleFactory>,\n  DatasetSection: ReturnType<typeof DatasetSectionFactory>,\n  AddLayerButton: ReturnType<typeof AddLayerButtonFactory>,\n  InfoHelper: ReturnType<typeof InfoHelperFactory>\n) {\n  const LayerManager: React.FC<LayerManagerProps> = ({\n    layers,\n    datasets,\n    intl,\n    layerOrder,\n    panelListView,\n    panelMetadata,\n    layerClasses,\n    layerBlending,\n    overlayBlending,\n    showAddDataModal,\n    updateTableColor,\n    showDatasetTable,\n    removeDataset,\n    uiStateActions,\n    visStateActions,\n    mapStateActions\n  }) => {\n    const {addLayer} = visStateActions;\n    const {togglePanelListView} = uiStateActions;\n    const onAddLayer = useCallback(\n      (dataset: string) => {\n        addLayer(undefined, dataset);\n      },\n      [addLayer]\n    );\n\n    const onTogglePanelListView = useCallback(\n      (listView: string) => {\n        togglePanelListView({panelId: 'layer', listView});\n      },\n      [togglePanelListView]\n    );\n\n    const isSortByDatasetMode = panelListView === PANEL_VIEW_TOGGLES.byDataset;\n\n    const enableRasterTileLayer = getApplicationConfig().enableRasterTileLayer;\n    const filteredLayerClasses = useMemo(() => {\n      if (enableRasterTileLayer) return layerClasses;\n      /* eslint-disable @typescript-eslint/no-unused-vars */\n      const {rasterTile, ...restClasses} = layerClasses;\n      return restClasses as LayerClassesType;\n    }, [enableRasterTileLayer, layerClasses]);\n\n    return (\n      <div className=\"layer-manager\">\n        <SidePanelSection>\n          <PanelViewListToggle togglePanelListView={onTogglePanelListView} mode={panelListView} />\n        </SidePanelSection>\n        <DatasetSection\n          datasets={datasets}\n          showDatasetTable={showDatasetTable}\n          updateTableColor={updateTableColor}\n          removeDataset={removeDataset}\n          showDeleteDataset\n          showDatasetList={!isSortByDatasetMode}\n          showAddDataModal={showAddDataModal}\n        />\n        <SidePanelDivider />\n        <SidePanelSection>\n          <PanelTitle\n            className=\"layer-manager-title\"\n            title={intl.formatMessage({id: panelMetadata.label})}\n          >\n            <AddLayerButton datasets={datasets} onAdd={onAddLayer} />\n          </PanelTitle>\n        </SidePanelSection>\n        <SidePanelSection>\n          {isSortByDatasetMode ? (\n            <DatasetLayerGroup\n              datasets={datasets}\n              showDatasetTable={showDatasetTable}\n              layers={layers}\n              updateTableColor={updateTableColor}\n              removeDataset={removeDataset}\n              layerOrder={layerOrder}\n              layerClasses={filteredLayerClasses}\n              uiStateActions={uiStateActions}\n              visStateActions={visStateActions}\n              mapStateActions={mapStateActions}\n              showDeleteDataset\n            />\n          ) : (\n            <LayerList\n              layers={layers}\n              datasets={datasets}\n              layerOrder={layerOrder}\n              uiStateActions={uiStateActions}\n              visStateActions={visStateActions}\n              mapStateActions={mapStateActions}\n              layerClasses={filteredLayerClasses}\n            />\n          )}\n        </SidePanelSection>\n        <LayerBlendingSelector\n          layerBlending={layerBlending}\n          updateLayerBlending={visStateActions.updateLayerBlending}\n          intl={intl}\n        />\n        <OverlayBlendingSelector\n          overlayBlending={overlayBlending}\n          updateOverlayBlending={visStateActions.updateOverlayBlending}\n          intl={intl}\n          infoHelper={\n            <InfoHelper\n              id={`overlayBlending-description`}\n              description={'overlayBlending.description'}\n            />\n          }\n        />\n      </div>\n    );\n  };\n\n  return injectIntl(LayerManager);\n}\n\nexport default LayerManagerFactory;\n"],"mappings":"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","ignoreList":[]}