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
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 _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":[]}
;