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
JavaScript
;
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"]}