kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
172 lines (170 loc) • 28.8 kB
JavaScript
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 _dndLayerItems = require("../../common/dnd-layer-items");
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 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.$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: _dndLayerItems.SORTABLE_LAYER_TYPE,
parent: _dndLayerItems.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: _dndLayerItems.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","_dndLayerItems","_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","$transition","$transform","theme","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","transform","transition","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} from '@kepler.gl/constants';\nimport {SplitMap} from '@kepler.gl/types';\nimport {SORTABLE_LAYER_TYPE, SORTABLE_SIDE_PANEL_TYPE} from '../../common/dnd-layer-items';\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  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":[]}
;