kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
124 lines (123 loc) • 20.9 kB
JavaScript
"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 _constants = require("@kepler.gl/constants");
var _reducers = require("@kepler.gl/reducers");
var _layerPanelHeader = _interopRequireDefault(require("./side-panel/layer-panel/layer-panel-header"));
var _injector = require("./injector");
var _useDndLayers2 = _interopRequireDefault(require("./hooks/use-dnd-layers"));
var _useDndEffects2 = _interopRequireDefault(require("./hooks/use-dnd-effects"));
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 ? _constants.DND_EMPTY_MODIFIERS : _constants.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 _constants.SORTABLE_LAYER_TYPE:
onLayerDragStart(event);
break;
case _constants.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 _constants.SORTABLE_LAYER_TYPE:
onLayerDragEnd(event);
break;
case _constants.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 (0, _injector.withState)([_reducers.visStateLens], function (state) {
return state;
})(DndContext);
}
var _default = exports["default"] = DndContextFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_core","_console","_constants","_reducers","_layerPanelHeader","_injector","_useDndLayers2","_useDndEffects2","_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","withState","visStateLens","state","_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';\nimport Console from 'global/console';\n\nimport {\n  DND_EMPTY_MODIFIERS,\n  DND_MODIFIERS,\n  SORTABLE_LAYER_TYPE,\n  SORTABLE_EFFECT_TYPE\n} from '@kepler.gl/constants';\nimport {visStateLens} from '@kepler.gl/reducers';\nimport {VisState} from '@kepler.gl/schemas';\n\nimport LayerPanelHeaderFactory from './side-panel/layer-panel/layer-panel-header';\nimport {withState} from './injector';\nimport useDndLayers from './hooks/use-dnd-layers';\nimport useDndEffects from './hooks/use-dnd-effects';\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<PropsWithChildren> {\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 withState([visStateLens], state => state)(DndContext) as React.FC<PropsWithChildren>;\n}\n\nexport default DndContextFactory;\n"],"mappings":"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","ignoreList":[]}