kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
77 lines (75 loc) • 12.6 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _react = _interopRequireWildcard(require("react"));
var _itemSelector = _interopRequireDefault(require("../common/item-selector/item-selector"));
var _constants = require("@kepler.gl/constants");
var _components = require("./components");
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
// SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
var layerFilter = function layerFilter(layer) {
return layer.type === _constants.LAYER_TYPES.point;
};
var isAlreadySelected = function isAlreadySelected(selectedLayers, layerId) {
return selectedLayers.findIndex(function (l) {
return l.id === layerId;
}) === -1;
};
function PolygonFilterFactory() {
var PolygonFilter = /*#__PURE__*/_react["default"].memo(function (_ref) {
var filter = _ref.filter,
layers = _ref.layers,
setLayers = _ref.setLayers;
var setNewLayers = (0, _react.useCallback)(function (newLayers) {
return setLayers(newLayers.map(function (l) {
return l.id;
}));
}, [setLayers]);
var selectedLayers = (0, _react.useMemo)(function () {
return layers.filter(function (l) {
var _filter$layerId;
return (_filter$layerId = filter.layerId) === null || _filter$layerId === void 0 ? void 0 : _filter$layerId.includes(l.id);
});
}, [filter, layers]);
var availableLayers = (0, _react.useMemo)(function () {
// remove already added layers and filter out non point layers
return layers.filter(function (layer) {
return layerFilter(layer) && isAlreadySelected(selectedLayers, layer.id);
});
}, [layers, selectedLayers]);
var searchOptions = (0, _react.useCallback)(function (value, options) {
var searchStr = value === null || value === void 0 ? void 0 : value.toLowerCase();
return options.filter(function (l) {
var _l$config;
return ((_l$config = l.config) === null || _l$config === void 0 || (_l$config = _l$config.label) === null || _l$config === void 0 ? void 0 : _l$config.toLowerCase().indexOf(searchStr)) >= 0;
});
}, []);
return /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(_components.StyledFilterPanel, {
htmlFor: "filter-".concat(filter.id)
}, "Layers:"), /*#__PURE__*/_react["default"].createElement(_itemSelector["default"], {
options: availableLayers,
selectedItems: selectedLayers,
onChange: setNewLayers,
searchable: true,
searchOptions: searchOptions,
multiSelect: true,
getOptionValue: function getOptionValue(l) {
return l.id;
},
displayOption: function displayOption(l) {
return l.config.label;
},
placeholder: 'placeholder.selectLayer'
}));
});
PolygonFilter.displayName = 'PolygonFilter';
return PolygonFilter;
}
var _default = exports["default"] = PolygonFilterFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_itemSelector","_interopRequireDefault","_constants","_components","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","layerFilter","layer","type","LAYER_TYPES","point","isAlreadySelected","selectedLayers","layerId","findIndex","l","id","PolygonFilterFactory","PolygonFilter","React","memo","_ref","filter","layers","setLayers","setNewLayers","useCallback","newLayers","map","useMemo","_filter$layerId","includes","availableLayers","searchOptions","value","options","searchStr","toLowerCase","_l$config","config","label","indexOf","createElement","StyledFilterPanel","htmlFor","concat","selectedItems","onChange","searchable","multiSelect","getOptionValue","displayOption","placeholder","displayName","_default","exports"],"sources":["../../src/filters/polygon-filter.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useMemo, useCallback} from 'react';\nimport ItemSelector from '../common/item-selector/item-selector';\nimport {Layer} from '@kepler.gl/layers';\nimport {LAYER_TYPES} from '@kepler.gl/constants';\nimport {PolygonFilterProps} from './types';\nimport {StyledFilterPanel} from './components';\n\nconst layerFilter = (layer: Layer) => layer.type === LAYER_TYPES.point;\nconst isAlreadySelected = (selectedLayers: Layer[], layerId: string) =>\n  selectedLayers.findIndex(l => l.id === layerId) === -1;\n\nfunction PolygonFilterFactory() {\n  const PolygonFilter: React.FC<PolygonFilterProps> = React.memo(({filter, layers, setLayers}) => {\n    const setNewLayers = useCallback(\n      newLayers => {\n        return setLayers(newLayers.map((l: Layer) => l.id));\n      },\n      [setLayers]\n    );\n\n    const selectedLayers = useMemo(\n      () => layers.filter(l => filter.layerId?.includes(l.id)),\n      [filter, layers]\n    );\n\n    const availableLayers = useMemo(() => {\n      // remove already added layers and filter out non point layers\n      return layers.filter(\n        layer => layerFilter(layer) && isAlreadySelected(selectedLayers, layer.id)\n      );\n    }, [layers, selectedLayers]);\n\n    const searchOptions = useCallback((value, options) => {\n      const searchStr = value?.toLowerCase();\n      return options.filter(l => l.config?.label?.toLowerCase().indexOf(searchStr) >= 0);\n    }, []);\n\n    return (\n      <div>\n        <StyledFilterPanel htmlFor={`filter-${filter.id}`}>Layers:</StyledFilterPanel>\n        <ItemSelector\n          options={availableLayers}\n          selectedItems={selectedLayers}\n          onChange={setNewLayers}\n          searchable={true}\n          searchOptions={searchOptions}\n          multiSelect={true}\n          getOptionValue={(l: Layer) => l.id}\n          displayOption={(l: Layer) => l.config.label}\n          placeholder={'placeholder.selectLayer'}\n        />\n      </div>\n    );\n  });\n\n  PolygonFilter.displayName = 'PolygonFilter';\n\n  return PolygonFilter;\n}\n\nexport default PolygonFilterFactory;\n"],"mappings":"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","ignoreList":[]}
;