kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
120 lines (117 loc) • 24.9 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 _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("/Users/ihordykhta/Desktop/unfolded/kepler.gl/node_modules/react"));
var _styledComponents = _interopRequireDefault(require("/Users/ihordykhta/Desktop/unfolded/kepler.gl/node_modules/styled-components"));
var _reactIntl = require("/Users/ihordykhta/Desktop/unfolded/kepler.gl/node_modules/react-intl");
var _src = require("/Users/ihordykhta/Desktop/unfolded/kepler.gl/src/actions/src");
var _src2 = require("/Users/ihordykhta/Desktop/unfolded/kepler.gl/src/constants/src");
var _src3 = require("/Users/ihordykhta/Desktop/unfolded/kepler.gl/src/reducers/src");
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 === _src2.LIGHT_AND_SHADOW_EFFECT.type;
});
return _src2.EFFECT_DESCRIPTIONS.map(function (desc) {
return _objectSpread(_objectSpread({}, desc), {}, {
disabled: Boolean(hasShadow && desc.type === _src2.LIGHT_AND_SHADOW_EFFECT.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)([_src3.visStateLens], function (state) {
return state;
}, {
visStateActions: {
addEffect: _src.addEffect,
updateEffect: _src.updateEffect,
removeEffect: _src.removeEffect,
reorderEffect: _src.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","_src","_src2","_src3","_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","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/components/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 {LIGHT_AND_SHADOW_EFFECT, EFFECT_DESCRIPTIONS} 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\n      return EFFECT_DESCRIPTIONS.map(desc => {\n        return {\n          ...desc,\n          disabled: Boolean(hasShadow && desc.type === LIGHT_AND_SHADOW_EFFECT.type)\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":[]}
;