UNPKG

kepler.gl.geoiq

Version:

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

189 lines (152 loc) 26.6 kB
"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 _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 _reselect = require("reselect"); var _fieldSelector = _interopRequireDefault(require("../common/field-selector")); var _styledComponents2 = require("../common/styled-components"); var _icons = require("../common/icons"); var _speedControl = _interopRequireDefault(require("../common/animation-control/speed-control")); var _timeRangeFilter = _interopRequireDefault(require("./time-range-filter")); var _floatingTimeDisplay = _interopRequireDefault(require("../common/animation-control/floating-time-display")); var _templateObject, _templateObject2; 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 TOP_SECTION_HEIGHT = '36px'; var TopSectionWrapper = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n width: 90%;\n color: ", ";\n height: ", ";\n\n .bottom-widget__y-axis {\n flex-grow: 1;\n margin-left: 20px;\n }\n\n .bottom-widget__field-select {\n width: 160px;\n display: inline-block;\n\n .item-selector__dropdown {\n background: transparent;\n padding: 4px 10px 4px 4px;\n border-color: transparent;\n\n :active,\n :focus,\n &.focus,\n &.active {\n background: transparent;\n border-color: transparent;\n }\n }\n\n .item-selector__dropdown:hover {\n background: transparent;\n border-color: transparent;\n\n .item-selector__dropdown__value {\n color: ", ";\n }\n }\n }\n\n .animation-control__speed-control {\n margin-right: -12px;\n\n .animation-control__speed-slider {\n right: calc(0% - 48px);\n }\n }\n"])), function (props) { return props.theme.labelColor; }, TOP_SECTION_HEIGHT, function (props) { return props.hoverColor ? props.theme[props.hoverColor] : props.theme.textColorHl; }); var StyledTitle = (0, _styledComponents["default"])(_styledComponents2.CenterFlexbox)(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n flex-grow: 0;\n color: ", ";\n margin-right: 10px;\n\n .bottom-widget__icon {\n margin-right: 6px;\n }\n .bottom-widget__icon.speed {\n margin-right: 0;\n }\n"])), function (props) { return props.theme.textColor; }); TimeWidgetFactory.deps = [_speedControl["default"], _timeRangeFilter["default"], _floatingTimeDisplay["default"]]; function TimeWidgetFactory(SpeedControl, TimeRangeFilter, FloatingTimeDisplay) { var TimeWidget = /*#__PURE__*/function (_Component) { (0, _inherits2["default"])(TimeWidget, _Component); var _super = _createSuper(TimeWidget); function TimeWidget() { var _this; (0, _classCallCheck2["default"])(this, TimeWidget); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = _super.call.apply(_super, [this].concat(args)); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "state", { showSpeedControl: false }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "fieldSelector", function (props) { return props.fields; }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "yAxisFieldsSelector", (0, _reselect.createSelector)(_this.fieldSelector, function (fields) { return fields.filter(function (f) { return f.type === 'integer' || f.type === 'real'; }); })); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_updateAnimationSpeed", function (speed) { return _this.props.updateAnimationSpeed(_this.props.index, speed); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_toggleSpeedControl", function () { return _this.setState({ showSpeedControl: !_this.state.showSpeedControl }); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_setFilterPlotYAxis", function (value) { return _this.props.setFilterPlot(_this.props.index, { yAxis: value }); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_updateAnimationSpeed", function (speed) { return _this.props.updateAnimationSpeed(_this.props.index, speed); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_toggleAnimation", function () { return _this.props.toggleAnimation(_this.props.index); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onClose", function () { return _this.props.enlargeFilter(_this.props.index); }); return _this; } (0, _createClass2["default"])(TimeWidget, [{ key: "render", value: function render() { var _this$props = this.props, datasets = _this$props.datasets, filter = _this$props.filter, index = _this$props.index, readOnly = _this$props.readOnly, _setFilter = _this$props.setFilter, showTimeDisplay = _this$props.showTimeDisplay; var showSpeedControl = this.state.showSpeedControl; return (/*#__PURE__*/_react["default"].createElement(_styledComponents2.BottomWidgetInner, { className: "bottom-widget--inner" }, /*#__PURE__*/_react["default"].createElement(TopSectionWrapper, null, /*#__PURE__*/_react["default"].createElement(StyledTitle, { className: "bottom-widget__field" }, /*#__PURE__*/_react["default"].createElement(_styledComponents2.CenterFlexbox, { className: "bottom-widget__icon" }, /*#__PURE__*/_react["default"].createElement(_icons.Clock, { height: "15px" })), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SelectTextBold, null, filter.name)), /*#__PURE__*/_react["default"].createElement(StyledTitle, { className: "bottom-widget__y-axis" }, /*#__PURE__*/_react["default"].createElement(_styledComponents2.CenterFlexbox, { className: "bottom-widget__icon" }, /*#__PURE__*/_react["default"].createElement(_icons.LineChart, { height: "15px" })), /*#__PURE__*/_react["default"].createElement("div", { className: "bottom-widget__field-select" }, /*#__PURE__*/_react["default"].createElement(_fieldSelector["default"], { fields: this.yAxisFieldsSelector(datasets[filter.dataId]), placement: "top", id: "selected-time-widget-field", value: filter.yAxis ? filter.yAxis.name : null, onSelect: this._setFilterPlotYAxis, placeholder: "Y Axis", erasable: true, showToken: false }))), /*#__PURE__*/_react["default"].createElement(StyledTitle, { className: "bottom-widget__speed" }, /*#__PURE__*/_react["default"].createElement(SpeedControl, { onClick: this._toggleSpeedControl, showSpeedControl: showSpeedControl, updateAnimationSpeed: this._updateAnimationSpeed, speed: filter.speed })), !readOnly ? /*#__PURE__*/_react["default"].createElement(_styledComponents2.CenterFlexbox, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.IconRoundSmall, null, /*#__PURE__*/_react["default"].createElement(_icons.Close, { height: "12px", onClick: this._onClose }))) : null), /*#__PURE__*/_react["default"].createElement(TimeRangeFilter, { filter: filter, isLargeData: datasets[filter.dataId[0]].isLargeCategory, setFilter: function setFilter(value) { return _setFilter(index, 'value', value); }, toggleAnimation: this._toggleAnimation, hideTimeTitle: showTimeDisplay, isAnimatable: true }), showTimeDisplay ? /*#__PURE__*/_react["default"].createElement(FloatingTimeDisplay, { currentTime: filter.value }) : null) ); } }]); return TimeWidget; }(_react.Component); return TimeWidget; } var _default = exports["default"] = TimeWidgetFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/filters/time-widget.js"],"names":["TOP_SECTION_HEIGHT","TopSectionWrapper","styled","div","props","theme","labelColor","hoverColor","textColorHl","StyledTitle","CenterFlexbox","textColor","TimeWidgetFactory","deps","SpeedControlFactory","TimeRangeFilterFactory","FloatingTimeDisplayFactory","SpeedControl","TimeRangeFilter","FloatingTimeDisplay","TimeWidget","showSpeedControl","fields","fieldSelector","filter","f","type","speed","updateAnimationSpeed","index","setState","state","value","setFilterPlot","yAxis","toggleAnimation","enlargeFilter","datasets","readOnly","setFilter","showTimeDisplay","name","yAxisFieldsSelector","dataId","_setFilterPlotYAxis","_toggleSpeedControl","_updateAnimationSpeed","_onClose","isLargeCategory","_toggleAnimation","Component"],"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 {createSelector} from 'reselect';\n\nimport FieldSelector from 'components/common/field-selector';\n\nimport {\n  SelectTextBold,\n  IconRoundSmall,\n  CenterFlexbox,\n  BottomWidgetInner\n} from 'components/common/styled-components';\nimport {Close, Clock, LineChart} from 'components/common/icons';\nimport SpeedControlFactory from 'components/common/animation-control/speed-control';\nimport TimeRangeFilterFactory from 'components/filters/time-range-filter';\nimport FloatingTimeDisplayFactory from 'components/common/animation-control/floating-time-display';\n\nconst TOP_SECTION_HEIGHT = '36px';\n\nconst TopSectionWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  width: 90%;\n  color: ${props => props.theme.labelColor};\n  height: ${TOP_SECTION_HEIGHT};\n\n  .bottom-widget__y-axis {\n    flex-grow: 1;\n    margin-left: 20px;\n  }\n\n  .bottom-widget__field-select {\n    width: 160px;\n    display: inline-block;\n\n    .item-selector__dropdown {\n      background: transparent;\n      padding: 4px 10px 4px 4px;\n      border-color: transparent;\n\n      :active,\n      :focus,\n      &.focus,\n      &.active {\n        background: transparent;\n        border-color: transparent;\n      }\n    }\n\n    .item-selector__dropdown:hover {\n      background: transparent;\n      border-color: transparent;\n\n      .item-selector__dropdown__value {\n        color: ${props =>\n          props.hoverColor\n            ? props.theme[props.hoverColor]\n            : props.theme.textColorHl};\n      }\n    }\n  }\n\n  .animation-control__speed-control {\n    margin-right: -12px;\n\n    .animation-control__speed-slider {\n      right: calc(0% - 48px);\n    }\n  }\n`;\n\nconst StyledTitle = styled(CenterFlexbox)`\n  flex-grow: 0;\n  color: ${props => props.theme.textColor};\n  margin-right: 10px;\n\n  .bottom-widget__icon {\n    margin-right: 6px;\n  }\n  .bottom-widget__icon.speed {\n    margin-right: 0;\n  }\n`;\n\nTimeWidgetFactory.deps = [\n  SpeedControlFactory,\n  TimeRangeFilterFactory,\n  FloatingTimeDisplayFactory\n];\n\nfunction TimeWidgetFactory(SpeedControl, TimeRangeFilter, FloatingTimeDisplay) {\n  class TimeWidget extends Component {\n    state = {\n      showSpeedControl: false\n    };\n\n    fieldSelector = props => props.fields;\n    yAxisFieldsSelector = createSelector(this.fieldSelector, fields =>\n      fields.filter(f => f.type === 'integer' || f.type === 'real')\n    );\n\n    _updateAnimationSpeed = speed =>\n      this.props.updateAnimationSpeed(this.props.index, speed);\n\n    _toggleSpeedControl = () =>\n      this.setState({showSpeedControl: !this.state.showSpeedControl});\n\n    _setFilterPlotYAxis = value =>\n      this.props.setFilterPlot(this.props.index, {yAxis: value});\n\n    _updateAnimationSpeed = speed =>\n      this.props.updateAnimationSpeed(this.props.index, speed);\n\n    _toggleAnimation = () => this.props.toggleAnimation(this.props.index);\n\n    _onClose = () => this.props.enlargeFilter(this.props.index);\n\n    render() {\n      const {\n        datasets,\n        filter,\n        index,\n        readOnly,\n        setFilter,\n        showTimeDisplay\n      } = this.props;\n\n      const {showSpeedControl} = this.state;\n      return (\n        <BottomWidgetInner className=\"bottom-widget--inner\">\n          <TopSectionWrapper>\n            <StyledTitle className=\"bottom-widget__field\">\n              <CenterFlexbox className=\"bottom-widget__icon\">\n                <Clock height=\"15px\" />\n              </CenterFlexbox>\n              <SelectTextBold>{filter.name}</SelectTextBold>\n            </StyledTitle>\n            <StyledTitle className=\"bottom-widget__y-axis\">\n              <CenterFlexbox className=\"bottom-widget__icon\">\n                <LineChart height=\"15px\" />\n              </CenterFlexbox>\n              <div className=\"bottom-widget__field-select\">\n                <FieldSelector\n                  fields={this.yAxisFieldsSelector(datasets[filter.dataId])}\n                  placement=\"top\"\n                  id=\"selected-time-widget-field\"\n                  value={filter.yAxis ? filter.yAxis.name : null}\n                  onSelect={this._setFilterPlotYAxis}\n                  placeholder=\"Y Axis\"\n                  erasable\n                  showToken={false}\n                />\n              </div>\n            </StyledTitle>\n            <StyledTitle className=\"bottom-widget__speed\">\n              <SpeedControl\n                onClick={this._toggleSpeedControl}\n                showSpeedControl={showSpeedControl}\n                updateAnimationSpeed={this._updateAnimationSpeed}\n                speed={filter.speed}\n              />\n            </StyledTitle>\n            {!readOnly ? (\n              <CenterFlexbox>\n                <IconRoundSmall>\n                  <Close height=\"12px\" onClick={this._onClose} />\n                </IconRoundSmall>\n              </CenterFlexbox>\n            ) : null}\n          </TopSectionWrapper>\n          <TimeRangeFilter\n            filter={filter}\n            isLargeData={datasets[filter.dataId[0]].isLargeCategory}\n            setFilter={value => setFilter(index, 'value', value)}\n            toggleAnimation={this._toggleAnimation}\n            hideTimeTitle={showTimeDisplay}\n            isAnimatable\n          />\n          {showTimeDisplay ? (\n            <FloatingTimeDisplay currentTime={filter.value} />\n          ) : null}\n        </BottomWidgetInner>\n      );\n    }\n  }\n  return TimeWidget;\n}\n\nexport default TimeWidgetFactory;\n"]}