UNPKG

kepler.gl

Version:

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

77 lines (74 loc) 13.4 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 _react = _interopRequireWildcard(require("react")); var _utils = require("@kepler.gl/utils"); var _constants = require("@kepler.gl/constants"); var _animationController = _interopRequireDefault(require("./common/animation-control/animation-controller")); 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; } // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project FilterAnimationControllerFactory.deps = [_animationController["default"]]; function FilterAnimationControllerFactory(AnimationController) { var FilterAnimationController = function FilterAnimationController(_ref) { var _filter$plotType2; var filter = _ref.filter, filterIdx = _ref.filterIdx, setFilterAnimationTime = _ref.setFilterAnimationTime, children = _ref.children; var binThresholds = (0, _react.useMemo)(function () { var _filter$plotType; return (0, _utils.getBinThresholds)((_filter$plotType = filter.plotType) === null || _filter$plotType === void 0 ? void 0 : _filter$plotType.interval, filter.domain); }, [(_filter$plotType2 = filter.plotType) === null || _filter$plotType2 === void 0 ? void 0 : _filter$plotType2.interval, filter.domain]); var steps = (0, _react.useMemo)(function () { if (binThresholds) { var thresholds = (0, _toConsumableArray2["default"])(binThresholds); // pop last threshold thresholds.pop(); return thresholds; } return null; }, [binThresholds]); var updateAnimation = (0, _react.useCallback)(function (value) { switch (filter.animationWindow) { case _constants.ANIMATION_WINDOW.interval: { var idx = value[1]; if (idx < binThresholds.length - 1) { setFilterAnimationTime(filterIdx, 'value', [binThresholds[idx], binThresholds[idx + 1] - 1]); } break; } default: setFilterAnimationTime(filterIdx, 'value', value); break; } }, [filterIdx, binThresholds, filter.animationWindow, setFilterAnimationTime]); // if filter is synced merge the filter and animation config var timeline = (0, _utils.getTimelineFromFilter)(filter); return /*#__PURE__*/_react["default"].createElement(AnimationController, { key: "filter-control", value: filter.value, domain: filter.domain, speed: filter.speed, isAnimating: filter.isAnimating, animationWindow: filter.animationWindow, steps: steps, updateAnimation: updateAnimation // @ts-expect-error different function type, goes to TimeWidget setFilterAnimationTime() , setTimelineValue: setFilterAnimationTime, timeline: timeline, children: children }); }; return FilterAnimationController; } var _default = exports["default"] = FilterAnimationControllerFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_utils","_constants","_animationController","_interopRequireDefault","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","FilterAnimationControllerFactory","deps","AnimationControllerFactory","AnimationController","FilterAnimationController","_ref","_filter$plotType2","filter","filterIdx","setFilterAnimationTime","children","binThresholds","useMemo","_filter$plotType","getBinThresholds","plotType","interval","domain","steps","thresholds","_toConsumableArray2","pop","updateAnimation","useCallback","value","animationWindow","ANIMATION_WINDOW","idx","length","timeline","getTimelineFromFilter","createElement","key","speed","isAnimating","setTimelineValue","_default","exports"],"sources":["../src/filter-animation-controller.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useMemo} from 'react';\nimport {getBinThresholds, getTimelineFromFilter} from '@kepler.gl/utils';\nimport {TimeRangeFilter} from '@kepler.gl/types';\nimport {ANIMATION_WINDOW} from '@kepler.gl/constants';\nimport AnimationControllerFactory from './common/animation-control/animation-controller';\nimport {Timeline} from '@kepler.gl/types';\n\ninterface FilterAnimationControllerProps {\n  filter: TimeRangeFilter & {animationWindow?: string};\n  filterIdx: number;\n  setFilterAnimationTime: (idx: number, value: string, a: any[]) => void;\n  children?: (\n    isAnimating: boolean | undefined,\n    startAnimation: () => void,\n    pauseAnimation: () => void,\n    resetAnimation: () => void,\n    timeline: Timeline | undefined,\n    setTimelineValue: (x: any) => void\n  ) => React.ReactElement | null;\n}\n\nFilterAnimationControllerFactory.deps = [AnimationControllerFactory];\nfunction FilterAnimationControllerFactory(\n  AnimationController: ReturnType<typeof AnimationControllerFactory>\n) {\n  const FilterAnimationController: React.FC<FilterAnimationControllerProps> = ({\n    filter,\n    filterIdx,\n    setFilterAnimationTime,\n    children\n  }) => {\n    const binThresholds = useMemo(() => {\n      return getBinThresholds(filter.plotType?.interval, filter.domain);\n    }, [filter.plotType?.interval, filter.domain]);\n\n    const steps = useMemo(() => {\n      if (binThresholds) {\n        const thresholds = [...binThresholds];\n        // pop last threshold\n        thresholds.pop();\n        return thresholds;\n      }\n\n      return null;\n    }, [binThresholds]);\n\n    const updateAnimation = useCallback(\n      value => {\n        switch (filter.animationWindow) {\n          case ANIMATION_WINDOW.interval: {\n            const idx = value[1];\n            if (idx < binThresholds.length - 1) {\n              setFilterAnimationTime(filterIdx, 'value', [\n                binThresholds[idx],\n                binThresholds[idx + 1] - 1\n              ]);\n            }\n            break;\n          }\n          default:\n            setFilterAnimationTime(filterIdx, 'value', value);\n            break;\n        }\n      },\n      [filterIdx, binThresholds, filter.animationWindow, setFilterAnimationTime]\n    );\n\n    // if filter is synced merge the filter and animation config\n    const timeline = getTimelineFromFilter(filter);\n\n    return (\n      <AnimationController\n        key=\"filter-control\"\n        value={filter.value}\n        domain={filter.domain}\n        speed={filter.speed}\n        isAnimating={filter.isAnimating}\n        animationWindow={filter.animationWindow}\n        steps={steps}\n        updateAnimation={updateAnimation}\n        // @ts-expect-error different function type, goes to TimeWidget setFilterAnimationTime()\n        setTimelineValue={setFilterAnimationTime}\n        timeline={timeline}\n        children={children}\n      />\n    );\n  };\n  return FilterAnimationController;\n}\n\nexport default FilterAnimationControllerFactory;\n"],"mappings":"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","ignoreList":[]}