UNPKG

kepler.gl

Version:

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

173 lines (171 loc) 28.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"] = void 0; var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _classnames3 = _interopRequireDefault(require("classnames")); var _sortable = require("@dnd-kit/sortable"); var _utilities = require("@dnd-kit/utilities"); var _layerPanel = _interopRequireDefault(require("./layer-panel")); var _utils = require("@kepler.gl/utils"); var _constants = require("@kepler.gl/constants"); var _templateObject, _templateObject2; // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project 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; } // make sure the element is always visible while is being dragged // item being dragged is appended in body, here to reset its global style var Container = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n gap: 8px;\n"]))); var SortableStyledItem = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n z-index: ", ";\n transition: ", ";\n transform: ", ";\n &.sorting {\n opacity: 0.3;\n pointer-events: none;\n }\n &.sorting-layers .layer-panel__header {\n background-color: ", ";\n font-family: ", ";\n font-weight: ", ";\n font-size: ", ";\n line-height: ", ";\n *,\n *:before,\n *:after {\n box-sizing: border-box;\n }\n .layer__drag-handle {\n opacity: 1;\n color: ", ";\n }\n }\n"])), function (props) { return props.theme.dropdownWrapperZ + 1; }, function (props) { return props.transition; }, function (props) { return props.transform; }, function (props) { return props.theme.panelBackgroundHover; }, function (props) { return props.theme.fontFamily; }, function (props) { return props.theme.fontWeight; }, function (props) { return props.theme.fontSize; }, function (props) { return props.theme.lineHeight; }, function (props) { return props.theme.textColorHl; }); var INITIAL_LAYERS_TO_SHOW = []; LayerListFactory.deps = [_layerPanel["default"]]; function LayerListFactory(LayerPanel) { // By wrapping layer panel using a sortable element we don't have to implement the drag and drop logic into the panel itself; // Developers can provide any layer panel implementation and it will still be sortable var SortableItem = function SortableItem(_ref) { var layer = _ref.layer, idx = _ref.idx, panelProps = _ref.panelProps, layerActions = _ref.layerActions, disabled = _ref.disabled; var _useSortable = (0, _sortable.useSortable)({ id: layer.id, data: { type: _constants.SORTABLE_LAYER_TYPE, parent: _constants.SORTABLE_SIDE_PANEL_TYPE }, disabled: disabled }), attributes = _useSortable.attributes, listeners = _useSortable.listeners, setNodeRef = _useSortable.setNodeRef, isDragging = _useSortable.isDragging, transform = _useSortable.transform, transition = _useSortable.transition; return /*#__PURE__*/_react["default"].createElement(SortableStyledItem, (0, _extends2["default"])({ ref: setNodeRef, className: (0, _classnames3["default"])((0, _defineProperty2["default"])({}, _constants.dataTestIds.sortableLayerItem, !disabled), (0, _defineProperty2["default"])({}, _constants.dataTestIds.staticLayerItem, disabled), { sorting: isDragging }), "data-testid": disabled ? _constants.dataTestIds.staticLayerItem : _constants.dataTestIds.sortableLayerItem, transform: _utilities.CSS.Transform.toString(transform), transition: transition }, attributes), /*#__PURE__*/_react["default"].createElement(LayerPanel, (0, _extends2["default"])({}, panelProps, layerActions, { key: layer.id, idx: idx, layer: layer, listeners: listeners, isDraggable: !disabled }))); }; var LayerList = function LayerList(props) { var layers = props.layers, datasets = props.datasets, layerOrder = props.layerOrder, uiStateActions = props.uiStateActions, visStateActions = props.visStateActions, mapStateActions = props.mapStateActions, layerClasses = props.layerClasses, _props$isSortable = props.isSortable, isSortable = _props$isSortable === void 0 ? true : _props$isSortable, splitMap = props.splitMap; var openModal = uiStateActions.toggleModal; var layersToShow = (0, _react.useMemo)(function () { return layerOrder.reduce(function (acc, layerId) { var layer = (0, _utils.findById)(layerId)(layers.filter(Boolean)); if (!layer) { return acc; } return !layer.config.hidden ? [].concat((0, _toConsumableArray2["default"])(acc), [layer]) : acc; }, INITIAL_LAYERS_TO_SHOW); }, [layers, layerOrder]); var sidePanelDndItems = (0, _react.useMemo)(function () { return layersToShow.map(function (_ref2) { var id = _ref2.id; return id; }); }, [layersToShow]); var layerTypeOptions = (0, _react.useMemo)(function () { return Object.keys(layerClasses).map(function (key) { var layer = new layerClasses[key]({ dataId: '' }); return { id: key, label: layer.name, icon: layer.layerIcon, requireData: layer.requireData }; }); }, [layerClasses]); var layerActions = (0, _react.useMemo)(function () { return { layerColorUIChange: visStateActions.layerColorUIChange, layerConfigChange: visStateActions.layerConfigChange, layerVisualChannelConfigChange: visStateActions.layerVisualChannelConfigChange, layerToggleVisibility: visStateActions.layerToggleVisibility, layerTypeChange: visStateActions.layerTypeChange, layerVisConfigChange: visStateActions.layerVisConfigChange, layerTextLabelChange: visStateActions.layerTextLabelChange, removeLayer: visStateActions.removeLayer, zoomToLayer: mapStateActions.fitBounds, duplicateLayer: visStateActions.duplicateLayer, layerSetIsValid: visStateActions.layerSetIsValid }; }, [visStateActions, mapStateActions]); var panelProps = (0, _react.useMemo)(function () { return { datasets: datasets, openModal: openModal, layerTypeOptions: layerTypeOptions, splitMap: splitMap }; }, [datasets, openModal, layerTypeOptions, splitMap]); return /*#__PURE__*/_react["default"].createElement(Container, null, /*#__PURE__*/_react["default"].createElement(_sortable.SortableContext, { id: _constants.SORTABLE_SIDE_PANEL_TYPE, items: sidePanelDndItems, strategy: _sortable.verticalListSortingStrategy, disabled: !isSortable }, layersToShow.map(function (layer) { return /*#__PURE__*/_react["default"].createElement(SortableItem, { key: layer.id, layer: layer, idx: layers.findIndex(function (l) { return (l === null || l === void 0 ? void 0 : l.id) === layer.id; }), panelProps: panelProps, layerActions: layerActions, disabled: !isSortable }); }))); }; return LayerList; } var _default = exports["default"] = LayerListFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_classnames3","_sortable","_utilities","_layerPanel","_utils","_constants","_templateObject","_templateObject2","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","Container","styled","div","_taggedTemplateLiteral2","SortableStyledItem","props","theme","dropdownWrapperZ","transition","transform","panelBackgroundHover","fontFamily","fontWeight","fontSize","lineHeight","textColorHl","INITIAL_LAYERS_TO_SHOW","LayerListFactory","deps","LayerPanelFactory","LayerPanel","SortableItem","_ref","layer","idx","panelProps","layerActions","disabled","_useSortable","useSortable","id","data","type","SORTABLE_LAYER_TYPE","parent","SORTABLE_SIDE_PANEL_TYPE","attributes","listeners","setNodeRef","isDragging","createElement","_extends2","ref","className","classnames","_defineProperty2","dataTestIds","sortableLayerItem","staticLayerItem","sorting","CSS","Transform","toString","key","isDraggable","LayerList","layers","datasets","layerOrder","uiStateActions","visStateActions","mapStateActions","layerClasses","_props$isSortable","isSortable","splitMap","openModal","toggleModal","layersToShow","useMemo","reduce","acc","layerId","findById","filter","Boolean","config","hidden","concat","_toConsumableArray2","sidePanelDndItems","map","_ref2","layerTypeOptions","keys","dataId","label","name","icon","layerIcon","requireData","layerColorUIChange","layerConfigChange","layerVisualChannelConfigChange","layerToggleVisibility","layerTypeChange","layerVisConfigChange","layerTextLabelChange","removeLayer","zoomToLayer","fitBounds","duplicateLayer","layerSetIsValid","SortableContext","items","strategy","verticalListSortingStrategy","findIndex","l","_default","exports"],"sources":["../../../src/side-panel/layer-panel/layer-list.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useMemo} from 'react';\nimport styled from 'styled-components';\nimport classnames from 'classnames';\n\nimport {Layer, LayerClassesType} from '@kepler.gl/layers';\nimport {Datasets} from '@kepler.gl/table';\nimport {UIStateActions, VisStateActions, MapStateActions} from '@kepler.gl/actions';\n\nimport {useSortable, SortableContext, verticalListSortingStrategy} from '@dnd-kit/sortable';\nimport {CSS} from '@dnd-kit/utilities';\nimport LayerPanelFactory from './layer-panel';\nimport {findById} from '@kepler.gl/utils';\nimport {dataTestIds, SORTABLE_LAYER_TYPE, SORTABLE_SIDE_PANEL_TYPE} from '@kepler.gl/constants';\nimport {SplitMap} from '@kepler.gl/types';\n\nexport type LayerListProps = {\n  datasets: Datasets;\n  layers: Layer[];\n  layerOrder: string[];\n  layerClasses: LayerClassesType;\n  isSortable?: boolean;\n  splitMap?: SplitMap;\n  uiStateActions: typeof UIStateActions;\n  visStateActions: typeof VisStateActions;\n  mapStateActions: typeof MapStateActions;\n};\n\nexport type LayerListFactoryDeps = [typeof LayerPanelFactory];\n\n// make sure the element is always visible while is being dragged\n// item being dragged is appended in body, here to reset its global style\n\nconst Container = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: 8px;\n`;\n\ninterface SortableStyledItemProps {\n  transition?: string;\n  transform?: string;\n}\n\nconst SortableStyledItem = styled.div<SortableStyledItemProps>`\n  z-index: ${props => props.theme.dropdownWrapperZ + 1};\n  transition: ${props => props.transition};\n  transform: ${props => props.transform};\n  &.sorting {\n    opacity: 0.3;\n    pointer-events: none;\n  }\n  &.sorting-layers .layer-panel__header {\n    background-color: ${props => props.theme.panelBackgroundHover};\n    font-family: ${props => props.theme.fontFamily};\n    font-weight: ${props => props.theme.fontWeight};\n    font-size: ${props => props.theme.fontSize};\n    line-height: ${props => props.theme.lineHeight};\n    *,\n    *:before,\n    *:after {\n      box-sizing: border-box;\n    }\n    .layer__drag-handle {\n      opacity: 1;\n      color: ${props => props.theme.textColorHl};\n    }\n  }\n`;\n\nconst INITIAL_LAYERS_TO_SHOW: Layer[] = [];\n\nLayerListFactory.deps = [LayerPanelFactory];\n\nfunction LayerListFactory(LayerPanel: ReturnType<typeof LayerPanelFactory>) {\n  // By wrapping layer panel using a sortable element we don't have to implement the drag and drop logic into the panel itself;\n  // Developers can provide any layer panel implementation and it will still be sortable\n  const SortableItem = ({layer, idx, panelProps, layerActions, disabled}) => {\n    const {attributes, listeners, setNodeRef, isDragging, transform, transition} = useSortable({\n      id: layer.id,\n      data: {\n        type: SORTABLE_LAYER_TYPE,\n        parent: SORTABLE_SIDE_PANEL_TYPE\n      },\n      disabled\n    });\n\n    return (\n      <SortableStyledItem\n        ref={setNodeRef}\n        className={classnames(\n          {[dataTestIds.sortableLayerItem]: !disabled},\n          {[dataTestIds.staticLayerItem]: disabled},\n          {sorting: isDragging}\n        )}\n        data-testid={disabled ? dataTestIds.staticLayerItem : dataTestIds.sortableLayerItem}\n        transform={CSS.Transform.toString(transform)}\n        transition={transition}\n        {...attributes}\n      >\n        <LayerPanel\n          {...panelProps}\n          {...layerActions}\n          key={layer.id}\n          idx={idx}\n          layer={layer}\n          listeners={listeners}\n          isDraggable={!disabled}\n        />\n      </SortableStyledItem>\n    );\n  };\n\n  const LayerList: React.FC<LayerListProps> = props => {\n    const {\n      layers,\n      datasets,\n      layerOrder,\n      uiStateActions,\n      visStateActions,\n      mapStateActions,\n      layerClasses,\n      isSortable = true,\n      splitMap\n    } = props;\n    const {toggleModal: openModal} = uiStateActions;\n\n    const layersToShow = useMemo(() => {\n      return layerOrder.reduce((acc, layerId) => {\n        const layer = findById(layerId)(layers.filter(Boolean));\n        if (!layer) {\n          return acc;\n        }\n        return !layer.config.hidden ? [...acc, layer] : acc;\n      }, INITIAL_LAYERS_TO_SHOW);\n    }, [layers, layerOrder]);\n\n    const sidePanelDndItems = useMemo(() => {\n      return layersToShow.map(({id}) => id);\n    }, [layersToShow]);\n\n    const layerTypeOptions = useMemo(\n      () =>\n        Object.keys(layerClasses).map(key => {\n          const layer = new layerClasses[key]({dataId: ''});\n          return {\n            id: key,\n            label: layer.name,\n            icon: layer.layerIcon,\n            requireData: layer.requireData\n          };\n        }),\n      [layerClasses]\n    );\n\n    const layerActions = useMemo(\n      () => ({\n        layerColorUIChange: visStateActions.layerColorUIChange,\n        layerConfigChange: visStateActions.layerConfigChange,\n        layerVisualChannelConfigChange: visStateActions.layerVisualChannelConfigChange,\n        layerToggleVisibility: visStateActions.layerToggleVisibility,\n        layerTypeChange: visStateActions.layerTypeChange,\n        layerVisConfigChange: visStateActions.layerVisConfigChange,\n        layerTextLabelChange: visStateActions.layerTextLabelChange,\n        removeLayer: visStateActions.removeLayer,\n        zoomToLayer: mapStateActions.fitBounds,\n        duplicateLayer: visStateActions.duplicateLayer,\n        layerSetIsValid: visStateActions.layerSetIsValid\n      }),\n      [visStateActions, mapStateActions]\n    );\n\n    const panelProps = useMemo(\n      () => ({\n        datasets,\n        openModal,\n        layerTypeOptions,\n        splitMap\n      }),\n      [datasets, openModal, layerTypeOptions, splitMap]\n    );\n\n    return (\n      <Container>\n        <SortableContext\n          id={SORTABLE_SIDE_PANEL_TYPE}\n          items={sidePanelDndItems}\n          strategy={verticalListSortingStrategy}\n          disabled={!isSortable}\n        >\n          {/* warning: containerId should be similar to the first key in dndItems defined in kepler-gl.js*/}\n          {layersToShow.map(layer => (\n            <SortableItem\n              key={layer.id}\n              layer={layer}\n              idx={layers.findIndex(l => l?.id === layer.id)}\n              panelProps={panelProps}\n              layerActions={layerActions}\n              disabled={!isSortable}\n            />\n          ))}\n        </SortableContext>\n      </Container>\n    );\n  };\n  return LayerList;\n}\nexport default LayerListFactory;\n"],"mappings":"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","ignoreList":[]}