kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
182 lines (154 loc) • 20.4 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.generateMapboxLayers = generateMapboxLayers;
exports.updateMapboxLayers = updateMapboxLayers;
exports.geojsonFromPoints = geojsonFromPoints;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _baseLayer = require("./base-layer");
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
/**
* 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
* @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] : [];
if (layerData.length > 0) {
return layerOrder.slice().reverse().reduce(function (overlays, idx) {
var layer = layers[idx];
return layer.overlayType !== _baseLayer.OVERLAY_TYPE.mapboxgl ? overlays : [].concat((0, _toConsumableArray2["default"])(overlays), [{
id: layer.id,
data: layerData[idx].data,
config: layerData[idx].config,
datasetId: layer.config.dataId
}]);
}, []);
}
return [];
}
;
/**
* Update mapbox layers on the given map
* @param map
* @param newLayers Array 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: datasetId}
* @param mapLayers carries information about split map view
*/
function updateMapboxLayers(map) {
var newLayers = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
var oldLayers = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null;
var mapLayers = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null;
var opt = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : {
force: true
};
// delete non existing layers
if (oldLayers) {
var oldLayersKeys = Object.keys(oldLayers);
if (newLayers.length === 0 && oldLayersKeys.length > 0) {
oldLayersKeys.forEach(function (layerId) {
return map.removeLayer(layerId);
});
} else {
// remove layers
var currentLayersIds = newLayers.reduce(function (_final, layer) {
return _objectSpread({}, _final, (0, _defineProperty2["default"])({}, layer.id, true));
}, {});
var layersToDelete = oldLayersKeys.reduce(function (_final2, layerId) {
// if layer doesn't exists anymore
if (!currentLayersIds[layerId]) {
return _objectSpread({}, _final2, (0, _defineProperty2["default"])({}, layerId, oldLayers[layerId]));
}
return _final2;
}, []);
Object.keys(layersToDelete).forEach(function (layerId) {
return map.removeLayer(layerId);
});
}
} // insert or update new layer
// TODO: fix complexity
/* eslint-disable complexity */
newLayers.forEach(function (overlay) {
var layerId = overlay.id,
config = overlay.config,
data = overlay.data,
datasetId = overlay.datasetId;
if (!data && !config) {
return;
}
var isAvailableAndVisible = !(mapLayers && mapLayers[layerId]) || mapLayers[layerId].isVisible; // checking if source already exists
if (data && isAvailableAndVisible) {
var source = map.getSource(datasetId);
if (!source) {
map.addSource(datasetId, {
type: 'geojson',
data: data
});
} else {
source.setData(data);
}
}
var oldConfig = oldLayers[layerId];
var mapboxLayer = map.getLayer(layerId); // compare with previous configs
if (!oldConfig || oldConfig !== config || !mapboxLayer || opt.force) {
// check if layer already is set
// remove it if exists
if (mapboxLayer) {
map.removeLayer(layerId);
} // add if visible and available
if (isAvailableAndVisible) {
map.addLayer(config);
}
}
});
/* eslint-enable complexity */
// TODO: think about removing sources
}
;
/**
*
* @param points
* @param columns {
* lat: {fieldIdx},
* lng: {fieldIdx},
* alt: {fieldIdx}
* }
* @param properties [{label: {fieldIdx}]
* @returns {{type: string, properties: {}, features: {type: string, properties: {}, geometry: {type: string, coordinates: *[]}}[]}}
*/
function geojsonFromPoints() {
var allData = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
var filteredIndex = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
var columns = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
var properties = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : [];
return {
type: 'FeatureCollection',
features: filteredIndex.map(function (index) {
return allData[index];
}).map(function (point) {
return {
type: 'Feature',
properties: properties.reduce(function (_final3, property) {
return _objectSpread({}, _final3, (0, _defineProperty2["default"])({}, property.name, point[property.tableFieldIndex - 1]));
}, {}),
geometry: {
type: 'Point',
coordinates: [columns.lng ? point[columns.lng.fieldIdx] : null, // lng
columns.lat ? point[columns.lat.fieldIdx] : null, // lat
columns.altitude ? point[columns.altitude.fieldIdx] : 0 // altitude
]
}
};
})
};
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/layers/mapbox-utils.js"],"names":["generateMapboxLayers","layers","layerData","layerOrder","length","slice","reverse","reduce","overlays","idx","layer","overlayType","OVERLAY_TYPE","mapboxgl","id","data","config","datasetId","dataId","updateMapboxLayers","map","newLayers","oldLayers","mapLayers","opt","force","oldLayersKeys","Object","keys","forEach","layerId","removeLayer","currentLayersIds","final","layersToDelete","overlay","isAvailableAndVisible","isVisible","source","getSource","addSource","type","setData","oldConfig","mapboxLayer","getLayer","addLayer","geojsonFromPoints","allData","filteredIndex","columns","properties","features","index","point","property","name","tableFieldIndex","geometry","coordinates","lng","fieldIdx","lat","altitude"],"mappings":"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","sourcesContent":["// Copyright (c) 2019 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 {OVERLAY_TYPE} from './base-layer';\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 * @returns {*}\n */\nexport function generateMapboxLayers(layers = [], layerData = [], layerOrder = []) {\n  if (layerData.length > 0) {\n    return layerOrder.slice()\n      .reverse()\n      .reduce((overlays, idx) => {\n        const layer = layers[idx];\n\n        return layer.overlayType !== OVERLAY_TYPE.mapboxgl ?\n          overlays\n          : [\n            ...overlays,\n            {\n              id: layer.id,\n              data: layerData[idx].data,\n              config: layerData[idx].config,\n              datasetId: layer.config.dataId\n            }\n          ]\n      }, []);\n  }\n\n  return [];\n};\n\n/**\n * Update mapbox layers on the given map\n * @param map\n * @param newLayers Array 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: datasetId}\n * @param mapLayers carries information about split map view\n */\nexport function updateMapboxLayers(map, newLayers = [], oldLayers = null, mapLayers = null, opt = {force: true}) {\n  // delete non existing layers\n\n  if (oldLayers) {\n    const oldLayersKeys = Object.keys(oldLayers);\n    if (newLayers.length === 0 && oldLayersKeys.length > 0) {\n      oldLayersKeys.forEach(layerId => map.removeLayer(layerId));\n    } else {\n      // remove layers\n      const currentLayersIds = newLayers.reduce((final, layer) => ({\n        ...final,\n        [layer.id]: true\n      }), {});\n\n      const layersToDelete = oldLayersKeys.reduce((final, layerId) => {\n        // if layer doesn't exists anymore\n        if (!currentLayersIds[layerId]) {\n          return {\n            ...final,\n            [layerId]: oldLayers[layerId]\n          };\n        }\n        return final;\n      }, []);\n      Object.keys(layersToDelete).forEach(layerId => map.removeLayer(layerId));\n    }\n  }\n\n  // insert or update new layer\n  // TODO: fix complexity\n  /* eslint-disable complexity */\n  newLayers.forEach(overlay => {\n    const {id: layerId, config, data, datasetId} = overlay;\n    if (!data && !config) {\n      return;\n    }\n    const isAvailableAndVisible =\n      !(mapLayers && mapLayers[layerId]) || mapLayers[layerId].isVisible;\n    // checking if source already exists\n\n    if (data && isAvailableAndVisible) {\n      const source = map.getSource(datasetId);\n      if (!source) {\n        map.addSource(datasetId, {\n          type: 'geojson',\n          data\n        });\n      }\n      else {\n        source.setData(data);\n      }\n    }\n\n    const oldConfig = oldLayers[layerId];\n    const mapboxLayer = map.getLayer(layerId);\n    // compare with previous configs\n\n    if (!oldConfig || oldConfig !== config || !mapboxLayer || opt.force) {\n      // check if layer already is set\n      // remove it if exists\n      if (mapboxLayer) {\n        map.removeLayer(layerId);\n      }\n      // add if visible and available\n      if (isAvailableAndVisible) {\n        map.addLayer(config);\n      }\n    }\n  });\n  /* eslint-enable complexity */\n  // TODO: think about removing sources\n};\n\n/**\n *\n * @param points\n * @param columns {\n * lat: {fieldIdx},\n * lng: {fieldIdx},\n * alt: {fieldIdx}\n * }\n * @param properties [{label: {fieldIdx}]\n * @returns {{type: string, properties: {}, features: {type: string, properties: {}, geometry: {type: string, coordinates: *[]}}[]}}\n */\nexport function geojsonFromPoints(allData = [], filteredIndex = [], columns = {}, properties = []) {\n  return {\n    type: 'FeatureCollection',\n    features: filteredIndex.map(index => allData[index]).map(point => ({\n      type: 'Feature',\n      properties: properties.reduce((final, property) => ({\n        ...final,\n        [property.name]: point[property.tableFieldIndex - 1]\n      }), {}),\n      geometry: {\n        type: 'Point',\n        coordinates: [\n          columns.lng ? point[columns.lng.fieldIdx] : null, // lng\n          columns.lat ? point[columns.lat.fieldIdx] : null, // lat\n          columns.altitude ? point[columns.altitude.fieldIdx] : 0 // altitude\n        ]\n      }\n    }))\n  };\n}\n"]}