kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
102 lines (87 loc) • 12.9 kB
JavaScript
"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) 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.
PolygonFilterPanelFactory.deps = [_filterPanelHeader["default"], _polygonFilter["default"], _panelHeaderAction["default"]];
function PolygonFilterPanelFactory(FilterPanelHeader, PolygonFilter, PanelHeaderAction) {
/** @type {import('./filter-panel-types').FilterPanelComponent} */
var PolygonFilterPanel = /*#__PURE__*/_react["default"].memo(function (_ref) {
var idx = _ref.idx,
datasets = _ref.datasets,
layers = _ref.layers,
allAvailableFields = _ref.allAvailableFields,
filter = _ref.filter,
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, idx]);
var isVisible = (0, _lodash["default"])(filter, ['value', 'properties', 'isVisible'], true);
var featureType = (0, _lodash["default"])(filter, ['value', 'properties', 'renderType'], true);
return /*#__PURE__*/_react["default"].createElement("div", {
className: "polygon-filter-panel"
}, /*#__PURE__*/_react["default"].createElement(FilterPanelHeader, {
datasets: filterDatasets,
allAvailableFields: allAvailableFields,
idx: idx,
filter: filter,
removeFilter: removeFilter
}, /*#__PURE__*/_react["default"].createElement(_components.StyledFilterPanel, null, "Geo - ", featureType), /*#__PURE__*/_react["default"].createElement(PanelHeaderAction, {
id: filter.id,
onClick: toggleFilterFeature,
tooltip: isVisible ? 'tooltip.hideFeature' : 'tooltip.showFeature',
IconComponent: isVisible ? _icons.EyeSeen : _icons.EyeUnseen,
active: isVisible
})), /*#__PURE__*/_react["default"].createElement(_styledComponents.StyledFilterContent, {
className: "filter-panel__content"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "filter-panel__filter"
}, /*#__PURE__*/_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","PanelHeaderActionFactory","FilterPanelHeader","PolygonFilter","PanelHeaderAction","PolygonFilterPanel","React","memo","idx","datasets","layers","allAvailableFields","filter","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,CAC/BC,6BAD+B,EAE/BC,yBAF+B,EAG/BC,6BAH+B,CAAjC;;AAMA,SAASJ,yBAAT,CAAmCK,iBAAnC,EAAsDC,aAAtD,EAAqEC,iBAArE,EAAwF;AACtF;AACA,MAAMC,kBAAkB,gBAAGC,kBAAMC,IAAN,CACzB,gBASM;AAAA,QARJC,GAQI,QARJA,GAQI;AAAA,QAPJC,QAOI,QAPJA,QAOI;AAAA,QANJC,MAMI,QANJA,MAMI;AAAA,QALJC,kBAKI,QALJA,kBAKI;AAAA,QAJJC,MAII,QAJJA,MAII;AAAA,QAHJC,YAGI,QAHJA,YAGI;AAAA,QAFJC,SAEI,QAFJA,SAEI;AAAA,QADJC,mBACI,QADJA,mBACI;AACJ,QAAMC,cAAc,GAAG,oBAAQ;AAAA,aAAMJ,MAAM,CAACK,MAAP,CAAcC,GAAd,CAAkB,UAAAC,CAAC;AAAA,eAAIV,QAAQ,CAACU,CAAD,CAAZ;AAAA,OAAnB,CAAN;AAAA,KAAR,EAAmD,CAACP,MAAD,EAASH,QAAT,CAAnD,CAAvB;AAEA,QAAMW,WAAW,GAAG,wBAAY,UAAAC,KAAK;AAAA,aAAIP,SAAS,CAACN,GAAD,EAAM,SAAN,EAAiBa,KAAjB,CAAb;AAAA,KAAjB,EAAuD,CAACP,SAAD,EAAYN,GAAZ,CAAvD,CAApB;AAEA,QAAMc,SAAS,GAAG,wBAAIV,MAAJ,EAAY,CAAC,OAAD,EAAU,YAAV,EAAwB,WAAxB,CAAZ,EAAkD,IAAlD,CAAlB;AACA,QAAMW,WAAW,GAAG,wBAAIX,MAAJ,EAAY,CAAC,OAAD,EAAU,YAAV,EAAwB,YAAxB,CAAZ,EAAmD,IAAnD,CAApB;AAEA,wBACE;AAAK,MAAA,SAAS,EAAC;AAAf,oBACE,gCAAC,iBAAD;AACE,MAAA,QAAQ,EAAEI,cADZ;AAEE,MAAA,kBAAkB,EAAEL,kBAFtB;AAGE,MAAA,GAAG,EAAEH,GAHP;AAIE,MAAA,MAAM,EAAEI,MAJV;AAKE,MAAA,YAAY,EAAEC;AALhB,oBAOE,gCAAC,6BAAD,kBAA0BU,WAA1B,CAPF,eAQE,gCAAC,iBAAD;AACE,MAAA,EAAE,EAAEX,MAAM,CAACY,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,oBACE;AAAK,MAAA,SAAS,EAAC;AAAf,oBACE,gCAAC,aAAD;AACE,MAAA,MAAM,EAAEV,MADV;AAEE,MAAA,MAAM,EAAEF,MAFV;AAGE,MAAA,SAAS,EAAEU,WAHb;AAIE,MAAA,mBAAmB,EAAEL;AAJvB,MADF,CADF,CAjBF,CADF;AA8BD,GAhDwB,CAA3B;;AAmDAV,EAAAA,kBAAkB,CAACsB,WAAnB,GAAiC,oBAAjC;AAEA,SAAOtB,kBAAP;AACD;;eAEcR,yB","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, {useMemo, useCallback} from 'react';\nimport {StyledFilterContent} from 'components/common/styled-components';\nimport PolygonFilterFactory from 'components/filters/polygon-filter';\nimport PanelHeaderActionFactory from 'components/side-panel/panel-header-action';\nimport {EyeSeen, EyeUnseen} from 'components/common/icons';\n\nimport FilterPanelHeaderFactory from 'components/side-panel/filter-panel/filter-panel-header';\nimport {StyledFilterPanel} from '../components';\n\nimport get from 'lodash.get';\n\nPolygonFilterPanelFactory.deps = [\n  FilterPanelHeaderFactory,\n  PolygonFilterFactory,\n  PanelHeaderActionFactory\n];\n\nfunction PolygonFilterPanelFactory(FilterPanelHeader, PolygonFilter, PanelHeaderAction) {\n  /** @type {import('./filter-panel-types').FilterPanelComponent} */\n  const PolygonFilterPanel = React.memo(\n    ({\n      idx,\n      datasets,\n      layers,\n      allAvailableFields,\n      filter,\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, idx]);\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"]}