kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
227 lines (223 loc) • 28.3 kB
JavaScript
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 _lodash = _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 _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, _lodash["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, _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);
data.fields = (_metadata = metadata) === null || _metadata === void 0 ? void 0 : _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 _ref3, remoteTileFormat, tilesetMetadataUrl, tilesetDataUrl, rawMetadata, tileSource, metadata;
return _regenerator["default"].wrap(function _callee3$(_context3) {
while (1) switch (_context3.prev = _context3.next) {
case 0:
if (!(datasetInfo.info.type !== _constants.DatasetType.VECTOR_TILE)) {
_context3.next = 2;
break;
}
return _context3.abrupt("return", null);
case 2:
_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')) {
_context3.next = 5;
break;
}
return _context3.abrupt("return", null);
case 5:
_context3.prev = 5;
rawMetadata = null;
if (!(remoteTileFormat === _constants.RemoteTileFormat.MVT)) {
_context3.next = 13;
break;
}
_context3.next = 10;
return (0, _tilesetUtils.getMVTMetadata)(tilesetMetadataUrl);
case 10:
rawMetadata = _context3.sent;
_context3.next = 17;
break;
case 13:
tileSource = _pmtiles.PMTilesSource.createDataSource(tilesetMetadataUrl, {});
_context3.next = 16;
return tileSource.metadata;
case 16:
rawMetadata = _context3.sent;
case 17:
if (!rawMetadata) {
_context3.next = 22;
break;
}
metadata = (0, _vectorTileUtils.parseVectorMetadata)(rawMetadata);
_context3.next = 21;
return (0, _vectorTileUtils.getFieldsFromTile)({
remoteTileFormat: remoteTileFormat,
tilesetUrl: tilesetDataUrl,
metadataUrl: tilesetMetadataUrl,
metadata: metadata
});
case 21:
return _context3.abrupt("return", metadata);
case 22:
_context3.next = 26;
break;
case 24:
_context3.prev = 24;
_context3.t0 = _context3["catch"](5);
case 26:
return _context3.abrupt("return", null);
case 27:
case "end":
return _context3.stop();
}
}, _callee3, null, [[5, 24]]);
}));
return _refreshRemoteData.apply(this, arguments);
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_lodash","_interopRequireDefault","require","_keplerTable","_tasks","_constants","_utils","_pmtiles","_tilesetUtils","_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","_metadata","_callee2$","_context2","refreshRemoteData","fields","importData","Task","fromPromise","_x3","_refreshRemoteData","_callee3","_ref3","remoteTileFormat","tilesetMetadataUrl","tilesetDataUrl","rawMetadata","tileSource","_callee3$","_context3","type","DatasetType","VECTOR_TILE","RemoteTileFormat","PMTILES","MVT","getMVTMetadata","PMTilesSource","createDataSource","parseVectorMetadata","getFieldsFromTile","tilesetUrl","metadataUrl","t0"],"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 {DatasetType, RemoteTileFormat, VectorTileDatasetMetadata} 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 {parseVectorMetadata, getFieldsFromTile} 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    data.fields = metadata?.fields;\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) {\n  // so far only vector tile layers should refresh metadata\n  if (datasetInfo.info.type !== DatasetType.VECTOR_TILE) {\n    return null;\n  }\n\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\n  return null;\n}\n"],"mappings":"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","ignoreList":[]}
;