UNPKG

kepler.gl

Version:

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

101 lines (100 loc) 18.5 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 _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _constants = require("@kepler.gl/constants"); var _styledComponents2 = require("../common/styled-components"); var _timeRangeSlider = _interopRequireDefault(require("../common/time-range-slider")); var _floatingTimeDisplay = _interopRequireDefault(require("../common/animation-control/floating-time-display")); var _timeRangeFilter = require("./time-range-filter"); var _timeWidgetTop = _interopRequireDefault(require("./time-widget-top")); 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 TimeBottomWidgetInner = (0, _styledComponents["default"])(_styledComponents2.BottomWidgetInner)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n padding: 6px 32px 24px 32px;\n"]))); TimeWidgetFactory.deps = [_timeRangeSlider["default"], _floatingTimeDisplay["default"], _timeWidgetTop["default"]]; function TimeWidgetFactory(TimeRangeSlider, FloatingTimeDisplay, TimeWidgetTop) { var TimeWidget = function TimeWidget(_ref) { var datasets = _ref.datasets, filter = _ref.filter, layers = _ref.layers, index = _ref.index, readOnly = _ref.readOnly, showTimeDisplay = _ref.showTimeDisplay, setFilterAnimationTime = _ref.setFilterAnimationTime, onClose = _ref.onClose, onToggleMinify = _ref.onToggleMinify, resetAnimation = _ref.resetAnimation, isAnimatable = _ref.isAnimatable, updateAnimationSpeed = _ref.updateAnimationSpeed, toggleAnimation = _ref.toggleAnimation, setFilterPlot = _ref.setFilterPlot, setFilterAnimationWindow = _ref.setFilterAnimationWindow, animationConfig = _ref.animationConfig, timeline = _ref.timeline; var _updateAnimationSpeed = (0, _react.useCallback)(function (speed) { return updateAnimationSpeed(index, speed); }, [updateAnimationSpeed, index]); var _toggleAnimation = (0, _react.useCallback)(function () { return toggleAnimation(index); }, [toggleAnimation, index]); var isMinified = (0, _react.useMemo)(function () { return filter.view === _constants.FILTER_VIEW_TYPES.minified; }, [filter]); var _setFilterAnimationWindow = (0, _react.useCallback)(function (animationWindow) { return setFilterAnimationWindow({ id: filter.id, animationWindow: animationWindow }); }, [setFilterAnimationWindow, filter.id]); var timeSliderOnChange = (0, _react.useCallback)(function (value) { return setFilterAnimationTime(index, 'value', value); }, [setFilterAnimationTime, index]); var _setFilterPlot = (0, _react.useCallback)(function (newProp, valueIndex) { return setFilterPlot(index, newProp, valueIndex); }, [index, setFilterPlot]); var timeRangeSlideProps = (0, _react.useMemo)(function () { return (0, _timeRangeFilter.timeRangeSliderFieldsSelector)(filter, datasets, layers); }, [filter, datasets, layers]); return /*#__PURE__*/_react["default"].createElement(TimeBottomWidgetInner, { className: "bottom-widget--inner" }, /*#__PURE__*/_react["default"].createElement(TimeWidgetTop, { filter: filter, readOnly: readOnly, datasets: datasets, setFilterPlot: _setFilterPlot, index: index, onClose: onClose, onToggleMinify: onToggleMinify, isMinified: isMinified }), /*#__PURE__*/_react["default"].createElement(TimeRangeSlider, (0, _extends2["default"])({}, timeRangeSlideProps, { onChange: timeSliderOnChange, toggleAnimation: _toggleAnimation, updateAnimationSpeed: _updateAnimationSpeed, setFilterAnimationWindow: _setFilterAnimationWindow, hideTimeTitle: showTimeDisplay, resetAnimation: resetAnimation, isAnimatable: isAnimatable, setFilterPlot: _setFilterPlot, animationConfig: animationConfig, isMinified: isMinified, timeline: timeline })), showTimeDisplay ? /*#__PURE__*/_react["default"].createElement(FloatingTimeDisplay, { currentTime: filter.value, defaultTimeFormat: filter.defaultTimeFormat, timeFormat: filter.timeFormat, timezone: filter.timezone }) : null); }; return /*#__PURE__*/_react["default"].memo(TimeWidget); } var _default = exports["default"] = TimeWidgetFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_constants","_styledComponents2","_timeRangeSlider","_floatingTimeDisplay","_timeRangeFilter","_timeWidgetTop","_templateObject","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","TimeBottomWidgetInner","styled","BottomWidgetInner","_taggedTemplateLiteral2","TimeWidgetFactory","deps","TimeRangeSliderFactory","FloatingTimeDisplayFactory","TimeWidgetTopFactory","TimeRangeSlider","FloatingTimeDisplay","TimeWidgetTop","TimeWidget","_ref","datasets","filter","layers","index","readOnly","showTimeDisplay","setFilterAnimationTime","onClose","onToggleMinify","resetAnimation","isAnimatable","updateAnimationSpeed","toggleAnimation","setFilterPlot","setFilterAnimationWindow","animationConfig","timeline","_updateAnimationSpeed","useCallback","speed","_toggleAnimation","isMinified","useMemo","view","FILTER_VIEW_TYPES","minified","_setFilterAnimationWindow","animationWindow","id","timeSliderOnChange","value","_setFilterPlot","newProp","valueIndex","timeRangeSlideProps","timeRangeSliderFieldsSelector","createElement","className","_extends2","onChange","hideTimeTitle","currentTime","defaultTimeFormat","timeFormat","timezone","React","memo","_default","exports"],"sources":["../../src/filters/time-widget.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useMemo} from 'react';\nimport styled from 'styled-components';\nimport {FILTER_VIEW_TYPES} from '@kepler.gl/constants';\nimport {BottomWidgetInner} from '../common/styled-components';\nimport TimeRangeSliderFactory from '../common/time-range-slider';\nimport FloatingTimeDisplayFactory from '../common/animation-control/floating-time-display';\nimport {timeRangeSliderFieldsSelector} from './time-range-filter';\nimport {TimeWidgetProps} from './types';\nimport TimeWidgetTopFactory from './time-widget-top';\n\nconst TimeBottomWidgetInner = styled(BottomWidgetInner)`\n  padding: 6px 32px 24px 32px;\n`;\n\nTimeWidgetFactory.deps = [TimeRangeSliderFactory, FloatingTimeDisplayFactory, TimeWidgetTopFactory];\n\nfunction TimeWidgetFactory(\n  TimeRangeSlider: ReturnType<typeof TimeRangeSliderFactory>,\n  FloatingTimeDisplay: ReturnType<typeof FloatingTimeDisplayFactory>,\n  TimeWidgetTop: ReturnType<typeof TimeWidgetTopFactory>\n) {\n  const TimeWidget: React.FC<TimeWidgetProps> = ({\n    datasets,\n    filter,\n    layers,\n    index,\n    readOnly,\n    showTimeDisplay,\n    setFilterAnimationTime,\n    onClose,\n    onToggleMinify,\n    resetAnimation,\n    isAnimatable,\n    updateAnimationSpeed,\n    toggleAnimation,\n    setFilterPlot,\n    setFilterAnimationWindow,\n    animationConfig,\n    timeline\n  }: TimeWidgetProps) => {\n    const _updateAnimationSpeed = useCallback(\n      speed => updateAnimationSpeed(index, speed),\n      [updateAnimationSpeed, index]\n    );\n\n    const _toggleAnimation = useCallback(() => toggleAnimation(index), [toggleAnimation, index]);\n\n    const isMinified = useMemo(() => filter.view === FILTER_VIEW_TYPES.minified, [filter]);\n\n    const _setFilterAnimationWindow = useCallback(\n      animationWindow => setFilterAnimationWindow({id: filter.id, animationWindow}),\n      [setFilterAnimationWindow, filter.id]\n    );\n\n    const timeSliderOnChange = useCallback(\n      value => setFilterAnimationTime(index, 'value', value),\n      [setFilterAnimationTime, index]\n    );\n\n    const _setFilterPlot = useCallback(\n      (newProp, valueIndex) => setFilterPlot(index, newProp, valueIndex),\n      [index, setFilterPlot]\n    );\n\n    const timeRangeSlideProps = useMemo(\n      () => timeRangeSliderFieldsSelector(filter, datasets, layers),\n      [filter, datasets, layers]\n    );\n\n    return (\n      <TimeBottomWidgetInner className=\"bottom-widget--inner\">\n        <TimeWidgetTop\n          filter={filter}\n          readOnly={readOnly}\n          datasets={datasets}\n          setFilterPlot={_setFilterPlot}\n          index={index}\n          onClose={onClose}\n          onToggleMinify={onToggleMinify}\n          isMinified={isMinified}\n        />\n        {/* Once AnimationControl is able to display large timeline*/}\n        {/* we can replace TimeRangeSlider with AnimationControl*/}\n        <TimeRangeSlider\n          {...timeRangeSlideProps}\n          onChange={timeSliderOnChange}\n          toggleAnimation={_toggleAnimation}\n          updateAnimationSpeed={_updateAnimationSpeed}\n          setFilterAnimationWindow={_setFilterAnimationWindow}\n          hideTimeTitle={showTimeDisplay}\n          resetAnimation={resetAnimation}\n          isAnimatable={isAnimatable}\n          setFilterPlot={_setFilterPlot}\n          animationConfig={animationConfig}\n          isMinified={isMinified}\n          timeline={timeline}\n        />\n        {showTimeDisplay ? (\n          <FloatingTimeDisplay\n            currentTime={filter.value}\n            defaultTimeFormat={filter.defaultTimeFormat}\n            timeFormat={filter.timeFormat}\n            timezone={filter.timezone}\n          />\n        ) : null}\n      </TimeBottomWidgetInner>\n    );\n  };\n\n  return React.memo(TimeWidget);\n}\n\nexport default TimeWidgetFactory;\n"],"mappings":"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","ignoreList":[]}