kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
416 lines (413 loc) • 54.3 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.filesToDataPayload = filesToDataPayload;
exports.isArrowData = isArrowData;
exports.isArrowTable = isArrowTable;
exports.isFeature = isFeature;
exports.isFeatureCollection = isFeatureCollection;
exports.isGeoJson = isGeoJson;
exports.isKeplerGlMap = isKeplerGlMap;
exports.isRowObject = isRowObject;
exports.makeProgressIterator = makeProgressIterator;
exports.processFileData = processFileData;
exports.readBatch = readBatch;
exports.readFileInBatches = readFileInBatches;
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _awaitAsyncGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/awaitAsyncGenerator"));
var _wrapAsyncGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/wrapAsyncGenerator"));
var arrow = _interopRequireWildcard(require("apache-arrow"));
var _core = require("@loaders.gl/core");
var _json = require("@loaders.gl/json");
var _csv = require("@loaders.gl/csv");
var _arrow = require("@loaders.gl/arrow");
var _parquet = require("@loaders.gl/parquet");
var _utils = require("@kepler.gl/utils");
var _commonUtils = require("@kepler.gl/common-utils");
var _constants = require("@kepler.gl/constants");
var _table = require("@kepler.gl/table");
var _dataProcessor = require("./data-processor");
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; }
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; }
function _asyncIterator(r) { var n, t, o, e = 2; for ("undefined" != typeof Symbol && (t = Symbol.asyncIterator, o = Symbol.iterator); e--;) { if (t && null != (n = r[t])) return n.call(r); if (o && null != (n = r[o])) return new AsyncFromSyncIterator(n.call(r)); t = "@@asyncIterator", o = "@@iterator"; } throw new TypeError("Object is not async iterable"); }
function AsyncFromSyncIterator(r) { function AsyncFromSyncIteratorContinuation(r) { if (Object(r) !== r) return Promise.reject(new TypeError(r + " is not an object.")); var n = r.done; return Promise.resolve(r.value).then(function (r) { return { value: r, done: n }; }); } return AsyncFromSyncIterator = function AsyncFromSyncIterator(r) { this.s = r, this.n = r.next; }, AsyncFromSyncIterator.prototype = { s: null, n: null, next: function next() { return AsyncFromSyncIteratorContinuation(this.n.apply(this.s, arguments)); }, "return": function _return(r) { var n = this.s["return"]; return void 0 === n ? Promise.resolve({ value: r, done: !0 }) : AsyncFromSyncIteratorContinuation(n.apply(this.s, arguments)); }, "throw": function _throw(r) { var n = this.s["return"]; return void 0 === n ? Promise.reject(r) : AsyncFromSyncIteratorContinuation(n.apply(this.s, arguments)); } }, new AsyncFromSyncIterator(r); } // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
var BATCH_TYPE = {
METADATA: 'metadata',
PARTIAL_RESULT: 'partial-result',
FINAL_RESULT: 'final-result'
};
var CSV_LOADER_OPTIONS = {
shape: 'object-row-table',
dynamicTyping: false // not working for now
};
var ARROW_LOADER_OPTIONS = {
shape: 'arrow-table',
batchDebounceMs: 10 // time to delay between batches, for incremental loading
};
var PARQUET_LOADER_OPTIONS = {
shape: 'arrow-table'
};
var JSON_LOADER_OPTIONS = {
shape: 'object-row-table',
// instruct loaders.gl on what json paths to stream
jsonpaths: ['$',
// JSON Row array
'$.features',
// GeoJSON
'$.datasets' // KeplerGL JSON
]
};
/**
* check if table is an ArrowTable object
* @param table - object to check
* @returns {boolean} - true if table is an ArrowTable object type guarded
*/
function isArrowTable(table) {
return Boolean(table instanceof arrow.Table);
}
/**
* check if data is an ArrowData object, which is an array of RecordBatch
* @param data - object to check
* @returns {boolean} - true if data is an ArrowData object type guarded
*/
function isArrowData(data) {
return Array.isArray(data) && Boolean(data.length && data[0].data && data[0].schema);
}
function isGeoJson(json) {
// json can be feature collection
// or single feature
return (0, _utils.isPlainObject)(json) && (isFeature(json) || isFeatureCollection(json));
}
function isFeature(json) {
return (0, _utils.isPlainObject)(json) && json.type === 'Feature' && Boolean(json.geometry);
}
function isFeatureCollection(json) {
return (0, _utils.isPlainObject)(json) && json.type === 'FeatureCollection' && Boolean(json.features);
}
function isRowObject(json) {
return Array.isArray(json) && (0, _utils.isPlainObject)(json[0]);
}
function isKeplerGlMap(json) {
return Boolean((0, _utils.isPlainObject)(json) && json.datasets && json.config && json.info && (0, _utils.isPlainObject)(json.info) && json.info.app === 'kepler.gl');
}
function makeProgressIterator(_x, _x2) {
return _makeProgressIterator.apply(this, arguments);
} // eslint-disable-next-line complexity
function _makeProgressIterator() {
_makeProgressIterator = (0, _wrapAsyncGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(asyncIterator, info) {
var rowCount, _iteratorAbruptCompletion, _didIteratorError, _iteratorError, _iterator, _step, batch, rowCountInBatch, percent, progress;
return _regenerator["default"].wrap(function _callee$(_context) {
while (1) switch (_context.prev = _context.next) {
case 0:
rowCount = 0;
_iteratorAbruptCompletion = false;
_didIteratorError = false;
_context.prev = 3;
_iterator = _asyncIterator(asyncIterator);
case 5:
_context.next = 7;
return (0, _awaitAsyncGenerator2["default"])(_iterator.next());
case 7:
if (!(_iteratorAbruptCompletion = !(_step = _context.sent).done)) {
_context.next = 18;
break;
}
batch = _step.value;
// the length could be stored in `batch.length` for arrow batch
rowCountInBatch = batch.data && (batch.data.length || batch.length) || 0;
rowCount += rowCountInBatch;
percent = Number.isFinite(batch.bytesUsed) ? batch.bytesUsed / info.size : null; // Update progress object
progress = _objectSpread({
rowCount: rowCount,
rowCountInBatch: rowCountInBatch
}, Number.isFinite(percent) ? {
percent: percent
} : {});
_context.next = 15;
return _objectSpread(_objectSpread({}, batch), {}, {
progress: progress
});
case 15:
_iteratorAbruptCompletion = false;
_context.next = 5;
break;
case 18:
_context.next = 24;
break;
case 20:
_context.prev = 20;
_context.t0 = _context["catch"](3);
_didIteratorError = true;
_iteratorError = _context.t0;
case 24:
_context.prev = 24;
_context.prev = 25;
if (!(_iteratorAbruptCompletion && _iterator["return"] != null)) {
_context.next = 29;
break;
}
_context.next = 29;
return (0, _awaitAsyncGenerator2["default"])(_iterator["return"]());
case 29:
_context.prev = 29;
if (!_didIteratorError) {
_context.next = 32;
break;
}
throw _iteratorError;
case 32:
return _context.finish(29);
case 33:
return _context.finish(24);
case 34:
case "end":
return _context.stop();
}
}, _callee, null, [[3, 20, 24, 34], [25,, 29, 33]]);
}));
return _makeProgressIterator.apply(this, arguments);
}
function readBatch(_x3, _x4) {
return _readBatch.apply(this, arguments);
}
function _readBatch() {
_readBatch = (0, _wrapAsyncGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2(asyncIterator, fileName) {
var result, batches, _iteratorAbruptCompletion2, _didIteratorError2, _iteratorError2, _iterator2, _step2, batch, streamingPath, batchData, i;
return _regenerator["default"].wrap(function _callee2$(_context2) {
while (1) switch (_context2.prev = _context2.next) {
case 0:
result = null;
batches = [];
_iteratorAbruptCompletion2 = false;
_didIteratorError2 = false;
_context2.prev = 4;
_iterator2 = _asyncIterator(asyncIterator);
case 6:
_context2.next = 8;
return (0, _awaitAsyncGenerator2["default"])(_iterator2.next());
case 8:
if (!(_iteratorAbruptCompletion2 = !(_step2 = _context2.sent).done)) {
_context2.next = 16;
break;
}
batch = _step2.value;
// Last batch will have this special type and will provide all the root
// properties of the parsed document.
// Only json parse will have `FINAL_RESULT`
if (batch.batchType === BATCH_TYPE.FINAL_RESULT) {
if (batch.container) {
result = _objectSpread({}, batch.container);
}
// Set the streamed data correctly is Batch json path is set
// and the path streamed is not the top level object (jsonpath = '$')
if (batch.jsonpath && batch.jsonpath.length > 1) {
streamingPath = new _json._JSONPath(batch.jsonpath);
streamingPath.setFieldAtPath(result, batches);
} else if (batch.jsonpath && batch.jsonpath.length === 1) {
// The streamed object is a ROW JSON-batch (jsonpath = '$')
// row objects
result = batches;
}
} else {
batchData = isArrowTable(batch.data) ? batch.data.batches : batch.data;
for (i = 0; i < (batchData === null || batchData === void 0 ? void 0 : batchData.length); i++) {
batches.push(batchData[i]);
}
}
_context2.next = 13;
return _objectSpread(_objectSpread(_objectSpread({}, batch), batch.schema ? {
headers: Object.keys(batch.schema)
} : {}), {}, {
fileName: fileName,
// if dataset is CSV, data is set to the raw batches
data: result ? result : batches
});
case 13:
_iteratorAbruptCompletion2 = false;
_context2.next = 6;
break;
case 16:
_context2.next = 22;
break;
case 18:
_context2.prev = 18;
_context2.t0 = _context2["catch"](4);
_didIteratorError2 = true;
_iteratorError2 = _context2.t0;
case 22:
_context2.prev = 22;
_context2.prev = 23;
if (!(_iteratorAbruptCompletion2 && _iterator2["return"] != null)) {
_context2.next = 27;
break;
}
_context2.next = 27;
return (0, _awaitAsyncGenerator2["default"])(_iterator2["return"]());
case 27:
_context2.prev = 27;
if (!_didIteratorError2) {
_context2.next = 30;
break;
}
throw _iteratorError2;
case 30:
return _context2.finish(27);
case 31:
return _context2.finish(22);
case 32:
case "end":
return _context2.stop();
}
}, _callee2, null, [[4, 18, 22, 32], [23,, 27, 31]]);
}));
return _readBatch.apply(this, arguments);
}
function readFileInBatches(_x5) {
return _readFileInBatches.apply(this, arguments);
}
function _readFileInBatches() {
_readFileInBatches = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3(_ref) {
var file, _ref$loaders, loaders, _ref$loadOptions, loadOptions, batchIterator, progressIterator;
return _regenerator["default"].wrap(function _callee3$(_context3) {
while (1) switch (_context3.prev = _context3.next) {
case 0:
file = _ref.file, _ref$loaders = _ref.loaders, loaders = _ref$loaders === void 0 ? [] : _ref$loaders, _ref$loadOptions = _ref.loadOptions, loadOptions = _ref$loadOptions === void 0 ? {} : _ref$loadOptions;
loaders = [_json.JSONLoader, _csv.CSVLoader, _arrow.GeoArrowLoader, _parquet.ParquetWasmLoader].concat((0, _toConsumableArray2["default"])(loaders));
loadOptions = _objectSpread({
csv: CSV_LOADER_OPTIONS,
arrow: ARROW_LOADER_OPTIONS,
json: JSON_LOADER_OPTIONS,
parquet: PARQUET_LOADER_OPTIONS,
metadata: true
}, loadOptions);
_context3.next = 5;
return (0, _core.parseInBatches)(file, loaders, loadOptions);
case 5:
batchIterator = _context3.sent;
progressIterator = makeProgressIterator(batchIterator, {
size: file.size
});
return _context3.abrupt("return", readBatch(progressIterator, file.name));
case 8:
case "end":
return _context3.stop();
}
}, _callee3);
}));
return _readFileInBatches.apply(this, arguments);
}
function processFileData(_x6) {
return _processFileData.apply(this, arguments);
}
function _processFileData() {
_processFileData = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4(_ref2) {
var _getApplicationConfig;
var content, fileCache, fileName, data, format, processor, id, table, processorResult, result;
return _regenerator["default"].wrap(function _callee4$(_context4) {
while (1) switch (_context4.prev = _context4.next) {
case 0:
content = _ref2.content, fileCache = _ref2.fileCache;
fileName = content.fileName, data = content.data;
console.log('Processing file', fileName);
// generate unique id with length of 4 using fileName string
id = (0, _utils.generateHashIdFromString)(fileName); // decide on which table class to use based on application config
table = (_getApplicationConfig = (0, _utils.getApplicationConfig)().table) !== null && _getApplicationConfig !== void 0 ? _getApplicationConfig : _table.KeplerTable;
if (typeof table.getFileProcessor === 'function') {
// use custom processors from table class
processorResult = table.getFileProcessor(data);
format = processorResult.format;
processor = processorResult.processor;
} else {
// use default processors
if (isArrowData(data)) {
format = _constants.DATASET_FORMATS.arrow;
processor = _dataProcessor.processArrowBatches;
} else if (isKeplerGlMap(data)) {
format = _constants.DATASET_FORMATS.keplergl;
processor = _dataProcessor.processKeplerglJSON;
} else if (isRowObject(data)) {
// csv file goes here
format = _constants.DATASET_FORMATS.row;
processor = _dataProcessor.processRowObject;
} else if (isGeoJson(data)) {
format = _constants.DATASET_FORMATS.geojson;
processor = _dataProcessor.processGeojson;
}
}
if (!(format && processor)) {
_context4.next = 19;
break;
}
_context4.prev = 7;
_context4.next = 10;
return processor(data);
case 10:
result = _context4.sent;
_context4.next = 16;
break;
case 13:
_context4.prev = 13;
_context4.t0 = _context4["catch"](7);
throw new Error("Can not process uploaded file, ".concat((0, _utils.getError)(_context4.t0)));
case 16:
return _context4.abrupt("return", [].concat((0, _toConsumableArray2["default"])(fileCache), [{
data: result,
info: {
id: id,
label: content.fileName,
format: format
}
}]));
case 19:
throw new Error('Can not process uploaded file, unknown file format');
case 20:
case "end":
return _context4.stop();
}
}, _callee4, null, [[7, 13]]);
}));
return _processFileData.apply(this, arguments);
}
function filesToDataPayload(fileCache) {
// seperate out files which could be a single datasets. or a keplergl map json
var collection = fileCache.reduce(function (accu, file) {
var data = file.data,
info = file.info;
if ((info === null || info === void 0 ? void 0 : info.format) === _constants.DATASET_FORMATS.keplergl) {
// if file contains a single kepler map dataset & config
accu.keplerMaps.push(_objectSpread(_objectSpread({}, data), {}, {
options: {
centerMap: !(data.config && data.config.mapState)
}
}));
} else if (_constants.DATASET_FORMATS[info === null || info === void 0 ? void 0 : info.format]) {
// if file contains only data
var newDataset = {
data: data,
info: _objectSpread({
id: (info === null || info === void 0 ? void 0 : info.id) || (0, _commonUtils.generateHashId)(4)
}, info || {})
};
accu.datasets.push(newDataset);
}
return accu;
}, {
datasets: [],
keplerMaps: []
});
// add kepler map first with config
// add datasets later in one add data call
return collection.keplerMaps.concat({
datasets: collection.datasets
});
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["arrow","_interopRequireWildcard","require","_core","_json","_csv","_arrow","_parquet","_utils","_commonUtils","_constants","_table","_dataProcessor","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","_asyncIterator","Symbol","asyncIterator","iterator","AsyncFromSyncIterator","TypeError","AsyncFromSyncIteratorContinuation","Promise","reject","done","resolve","value","then","s","next","prototype","_return","_throw","BATCH_TYPE","METADATA","PARTIAL_RESULT","FINAL_RESULT","CSV_LOADER_OPTIONS","shape","dynamicTyping","ARROW_LOADER_OPTIONS","batchDebounceMs","PARQUET_LOADER_OPTIONS","JSON_LOADER_OPTIONS","jsonpaths","isArrowTable","table","Boolean","Table","isArrowData","data","Array","isArray","schema","isGeoJson","json","isPlainObject","isFeature","isFeatureCollection","type","geometry","features","isRowObject","isKeplerGlMap","datasets","config","info","app","makeProgressIterator","_x","_x2","_makeProgressIterator","_wrapAsyncGenerator2","_regenerator","mark","_callee","rowCount","_iteratorAbruptCompletion","_didIteratorError","_iteratorError","_iterator","_step","batch","rowCountInBatch","percent","progress","wrap","_callee$","_context","prev","_awaitAsyncGenerator2","sent","Number","isFinite","bytesUsed","size","t0","finish","stop","readBatch","_x3","_x4","_readBatch","_callee2","fileName","result","batches","_iteratorAbruptCompletion2","_didIteratorError2","_iteratorError2","_iterator2","_step2","streamingPath","batchData","_callee2$","_context2","batchType","container","jsonpath","_JSONPath","setFieldAtPath","headers","readFileInBatches","_x5","_readFileInBatches","_asyncToGenerator2","_callee3","_ref","file","_ref$loaders","loaders","_ref$loadOptions","loadOptions","batchIterator","progressIterator","_callee3$","_context3","JSONLoader","CSVLoader","GeoArrowLoader","ParquetWasmLoader","concat","_toConsumableArray2","csv","parquet","metadata","parseInBatches","abrupt","name","processFileData","_x6","_processFileData","_callee4","_ref2","_getApplicationConfig","content","fileCache","format","processor","id","processorResult","_callee4$","_context4","console","log","generateHashIdFromString","getApplicationConfig","KeplerTable","getFileProcessor","DATASET_FORMATS","processArrowBatches","keplergl","processKeplerglJSON","row","processRowObject","geojson","processGeojson","Error","getError","label","filesToDataPayload","collection","reduce","accu","keplerMaps","options","centerMap","mapState","newDataset","generateHashId"],"sources":["../src/file-handler.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport * as arrow from 'apache-arrow';\nimport {parseInBatches} from '@loaders.gl/core';\nimport {JSONLoader, _JSONPath} from '@loaders.gl/json';\nimport {CSVLoader} from '@loaders.gl/csv';\nimport {GeoArrowLoader} from '@loaders.gl/arrow';\nimport {ParquetWasmLoader} from '@loaders.gl/parquet';\nimport {Loader} from '@loaders.gl/loader-utils';\nimport {\n  isPlainObject,\n  generateHashIdFromString,\n  getApplicationConfig,\n  getError\n} from '@kepler.gl/utils';\nimport {generateHashId} from '@kepler.gl/common-utils';\nimport {DATASET_FORMATS} from '@kepler.gl/constants';\nimport {AddDataToMapPayload, Feature, LoadedMap, ProcessorResult} from '@kepler.gl/types';\nimport {KeplerTable} from '@kepler.gl/table';\nimport {FeatureCollection} from '@turf/helpers';\n\nimport {\n  processArrowBatches,\n  processGeojson,\n  processKeplerglJSON,\n  processRowObject\n} from './data-processor';\n\nimport {FileCacheItem, ValidKeplerGlMap} from './types';\n\nconst BATCH_TYPE = {\n  METADATA: 'metadata',\n  PARTIAL_RESULT: 'partial-result',\n  FINAL_RESULT: 'final-result'\n};\n\nconst CSV_LOADER_OPTIONS = {\n  shape: 'object-row-table',\n  dynamicTyping: false // not working for now\n};\n\nconst ARROW_LOADER_OPTIONS = {\n  shape: 'arrow-table',\n  batchDebounceMs: 10 // time to delay between batches, for incremental loading\n};\n\nconst PARQUET_LOADER_OPTIONS = {\n  shape: 'arrow-table'\n};\n\nconst JSON_LOADER_OPTIONS = {\n  shape: 'object-row-table',\n  // instruct loaders.gl on what json paths to stream\n  jsonpaths: [\n    '$', // JSON Row array\n    '$.features', // GeoJSON\n    '$.datasets' // KeplerGL JSON\n  ]\n};\n\nexport type ProcessFileDataContent = {\n  data: unknown;\n  fileName: string;\n  length?: number;\n  progress?: {rowCount?: number; rowCountInBatch?: number; percent?: number};\n  /**  metadata e.g. for arrow data, metadata could be the schema.fields */\n  metadata?: Map<string, string>;\n};\n\n/**\n * check if table is an ArrowTable object\n * @param table - object to check\n * @returns {boolean} - true if table is an ArrowTable object type guarded\n */\nexport function isArrowTable(table: any): table is arrow.Table {\n  return Boolean(table instanceof arrow.Table);\n}\n\n/**\n * check if data is an ArrowData object, which is an array of RecordBatch\n * @param data - object to check\n * @returns {boolean} - true if data is an ArrowData object type guarded\n */\nexport function isArrowData(data: any): boolean {\n  return Array.isArray(data) && Boolean(data.length && data[0].data && data[0].schema);\n}\n\nexport function isGeoJson(json: unknown): json is Feature | FeatureCollection {\n  // json can be feature collection\n  // or single feature\n  return isPlainObject(json) && (isFeature(json) || isFeatureCollection(json));\n}\n\nexport function isFeature(json: unknown): json is Feature {\n  return isPlainObject(json) && json.type === 'Feature' && Boolean(json.geometry);\n}\n\nexport function isFeatureCollection(json: unknown): json is FeatureCollection {\n  return isPlainObject(json) && json.type === 'FeatureCollection' && Boolean(json.features);\n}\n\nexport function isRowObject(json: any): boolean {\n  return Array.isArray(json) && isPlainObject(json[0]);\n}\n\nexport function isKeplerGlMap(json: unknown): json is ValidKeplerGlMap {\n  return Boolean(\n    isPlainObject(json) &&\n      json.datasets &&\n      json.config &&\n      json.info &&\n      isPlainObject(json.info) &&\n      json.info.app === 'kepler.gl'\n  );\n}\n\nexport async function* makeProgressIterator(\n  asyncIterator: AsyncIterable<any>,\n  info: {size: number}\n): AsyncGenerator {\n  let rowCount = 0;\n\n  for await (const batch of asyncIterator) {\n    // the length could be stored in `batch.length` for arrow batch\n    const rowCountInBatch = (batch.data && (batch.data.length || batch.length)) || 0;\n    rowCount += rowCountInBatch;\n    const percent = Number.isFinite(batch.bytesUsed) ? batch.bytesUsed / info.size : null;\n\n    // Update progress object\n    const progress = {\n      rowCount,\n      rowCountInBatch,\n      ...(Number.isFinite(percent) ? {percent} : {})\n    };\n\n    yield {...batch, progress};\n  }\n}\n\n// eslint-disable-next-line complexity\nexport async function* readBatch(\n  asyncIterator: AsyncIterable<any>,\n  fileName: string\n): AsyncGenerator {\n  let result = null;\n  const batches = <any>[];\n  for await (const batch of asyncIterator) {\n    // Last batch will have this special type and will provide all the root\n    // properties of the parsed document.\n    // Only json parse will have `FINAL_RESULT`\n    if (batch.batchType === BATCH_TYPE.FINAL_RESULT) {\n      if (batch.container) {\n        result = {...batch.container};\n      }\n      // Set the streamed data correctly is Batch json path is set\n      // and the path streamed is not the top level object (jsonpath = '$')\n      if (batch.jsonpath && batch.jsonpath.length > 1) {\n        const streamingPath = new _JSONPath(batch.jsonpath);\n        streamingPath.setFieldAtPath(result, batches);\n      } else if (batch.jsonpath && batch.jsonpath.length === 1) {\n        // The streamed object is a ROW JSON-batch (jsonpath = '$')\n        // row objects\n        result = batches;\n      }\n    } else {\n      const batchData = isArrowTable(batch.data) ? batch.data.batches : batch.data;\n      for (let i = 0; i < batchData?.length; i++) {\n        batches.push(batchData[i]);\n      }\n    }\n\n    yield {\n      ...batch,\n      ...(batch.schema ? {headers: Object.keys(batch.schema)} : {}),\n      fileName,\n      // if dataset is CSV, data is set to the raw batches\n      data: result ? result : batches\n    };\n  }\n}\n\nexport async function readFileInBatches({\n  file,\n  loaders = [],\n  loadOptions = {}\n}: {\n  file: File;\n  fileCache: FileCacheItem[];\n  loaders: Loader[];\n  loadOptions: any;\n}): Promise<AsyncGenerator> {\n  loaders = [JSONLoader, CSVLoader, GeoArrowLoader, ParquetWasmLoader, ...loaders];\n  loadOptions = {\n    csv: CSV_LOADER_OPTIONS,\n    arrow: ARROW_LOADER_OPTIONS,\n    json: JSON_LOADER_OPTIONS,\n    parquet: PARQUET_LOADER_OPTIONS,\n    metadata: true,\n    ...loadOptions\n  };\n\n  const batchIterator = await parseInBatches(file, loaders, loadOptions);\n  const progressIterator = makeProgressIterator(batchIterator, {size: file.size});\n\n  return readBatch(progressIterator, file.name);\n}\n\nexport async function processFileData({\n  content,\n  fileCache\n}: {\n  content: ProcessFileDataContent;\n  fileCache: FileCacheItem[];\n}): Promise<FileCacheItem[]> {\n  const {fileName, data} = content;\n  let format: string | undefined;\n  let processor: ((data: any) => ProcessorResult | LoadedMap | null) | undefined;\n  console.log('Processing file', fileName);\n  // generate unique id with length of 4 using fileName string\n  const id = generateHashIdFromString(fileName);\n  // decide on which table class to use based on application config\n  const table = getApplicationConfig().table ?? KeplerTable;\n\n  if (typeof table.getFileProcessor === 'function') {\n    // use custom processors from table class\n    const processorResult = table.getFileProcessor(data);\n    format = processorResult.format;\n    processor = processorResult.processor;\n  } else {\n    // use default processors\n    if (isArrowData(data)) {\n      format = DATASET_FORMATS.arrow;\n      processor = processArrowBatches;\n    } else if (isKeplerGlMap(data)) {\n      format = DATASET_FORMATS.keplergl;\n      processor = processKeplerglJSON;\n    } else if (isRowObject(data)) {\n      // csv file goes here\n      format = DATASET_FORMATS.row;\n      processor = processRowObject;\n    } else if (isGeoJson(data)) {\n      format = DATASET_FORMATS.geojson;\n      processor = processGeojson;\n    }\n  }\n  if (format && processor) {\n    // eslint-disable-next-line no-useless-catch\n    let result;\n    try {\n      result = await processor(data);\n    } catch (error) {\n      throw new Error(`Can not process uploaded file, ${getError(error as Error)}`);\n    }\n\n    return [\n      ...fileCache,\n      {\n        data: result,\n        info: {\n          id,\n          label: content.fileName,\n          format\n        }\n      }\n    ];\n  } else {\n    throw new Error('Can not process uploaded file, unknown file format');\n  }\n}\n\nexport function filesToDataPayload(fileCache: FileCacheItem[]): AddDataToMapPayload[] {\n  // seperate out files which could be a single datasets. or a keplergl map json\n  const collection = fileCache.reduce<{\n    datasets: FileCacheItem[];\n    keplerMaps: AddDataToMapPayload[];\n  }>(\n    (accu, file) => {\n      const {data, info} = file;\n      if (info?.format === DATASET_FORMATS.keplergl) {\n        // if file contains a single kepler map dataset & config\n        accu.keplerMaps.push({\n          ...data,\n          options: {\n            centerMap: !(data.config && data.config.mapState)\n          }\n        });\n      } else if (DATASET_FORMATS[info?.format]) {\n        // if file contains only data\n        const newDataset = {\n          data,\n          info: {\n            id: info?.id || generateHashId(4),\n            ...(info || {})\n          }\n        };\n        accu.datasets.push(newDataset);\n      }\n      return accu;\n    },\n    {datasets: [], keplerMaps: []}\n  );\n\n  // add kepler map first with config\n  // add datasets later in one add data call\n  return collection.keplerMaps.concat({datasets: collection.datasets});\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAGA,IAAAA,KAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,KAAA,GAAAD,OAAA;AACA,IAAAE,KAAA,GAAAF,OAAA;AACA,IAAAG,IAAA,GAAAH,OAAA;AACA,IAAAI,MAAA,GAAAJ,OAAA;AACA,IAAAK,QAAA,GAAAL,OAAA;AAEA,IAAAM,MAAA,GAAAN,OAAA;AAMA,IAAAO,YAAA,GAAAP,OAAA;AACA,IAAAQ,UAAA,GAAAR,OAAA;AAEA,IAAAS,MAAA,GAAAT,OAAA;AAGA,IAAAU,cAAA,GAAAV,OAAA;AAK0B,SAAAW,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAb,wBAAAa,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,gBAAAK,OAAA,CAAAL,CAAA,0BAAAA,CAAA,sBAAAA,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,cAAAR,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AAAA,SAAAW,QAAAnB,CAAA,EAAAE,CAAA,QAAAC,CAAA,GAAAQ,MAAA,CAAAS,IAAA,CAAApB,CAAA,OAAAW,MAAA,CAAAU,qBAAA,QAAAC,CAAA,GAAAX,MAAA,CAAAU,qBAAA,CAAArB,CAAA,GAAAE,CAAA,KAAAoB,CAAA,GAAAA,CAAA,CAAAC,MAAA,WAAArB,CAAA,WAAAS,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAE,CAAA,EAAAsB,UAAA,OAAArB,CAAA,CAAAsB,IAAA,CAAAC,KAAA,CAAAvB,CAAA,EAAAmB,CAAA,YAAAnB,CAAA;AAAA,SAAAwB,cAAA3B,CAAA,aAAAE,CAAA,MAAAA,CAAA,GAAA0B,SAAA,CAAAC,MAAA,EAAA3B,CAAA,UAAAC,CAAA,WAAAyB,SAAA,CAAA1B,CAAA,IAAA0B,SAAA,CAAA1B,CAAA,QAAAA,CAAA,OAAAiB,OAAA,CAAAR,MAAA,CAAAR,CAAA,OAAA2B,OAAA,WAAA5B,CAAA,QAAA6B,gBAAA,aAAA/B,CAAA,EAAAE,CAAA,EAAAC,CAAA,CAAAD,CAAA,SAAAS,MAAA,CAAAqB,yBAAA,GAAArB,MAAA,CAAAsB,gBAAA,CAAAjC,CAAA,EAAAW,MAAA,CAAAqB,yBAAA,CAAA7B,CAAA,KAAAgB,OAAA,CAAAR,MAAA,CAAAR,CAAA,GAAA2B,OAAA,WAAA5B,CAAA,IAAAS,MAAA,CAAAC,cAAA,CAAAZ,CAAA,EAAAE,CAAA,EAAAS,MAAA,CAAAE,wBAAA,CAAAV,CAAA,EAAAD,CAAA,iBAAAF,CAAA;AAAA,SAAAkC,eAAAhC,CAAA,QAAAM,CAAA,EAAAL,CAAA,EAAAmB,CAAA,EAAAtB,CAAA,iCAAAmC,MAAA,KAAAhC,CAAA,GAAAgC,MAAA,CAAAC,aAAA,EAAAd,CAAA,GAAAa,MAAA,CAAAE,QAAA,GAAArC,CAAA,WAAAG,CAAA,aAAAK,CAAA,GAAAN,CAAA,CAAAC,CAAA,WAAAK,CAAA,CAAAQ,IAAA,CAAAd,CAAA,OAAAoB,CAAA,aAAAd,CAAA,GAAAN,CAAA,CAAAoB,CAAA,eAAAgB,qBAAA,CAAA9B,CAAA,CAAAQ,IAAA,CAAAd,CAAA,IAAAC,CAAA,sBAAAmB,CAAA,6BAAAiB,SAAA;AAAA,SAAAD,sBAAApC,CAAA,aAAAsC,kCAAAtC,CAAA,QAAAS,MAAA,CAAAT,CAAA,MAAAA,CAAA,SAAAuC,OAAA,CAAAC,MAAA,KAAAH,SAAA,CAAArC,CAAA,+BAAAM,CAAA,GAAAN,CAAA,CAAAyC,IAAA,SAAAF,OAAA,CAAAG,OAAA,CAAA1C,CAAA,CAAA2C,KAAA,EAAAC,IAAA,WAAA5C,CAAA,aAAA2C,KAAA,EAAA3C,CAAA,EAAAyC,IAAA,EAAAnC,CAAA,iBAAA8B,qBAAA,YAAAA,sBAAApC,CAAA,SAAA6C,CAAA,GAAA7C,CAAA,OAAAM,CAAA,GAAAN,CAAA,CAAA8C,IAAA,KAAAV,qBAAA,CAAAW,SAAA,KAAAF,CAAA,QAAAvC,CAAA,QAAAwC,IAAA,WAAAA,KAAA,WAAAR,iCAAA,MAAAhC,CAAA,CAAAkB,KAAA,MAAAqB,CAAA,EAAAnB,SAAA,0BAAAsB,QAAAhD,CAAA,QAAAM,CAAA,QAAAuC,CAAA,8BAAAvC,CAAA,GAAAiC,OAAA,CAAAG,OAAA,GAAAC,KAAA,EAAA3C,CAAA,EAAAyC,IAAA,UAAAH,iCAAA,CAAAhC,CAAA,CAAAkB,KAAA,MAAAqB,CAAA,EAAAnB,SAAA,yBAAAuB,OAAAjD,CAAA,QAAAM,CAAA,QAAAuC,CAAA,8BAAAvC,CAAA,GAAAiC,OAAA,CAAAC,MAAA,CAAAxC,CAAA,IAAAsC,iCAAA,CAAAhC,CAAA,CAAAkB,KAAA,MAAAqB,CAAA,EAAAnB,SAAA,aAAAU,qBAAA,CAAApC,CAAA,KA3B1B;AACA;AA8BA,IAAMkD,UAAU,GAAG;EACjBC,QAAQ,EAAE,UAAU;EACpBC,cAAc,EAAE,gBAAgB;EAChCC,YAAY,EAAE;AAChB,CAAC;AAED,IAAMC,kBAAkB,GAAG;EACzBC,KAAK,EAAE,kBAAkB;EACzBC,aAAa,EAAE,KAAK,CAAC;AACvB,CAAC;AAED,IAAMC,oBAAoB,GAAG;EAC3BF,KAAK,EAAE,aAAa;EACpBG,eAAe,EAAE,EAAE,CAAC;AACtB,CAAC;AAED,IAAMC,sBAAsB,GAAG;EAC7BJ,KAAK,EAAE;AACT,CAAC;AAED,IAAMK,mBAAmB,GAAG;EAC1BL,KAAK,EAAE,kBAAkB;EACzB;EACAM,SAAS,EAAE,CACT,GAAG;EAAE;EACL,YAAY;EAAE;EACd,YAAY,CAAC;EAAA;AAEjB,CAAC;AAWD;AACA;AACA;AACA;AACA;AACO,SAASC,YAAYA,CAACC,KAAU,EAAwB;EAC7D,OAAOC,OAAO,CAACD,KAAK,YAAY/E,KAAK,CAACiF,KAAK,CAAC;AAC9C;;AAEA;AACA;AACA;AACA;AACA;AACO,SAASC,WAAWA,CAACC,IAAS,EAAW;EAC9C,OAAOC,KAAK,CAACC,OAAO,CAACF,IAAI,CAAC,IAAIH,OAAO,CAACG,IAAI,CAACxC,MAAM,IAAIwC,IAAI,CAAC,CAAC,CAAC,CAACA,IAAI,IAAIA,IAAI,CAAC,CAAC,CAAC,CAACG,MAAM,CAAC;AACtF;AAEO,SAASC,SAASA,CAACC,IAAa,EAAuC;EAC5E;EACA;EACA,OAAO,IAAAC,oBAAa,EAACD,IAAI,CAAC,KAAKE,SAAS,CAACF,IAAI,CAAC,IAAIG,mBAAmB,CAACH,IAAI,CAAC,CAAC;AAC9E;AAEO,SAASE,SAASA,CAACF,IAAa,EAAmB;EACxD,OAAO,IAAAC,oBAAa,EAACD,IAAI,CAAC,IAAIA,IAAI,CAACI,IAAI,KAAK,SAAS,IAAIZ,OAAO,CAACQ,IAAI,CAACK,QAAQ,CAAC;AACjF;AAEO,SAASF,mBAAmBA,CAACH,IAAa,EAA6B;EAC5E,OAAO,IAAAC,oBAAa,EAACD,IAAI,CAAC,IAAIA,IAAI,CAACI,IAAI,KAAK,mBAAmB,IAAIZ,OAAO,CAACQ,IAAI,CAACM,QAAQ,CAAC;AAC3F;AAEO,SAASC,WAAWA,CAACP,IAAS,EAAW;EAC9C,OAAOJ,KAAK,CAACC,OAAO,CAACG,IAAI,CAAC,IAAI,IAAAC,oBAAa,EAACD,IAAI,CAAC,CAAC,CAAC,CAAC;AACtD;AAEO,SAASQ,aAAaA,CAACR,IAAa,EAA4B;EACrE,OAAOR,OAAO,CACZ,IAAAS,oBAAa,EAACD,IAAI,CAAC,IACjBA,IAAI,CAACS,QAAQ,IACbT,IAAI,CAACU,MAAM,IACXV,IAAI,CAACW,IAAI,IACT,IAAAV,oBAAa,EAACD,IAAI,CAACW,IAAI,CAAC,IACxBX,IAAI,CAACW,IAAI,CAACC,GAAG,KAAK,WACtB,CAAC;AACH;AAAC,SAEsBC,oBAAoBA,CAAAC,EAAA,EAAAC,GAAA;EAAA,OAAAC,qBAAA,CAAAhE,KAAA,OAAAE,SAAA;AAAA,EAuB3C;AAAA,SAAA8D,sBAAA;EAAAA,qBAAA,OAAAC,oBAAA,2BAAAC,YAAA,YAAAC,IAAA,CAvBO,SAAAC,QACL1D,aAAiC,EACjCiD,IAAoB;IAAA,IAAAU,QAAA,EAAAC,yBAAA,EAAAC,iBAAA,EAAAC,cAAA,EAAAC,SAAA,EAAAC,KAAA,EAAAC,KAAA,EAAAC,eAAA,EAAAC,OAAA,EAAAC,QAAA;IAAA,OAAAZ,YAAA,YAAAa,IAAA,UAAAC,SAAAC,QAAA;MAAA,kBAAAA,QAAA,CAAAC,IAAA,GAAAD,QAAA,CAAA3D,IAAA;QAAA;UAEhB+C,QAAQ,GAAG,CAAC;UAAAC,yBAAA;UAAAC,iBAAA;UAAAU,QAAA,CAAAC,IAAA;UAAAT,SAAA,GAAAjE,cAAA,CAEUE,aAAa;QAAA;UAAAuE,QAAA,CAAA3D,IAAA;UAAA,WAAA6D,qBAAA,aAAAV,SAAA,CAAAnD,IAAA;QAAA;UAAA,MAAAgD,yBAAA,KAAAI,KAAA,GAAAO,QAAA,CAAAG,IAAA,EAAAnE,IAAA;YAAAgE,QAAA,CAAA3D,IAAA;YAAA;UAAA;UAAtBqD,KAAK,GAAAD,KAAA,CAAAvD,KAAA;UACpB;UACMyD,eAAe,GAAID,KAAK,CAAChC,IAAI,KAAKgC,KAAK,CAAChC,IAAI,CAACxC,MAAM,IAAIwE,KAAK,CAACxE,MAAM,CAAC,IAAK,CAAC;UAChFkE,QAAQ,IAAIO,eAAe;UACrBC,OAAO,GAAGQ,MAAM,CAACC,QAAQ,CAACX,KAAK,CAACY,SAAS,CAAC,GAAGZ,KAAK,CAACY,SAAS,GAAG5B,IAAI,CAAC6B,IAAI,GAAG,IAAI,EAErF;UACMV,QAAQ,GAAA7E,aAAA;YACZoE,QAAQ,EAARA,QAAQ;YACRO,eAAe,EAAfA;UAAe,GACXS,MAAM,CAACC,QAAQ,CAACT,OAAO,CAAC,GAAG;YAACA,OAAO,EAAPA;UAAO,CAAC,GAAG,CAAC,CAAC;UAAAI,QAAA,CAAA3D,IAAA;UAG/C,OAAArB,aAAA,CAAAA,aAAA,KAAU0E,KAAK;YAAEG,QAAQ,EAARA;UAAQ;QAAC;UAAAR,yBAAA;UAAAW,QAAA,CAAA3D,IAAA;UAAA;QAAA;UAAA2D,QAAA,CAAA3D,IAAA;UAAA;QAAA;UAAA2D,QAAA,CAAAC,IAAA;UAAAD,QAAA,CAAAQ,EAAA,GAAAR,QAAA;UAAAV,iBAAA;UAAAC,cAAA,GAAAS,QAAA,CAAAQ,EAAA;QAAA;UAAAR,QAAA,CAAAC,IAAA;UAAAD,QAAA,CAAAC,IAAA;UAAA,MAAAZ,yBAAA,IAAAG,SAAA;YAAAQ,QAAA,CAAA3D,IAAA;YAAA;UAAA;UAAA2D,QAAA,CAAA3D,IAAA;UAAA,WAAA6D,qBAAA,aAAAV,SAAA;QAAA;UAAAQ,QAAA,CAAAC,IAAA;UAAA,KAAAX,iBAAA;YAAAU,QAAA,CAAA3D,IAAA;YAAA;UAAA;UAAA,MAAAkD,cAAA;QAAA;UAAA,OAAAS,QAAA,CAAAS,MAAA;QAAA;UAAA,OAAAT,QAAA,CAAAS,MAAA;QAAA;QAAA;UAAA,OAAAT,QAAA,CAAAU,IAAA;MAAA;IAAA,GAAAvB,OAAA;EAAA,CAE7B;EAAA,OAAAJ,qBAAA,CAAAhE,KAAA,OAAAE,SAAA;AAAA;AAAA,SAGsB0F,SAASA,CAAAC,GAAA,EAAAC,GAAA;EAAA,OAAAC,UAAA,CAAA/F,KAAA,OAAAE,SAAA;AAAA;AAAA,SAAA6F,WAAA;EAAAA,UAAA,OAAA9B,oBAAA,2BAAAC,YAAA,YAAAC,IAAA,CAAzB,SAAA6B,SACLtF,aAAiC,EACjCuF,QAAgB;IAAA,IAAAC,MAAA,EAAAC,OAAA,EAAAC,0BAAA,EAAAC,kBAAA,EAAAC,eAAA,EAAAC,UAAA,EAAAC,MAAA,EAAA7B,KAAA,EAAA8B,aAAA,EAAAC,SAAA,EAAAnH,CAAA;IAAA,OAAA2E,YAAA,YAAAa,IAAA,UAAA4B,UAAAC,SAAA;MAAA,kBAAAA,SAAA,CAAA1B,IAAA,GAAA0B,SAAA,CAAAtF,IAAA;QAAA;UAEZ4E,MAAM,GAAG,IAAI;UACXC,OAAO,GAAQ,EAAE;UAAAC,0BAAA;UAAAC,kBAAA;UAAAO,SAAA,CAAA1B,IAAA;UAAAqB,UAAA,GAAA/F,cAAA,CACGE,aAAa;QAAA;UAAAkG,SAAA,CAAAtF,IAAA;UAAA,WAAA6D,qBAAA,aAAAoB,UAAA,CAAAjF,IAAA;QAAA;UAAA,MAAA8E,0BAAA,KAAAI,MAAA,GAAAI,SAAA,CAAAxB,IAAA,EAAAnE,IAAA;YAAA2F,SAAA,CAAAtF,IAAA;YAAA;UAAA;UAAtBqD,KAAK,GAAA6B,MAAA,CAAArF,KAAA;UACpB;UACA;UACA;UACA,IAAIwD,KAAK,CAACkC,SAAS,KAAKnF,UAAU,CAACG,YAAY,EAAE;YAC/C,IAAI8C,KAAK,CAACmC,SAAS,EAAE;cACnBZ,MAAM,GAAAjG,aAAA,KAAO0E,KAAK,CAACmC,SAAS,CAAC;YAC/B;YACA;YACA;YACA,IAAInC,KAAK,CAACoC,QAAQ,IAAIpC,KAAK,CAACoC,QAAQ,CAAC5G,MAAM,GAAG,CAAC,EAAE;cACzCsG,aAAa,GAAG,IAAIO,eAAS,CAACrC,KAAK,CAACoC,QAAQ,CAAC;cACnDN,aAAa,CAACQ,cAAc,CAACf,MAAM,EAAEC,OAAO,CAAC;YAC/C,CAAC,MAAM,IAAIxB,KAAK,CAACoC,QAAQ,IAAIpC,KAAK,CAACoC,QAAQ,CAAC5G,MAAM,KAAK,CAAC,EAAE;cACxD;cACA;cACA+F,MAAM,GAAGC,OAAO;YAClB;UACF,CAAC,MAAM;YACCO,SAAS,GAAGpE,YAAY,CAACqC,KAAK,CAAChC,IAAI,CAAC,GAAGgC,KAAK,CAAChC,IAAI,CAACwD,OAAO,GAAGxB,KAAK,CAAChC,IAAI;YAC5E,KAASpD,CAAC,GAAG,CAAC,EAAEA,CAAC,IAAGmH,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEvG,MAAM,GAAEZ,CAAC,EAAE,EAAE;cAC1C4G,OAAO,CAACpG,IAAI,CAAC2G,SAAS,CAACnH,CAAC,CAAC,CAAC;YAC5B;UACF;UAACqH,SAAA,CAAAtF,IAAA;UAED,OAAArB,aAAA,CAAAA,aAAA,CAAAA,aAAA,KACK0E,KAAK,GACJA,KAAK,CAAC7B,MAAM,GAAG;YAACoE,OAAO,EAAEjI,MAAM,CAACS,IAAI,CAACiF,KAAK,CAAC7B,MAAM;UAAC,CAAC,GAAG,CAAC,CAAC;YAC5DmD,QAAQ,EAARA,QAAQ;YACR;YACAtD,IAAI,EAAEuD,MAAM,GAAGA,MAAM,GAAGC;UAAO;QAChC;UAAAC,0BAAA;UAAAQ,SAAA,CAAAtF,IAAA;UAAA;QAAA;UAAAsF,SAAA,CAAAtF,IAAA;UAAA;QAAA;UAAAsF,SAAA,CAAA1B,IAAA;UAAA0B,SAAA,CAAAnB,EAAA,GAAAmB,SAAA;UAAAP,kBAAA;UAAAC,eAAA,GAAAM,SAAA,CAAAnB,EAAA;QAAA;UAAAmB,SAAA,CAAA1B,IAAA;UAAA0B,SAAA,CAAA1B,IAAA;UAAA,MAAAkB,0BAAA,IAAAG,UAAA;YAAAK,SAAA,CAAAtF,IAAA;YAAA;UAAA;UAAAsF,SAAA,CAAAtF,IAAA;UAAA,WAAA6D,qBAAA,aAAAoB,UAAA;QAAA;UAAAK,SAAA,CAAA1B,IAAA;UAAA,KAAAmB,kBAAA;YAAAO,SAAA,CAAAtF,IAAA;YAAA;UAAA;UAAA,MAAAgF,eAAA;QAAA;UAAA,OAAAM,SAAA,CAAAlB,MAAA;QAAA;UAAA,OAAAkB,SAAA,CAAAlB,MAAA;QAAA;QAAA;UAAA,OAAAkB,SAAA,CAAAjB,IAAA;MAAA;IAAA,GAAAK,QAAA;EAAA,CAEJ;EAAA,OAAAD,UAAA,CAAA/F,KAAA,OAAAE,SAAA;AAAA;AAAA,SAEqBiH,iBAAiBA,CAAAC,GAAA;EAAA,OAAAC,kBAAA,CAAArH,KAAA,OAAAE,SAAA;AAAA;AAAA,SAAAmH,mBAAA;EAAAA,kBAAA,OAAAC,kBAAA,2BAAApD,YAAA,YAAAC,IAAA,CAAhC,SAAAoD,SAAAC,IAAA;IAAA,IAAAC,IAAA,EAAAC,YAAA,EAAAC,OAAA,EAAAC,gBAAA,EAAAC,WAAA,EAAAC,aAAA,EAAAC,gBAAA;IAAA,OAAA7D,YAAA,YAAAa,IAAA,UAAAiD,UAAAC,SAAA;MAAA,kBAAAA,SAAA,CAAA/C,IAAA,GAAA+C,SAAA,CAAA3G,IAAA;QAAA;UACLmG,IAAI,GAAAD,IAAA,CAAJC,IAAI,EAAAC,YAAA,GAAAF,IAAA,CACJG,OAAO,EAAPA,OAAO,GAAAD,YAAA,cAAG,EAAE,GAAAA,YAAA,EAAAE,gBAAA,GAAAJ,IAAA,CACZK,WAAW,EAAXA,WAAW,GAAAD,gBAAA,cAAG,CAAC,CAAC,GAAAA,gBAAA;UAOhBD,OAAO,IAAIO,gBAAU,EAAEC,cAAS,EAAEC,qBAAc,EAAEC,0BAAiB,EAAAC,MAAA,KAAAC,mBAAA,aAAKZ,OAAO,EAAC;UAChFE,WAAW,GAAA5H,aAAA;YACTuI,GAAG,EAAE1G,kBAAkB;YACvBtE,KAAK,EAAEyE,oBAAoB;YAC3Be,IAAI,EAAEZ,mBAAmB;YACzBqG,OAAO,EAAEtG,sBAAsB;YAC/BuG,QAAQ,EAAE;UAAI,GACXb,WAAW,CACf;UAACI,SAAA,CAAA3G,IAAA;UAAA,OAE0B,IAAAqH,oBAAc,EAAClB,IAAI,EAAEE,OAAO,EAAEE,WAAW,CAAC;QAAA;UAAhEC,aAAa,GAAAG,SAAA,CAAA7C,IAAA;UACb2C,gBAAgB,GAAGlE,oBAAoB,CAACiE,aAAa,EAAE;YAACtC,IAAI,EAAEiC,IAAI,CAACjC;UAAI,CAAC,CAAC;UAAA,OAAAyC,SAAA,CAAAW,MAAA,WAExEhD,SAAS,CAACmC,gBAAgB,EAAEN,IAAI,CAACoB,IAAI,CAAC;QAAA;QAAA;UAAA,OAAAZ,SAAA,CAAAtC,IAAA;MAAA;IAAA,GAAA4B,QAAA;EAAA,CAC9C;EAAA,OAAAF,kBAAA,CAAArH,KAAA,OAAAE,SAAA