kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
211 lines (168 loc) • 26.1 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 _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
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 _moment = _interopRequireDefault(require("moment"));
var _window = require("global/window");
var _slider = _interopRequireDefault(require("../slider/slider"));
var _styledComponents2 = require("../styled-components");
var _speedControl = _interopRequireDefault(require("./speed-control"));
var _playbackControls = _interopRequireDefault(require("./playback-controls"));
var _floatingTimeDisplay = _interopRequireDefault(require("./floating-time-display"));
var _defaultSettings = require("../../../constants/default-settings");
var _templateObject, _templateObject2, _templateObject3;
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
var SliderWrapper = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n position: relative;\n flex-grow: 1;\n margin-right: 24px;\n margin-left: 24px;\n"])));
var AnimationWidgetInner = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n display: flex;\n align-items: center;\n height: 32px;\n\n .animation-control__speed-control {\n margin-right: -10px;\n\n .animation-control__speed-slider {\n right: calc(0% - 10px);\n }\n }\n"])));
var StyledDomain = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-weight: 400;\n font-size: 10px;\n"])), function (props) {
return props.theme.titleTextColor;
});
var defaultTimeFormat = 'MM/DD/YY hh:mm:ss';
var BUTTON_HEIGHT = '18px';
AnimationControlFactory.deps = [_speedControl["default"], _playbackControls["default"], _floatingTimeDisplay["default"]];
function AnimationControlFactory(SpeedControl, AnimationPlaybacks, FloatingTimeDisplay) {
var AnimationControl = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(AnimationControl, _Component);
var _super = _createSuper(AnimationControl);
function AnimationControl(props) {
var _this;
(0, _classCallCheck2["default"])(this, AnimationControl);
_this = _super.call(this, props);
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onSlider1Change", function (val) {
var domain = _this.props.animationConfig.domain;
if (val >= domain[0] && val <= domain[1]) {
_this.props.updateAnimationTime(val);
}
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_updateAnimationTime", function () {
var domain = _this.props.animationConfig.domain;
_this.props.updateAnimationTime(domain[0]);
_this._startAnimation();
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_startAnimation", function () {
_this._pauseAnimation();
_this.setState({
isAnimating: true
});
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_nextFrame", function () {
_this._animation = null;
var _this$props$animation = _this.props.animationConfig,
currentTime = _this$props$animation.currentTime,
domain = _this$props$animation.domain,
_this$props$animation2 = _this$props$animation.speed,
speed = _this$props$animation2 === void 0 ? 1 : _this$props$animation2;
var adjustedSpeed = (domain[1] - domain[0]) / _defaultSettings.BASE_SPEED * speed;
var nextTime = currentTime + speed > domain[1] ? domain[0] : currentTime + adjustedSpeed;
_this.props.updateAnimationTime(nextTime);
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_pauseAnimation", function () {
if (_this._animation) {
(0, _window.cancelAnimationFrame)(_this._animation);
_this._animation = null;
}
_this.setState({
isAnimating: false
});
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "toggleSpeedControl", function () {
_this.setState({
showSpeedControl: !_this.state.showSpeedControl
});
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onChange", function () {
_this.toggleSpeedControl();
});
_this.state = {
isAnimating: false,
width: 288,
showSpeedControl: false
};
_this._animation = null;
return _this;
}
(0, _createClass2["default"])(AnimationControl, [{
key: "componentDidUpdate",
value: function componentDidUpdate() {
if (!this._animation && this.state.isAnimating) {
this._animation = (0, _window.requestAnimationFrame)(this._nextFrame);
}
}
}, {
key: "render",
value: function render() {
var _this$props$animation3 = this.props.animationConfig,
currentTime = _this$props$animation3.currentTime,
domain = _this$props$animation3.domain,
speed = _this$props$animation3.speed;
var showSpeedControl = this.state.showSpeedControl;
return (/*#__PURE__*/_react["default"].createElement(_styledComponents2.BottomWidgetInner, {
className: "bottom-widget--inner"
}, /*#__PURE__*/_react["default"].createElement(AnimationWidgetInner, {
className: "animation-widget--inner"
}, /*#__PURE__*/_react["default"].createElement("div", {
style: {
marginLeft: '-10px'
}
}, /*#__PURE__*/_react["default"].createElement(AnimationPlaybacks, {
className: "animation-control-playpause",
startAnimation: this._startAnimation,
isAnimating: this.state.isAnimating,
pauseAnimation: this._pauseAnimation,
resetAnimation: this._resetAnimation,
buttonHeight: BUTTON_HEIGHT,
buttonStyle: "link"
})), /*#__PURE__*/_react["default"].createElement(StyledDomain, {
className: "animation-control__time-domain"
}, /*#__PURE__*/_react["default"].createElement("span", null, _moment["default"].utc(domain[0]).format(defaultTimeFormat))), /*#__PURE__*/_react["default"].createElement(SliderWrapper, {
className: "animation-control__slider"
}, /*#__PURE__*/_react["default"].createElement(_slider["default"], {
showValues: false,
isRanged: false,
minValue: domain ? domain[0] : 0,
maxValue: domain ? domain[1] : 1,
value1: currentTime,
onSlider1Change: this.onSlider1Change,
enableBarDrag: true
})), /*#__PURE__*/_react["default"].createElement(StyledDomain, {
className: "animation-control__time-domain"
}, /*#__PURE__*/_react["default"].createElement("span", null, _moment["default"].utc(domain[1]).format(defaultTimeFormat))), /*#__PURE__*/_react["default"].createElement("div", {
className: "animation-control__speed-control"
}, /*#__PURE__*/_react["default"].createElement(SpeedControl, {
onClick: this.toggleSpeedControl,
showSpeedControl: showSpeedControl,
updateAnimationSpeed: this.props.updateAnimationSpeed,
speed: speed,
buttonHeight: BUTTON_HEIGHT
}))), /*#__PURE__*/_react["default"].createElement(FloatingTimeDisplay, {
currentTime: currentTime
}))
);
}
}]);
return AnimationControl;
}(_react.Component);
AnimationControl.defaultProps = {
sliderHandleWidth: 12,
onChange: function onChange() {}
};
return AnimationControl;
}
var _default = exports["default"] = AnimationControlFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/common/animation-control/animation-control.js"],"names":["SliderWrapper","styled","div","AnimationWidgetInner","StyledDomain","props","theme","titleTextColor","defaultTimeFormat","BUTTON_HEIGHT","AnimationControlFactory","deps","SpeedControlFactory","AnimationPlaybacksFactory","FloatingTimeDisplayFactory","SpeedControl","AnimationPlaybacks","FloatingTimeDisplay","AnimationControl","val","domain","animationConfig","updateAnimationTime","_startAnimation","_pauseAnimation","setState","isAnimating","_animation","currentTime","speed","adjustedSpeed","BASE_SPEED","nextTime","showSpeedControl","state","toggleSpeedControl","width","_nextFrame","marginLeft","_resetAnimation","moment","utc","format","onSlider1Change","updateAnimationSpeed","Component","defaultProps","sliderHandleWidth","onChange"],"mappings":"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","sourcesContent":["// Copyright (c) 2023 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, {Component} from 'react';\nimport styled from 'styled-components';\nimport moment from 'moment';\nimport {requestAnimationFrame, cancelAnimationFrame} from 'global/window';\n\nimport Slider from 'components/common/slider/slider';\nimport {BottomWidgetInner} from 'components/common/styled-components';\nimport SpeedControlFactory from './speed-control';\nimport AnimationPlaybacksFactory from './playback-controls';\nimport FloatingTimeDisplayFactory from './floating-time-display';\nimport {BASE_SPEED} from 'constants/default-settings';\n\nconst SliderWrapper = styled.div`\n  display: flex;\n  position: relative;\n  flex-grow: 1;\n  margin-right: 24px;\n  margin-left: 24px;\n`;\n\nconst AnimationWidgetInner = styled.div`\n  position: relative;\n  display: flex;\n  align-items: center;\n  height: 32px;\n\n  .animation-control__speed-control {\n    margin-right: -10px;\n\n    .animation-control__speed-slider {\n      right: calc(0% - 10px);\n    }\n  }\n`;\n\nconst StyledDomain = styled.div`\n  color: ${props => props.theme.titleTextColor};\n  font-weight: 400;\n  font-size: 10px;\n`;\n\nconst defaultTimeFormat = 'MM/DD/YY hh:mm:ss';\nconst BUTTON_HEIGHT = '18px';\n\nAnimationControlFactory.deps = [\n  SpeedControlFactory,\n  AnimationPlaybacksFactory,\n  FloatingTimeDisplayFactory\n];\n\nfunction AnimationControlFactory(\n  SpeedControl,\n  AnimationPlaybacks,\n  FloatingTimeDisplay\n) {\n  class AnimationControl extends Component {\n    constructor(props) {\n      super(props);\n      this.state = {\n        isAnimating: false,\n        width: 288,\n        showSpeedControl: false\n      };\n      this._animation = null;\n    }\n\n    componentDidUpdate() {\n      if (!this._animation && this.state.isAnimating) {\n        this._animation = requestAnimationFrame(this._nextFrame);\n      }\n    }\n\n    onSlider1Change = val => {\n      const {domain} = this.props.animationConfig;\n      if (val >= domain[0] && val <= domain[1]) {\n        this.props.updateAnimationTime(val);\n      }\n    };\n\n    _updateAnimationTime = () => {\n      const {domain} = this.props.animationConfig;\n      this.props.updateAnimationTime(domain[0]);\n      this._startAnimation();\n    };\n\n    _startAnimation = () => {\n      this._pauseAnimation();\n      this.setState({isAnimating: true});\n    };\n\n    _nextFrame = () => {\n      this._animation = null;\n      const {currentTime, domain, speed = 1} = this.props.animationConfig;\n      const adjustedSpeed = ((domain[1] - domain[0]) / BASE_SPEED) * speed;\n      const nextTime =\n        currentTime + speed > domain[1]\n          ? domain[0]\n          : currentTime + adjustedSpeed;\n      this.props.updateAnimationTime(nextTime);\n    };\n\n    _pauseAnimation = () => {\n      if (this._animation) {\n        cancelAnimationFrame(this._animation);\n        this._animation = null;\n      }\n      this.setState({isAnimating: false});\n    };\n\n    toggleSpeedControl = () => {\n      this.setState({showSpeedControl: !this.state.showSpeedControl});\n    };\n\n    onChange = () => {\n      this.toggleSpeedControl();\n    };\n\n    render() {\n      const {currentTime, domain, speed} = this.props.animationConfig;\n      const {showSpeedControl} = this.state;\n\n      return (\n        <BottomWidgetInner className=\"bottom-widget--inner\">\n          <AnimationWidgetInner className=\"animation-widget--inner\">\n            <div style={{marginLeft: '-10px'}}>\n              <AnimationPlaybacks\n                className=\"animation-control-playpause\"\n                startAnimation={this._startAnimation}\n                isAnimating={this.state.isAnimating}\n                pauseAnimation={this._pauseAnimation}\n                resetAnimation={this._resetAnimation}\n                buttonHeight={BUTTON_HEIGHT}\n                buttonStyle=\"link\"\n              />\n            </div>\n            <StyledDomain className=\"animation-control__time-domain\">\n              <span>{moment.utc(domain[0]).format(defaultTimeFormat)}</span>\n            </StyledDomain>\n            <SliderWrapper className=\"animation-control__slider\">\n              <Slider\n                showValues={false}\n                isRanged={false}\n                minValue={domain ? domain[0] : 0}\n                maxValue={domain ? domain[1] : 1}\n                value1={currentTime}\n                onSlider1Change={this.onSlider1Change}\n                enableBarDrag={true}\n              />\n            </SliderWrapper>\n            <StyledDomain className=\"animation-control__time-domain\">\n              <span>{moment.utc(domain[1]).format(defaultTimeFormat)}</span>\n            </StyledDomain>\n            <div className=\"animation-control__speed-control\">\n              <SpeedControl\n                onClick={this.toggleSpeedControl}\n                showSpeedControl={showSpeedControl}\n                updateAnimationSpeed={this.props.updateAnimationSpeed}\n                speed={speed}\n                buttonHeight={BUTTON_HEIGHT}\n              />\n            </div>\n          </AnimationWidgetInner>\n          <FloatingTimeDisplay currentTime={currentTime} />\n        </BottomWidgetInner>\n      );\n    }\n  }\n\n  AnimationControl.defaultProps = {\n    sliderHandleWidth: 12,\n    onChange: () => {}\n  };\n\n  return AnimationControl;\n}\n\nexport default AnimationControlFactory;\n"]}