UNPKG

kepler.gl

Version:

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

257 lines (215 loc) 25.3 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.TimeWidget = undefined; var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); var _createClass2 = require('babel-runtime/helpers/createClass'); var _createClass3 = _interopRequireDefault(_createClass2); var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); var _inherits2 = require('babel-runtime/helpers/inherits'); var _inherits3 = _interopRequireDefault(_inherits2); var _taggedTemplateLiteral2 = require('babel-runtime/helpers/taggedTemplateLiteral'); var _taggedTemplateLiteral3 = _interopRequireDefault(_taggedTemplateLiteral2); var _templateObject = (0, _taggedTemplateLiteral3.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'], ['\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']), _templateObject2 = (0, _taggedTemplateLiteral3.default)(['\n position: absolute;\n display: flex;\n justify-content: space-between;\n width: 100%;\n padding-right: ', 'px;\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'], ['\n position: absolute;\n display: flex;\n justify-content: space-between;\n width: 100%;\n padding-right: ', 'px;\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']), _templateObject3 = (0, _taggedTemplateLiteral3.default)(['\n padding-right: 76px;\n'], ['\n padding-right: 76px;\n']), _templateObject4 = (0, _taggedTemplateLiteral3.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'], ['\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']), _templateObject5 = (0, _taggedTemplateLiteral3.default)(['\n flex-grow: 0;\n color: ', ';\n\n .bottom-widget__icon {\n margin-right: 6px;\n }\n'], ['\n flex-grow: 0;\n color: ', ';\n\n .bottom-widget__icon {\n margin-right: 6px;\n }\n']); // Copyright (c) 2018 Uber Technologies, Inc. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _styledComponents = require('styled-components'); var _styledComponents2 = _interopRequireDefault(_styledComponents); var _reselect = require('reselect'); var _fieldSelector = require('../common/field-selector'); var _fieldSelector2 = _interopRequireDefault(_fieldSelector); var _styledComponents3 = require('../common/styled-components'); var _timeRangeFilter = require('./time-range-filter'); var _timeRangeFilter2 = _interopRequireDefault(_timeRangeFilter); var _icons = require('../common/icons'); var _filterUtils = require('../../utils/filter-utils'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var innerPdSide = 32; var WidgetContainer = _styledComponents2.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 = _styledComponents2.default.div(_templateObject2, innerPdSide * 2, function (props) { return props.theme.labelColor; }); /* eslint-disable no-unused-vars */ var Tabs = _styledComponents2.default.div(_templateObject3); var Tab = _styledComponents2.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 = _styledComponents3.CenterFlexbox.extend(_templateObject5, function (props) { return props.theme.textColor; }); var AnimationSpeedToggle = function AnimationSpeedToggle(_ref) { var updateAnimationSpeed = _ref.updateAnimationSpeed, speed = _ref.speed; return _react2.default.createElement( Tabs, null, _filterUtils.TIME_ANIMATION_SPEED.map(function (_ref2) { var label = _ref2.label, value = _ref2.value; return _react2.default.createElement( Tab, { key: value, active: value === speed, onClick: function onClick() { return updateAnimationSpeed(value); } }, label ); }) ); }; var TimeWidget = exports.TimeWidget = function (_Component) { (0, _inherits3.default)(TimeWidget, _Component); function TimeWidget() { var _ref3; var _temp, _this, _ret; (0, _classCallCheck3.default)(this, TimeWidget); for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } return _ret = (_temp = (_this = (0, _possibleConstructorReturn3.default)(this, (_ref3 = TimeWidget.__proto__ || Object.getPrototypeOf(TimeWidget)).call.apply(_ref3, [this].concat(args))), _this), _this.fieldSelector = function (props) { return props.fields; }, _this.yAxisFieldsSelector = (0, _reselect.createSelector)(_this.fieldSelector, function (fields) { return fields.filter(function (f) { return f.type === 'integer' || f.type === 'real'; }); }), _temp), (0, _possibleConstructorReturn3.default)(_this, _ret); } (0, _createClass3.default)(TimeWidget, [{ key: 'render', value: function render() { var _props = this.props, enlargedIdx = _props.enlargedIdx, enlargeFilter = _props.enlargeFilter, filter = _props.filter, isAnyFilterAnimating = _props.isAnyFilterAnimating, _setFilter = _props.setFilter, setFilterPlot = _props.setFilterPlot, _toggleAnimation = _props.toggleAnimation, _updateAnimationSpeed = _props.updateAnimationSpeed, width = _props.width; return _react2.default.createElement( WidgetContainer, { width: width }, _react2.default.createElement( 'div', { className: 'bottom-widget--inner' }, _react2.default.createElement( TopSectionWrapper, null, _react2.default.createElement( StyledTitle, { className: 'bottom-widget__field' }, _react2.default.createElement( _styledComponents3.CenterFlexbox, { className: 'bottom-widget__icon' }, _react2.default.createElement(_icons.Clock, { height: '15px' }) ), _react2.default.createElement( _styledComponents3.SelectTextBold, null, filter.name ) ), _react2.default.createElement( StyledTitle, { className: 'bottom-widget__y-axis' }, _react2.default.createElement( _styledComponents3.CenterFlexbox, { className: 'bottom-widget__icon' }, _react2.default.createElement(_icons.LineChart, { height: '15px' }) ), _react2.default.createElement( 'div', { className: 'bottom-widget__field-select' }, _react2.default.createElement(_fieldSelector2.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 }) ) ), _react2.default.createElement(AnimationSpeedToggle, { updateAnimationSpeed: function updateAnimationSpeed(speed) { return _updateAnimationSpeed(enlargedIdx, speed); }, speed: filter.speed }), _react2.default.createElement( _styledComponents3.IconRoundSmall, null, _react2.default.createElement(_icons.Close, { height: '12px', onClick: function onClick() { return enlargeFilter(enlargedIdx); } }) ) ), _react2.default.createElement(_timeRangeFilter2.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); var TimeWidgetFactory = function TimeWidgetFactory() { return TimeWidget; }; exports.default = TimeWidgetFactory; //# 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","fieldSelector","fields","yAxisFieldsSelector","filter","f","type","enlargedIdx","enlargeFilter","isAnyFilterAnimating","setFilter","setFilterPlot","toggleAnimation","name","yAxis","Component","TimeWidgetFactory"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iQAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;AACA;;;;AACA;;AAEA;;;;AACA;;AACA;;;;AACA;;AACA;;;;AACA,IAAMA,cAAc,EAApB;;AAEA,IAAMC,kBAAkBC,2BAAOC,GAAzB,kBAEW;AAAA,SAASC,MAAMC,KAAN,CAAYC,SAAZ,CAAsBC,MAAtB,CAA6BC,GAAtC;AAAA,CAFX,EAGa;AAAA,SAASJ,MAAMC,KAAN,CAAYC,SAAZ,CAAsBC,MAAtB,CAA6BE,KAAtC;AAAA,CAHb,EAIc;AAAA,SAASL,MAAMC,KAAN,CAAYC,SAAZ,CAAsBC,MAAtB,CAA6BG,MAAtC;AAAA,CAJd,EAKY;AAAA,SAASN,MAAMC,KAAN,CAAYC,SAAZ,CAAsBC,MAAtB,CAA6BI,IAAtC;AAAA,CALZ,EASK;AAAA,SAASP,MAAMQ,KAAf;AAAA,CATL,EAYkB;AAAA,SAASR,MAAMC,KAAN,CAAYQ,WAArB;AAAA,CAZlB,EAacb,WAbd,CAAN;;AAkBA,IAAMc,oBAAoBZ,2BAAOC,GAA3B,mBAKaH,cAAc,CAL3B,EAMK;AAAA,SAASI,MAAMC,KAAN,CAAYU,UAArB;AAAA,CANL,CAAN;;AAmBA;AACA,IAAMC,OAAOd,2BAAOC,GAAd,kBAAN;;AAIA,IAAMc,MAAMf,2BAAOC,GAAb,mBAEA;AAAA,SAAUC,MAAMc,MAAN,GAAed,MAAMC,KAAN,CAAYc,WAA3B,GAAyC,aAAnD;AAAA,CAFA,EAGK;AAAA,SACTf,MAAMc,MAAN,GAAed,MAAMC,KAAN,CAAYc,WAA3B,GAAyCf,MAAMC,KAAN,CAAYU,UAD5C;AAAA,CAHL,CAAN;AAiBA;;AAEA,IAAMK,cAAcC,iCAAcC,MAA5B,mBAEK;AAAA,SAASlB,MAAMC,KAAN,CAAYkB,SAArB;AAAA,CAFL,CAAN;;AASA,IAAMC,uBAAuB,SAAvBA,oBAAuB;AAAA,MAAEC,oBAAF,QAAEA,oBAAF;AAAA,MAAwBC,KAAxB,QAAwBA,KAAxB;AAAA,SAC3B;AAAC,QAAD;AAAA;AACGC,sCAAqBC,GAArB,CAAyB;AAAA,UAAEC,KAAF,SAAEA,KAAF;AAAA,UAASC,KAAT,SAASA,KAAT;AAAA,aACxB;AAAC,WAAD;AAAA,UAAK,KAAKA,KAAV,EAAiB,QAAQA,UAAUJ,KAAnC;AACE,mBAAS;AAAA,mBAAMD,qBAAqBK,KAArB,CAAN;AAAA,WADX;AAC+CD;AAD/C,OADwB;AAAA,KAAzB;AADH,GAD2B;AAAA,CAA7B;;IASaE,U,WAAAA,U;;;;;;;;;;;;;;8MACXC,a,GAAgB;AAAA,aAAS5B,MAAM6B,MAAf;AAAA,K,QAChBC,mB,GAAsB,8BAAe,MAAKF,aAApB,EAAmC;AAAA,aACvDC,OAAOE,MAAP,CAAc;AAAA,eAAKC,EAAEC,IAAF,KAAW,SAAX,IAAwBD,EAAEC,IAAF,KAAW,MAAxC;AAAA,OAAd,CADuD;AAAA,KAAnC,C;;;;;6BAIb;AAAA,mBAWH,KAAKjC,KAXF;AAAA,UAELkC,WAFK,UAELA,WAFK;AAAA,UAGLC,aAHK,UAGLA,aAHK;AAAA,UAILJ,MAJK,UAILA,MAJK;AAAA,UAKLK,oBALK,UAKLA,oBALK;AAAA,UAMLC,UANK,UAMLA,SANK;AAAA,UAOLC,aAPK,UAOLA,aAPK;AAAA,UAQLC,gBARK,UAQLA,eARK;AAAA,UASLlB,qBATK,UASLA,oBATK;AAAA,UAULb,KAVK,UAULA,KAVK;;;AAaP,aACE;AAAC,uBAAD;AAAA,UAAiB,OAAOA,KAAxB;AACE;AAAA;AAAA,YAAK,WAAU,sBAAf;AACE;AAAC,6BAAD;AAAA;AACE;AAAC,yBAAD;AAAA,gBAAa,WAAU,sBAAvB;AACE;AAAC,gDAAD;AAAA,kBAAe,WAAU,qBAAzB;AACE,8CAAC,YAAD,IAAO,QAAO,MAAd;AADF,eADF;AAIE;AAAC,iDAAD;AAAA;AAAiBuB,uBAAOS;AAAxB;AAJF,aADF;AAOE;AAAC,yBAAD;AAAA,gBAAa,WAAU,uBAAvB;AACE;AAAC,gDAAD;AAAA,kBAAe,WAAU,qBAAzB;AACE,8CAAC,gBAAD,IAAW,QAAO,MAAlB;AADF,eADF;AAIE;AAAA;AAAA,kBAAK,WAAU,6BAAf;AACE,8CAAC,uBAAD;AACE,0BAAQ,KAAKV,mBAAL,CAAyB,KAAK9B,KAA9B,CADV;AAEE,6BAAU,KAFZ;AAGE,sBAAG,4BAHL;AAIE,yBAAO+B,OAAOU,KAAP,GAAeV,OAAOU,KAAP,CAAaD,IAA5B,GAAmC,IAJ5C;AAKE,4BAAU;AAAA,2BAASF,cAAcJ,WAAd,EAA2B,EAACO,OAAOf,KAAR,EAA3B,CAAT;AAAA,mBALZ;AAME,8BAAW,WANb;AAOE,+BAAY,eAPd;AAQE,gCARF;AASE,6BAAW;AATb;AADF;AAJF,aAPF;AAyBE,0CAAC,oBAAD;AACE,oCAAsB,8BAACJ,KAAD;AAAA,uBAAWD,sBAAqBa,WAArB,EAAkCZ,KAAlC,CAAX;AAAA,eADxB;AAEE,qBAAOS,OAAOT,KAFhB,GAzBF;AA4BE;AAAC,+CAAD;AAAA;AACE,4CAAC,YAAD,IAAO,QAAO,MAAd,EAAqB,SAAS;AAAA,yBAAMa,cAAcD,WAAd,CAAN;AAAA,iBAA9B;AADF;AA5BF,WADF;AAiCE,wCAAC,yBAAD;AACE,oBAAQH,MADV;AAEE,uBAAW;AAAA,qBAASM,WAAUH,WAAV,EAAuB,OAAvB,EAAgCR,KAAhC,CAAT;AAAA,aAFb;AAGE,kCAAsBU,oBAHxB;AAIE,kCAAsB,8BAACd,KAAD;AAAA,qBAAWD,sBAAqBa,WAArB,EAAkCZ,KAAlC,CAAX;AAAA,aAJxB;AAKE,6BAAiB;AAAA,qBAAMiB,iBAAgBL,WAAhB,CAAN;AAAA;AALnB;AAjCF;AADF,OADF;AA6CD;;;EAhE6BQ,gB;;AAmEhC,IAAMC,oBAAoB,SAApBA,iBAAoB;AAAA,SAAMhB,UAAN;AAAA,CAA1B;kBACegB,iB","file":"time-widget.js","sourcesContent":["// Copyright (c) 2018 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: 100%;\n  padding-right: ${innerPdSide * 2}px;\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"]}