UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

332 lines (328 loc) 38.3 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.createNewDataEntry = createNewDataEntry; exports.getNewDatasetColor = getNewDatasetColor; var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _uniq = _interopRequireDefault(require("lodash/uniq")); var _keplerTable = _interopRequireDefault(require("./kepler-table")); var _tasks = _interopRequireDefault(require("react-palm/tasks")); var _constants = require("@kepler.gl/constants"); var _utils = require("@kepler.gl/utils"); var _pmtiles = require("@loaders.gl/pmtiles"); var _tilesetUtils = require("./tileset/tileset-utils"); var _rasterTileUtils = require("./tileset/raster-tile-utils"); var _vectorTileUtils = require("./tileset/vector-tile-utils"); var _excluded = ["info", "data"]; // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project 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; } // apply a color for each dataset // to use as label colors var datasetColors = ['#8F2FBF', '#005CFF', '#C06C84', '#F8B195', '#547A82', '#3EACA8', '#A2D4AB'].map(_utils.hexToRgb); function getNewDatasetColor(datasets) { var presetColors = datasetColors.map(String); var usedColors = (0, _uniq["default"])(Object.values(datasets).map(function (d) { return String(d.color); })).filter(function (c) { return presetColors.includes(c); }); if (usedColors.length === presetColors.length) { // if we already depleted the pool of color return _utils.datasetColorMaker.next().value; } var color = _utils.datasetColorMaker.next().value; while (usedColors.includes(String(color))) { color = _utils.datasetColorMaker.next().value; } return color; } /** * Take datasets payload from addDataToMap, create datasets entry save to visState */ function createNewDataEntry(_ref) { var _getApplicationConfig; var info = _ref.info, data = _ref.data, opts = (0, _objectWithoutProperties2["default"])(_ref, _excluded); var datasets = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; var TableClass = (_getApplicationConfig = (0, _utils.getApplicationConfig)().table) !== null && _getApplicationConfig !== void 0 ? _getApplicationConfig : _keplerTable["default"]; var dataValidator = _utils.validateInputData; if (typeof TableClass.getInputDataValidator === 'function') { dataValidator = TableClass.getInputDataValidator(); } var validatedData = dataValidator(data); if (!validatedData) { return null; } // check if dataset already exists, and update it when loading data by batches incrementally if (info && info.id && datasets[info.id]) { // get keplerTable from datasets var keplerTable = datasets[info.id]; // update the data in keplerTable return UPDATE_TABLE_TASK({ table: keplerTable, data: validatedData }); } info = info || {}; var color = info.color || getNewDatasetColor(datasets); return CREATE_TABLE_TASK({ info: info, color: color, opts: opts, data: validatedData }); } function updateTable(_x) { return _updateTable.apply(this, arguments); } function _updateTable() { _updateTable = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(_ref2) { var table, data, updated; return _regenerator["default"].wrap(function _callee$(_context) { while (1) switch (_context.prev = _context.next) { case 0: table = _ref2.table, data = _ref2.data; _context.next = 3; return table.update(data); case 3: updated = _context.sent; return _context.abrupt("return", updated); case 5: case "end": return _context.stop(); } }, _callee); })); return _updateTable.apply(this, arguments); } function createTable(_x2) { return _createTable.apply(this, arguments); } function _createTable() { _createTable = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2(datasetInfo) { var _getApplicationConfig2; var info, color, opts, data, refreshedMetadata, metadata, TableClass, table; return _regenerator["default"].wrap(function _callee2$(_context2) { while (1) switch (_context2.prev = _context2.next) { case 0: info = datasetInfo.info, color = datasetInfo.color, opts = datasetInfo.opts, data = datasetInfo.data; // update metadata for remote tiled datasets _context2.next = 3; return refreshRemoteData(datasetInfo); case 3: refreshedMetadata = _context2.sent; metadata = opts.metadata; if (refreshedMetadata) { metadata = _objectSpread(_objectSpread({}, opts.metadata), refreshedMetadata); if (metadata.fields) { data.fields = metadata.fields; } } TableClass = (_getApplicationConfig2 = (0, _utils.getApplicationConfig)().table) !== null && _getApplicationConfig2 !== void 0 ? _getApplicationConfig2 : _keplerTable["default"]; table = new TableClass(_objectSpread(_objectSpread({ info: info, color: color }, opts), {}, { metadata: metadata })); _context2.next = 10; return table.importData({ data: data }); case 10: return _context2.abrupt("return", table); case 11: case "end": return _context2.stop(); } }, _callee2); })); return _createTable.apply(this, arguments); } var UPDATE_TABLE_TASK = _tasks["default"].fromPromise(updateTable, 'UPDATE_TABLE_TASK'); var CREATE_TABLE_TASK = _tasks["default"].fromPromise(createTable, 'CREATE_TABLE_TASK'); /** * Fetch metadata for vector tile layers using tilesetMetadataUrl from metadata * @param datasetInfo * @returns */ function refreshRemoteData(_x3) { return _refreshRemoteData.apply(this, arguments); } function _refreshRemoteData() { _refreshRemoteData = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3(datasetInfo) { var type; return _regenerator["default"].wrap(function _callee3$(_context3) { while (1) switch (_context3.prev = _context3.next) { case 0: type = datasetInfo.info.type; _context3.t0 = type; _context3.next = _context3.t0 === _constants.DatasetType.VECTOR_TILE ? 4 : _context3.t0 === _constants.DatasetType.RASTER_TILE ? 7 : 10; break; case 4: _context3.next = 6; return refreshVectorTileMetadata(datasetInfo); case 6: return _context3.abrupt("return", _context3.sent); case 7: _context3.next = 9; return refreshRasterTileMetadata(datasetInfo); case 9: return _context3.abrupt("return", _context3.sent); case 10: return _context3.abrupt("return", null); case 11: case "end": return _context3.stop(); } }, _callee3); })); return _refreshRemoteData.apply(this, arguments); } function refreshVectorTileMetadata(_x4) { return _refreshVectorTileMetadata.apply(this, arguments); } function _refreshVectorTileMetadata() { _refreshVectorTileMetadata = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4(datasetInfo) { var _ref3, remoteTileFormat, tilesetMetadataUrl, tilesetDataUrl, rawMetadata, tileSource, metadata; return _regenerator["default"].wrap(function _callee4$(_context4) { while (1) switch (_context4.prev = _context4.next) { case 0: _ref3 = datasetInfo.opts.metadata || {}, remoteTileFormat = _ref3.remoteTileFormat, tilesetMetadataUrl = _ref3.tilesetMetadataUrl, tilesetDataUrl = _ref3.tilesetDataUrl; if (!(!(remoteTileFormat === _constants.RemoteTileFormat.PMTILES || remoteTileFormat === _constants.RemoteTileFormat.MVT) || typeof tilesetMetadataUrl !== 'string' || typeof tilesetDataUrl !== 'string')) { _context4.next = 3; break; } return _context4.abrupt("return", null); case 3: _context4.prev = 3; rawMetadata = null; if (!(remoteTileFormat === _constants.RemoteTileFormat.MVT)) { _context4.next = 11; break; } _context4.next = 8; return (0, _tilesetUtils.getMVTMetadata)(tilesetMetadataUrl); case 8: rawMetadata = _context4.sent; _context4.next = 15; break; case 11: tileSource = _pmtiles.PMTilesSource.createDataSource(tilesetMetadataUrl, {}); _context4.next = 14; return tileSource.metadata; case 14: rawMetadata = _context4.sent; case 15: if (!rawMetadata) { _context4.next = 20; break; } metadata = (0, _vectorTileUtils.parseVectorMetadata)(rawMetadata); _context4.next = 19; return (0, _vectorTileUtils.getFieldsFromTile)({ remoteTileFormat: remoteTileFormat, tilesetUrl: tilesetDataUrl, metadataUrl: tilesetMetadataUrl, metadata: metadata }); case 19: return _context4.abrupt("return", metadata); case 20: _context4.next = 24; break; case 22: _context4.prev = 22; _context4.t0 = _context4["catch"](3); case 24: return _context4.abrupt("return", null); case 25: case "end": return _context4.stop(); } }, _callee4, null, [[3, 22]]); })); return _refreshVectorTileMetadata.apply(this, arguments); } function refreshRasterTileMetadata(_x5) { return _refreshRasterTileMetadata.apply(this, arguments); } function _refreshRasterTileMetadata() { _refreshRasterTileMetadata = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee5(datasetInfo) { var _ref4, metadataUrl, pmtilesType, tileSource, rawMetadata, response, _rawMetadata, metadata; return _regenerator["default"].wrap(function _callee5$(_context5) { while (1) switch (_context5.prev = _context5.next) { case 0: _ref4 = datasetInfo.opts.metadata || {}, metadataUrl = _ref4.metadataUrl, pmtilesType = _ref4.pmtilesType; if (!(typeof metadataUrl !== 'string')) { _context5.next = 3; break; } return _context5.abrupt("return", null); case 3: _context5.prev = 3; if (!(pmtilesType === _constants.PMTilesType.RASTER)) { _context5.next = 13; break; } tileSource = _pmtiles.PMTilesSource.createDataSource(metadataUrl, {}); _context5.next = 8; return tileSource.metadata; case 8: rawMetadata = _context5.sent; if (!rawMetadata) { _context5.next = 11; break; } return _context5.abrupt("return", (0, _vectorTileUtils.parseVectorMetadata)(rawMetadata)); case 11: _context5.next = 25; break; case 13: _context5.next = 15; return fetch(metadataUrl); case 15: response = _context5.sent; if (response.ok) { _context5.next = 18; break; } throw new Error("Failed Fetch ".concat(metadataUrl)); case 18: _context5.next = 20; return response.json(); case 20: _rawMetadata = _context5.sent; metadata = (0, _rasterTileUtils.parseRasterMetadata)(_rawMetadata, { allowCollections: true }); if (!(metadata instanceof Error)) { _context5.next = 24; break; } throw new Error("Failed to parse metadata ".concat(metadata.message)); case 24: return _context5.abrupt("return", metadata); case 25: _context5.next = 29; break; case 27: _context5.prev = 27; _context5.t0 = _context5["catch"](3); case 29: return _context5.abrupt("return", null); case 30: case "end": return _context5.stop(); } }, _callee5, null, [[3, 27]]); })); return _refreshRasterTileMetadata.apply(this, arguments); } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_uniq","_interopRequireDefault","require","_keplerTable","_tasks","_constants","_utils","_pmtiles","_tilesetUtils","_rasterTileUtils","_vectorTileUtils","_excluded","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","datasetColors","map","hexToRgb","getNewDatasetColor","datasets","presetColors","String","usedColors","uniq","values","d","color","c","includes","datasetColorMaker","next","value","createNewDataEntry","_ref","_getApplicationConfig","info","data","opts","_objectWithoutProperties2","undefined","TableClass","getApplicationConfig","table","KeplerTable","dataValidator","validateInputData","getInputDataValidator","validatedData","id","keplerTable","UPDATE_TABLE_TASK","CREATE_TABLE_TASK","updateTable","_x","_updateTable","_asyncToGenerator2","_regenerator","mark","_callee","_ref2","updated","wrap","_callee$","_context","prev","update","sent","abrupt","stop","createTable","_x2","_createTable","_callee2","datasetInfo","_getApplicationConfig2","refreshedMetadata","metadata","_callee2$","_context2","refreshRemoteData","fields","importData","Task","fromPromise","_x3","_refreshRemoteData","_callee3","type","_callee3$","_context3","t0","DatasetType","VECTOR_TILE","RASTER_TILE","refreshVectorTileMetadata","refreshRasterTileMetadata","_x4","_refreshVectorTileMetadata","_callee4","_ref3","remoteTileFormat","tilesetMetadataUrl","tilesetDataUrl","rawMetadata","tileSource","_callee4$","_context4","RemoteTileFormat","PMTILES","MVT","getMVTMetadata","PMTilesSource","createDataSource","parseVectorMetadata","getFieldsFromTile","tilesetUrl","metadataUrl","_x5","_refreshRasterTileMetadata","_callee5","_ref4","pmtilesType","response","_rawMetadata","_callee5$","_context5","PMTilesType","RASTER","fetch","ok","Error","concat","json","parseRasterMetadata","allowCollections","message"],"sources":["../src/dataset-utils.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport uniq from 'lodash/uniq';\nimport KeplerTable, {Datasets} from './kepler-table';\nimport {ProtoDataset, RGBColor} from '@kepler.gl/types';\nimport Task from 'react-palm/tasks';\n\nimport {\n  DatasetType,\n  RasterTileDatasetMetadata,\n  PMTilesType,\n  RemoteTileFormat,\n  VectorTileDatasetMetadata\n} from '@kepler.gl/constants';\nimport {\n  hexToRgb,\n  validateInputData,\n  datasetColorMaker,\n  getApplicationConfig\n} from '@kepler.gl/utils';\nimport {PMTilesSource, PMTilesMetadata} from '@loaders.gl/pmtiles';\nimport {/* MVTSource,*/ TileJSON} from '@loaders.gl/mvt';\n\nimport {getMVTMetadata} from './tileset/tileset-utils';\nimport {parseRasterMetadata} from './tileset/raster-tile-utils';\nimport {\n  parseVectorMetadata,\n  getFieldsFromTile,\n  VectorTileMetadata\n} from './tileset/vector-tile-utils';\n\n// apply a color for each dataset\n// to use as label colors\nconst datasetColors = [\n  '#8F2FBF',\n  '#005CFF',\n  '#C06C84',\n  '#F8B195',\n  '#547A82',\n  '#3EACA8',\n  '#A2D4AB'\n].map(hexToRgb);\n\nexport function getNewDatasetColor(datasets: Datasets): RGBColor {\n  const presetColors = datasetColors.map(String);\n  const usedColors = uniq(Object.values(datasets).map(d => String(d.color))).filter(c =>\n    presetColors.includes(c)\n  );\n\n  if (usedColors.length === presetColors.length) {\n    // if we already depleted the pool of color\n    return datasetColorMaker.next().value;\n  }\n\n  let color = datasetColorMaker.next().value;\n  while (usedColors.includes(String(color))) {\n    color = datasetColorMaker.next().value;\n  }\n\n  return color;\n}\n\n/**\n * Take datasets payload from addDataToMap, create datasets entry save to visState\n */\nexport function createNewDataEntry(\n  {info, data, ...opts}: ProtoDataset,\n  datasets: Datasets = {}\n): Datasets | null {\n  const TableClass = getApplicationConfig().table ?? KeplerTable;\n  let dataValidator = validateInputData;\n  if (typeof TableClass.getInputDataValidator === 'function') {\n    dataValidator = TableClass.getInputDataValidator();\n  }\n\n  const validatedData = dataValidator(data);\n  if (!validatedData) {\n    return null;\n  }\n\n  // check if dataset already exists, and update it when loading data by batches incrementally\n  if (info && info.id && datasets[info.id]) {\n    // get keplerTable from datasets\n    const keplerTable = datasets[info.id];\n    // update the data in keplerTable\n    return UPDATE_TABLE_TASK({table: keplerTable, data: validatedData});\n  }\n\n  info = info || {};\n  const color = info.color || getNewDatasetColor(datasets);\n\n  return CREATE_TABLE_TASK({\n    info,\n    color,\n    opts,\n    data: validatedData\n  });\n}\n\nasync function updateTable({table, data}) {\n  const updated = await table.update(data); // Assuming `table` has an `update` method\n  return updated;\n}\n\ntype CreateTableProps = {\n  info: any;\n  color: RGBColor;\n  opts: {\n    metadata?: Record<string, unknown>;\n  };\n  data: any;\n};\n\nasync function createTable(datasetInfo: CreateTableProps) {\n  const {info, color, opts, data} = datasetInfo;\n\n  // update metadata for remote tiled datasets\n  const refreshedMetadata = await refreshRemoteData(datasetInfo);\n  let metadata = opts.metadata;\n  if (refreshedMetadata) {\n    metadata = {...opts.metadata, ...refreshedMetadata};\n    if (metadata.fields) {\n      data.fields = metadata.fields;\n    }\n  }\n\n  const TableClass = getApplicationConfig().table ?? KeplerTable;\n  const table = new TableClass({\n    info,\n    color,\n    ...opts,\n    metadata\n  });\n  await table.importData({data});\n\n  return table;\n}\nconst UPDATE_TABLE_TASK = Task.fromPromise(updateTable, 'UPDATE_TABLE_TASK');\nconst CREATE_TABLE_TASK = Task.fromPromise(createTable, 'CREATE_TABLE_TASK');\n\n/**\n * Fetch metadata for vector tile layers using tilesetMetadataUrl from metadata\n * @param datasetInfo\n * @returns\n */\nasync function refreshRemoteData(datasetInfo: CreateTableProps): Promise<object | null> {\n  const {type} = datasetInfo.info;\n  switch (type) {\n    case DatasetType.VECTOR_TILE:\n      return await refreshVectorTileMetadata(datasetInfo);\n    case DatasetType.RASTER_TILE:\n      return await refreshRasterTileMetadata(datasetInfo);\n    default:\n      return null;\n  }\n}\n\nasync function refreshVectorTileMetadata(\n  datasetInfo: CreateTableProps\n): Promise<VectorTileMetadata | null> {\n  const {remoteTileFormat, tilesetMetadataUrl, tilesetDataUrl} =\n    (datasetInfo.opts.metadata as VectorTileDatasetMetadata) || {};\n\n  if (\n    !(remoteTileFormat === RemoteTileFormat.PMTILES || remoteTileFormat === RemoteTileFormat.MVT) ||\n    typeof tilesetMetadataUrl !== 'string' ||\n    typeof tilesetDataUrl !== 'string'\n  ) {\n    return null;\n  }\n\n  try {\n    let rawMetadata: PMTilesMetadata | TileJSON | null = null;\n    if (remoteTileFormat === RemoteTileFormat.MVT) {\n      rawMetadata = await getMVTMetadata(tilesetMetadataUrl);\n    } else {\n      const tileSource = PMTilesSource.createDataSource(tilesetMetadataUrl, {});\n      rawMetadata = await tileSource.metadata;\n    }\n\n    if (rawMetadata) {\n      const metadata = parseVectorMetadata(rawMetadata);\n\n      await getFieldsFromTile({\n        remoteTileFormat,\n        tilesetUrl: tilesetDataUrl,\n        metadataUrl: tilesetMetadataUrl,\n        metadata\n      });\n\n      return metadata;\n    }\n  } catch (err) {\n    // ignore for now, and use old metadata\n  }\n  return null;\n}\n\nasync function refreshRasterTileMetadata(datasetInfo: CreateTableProps): Promise<any | null> {\n  const {metadataUrl, pmtilesType} = (datasetInfo.opts.metadata as RasterTileDatasetMetadata) || {};\n\n  if (typeof metadataUrl !== 'string') {\n    return null;\n  }\n\n  try {\n    if (pmtilesType === PMTilesType.RASTER) {\n      const tileSource = PMTilesSource.createDataSource(metadataUrl, {});\n      const rawMetadata: PMTilesMetadata = await tileSource.metadata;\n\n      if (rawMetadata) {\n        return parseVectorMetadata(rawMetadata);\n      }\n    } else {\n      // it's stac raster tiles\n      const response = await fetch(metadataUrl);\n      if (!response.ok) {\n        throw new Error(`Failed Fetch ${metadataUrl}`);\n      }\n      const rawMetadata = await response.json();\n\n      const metadata = parseRasterMetadata(rawMetadata, {allowCollections: true});\n      if (metadata instanceof Error) {\n        throw new Error(`Failed to parse metadata ${metadata.message}`);\n      }\n\n      return metadata;\n    }\n  } catch (err) {\n    // ignore for now, and use old metadata\n  }\n  return null;\n}\n"],"mappings":"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","ignoreList":[]}