UNPKG

kepler.gl

Version:

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

130 lines (129 loc) 21.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 _utilities = require("@dnd-kit/utilities"); var _sortable = require("@dnd-kit/sortable"); var _constants = require("@kepler.gl/constants"); var _utils = require("@kepler.gl/utils"); var _dndLayerItems = require("../common/dnd-layer-items"); var _effectPanel = _interopRequireDefault(require("./effect-panel")); 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; } var Container = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n"]))); var SortableStyledItem = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n z-index: ", ";\n transition: ", ";\n transform: ", ";\n outline: none;\n &.sorting {\n opacity: 0.3;\n pointer-events: none;\n }\n &.sorting-effects .effect-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 .effect__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; }); EffectListFactory.deps = [_effectPanel["default"]]; function EffectListFactory(EffectPanel) { var SortableItem = function SortableItem(_ref) { var effect = _ref.effect, idx = _ref.idx, panelProps = _ref.panelProps, disabled = _ref.disabled; var _useSortable = (0, _sortable.useSortable)({ id: effect.id, data: { type: _dndLayerItems.SORTABLE_EFFECT_TYPE, parent: _dndLayerItems.SORTABLE_EFFECT_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.sortableEffectItem, !disabled), (0, _defineProperty2["default"])({}, _constants.dataTestIds.staticEffectItem, disabled), { sorting: isDragging }), "data-testid": disabled ? _constants.dataTestIds.staticEffectItem : _constants.dataTestIds.sortableEffectItem, transform: _utilities.CSS.Transform.toString(transform), transition: transition || '' }, attributes), /*#__PURE__*/_react["default"].createElement(EffectPanel, (0, _extends2["default"])({}, panelProps, { key: effect.id, idx: idx, effect: effect, listeners: listeners, isDraggable: !disabled }))); }; var EffectList = function EffectList(props) { var effects = props.effects, effectOrder = props.effectOrder, visStateActions = props.visStateActions; var effectsToShow = (0, _react.useMemo)(function () { return effectOrder.reduce(function (acc, effectId) { var effect = (0, _utils.findById)(effectId)(effects.filter(Boolean)); if (!effect) { return acc; } return [].concat((0, _toConsumableArray2["default"])(acc), [effect]); }, []); }, [effects, effectOrder]); var sidePanelDndItems = (0, _react.useMemo)(function () { return effectsToShow.map(function (_ref2) { var id = _ref2.id; return id; }); }, [effectsToShow]); var panelProps = (0, _react.useMemo)(function () { return { effects: effects, effectOrder: effectOrder, removeEffect: visStateActions.removeEffect, updateEffect: visStateActions.updateEffect }; }, [effects, effectOrder, visStateActions]); return /*#__PURE__*/_react["default"].createElement(Container, null, /*#__PURE__*/_react["default"].createElement(_sortable.SortableContext, { id: _dndLayerItems.SORTABLE_EFFECT_PANEL_TYPE, items: sidePanelDndItems, strategy: _sortable.verticalListSortingStrategy, disabled: false }, effectsToShow.map(function (effect) { return /*#__PURE__*/_react["default"].createElement(SortableItem, { key: effect.id, effect: effect, idx: effects.findIndex(function (l) { return (l === null || l === void 0 ? void 0 : l.id) === effect.id; }), panelProps: panelProps, disabled: false }); }))); }; return EffectList; } var _default = exports["default"] = EffectListFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_classnames3","_utilities","_sortable","_constants","_utils","_dndLayerItems","_effectPanel","_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","EffectListFactory","deps","EffectPanelFactory","EffectPanel","SortableItem","_ref","effect","idx","panelProps","disabled","_useSortable","useSortable","id","data","type","SORTABLE_EFFECT_TYPE","parent","SORTABLE_EFFECT_PANEL_TYPE","attributes","listeners","setNodeRef","isDragging","createElement","_extends2","ref","className","classnames","_defineProperty2","dataTestIds","sortableEffectItem","staticEffectItem","sorting","CSS","Transform","toString","key","isDraggable","EffectList","effects","effectOrder","visStateActions","effectsToShow","useMemo","reduce","acc","effectId","findById","filter","Boolean","concat","_toConsumableArray2","sidePanelDndItems","map","_ref2","removeEffect","updateEffect","SortableContext","items","strategy","verticalListSortingStrategy","findIndex","l","_default","exports"],"sources":["../../src/effects/effect-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';\nimport {CSS} from '@dnd-kit/utilities';\nimport {useSortable, SortableContext, verticalListSortingStrategy} from '@dnd-kit/sortable';\n\nimport {dataTestIds} from '@kepler.gl/constants';\nimport {findById} from '@kepler.gl/utils';\nimport {Effect} from '@kepler.gl/types';\nimport {\n  addEffect,\n  updateEffect,\n  removeEffect,\n  reorderEffect,\n  ActionHandler\n} from '@kepler.gl/actions';\n\nimport {SORTABLE_EFFECT_TYPE, SORTABLE_EFFECT_PANEL_TYPE} from '../common/dnd-layer-items';\nimport EffectPanelFactory from './effect-panel';\n\nexport type EffectListProps = {\n  effects: Effect[];\n  effectOrder: string[];\n  visStateActions: {\n    addEffect: ActionHandler<typeof addEffect>;\n    updateEffect: ActionHandler<typeof updateEffect>;\n    removeEffect: ActionHandler<typeof removeEffect>;\n    reorderEffect: ActionHandler<typeof reorderEffect>;\n  };\n  isSortable: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  flex-direction: column;\n`;\n\ntype SortableStyledItemProps = {transition?: string; transform?: string};\nconst SortableStyledItem = styled.div<SortableStyledItemProps>`\n  z-index: ${props => props.theme.dropdownWrapperZ + 1};\n  transition: ${props => props.transition};\n  transform: ${props => props.transform};\n  outline: none;\n  &.sorting {\n    opacity: 0.3;\n    pointer-events: none;\n  }\n  &.sorting-effects .effect-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    .effect__drag-handle {\n      opacity: 1;\n      color: ${props => props.theme.textColorHl};\n    }\n  }\n`;\n\nEffectListFactory.deps = [EffectPanelFactory];\n\nfunction EffectListFactory(\n  EffectPanel: ReturnType<typeof EffectPanelFactory>\n): React.FC<EffectListProps> {\n  const SortableItem = ({effect, idx, panelProps, disabled}) => {\n    const {attributes, listeners, setNodeRef, isDragging, transform, transition} = useSortable({\n      id: effect.id,\n      data: {\n        type: SORTABLE_EFFECT_TYPE,\n        parent: SORTABLE_EFFECT_PANEL_TYPE\n      },\n      disabled\n    });\n\n    return (\n      <SortableStyledItem\n        ref={setNodeRef}\n        className={classnames(\n          {[dataTestIds.sortableEffectItem]: !disabled},\n          {[dataTestIds.staticEffectItem]: disabled},\n          {sorting: isDragging}\n        )}\n        data-testid={disabled ? dataTestIds.staticEffectItem : dataTestIds.sortableEffectItem}\n        transform={CSS.Transform.toString(transform)}\n        transition={transition || ''}\n        {...attributes}\n      >\n        <EffectPanel\n          {...panelProps}\n          key={effect.id}\n          idx={idx}\n          effect={effect}\n          listeners={listeners}\n          isDraggable={!disabled}\n        />\n      </SortableStyledItem>\n    );\n  };\n\n  const EffectList = (props: EffectListProps) => {\n    const {effects, effectOrder, visStateActions} = props;\n\n    const effectsToShow = useMemo(() => {\n      return effectOrder.reduce((acc, effectId) => {\n        const effect = findById(effectId)(effects.filter(Boolean));\n        if (!effect) {\n          return acc;\n        }\n        return [...acc, effect];\n      }, [] as Effect[]);\n    }, [effects, effectOrder]);\n\n    const sidePanelDndItems = useMemo(() => {\n      return effectsToShow.map(({id}) => id);\n    }, [effectsToShow]);\n\n    const panelProps = useMemo(\n      () => ({\n        effects,\n        effectOrder,\n        removeEffect: visStateActions.removeEffect,\n        updateEffect: visStateActions.updateEffect\n      }),\n      [effects, effectOrder, visStateActions]\n    );\n\n    return (\n      <Container>\n        <SortableContext\n          id={SORTABLE_EFFECT_PANEL_TYPE}\n          items={sidePanelDndItems}\n          strategy={verticalListSortingStrategy}\n          disabled={false}\n        >\n          {effectsToShow.map(effect => (\n            <SortableItem\n              key={effect.id}\n              effect={effect}\n              idx={effects.findIndex(l => l?.id === effect.id)}\n              panelProps={panelProps}\n              disabled={false}\n            />\n          ))}\n        </SortableContext>\n      </Container>\n    );\n  };\n  return EffectList;\n}\n\nexport default EffectListFactory;\n"],"mappings":"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","ignoreList":[]}