UNPKG

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