UNPKG

kepler.gl

Version:

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

120 lines (119 loc) 20.3 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.DragItem = void 0; var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _core = require("@dnd-kit/core"); var _console = _interopRequireDefault(require("global/console")); var _layerPanelHeader = _interopRequireDefault(require("./side-panel/layer-panel/layer-panel-header")); var _useDndLayers2 = _interopRequireDefault(require("./hooks/use-dnd-layers")); var _useDndEffects2 = _interopRequireDefault(require("./hooks/use-dnd-effects")); var _dndLayerItems = require("./common/dnd-layer-items"); var _templateObject; // 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; } var DragItem = exports.DragItem = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n border-radius: ", "px;\n padding: 5px 10px;\n display: inline;\n"])), function (props) { return props.theme.textColorHl; }, function (props) { return props.theme.radioButtonRadius; }); var nop = function nop() { return undefined; }; DndContextFactory.deps = [_layerPanelHeader["default"]]; function DndContextFactory(LayerPanelHeader) { var LayerPanelOverlay = function LayerPanelOverlay(_ref) { var layer = _ref.layer, datasets = _ref.datasets; var color = layer.config.dataId && datasets[layer.config.dataId] ? datasets[layer.config.dataId].color : null; return /*#__PURE__*/_react["default"].createElement(LayerPanelHeader, { isConfigActive: false, layerId: layer.id, isVisible: true, isValid: true, label: layer.config.label, labelRCGColorValues: color, onToggleVisibility: nop, onResetIsValid: nop, onUpdateLayerLabel: nop, onToggleEnableConfig: nop, onDuplicateLayer: nop, onRemoveLayer: nop, onZoomToLayer: nop, layerType: layer.type, allowDuplicate: false, isDragNDropEnabled: false }); }; var DndContext = function DndContext(_ref2) { var children = _ref2.children, visState = _ref2.visState; var datasets = visState.datasets, layerOrder = visState.layerOrder, layers = visState.layers, effects = visState.effects, effectOrder = visState.effectOrder, splitMaps = visState.splitMaps; var _useDndLayers = (0, _useDndLayers2["default"])(layers, layerOrder), activeLayer = _useDndLayers.activeLayer, onLayerDragStart = _useDndLayers.onDragStart, onLayerDragEnd = _useDndLayers.onDragEnd; var _useDndEffects = (0, _useDndEffects2["default"])(effects, effectOrder), onEffectDragStart = _useDndEffects.onDragStart, onEffectDragEnd = _useDndEffects.onDragEnd; var isSplit = (0, _react.useMemo)(function () { return (splitMaps === null || splitMaps === void 0 ? void 0 : splitMaps.length) > 1; }, [splitMaps]); var dndModifiers = (0, _react.useMemo)(function () { return isSplit ? _dndLayerItems.DND_EMPTY_MODIFIERS : _dndLayerItems.DND_MODIFIERS; }, [isSplit]); var onDragStart = (0, _react.useCallback)(function (event) { var _event$active$data; var activeType = (_event$active$data = event.active.data) === null || _event$active$data === void 0 || (_event$active$data = _event$active$data.current) === null || _event$active$data === void 0 ? void 0 : _event$active$data.type; switch (activeType) { case _dndLayerItems.SORTABLE_LAYER_TYPE: onLayerDragStart(event); break; case _dndLayerItems.SORTABLE_EFFECT_TYPE: onEffectDragStart(event); break; default: _console["default"].log("activeType ".concat(activeType, " unknown")); } }, [onLayerDragStart, onEffectDragStart]); var onDragEnd = (0, _react.useCallback)(function (event) { var _event$active$data2; var activeType = (_event$active$data2 = event.active.data) === null || _event$active$data2 === void 0 || (_event$active$data2 = _event$active$data2.current) === null || _event$active$data2 === void 0 ? void 0 : _event$active$data2.type; switch (activeType) { case _dndLayerItems.SORTABLE_LAYER_TYPE: onLayerDragEnd(event); break; case _dndLayerItems.SORTABLE_EFFECT_TYPE: onEffectDragEnd(event); break; default: _console["default"].log("activeType ".concat(activeType, " unknown")); } }, [onLayerDragEnd, onEffectDragEnd]); return /*#__PURE__*/_react["default"].createElement(_core.DndContext, { onDragStart: onDragStart, onDragEnd: onDragEnd, modifiers: dndModifiers }, children, activeLayer ? /*#__PURE__*/_react["default"].createElement(_core.DragOverlay, { modifiers: dndModifiers, dropAnimation: null }, /*#__PURE__*/_react["default"].createElement(DragItem, null, /*#__PURE__*/_react["default"].createElement(LayerPanelOverlay, { layer: activeLayer, datasets: datasets }))) : null); }; return DndContext; } var _default = exports["default"] = DndContextFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_core","_console","_layerPanelHeader","_useDndLayers2","_useDndEffects2","_dndLayerItems","_templateObject","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","DragItem","exports","styled","div","_taggedTemplateLiteral2","props","theme","textColorHl","radioButtonRadius","nop","undefined","DndContextFactory","deps","LayerPanelHeaderFactory","LayerPanelHeader","LayerPanelOverlay","_ref","layer","datasets","color","config","dataId","createElement","isConfigActive","layerId","id","isVisible","isValid","label","labelRCGColorValues","onToggleVisibility","onResetIsValid","onUpdateLayerLabel","onToggleEnableConfig","onDuplicateLayer","onRemoveLayer","onZoomToLayer","layerType","type","allowDuplicate","isDragNDropEnabled","DndContext","_ref2","children","visState","layerOrder","layers","effects","effectOrder","splitMaps","_useDndLayers","useDndLayers","activeLayer","onLayerDragStart","onDragStart","onLayerDragEnd","onDragEnd","_useDndEffects","useDndEffects","onEffectDragStart","onEffectDragEnd","isSplit","useMemo","length","dndModifiers","DND_EMPTY_MODIFIERS","DND_MODIFIERS","useCallback","event","_event$active$data","activeType","active","data","current","SORTABLE_LAYER_TYPE","SORTABLE_EFFECT_TYPE","Console","log","concat","_event$active$data2","modifiers","DragOverlay","dropAnimation","_default"],"sources":["../src/dnd-context.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useMemo, PropsWithChildren} from 'react';\nimport styled from 'styled-components';\nimport {DndContext as DndKitContext, DragOverlay} from '@dnd-kit/core';\n\nimport Console from 'global/console';\nimport {VisState} from '@kepler.gl/schemas';\n\nimport LayerPanelHeaderFactory from './side-panel/layer-panel/layer-panel-header';\nimport useDndLayers from './hooks/use-dnd-layers';\nimport useDndEffects from './hooks/use-dnd-effects';\n\nimport {\n  DND_MODIFIERS,\n  DND_EMPTY_MODIFIERS,\n  SORTABLE_LAYER_TYPE,\n  SORTABLE_EFFECT_TYPE\n} from './common/dnd-layer-items';\n\nexport type DndContextProps = PropsWithChildren<{\n  visState: VisState;\n}>;\n\nexport type DndContextComponent = React.FC<DndContextProps>;\n\nexport const DragItem = styled.div`\n  color: ${props => props.theme.textColorHl};\n  border-radius: ${props => props.theme.radioButtonRadius}px;\n  padding: 5px 10px;\n  display: inline;\n`;\n\nconst nop = () => undefined;\n\nDndContextFactory.deps = [LayerPanelHeaderFactory];\n\nfunction DndContextFactory(\n  LayerPanelHeader: ReturnType<typeof LayerPanelHeaderFactory>\n): React.FC<DndContextProps> {\n  const LayerPanelOverlay = ({layer, datasets}) => {\n    const color =\n      layer.config.dataId && datasets[layer.config.dataId]\n        ? datasets[layer.config.dataId].color\n        : null;\n    return (\n      <LayerPanelHeader\n        isConfigActive={false}\n        layerId={layer.id}\n        isVisible={true}\n        isValid={true}\n        label={layer.config.label}\n        labelRCGColorValues={color}\n        onToggleVisibility={nop}\n        onResetIsValid={nop}\n        onUpdateLayerLabel={nop}\n        onToggleEnableConfig={nop}\n        onDuplicateLayer={nop}\n        onRemoveLayer={nop}\n        onZoomToLayer={nop}\n        layerType={layer.type}\n        allowDuplicate={false}\n        isDragNDropEnabled={false}\n      />\n    );\n  };\n\n  const DndContext = ({children, visState}: DndContextProps) => {\n    const {datasets, layerOrder, layers, effects, effectOrder, splitMaps} = visState;\n\n    const {\n      activeLayer,\n      onDragStart: onLayerDragStart,\n      onDragEnd: onLayerDragEnd\n    } = useDndLayers(layers, layerOrder);\n    const {onDragStart: onEffectDragStart, onDragEnd: onEffectDragEnd} = useDndEffects(\n      effects,\n      effectOrder\n    );\n\n    const isSplit = useMemo(() => splitMaps?.length > 1, [splitMaps]);\n    const dndModifiers = useMemo(() => (isSplit ? DND_EMPTY_MODIFIERS : DND_MODIFIERS), [isSplit]);\n\n    const onDragStart = useCallback(\n      event => {\n        const activeType = event.active.data?.current?.type;\n        switch (activeType) {\n          case SORTABLE_LAYER_TYPE:\n            onLayerDragStart(event);\n            break;\n          case SORTABLE_EFFECT_TYPE:\n            onEffectDragStart(event);\n            break;\n          default:\n            Console.log(`activeType ${activeType} unknown`);\n        }\n      },\n      [onLayerDragStart, onEffectDragStart]\n    );\n\n    const onDragEnd = useCallback(\n      event => {\n        const activeType = event.active.data?.current?.type;\n        switch (activeType) {\n          case SORTABLE_LAYER_TYPE:\n            onLayerDragEnd(event);\n            break;\n          case SORTABLE_EFFECT_TYPE:\n            onEffectDragEnd(event);\n            break;\n          default:\n            Console.log(`activeType ${activeType} unknown`);\n        }\n      },\n      [onLayerDragEnd, onEffectDragEnd]\n    );\n\n    return (\n      <DndKitContext onDragStart={onDragStart} onDragEnd={onDragEnd} modifiers={dndModifiers}>\n        {children}\n        {activeLayer ? (\n          <DragOverlay modifiers={dndModifiers} dropAnimation={null}>\n            <DragItem>\n              <LayerPanelOverlay layer={activeLayer} datasets={datasets} />\n            </DragItem>\n          </DragOverlay>\n        ) : null}\n      </DndKitContext>\n    );\n  };\n\n  return DndContext;\n}\n\nexport default DndContextFactory;\n"],"mappings":"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","ignoreList":[]}