UNPKG

kepler.gl.geoiq

Version:

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

327 lines (267 loc) 32.7 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); 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 _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _moment = _interopRequireDefault(require("moment")); var _window = require("global/window"); var _classnames = _interopRequireDefault(require("classnames")); var _lodash = _interopRequireDefault(require("lodash.throttle")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _reselect = require("reselect"); var _icons = require("./icons"); var _styledComponents2 = require("./styled-components"); var _filterUtils = require("../../utils/filter-utils"); var _rangeSlider = _interopRequireDefault(require("./range-slider")); var _timeSliderMarker = _interopRequireDefault(require("./time-slider-marker")); function _templateObject4() { var data = (0, _taggedTemplateLiteral2["default"])(["\n svg {\n margin: 0 6px;\n }\n"]); _templateObject4 = function _templateObject4() { return data; }; return data; } function _templateObject3() { var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 12px;\n margin-right: 42px;\n\n &.disabled {\n opacity: 0.4;\n pointer-events: none;\n }\n"]); _templateObject3 = function _templateObject3() { return data; }; return data; } function _templateObject2() { var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n height: ", ";\n align-items: center;\n font-size: 11px;\n justify-content: ", ";\n color: ", ";\n\n .horizontal-bar {\n padding: 0 12px;\n }\n\n .time-value {\n display: flex;\n flex-direction: ", ";\n align-items: flex-start;\n }\n\n .time-value:last-child {\n align-items: flex-end;\n }\n"]); _templateObject2 = function _templateObject2() { return data; }; return data; } function _templateObject() { var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-top: ", ";\n align-items: flex-end;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n"]); _templateObject = function _templateObject() { return data; }; return data; } var defaultTimeFormat = function defaultTimeFormat(val) { return _moment["default"].utc(val).format('MM/DD/YY hh:mma'); }; var animationControlWidth = 140; var StyledSliderContainer = _styledComponents["default"].div(_templateObject(), function (props) { return props.isEnlarged ? '12px' : '0px'; }); var TimeRangeSlider = /*#__PURE__*/ function (_Component) { (0, _inherits2["default"])(TimeRangeSlider, _Component); function TimeRangeSlider(_props) { var _this; (0, _classCallCheck2["default"])(this, TimeRangeSlider); _this = (0, _possibleConstructorReturn2["default"])(this, (0, _getPrototypeOf2["default"])(TimeRangeSlider).call(this, _props)); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "domainSelector", function (props) { return props.domain; }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "titleFormatter", (0, _reselect.createSelector)(_this.domainSelector, function (domain) { return (0, _filterUtils.getTimeWidgetTitleFormatter)(domain); })); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_sliderUpdate", function (args) { _this._sliderThrottle.cancel(); _this._sliderThrottle(args); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_resetAnimation", function () { var _this$props = _this.props, domain = _this$props.domain, value = _this$props.value; var value0 = domain[0]; var value1 = value0 + value[1] - value[0]; _this.props.onChange([value0, value1]); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_startAnimation", function () { _this._pauseAnimation(); _this.props.toggleAnimation(); _this.setState({ isAnimating: true }); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_pauseAnimation", function () { if (_this._animation) { (0, _window.cancelAnimationFrame)(_this._animation); _this.props.toggleAnimation(); _this._animation = null; } _this.setState({ isAnimating: false }); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_nextFrame", function () { _this._animation = null; var _this$props2 = _this.props, domain = _this$props2.domain, value = _this$props2.value; var speed = (domain[1] - domain[0]) / _filterUtils.BASE_SPEED * _this.props.speed; // loop when reaches the end var value0 = value[1] + speed > domain[1] ? domain[0] : value[0] + speed; var value1 = value0 + value[1] - value[0]; _this.props.onChange([value0, value1]); }); _this.state = { isAnimating: false, width: 288 }; _this._animation = null; _this._sliderThrottle = (0, _lodash["default"])(function () { var _this$props3; return (_this$props3 = _this.props).onChange.apply(_this$props3, arguments); }, 20); return _this; } (0, _createClass2["default"])(TimeRangeSlider, [{ 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$props4 = this.props, domain = _this$props4.domain, value = _this$props4.value, isEnlarged = _this$props4.isEnlarged; var isAnimating = this.state.isAnimating; return _react["default"].createElement("div", { className: "time-range-slider" }, _react["default"].createElement(TimeTitle, { timeFormat: this.titleFormatter(this.props), value: value, isEnlarged: isEnlarged }), _react["default"].createElement(StyledSliderContainer, { className: "time-range-slider__container", isEnlarged: isEnlarged }, isEnlarged ? _react["default"].createElement(AnimationControls, { isAnimatable: this.props.isAnimatable, isEnlarged: isEnlarged, isAnimating: isAnimating, pauseAnimation: this._pauseAnimation, resetAnimation: this._resetAnimation, startAnimation: this._startAnimation }) : null, _react["default"].createElement("div", { style: { width: isEnlarged ? "calc(100% - ".concat(animationControlWidth, "px)") : '100%' } }, _react["default"].createElement(_rangeSlider["default"], { range: domain, value0: value[0], value1: value[1], histogram: this.props.histogram, lineChart: this.props.lineChart, plotType: this.props.plotType, isEnlarged: isEnlarged, showInput: false, step: this.props.step, onChange: this._sliderUpdate, xAxis: _timeSliderMarker["default"] })))); } }]); return TimeRangeSlider; }(_react.Component); exports["default"] = TimeRangeSlider; (0, _defineProperty2["default"])(TimeRangeSlider, "propTypes", { onChange: _propTypes["default"].func.isRequired, domain: _propTypes["default"].arrayOf(_propTypes["default"].number).isRequired, value: _propTypes["default"].arrayOf(_propTypes["default"].number).isRequired, step: _propTypes["default"].number.isRequired, plotType: _propTypes["default"].string, histogram: _propTypes["default"].arrayOf(_propTypes["default"].any), lineChart: _propTypes["default"].object, toggleAnimation: _propTypes["default"].func.isRequired, isAnimatable: _propTypes["default"].bool, isEnlarged: _propTypes["default"].bool, speed: _propTypes["default"].number }); var TimeValueWrapper = _styledComponents["default"].div(_templateObject2(), function (props) { return props.theme.secondaryInputHeight; }, function (props) { return props.isEnlarged ? 'center' : 'space-between'; }, function (props) { return props.theme.labelColor; }, function (props) { return props.isEnlarged ? 'row' : 'column'; }); var TimeTitle = function TimeTitle(_ref) { var value = _ref.value, isEnlarged = _ref.isEnlarged, _ref$timeFormat = _ref.timeFormat, timeFormat = _ref$timeFormat === void 0 ? defaultTimeFormat : _ref$timeFormat; return _react["default"].createElement(TimeValueWrapper, { isEnlarged: isEnlarged }, _react["default"].createElement(TimeValue, { key: 0, value: _moment["default"].utc(value[0]).format(timeFormat), split: !isEnlarged }), isEnlarged ? _react["default"].createElement("div", { className: "horizontal-bar" }, _react["default"].createElement(_icons.Minus, { height: "12px" })) : null, _react["default"].createElement(TimeValue, { key: 1, value: _moment["default"].utc(value[1]).format(timeFormat), split: !isEnlarged })); }; var TimeValue = function TimeValue(_ref2) { var value = _ref2.value, split = _ref2.split; return (// render two lines if not enlarged _react["default"].createElement("div", { className: "time-value" }, split ? value.split(' ').map(function (v, i) { return _react["default"].createElement("div", { key: i }, i === 0 ? _react["default"].createElement(_styledComponents2.SelectText, null, v) : _react["default"].createElement(_styledComponents2.SelectTextBold, null, v)); }) : _react["default"].createElement(_styledComponents2.SelectTextBold, null, value)) ); }; var StyledAnimationControls = _styledComponents["default"].div(_templateObject3()); var IconButton = _styledComponents2.Button.extend(_templateObject4()); var AnimationControls = function AnimationControls(_ref3) { var isAnimatable = _ref3.isAnimatable, isAnimating = _ref3.isAnimating, pauseAnimation = _ref3.pauseAnimation, resetAnimation = _ref3.resetAnimation, startAnimation = _ref3.startAnimation; return _react["default"].createElement(StyledAnimationControls, { className: (0, _classnames["default"])('time-range-slider__control', { disabled: !isAnimatable }) }, _react["default"].createElement(_styledComponents2.ButtonGroup, null, _react["default"].createElement(IconButton, { className: "playback-control-button", onClick: resetAnimation, secondary: true }, _react["default"].createElement(_icons.Reset, { height: "12px" })), _react["default"].createElement(IconButton, { className: (0, _classnames["default"])('playback-control-button', { active: isAnimating }), onClick: isAnimating ? pauseAnimation : startAnimation, secondary: true }, isAnimating ? _react["default"].createElement(_icons.Pause, { height: "12px" }) : _react["default"].createElement(_icons.Play, { height: "12px" })))); }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/common/time-range-slider.js"],"names":["defaultTimeFormat","val","moment","utc","format","animationControlWidth","StyledSliderContainer","styled","div","props","isEnlarged","TimeRangeSlider","domain","domainSelector","args","_sliderThrottle","cancel","value","value0","value1","onChange","_pauseAnimation","toggleAnimation","setState","isAnimating","_animation","speed","BASE_SPEED","state","width","_nextFrame","titleFormatter","isAnimatable","_resetAnimation","_startAnimation","histogram","lineChart","plotType","step","_sliderUpdate","TimeSliderMarker","Component","PropTypes","func","isRequired","arrayOf","number","string","any","object","bool","TimeValueWrapper","theme","secondaryInputHeight","labelColor","TimeTitle","timeFormat","TimeValue","split","map","v","i","StyledAnimationControls","IconButton","Button","extend","AnimationControls","pauseAnimation","resetAnimation","startAnimation","disabled","active"],"mappings":"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","sourcesContent":["// Copyright (c) 2019 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 PropTypes from 'prop-types';\nimport moment from 'moment';\nimport {requestAnimationFrame, cancelAnimationFrame} from 'global/window';\nimport classnames from 'classnames';\nimport throttle from 'lodash.throttle';\nimport styled from 'styled-components';\nimport {createSelector} from 'reselect';\nimport {Play, Reset, Pause, Minus} from 'components/common/icons';\nimport {SelectTextBold, SelectText, Button, ButtonGroup} from 'components/common/styled-components';\nimport {getTimeWidgetTitleFormatter, BASE_SPEED} from 'utils/filter-utils';\nimport RangeSlider from './range-slider';\nimport TimeSliderMarker from './time-slider-marker';\n\nconst defaultTimeFormat = val => moment.utc(val).format('MM/DD/YY hh:mma');\nconst animationControlWidth = 140;\n\nconst StyledSliderContainer = styled.div`\n  margin-top: ${props => props.isEnlarged ? '12px' : '0px'};\n  align-items: flex-end;\n  display: flex;\n  flex-direction: row;\n  justify-content: space-between;\n`;\n\nexport default class TimeRangeSlider extends Component {\n  static propTypes = {\n    onChange: PropTypes.func.isRequired,\n    domain: PropTypes.arrayOf(PropTypes.number).isRequired,\n    value: PropTypes.arrayOf(PropTypes.number).isRequired,\n    step: PropTypes.number.isRequired,\n    plotType: PropTypes.string,\n    histogram: PropTypes.arrayOf(PropTypes.any),\n    lineChart: PropTypes.object,\n    toggleAnimation: PropTypes.func.isRequired,\n    isAnimatable: PropTypes.bool,\n    isEnlarged: PropTypes.bool,\n    speed: PropTypes.number\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      isAnimating: false,\n      width: 288\n    };\n    this._animation = null;\n    this._sliderThrottle = throttle((...value) => this.props.onChange(...value), 20);\n  }\n\n  componentDidUpdate() {\n    if (!this._animation && this.state.isAnimating) {\n      this._animation = requestAnimationFrame(this._nextFrame);\n    }\n  }\n\n  domainSelector = props => props.domain;\n  titleFormatter = createSelector(this.domainSelector, domain =>\n    getTimeWidgetTitleFormatter(domain)\n  );\n\n  _sliderUpdate = args => {\n    this._sliderThrottle.cancel();\n    this._sliderThrottle(args);\n  };\n\n  _resetAnimation = () => {\n    const {domain, value} = this.props;\n    const value0 = domain[0];\n    const value1 = value0 + value[1] - value[0];\n    this.props.onChange([value0, value1]);\n  };\n\n  _startAnimation = () => {\n    this._pauseAnimation();\n    this.props.toggleAnimation();\n    this.setState({isAnimating: true});\n  };\n\n  _pauseAnimation = () => {\n    if (this._animation) {\n      cancelAnimationFrame(this._animation);\n      this.props.toggleAnimation();\n      this._animation = null;\n    }\n    this.setState({isAnimating: false});\n  };\n\n  _nextFrame = () => {\n    this._animation = null;\n\n    const {domain, value} = this.props;\n    const speed = ((domain[1] - domain[0]) / BASE_SPEED) * this.props.speed;\n\n    // loop when reaches the end\n    const value0 = value[1] + speed > domain[1] ? domain[0] : value[0] + speed;\n    const value1 = value0 + value[1] - value[0];\n    this.props.onChange([value0, value1]);\n  };\n\n  render() {\n    const {domain, value, isEnlarged} = this.props;\n    const {isAnimating} = this.state;\n\n    return (\n      <div className=\"time-range-slider\">\n        <TimeTitle\n          timeFormat={this.titleFormatter(this.props)}\n          value={value}\n          isEnlarged={isEnlarged}\n        />\n        <StyledSliderContainer\n          className=\"time-range-slider__container\"\n          isEnlarged={isEnlarged}>\n          {isEnlarged ? <AnimationControls\n            isAnimatable={this.props.isAnimatable}\n            isEnlarged={isEnlarged}\n            isAnimating={isAnimating}\n            pauseAnimation={this._pauseAnimation}\n            resetAnimation={this._resetAnimation}\n            startAnimation={this._startAnimation}\n          /> : null}\n          <div style={{width: isEnlarged ? `calc(100% - ${animationControlWidth}px)` : '100%'}}>\n            <RangeSlider\n              range={domain}\n              value0={value[0]}\n              value1={value[1]}\n              histogram={this.props.histogram}\n              lineChart={this.props.lineChart}\n              plotType={this.props.plotType}\n              isEnlarged={isEnlarged}\n              showInput={false}\n              step={this.props.step}\n              onChange={this._sliderUpdate}\n              xAxis={TimeSliderMarker}\n            />\n          </div>\n        </StyledSliderContainer>\n      </div>\n    );\n  }\n}\n\nconst TimeValueWrapper = styled.div`\n  display: flex;\n  height: ${props => props.theme.secondaryInputHeight};\n  align-items: center;\n  font-size: 11px;\n  justify-content: ${props => props.isEnlarged ? 'center' : 'space-between'};\n  color: ${props => props.theme.labelColor};\n\n  .horizontal-bar {\n    padding: 0 12px;\n  }\n\n  .time-value {\n    display: flex;\n    flex-direction: ${props => props.isEnlarged ? 'row' : 'column'};\n    align-items: flex-start;\n  }\n\n  .time-value:last-child {\n    align-items: flex-end;\n  }\n`;\n\nconst TimeTitle = ({value, isEnlarged, timeFormat = defaultTimeFormat}) => (\n  <TimeValueWrapper isEnlarged={isEnlarged}>\n    <TimeValue key={0} value={moment.utc(value[0]).format(timeFormat)} split={!isEnlarged}/>\n    {isEnlarged ? (\n      <div className=\"horizontal-bar\">\n        <Minus height=\"12px\"/>\n      </div>\n    ) : null}\n    <TimeValue key={1} value={moment.utc(value[1]).format(timeFormat)} split={!isEnlarged}/>\n  </TimeValueWrapper>\n);\n\nconst TimeValue = ({value, split}) => (\n  // render two lines if not enlarged\n  <div className=\"time-value\">\n    {split ? value.split(' ').map((v, i) => (\n      <div key={i}>\n        {i === 0 ? <SelectText>{v}</SelectText> :\n        <SelectTextBold>{v}</SelectTextBold>}\n      </div>\n    )) : <SelectTextBold>{value}</SelectTextBold>}\n  </div>\n);\n\nconst StyledAnimationControls = styled.div`\n  margin-bottom: 12px;\n  margin-right: 42px;\n\n  &.disabled {\n    opacity: 0.4;\n    pointer-events: none;\n  }\n`;\n\nconst IconButton = Button.extend`\n  svg {\n    margin: 0 6px;\n  }\n`;\n\nconst AnimationControls = ({\n  isAnimatable,\n  isAnimating,\n  pauseAnimation,\n  resetAnimation,\n  startAnimation\n}) => (\n  <StyledAnimationControls\n    className={classnames('time-range-slider__control', {disabled: !isAnimatable})}\n  >\n    <ButtonGroup>\n      <IconButton className=\"playback-control-button\"\n        onClick={resetAnimation} secondary>\n        <Reset height=\"12px\"/>\n      </IconButton>\n      <IconButton className={classnames('playback-control-button', {active: isAnimating})}\n        onClick={isAnimating ? pauseAnimation : startAnimation} secondary>\n        {isAnimating ? <Pause height=\"12px\"/> : <Play height=\"12px\"/>}\n      </IconButton>\n    </ButtonGroup>\n  </StyledAnimationControls>\n);\n"]}