kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
126 lines (97 loc) • 11.4 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
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);
exports.default = BottomWidgetFactory;
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
var _timeWidget = require('./filters/time-widget');
var _timeWidget2 = _interopRequireDefault(_timeWidget);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var propsTypes = {
filters: _propTypes2.default.array,
datasets: _propTypes2.default.object,
uiState: _propTypes2.default.object,
visStateActions: _propTypes2.default.object,
sidePanelWidth: _propTypes2.default.number,
containerW: _propTypes2.default.number
}; // 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 MaxWidth = 1080;
BottomWidgetFactory.deps = [_timeWidget2.default];
function BottomWidgetFactory(TimeWidget) {
var BottomWidget = function (_Component) {
(0, _inherits3.default)(BottomWidget, _Component);
function BottomWidget() {
(0, _classCallCheck3.default)(this, BottomWidget);
return (0, _possibleConstructorReturn3.default)(this, (BottomWidget.__proto__ || Object.getPrototypeOf(BottomWidget)).apply(this, arguments));
}
(0, _createClass3.default)(BottomWidget, [{
key: 'render',
value: function render() {
var _props = this.props,
datasets = _props.datasets,
filters = _props.filters,
visStateActions = _props.visStateActions,
containerW = _props.containerW,
uiState = _props.uiState,
sidePanelWidth = _props.sidePanelWidth;
var activeSidePanel = uiState.activeSidePanel;
var isOpen = Boolean(activeSidePanel);
var enlargedFilterIdx = filters.findIndex(function (f) {
return f.enlarged;
});
var isAnyFilterAnimating = filters.some(function (f) {
return f.isAnimating;
});
var enlargedFilterWidth = isOpen ? containerW - sidePanelWidth : containerW;
if (enlargedFilterIdx < 0) {
return null;
}
return _react2.default.createElement(TimeWidget, {
fields: datasets[filters[enlargedFilterIdx].dataId].fields,
setFilterPlot: visStateActions.setFilterPlot,
setFilter: visStateActions.setFilter,
toggleAnimation: visStateActions.toggleAnimation,
updateAnimationSpeed: visStateActions.updateAnimationSpeed,
enlargeFilter: visStateActions.enlargeFilter,
width: Math.min(MaxWidth, enlargedFilterWidth),
isAnyFilterAnimating: isAnyFilterAnimating,
enlargedIdx: enlargedFilterIdx,
filter: filters[enlargedFilterIdx]
});
}
}]);
return BottomWidget;
}(_react.Component);
BottomWidget.propsTypes = propsTypes;
return BottomWidget;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2JvdHRvbS13aWRnZXQuanMiXSwibmFtZXMiOlsiQm90dG9tV2lkZ2V0RmFjdG9yeSIsInByb3BzVHlwZXMiLCJmaWx0ZXJzIiwiUHJvcFR5cGVzIiwiYXJyYXkiLCJkYXRhc2V0cyIsIm9iamVjdCIsInVpU3RhdGUiLCJ2aXNTdGF0ZUFjdGlvbnMiLCJzaWRlUGFuZWxXaWR0aCIsIm51bWJlciIsImNvbnRhaW5lclciLCJNYXhXaWR0aCIsImRlcHMiLCJUaW1lV2lkZ2V0RmFjdG9yeSIsIlRpbWVXaWRnZXQiLCJCb3R0b21XaWRnZXQiLCJwcm9wcyIsImFjdGl2ZVNpZGVQYW5lbCIsImlzT3BlbiIsIkJvb2xlYW4iLCJlbmxhcmdlZEZpbHRlcklkeCIsImZpbmRJbmRleCIsImYiLCJlbmxhcmdlZCIsImlzQW55RmlsdGVyQW5pbWF0aW5nIiwic29tZSIsImlzQW5pbWF0aW5nIiwiZW5sYXJnZWRGaWx0ZXJXaWR0aCIsImRhdGFJZCIsImZpZWxkcyIsInNldEZpbHRlclBsb3QiLCJzZXRGaWx0ZXIiLCJ0b2dnbGVBbmltYXRpb24iLCJ1cGRhdGVBbmltYXRpb25TcGVlZCIsImVubGFyZ2VGaWx0ZXIiLCJNYXRoIiwibWluIiwiQ29tcG9uZW50Il0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O2tCQXFDd0JBLG1COztBQWpCeEI7Ozs7QUFDQTs7OztBQUNBOzs7Ozs7QUFFQSxJQUFNQyxhQUFhO0FBQ2pCQyxXQUFTQyxvQkFBVUMsS0FERjtBQUVqQkMsWUFBVUYsb0JBQVVHLE1BRkg7QUFHakJDLFdBQVNKLG9CQUFVRyxNQUhGO0FBSWpCRSxtQkFBaUJMLG9CQUFVRyxNQUpWO0FBS2pCRyxrQkFBZ0JOLG9CQUFVTyxNQUxUO0FBTWpCQyxjQUFZUixvQkFBVU87QUFOTCxDQUFuQixDLENBeEJBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQWVBLElBQU1FLFdBQVcsSUFBakI7O0FBRUFaLG9CQUFvQmEsSUFBcEIsR0FBMkIsQ0FBQ0Msb0JBQUQsQ0FBM0I7O0FBRWUsU0FBU2QsbUJBQVQsQ0FBNkJlLFVBQTdCLEVBQXlDO0FBQUEsTUFFaERDLFlBRmdEO0FBQUE7O0FBQUE7QUFBQTtBQUFBO0FBQUE7O0FBQUE7QUFBQTtBQUFBLCtCQUczQztBQUFBLHFCQVFILEtBQUtDLEtBUkY7QUFBQSxZQUVMWixRQUZLLFVBRUxBLFFBRks7QUFBQSxZQUdMSCxPQUhLLFVBR0xBLE9BSEs7QUFBQSxZQUlMTSxlQUpLLFVBSUxBLGVBSks7QUFBQSxZQUtMRyxVQUxLLFVBS0xBLFVBTEs7QUFBQSxZQU1MSixPQU5LLFVBTUxBLE9BTks7QUFBQSxZQU9MRSxjQVBLLFVBT0xBLGNBUEs7QUFBQSxZQVNBUyxlQVRBLEdBU21CWCxPQVRuQixDQVNBVyxlQVRBOztBQVVQLFlBQU1DLFNBQVNDLFFBQVFGLGVBQVIsQ0FBZjs7QUFFQSxZQUFNRyxvQkFBb0JuQixRQUFRb0IsU0FBUixDQUFrQjtBQUFBLGlCQUFLQyxFQUFFQyxRQUFQO0FBQUEsU0FBbEIsQ0FBMUI7QUFDQSxZQUFNQyx1QkFBdUJ2QixRQUFRd0IsSUFBUixDQUFhO0FBQUEsaUJBQUtILEVBQUVJLFdBQVA7QUFBQSxTQUFiLENBQTdCO0FBQ0EsWUFBTUMsc0JBQXNCVCxTQUFTUixhQUFhRixjQUF0QixHQUF1Q0UsVUFBbkU7O0FBRUEsWUFBSVUsb0JBQW9CLENBQXhCLEVBQTJCO0FBQ3pCLGlCQUFPLElBQVA7QUFDRDs7QUFFRCxlQUNFLDhCQUFDLFVBQUQ7QUFDRSxrQkFBUWhCLFNBQVNILFFBQVFtQixpQkFBUixFQUEyQlEsTUFBcEMsRUFBNENDLE1BRHREO0FBRUUseUJBQWV0QixnQkFBZ0J1QixhQUZqQztBQUdFLHFCQUFXdkIsZ0JBQWdCd0IsU0FIN0I7QUFJRSwyQkFBaUJ4QixnQkFBZ0J5QixlQUpuQztBQUtFLGdDQUFzQnpCLGdCQUFnQjBCLG9CQUx4QztBQU1FLHlCQUFlMUIsZ0JBQWdCMkIsYUFOakM7QUFPRSxpQkFBT0MsS0FBS0MsR0FBTCxDQUFTekIsUUFBVCxFQUFtQmdCLG1CQUFuQixDQVBUO0FBUUUsZ0NBQXNCSCxvQkFSeEI7QUFTRSx1QkFBYUosaUJBVGY7QUFVRSxrQkFBUW5CLFFBQVFtQixpQkFBUjtBQVZWLFVBREY7QUFjRDtBQXJDbUQ7QUFBQTtBQUFBLElBRTNCaUIsZ0JBRjJCOztBQXdDdER0QixlQUFhZixVQUFiLEdBQTBCQSxVQUExQjs7QUFFQSxTQUFPZSxZQUFQO0FBQ0QiLCJmaWxlIjoiYm90dG9tLXdpZGdldC5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8vIENvcHlyaWdodCAoYykgMjAxOCBVYmVyIFRlY2hub2xvZ2llcywgSW5jLlxuLy9cbi8vIFBlcm1pc3Npb24gaXMgaGVyZWJ5IGdyYW50ZWQsIGZyZWUgb2YgY2hhcmdlLCB0byBhbnkgcGVyc29uIG9idGFpbmluZyBhIGNvcHlcbi8vIG9mIHRoaXMgc29mdHdhcmUgYW5kIGFzc29jaWF0ZWQgZG9jdW1lbnRhdGlvbiBmaWxlcyAodGhlIFwiU29mdHdhcmVcIiksIHRvIGRlYWxcbi8vIGluIHRoZSBTb2Z0d2FyZSB3aXRob3V0IHJlc3RyaWN0aW9uLCBpbmNsdWRpbmcgd2l0aG91dCBsaW1pdGF0aW9uIHRoZSByaWdodHNcbi8vIHRvIHVzZSwgY29weSwgbW9kaWZ5LCBtZXJnZSwgcHVibGlzaCwgZGlzdHJpYnV0ZSwgc3VibGljZW5zZSwgYW5kL29yIHNlbGxcbi8vIGNvcGllcyBvZiB0aGUgU29mdHdhcmUsIGFuZCB0byBwZXJtaXQgcGVyc29ucyB0byB3aG9tIHRoZSBTb2Z0d2FyZSBpc1xuLy8gZnVybmlzaGVkIHRvIGRvIHNvLCBzdWJqZWN0IHRvIHRoZSBmb2xsb3dpbmcgY29uZGl0aW9uczpcbi8vXG4vLyBUaGUgYWJvdmUgY29weXJpZ2h0IG5vdGljZSBhbmQgdGhpcyBwZXJtaXNzaW9uIG5vdGljZSBzaGFsbCBiZSBpbmNsdWRlZCBpblxuLy8gYWxsIGNvcGllcyBvciBzdWJzdGFudGlhbCBwb3J0aW9ucyBvZiB0aGUgU29mdHdhcmUuXG4vL1xuLy8gVEhFIFNPRlRXQVJFIElTIFBST1ZJREVEIFwiQVMgSVNcIiwgV0lUSE9VVCBXQVJSQU5UWSBPRiBBTlkgS0lORCwgRVhQUkVTUyBPUlxuLy8gSU1QTElFRCwgSU5DTFVESU5HIEJVVCBOT1QgTElNSVRFRCBUTyBUSEUgV0FSUkFOVElFUyBPRiBNRVJDSEFOVEFCSUxJVFksXG4vLyBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRSBBTkQgTk9OSU5GUklOR0VNRU5ULiBJTiBOTyBFVkVOVCBTSEFMTCBUSEVcbi8vIEFVVEhPUlMgT1IgQ09QWVJJR0hUIEhPTERFUlMgQkUgTElBQkxFIEZPUiBBTlkgQ0xBSU0sIERBTUFHRVMgT1IgT1RIRVJcbi8vIExJQUJJTElUWSwgV0hFVEhFUiBJTiBBTiBBQ1RJT04gT0YgQ09OVFJBQ1QsIFRPUlQgT1IgT1RIRVJXSVNFLCBBUklTSU5HIEZST00sXG4vLyBPVVQgT0YgT1IgSU4gQ09OTkVDVElPTiBXSVRIIFRIRSBTT0ZUV0FSRSBPUiBUSEUgVVNFIE9SIE9USEVSIERFQUxJTkdTIElOXG4vLyBUSEUgU09GVFdBUkUuXG5cbmltcG9ydCBSZWFjdCwge0NvbXBvbmVudH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCBUaW1lV2lkZ2V0RmFjdG9yeSBmcm9tICcuL2ZpbHRlcnMvdGltZS13aWRnZXQnO1xuXG5jb25zdCBwcm9wc1R5cGVzID0ge1xuICBmaWx0ZXJzOiBQcm9wVHlwZXMuYXJyYXksXG4gIGRhdGFzZXRzOiBQcm9wVHlwZXMub2JqZWN0LFxuICB1aVN0YXRlOiBQcm9wVHlwZXMub2JqZWN0LFxuICB2aXNTdGF0ZUFjdGlvbnM6IFByb3BUeXBlcy5vYmplY3QsXG4gIHNpZGVQYW5lbFdpZHRoOiBQcm9wVHlwZXMubnVtYmVyLFxuICBjb250YWluZXJXOiBQcm9wVHlwZXMubnVtYmVyXG59O1xuXG5jb25zdCBNYXhXaWR0aCA9IDEwODA7XG5cbkJvdHRvbVdpZGdldEZhY3RvcnkuZGVwcyA9IFtUaW1lV2lkZ2V0RmFjdG9yeV07XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIEJvdHRvbVdpZGdldEZhY3RvcnkoVGltZVdpZGdldCkge1xuXG4gIGNsYXNzIEJvdHRvbVdpZGdldCBleHRlbmRzIENvbXBvbmVudCB7XG4gICAgcmVuZGVyKCkge1xuICAgICAgY29uc3Qge1xuICAgICAgICBkYXRhc2V0cyxcbiAgICAgICAgZmlsdGVycyxcbiAgICAgICAgdmlzU3RhdGVBY3Rpb25zLFxuICAgICAgICBjb250YWluZXJXLFxuICAgICAgICB1aVN0YXRlLFxuICAgICAgICBzaWRlUGFuZWxXaWR0aFxuICAgICAgfSA9IHRoaXMucHJvcHM7XG4gICAgICBjb25zdCB7YWN0aXZlU2lkZVBhbmVsfSA9IHVpU3RhdGU7XG4gICAgICBjb25zdCBpc09wZW4gPSBCb29sZWFuKGFjdGl2ZVNpZGVQYW5lbCk7XG5cbiAgICAgIGNvbnN0IGVubGFyZ2VkRmlsdGVySWR4ID0gZmlsdGVycy5maW5kSW5kZXgoZiA9PiBmLmVubGFyZ2VkKTtcbiAgICAgIGNvbnN0IGlzQW55RmlsdGVyQW5pbWF0aW5nID0gZmlsdGVycy5zb21lKGYgPT4gZi5pc0FuaW1hdGluZyk7XG4gICAgICBjb25zdCBlbmxhcmdlZEZpbHRlcldpZHRoID0gaXNPcGVuID8gY29udGFpbmVyVyAtIHNpZGVQYW5lbFdpZHRoIDogY29udGFpbmVyVztcblxuICAgICAgaWYgKGVubGFyZ2VkRmlsdGVySWR4IDwgMCkge1xuICAgICAgICByZXR1cm4gbnVsbDtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIChcbiAgICAgICAgPFRpbWVXaWRnZXRcbiAgICAgICAgICBmaWVsZHM9e2RhdGFzZXRzW2ZpbHRlcnNbZW5sYXJnZWRGaWx0ZXJJZHhdLmRhdGFJZF0uZmllbGRzfVxuICAgICAgICAgIHNldEZpbHRlclBsb3Q9e3Zpc1N0YXRlQWN0aW9ucy5zZXRGaWx0ZXJQbG90fVxuICAgICAgICAgIHNldEZpbHRlcj17dmlzU3RhdGVBY3Rpb25zLnNldEZpbHRlcn1cbiAgICAgICAgICB0b2dnbGVBbmltYXRpb249e3Zpc1N0YXRlQWN0aW9ucy50b2dnbGVBbmltYXRpb259XG4gICAgICAgICAgdXBkYXRlQW5pbWF0aW9uU3BlZWQ9e3Zpc1N0YXRlQWN0aW9ucy51cGRhdGVBbmltYXRpb25TcGVlZH1cbiAgICAgICAgICBlbmxhcmdlRmlsdGVyPXt2aXNTdGF0ZUFjdGlvbnMuZW5sYXJnZUZpbHRlcn1cbiAgICAgICAgICB3aWR0aD17TWF0aC5taW4oTWF4V2lkdGgsIGVubGFyZ2VkRmlsdGVyV2lkdGgpfVxuICAgICAgICAgIGlzQW55RmlsdGVyQW5pbWF0aW5nPXtpc0FueUZpbHRlckFuaW1hdGluZ31cbiAgICAgICAgICBlbmxhcmdlZElkeD17ZW5sYXJnZWRGaWx0ZXJJZHh9XG4gICAgICAgICAgZmlsdGVyPXtmaWx0ZXJzW2VubGFyZ2VkRmlsdGVySWR4XX1cbiAgICAgICAgLz5cbiAgICAgICk7XG4gICAgfVxuICB9XG5cbiAgQm90dG9tV2lkZ2V0LnByb3BzVHlwZXMgPSBwcm9wc1R5cGVzO1xuXG4gIHJldHVybiBCb3R0b21XaWRnZXQ7XG59XG4iXX0=
;