kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
180 lines (175 loc) • 24.1 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.generateMapboxLayers = generateMapboxLayers;
exports.geoJsonFromData = geoJsonFromData;
exports.gpuFilterToMapboxFilter = gpuFilterToMapboxFilter;
exports.prefixGpuField = void 0;
exports.updateMapboxLayers = updateMapboxLayers;
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _baseLayer = require("./base-layer");
var _utils = require("@kepler.gl/utils");
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
/**
* This function will convert layers to mapbox layers
* @param layers the layers to be converted
* @param layerData extra layer information
* @param layerOrder the order by which we should convert layers
* @param layersToRender {[id]: true | false} object whether each layer should be rendered
* @returns
*/
function generateMapboxLayers() {
var layers = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
var layerData = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
var layerOrder = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];
var layersToRender = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};
if (layerData.length > 0) {
return layerOrder.slice().reverse().filter(function (layerId) {
var layer = (0, _utils.findById)(layerId)(layers);
return (layer === null || layer === void 0 ? void 0 : layer.overlayType) === _baseLayer.OVERLAY_TYPE_CONST.mapboxgl && layersToRender[layerId];
}).reduce(function (acc, layerId) {
var layerIndex = layers.findIndex(function (l) {
return l.id === layerId;
});
if (layerIndex === -1) {
return acc;
}
var layer = layers[layerIndex];
if (!(layer.overlayType === _baseLayer.OVERLAY_TYPE_CONST.mapboxgl && layersToRender[layerId])) {
return acc;
}
return _objectSpread(_objectSpread({}, acc), {}, (0, _defineProperty2["default"])({}, layer.id, {
id: layer.id,
data: layerData[layerIndex].data,
isVisible: layer.config.isVisible,
config: layerData[layerIndex].config,
hidden: layer.config.hidden,
sourceId: layerData[layerIndex].config.source
}));
}, {});
}
return {};
}
/**
* Update mapbox layers on the given map
* @param map
* @param newLayers Map of new mapbox layers to be displayed
* @param oldLayers Map of the old layers to be compare with the current ones to detect deleted layers
* {layerId: sourceId}
*/
function updateMapboxLayers(map) {
var newLayers = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
var oldLayers = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null;
// delete no longer existed old layers
if (oldLayers) {
checkAndRemoveOldLayers(map, oldLayers, newLayers);
}
// insert or update new layer
Object.values(newLayers).forEach(function (overlay) {
var layerId = overlay.id,
config = overlay.config,
data = overlay.data,
sourceId = overlay.sourceId,
isVisible = overlay.isVisible;
if (!data && !config) {
return;
}
var _ref = oldLayers && oldLayers[layerId] || {},
oldData = _ref.data,
oldConfig = _ref.config;
if (data && data !== oldData) {
updateSourceData(map, sourceId, data);
}
// compare with previous configs
if (oldConfig !== config) {
updateLayerConfig(map, layerId, config, isVisible);
}
});
}
function checkAndRemoveOldLayers(map, oldLayers, newLayers) {
Object.keys(oldLayers).forEach(function (layerId) {
if (!newLayers[layerId]) {
map.removeLayer(layerId);
}
});
}
function updateLayerConfig(map, layerId, config, isVisible) {
var mapboxLayer = map.getLayer(layerId);
if (mapboxLayer) {
// check if layer already is set
// remove it if exists
map.removeLayer(layerId);
}
map.addLayer(config);
map.setLayoutProperty(layerId, 'visibility', isVisible ? 'visible' : 'none');
}
function updateSourceData(map, sourceId, data) {
var source = map.getSource(sourceId);
if (!source) {
map.addSource(sourceId, {
type: 'geojson',
data: data
});
} else {
source.setData(data);
}
}
/**
*
* @param filteredIndex
* @param getGeometry {({index: number}) => any}
* @param getProperties {({index: number}) => any}
* @returns FeatureCollection
*/
function geoJsonFromData() {
var filteredIndex = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
var getGeometry = arguments.length > 1 ? arguments[1] : undefined;
var getProperties = arguments.length > 2 ? arguments[2] : undefined;
var geojson = {
type: 'FeatureCollection',
features: []
};
for (var i = 0; i < filteredIndex.length; i++) {
var index = filteredIndex[i];
var rowIndex = {
index: index
};
var geometry = getGeometry(rowIndex);
if (geometry) {
geojson.features.push({
type: 'Feature',
properties: _objectSpread({
index: index
}, getProperties(rowIndex)),
geometry: geometry
});
}
}
return geojson;
}
var prefixGpuField = exports.prefixGpuField = function prefixGpuField(name) {
return "gpu:".concat(name);
};
function gpuFilterToMapboxFilter(gpuFilter) {
var filterRange = gpuFilter.filterRange,
filterValueUpdateTriggers = gpuFilter.filterValueUpdateTriggers;
var hasFilter = Object.values(filterValueUpdateTriggers).filter(function (d) {
return d;
});
if (!hasFilter.length) {
return null;
}
var condition = ['all'];
// [">=", key, value]
// ["<=", key, value]
var expressions = Object.values(filterValueUpdateTriggers).reduce(function (accu, gpu, i) {
return gpu !== null && gpu !== void 0 && gpu.name ? [].concat((0, _toConsumableArray2["default"])(accu), [['>=', prefixGpuField(gpu.name), filterRange[i][0]], ['<=', prefixGpuField(gpu.name), filterRange[i][1]]]) : accu;
}, condition);
return expressions;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_baseLayer","require","_utils","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","generateMapboxLayers","layers","undefined","layerData","layerOrder","layersToRender","slice","reverse","layerId","layer","findById","overlayType","OVERLAY_TYPE_CONST","mapboxgl","reduce","acc","layerIndex","findIndex","l","id","data","isVisible","config","hidden","sourceId","source","updateMapboxLayers","map","newLayers","oldLayers","checkAndRemoveOldLayers","values","overlay","_ref","oldData","oldConfig","updateSourceData","updateLayerConfig","removeLayer","mapboxLayer","getLayer","addLayer","setLayoutProperty","getSource","addSource","type","setData","geoJsonFromData","filteredIndex","getGeometry","getProperties","geojson","features","i","index","rowIndex","geometry","properties","prefixGpuField","exports","name","concat","gpuFilterToMapboxFilter","gpuFilter","filterRange","filterValueUpdateTriggers","hasFilter","d","condition","expressions","accu","gpu","_toConsumableArray2"],"sources":["../src/mapbox-utils.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport Layer, {OVERLAY_TYPE_CONST} from './base-layer';\nimport {Feature} from 'geojson';\n\nimport {findById} from '@kepler.gl/utils';\n\n/**\n * This function will convert layers to mapbox layers\n * @param layers the layers to be converted\n * @param layerData extra layer information\n * @param layerOrder the order by which we should convert layers\n * @param layersToRender {[id]: true | false} object whether each layer should be rendered\n * @returns\n */\nexport function generateMapboxLayers(\n  layers: Layer[] = [],\n  layerData: any[] = [],\n  layerOrder: string[] = [],\n  layersToRender: {[key: string]: boolean} = {}\n): {[key: string]: Layer} {\n  if (layerData.length > 0) {\n    return layerOrder\n      .slice()\n      .reverse()\n      .filter(layerId => {\n        const layer = findById(layerId)(layers);\n        return layer?.overlayType === OVERLAY_TYPE_CONST.mapboxgl && layersToRender[layerId];\n      })\n      .reduce((acc, layerId) => {\n        const layerIndex = layers.findIndex(l => l.id === layerId);\n        if (layerIndex === -1) {\n          return acc;\n        }\n\n        const layer = layers[layerIndex];\n\n        if (!(layer.overlayType === OVERLAY_TYPE_CONST.mapboxgl && layersToRender[layerId])) {\n          return acc;\n        }\n\n        return {\n          ...acc,\n          [layer.id]: {\n            id: layer.id,\n            data: layerData[layerIndex].data,\n            isVisible: layer.config.isVisible,\n            config: layerData[layerIndex].config,\n            hidden: layer.config.hidden,\n            sourceId: layerData[layerIndex].config.source\n          }\n        };\n      }, {});\n  }\n\n  return {};\n}\n\ntype newLayersType = {\n  [key: string]: Layer & Partial<{data: any; sourceId: any; isVisible: boolean}>;\n};\ntype oldLayersType = {[key: string]: Layer & {data?: any}};\n/**\n * Update mapbox layers on the given map\n * @param map\n * @param newLayers Map of new mapbox layers to be displayed\n * @param oldLayers Map of the old layers to be compare with the current ones to detect deleted layers\n *                  {layerId: sourceId}\n */\nexport function updateMapboxLayers(\n  map,\n  newLayers: newLayersType = {},\n  oldLayers: oldLayersType | null = null\n) {\n  // delete no longer existed old layers\n  if (oldLayers) {\n    checkAndRemoveOldLayers(map, oldLayers, newLayers);\n  }\n\n  // insert or update new layer\n  Object.values(newLayers).forEach(overlay => {\n    const {id: layerId, config, data, sourceId, isVisible} = overlay;\n    if (!data && !config) {\n      return;\n    }\n\n    const {data: oldData, config: oldConfig} = (oldLayers && oldLayers[layerId]) || {};\n\n    if (data && data !== oldData) {\n      updateSourceData(map, sourceId, data);\n    }\n\n    // compare with previous configs\n    if (oldConfig !== config) {\n      updateLayerConfig(map, layerId, config, isVisible);\n    }\n  });\n}\n\nfunction checkAndRemoveOldLayers(map, oldLayers: oldLayersType, newLayers: newLayersType) {\n  Object.keys(oldLayers).forEach(layerId => {\n    if (!newLayers[layerId]) {\n      map.removeLayer(layerId);\n    }\n  });\n}\n\nfunction updateLayerConfig(map, layerId, config, isVisible) {\n  const mapboxLayer = map.getLayer(layerId);\n\n  if (mapboxLayer) {\n    // check if layer already is set\n    // remove it if exists\n    map.removeLayer(layerId);\n  }\n\n  map.addLayer(config);\n  map.setLayoutProperty(layerId, 'visibility', isVisible ? 'visible' : 'none');\n}\n\nfunction updateSourceData(map, sourceId, data) {\n  const source = map.getSource(sourceId);\n\n  if (!source) {\n    map.addSource(sourceId, {\n      type: 'geojson',\n      data\n    });\n  } else {\n    source.setData(data);\n  }\n}\n\n/**\n *\n * @param filteredIndex\n * @param getGeometry {({index: number}) => any}\n * @param getProperties {({index: number}) => any}\n * @returns FeatureCollection\n */\nexport function geoJsonFromData(\n  filteredIndex: number[] = [],\n  getGeometry: (arg: {index: number}) => any,\n  getProperties: (arg: {index: number}) => object\n) {\n  const geojson: {type: string; features: Feature[]} = {\n    type: 'FeatureCollection',\n    features: []\n  };\n\n  for (let i = 0; i < filteredIndex.length; i++) {\n    const index = filteredIndex[i];\n    const rowIndex = {index};\n    const geometry = getGeometry(rowIndex);\n\n    if (geometry) {\n      geojson.features.push({\n        type: 'Feature',\n        properties: {\n          index,\n          ...getProperties(rowIndex)\n        },\n        geometry\n      });\n    }\n  }\n\n  return geojson;\n}\n\nexport const prefixGpuField = name => `gpu:${name}`;\n\nexport function gpuFilterToMapboxFilter(gpuFilter) {\n  const {filterRange, filterValueUpdateTriggers} = gpuFilter;\n\n  const hasFilter = Object.values(filterValueUpdateTriggers).filter(d => d);\n\n  if (!hasFilter.length) {\n    return null;\n  }\n\n  const condition = ['all'];\n\n  // [\">=\", key, value]\n  // [\"<=\", key, value]\n  const expressions = Object.values(filterValueUpdateTriggers as ({name: string} | null)[]).reduce(\n    (accu: any[], gpu, i) =>\n      gpu?.name\n        ? [\n            ...accu,\n            ['>=', prefixGpuField(gpu.name), filterRange[i][0]],\n            ['<=', prefixGpuField(gpu.name), filterRange[i][1]]\n          ]\n        : accu,\n    condition\n  );\n\n  return expressions;\n}\n"],"mappings":"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","ignoreList":[]}
;