UNPKG

kepler.gl

Version:

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

127 lines (124 loc) 26.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"] = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _reactIntl = require("react-intl"); var _actions = require("@kepler.gl/actions"); var _constants = require("@kepler.gl/constants"); var _reducers = require("@kepler.gl/reducers"); var _injector = require("../injector"); var _sidePanelTitle = _interopRequireDefault(require("./side-panel-title")); var _effectList = _interopRequireDefault(require("./effect-list")); var _effectTypeSelector = _interopRequireDefault(require("./effect-type-selector")); var _templateObject, _templateObject2, _templateObject3, _templateObject4; // 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; } function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } var StyledEffectPanelContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n pointer-events: none !important; /* prevent padding from blocking input */\n flex-grow: 1;\n justify-content: space-between;\n overflow: hidden;\n\n & > * {\n /* all children should allow input */\n pointer-events: all;\n }\n"]))); // top right position absolute var StyledEffectPanel = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n top: 0;\n background-color: ", ";\n display: flex;\n flex-direction: column;\n flex-grow: 1;\n overflow: hidden;\n"])), function (props) { return props.theme.sidePanelBg; }); var StyledEffectPanelHeader = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n padding: ", ";\n border-bottom: 1px solid ", ";\n min-width: ", "px;\n"])), function (_ref) { var theme = _ref.theme; return "".concat(theme.effectPanelPaddingTop, "px ").concat(theme.effectPanelPaddingSide, "px 4px ").concat(theme.effectPanelPaddingSide, "px"); }, function (props) { return props.theme.borderColor; }, function (_ref2) { var theme = _ref2.theme; return theme.effectPanelWidth; }); var StyledEffectPanelContent = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n ", ";\n padding: ", ";\n overflow: overlay;\n display: flex;\n flex-direction: column;\n"])), function (props) { return props.theme.sidePanelScrollBar; }, function (props) { return props.extended ? '32px' : '10px 0px 10px 0px'; }); EffectManagerFactory.deps = [_effectList["default"], _sidePanelTitle["default"], _effectTypeSelector["default"]]; function EffectManagerFactory(EffectList, SidePanelTitle, EffectTypeSelector) { var EffectManager = function EffectManager(props) { var intl = props.intl, visStateActions = props.visStateActions, visState = props.visState, children = props.children; var effects = visState.effects, effectOrder = visState.effectOrder; var visStateAddEffect = visStateActions.addEffect; var _useState = (0, _react.useState)(false), _useState2 = (0, _slicedToArray2["default"])(_useState, 2), typeSelectorOpened = _useState2[0], setTypeSelectorOpened = _useState2[1]; // Prevent shadow effect from being added multiple times var effectOptions = (0, _react.useMemo)(function () { var hasShadow = effects.some(function (effect) { return effect.type === _constants.LIGHT_AND_SHADOW_EFFECT.type; }); var hasDistanceFog = effects.some(function (effect) { return effect.type === _constants.DISTANCE_FOG_TYPE; }); var hasSurfaceFog = effects.some(function (effect) { return effect.type === _constants.SURFACE_FOG_TYPE; }); var hasAnyFog = hasDistanceFog || hasSurfaceFog; return _constants.EFFECT_DESCRIPTIONS.map(function (desc) { return _objectSpread(_objectSpread({}, desc), {}, { disabled: Boolean(hasShadow && desc.type === _constants.LIGHT_AND_SHADOW_EFFECT.type || hasAnyFog && (desc.type === _constants.DISTANCE_FOG_TYPE || desc.type === _constants.SURFACE_FOG_TYPE)) }); }); }, [effects]); var onAddEffect = (0, _react.useCallback)(function (type) { visStateAddEffect({ type: type }); }, [visStateAddEffect]); var onTypeSelectOpen = (0, _react.useCallback)(function () { setTypeSelectorOpened(true); }, []); var onTypeSelectClose = (0, _react.useCallback)(function () { setTypeSelectorOpened(false); }, []); return /*#__PURE__*/_react["default"].createElement(StyledEffectPanelContainer, { className: "effect-manager" }, /*#__PURE__*/_react["default"].createElement(StyledEffectPanel, null, /*#__PURE__*/_react["default"].createElement(StyledEffectPanelHeader, { className: "effect-panel-header" }, /*#__PURE__*/_react["default"].createElement(SidePanelTitle, { className: "effect-manager-title", title: intl.formatMessage({ id: 'effectManager.effects' }) }, /*#__PURE__*/_react["default"].createElement(EffectTypeSelector, { options: effectOptions, onSelect: onAddEffect, onOpen: onTypeSelectOpen, onBlur: onTypeSelectClose }))), /*#__PURE__*/_react["default"].createElement(StyledEffectPanelContent, { extended: typeSelectorOpened && effects.length === 0 }, /*#__PURE__*/_react["default"].createElement(EffectList, { effects: effects, effectOrder: effectOrder, visStateActions: visStateActions, isSortable: true }))), children); }; return (0, _injector.withState)([_reducers.visStateLens], function (state) { return state; }, { visStateActions: { addEffect: _actions.addEffect, updateEffect: _actions.updateEffect, removeEffect: _actions.removeEffect, reorderEffect: _actions.reorderEffect } })((0, _reactIntl.injectIntl)(EffectManager)); } var _default = exports["default"] = EffectManagerFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_reactIntl","_actions","_constants","_reducers","_injector","_sidePanelTitle","_effectList","_effectTypeSelector","_templateObject","_templateObject2","_templateObject3","_templateObject4","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","StyledEffectPanelContainer","styled","div","_taggedTemplateLiteral2","StyledEffectPanel","props","theme","sidePanelBg","StyledEffectPanelHeader","_ref","concat","effectPanelPaddingTop","effectPanelPaddingSide","borderColor","_ref2","effectPanelWidth","StyledEffectPanelContent","sidePanelScrollBar","extended","EffectManagerFactory","deps","EffectListFactory","SidePanelTitleFactory","EffectTypeSelectorFactory","EffectList","SidePanelTitle","EffectTypeSelector","EffectManager","intl","visStateActions","visState","children","effects","effectOrder","visStateAddEffect","addEffect","_useState","useState","_useState2","_slicedToArray2","typeSelectorOpened","setTypeSelectorOpened","effectOptions","useMemo","hasShadow","some","effect","type","LIGHT_AND_SHADOW_EFFECT","hasDistanceFog","DISTANCE_FOG_TYPE","hasSurfaceFog","SURFACE_FOG_TYPE","hasAnyFog","EFFECT_DESCRIPTIONS","map","desc","disabled","Boolean","onAddEffect","useCallback","onTypeSelectOpen","onTypeSelectClose","createElement","className","title","formatMessage","id","options","onSelect","onOpen","onBlur","isSortable","withState","visStateLens","state","updateEffect","removeEffect","reorderEffect","injectIntl","_default","exports"],"sources":["../../src/effects/effect-manager.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useMemo, useState, useCallback} from 'react';\nimport styled from 'styled-components';\nimport {injectIntl, IntlShape} from 'react-intl';\n\nimport {\n  addEffect,\n  updateEffect,\n  removeEffect,\n  reorderEffect,\n  ActionHandler\n} from '@kepler.gl/actions';\nimport {\n  LIGHT_AND_SHADOW_EFFECT,\n  EFFECT_DESCRIPTIONS,\n  DISTANCE_FOG_TYPE,\n  SURFACE_FOG_TYPE\n} from '@kepler.gl/constants';\nimport {visStateLens} from '@kepler.gl/reducers';\nimport {Effect} from '@kepler.gl/types';\nimport {VisState} from '@kepler.gl/schemas';\n\nimport {withState} from '../injector';\nimport SidePanelTitleFactory from './side-panel-title';\nimport EffectListFactory from './effect-list';\nimport EffectTypeSelectorFactory, {EffectTypeSelectorProps} from './effect-type-selector';\n\nexport type EffectManagerState = {\n  visState: VisState;\n  visStateActions: {\n    addEffect: ActionHandler<typeof addEffect>;\n    updateEffect: ActionHandler<typeof updateEffect>;\n    removeEffect: ActionHandler<typeof removeEffect>;\n    reorderEffect: ActionHandler<typeof reorderEffect>;\n  };\n  effects: Effect[];\n  effectOrder: string[];\n  children: React.ReactNode;\n};\nexport type EffectManagerProps = EffectManagerWithIntlProp & EffectManagerState;\n\nexport type EffectManagerWithIntlProp = {intl: IntlShape};\n\nconst StyledEffectPanelContainer = styled.div`\n  display: flex;\n  flex-direction: column;\n  pointer-events: none !important; /* prevent padding from blocking input */\n  flex-grow: 1;\n  justify-content: space-between;\n  overflow: hidden;\n\n  & > * {\n    /* all children should allow input */\n    pointer-events: all;\n  }\n`;\n\n// top right position absolute\nconst StyledEffectPanel = styled.div`\n  top: 0;\n  background-color: ${props => props.theme.sidePanelBg};\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n  overflow: hidden;\n`;\n\nconst StyledEffectPanelHeader = styled.div`\n  padding: ${({theme}) =>\n    `${theme.effectPanelPaddingTop}px ${theme.effectPanelPaddingSide}px 4px ${theme.effectPanelPaddingSide}px`};\n  border-bottom: 1px solid ${props => props.theme.borderColor};\n  min-width: ${({theme}) => theme.effectPanelWidth}px;\n`;\n\ntype StyledEffectPanelContentProps = {\n  extended?: boolean;\n};\nconst StyledEffectPanelContent = styled.div<StyledEffectPanelContentProps>`\n  ${props => props.theme.sidePanelScrollBar};\n  padding: ${props => (props.extended ? '32px' : '10px 0px 10px 0px')};\n  overflow: overlay;\n  display: flex;\n  flex-direction: column;\n`;\n\nEffectManagerFactory.deps = [EffectListFactory, SidePanelTitleFactory, EffectTypeSelectorFactory];\n\nfunction EffectManagerFactory(\n  EffectList: ReturnType<typeof EffectListFactory>,\n  SidePanelTitle: ReturnType<typeof SidePanelTitleFactory>,\n  EffectTypeSelector: ReturnType<typeof EffectTypeSelectorFactory>\n): React.FC<EffectManagerProps> {\n  const EffectManager = (props: EffectManagerWithIntlProp & EffectManagerState) => {\n    const {intl, visStateActions, visState, children} = props;\n    const {effects, effectOrder} = visState;\n    const {addEffect: visStateAddEffect} = visStateActions;\n    const [typeSelectorOpened, setTypeSelectorOpened] = useState(false);\n\n    // Prevent shadow effect from being added multiple times\n    const effectOptions: EffectTypeSelectorProps['options'] = useMemo(() => {\n      const hasShadow = effects.some(effect => {\n        return effect.type === LIGHT_AND_SHADOW_EFFECT.type;\n      });\n      const hasDistanceFog = effects.some(effect => {\n        return effect.type === DISTANCE_FOG_TYPE;\n      });\n      const hasSurfaceFog = effects.some(effect => {\n        return effect.type === SURFACE_FOG_TYPE;\n      });\n      const hasAnyFog = hasDistanceFog || hasSurfaceFog;\n\n      return EFFECT_DESCRIPTIONS.map(desc => {\n        return {\n          ...desc,\n          disabled: Boolean(\n            (hasShadow && desc.type === LIGHT_AND_SHADOW_EFFECT.type) ||\n              (hasAnyFog && (desc.type === DISTANCE_FOG_TYPE || desc.type === SURFACE_FOG_TYPE))\n          )\n        };\n      });\n    }, [effects]);\n\n    const onAddEffect = useCallback(\n      type => {\n        visStateAddEffect({type});\n      },\n      [visStateAddEffect]\n    );\n\n    const onTypeSelectOpen = useCallback(() => {\n      setTypeSelectorOpened(true);\n    }, []);\n\n    const onTypeSelectClose = useCallback(() => {\n      setTypeSelectorOpened(false);\n    }, []);\n\n    return (\n      <StyledEffectPanelContainer className=\"effect-manager\">\n        <StyledEffectPanel>\n          <StyledEffectPanelHeader className=\"effect-panel-header\">\n            <SidePanelTitle\n              className=\"effect-manager-title\"\n              title={intl.formatMessage({id: 'effectManager.effects'})}\n            >\n              <EffectTypeSelector\n                options={effectOptions}\n                onSelect={onAddEffect}\n                onOpen={onTypeSelectOpen}\n                onBlur={onTypeSelectClose}\n              />\n            </SidePanelTitle>\n          </StyledEffectPanelHeader>\n\n          <StyledEffectPanelContent extended={typeSelectorOpened && effects.length === 0}>\n            <EffectList\n              effects={effects}\n              effectOrder={effectOrder}\n              visStateActions={visStateActions}\n              isSortable={true}\n            />\n          </StyledEffectPanelContent>\n        </StyledEffectPanel>\n        {children}\n      </StyledEffectPanelContainer>\n    );\n  };\n\n  return withState([visStateLens], state => state, {\n    visStateActions: {addEffect, updateEffect, removeEffect, reorderEffect}\n  })(injectIntl(EffectManager)) as React.FC<EffectManagerProps>;\n}\n\nexport default EffectManagerFactory;\n"],"mappings":"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","ignoreList":[]}