kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
160 lines (131 loc) • 16.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"] = 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 _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("./source-data-catalog"));
var _filterPanel = _interopRequireDefault(require("./filter-panel/filter-panel"));
// Copyright (c) 2019 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.
FilterManagerFactory.deps = [_sourceDataCatalog["default"], _filterPanel["default"]];
function FilterManagerFactory(SourceDataCatalog, FilterPanel) {
var _class, _temp;
return _temp = _class =
/*#__PURE__*/
function (_Component) {
(0, _inherits2["default"])(FilterManager, _Component);
function FilterManager() {
var _getPrototypeOf2;
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 = (0, _possibleConstructorReturn2["default"])(this, (_getPrototypeOf2 = (0, _getPrototypeOf3["default"])(FilterManager)).call.apply(_getPrototypeOf2, [this].concat(args)));
(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;
}));
(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;
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 _react["default"].createElement("div", {
className: "filter-manager"
}, _react["default"].createElement(SourceDataCatalog, {
datasets: datasets,
showDatasetTable: this.props.showDatasetTable
}), _react["default"].createElement(_styledComponents.SidePanelDivider, null), _react["default"].createElement(_styledComponents.SidePanelSection, null, filters && filters.map(function (filter, idx) {
return _react["default"].createElement(FilterPanel, {
key: "".concat(filter.id, "-").concat(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
});
})), _react["default"].createElement(_styledComponents.Button, {
inactive: hadEmptyFilter || !hadDataset,
width: "105px",
onClick: this._addFilter
}, _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,
showDatasetTable: _propTypes["default"].func,
// fields can be undefined when dataset is not selected
fields: _propTypes["default"].arrayOf(_propTypes["default"].any)
}), _temp;
}
var _default = FilterManagerFactory;
exports["default"] = _default;
//# 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","isAnyFilterAnimating","some","f","isAnimating","hadEmptyFilter","name","hadDataset","showDatasetTable","map","filter","idx","id","removeFilter","enlargeFilter","toggleAnimation","setFilter","_addFilter","Component","PropTypes","object","func","isRequired","arrayOf","any","fields"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAoBA;;AACA;;AACA;;AACA;;AAKA;;AACA;;AACA;;AA9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAcAA,oBAAoB,CAACC,IAArB,GAA4B,CAACC,6BAAD,EAA2BC,uBAA3B,CAA5B;;AAEA,SAASH,oBAAT,CAA8BI,iBAA9B,EAAiDC,WAAjD,EAA8D;AAAA;;AAC5D;AAAA;AAAA;AAAA;;AAAA;AAAA;;AAAA;;AAAA;;AAAA;AAAA;AAAA;;AAAA;AAAA,2GAgBqB,UAAAC,KAAK;AAAA,eAAIA,KAAK,CAACC,QAAV;AAAA,OAhB1B;AAAA,iHAiB2B,8BACvB,MAAKC,gBADkB,EAEvB,UAAAD,QAAQ;AAAA,eACLE,MAAM,CAACC,IAAP,CAAYH,QAAZ,EAAsBI,MAAtB,IAAgCF,MAAM,CAACC,IAAP,CAAYH,QAAZ,EAAsB,CAAtB,CAAjC,IAA8D,IADxD;AAAA,OAFe,CAjB3B;AAAA,qGAwBe,YAAM;AACjB,YAAMK,cAAc,GAAG,MAAKC,sBAAL,CAA4B,MAAKC,KAAjC,CAAvB;;AACA,cAAKA,KAAL,CAAWC,SAAX,CAAqBH,cAArB;AACD,OA3BH;AAAA;AAAA;;AAAA;AAAA;AAAA,+BA6BW;AAAA;;AAAA,0BACqB,KAAKE,KAD1B;AAAA,YACAE,OADA,eACAA,OADA;AAAA,YACST,QADT,eACSA,QADT;AAEP,YAAMU,oBAAoB,GAAGD,OAAO,CAACE,IAAR,CAAa,UAAAC,CAAC;AAAA,iBAAIA,CAAC,CAACC,WAAN;AAAA,SAAd,CAA7B;AACA,YAAMC,cAAc,GAAGL,OAAO,CAACE,IAAR,CAAa,UAAAC,CAAC;AAAA,iBAAI,CAACA,CAAC,CAACG,IAAP;AAAA,SAAd,CAAvB;AACA,YAAMC,UAAU,GAAGd,MAAM,CAACC,IAAP,CAAYH,QAAZ,EAAsBI,MAAzC;AAEA,eACE;AAAK,UAAA,SAAS,EAAC;AAAf,WACE,gCAAC,iBAAD;AACE,UAAA,QAAQ,EAAEJ,QADZ;AAEE,UAAA,gBAAgB,EAAE,KAAKO,KAAL,CAAWU;AAF/B,UADF,EAKE,gCAAC,kCAAD,OALF,EAME,gCAAC,kCAAD,QACGR,OAAO,IACNA,OAAO,CAACS,GAAR,CAAY,UAACC,MAAD,EAASC,GAAT;AAAA,iBACV,gCAAC,WAAD;AACE,YAAA,GAAG,YAAKD,MAAM,CAACE,EAAZ,cAAkBD,GAAlB,CADL;AAEE,YAAA,GAAG,EAAEA,GAFP;AAGE,YAAA,OAAO,EAAEX,OAHX;AAIE,YAAA,MAAM,EAAEU,MAJV;AAKE,YAAA,QAAQ,EAAEnB,QALZ;AAME,YAAA,oBAAoB,EAAEU,oBANxB;AAOE,YAAA,YAAY,EAAE;AAAA,qBAAM,MAAI,CAACH,KAAL,CAAWe,YAAX,CAAwBF,GAAxB,CAAN;AAAA,aAPhB;AAQE,YAAA,aAAa,EAAE;AAAA,qBAAM,MAAI,CAACb,KAAL,CAAWgB,aAAX,CAAyBH,GAAzB,CAAN;AAAA,aARjB;AASE,YAAA,eAAe,EAAE;AAAA,qBAAM,MAAI,CAACb,KAAL,CAAWiB,eAAX,CAA2BJ,GAA3B,CAAN;AAAA,aATnB;AAUE,YAAA,SAAS,EAAE,MAAI,CAACb,KAAL,CAAWkB;AAVxB,YADU;AAAA,SAAZ,CAFJ,CANF,EAuBE,gCAAC,wBAAD;AACE,UAAA,QAAQ,EAAEX,cAAc,IAAI,CAACE,UAD/B;AAEE,UAAA,KAAK,EAAC,OAFR;AAGE,UAAA,OAAO,EAAE,KAAKU;AAHhB,WAKE,gCAAC,UAAD;AAAK,UAAA,MAAM,EAAC;AAAZ,UALF,eAvBF,CADF;AAkCD;AArEH;AAAA;AAAA,IAAmCC,gBAAnC,yDACqB;AACjB3B,IAAAA,QAAQ,EAAE4B,sBAAUC,MADH;AAEjBrB,IAAAA,SAAS,EAAEoB,sBAAUE,IAAV,CAAeC,UAFT;AAGjBT,IAAAA,YAAY,EAAEM,sBAAUE,IAAV,CAAeC,UAHZ;AAIjBR,IAAAA,aAAa,EAAEK,sBAAUE,IAAV,CAAeC,UAJb;AAKjBP,IAAAA,eAAe,EAAEI,sBAAUE,IAAV,CAAeC,UALf;AAMjBN,IAAAA,SAAS,EAAEG,sBAAUE,IAAV,CAAeC,UANT;AAOjBtB,IAAAA,OAAO,EAAEmB,sBAAUI,OAAV,CAAkBJ,sBAAUK,GAA5B,EAAiCF,UAPzB;AAQjBd,IAAAA,gBAAgB,EAAEW,sBAAUE,IARX;AAUjB;AACAI,IAAAA,MAAM,EAAEN,sBAAUI,OAAV,CAAkBJ,sBAAUK,GAA5B;AAXS,GADrB;AAuED;;eAEcxC,oB","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 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 './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      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\" />\n            Add Filter\n          </Button>\n        </div>\n      );\n    }\n  };\n}\n\nexport default FilterManagerFactory;\n"]}