UNPKG

kepler.gl

Version:

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

104 lines (89 loc) 12.8 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 _styledComponents = require("../../common/styled-components"); var _polygonFilter = _interopRequireDefault(require("../polygon-filter")); var _panelHeaderAction = _interopRequireDefault(require("../../side-panel/panel-header-action")); var _icons = require("../../common/icons"); var _filterPanelHeader = _interopRequireDefault(require("../../side-panel/filter-panel/filter-panel-header")); var _components = require("../components"); var _lodash = _interopRequireDefault(require("lodash.get")); // Copyright (c) 2020 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. PolygonFilterPanelFactory.deps = [_filterPanelHeader["default"], _polygonFilter["default"]]; function PolygonFilterPanelFactory(FilterPanelHeader, PolygonFilter) { var PolygonFilterPanel = _react["default"].memo(function (_ref) { var idx = _ref.idx, datasets = _ref.datasets, layers = _ref.layers, layerData = _ref.layerData, allAvailableFields = _ref.allAvailableFields, filter = _ref.filter, isAnyFilterAnimating = _ref.isAnyFilterAnimating, enlargeFilter = _ref.enlargeFilter, removeFilter = _ref.removeFilter, setFilter = _ref.setFilter, toggleFilterFeature = _ref.toggleFilterFeature; var filterDatasets = (0, _react.useMemo)(function () { return filter.dataId.map(function (d) { return datasets[d]; }); }, [filter, datasets]); var onSetLayers = (0, _react.useCallback)(function (value) { return setFilter(idx, 'layerId', value); }, [setFilter]); var isVisible = (0, _lodash["default"])(filter, ['value', 'properties', 'isVisible'], true); var featureType = (0, _lodash["default"])(filter, ['value', 'properties', 'renderType'], true); return _react["default"].createElement("div", { className: "polygon-filter-panel" }, _react["default"].createElement(FilterPanelHeader, { datasets: filterDatasets, allAvailableFields: allAvailableFields, idx: idx, filter: filter, removeFilter: removeFilter }, _react["default"].createElement(_components.StyledFilterPanel, null, "Geo - ", featureType), _react["default"].createElement(_panelHeaderAction["default"], { id: filter.id, onClick: toggleFilterFeature, tooltip: isVisible ? 'tooltip.hideFeature' : 'tooltip.showFeature', IconComponent: isVisible ? _icons.EyeSeen : _icons.EyeUnseen, active: isVisible })), _react["default"].createElement(_styledComponents.StyledFilterContent, { className: "filter-panel__content" }, _react["default"].createElement("div", { className: "filter-panel__filter" }, _react["default"].createElement(PolygonFilter, { filter: filter, layers: layers, setLayers: onSetLayers, toggleFilterFeature: toggleFilterFeature })))); }); PolygonFilterPanel.displayName = 'PolygonFilterPanel'; return PolygonFilterPanel; } var _default = PolygonFilterPanelFactory; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/filters/filter-panels/polygon-filter-panel.js"],"names":["PolygonFilterPanelFactory","deps","FilterPanelHeaderFactory","PolygonFilterFactory","FilterPanelHeader","PolygonFilter","PolygonFilterPanel","React","memo","idx","datasets","layers","layerData","allAvailableFields","filter","isAnyFilterAnimating","enlargeFilter","removeFilter","setFilter","toggleFilterFeature","filterDatasets","dataId","map","d","onSetLayers","value","isVisible","featureType","id","EyeSeen","EyeUnseen","displayName"],"mappings":";;;;;;;;;;;AAoBA;;AACA;;AACA;;AACA;;AACA;;AAEA;;AACA;;AAEA;;AA7BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAaAA,yBAAyB,CAACC,IAA1B,GAAiC,CAACC,6BAAD,EAA2BC,yBAA3B,CAAjC;;AAEA,SAASH,yBAAT,CAAmCI,iBAAnC,EAAsDC,aAAtD,EAAqE;AACnE,MAAMC,kBAAkB,GAAGC,kBAAMC,IAAN,CACzB,gBAYM;AAAA,QAXJC,GAWI,QAXJA,GAWI;AAAA,QAVJC,QAUI,QAVJA,QAUI;AAAA,QATJC,MASI,QATJA,MASI;AAAA,QARJC,SAQI,QARJA,SAQI;AAAA,QAPJC,kBAOI,QAPJA,kBAOI;AAAA,QANJC,MAMI,QANJA,MAMI;AAAA,QALJC,oBAKI,QALJA,oBAKI;AAAA,QAJJC,aAII,QAJJA,aAII;AAAA,QAHJC,YAGI,QAHJA,YAGI;AAAA,QAFJC,SAEI,QAFJA,SAEI;AAAA,QADJC,mBACI,QADJA,mBACI;AACJ,QAAMC,cAAc,GAAG,oBAAQ;AAAA,aAAMN,MAAM,CAACO,MAAP,CAAcC,GAAd,CAAkB,UAAAC,CAAC;AAAA,eAAIb,QAAQ,CAACa,CAAD,CAAZ;AAAA,OAAnB,CAAN;AAAA,KAAR,EAAmD,CAACT,MAAD,EAASJ,QAAT,CAAnD,CAAvB;AAEA,QAAMc,WAAW,GAAG,wBAAY,UAAAC,KAAK;AAAA,aAAIP,SAAS,CAACT,GAAD,EAAM,SAAN,EAAiBgB,KAAjB,CAAb;AAAA,KAAjB,EAAuD,CAACP,SAAD,CAAvD,CAApB;AAEA,QAAMQ,SAAS,GAAG,wBAAIZ,MAAJ,EAAY,CAAC,OAAD,EAAU,YAAV,EAAwB,WAAxB,CAAZ,EAAkD,IAAlD,CAAlB;AACA,QAAMa,WAAW,GAAG,wBAAIb,MAAJ,EAAY,CAAC,OAAD,EAAU,YAAV,EAAwB,YAAxB,CAAZ,EAAmD,IAAnD,CAApB;AAEA,WACE;AAAK,MAAA,SAAS,EAAC;AAAf,OACE,gCAAC,iBAAD;AACE,MAAA,QAAQ,EAAEM,cADZ;AAEE,MAAA,kBAAkB,EAAEP,kBAFtB;AAGE,MAAA,GAAG,EAAEJ,GAHP;AAIE,MAAA,MAAM,EAAEK,MAJV;AAKE,MAAA,YAAY,EAAEG;AALhB,OAOE,gCAAC,6BAAD,kBAA0BU,WAA1B,CAPF,EAQE,gCAAC,6BAAD;AACE,MAAA,EAAE,EAAEb,MAAM,CAACc,EADb;AAEE,MAAA,OAAO,EAAET,mBAFX;AAGE,MAAA,OAAO,EAAEO,SAAS,GAAG,qBAAH,GAA2B,qBAH/C;AAIE,MAAA,aAAa,EAAEA,SAAS,GAAGG,cAAH,GAAaC,gBAJvC;AAKE,MAAA,MAAM,EAAEJ;AALV,MARF,CADF,EAiBE,gCAAC,qCAAD;AAAqB,MAAA,SAAS,EAAC;AAA/B,OACE;AAAK,MAAA,SAAS,EAAC;AAAf,OACE,gCAAC,aAAD;AACE,MAAA,MAAM,EAAEZ,MADV;AAEE,MAAA,MAAM,EAAEH,MAFV;AAGE,MAAA,SAAS,EAAEa,WAHb;AAIE,MAAA,mBAAmB,EAAEL;AAJvB,MADF,CADF,CAjBF,CADF;AA8BD,GAnDwB,CAA3B;;AAsDAb,EAAAA,kBAAkB,CAACyB,WAAnB,GAAiC,oBAAjC;AAEA,SAAOzB,kBAAP;AACD;;eAEcN,yB","sourcesContent":["// Copyright (c) 2020 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, {useMemo, useCallback} from 'react';\nimport {StyledFilterContent} from 'components/common/styled-components';\nimport PolygonFilterFactory from 'components/filters/polygon-filter';\nimport PanelHeaderAction from 'components/side-panel/panel-header-action';\nimport {EyeSeen} from 'components/common/icons';\nimport {EyeUnseen} from 'components/common/icons';\nimport FilterPanelHeaderFactory from 'components/side-panel/filter-panel/filter-panel-header';\nimport {StyledFilterPanel} from '../components';\n\nimport get from 'lodash.get';\n\nPolygonFilterPanelFactory.deps = [FilterPanelHeaderFactory, PolygonFilterFactory];\n\nfunction PolygonFilterPanelFactory(FilterPanelHeader, PolygonFilter) {\n  const PolygonFilterPanel = React.memo(\n    ({\n      idx,\n      datasets,\n      layers,\n      layerData,\n      allAvailableFields,\n      filter,\n      isAnyFilterAnimating,\n      enlargeFilter,\n      removeFilter,\n      setFilter,\n      toggleFilterFeature\n    }) => {\n      const filterDatasets = useMemo(() => filter.dataId.map(d => datasets[d]), [filter, datasets]);\n\n      const onSetLayers = useCallback(value => setFilter(idx, 'layerId', value), [setFilter]);\n\n      const isVisible = get(filter, ['value', 'properties', 'isVisible'], true);\n      const featureType = get(filter, ['value', 'properties', 'renderType'], true);\n\n      return (\n        <div className=\"polygon-filter-panel\">\n          <FilterPanelHeader\n            datasets={filterDatasets}\n            allAvailableFields={allAvailableFields}\n            idx={idx}\n            filter={filter}\n            removeFilter={removeFilter}\n          >\n            <StyledFilterPanel>Geo - {featureType}</StyledFilterPanel>\n            <PanelHeaderAction\n              id={filter.id}\n              onClick={toggleFilterFeature}\n              tooltip={isVisible ? 'tooltip.hideFeature' : 'tooltip.showFeature'}\n              IconComponent={isVisible ? EyeSeen : EyeUnseen}\n              active={isVisible}\n            />\n          </FilterPanelHeader>\n          <StyledFilterContent className=\"filter-panel__content\">\n            <div className=\"filter-panel__filter\">\n              <PolygonFilter\n                filter={filter}\n                layers={layers}\n                setLayers={onSetLayers}\n                toggleFilterFeature={toggleFilterFeature}\n              />\n            </div>\n          </StyledFilterContent>\n        </div>\n      );\n    }\n  );\n\n  PolygonFilterPanel.displayName = 'PolygonFilterPanel';\n\n  return PolygonFilterPanel;\n}\n\nexport default PolygonFilterPanelFactory;\n"]}