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
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) 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"]}