kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
248 lines (213 loc) • 28.3 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _reselect = require("reselect");
var _styledComponents = require("../common/styled-components");
var _icons = require("../common/icons");
var _sourceDataCatalog = _interopRequireDefault(require("./common/source-data-catalog"));
var _filterPanel = _interopRequireDefault(require("./filter-panel/filter-panel"));
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
FilterManagerFactory.deps = [_sourceDataCatalog["default"], _filterPanel["default"]];
function FilterManagerFactory(SourceDataCatalog, FilterPanel) {
var _class, _temp;
return _temp = _class = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(FilterManager, _Component);
var _super = _createSuper(FilterManager);
function FilterManager() {
var _this;
(0, _classCallCheck2["default"])(this, FilterManager);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this = _super.call.apply(_super, [this].concat(args));
/* selectors */
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "datasetsSelector", function (state) {
return state.datasets;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "defaultDatasetSelector", (0, _reselect.createSelector)(_this.datasetsSelector, function (datasets) {
return Object.keys(datasets).length && Object.keys(datasets)[0] || null;
}));
/* actions */
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_addFilter", function () {
var defaultDataset = _this.defaultDatasetSelector(_this.props);
_this.props.addFilter(defaultDataset);
});
return _this;
}
(0, _createClass2["default"])(FilterManager, [{
key: "render",
value: function render() {
var _this2 = this;
var _this$props = this.props,
filters = _this$props.filters,
datasets = _this$props.datasets,
mapState = _this$props.mapState,
auth = _this$props.auth,
project = _this$props.project,
layers = _this$props.layers;
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 (/*#__PURE__*/_react["default"].createElement("div", {
className: "filter-manager"
}, /*#__PURE__*/_react["default"].createElement(SourceDataCatalog, {
datasets: datasets,
showDatasetTable: this.props.showDatasetTable
}), /*#__PURE__*/_react["default"].createElement(_styledComponents.SidePanelDivider, null), /*#__PURE__*/_react["default"].createElement(_styledComponents.SidePanelSection, null, filters && filters.map(function (filter, idx) {
return (/*#__PURE__*/_react["default"].createElement(FilterPanel, {
key: "".concat(filter.id, "-").concat(idx),
idx: idx,
filters: filters,
filter: filter,
layers: layers,
datasets: datasets,
mapState: mapState,
isAnyFilterAnimating: isAnyFilterAnimating,
removeFilter: function removeFilter() {
return _this2.props.removeFilter(idx, mapState, auth, project);
},
enlargeFilter: function enlargeFilter() {
return _this2.props.enlargeFilter(idx);
},
toggleAnimation: function toggleAnimation() {
return _this2.props.toggleAnimation(idx);
},
setFilter: _this2.props.setFilter,
setFilterAPI: _this2.props.setFilterAPI,
auth: auth,
project: project
})
);
})), /*#__PURE__*/_react["default"].createElement(_styledComponents.Button, {
inactive: hadEmptyFilter || !hadDataset,
width: "105px",
onClick: this._addFilter
}, /*#__PURE__*/_react["default"].createElement(_icons.Add, {
height: "12px"
}), "Add Filter"))
);
}
}]);
return FilterManager;
}(_react.Component), (0, _defineProperty2["default"])(_class, "propTypes", {
datasets: _propTypes["default"].object,
addFilter: _propTypes["default"].func.isRequired,
removeFilter: _propTypes["default"].func.isRequired,
enlargeFilter: _propTypes["default"].func.isRequired,
toggleAnimation: _propTypes["default"].func.isRequired,
setFilter: _propTypes["default"].func.isRequired,
filters: _propTypes["default"].arrayOf(_propTypes["default"].any).isRequired,
layers: _propTypes["default"].arrayOf(_propTypes["default"].any).isRequired,
showDatasetTable: _propTypes["default"].func,
setFilterAPI: _propTypes["default"].func.isRequired,
mapState: _propTypes["default"].object,
auth: _propTypes["default"].object.isRequired,
project: _propTypes["default"].object.isRequired,
// fields can be undefined when dataset is not selected
fields: _propTypes["default"].arrayOf(_propTypes["default"].any)
}), _temp;
}
var _default = exports["default"] = FilterManagerFactory; // import React, {Component} from 'react';
// import PropTypes from 'prop-types';
// import {createSelector} from 'reselect';
// import {
// SidePanelSection,
// SidePanelDivider,
// Button
// } from 'components/common/styled-components';
// import {Add} from 'components/common/icons';
// import SourceDataCatalogFactory from './common/source-data-catalog';
// import FilterPanelFactory from './filter-panel/filter-panel';
// FilterManagerFactory.deps = [SourceDataCatalogFactory, FilterPanelFactory];
// function FilterManagerFactory(SourceDataCatalog, FilterPanel) {
// return class FilterManager extends Component {
// static propTypes = {
// datasets: PropTypes.object,
// layers: PropTypes.arrayOf(PropTypes.any).isRequired,
// addFilter: PropTypes.func.isRequired,
// removeFilter: PropTypes.func.isRequired,
// enlargeFilter: PropTypes.func.isRequired,
// toggleAnimation: PropTypes.func.isRequired,
// setFilter: PropTypes.func.isRequired,
// filters: PropTypes.arrayOf(PropTypes.any).isRequired,
// showDatasetTable: PropTypes.func,
// // fields can be undefined when dataset is not selected
// fields: PropTypes.arrayOf(PropTypes.any)
// };
// /* selectors */
// datasetsSelector = state => state.datasets;
// defaultDatasetSelector = createSelector(
// this.datasetsSelector,
// datasets =>
// (Object.keys(datasets).length && Object.keys(datasets)[0]) || null
// );
// /* actions */
// _addFilter = () => {
// const defaultDataset = this.defaultDatasetSelector(this.props);
// this.props.addFilter(defaultDataset);
// };
// render() {
// const {filters, datasets, layers} = this.props;
// const isAnyFilterAnimating = filters.some(f => f.isAnimating);
// const hadEmptyFilter = filters.some(f => !f.name);
// const hadDataset = Object.keys(datasets).length;
// return (
// <div className="filter-manager">
// <SourceDataCatalog
// datasets={datasets}
// showDatasetTable={this.props.showDatasetTable}
// />
// <SidePanelDivider />
// <SidePanelSection>
// {filters &&
// filters.map((filter, idx) => (
// <FilterPanel
// key={`${filter.id}-${idx}`}
// idx={idx}
// filters={filters}
// filter={filter}
// datasets={datasets}
// layers={layers}
// isAnyFilterAnimating={isAnyFilterAnimating}
// removeFilter={() => this.props.removeFilter(idx)}
// enlargeFilter={() => this.props.enlargeFilter(idx)}
// toggleAnimation={() => this.props.toggleAnimation(idx)}
// setFilter={this.props.setFilter}
// />
// ))}
// </SidePanelSection>
// <Button
// inactive={hadEmptyFilter || !hadDataset}
// width="105px"
// onClick={this._addFilter}
// >
// <Add height="12px" />
// Add Filter
// </Button>
// </div>
// );
// }
// };
// }
// export default FilterManagerFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/side-panel/filter-manager.js"],"names":["FilterManagerFactory","deps","SourceDataCatalogFactory","FilterPanelFactory","SourceDataCatalog","FilterPanel","state","datasets","datasetsSelector","Object","keys","length","defaultDataset","defaultDatasetSelector","props","addFilter","filters","mapState","auth","project","layers","isAnyFilterAnimating","some","f","isAnimating","hadEmptyFilter","name","hadDataset","showDatasetTable","map","filter","idx","id","removeFilter","enlargeFilter","toggleAnimation","setFilter","setFilterAPI","_addFilter","Component","PropTypes","object","func","isRequired","arrayOf","any","fields"],"mappings":"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","sourcesContent":["// Copyright (c) 2023 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 SourceDataCatalogFactory from './common/source-data-catalog';\nimport FilterPanelFactory from './filter-panel/filter-panel';\n\nFilterManagerFactory.deps = [SourceDataCatalogFactory, FilterPanelFactory];\n\nfunction FilterManagerFactory(SourceDataCatalog, FilterPanel) {\n  return 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      layers: PropTypes.arrayOf(PropTypes.any).isRequired,\n      showDatasetTable: PropTypes.func,\n      setFilterAPI: PropTypes.func.isRequired,\n      mapState: PropTypes.object,\n      auth: PropTypes.object.isRequired,\n      project: PropTypes.object.isRequired,\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, mapState, auth, project, layers} = 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                  layers={layers}\n                  datasets={datasets}\n                  mapState={mapState}\n                  isAnyFilterAnimating={isAnyFilterAnimating}\n                  removeFilter={() =>\n                    this.props.removeFilter(idx, mapState, auth, project)\n                  }\n                  enlargeFilter={() => this.props.enlargeFilter(idx)}\n                  toggleAnimation={() => this.props.toggleAnimation(idx)}\n                  setFilter={this.props.setFilter}\n                  setFilterAPI={this.props.setFilterAPI}\n                  auth={auth}\n                  project={project}\n                />\n              ))}\n          </SidePanelSection>\n          <Button\n            inactive={hadEmptyFilter || !hadDataset}\n            width=\"105px\"\n            onClick={this._addFilter}\n          >\n            <Add height=\"12px\" />\n            Add Filter\n          </Button>\n        </div>\n      );\n    }\n  };\n}\n\nexport default FilterManagerFactory; // import React, {Component} from 'react';\n// import PropTypes from 'prop-types';\n// import {createSelector} from 'reselect';\n// import {\n//   SidePanelSection,\n//   SidePanelDivider,\n//   Button\n// } from 'components/common/styled-components';\n// import {Add} from 'components/common/icons';\n// import SourceDataCatalogFactory from './common/source-data-catalog';\n// import FilterPanelFactory from './filter-panel/filter-panel';\n\n// FilterManagerFactory.deps = [SourceDataCatalogFactory, FilterPanelFactory];\n\n// function FilterManagerFactory(SourceDataCatalog, FilterPanel) {\n//   return class FilterManager extends Component {\n//     static propTypes = {\n//       datasets: PropTypes.object,\n//       layers: PropTypes.arrayOf(PropTypes.any).isRequired,\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, layers} = 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//                   layers={layers}\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\" />\n//             Add Filter\n//           </Button>\n//         </div>\n//       );\n//     }\n//   };\n// }\n\n// export default FilterManagerFactory;\n"]}