UNPKG

kepler.gl

Version:

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

278 lines (244 loc) 35.6 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = exports.AnimationWindowControl = exports.IconButton = void 0; var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); 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 _localization = require("../../../localization"); var _styledComponents2 = require("../styled-components"); var _animationSpeedSlider = _interopRequireDefault(require("./animation-speed-slider")); var _icons = require("../icons"); var _defaultSettings = require("../../../constants/default-settings"); var _dataUtils = require("../../../utils/data-utils"); var _templateObject, _templateObject2, _templateObject3, _DEFAULT_ANIMATE_ITEM; var DELAY_SHOW = 500; var DEFAULT_BUTTON_HEIGHT = '20px'; var StyledAnimationControls = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n position: relative;\n\n &.disabled {\n opacity: 0.4;\n pointer-events: none;\n }\n"]))); var StyledSpeedControl = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n\n .animation-control__speed-slider {\n left: 0;\n }\n"]))); var IconButton = (0, _styledComponents["default"])(_styledComponents2.Button)(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n width: ", "px;\n height: 32px;\n color: ", ";\n background-color: ", ";\n border-radius: 4px;\n margin-left: 7px;\n border: 0;\n padding: 0;\n\n .__react_component_tooltip {\n font-family: ", ";\n }\n svg {\n margin: 0;\n }\n &.active {\n background-color: ", ";\n }\n"])), function (props) { return props.collapsed ? 0 : 32; }, function (props) { return props.theme.playbackButtonColor; }, function (props) { return props.theme.playbackButtonBgColor; }, function (props) { return props.theme.fontFamily; }, function (props) { return props.theme.playbackButtonActBgColor; }); exports.IconButton = IconButton; function nop() {} var DEFAULT_ICONS = { /* eslint-disable react/display-name */ reset: function reset(_) { return /*#__PURE__*/_react["default"].createElement(_icons.Reset, { height: "18px" }); }, play: function play(_) { return /*#__PURE__*/_react["default"].createElement(_icons.Play, { height: "18px" }); }, pause: function pause(_) { return /*#__PURE__*/_react["default"].createElement(_icons.Pause, { height: "18px" }); }, /* eslint-enable react/display-name */ speed: _icons.Rocket, animationFree: _icons.FreeWindow, animationIncremental: _icons.AnchorWindow }; var DEFAULT_ANIMATE_ITEMS = (_DEFAULT_ANIMATE_ITEM = {}, (0, _defineProperty2["default"])(_DEFAULT_ANIMATE_ITEM, _defaultSettings.ANIMATION_WINDOW.free, { id: _defaultSettings.ANIMATION_WINDOW.free, icon: DEFAULT_ICONS.animationFree, tooltip: 'tooltip.animationByWindow' }), (0, _defineProperty2["default"])(_DEFAULT_ANIMATE_ITEM, _defaultSettings.ANIMATION_WINDOW.incremental, { id: _defaultSettings.ANIMATION_WINDOW.incremental, icon: DEFAULT_ICONS.animationIncremental, tooltip: 'tooltip.animationByIncremental' }), _DEFAULT_ANIMATE_ITEM); var AnimationWindowControl = function AnimationWindowControl(_ref) { var _onClick = _ref.onClick, selected = _ref.selected, onHide = _ref.onHide, height = _ref.height, animationItems = _ref.animationItems, _ref$btnStyle = _ref.btnStyle, btnStyle = _ref$btnStyle === void 0 ? {} : _ref$btnStyle; return /*#__PURE__*/_react["default"].createElement("div", null, Object.values(animationItems).filter(function (item) { return item.id !== selected; }).map(function (item) { return /*#__PURE__*/_react["default"].createElement(IconButton, (0, _extends2["default"])({ key: item.id, "data-tip": true, "data-for": "".concat(item.id, "-tooltip"), className: "playback-control-button", onClick: function onClick() { _onClick(item.id); onHide(); } }, btnStyle), /*#__PURE__*/_react["default"].createElement(item.icon, { height: height }), item.tooltip ? /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, { id: "".concat(item.id, "-tooltip"), effect: "solid", place: "top" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: item.tooltip })) : null); })); }; exports.AnimationWindowControl = AnimationWindowControl; PlaybackControlsFactory.deps = [_animationSpeedSlider["default"]]; function PlaybackControlsFactory(AnimationSpeedSlider) { // eslint-disable-next-line complexity var PlaybackControls = function PlaybackControls(_ref2) { var _ref2$isAnimatable = _ref2.isAnimatable, isAnimatable = _ref2$isAnimatable === void 0 ? true : _ref2$isAnimatable, isAnimating = _ref2.isAnimating, width = _ref2.width, speed = _ref2.speed, _ref2$animationWindow = _ref2.animationWindow, animationWindow = _ref2$animationWindow === void 0 ? _defaultSettings.ANIMATION_WINDOW.free : _ref2$animationWindow, setFilterAnimationWindow = _ref2.setFilterAnimationWindow, updateAnimationSpeed = _ref2.updateAnimationSpeed, _ref2$pauseAnimation = _ref2.pauseAnimation, pauseAnimation = _ref2$pauseAnimation === void 0 ? nop : _ref2$pauseAnimation, _ref2$resetAnimation = _ref2.resetAnimation, resetAnimation = _ref2$resetAnimation === void 0 ? nop : _ref2$resetAnimation, _ref2$startAnimation = _ref2.startAnimation, startAnimation = _ref2$startAnimation === void 0 ? nop : _ref2$startAnimation, _ref2$playbackIcons = _ref2.playbackIcons, playbackIcons = _ref2$playbackIcons === void 0 ? DEFAULT_ICONS : _ref2$playbackIcons, _ref2$animationItems = _ref2.animationItems, animationItems = _ref2$animationItems === void 0 ? DEFAULT_ANIMATE_ITEMS : _ref2$animationItems, _ref2$buttonStyle = _ref2.buttonStyle, buttonStyle = _ref2$buttonStyle === void 0 ? 'secondary' : _ref2$buttonStyle, _ref2$buttonHeight = _ref2.buttonHeight, buttonHeight = _ref2$buttonHeight === void 0 ? DEFAULT_BUTTON_HEIGHT : _ref2$buttonHeight; 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 }), style: { width: "".concat(width, "px") } }, setFilterAnimationWindow ? /*#__PURE__*/_react["default"].createElement(IconButton, (0, _extends2["default"])({ "data-tip": true, "data-for": "animate-window", className: (0, _classnames["default"])('playback-control-button', { active: showAnimationWindowControl }), onClick: toggleAnimationWindowControl }, btnStyle), function () { if (animationItems[animationWindow]) { var WindowIcon = animationItems[animationWindow].icon; return /*#__PURE__*/_react["default"].createElement(WindowIcon, { height: buttonHeight }); } return null; }(), animationItems[animationWindow] && animationItems[animationWindow].tooltip ? /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, { id: "animate-window", place: "top", delayShow: 500, effect: "solid" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: animationItems[animationWindow].tooltip })) : null) : null, showAnimationWindowControl ? /*#__PURE__*/_react["default"].createElement(AnimationWindowControl, { onClick: setFilterAnimationWindow, selected: animationWindow, onHide: toggleAnimationWindowControl, height: buttonHeight, btnStyle: btnStyle, animationItems: animationItems }) : null, showAnimationWindowControl || !updateAnimationSpeed ? null : /*#__PURE__*/_react["default"].createElement(StyledSpeedControl, null, /*#__PURE__*/_react["default"].createElement(IconButton, (0, _extends2["default"])({ "data-tip": true, "data-for": "animate-speed", className: "playback-control-button" }, btnStyle, { onClick: hideAndShowSpeedControl }), /*#__PURE__*/_react["default"].createElement(playbackIcons.speed, { height: buttonHeight }), /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, { id: "animate-speed", place: "top", delayShow: DELAY_SHOW, effect: "solid" }, /*#__PURE__*/_react["default"].createElement("span", null, (0, _dataUtils.preciseRound)(speed, 1), "x"))), isSpeedControlVisible ? /*#__PURE__*/_react["default"].createElement(AnimationSpeedSlider, { onHide: hideAndShowSpeedControl, updateAnimationSpeed: updateAnimationSpeed, speed: speed }) : null), showAnimationWindowControl ? null : /*#__PURE__*/_react["default"].createElement(IconButton, (0, _extends2["default"])({ "data-tip": true, "data-for": "animate-reset", className: "playback-control-button", onClick: resetAnimation }, btnStyle), /*#__PURE__*/_react["default"].createElement(playbackIcons.reset, { height: buttonHeight }), /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, { id: "animate-reset", place: "top", delayShow: DELAY_SHOW, effect: "solid" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: "tooltip.reset" }))), showAnimationWindowControl ? null : /*#__PURE__*/_react["default"].createElement(IconButton, (0, _extends2["default"])({ "data-tip": true, "data-for": "animate-play-pause", className: (0, _classnames["default"])('playback-control-button', { active: isAnimating }), onClick: isAnimating ? pauseAnimation : startAnimation, hide: isSpeedControlVisible }, btnStyle), isAnimating ? /*#__PURE__*/_react["default"].createElement(playbackIcons.pause, { height: buttonHeight }) : /*#__PURE__*/_react["default"].createElement(playbackIcons.play, { height: buttonHeight }), /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, { id: "animate-play-pause", place: "top", delayShow: DELAY_SHOW, effect: "solid" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: isAnimating ? 'tooltip.pause' : 'tooltip.play' })))); }; return PlaybackControls; } var _default = PlaybackControlsFactory; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/common/animation-control/playback-controls.js"],"names":["DELAY_SHOW","DEFAULT_BUTTON_HEIGHT","StyledAnimationControls","styled","div","StyledSpeedControl","IconButton","Button","props","collapsed","theme","playbackButtonColor","playbackButtonBgColor","fontFamily","playbackButtonActBgColor","nop","DEFAULT_ICONS","reset","_","play","pause","speed","Rocket","animationFree","FreeWindow","animationIncremental","AnchorWindow","DEFAULT_ANIMATE_ITEMS","ANIMATION_WINDOW","free","id","icon","tooltip","incremental","AnimationWindowControl","onClick","selected","onHide","height","animationItems","btnStyle","Object","values","filter","item","map","PlaybackControlsFactory","deps","AnimationSpeedSliderFactory","AnimationSpeedSlider","PlaybackControls","isAnimatable","isAnimating","width","animationWindow","setFilterAnimationWindow","updateAnimationSpeed","pauseAnimation","resetAnimation","startAnimation","playbackIcons","buttonStyle","buttonHeight","isSpeedControlVisible","toggleSpeedControl","showAnimationWindowControl","setShowAnimationWindowControl","toggleAnimationWindowControl","hideAndShowSpeedControl","window","setTimeout","disabled","active","WindowIcon"],"mappings":"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","sourcesContent":["// Copyright (c) 2021 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport React, {useState, useCallback} from 'react';\nimport styled from 'styled-components';\nimport classnames from 'classnames';\nimport {FormattedMessage} from 'localization';\nimport {Button, Tooltip} from 'components/common/styled-components';\nimport AnimationSpeedSliderFactory from './animation-speed-slider';\nimport {Reset, Play, Pause, Rocket, AnchorWindow, FreeWindow} from 'components/common/icons';\nimport {ANIMATION_WINDOW} from 'constants/default-settings';\nimport {preciseRound} from 'utils/data-utils';\n\nconst DELAY_SHOW = 500;\nconst DEFAULT_BUTTON_HEIGHT = '20px';\n\nconst StyledAnimationControls = styled.div`\n  display: flex;\n  position: relative;\n\n  &.disabled {\n    opacity: 0.4;\n    pointer-events: none;\n  }\n`;\n\nconst StyledSpeedControl = styled.div`\n  display: flex;\n  align-items: center;\n\n  .animation-control__speed-slider {\n    left: 0;\n  }\n`;\n\nexport const IconButton = styled(Button)`\n  width: ${props => (props.collapsed ? 0 : 32)}px;\n  height: 32px;\n  color: ${props => props.theme.playbackButtonColor};\n  background-color: ${props => props.theme.playbackButtonBgColor};\n  border-radius: 4px;\n  margin-left: 7px;\n  border: 0;\n  padding: 0;\n\n  .__react_component_tooltip {\n    font-family: ${props => props.theme.fontFamily};\n  }\n  svg {\n    margin: 0;\n  }\n  &.active {\n    background-color: ${props => props.theme.playbackButtonActBgColor};\n  }\n`;\n\nfunction nop() {}\nconst DEFAULT_ICONS = {\n  /* eslint-disable react/display-name */\n  reset: _ => <Reset height=\"18px\" />,\n  play: _ => <Play height=\"18px\" />,\n  pause: _ => <Pause height=\"18px\" />,\n  /* eslint-enable react/display-name */\n  speed: Rocket,\n  animationFree: FreeWindow,\n  animationIncremental: AnchorWindow\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};\n\nexport const AnimationWindowControl = ({\n  onClick,\n  selected,\n  onHide,\n  height,\n  animationItems,\n  btnStyle = {}\n}) => (\n  <div>\n    {Object.values(animationItems)\n      .filter(item => item.id !== selected)\n      .map(item => (\n        <IconButton\n          key={item.id}\n          data-tip\n          data-for={`${item.id}-tooltip`}\n          className=\"playback-control-button\"\n          onClick={() => {\n            onClick(item.id);\n            onHide();\n          }}\n          {...btnStyle}\n        >\n          <item.icon height={height} />\n          {item.tooltip ? (\n            <Tooltip id={`${item.id}-tooltip`} effect=\"solid\" place=\"top\">\n              <FormattedMessage id={item.tooltip} />\n            </Tooltip>\n          ) : null}\n        </IconButton>\n      ))}\n  </div>\n);\n\nPlaybackControlsFactory.deps = [AnimationSpeedSliderFactory];\nfunction PlaybackControlsFactory(AnimationSpeedSlider) {\n  // eslint-disable-next-line complexity\n  const PlaybackControls = ({\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  }) => {\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    return (\n      <StyledAnimationControls\n        className={classnames('playback-controls', {\n          disabled: !isAnimatable\n        })}\n        style={{width: `${width}px`}}\n      >\n        {/** Window */}\n        {setFilterAnimationWindow ? (\n          <IconButton\n            data-tip\n            data-for=\"animate-window\"\n            className={classnames('playback-control-button', {active: showAnimationWindowControl})}\n            onClick={toggleAnimationWindowControl}\n            {...btnStyle}\n          >\n            {(() => {\n              if (animationItems[animationWindow]) {\n                const WindowIcon = animationItems[animationWindow].icon;\n                return <WindowIcon height={buttonHeight} />;\n              }\n              return null;\n            })()}\n            {animationItems[animationWindow] && animationItems[animationWindow].tooltip ? (\n              <Tooltip id=\"animate-window\" place=\"top\" delayShow={500} effect=\"solid\">\n                <FormattedMessage id={animationItems[animationWindow].tooltip} />\n              </Tooltip>\n            ) : null}\n          </IconButton>\n        ) : null}\n\n        {showAnimationWindowControl ? (\n          <AnimationWindowControl\n            onClick={setFilterAnimationWindow}\n            selected={animationWindow}\n            onHide={toggleAnimationWindowControl}\n            height={buttonHeight}\n            btnStyle={btnStyle}\n            animationItems={animationItems}\n          />\n        ) : null}\n\n        {/** Speed */}\n        {showAnimationWindowControl || !updateAnimationSpeed ? null : (\n          <StyledSpeedControl>\n            <IconButton\n              data-tip\n              data-for=\"animate-speed\"\n              className=\"playback-control-button\"\n              {...btnStyle}\n              onClick={hideAndShowSpeedControl}\n            >\n              <playbackIcons.speed height={buttonHeight} />\n              <Tooltip id=\"animate-speed\" place=\"top\" delayShow={DELAY_SHOW} effect=\"solid\">\n                <span>{preciseRound(speed, 1)}x</span>\n              </Tooltip>\n            </IconButton>\n            {isSpeedControlVisible ? (\n              <AnimationSpeedSlider\n                onHide={hideAndShowSpeedControl}\n                updateAnimationSpeed={updateAnimationSpeed}\n                speed={speed}\n              />\n            ) : null}\n          </StyledSpeedControl>\n        )}\n\n        {/** Reset */}\n        {showAnimationWindowControl ? null : (\n          <IconButton\n            data-tip\n            data-for=\"animate-reset\"\n            className=\"playback-control-button\"\n            onClick={resetAnimation}\n            {...btnStyle}\n          >\n            <playbackIcons.reset height={buttonHeight} />\n            <Tooltip id=\"animate-reset\" place=\"top\" delayShow={DELAY_SHOW} effect=\"solid\">\n              <FormattedMessage id=\"tooltip.reset\" />\n            </Tooltip>\n          </IconButton>\n        )}\n\n        {/** Play and pause */}\n        {showAnimationWindowControl ? null : (\n          <IconButton\n            data-tip\n            data-for=\"animate-play-pause\"\n            className={classnames('playback-control-button', {active: isAnimating})}\n            onClick={isAnimating ? pauseAnimation : startAnimation}\n            hide={isSpeedControlVisible}\n            {...btnStyle}\n          >\n            {isAnimating ? (\n              <playbackIcons.pause height={buttonHeight} />\n            ) : (\n              <playbackIcons.play height={buttonHeight} />\n            )}\n            <Tooltip id=\"animate-play-pause\" place=\"top\" delayShow={DELAY_SHOW} effect=\"solid\">\n              <FormattedMessage id={isAnimating ? 'tooltip.pause' : 'tooltip.play'} />\n            </Tooltip>\n          </IconButton>\n        )}\n      </StyledAnimationControls>\n    );\n  };\n  return PlaybackControls;\n}\n\nexport default PlaybackControlsFactory;\n"]}