UNPKG

kepler.gl.geoiq

Version:

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

255 lines (202 loc) 23.8 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"] = exports.TimeWidget = 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 _getPrototypeOf3 = _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 _styledComponents = _interopRequireDefault(require("styled-components")); var _reselect = require("reselect"); var _fieldSelector = _interopRequireDefault(require("../common/field-selector")); var _styledComponents2 = require("../common/styled-components"); var _timeRangeFilter = _interopRequireDefault(require("./time-range-filter")); var _icons = require("../common/icons"); var _filterUtils = require("../../utils/filter-utils"); function _templateObject5() { var data = (0, _taggedTemplateLiteral2["default"])(["\n flex-grow: 0;\n color: ", ";\n\n .bottom-widget__icon {\n margin-right: 6px;\n }\n"]); _templateObject5 = function _templateObject5() { return data; }; return data; } function _templateObject4() { var data = (0, _taggedTemplateLiteral2["default"])(["\n border-bottom: 1px solid\n ", ";\n color: ", ";\n display: inline-block;\n font-size: 12px;\n height: 24px;\n margin-right: 4px;\n text-align: center;\n width: 24px;\n line-height: 24px;\n \n :hover {\n cursor: pointer;\n }\n"]); _templateObject4 = function _templateObject4() { return data; }; return data; } function _templateObject3() { var data = (0, _taggedTemplateLiteral2["default"])(["\n padding-right: 76px;\n"]); _templateObject3 = function _templateObject3() { return data; }; return data; } function _templateObject2() { var data = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n display: flex;\n justify-content: space-between;\n width: 90%;\n color: ", ";\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"]); _templateObject2 = function _templateObject2() { return data; }; return data; } function _templateObject() { var data = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n padding-top: ", "px;\n padding-right: ", "px;\n padding-bottom: ", "px;\n padding-left: ", "px; \n bottom: 0;\n right: 0;\n z-index: 1;\n width: ", "px;\n\n .bottom-widget--inner {\n background-color: ", ";\n padding: 10px ", "px;\n position: relative;\n }\n"]); _templateObject = function _templateObject() { return data; }; return data; } var innerPdSide = 32; var WidgetContainer = _styledComponents["default"].div(_templateObject(), function (props) { return props.theme.sidePanel.margin.top; }, function (props) { return props.theme.sidePanel.margin.right; }, function (props) { return props.theme.sidePanel.margin.bottom; }, function (props) { return props.theme.sidePanel.margin.left; }, function (props) { return props.width; }, function (props) { return props.theme.sidePanelBg; }, innerPdSide); var TopSectionWrapper = _styledComponents["default"].div(_templateObject2(), function (props) { return props.theme.labelColor; }); /* eslint-disable no-unused-vars */ var Tabs = _styledComponents["default"].div(_templateObject3()); var Tab = _styledComponents["default"].div(_templateObject4(), function (props) { return props.active ? props.theme.textColorHl : 'transparent'; }, function (props) { return props.active ? props.theme.textColorHl : props.theme.labelColor; }); /* eslint-enable no-unused-vars */ var StyledTitle = _styledComponents2.CenterFlexbox.extend(_templateObject5(), function (props) { return props.theme.textColor; }); var AnimationSpeedToggle = function AnimationSpeedToggle(_ref) { var updateAnimationSpeed = _ref.updateAnimationSpeed, speed = _ref.speed; return _react["default"].createElement(Tabs, null, _filterUtils.TIME_ANIMATION_SPEED.map(function (_ref2) { var label = _ref2.label, value = _ref2.value; return _react["default"].createElement(Tab, { key: value, active: value === speed, onClick: function onClick() { return updateAnimationSpeed(value); } }, label); })); }; var TimeWidget = /*#__PURE__*/ function (_Component) { (0, _inherits2["default"])(TimeWidget, _Component); function TimeWidget() { var _getPrototypeOf2; 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 = (0, _possibleConstructorReturn2["default"])(this, (_getPrototypeOf2 = (0, _getPrototypeOf3["default"])(TimeWidget)).call.apply(_getPrototypeOf2, [this].concat(args))); (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'; }); })); return _this; } (0, _createClass2["default"])(TimeWidget, [{ key: "render", value: function render() { var _this$props = this.props, enlargedIdx = _this$props.enlargedIdx, enlargeFilter = _this$props.enlargeFilter, filter = _this$props.filter, isAnyFilterAnimating = _this$props.isAnyFilterAnimating, _setFilter = _this$props.setFilter, setFilterPlot = _this$props.setFilterPlot, _toggleAnimation = _this$props.toggleAnimation, _updateAnimationSpeed = _this$props.updateAnimationSpeed, width = _this$props.width; return _react["default"].createElement(WidgetContainer, { width: width }, _react["default"].createElement("div", { className: "bottom-widget--inner" }, _react["default"].createElement(TopSectionWrapper, null, _react["default"].createElement(StyledTitle, { className: "bottom-widget__field" }, _react["default"].createElement(_styledComponents2.CenterFlexbox, { className: "bottom-widget__icon" }, _react["default"].createElement(_icons.Clock, { height: "15px" })), _react["default"].createElement(_styledComponents2.SelectTextBold, null, filter.name)), _react["default"].createElement(StyledTitle, { className: "bottom-widget__y-axis" }, _react["default"].createElement(_styledComponents2.CenterFlexbox, { className: "bottom-widget__icon" }, _react["default"].createElement(_icons.LineChart, { height: "15px" })), _react["default"].createElement("div", { className: "bottom-widget__field-select" }, _react["default"].createElement(_fieldSelector["default"], { fields: this.yAxisFieldsSelector(this.props), placement: "top", id: "selected-time-widget-field", value: filter.yAxis ? filter.yAxis.name : null, onSelect: function onSelect(value) { return setFilterPlot(enlargedIdx, { yAxis: value }); }, inputTheme: "secondary", placeholder: "Select Y Axis", erasable: true, showToken: false }))), _react["default"].createElement(AnimationSpeedToggle, { updateAnimationSpeed: function updateAnimationSpeed(speed) { return _updateAnimationSpeed(enlargedIdx, speed); }, speed: filter.speed }), _react["default"].createElement(_styledComponents2.IconRoundSmall, null, _react["default"].createElement(_icons.Close, { height: "12px", onClick: function onClick() { return enlargeFilter(enlargedIdx); } }))), _react["default"].createElement(_timeRangeFilter["default"], { filter: filter, setFilter: function setFilter(value) { return _setFilter(enlargedIdx, 'value', value); }, isAnyFilterAnimating: isAnyFilterAnimating, updateAnimationSpeed: function updateAnimationSpeed(speed) { return _updateAnimationSpeed(enlargedIdx, speed); }, toggleAnimation: function toggleAnimation() { return _toggleAnimation(enlargedIdx); } }))); } }]); return TimeWidget; }(_react.Component); exports.TimeWidget = TimeWidget; var TimeWidgetFactory = function TimeWidgetFactory() { return TimeWidget; }; var _default = TimeWidgetFactory; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/filters/time-widget.js"],"names":["innerPdSide","WidgetContainer","styled","div","props","theme","sidePanel","margin","top","right","bottom","left","width","sidePanelBg","TopSectionWrapper","labelColor","Tabs","Tab","active","textColorHl","StyledTitle","CenterFlexbox","extend","textColor","AnimationSpeedToggle","updateAnimationSpeed","speed","TIME_ANIMATION_SPEED","map","label","value","TimeWidget","fields","fieldSelector","filter","f","type","enlargedIdx","enlargeFilter","isAnyFilterAnimating","setFilter","setFilterPlot","toggleAnimation","name","yAxisFieldsSelector","yAxis","Component","TimeWidgetFactory"],"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 styled from 'styled-components';\nimport {createSelector} from 'reselect';\n\nimport FieldSelector from 'components/common/field-selector';\nimport {SelectTextBold, IconRoundSmall, CenterFlexbox} from 'components/common/styled-components';\nimport TimeRangeFilter from 'components/filters/time-range-filter';\nimport {Close, Clock, LineChart} from 'components/common/icons';\nimport {TIME_ANIMATION_SPEED} from 'utils/filter-utils';\nconst innerPdSide = 32;\n\nconst WidgetContainer = styled.div`\n  position: absolute;\n  padding-top: ${props => props.theme.sidePanel.margin.top}px;\n  padding-right: ${props => props.theme.sidePanel.margin.right}px;\n  padding-bottom: ${props => props.theme.sidePanel.margin.bottom}px;\n  padding-left: ${props => props.theme.sidePanel.margin.left}px;  \n  bottom: 0;\n  right: 0;\n  z-index: 1;\n  width: ${props => props.width}px;\n\n  .bottom-widget--inner {\n    background-color: ${props => props.theme.sidePanelBg};\n    padding: 10px ${innerPdSide}px;\n    position: relative;\n  }\n`;\n\nconst TopSectionWrapper = styled.div`\n  position: absolute;\n  display: flex;\n  justify-content: space-between;\n  width: 90%;\n  color: ${props => props.theme.labelColor};\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`;\n\n/* eslint-disable no-unused-vars */\nconst Tabs = styled.div`\n  padding-right: 76px;\n`;\n\nconst Tab = styled.div`\n  border-bottom: 1px solid\n    ${props => (props.active ? props.theme.textColorHl : 'transparent')};\n  color: ${props =>\n  props.active ? props.theme.textColorHl : props.theme.labelColor};\n  display: inline-block;\n  font-size: 12px;\n  height: 24px;\n  margin-right: 4px;\n  text-align: center;\n  width: 24px;\n  line-height: 24px;\n  \n  :hover {\n    cursor: pointer;\n  }\n`;\n/* eslint-enable no-unused-vars */\n\nconst StyledTitle = CenterFlexbox.extend`\n  flex-grow: 0;\n  color: ${props => props.theme.textColor};\n\n  .bottom-widget__icon {\n    margin-right: 6px;\n  }\n`;\n\nconst AnimationSpeedToggle = ({updateAnimationSpeed, speed}) => (\n  <Tabs>\n    {TIME_ANIMATION_SPEED.map(({label, value}) => (\n      <Tab key={value} active={value === speed}\n        onClick={() => updateAnimationSpeed(value)}>{label}</Tab>\n    ))}\n  </Tabs>\n);\n\nexport class TimeWidget extends Component {\n  fieldSelector = props => props.fields;\n  yAxisFieldsSelector = createSelector(this.fieldSelector, fields =>\n    fields.filter(f => f.type === 'integer' || f.type === 'real')\n  );\n\n  render() {\n    const {\n      enlargedIdx,\n      enlargeFilter,\n      filter,\n      isAnyFilterAnimating,\n      setFilter,\n      setFilterPlot,\n      toggleAnimation,\n      updateAnimationSpeed,\n      width\n    } = this.props;\n\n    return (\n      <WidgetContainer width={width}>\n        <div 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(this.props)}\n                  placement=\"top\"\n                  id=\"selected-time-widget-field\"\n                  value={filter.yAxis ? filter.yAxis.name : null}\n                  onSelect={value => setFilterPlot(enlargedIdx, {yAxis: value})}\n                  inputTheme=\"secondary\"\n                  placeholder=\"Select Y Axis\"\n                  erasable\n                  showToken={false}\n                />\n              </div>\n            </StyledTitle>\n            <AnimationSpeedToggle\n              updateAnimationSpeed={(speed) => updateAnimationSpeed(enlargedIdx, speed)}\n              speed={filter.speed}/>\n            <IconRoundSmall>\n              <Close height=\"12px\" onClick={() => enlargeFilter(enlargedIdx)} />\n            </IconRoundSmall>\n          </TopSectionWrapper>\n          <TimeRangeFilter\n            filter={filter}\n            setFilter={value => setFilter(enlargedIdx, 'value', value)}\n            isAnyFilterAnimating={isAnyFilterAnimating}\n            updateAnimationSpeed={(speed) => updateAnimationSpeed(enlargedIdx, speed)}\n            toggleAnimation={() => toggleAnimation(enlargedIdx)}\n          />\n        </div>\n      </WidgetContainer>\n    );\n  }\n}\n\nconst TimeWidgetFactory = () => TimeWidget;\nexport default TimeWidgetFactory;\n"]}