UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

132 lines (117 loc) 16.3 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _react = _interopRequireWildcard(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _localization = require("../../localization"); 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")); // Copyright (c) 2021 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 FilterManager = function FilterManager(_ref) { var _ref$filters = _ref.filters, filters = _ref$filters === void 0 ? [] : _ref$filters, datasets = _ref.datasets, layers = _ref.layers, showDatasetTable = _ref.showDatasetTable, visStateActions = _ref.visStateActions; var addFilter = visStateActions.addFilter, _enlargeFilter = visStateActions.enlargeFilter, _removeFilter = visStateActions.removeFilter, setFilter = visStateActions.setFilter, _toggleAnimation = visStateActions.toggleAnimation, _toggleFilterFeature = visStateActions.toggleFilterFeature; var isAnyFilterAnimating = filters.some(function (f) { return f.isAnimating; }); var hadEmptyFilter = filters.some(function (f) { return !f.name; }); var hadDataset = Object.keys(datasets).length; var onClickAddFilter = (0, _react.useCallback)(function () { var defaultDataset = Object.keys(datasets).length && Object.keys(datasets)[0] || null; addFilter(defaultDataset); }, [datasets, addFilter]); // render last added filter first var reversedIndex = (0, _react.useMemo)(function () { return new Array(filters.length).fill(0).map(function (d, i) { return i; }).reverse(); }, [filters.length]); return /*#__PURE__*/_react["default"].createElement("div", { className: "filter-manager" }, /*#__PURE__*/_react["default"].createElement(SourceDataCatalog, { datasets: datasets, showDatasetTable: showDatasetTable }), /*#__PURE__*/_react["default"].createElement(_styledComponents.SidePanelDivider, null), /*#__PURE__*/_react["default"].createElement(_styledComponents.SidePanelSection, null, reversedIndex.map(function (idx) { return /*#__PURE__*/_react["default"].createElement(FilterPanel, { key: "".concat(filters[idx].id, "-").concat(idx), idx: idx, filters: filters, filter: filters[idx], datasets: datasets, layers: layers, isAnyFilterAnimating: isAnyFilterAnimating, removeFilter: function removeFilter() { return _removeFilter(idx); }, enlargeFilter: function enlargeFilter() { return _enlargeFilter(idx); }, toggleAnimation: function toggleAnimation() { return _toggleAnimation(idx); }, toggleFilterFeature: function toggleFilterFeature() { return _toggleFilterFeature(idx); }, setFilter: setFilter }); })), /*#__PURE__*/_react["default"].createElement(_styledComponents.Button, { className: "add-filter-button", inactive: hadEmptyFilter || !hadDataset, width: "105px", onClick: onClickAddFilter }, /*#__PURE__*/_react["default"].createElement(_icons.Add, { height: "12px" }), /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'filterManager.addFilter' }))); }; FilterManager.propTypes = { datasets: _propTypes["default"].object, layers: _propTypes["default"].arrayOf(_propTypes["default"].any).isRequired, filters: _propTypes["default"].arrayOf(_propTypes["default"].any).isRequired, showDatasetTable: _propTypes["default"].func.isRequired, visStateActions: _propTypes["default"].object.isRequired, // fields can be undefined when dataset is not selected fields: _propTypes["default"].arrayOf(_propTypes["default"].any) }; return FilterManager; } 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","FilterManager","filters","datasets","layers","showDatasetTable","visStateActions","addFilter","enlargeFilter","removeFilter","setFilter","toggleAnimation","toggleFilterFeature","isAnyFilterAnimating","some","f","isAnimating","hadEmptyFilter","name","hadDataset","Object","keys","length","onClickAddFilter","defaultDataset","reversedIndex","Array","fill","map","d","i","reverse","idx","id","propTypes","PropTypes","object","arrayOf","any","isRequired","func","fields"],"mappings":"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","sourcesContent":["// Copyright (c) 2021 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, {useCallback, useMemo} from 'react';\nimport PropTypes from 'prop-types';\nimport {FormattedMessage} from 'localization';\nimport {Button, SidePanelDivider, SidePanelSection} 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  const FilterManager = ({filters = [], datasets, layers, showDatasetTable, visStateActions}) => {\n    const {\n      addFilter,\n      enlargeFilter,\n      removeFilter,\n      setFilter,\n      toggleAnimation,\n      toggleFilterFeature\n    } = visStateActions;\n    const isAnyFilterAnimating = filters.some(f => f.isAnimating);\n    const hadEmptyFilter = filters.some(f => !f.name);\n    const hadDataset = Object.keys(datasets).length;\n    const onClickAddFilter = useCallback(() => {\n      const defaultDataset = (Object.keys(datasets).length && Object.keys(datasets)[0]) || null;\n      addFilter(defaultDataset);\n    }, [datasets, addFilter]);\n    // render last added filter first\n    const reversedIndex = useMemo(() => {\n      return new Array(filters.length)\n        .fill(0)\n        .map((d, i) => i)\n        .reverse();\n    }, [filters.length]);\n\n    return (\n      <div className=\"filter-manager\">\n        <SourceDataCatalog datasets={datasets} showDatasetTable={showDatasetTable} />\n        <SidePanelDivider />\n        <SidePanelSection>\n          {reversedIndex.map(idx => (\n            <FilterPanel\n              key={`${filters[idx].id}-${idx}`}\n              idx={idx}\n              filters={filters}\n              filter={filters[idx]}\n              datasets={datasets}\n              layers={layers}\n              isAnyFilterAnimating={isAnyFilterAnimating}\n              removeFilter={() => removeFilter(idx)}\n              enlargeFilter={() => enlargeFilter(idx)}\n              toggleAnimation={() => toggleAnimation(idx)}\n              toggleFilterFeature={() => toggleFilterFeature(idx)}\n              setFilter={setFilter}\n            />\n          ))}\n        </SidePanelSection>\n        <Button\n          className=\"add-filter-button\"\n          inactive={hadEmptyFilter || !hadDataset}\n          width=\"105px\"\n          onClick={onClickAddFilter}\n        >\n          <Add height=\"12px\" />\n          <FormattedMessage id={'filterManager.addFilter'} />\n        </Button>\n      </div>\n    );\n  };\n\n  FilterManager.propTypes = {\n    datasets: PropTypes.object,\n    layers: PropTypes.arrayOf(PropTypes.any).isRequired,\n    filters: PropTypes.arrayOf(PropTypes.any).isRequired,\n    showDatasetTable: PropTypes.func.isRequired,\n    visStateActions: PropTypes.object.isRequired,\n\n    // fields can be undefined when dataset is not selected\n    fields: PropTypes.arrayOf(PropTypes.any)\n  };\n\n  return FilterManager;\n}\n\nexport default FilterManagerFactory;\n"]}