kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
178 lines (172 loc) • 38.2 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"] = BottomWidgetFactory;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireWildcard(require("styled-components"));
var _constants = require("@kepler.gl/constants");
var _utils = require("@kepler.gl/utils");
var _styles = require("@kepler.gl/styles");
var _timeWidget = _interopRequireDefault(require("./filters/time-widget"));
var _filterAnimationController = _interopRequireDefault(require("./filter-animation-controller"));
var _layerAnimationController = _interopRequireDefault(require("./layer-animation-controller"));
var _animationControl = _interopRequireDefault(require("./common/animation-control/animation-control"));
var _templateObject, _templateObject2, _templateObject3; // 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 maxWidth = 1080;
var BottomWidgetContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n padding-top: ", "px;\n padding-right: ", "px;\n padding-bottom: ", "px;\n padding-left: ", "px;\n pointer-events: none !important; /* prevent padding from blocking input */\n & > * {\n /* all children should allow input */\n pointer-events: all;\n }\n width: ", "px;\n z-index: 1;\n ", "\n"])), function (props) {
return props.hasPadding ? props.theme.bottomWidgetPaddingTop : 0;
}, function (props) {
return props.hasPadding ? props.theme.bottomWidgetPaddingRight : 0;
}, function (props) {
return props.hasPadding ? props.theme.bottomWidgetPaddingBottom : 0;
}, function (props) {
return props.hasPadding ? props.theme.bottomWidgetPaddingLeft : 0;
}, function (props) {
return props.width;
}, _styles.media.portable(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["padding: 0;"]))));
BottomWidgetFactory.deps = [_timeWidget["default"], _animationControl["default"], _filterAnimationController["default"], _layerAnimationController["default"]];
/* eslint-disable complexity */
function BottomWidgetFactory(TimeWidget, AnimationControl, FilterAnimationController, LayerAnimationController) {
var LayerAnimationControl = (0, _styledComponents["default"])(AnimationControl)(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n "])), function (props) {
return props.theme.sidePanelBg;
});
var BottomWidget = function BottomWidget(props) {
var _uiState$mapControls, _uiState$mapControls2, _theme$mapControl, _theme$mapControl2;
var datasets = props.datasets,
filters = props.filters,
animationConfig = props.animationConfig,
visStateActions = props.visStateActions,
containerW = props.containerW,
uiState = props.uiState,
sidePanelWidth = props.sidePanelWidth,
layers = props.layers,
rootRef = props.rootRef,
theme = props.theme;
var activeSidePanel = uiState.activeSidePanel,
readOnly = uiState.readOnly;
var isOpen = Boolean(activeSidePanel);
var enlargedFilterIdx = (0, _react.useMemo)(function () {
return filters.findIndex(function (f) {
return !(0, _utils.isSideFilter)(f);
});
}, [filters]);
var animatedFilterIdx = (0, _react.useMemo)(function () {
return filters.findIndex(function (f) {
return f.isAnimating;
});
}, [filters]);
var animatedFilter = animatedFilterIdx > -1 ? filters[animatedFilterIdx] : null;
// we need to hide layer timeline when filter is synced and not enlarged
var isTimelineLinkedWithFilter = (0, _react.useMemo)(function () {
return filters.some(function (f) {
return f.syncedWithLayerTimeline;
});
}, [filters]);
var isMobile = (0, _react.useMemo)(function () {
return (0, _utils.hasPortableWidth)(_styles.breakPointValues);
}, []);
var isLegendPinned = ((_uiState$mapControls = uiState.mapControls) === null || _uiState$mapControls === void 0 || (_uiState$mapControls = _uiState$mapControls.mapLegend) === null || _uiState$mapControls === void 0 ? void 0 : _uiState$mapControls.show) && ((_uiState$mapControls2 = uiState.mapControls) === null || _uiState$mapControls2 === void 0 || (_uiState$mapControls2 = _uiState$mapControls2.mapLegend) === null || _uiState$mapControls2 === void 0 ? void 0 : _uiState$mapControls2.active);
var spaceForLegendWidth = isLegendPinned ? ((_theme$mapControl = theme.mapControl) === null || _theme$mapControl === void 0 ? void 0 : _theme$mapControl.width) + ((_theme$mapControl2 = theme.mapControl) === null || _theme$mapControl2 === void 0 || (_theme$mapControl2 = _theme$mapControl2.mapLegend) === null || _theme$mapControl2 === void 0 || (_theme$mapControl2 = _theme$mapControl2.pinned) === null || _theme$mapControl2 === void 0 ? void 0 : _theme$mapControl2.right) * 2 - theme.bottomWidgetPaddingRight : 0;
var enlargedFilterWidth = (0, _react.useMemo)(function () {
return (!isMobile && isOpen ? containerW - sidePanelWidth : containerW) - spaceForLegendWidth;
}, [isMobile, isOpen, containerW, sidePanelWidth, spaceForLegendWidth]);
// show playback control if layers contain trip layer & at least one trip layer is visible
var animatableLayer = (0, _react.useMemo)(function () {
return layers.filter(function (l) {
return l.config.animation && l.config.animation.enabled && l.config.isVisible;
});
}, [layers]);
var readyToAnimation = (0, _react.useMemo)(function () {
return Array.isArray(animationConfig.domain) && Number.isFinite(animationConfig.currentTime);
}, [animationConfig.domain, animationConfig.currentTime]);
// if animation control is showing, hide time display in time slider
var showFloatingTimeDisplay = !animatableLayer.length;
var showAnimationControl = animatableLayer.length && readyToAnimation && !animationConfig.hideControl;
var showTimeWidget = enlargedFilterIdx > -1 && Object.keys(datasets).length > 0;
// if filter is not animating, pass in enlarged filter here because
// animation controller needs to call reset on it
var filter = (0, _react.useMemo)(function () {
return animatedFilter || filters[enlargedFilterIdx];
}, [animatedFilter, filters, enlargedFilterIdx]);
// we merge filter and timeline if filter is synced
var _useMemo = (0, _react.useMemo)(function () {
return filter !== null && filter !== void 0 && filter.syncedWithLayerTimeline ? (0, _utils.mergeFilterWithTimeline)(filter, animationConfig) : {
filter: filter,
animationConfig: animationConfig
};
}, [filter, animationConfig]),
enhancedFilter = _useMemo.filter,
enhancedAnimationConfig = _useMemo.animationConfig;
var onClose = (0, _react.useCallback)(function () {
return visStateActions.setFilterView(enlargedFilterIdx, _constants.FILTER_VIEW_TYPES.side);
}, [visStateActions, enlargedFilterIdx]);
var onToggleMinify = (0, _react.useCallback)(function () {
return visStateActions.setFilterView(enlargedFilterIdx, filter.view === _constants.FILTER_VIEW_TYPES.enlarged ? _constants.FILTER_VIEW_TYPES.minified : _constants.FILTER_VIEW_TYPES.enlarged);
}, [enlargedFilterIdx, visStateActions, filter]);
return /*#__PURE__*/_react["default"].createElement(BottomWidgetContainer, {
width: Math.min(maxWidth, enlargedFilterWidth),
style: {
marginRight: spaceForLegendWidth
},
className: "bottom-widget--container",
hasPadding: showAnimationControl || showTimeWidget,
ref: rootRef
}, !isTimelineLinkedWithFilter ? /*#__PURE__*/_react["default"].createElement(LayerAnimationController, {
animationConfig: enhancedAnimationConfig,
setLayerAnimationTime: visStateActions.setLayerAnimationTime
}, function (isAnimating, start, pause, resetAnimation, timeline, setTimelineValue) {
return showAnimationControl ? /*#__PURE__*/_react["default"].createElement(LayerAnimationControl, {
updateAnimationSpeed: visStateActions.updateLayerAnimationSpeed,
toggleAnimation: visStateActions.toggleLayerAnimation,
isAnimatable: !animatedFilter,
isAnimating: isAnimating,
resetAnimation: resetAnimation,
setTimelineValue: setTimelineValue,
timeline: timeline
}) : null;
}) : null, enhancedFilter ? /*#__PURE__*/_react["default"].createElement(FilterAnimationController, {
filter: enhancedFilter,
filterIdx: animatedFilterIdx > -1 ? animatedFilterIdx : enlargedFilterIdx,
setFilterAnimationTime: visStateActions.setFilterAnimationTime
}, function (isAnimating, start, pause, resetAnimation, timeline, setTimelineValue) {
return showTimeWidget && timeline ? /*#__PURE__*/_react["default"].createElement(TimeWidget
// TimeWidget uses React.memo, here we pass width
// even though it doesnt use it, to force rerender
, {
filter: enhancedFilter,
index: enlargedFilterIdx,
datasets: datasets,
layers: layers,
readOnly: readOnly,
showTimeDisplay: showFloatingTimeDisplay,
setFilterPlot: visStateActions.setFilterPlot,
setFilterAnimationTime: setTimelineValue,
setFilterAnimationWindow: visStateActions.setFilterAnimationWindow,
setFilterSyncTimelineMode: visStateActions.setTimeFilterSyncTimelineMode,
toggleAnimation: visStateActions.toggleFilterAnimation,
updateAnimationSpeed: visStateActions.updateFilterAnimationSpeed,
resetAnimation: resetAnimation,
isAnimatable: !animationConfig || !animationConfig.isAnimating,
animationConfig: animationConfig,
onClose: onClose,
timeline: timeline,
onToggleMinify: onToggleMinify
}) : null;
}) : null);
};
return (0, _styledComponents.withTheme)( /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
return /*#__PURE__*/_react["default"].createElement(BottomWidget, (0, _extends2["default"])({}, props, {
rootRef: ref
}));
}));
}
/* eslint-enable complexity */
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_constants","_utils","_styles","_timeWidget","_interopRequireDefault","_filterAnimationController","_layerAnimationController","_animationControl","_templateObject","_templateObject2","_templateObject3","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","maxWidth","BottomWidgetContainer","styled","div","_taggedTemplateLiteral2","props","hasPadding","theme","bottomWidgetPaddingTop","bottomWidgetPaddingRight","bottomWidgetPaddingBottom","bottomWidgetPaddingLeft","width","media","portable","BottomWidgetFactory","deps","TimeWidgetFactory","AnimationControlFactory","FilterAnimationControllerFactory","LayerAnimationControllerFactory","TimeWidget","AnimationControl","FilterAnimationController","LayerAnimationController","LayerAnimationControl","sidePanelBg","BottomWidget","_uiState$mapControls","_uiState$mapControls2","_theme$mapControl","_theme$mapControl2","datasets","filters","animationConfig","visStateActions","containerW","uiState","sidePanelWidth","layers","rootRef","activeSidePanel","readOnly","isOpen","Boolean","enlargedFilterIdx","useMemo","findIndex","f","isSideFilter","animatedFilterIdx","isAnimating","animatedFilter","isTimelineLinkedWithFilter","some","syncedWithLayerTimeline","isMobile","hasPortableWidth","breakPointValues","isLegendPinned","mapControls","mapLegend","show","active","spaceForLegendWidth","mapControl","pinned","right","enlargedFilterWidth","animatableLayer","filter","l","config","animation","enabled","isVisible","readyToAnimation","Array","isArray","domain","Number","isFinite","currentTime","showFloatingTimeDisplay","length","showAnimationControl","hideControl","showTimeWidget","keys","_useMemo","mergeFilterWithTimeline","enhancedFilter","enhancedAnimationConfig","onClose","useCallback","setFilterView","FILTER_VIEW_TYPES","side","onToggleMinify","view","enlarged","minified","createElement","Math","min","style","marginRight","className","ref","setLayerAnimationTime","start","pause","resetAnimation","timeline","setTimelineValue","updateAnimationSpeed","updateLayerAnimationSpeed","toggleAnimation","toggleLayerAnimation","isAnimatable","filterIdx","setFilterAnimationTime","index","showTimeDisplay","setFilterPlot","setFilterAnimationWindow","setFilterSyncTimelineMode","setTimeFilterSyncTimelineMode","toggleFilterAnimation","updateFilterAnimationSpeed","withTheme","forwardRef","_extends2"],"sources":["../src/bottom-widget.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {forwardRef, useMemo, useCallback} from 'react';\nimport styled, {withTheme, IStyledComponent} from 'styled-components';\n\nimport {FILTER_VIEW_TYPES} from '@kepler.gl/constants';\nimport {hasPortableWidth, isSideFilter, mergeFilterWithTimeline} from '@kepler.gl/utils';\nimport {media, breakPointValues} from '@kepler.gl/styles';\nimport {TimeRangeFilter} from '@kepler.gl/types';\n\nimport TimeWidgetFactory from './filters/time-widget';\nimport {bottomWidgetSelector} from './kepler-gl';\nimport FilterAnimationControllerFactory from './filter-animation-controller';\nimport LayerAnimationControllerFactory from './layer-animation-controller';\nimport AnimationControlFactory from './common/animation-control/animation-control';\nimport {BaseComponentProps} from './types';\n\nconst maxWidth = 1080;\n\nexport type BottomWidgetContainerProps = BaseComponentProps & {\n  hasPadding?: boolean;\n  width: number;\n  ref: React.ForwardedRef<HTMLDivElement>;\n};\n\nconst BottomWidgetContainer: IStyledComponent<\n  'web',\n  BottomWidgetContainerProps\n> = styled.div<BottomWidgetContainerProps>`\n  display: flex;\n  flex-direction: column;\n  padding-top: ${props => (props.hasPadding ? props.theme.bottomWidgetPaddingTop : 0)}px;\n  padding-right: ${props => (props.hasPadding ? props.theme.bottomWidgetPaddingRight : 0)}px;\n  padding-bottom: ${props => (props.hasPadding ? props.theme.bottomWidgetPaddingBottom : 0)}px;\n  padding-left: ${props => (props.hasPadding ? props.theme.bottomWidgetPaddingLeft : 0)}px;\n  pointer-events: none !important; /* prevent padding from blocking input */\n  & > * {\n    /* all children should allow input */\n    pointer-events: all;\n  }\n  width: ${props => props.width}px;\n  z-index: 1;\n  ${media.portable`padding: 0;`}\n`;\n\nexport type BottomWidgetProps = {\n  rootRef: React.ForwardedRef<HTMLDivElement>;\n  containerW: number;\n} & ReturnType<typeof bottomWidgetSelector>;\ntype ThemeProp = {\n  theme: any;\n};\ntype BottomWidgetThemedProps = BottomWidgetProps & ThemeProp;\n\nBottomWidgetFactory.deps = [\n  TimeWidgetFactory,\n  AnimationControlFactory,\n  FilterAnimationControllerFactory,\n  LayerAnimationControllerFactory\n];\n\n/* eslint-disable complexity */\nexport default function BottomWidgetFactory(\n  TimeWidget: ReturnType<typeof TimeWidgetFactory>,\n  AnimationControl: ReturnType<typeof AnimationControlFactory>,\n  FilterAnimationController: ReturnType<typeof FilterAnimationControllerFactory>,\n  LayerAnimationController: ReturnType<typeof LayerAnimationControllerFactory>\n): React.FC<BottomWidgetThemedProps> {\n  const LayerAnimationControl = styled(AnimationControl)`\n    background-color: ${props => props.theme.sidePanelBg};\n  `;\n\n  const BottomWidget: React.FC<BottomWidgetThemedProps> = (props: BottomWidgetThemedProps) => {\n    const {\n      datasets,\n      filters,\n      animationConfig,\n      visStateActions,\n      containerW,\n      uiState,\n      sidePanelWidth,\n      layers,\n      rootRef,\n      theme\n    } = props;\n\n    const {activeSidePanel, readOnly} = uiState;\n    const isOpen = Boolean(activeSidePanel);\n\n    const enlargedFilterIdx = useMemo(() => filters.findIndex(f => !isSideFilter(f)), [filters]);\n    const animatedFilterIdx = useMemo(() => filters.findIndex(f => f.isAnimating), [filters]);\n    const animatedFilter = animatedFilterIdx > -1 ? filters[animatedFilterIdx] : null;\n    // we need to hide layer timeline when filter is synced and not enlarged\n    const isTimelineLinkedWithFilter = useMemo(\n      () => (filters as TimeRangeFilter[]).some(f => f.syncedWithLayerTimeline),\n      [filters]\n    );\n\n    const isMobile = useMemo(() => hasPortableWidth(breakPointValues), []);\n    const isLegendPinned =\n      uiState.mapControls?.mapLegend?.show && uiState.mapControls?.mapLegend?.active;\n    const spaceForLegendWidth = isLegendPinned\n      ? theme.mapControl?.width +\n        theme.mapControl?.mapLegend?.pinned?.right * 2 -\n        theme.bottomWidgetPaddingRight\n      : 0;\n\n    const enlargedFilterWidth = useMemo(\n      () => (!isMobile && isOpen ? containerW - sidePanelWidth : containerW) - spaceForLegendWidth,\n      [isMobile, isOpen, containerW, sidePanelWidth, spaceForLegendWidth]\n    );\n\n    // show playback control if layers contain trip layer & at least one trip layer is visible\n    const animatableLayer = useMemo(\n      () =>\n        layers.filter(l => l.config.animation && l.config.animation.enabled && l.config.isVisible),\n      [layers]\n    );\n\n    const readyToAnimation = useMemo(\n      () => Array.isArray(animationConfig.domain) && Number.isFinite(animationConfig.currentTime),\n      [animationConfig.domain, animationConfig.currentTime]\n    );\n\n    // if animation control is showing, hide time display in time slider\n    const showFloatingTimeDisplay = !animatableLayer.length;\n    const showAnimationControl =\n      animatableLayer.length && readyToAnimation && !animationConfig.hideControl;\n    const showTimeWidget = enlargedFilterIdx > -1 && Object.keys(datasets).length > 0;\n\n    // if filter is not animating, pass in enlarged filter here because\n    // animation controller needs to call reset on it\n    const filter = useMemo(\n      () => (animatedFilter as TimeRangeFilter) || filters[enlargedFilterIdx],\n      [animatedFilter, filters, enlargedFilterIdx]\n    );\n\n    // we merge filter and timeline if filter is synced\n    const {filter: enhancedFilter, animationConfig: enhancedAnimationConfig} = useMemo(\n      () =>\n        filter?.syncedWithLayerTimeline\n          ? mergeFilterWithTimeline(filter, animationConfig)\n          : {filter, animationConfig},\n      [filter, animationConfig]\n    );\n\n    const onClose = useCallback(\n      () => visStateActions.setFilterView(enlargedFilterIdx, FILTER_VIEW_TYPES.side),\n      [visStateActions, enlargedFilterIdx]\n    );\n\n    const onToggleMinify = useCallback(\n      () =>\n        visStateActions.setFilterView(\n          enlargedFilterIdx,\n          filter.view === FILTER_VIEW_TYPES.enlarged\n            ? FILTER_VIEW_TYPES.minified\n            : FILTER_VIEW_TYPES.enlarged\n        ),\n      [enlargedFilterIdx, visStateActions, filter]\n    );\n\n    return (\n      <BottomWidgetContainer\n        width={Math.min(maxWidth, enlargedFilterWidth)}\n        style={{marginRight: spaceForLegendWidth}}\n        className=\"bottom-widget--container\"\n        hasPadding={showAnimationControl || showTimeWidget}\n        ref={rootRef}\n      >\n        {!isTimelineLinkedWithFilter ? (\n          <LayerAnimationController\n            animationConfig={enhancedAnimationConfig}\n            setLayerAnimationTime={visStateActions.setLayerAnimationTime}\n          >\n            {(isAnimating, start, pause, resetAnimation, timeline, setTimelineValue) =>\n              showAnimationControl ? (\n                <LayerAnimationControl\n                  updateAnimationSpeed={visStateActions.updateLayerAnimationSpeed}\n                  toggleAnimation={visStateActions.toggleLayerAnimation}\n                  isAnimatable={!animatedFilter}\n                  isAnimating={isAnimating}\n                  resetAnimation={resetAnimation}\n                  setTimelineValue={setTimelineValue}\n                  timeline={timeline}\n                />\n              ) : null\n            }\n          </LayerAnimationController>\n        ) : null}\n        {enhancedFilter ? (\n          <FilterAnimationController\n            filter={enhancedFilter}\n            filterIdx={animatedFilterIdx > -1 ? animatedFilterIdx : enlargedFilterIdx}\n            setFilterAnimationTime={visStateActions.setFilterAnimationTime}\n          >\n            {(isAnimating, start, pause, resetAnimation, timeline, setTimelineValue) =>\n              showTimeWidget && timeline ? (\n                <TimeWidget\n                  // TimeWidget uses React.memo, here we pass width\n                  // even though it doesnt use it, to force rerender\n                  filter={enhancedFilter as TimeRangeFilter}\n                  index={enlargedFilterIdx}\n                  datasets={datasets}\n                  layers={layers}\n                  readOnly={readOnly}\n                  showTimeDisplay={showFloatingTimeDisplay}\n                  setFilterPlot={visStateActions.setFilterPlot}\n                  setFilterAnimationTime={setTimelineValue}\n                  setFilterAnimationWindow={visStateActions.setFilterAnimationWindow}\n                  setFilterSyncTimelineMode={visStateActions.setTimeFilterSyncTimelineMode}\n                  toggleAnimation={visStateActions.toggleFilterAnimation}\n                  updateAnimationSpeed={visStateActions.updateFilterAnimationSpeed}\n                  resetAnimation={resetAnimation}\n                  isAnimatable={!animationConfig || !animationConfig.isAnimating}\n                  animationConfig={animationConfig}\n                  onClose={onClose}\n                  timeline={timeline}\n                  onToggleMinify={onToggleMinify}\n                />\n              ) : null\n            }\n          </FilterAnimationController>\n        ) : null}\n      </BottomWidgetContainer>\n    );\n  };\n\n  return withTheme(\n    forwardRef((props: BottomWidgetThemedProps, ref: React.ForwardedRef<HTMLDivElement>) => (\n      <BottomWidget {...props} rootRef={ref} />\n    ))\n  );\n}\n/* eslint-enable complexity */\n"],"mappings":"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","ignoreList":[]}