UNPKG

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
"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