kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
176 lines (139 loc) • 15.1 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = 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 _class, _temp2; // 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 _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
var _reselect = require('reselect');
var _styledComponents = require('../common/styled-components');
var _icons = require('../common/icons');
var _sourceDataCatalog = require('./source-data-catalog');
var _sourceDataCatalog2 = _interopRequireDefault(_sourceDataCatalog);
var _filterPanel = require('./filter-panel/filter-panel');
var _filterPanel2 = _interopRequireDefault(_filterPanel);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var FilterManager = (_temp2 = _class = function (_Component) {
(0, _inherits3.default)(FilterManager, _Component);
function FilterManager() {
var _ref;
var _temp, _this, _ret;
(0, _classCallCheck3.default)(this, FilterManager);
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, (_ref = FilterManager.__proto__ || Object.getPrototypeOf(FilterManager)).call.apply(_ref, [this].concat(args))), _this), _this.datasetsSelector = function (state) {
return state.datasets;
}, _this.defaultDatasetSelector = (0, _reselect.createSelector)(_this.datasetsSelector, function (datasets) {
return Object.keys(datasets).length && Object.keys(datasets)[0] || null;
}), _this._addFilter = function () {
var defaultDataset = _this.defaultDatasetSelector(_this.props);
_this.props.addFilter(defaultDataset);
}, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret);
}
/* selectors */
/* actions */
(0, _createClass3.default)(FilterManager, [{
key: 'render',
value: function render() {
var _this2 = this;
var _props = this.props,
filters = _props.filters,
datasets = _props.datasets;
var isAnyFilterAnimating = filters.some(function (f) {
return f.isAnimating;
});
var hadEmptyFilter = filters.some(function (f) {
return !f.name;
});
var hadDataset = Object.keys(datasets).length;
return _react2.default.createElement(
'div',
{ className: 'filter-manager' },
_react2.default.createElement(_sourceDataCatalog2.default, {
datasets: datasets,
showDatasetTable: this.props.showDatasetTable
}),
_react2.default.createElement(_styledComponents.SidePanelDivider, null),
_react2.default.createElement(
_styledComponents.SidePanelSection,
null,
filters && filters.map(function (filter, idx) {
return _react2.default.createElement(_filterPanel2.default, {
key: filter.id + '-' + idx,
idx: idx,
filters: filters,
filter: filter,
datasets: datasets,
isAnyFilterAnimating: isAnyFilterAnimating,
removeFilter: function removeFilter() {
return _this2.props.removeFilter(idx);
},
enlargeFilter: function enlargeFilter() {
return _this2.props.enlargeFilter(idx);
},
toggleAnimation: function toggleAnimation() {
return _this2.props.toggleAnimation(idx);
},
setFilter: _this2.props.setFilter
});
})
),
_react2.default.createElement(
_styledComponents.Button,
{
inactive: hadEmptyFilter || !hadDataset,
width: '105px',
onClick: this._addFilter
},
_react2.default.createElement(_icons.Add, { height: '12px' }),
'Add Filter'
)
);
}
}]);
return FilterManager;
}(_react.Component), _class.propTypes = {
datasets: _propTypes2.default.object,
addFilter: _propTypes2.default.func.isRequired,
removeFilter: _propTypes2.default.func.isRequired,
enlargeFilter: _propTypes2.default.func.isRequired,
toggleAnimation: _propTypes2.default.func.isRequired,
setFilter: _propTypes2.default.func.isRequired,
filters: _propTypes2.default.arrayOf(_propTypes2.default.any).isRequired,
showDatasetTable: _propTypes2.default.func,
// fields can be undefined when dataset is not selected
fields: _propTypes2.default.arrayOf(_propTypes2.default.any)
}, _temp2);
exports.default = FilterManager;
;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/side-panel/filter-manager.js"],"names":["FilterManager","datasetsSelector","state","datasets","defaultDatasetSelector","Object","keys","length","_addFilter","defaultDataset","props","addFilter","filters","isAnyFilterAnimating","some","f","isAnimating","hadEmptyFilter","name","hadDataset","showDatasetTable","map","filter","idx","id","removeFilter","enlargeFilter","toggleAnimation","setFilter","Component","propTypes","PropTypes","object","func","isRequired","arrayOf","any","fields"],"mappings":"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","file":"filter-manager.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 PropTypes from 'prop-types';\nimport {createSelector} from 'reselect';\nimport {\n  SidePanelSection,\n  SidePanelDivider,\n  Button\n} from 'components/common/styled-components';\nimport {Add} from 'components/common/icons';\nimport SourceDataCatalog from './source-data-catalog';\nimport FilterPanel from './filter-panel/filter-panel';\n\nexport default class FilterManager extends Component {\n  static propTypes = {\n    datasets: PropTypes.object,\n    addFilter: PropTypes.func.isRequired,\n    removeFilter: PropTypes.func.isRequired,\n    enlargeFilter: PropTypes.func.isRequired,\n    toggleAnimation: PropTypes.func.isRequired,\n    setFilter: PropTypes.func.isRequired,\n    filters: PropTypes.arrayOf(PropTypes.any).isRequired,\n    showDatasetTable: PropTypes.func,\n\n    // fields can be undefined when dataset is not selected\n    fields: PropTypes.arrayOf(PropTypes.any)\n  };\n\n  /* selectors */\n  datasetsSelector = state => state.datasets;\n  defaultDatasetSelector = createSelector(\n    this.datasetsSelector,\n    datasets =>\n      (Object.keys(datasets).length && Object.keys(datasets)[0]) || null\n  );\n\n  /* actions */\n  _addFilter = () => {\n    const defaultDataset = this.defaultDatasetSelector(this.props);\n    this.props.addFilter(defaultDataset);\n  };\n\n  render() {\n    const {filters, datasets} = this.props;\n    const isAnyFilterAnimating = filters.some(f => f.isAnimating);\n    const hadEmptyFilter = filters.some(f => !f.name);\n    const hadDataset = Object.keys(datasets).length;\n\n    return (\n      <div className=\"filter-manager\">\n        <SourceDataCatalog\n          datasets={datasets}\n          showDatasetTable={this.props.showDatasetTable}\n        />\n        <SidePanelDivider />\n        <SidePanelSection>\n          {filters &&\n            filters.map((filter, idx) => (\n              <FilterPanel\n                key={`${filter.id}-${idx}`}\n                idx={idx}\n                filters={filters}\n                filter={filter}\n                datasets={datasets}\n                isAnyFilterAnimating={isAnyFilterAnimating}\n                removeFilter={() => this.props.removeFilter(idx)}\n                enlargeFilter={() => this.props.enlargeFilter(idx)}\n                toggleAnimation={() => this.props.toggleAnimation(idx)}\n                setFilter={this.props.setFilter}\n              />\n            ))}\n        </SidePanelSection>\n        <Button\n          inactive={hadEmptyFilter || !hadDataset}\n          width=\"105px\"\n          onClick={this._addFilter}\n        >\n          <Add height=\"12px\" />Add Filter\n        </Button>\n      </div>\n    );\n  }\n};\n"]}
;