kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
162 lines (160 loc) • 27.4 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"] = void 0;
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _classnames = _interopRequireDefault(require("classnames"));
var _icons = require("../icons");
var _constants = require("@kepler.gl/constants");
var _animationSpeedSlider = _interopRequireDefault(require("./animation-speed-slider"));
var _windowActionControl = _interopRequireDefault(require("./window-action-control"));
var _animationWindowControl = _interopRequireDefault(require("./animation-window-control"));
var _resetControl = _interopRequireDefault(require("./reset-control"));
var _playControl = _interopRequireDefault(require("./play-control"));
var _speedControl = _interopRequireDefault(require("./speed-control"));
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 DEFAULT_BUTTON_HEIGHT = '20px';
var StyledAnimationControls = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n position: relative;\n width: ", "px;\n &.disabled {\n opacity: 0.4;\n pointer-events: none;\n }\n"])), function (props) {
return props.width;
});
var DEFAULT_ICONS = {
/* eslint-disable react/display-name */
reset: function reset() {
return /*#__PURE__*/_react["default"].createElement(_icons.Reset, {
height: "16px"
});
},
play: function play() {
return /*#__PURE__*/_react["default"].createElement(_icons.Play, {
height: "16px"
});
},
pause: function pause() {
return /*#__PURE__*/_react["default"].createElement(_icons.Pause, {
height: "16px"
});
},
"export": function _export() {
return /*#__PURE__*/_react["default"].createElement(_icons.Save, {
height: "16px"
});
},
/* eslint-enable react/display-name */
speed: function speed() {
return /*#__PURE__*/_react["default"].createElement(_icons.Speed, {
height: "16px"
});
},
animationFree: _icons.FreeWindow,
animationIncremental: _icons.AnchorWindow
};
function nop() {
return;
}
var DEFAULT_ANIMATE_ITEMS = (0, _defineProperty2["default"])((0, _defineProperty2["default"])({}, _constants.ANIMATION_WINDOW.free, {
id: _constants.ANIMATION_WINDOW.free,
icon: DEFAULT_ICONS.animationFree,
tooltip: 'tooltip.animationByWindow'
}), _constants.ANIMATION_WINDOW.incremental, {
id: _constants.ANIMATION_WINDOW.incremental,
icon: DEFAULT_ICONS.animationIncremental,
tooltip: 'tooltip.animationByIncremental'
});
PlaybackControlsFactory.deps = [
// keeping this for backwards compatibility but we can decide to drop it later
_animationSpeedSlider["default"], _windowActionControl["default"], _animationWindowControl["default"], _resetControl["default"], _playControl["default"]];
function PlaybackControlsFactory(AnimationSpeedSlider, WindowActionControl, AnimationWindowControl, ResetControl, PlayControl) {
var PLAYBACK_CONTROLS_DEFAULT_ACTION_COMPONENTS = [PlayControl, (0, _speedControl["default"])(AnimationSpeedSlider), ResetControl, WindowActionControl, AnimationWindowControl];
// eslint-disable-next-line complexity
var PlaybackControls = function PlaybackControls(_ref) {
var filter = _ref.filter,
_ref$isAnimatable = _ref.isAnimatable,
isAnimatable = _ref$isAnimatable === void 0 ? true : _ref$isAnimatable,
isAnimating = _ref.isAnimating,
width = _ref.width,
speed = _ref.speed,
_ref$animationWindow = _ref.animationWindow,
animationWindow = _ref$animationWindow === void 0 ? _constants.ANIMATION_WINDOW.free : _ref$animationWindow,
setFilterAnimationWindow = _ref.setFilterAnimationWindow,
updateAnimationSpeed = _ref.updateAnimationSpeed,
_ref$pauseAnimation = _ref.pauseAnimation,
pauseAnimation = _ref$pauseAnimation === void 0 ? nop : _ref$pauseAnimation,
_ref$resetAnimation = _ref.resetAnimation,
resetAnimation = _ref$resetAnimation === void 0 ? nop : _ref$resetAnimation,
_ref$startAnimation = _ref.startAnimation,
startAnimation = _ref$startAnimation === void 0 ? nop : _ref$startAnimation,
_ref$playbackIcons = _ref.playbackIcons,
playbackIcons = _ref$playbackIcons === void 0 ? DEFAULT_ICONS : _ref$playbackIcons,
_ref$animationItems = _ref.animationItems,
animationItems = _ref$animationItems === void 0 ? DEFAULT_ANIMATE_ITEMS : _ref$animationItems,
_ref$buttonStyle = _ref.buttonStyle,
buttonStyle = _ref$buttonStyle === void 0 ? 'secondary' : _ref$buttonStyle,
_ref$buttonHeight = _ref.buttonHeight,
buttonHeight = _ref$buttonHeight === void 0 ? DEFAULT_BUTTON_HEIGHT : _ref$buttonHeight,
_ref$playbackActionIt = _ref.playbackActionItems,
playbackActionItems = _ref$playbackActionIt === void 0 ? PLAYBACK_CONTROLS_DEFAULT_ACTION_COMPONENTS : _ref$playbackActionIt;
var _useState = (0, _react.useState)(false),
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
isSpeedControlVisible = _useState2[0],
toggleSpeedControl = _useState2[1];
var _useState3 = (0, _react.useState)(false),
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
showAnimationWindowControl = _useState4[0],
setShowAnimationWindowControl = _useState4[1];
var toggleAnimationWindowControl = (0, _react.useCallback)(function () {
setShowAnimationWindowControl(!showAnimationWindowControl);
}, [showAnimationWindowControl, setShowAnimationWindowControl]);
var btnStyle = buttonStyle ? (0, _defineProperty2["default"])({}, buttonStyle, true) : {};
var hideAndShowSpeedControl = (0, _react.useCallback)(function () {
if (!isSpeedControlVisible) {
toggleSpeedControl(true);
} else {
// TODO: A HACK to allow input onblur get triggered before the input is unmounted
// A better solution should be invested, see https://github.com/facebook/react/issues/12363
window.setTimeout(function () {
return toggleSpeedControl(false);
}, 200);
}
}, [isSpeedControlVisible, toggleSpeedControl]);
return /*#__PURE__*/_react["default"].createElement(StyledAnimationControls, {
className: (0, _classnames["default"])('playback-controls', {
disabled: !isAnimatable
}),
width: width
}, playbackActionItems.map(function (ActionComponent, index) {
return /*#__PURE__*/_react["default"].createElement(ActionComponent, {
key: index,
toggleAnimationWindowControl: toggleAnimationWindowControl,
showAnimationWindowControl: showAnimationWindowControl,
btnStyle: btnStyle,
hideAndShowSpeedControl: hideAndShowSpeedControl,
animationItems: animationItems,
animationWindow: animationWindow,
buttonHeight: buttonHeight,
filter: filter,
setFilterAnimationWindow: setFilterAnimationWindow,
updateAnimationSpeed: updateAnimationSpeed,
isAnimating: isAnimating,
pauseAnimation: pauseAnimation,
resetAnimation: resetAnimation,
startAnimation: startAnimation,
playbackIcons: playbackIcons,
isSpeedControlVisible: isSpeedControlVisible,
speed: speed
});
}));
};
return PlaybackControls;
}
var _default = exports["default"] = PlaybackControlsFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_classnames","_icons","_constants","_animationSpeedSlider","_windowActionControl","_animationWindowControl","_resetControl","_playControl","_speedControl","_templateObject","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","DEFAULT_BUTTON_HEIGHT","StyledAnimationControls","styled","div","_taggedTemplateLiteral2","props","width","DEFAULT_ICONS","reset","createElement","Reset","height","play","Play","pause","Pause","export","Save","speed","Speed","animationFree","FreeWindow","animationIncremental","AnchorWindow","nop","DEFAULT_ANIMATE_ITEMS","_defineProperty2","ANIMATION_WINDOW","free","id","icon","tooltip","incremental","PlaybackControlsFactory","deps","AnimationSpeedSliderFactory","WindowActionControlFactory","AnimationWindowControlFactory","ResetControlFactory","PlayControlFactory","AnimationSpeedSlider","WindowActionControl","AnimationWindowControl","ResetControl","PlayControl","PLAYBACK_CONTROLS_DEFAULT_ACTION_COMPONENTS","SpeedControlFactory","PlaybackControls","_ref","filter","_ref$isAnimatable","isAnimatable","isAnimating","_ref$animationWindow","animationWindow","setFilterAnimationWindow","updateAnimationSpeed","_ref$pauseAnimation","pauseAnimation","_ref$resetAnimation","resetAnimation","_ref$startAnimation","startAnimation","_ref$playbackIcons","playbackIcons","_ref$animationItems","animationItems","_ref$buttonStyle","buttonStyle","_ref$buttonHeight","buttonHeight","_ref$playbackActionIt","playbackActionItems","_useState","useState","_useState2","_slicedToArray2","isSpeedControlVisible","toggleSpeedControl","_useState3","_useState4","showAnimationWindowControl","setShowAnimationWindowControl","toggleAnimationWindowControl","useCallback","btnStyle","hideAndShowSpeedControl","window","setTimeout","className","classnames","disabled","map","ActionComponent","index","key","_default","exports"],"sources":["../../../src/common/animation-control/playback-controls.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useState, useCallback} from 'react';\nimport styled, {IStyledComponent} from 'styled-components';\nimport classnames from 'classnames';\nimport {Reset, Play, Pause, Save, Speed, AnchorWindow, FreeWindow} from '../icons';\nimport {ANIMATION_WINDOW} from '@kepler.gl/constants';\nimport {Filter, TimeRangeFilter} from '@kepler.gl/types';\nimport AnimationSpeedSliderFactory from './animation-speed-slider';\nimport WindowActionControlFactory from './window-action-control';\nimport AnimationWindowControlFactory, {AnimationItem} from './animation-window-control';\nimport ResetControlFactory from './reset-control';\nimport PlayControlFactory from './play-control';\nimport SpeedControlFactory from './speed-control';\nimport {BaseComponentProps} from '../../types';\n\nconst DEFAULT_BUTTON_HEIGHT = '20px';\n\nexport type StyledAnimationControlsProps = BaseComponentProps & {\n  width?: number;\n};\n\nconst StyledAnimationControls: IStyledComponent<\n  'web',\n  StyledAnimationControlsProps\n> = styled.div<StyledAnimationControlsProps>`\n  display: flex;\n  position: relative;\n  width: ${props => props.width}px;\n  &.disabled {\n    opacity: 0.4;\n    pointer-events: none;\n  }\n`;\n\nconst DEFAULT_ICONS = {\n  /* eslint-disable react/display-name */\n  reset: () => <Reset height=\"16px\" />,\n  play: () => <Play height=\"16px\" />,\n  pause: () => <Pause height=\"16px\" />,\n  export: () => <Save height=\"16px\" />,\n  /* eslint-enable react/display-name */\n  speed: () => <Speed height=\"16px\" />,\n  animationFree: FreeWindow,\n  animationIncremental: AnchorWindow\n};\n\nfunction nop() {\n  return;\n}\n\nconst DEFAULT_ANIMATE_ITEMS = {\n  [ANIMATION_WINDOW.free]: {\n    id: ANIMATION_WINDOW.free,\n    icon: DEFAULT_ICONS.animationFree,\n    tooltip: 'tooltip.animationByWindow'\n  },\n  [ANIMATION_WINDOW.incremental]: {\n    id: ANIMATION_WINDOW.incremental,\n    icon: DEFAULT_ICONS.animationIncremental,\n    tooltip: 'tooltip.animationByIncremental'\n  }\n};\nexport interface PlaybackControlsProps {\n  filter?: Filter;\n  isAnimatable?: boolean;\n  isAnimating?: boolean;\n  width?: number;\n  speed: number;\n  animationWindow?: null | TimeRangeFilter['animationWindow'];\n  setFilterAnimationWindow?: (id: string) => void;\n  updateAnimationSpeed?: (idx: number, speed: number) => void;\n  pauseAnimation?: () => void;\n  resetAnimation?: () => void;\n  startAnimation: () => void;\n  playbackIcons?: Record<string, React.FC<{height: number}>>;\n  animationItems?: {[key: string]: AnimationItem};\n  buttonStyle?: string;\n  buttonHeight?: string;\n  playbackActionItems?: React.FC[];\n  className?: string;\n}\n\nPlaybackControlsFactory.deps = [\n  // keeping this for backwards compatibility but we can decide to drop it later\n  AnimationSpeedSliderFactory,\n  WindowActionControlFactory,\n  AnimationWindowControlFactory,\n  ResetControlFactory,\n  PlayControlFactory\n];\n\nfunction PlaybackControlsFactory(\n  AnimationSpeedSlider: ReturnType<typeof AnimationSpeedSliderFactory>,\n  WindowActionControl,\n  AnimationWindowControl,\n  ResetControl,\n  PlayControl\n) {\n  const PLAYBACK_CONTROLS_DEFAULT_ACTION_COMPONENTS = [\n    PlayControl,\n    SpeedControlFactory(AnimationSpeedSlider),\n    ResetControl,\n    WindowActionControl,\n    AnimationWindowControl\n  ];\n\n  // eslint-disable-next-line complexity\n  const PlaybackControls: React.FC<PlaybackControlsProps> = ({\n    filter,\n    isAnimatable = true,\n    isAnimating,\n    width,\n    speed,\n    animationWindow = ANIMATION_WINDOW.free,\n    setFilterAnimationWindow,\n    updateAnimationSpeed,\n    pauseAnimation = nop,\n    resetAnimation = nop,\n    startAnimation = nop,\n    playbackIcons = DEFAULT_ICONS,\n    animationItems = DEFAULT_ANIMATE_ITEMS,\n    buttonStyle = 'secondary',\n    buttonHeight = DEFAULT_BUTTON_HEIGHT,\n    playbackActionItems = PLAYBACK_CONTROLS_DEFAULT_ACTION_COMPONENTS\n  }) => {\n    const [isSpeedControlVisible, toggleSpeedControl] = useState(false);\n    const [showAnimationWindowControl, setShowAnimationWindowControl] = useState(false);\n\n    const toggleAnimationWindowControl = useCallback(() => {\n      setShowAnimationWindowControl(!showAnimationWindowControl);\n    }, [showAnimationWindowControl, setShowAnimationWindowControl]);\n    const btnStyle = buttonStyle ? {[buttonStyle]: true} : {};\n\n    const hideAndShowSpeedControl = useCallback(() => {\n      if (!isSpeedControlVisible) {\n        toggleSpeedControl(true);\n      } else {\n        // TODO: A HACK to allow input onblur get triggered before the input is unmounted\n        // A better solution should be invested, see https://github.com/facebook/react/issues/12363\n        window.setTimeout(() => toggleSpeedControl(false), 200);\n      }\n    }, [isSpeedControlVisible, toggleSpeedControl]);\n\n    return (\n      <StyledAnimationControls\n        className={classnames('playback-controls', {\n          disabled: !isAnimatable\n        })}\n        width={width}\n      >\n        {/** Window */}\n        {playbackActionItems.map((ActionComponent, index) => (\n          <ActionComponent\n            key={index}\n            toggleAnimationWindowControl={toggleAnimationWindowControl}\n            showAnimationWindowControl={showAnimationWindowControl}\n            btnStyle={btnStyle}\n            hideAndShowSpeedControl={hideAndShowSpeedControl}\n            animationItems={animationItems}\n            animationWindow={animationWindow}\n            buttonHeight={buttonHeight}\n            filter={filter}\n            setFilterAnimationWindow={setFilterAnimationWindow}\n            updateAnimationSpeed={updateAnimationSpeed}\n            isAnimating={isAnimating}\n            pauseAnimation={pauseAnimation}\n            resetAnimation={resetAnimation}\n            startAnimation={startAnimation}\n            playbackIcons={playbackIcons}\n            isSpeedControlVisible={isSpeedControlVisible}\n            speed={speed}\n          />\n        ))}\n      </StyledAnimationControls>\n    );\n  };\n\n  return PlaybackControls;\n}\n\nexport default PlaybackControlsFactory;\n"],"mappings":"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","ignoreList":[]}