UNPKG

kepler.gl

Version:

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

302 lines (288 loc) 33.9 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.ACCEPTED_ANALYZER_TYPES = void 0; exports.analyzerTypeToFieldType = analyzerTypeToFieldType; exports.getFieldsFromData = getFieldsFromData; exports.getSampleForTypeAnalyze = getSampleForTypeAnalyze; exports.getSampleForTypeAnalyzeArrow = getSampleForTypeAnalyzeArrow; exports.renameDuplicateFields = renameDuplicateFields; var _typeAnalyzer = require("type-analyzer"); var _constants = require("@kepler.gl/constants"); var _window = require("global/window"); var _d3Array = require("d3-array"); var _data = require("./data"); var _h3Utils = require("./h3-utils"); // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project var H3_ANALYZER_TYPE = 'H3'; var ACCEPTED_ANALYZER_TYPES = exports.ACCEPTED_ANALYZER_TYPES = [_typeAnalyzer.DATA_TYPES.DATE, _typeAnalyzer.DATA_TYPES.TIME, _typeAnalyzer.DATA_TYPES.DATETIME, _typeAnalyzer.DATA_TYPES.NUMBER, _typeAnalyzer.DATA_TYPES.INT, _typeAnalyzer.DATA_TYPES.FLOAT, _typeAnalyzer.DATA_TYPES.BOOLEAN, _typeAnalyzer.DATA_TYPES.STRING, _typeAnalyzer.DATA_TYPES.GEOMETRY, _typeAnalyzer.DATA_TYPES.GEOMETRY_FROM_STRING, _typeAnalyzer.DATA_TYPES.PAIR_GEOMETRY_FROM_STRING, _typeAnalyzer.DATA_TYPES.ZIPCODE, _typeAnalyzer.DATA_TYPES.ARRAY, _typeAnalyzer.DATA_TYPES.OBJECT, H3_ANALYZER_TYPE]; var IGNORE_DATA_TYPES = Object.keys(_typeAnalyzer.DATA_TYPES).filter(function (type) { return !ACCEPTED_ANALYZER_TYPES.includes(type); }); /** * Getting sample data for analyzing field type. */ function getSampleForTypeAnalyze(_ref) { var fields = _ref.fields, rows = _ref.rows, _ref$sampleCount = _ref.sampleCount, sampleCount = _ref$sampleCount === void 0 ? 50 : _ref$sampleCount; var total = Math.min(sampleCount, rows.length); // const fieldOrder = fields.map(f => f.name); var sample = (0, _d3Array.range)(0, total, 1).map(function () { return {}; }); if (rows.length < 1) { return []; } var isRowObject = !Array.isArray(rows[0]); // collect sample data for each field fields.forEach(function (field, fieldIdx) { // row counter var i = 0; // sample counter var j = 0; while (j < total) { if (i >= rows.length) { // if depleted data pool sample[j][field] = null; j++; } else if ((0, _data.notNullorUndefined)(rows[i][isRowObject ? field : fieldIdx])) { var value = rows[i][isRowObject ? field : fieldIdx]; sample[j][field] = typeof value === 'string' ? value.trim() : value; j++; i++; } else { i++; } } }); return sample; } /** * Getting sample data for analyzing field type for Arrow tables. * @param table Arrow table or an array of vectors. * @param fields Field names. * @param sampleCount Number of sample rows to get. * @returns Sample rows. */ function getSampleForTypeAnalyzeArrow(table, fields) { var sampleCount = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 50; var isTable = !Array.isArray(table); var numRows = isTable ? table.numRows : table[0].length; var getVector = isTable ? function (index) { return table.getChildAt(index); } : function (index) { return table[index]; }; var total = Math.min(sampleCount, numRows); var sample = (0, _d3Array.range)(0, total, 1).map(function () { return {}; }); if (numRows < 1) { return []; } // collect sample data for each field fields.forEach(function (field, fieldIdx) { var rowIndex = 0; var sampleIndex = 0; while (sampleIndex < total) { var _getVector; if (rowIndex >= numRows) { // if depleted data pool sample[sampleIndex][field] = null; sampleIndex++; } else if ((0, _data.notNullorUndefined)((_getVector = getVector(fieldIdx)) === null || _getVector === void 0 ? void 0 : _getVector.get(rowIndex))) { var _getVector2; var value = (_getVector2 = getVector(fieldIdx)) === null || _getVector2 === void 0 ? void 0 : _getVector2.get(rowIndex); sample[sampleIndex][field] = typeof value === 'string' ? value.trim() : value; sampleIndex++; rowIndex++; } else { rowIndex++; } } }); return sample; } /** * Convert type-analyzer output to kepler.gl field types * * @param aType * @returns corresponding type in `ALL_FIELD_TYPES` */ /* eslint-disable complexity */ function analyzerTypeToFieldType(aType) { var DATE = _typeAnalyzer.DATA_TYPES.DATE, TIME = _typeAnalyzer.DATA_TYPES.TIME, DATETIME = _typeAnalyzer.DATA_TYPES.DATETIME, NUMBER = _typeAnalyzer.DATA_TYPES.NUMBER, INT = _typeAnalyzer.DATA_TYPES.INT, FLOAT = _typeAnalyzer.DATA_TYPES.FLOAT, BOOLEAN = _typeAnalyzer.DATA_TYPES.BOOLEAN, STRING = _typeAnalyzer.DATA_TYPES.STRING, GEOMETRY = _typeAnalyzer.DATA_TYPES.GEOMETRY, GEOMETRY_FROM_STRING = _typeAnalyzer.DATA_TYPES.GEOMETRY_FROM_STRING, PAIR_GEOMETRY_FROM_STRING = _typeAnalyzer.DATA_TYPES.PAIR_GEOMETRY_FROM_STRING, ZIPCODE = _typeAnalyzer.DATA_TYPES.ZIPCODE, ARRAY = _typeAnalyzer.DATA_TYPES.ARRAY, OBJECT = _typeAnalyzer.DATA_TYPES.OBJECT; // TODO: un recognized types // CURRENCY PERCENT NONE switch (aType) { case DATE: return _constants.ALL_FIELD_TYPES.date; case TIME: case DATETIME: return _constants.ALL_FIELD_TYPES.timestamp; case FLOAT: return _constants.ALL_FIELD_TYPES.real; case INT: return _constants.ALL_FIELD_TYPES.integer; case BOOLEAN: return _constants.ALL_FIELD_TYPES["boolean"]; case GEOMETRY: case GEOMETRY_FROM_STRING: case PAIR_GEOMETRY_FROM_STRING: return _constants.ALL_FIELD_TYPES.geojson; case ARRAY: return _constants.ALL_FIELD_TYPES.array; case OBJECT: return _constants.ALL_FIELD_TYPES.object; case NUMBER: case STRING: case ZIPCODE: return _constants.ALL_FIELD_TYPES.string; case H3_ANALYZER_TYPE: return _constants.ALL_FIELD_TYPES.h3; default: _window.console.warn("Unsupported analyzer type: ".concat(aType)); return _constants.ALL_FIELD_TYPES.string; } } /** * Analyze field types from data in `string` format, e.g. uploaded csv. * Assign `type`, `fieldIdx` and `format` (timestamp only) to each field * * @param data array of row object * @param fieldOrder array of field names as string * @returns formatted fields * @public * @example * * import {getFieldsFromData} from 'kepler.gl/common-utils'; * const data = [{ * time: '2016-09-17 00:09:55', * value: '4', * surge: '1.2', * isTrip: 'true', * zeroOnes: '0' * }, { * time: '2016-09-17 00:30:08', * value: '3', * surge: null, * isTrip: 'false', * zeroOnes: '1' * }, { * time: null, * value: '2', * surge: '1.3', * isTrip: null, * zeroOnes: '1' * }]; * * const fieldOrder = ['time', 'value', 'surge', 'isTrip', 'zeroOnes']; * const fields = getFieldsFromData(data, fieldOrder); * // fields = [ * // {name: 'time', format: 'YYYY-M-D H:m:s', fieldIdx: 1, type: 'timestamp'}, * // {name: 'value', format: '', fieldIdx: 4, type: 'integer'}, * // {name: 'surge', format: '', fieldIdx: 5, type: 'real'}, * // {name: 'isTrip', format: '', fieldIdx: 6, type: 'boolean'}, * // {name: 'zeroOnes', format: '', fieldIdx: 7, type: 'integer'}]; * */ function getFieldsFromData(data, fieldOrder) { // add a check for epoch timestamp var metadata = _typeAnalyzer.Analyzer.computeColMeta(data, [{ regex: /.*geojson|all_points/g, dataType: 'GEOMETRY' }, { regex: /.*census/g, dataType: 'STRING' }], { ignoredDataTypes: IGNORE_DATA_TYPES }); var _renameDuplicateField = renameDuplicateFields(fieldOrder), fieldByIndex = _renameDuplicateField.fieldByIndex; var result = fieldOrder.map(function (field, index) { var name = fieldByIndex[index]; var fieldMeta = metadata.find(function (m) { return m.key === field; }); // fieldMeta could be undefined if the field has no data and Analyzer.computeColMeta // will ignore the field. In this case, we will simply assign the field type to STRING // since dropping the column in the RowData could be expensive var type = (fieldMeta === null || fieldMeta === void 0 ? void 0 : fieldMeta.type) || 'STRING'; var format = (fieldMeta === null || fieldMeta === void 0 ? void 0 : fieldMeta.format) || ''; // quick check if first valid string in column is H3 if (type === _typeAnalyzer.DATA_TYPES.STRING) { for (var i = 0, n = data.length; i < n; ++i) { if ((0, _data.notNullorUndefined)(data[i][name])) { type = (0, _h3Utils.h3IsValid)(data[i][name] || '') ? H3_ANALYZER_TYPE : type; break; } } } // quick check if string is hex wkb if (type === _typeAnalyzer.DATA_TYPES.STRING) { type = data.some(function (d) { return (0, _data.isHexWkb)(d[name]); }) ? _typeAnalyzer.DATA_TYPES.GEOMETRY : type; } return { name: name, id: name, displayName: name, format: format, fieldIdx: index, type: analyzerTypeToFieldType(type), analyzerType: type, valueAccessor: function valueAccessor(dc) { return function (d) { return dc.valueAt(d.index, index); }; } }; }); return result; } /** * pass in an array of field names, rename duplicated one * and return a map from old field index to new name * * @param fieldOrder * @returns new field name by index */ function renameDuplicateFields(fieldOrder) { return fieldOrder.reduce(function (accu, field, i) { var allNames = accu.allNames; var fieldName = field; // add a counter to duplicated names if (allNames.includes(field)) { var counter = 0; while (allNames.includes("".concat(field, "-").concat(counter))) { counter++; } fieldName = "".concat(field, "-").concat(counter); } accu.fieldByIndex[i] = fieldName; accu.allNames.push(fieldName); return accu; }, { allNames: [], fieldByIndex: [] }); } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_typeAnalyzer","require","_constants","_window","_d3Array","_data","_h3Utils","H3_ANALYZER_TYPE","ACCEPTED_ANALYZER_TYPES","exports","AnalyzerDATA_TYPES","DATE","TIME","DATETIME","NUMBER","INT","FLOAT","BOOLEAN","STRING","GEOMETRY","GEOMETRY_FROM_STRING","PAIR_GEOMETRY_FROM_STRING","ZIPCODE","ARRAY","OBJECT","IGNORE_DATA_TYPES","Object","keys","filter","type","includes","getSampleForTypeAnalyze","_ref","fields","rows","_ref$sampleCount","sampleCount","total","Math","min","length","sample","range","map","isRowObject","Array","isArray","forEach","field","fieldIdx","i","j","notNullorUndefined","value","trim","getSampleForTypeAnalyzeArrow","table","arguments","undefined","isTable","numRows","getVector","index","getChildAt","rowIndex","sampleIndex","_getVector","get","_getVector2","analyzerTypeToFieldType","aType","ALL_FIELD_TYPES","date","timestamp","real","integer","geojson","array","object","string","h3","globalConsole","warn","concat","getFieldsFromData","data","fieldOrder","metadata","Analyzer","computeColMeta","regex","dataType","ignoredDataTypes","_renameDuplicateField","renameDuplicateFields","fieldByIndex","result","name","fieldMeta","find","m","key","format","n","h3IsValid","some","d","isHexWkb","id","displayName","analyzerType","valueAccessor","dc","valueAt","reduce","accu","allNames","fieldName","counter","push"],"sources":["../src/data-type.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {Analyzer, DATA_TYPES as AnalyzerDATA_TYPES} from 'type-analyzer';\nimport {ArrowTableInterface, ApacheVectorInterface, RowData, Field} from '@kepler.gl/types';\nimport {ALL_FIELD_TYPES} from '@kepler.gl/constants';\nimport {console as globalConsole} from 'global/window';\nimport {range} from 'd3-array';\nimport {isHexWkb, notNullorUndefined} from './data';\nimport {h3IsValid} from './h3-utils';\n\nconst H3_ANALYZER_TYPE = 'H3';\n\nexport const ACCEPTED_ANALYZER_TYPES = [\n  AnalyzerDATA_TYPES.DATE,\n  AnalyzerDATA_TYPES.TIME,\n  AnalyzerDATA_TYPES.DATETIME,\n  AnalyzerDATA_TYPES.NUMBER,\n  AnalyzerDATA_TYPES.INT,\n  AnalyzerDATA_TYPES.FLOAT,\n  AnalyzerDATA_TYPES.BOOLEAN,\n  AnalyzerDATA_TYPES.STRING,\n  AnalyzerDATA_TYPES.GEOMETRY,\n  AnalyzerDATA_TYPES.GEOMETRY_FROM_STRING,\n  AnalyzerDATA_TYPES.PAIR_GEOMETRY_FROM_STRING,\n  AnalyzerDATA_TYPES.ZIPCODE,\n  AnalyzerDATA_TYPES.ARRAY,\n  AnalyzerDATA_TYPES.OBJECT,\n  H3_ANALYZER_TYPE\n];\n\nconst IGNORE_DATA_TYPES = Object.keys(AnalyzerDATA_TYPES).filter(\n  type => !ACCEPTED_ANALYZER_TYPES.includes(type)\n);\n\n/**\n * Getting sample data for analyzing field type.\n */\nexport function getSampleForTypeAnalyze({\n  fields,\n  rows,\n  sampleCount = 50\n}: {\n  fields: string[];\n  rows: unknown[][] | RowData;\n  sampleCount?: number;\n}): RowData {\n  const total = Math.min(sampleCount, rows.length);\n  // const fieldOrder = fields.map(f => f.name);\n  const sample = range(0, total, 1).map(() => ({}));\n\n  if (rows.length < 1) {\n    return [];\n  }\n  const isRowObject = !Array.isArray(rows[0]);\n\n  // collect sample data for each field\n  fields.forEach((field, fieldIdx) => {\n    // row counter\n    let i = 0;\n    // sample counter\n    let j = 0;\n\n    while (j < total) {\n      if (i >= rows.length) {\n        // if depleted data pool\n        sample[j][field] = null;\n        j++;\n      } else if (notNullorUndefined(rows[i][isRowObject ? field : fieldIdx])) {\n        const value = rows[i][isRowObject ? field : fieldIdx];\n        sample[j][field] = typeof value === 'string' ? value.trim() : value;\n        j++;\n        i++;\n      } else {\n        i++;\n      }\n    }\n  });\n\n  return sample;\n}\n\n/**\n * Getting sample data for analyzing field type for Arrow tables.\n * @param table Arrow table or an array of vectors.\n * @param fields Field names.\n * @param sampleCount Number of sample rows to get.\n * @returns Sample rows.\n */\nexport function getSampleForTypeAnalyzeArrow(\n  table: ArrowTableInterface | ApacheVectorInterface[],\n  fields: string[],\n  sampleCount = 50\n): any[] {\n  const isTable = !Array.isArray(table);\n\n  const numRows = isTable ? table.numRows : table[0].length;\n  const getVector = isTable ? index => table.getChildAt(index) : index => table[index];\n\n  const total = Math.min(sampleCount, numRows);\n  const sample = range(0, total, 1).map(() => ({}));\n\n  if (numRows < 1) {\n    return [];\n  }\n\n  // collect sample data for each field\n  fields.forEach((field, fieldIdx) => {\n    let rowIndex = 0;\n    let sampleIndex = 0;\n\n    while (sampleIndex < total) {\n      if (rowIndex >= numRows) {\n        // if depleted data pool\n        sample[sampleIndex][field] = null;\n        sampleIndex++;\n      } else if (notNullorUndefined(getVector(fieldIdx)?.get(rowIndex))) {\n        const value = getVector(fieldIdx)?.get(rowIndex);\n        sample[sampleIndex][field] = typeof value === 'string' ? value.trim() : value;\n        sampleIndex++;\n        rowIndex++;\n      } else {\n        rowIndex++;\n      }\n    }\n  });\n\n  return sample;\n}\n\n/**\n * Convert type-analyzer output to kepler.gl field types\n *\n * @param aType\n * @returns corresponding type in `ALL_FIELD_TYPES`\n */\n/* eslint-disable complexity */\nexport function analyzerTypeToFieldType(aType: string): string {\n  const {\n    DATE,\n    TIME,\n    DATETIME,\n    NUMBER,\n    INT,\n    FLOAT,\n    BOOLEAN,\n    STRING,\n    GEOMETRY,\n    GEOMETRY_FROM_STRING,\n    PAIR_GEOMETRY_FROM_STRING,\n    ZIPCODE,\n    ARRAY,\n    OBJECT\n  } = AnalyzerDATA_TYPES;\n\n  // TODO: un recognized types\n  // CURRENCY PERCENT NONE\n  switch (aType) {\n    case DATE:\n      return ALL_FIELD_TYPES.date;\n    case TIME:\n    case DATETIME:\n      return ALL_FIELD_TYPES.timestamp;\n    case FLOAT:\n      return ALL_FIELD_TYPES.real;\n    case INT:\n      return ALL_FIELD_TYPES.integer;\n    case BOOLEAN:\n      return ALL_FIELD_TYPES.boolean;\n    case GEOMETRY:\n    case GEOMETRY_FROM_STRING:\n    case PAIR_GEOMETRY_FROM_STRING:\n      return ALL_FIELD_TYPES.geojson;\n    case ARRAY:\n      return ALL_FIELD_TYPES.array;\n    case OBJECT:\n      return ALL_FIELD_TYPES.object;\n    case NUMBER:\n    case STRING:\n    case ZIPCODE:\n      return ALL_FIELD_TYPES.string;\n    case H3_ANALYZER_TYPE:\n      return ALL_FIELD_TYPES.h3;\n    default:\n      globalConsole.warn(`Unsupported analyzer type: ${aType}`);\n      return ALL_FIELD_TYPES.string;\n  }\n}\n\n/**\n * Analyze field types from data in `string` format, e.g. uploaded csv.\n * Assign `type`, `fieldIdx` and `format` (timestamp only) to each field\n *\n * @param data array of row object\n * @param fieldOrder array of field names as string\n * @returns formatted fields\n * @public\n * @example\n *\n * import {getFieldsFromData} from 'kepler.gl/common-utils';\n * const data = [{\n *   time: '2016-09-17 00:09:55',\n *   value: '4',\n *   surge: '1.2',\n *   isTrip: 'true',\n *   zeroOnes: '0'\n * }, {\n *   time: '2016-09-17 00:30:08',\n *   value: '3',\n *   surge: null,\n *   isTrip: 'false',\n *   zeroOnes: '1'\n * }, {\n *   time: null,\n *   value: '2',\n *   surge: '1.3',\n *   isTrip: null,\n *   zeroOnes: '1'\n * }];\n *\n * const fieldOrder = ['time', 'value', 'surge', 'isTrip', 'zeroOnes'];\n * const fields = getFieldsFromData(data, fieldOrder);\n * // fields = [\n * // {name: 'time', format: 'YYYY-M-D H:m:s', fieldIdx: 1, type: 'timestamp'},\n * // {name: 'value', format: '', fieldIdx: 4, type: 'integer'},\n * // {name: 'surge', format: '', fieldIdx: 5, type: 'real'},\n * // {name: 'isTrip', format: '', fieldIdx: 6, type: 'boolean'},\n * // {name: 'zeroOnes', format: '', fieldIdx: 7, type: 'integer'}];\n *\n */\nexport function getFieldsFromData(data: RowData, fieldOrder: string[]): Field[] {\n  // add a check for epoch timestamp\n  const metadata = Analyzer.computeColMeta(\n    data,\n    [\n      {regex: /.*geojson|all_points/g, dataType: 'GEOMETRY'},\n      {regex: /.*census/g, dataType: 'STRING'}\n    ],\n    {ignoredDataTypes: IGNORE_DATA_TYPES}\n  );\n\n  const {fieldByIndex} = renameDuplicateFields(fieldOrder);\n\n  const result = fieldOrder.map((field, index) => {\n    const name = fieldByIndex[index];\n\n    const fieldMeta = metadata.find(m => m.key === field);\n\n    // fieldMeta could be undefined if the field has no data and Analyzer.computeColMeta\n    // will ignore the field. In this case, we will simply assign the field type to STRING\n    // since dropping the column in the RowData could be expensive\n    let type = fieldMeta?.type || 'STRING';\n    const format = fieldMeta?.format || '';\n\n    // quick check if first valid string in column is H3\n    if (type === AnalyzerDATA_TYPES.STRING) {\n      for (let i = 0, n = data.length; i < n; ++i) {\n        if (notNullorUndefined(data[i][name])) {\n          type = h3IsValid(data[i][name] || '') ? H3_ANALYZER_TYPE : type;\n          break;\n        }\n      }\n    }\n\n    // quick check if string is hex wkb\n    if (type === AnalyzerDATA_TYPES.STRING) {\n      type = data.some(d => isHexWkb(d[name])) ? AnalyzerDATA_TYPES.GEOMETRY : type;\n    }\n\n    return {\n      name,\n      id: name,\n      displayName: name,\n      format,\n      fieldIdx: index,\n      type: analyzerTypeToFieldType(type),\n      analyzerType: type,\n      valueAccessor: dc => d => {\n        return dc.valueAt(d.index, index);\n      }\n    };\n  });\n\n  return result;\n}\n\n/**\n * pass in an array of field names, rename duplicated one\n * and return a map from old field index to new name\n *\n * @param fieldOrder\n * @returns new field name by index\n */\nexport function renameDuplicateFields(fieldOrder: string[]): {\n  allNames: string[];\n  fieldByIndex: string[];\n} {\n  return fieldOrder.reduce<{allNames: string[]; fieldByIndex: string[]}>(\n    (accu, field, i) => {\n      const {allNames} = accu;\n      let fieldName = field;\n\n      // add a counter to duplicated names\n      if (allNames.includes(field)) {\n        let counter = 0;\n        while (allNames.includes(`${field}-${counter}`)) {\n          counter++;\n        }\n        fieldName = `${field}-${counter}`;\n      }\n\n      accu.fieldByIndex[i] = fieldName;\n      accu.allNames.push(fieldName);\n\n      return accu;\n    },\n    {allNames: [], fieldByIndex: []}\n  );\n}\n"],"mappings":";;;;;;;;;;;AAGA,IAAAA,aAAA,GAAAC,OAAA;AAEA,IAAAC,UAAA,GAAAD,OAAA;AACA,IAAAE,OAAA,GAAAF,OAAA;AACA,IAAAG,QAAA,GAAAH,OAAA;AACA,IAAAI,KAAA,GAAAJ,OAAA;AACA,IAAAK,QAAA,GAAAL,OAAA;AATA;AACA;;AAUA,IAAMM,gBAAgB,GAAG,IAAI;AAEtB,IAAMC,uBAAuB,GAAAC,OAAA,CAAAD,uBAAA,GAAG,CACrCE,wBAAkB,CAACC,IAAI,EACvBD,wBAAkB,CAACE,IAAI,EACvBF,wBAAkB,CAACG,QAAQ,EAC3BH,wBAAkB,CAACI,MAAM,EACzBJ,wBAAkB,CAACK,GAAG,EACtBL,wBAAkB,CAACM,KAAK,EACxBN,wBAAkB,CAACO,OAAO,EAC1BP,wBAAkB,CAACQ,MAAM,EACzBR,wBAAkB,CAACS,QAAQ,EAC3BT,wBAAkB,CAACU,oBAAoB,EACvCV,wBAAkB,CAACW,yBAAyB,EAC5CX,wBAAkB,CAACY,OAAO,EAC1BZ,wBAAkB,CAACa,KAAK,EACxBb,wBAAkB,CAACc,MAAM,EACzBjB,gBAAgB,CACjB;AAED,IAAMkB,iBAAiB,GAAGC,MAAM,CAACC,IAAI,CAACjB,wBAAkB,CAAC,CAACkB,MAAM,CAC9D,UAAAC,IAAI;EAAA,OAAI,CAACrB,uBAAuB,CAACsB,QAAQ,CAACD,IAAI,CAAC;AAAA,CACjD,CAAC;;AAED;AACA;AACA;AACO,SAASE,uBAAuBA,CAAAC,IAAA,EAQ3B;EAAA,IAPVC,MAAM,GAAAD,IAAA,CAANC,MAAM;IACNC,IAAI,GAAAF,IAAA,CAAJE,IAAI;IAAAC,gBAAA,GAAAH,IAAA,CACJI,WAAW;IAAXA,WAAW,GAAAD,gBAAA,cAAG,EAAE,GAAAA,gBAAA;EAMhB,IAAME,KAAK,GAAGC,IAAI,CAACC,GAAG,CAACH,WAAW,EAAEF,IAAI,CAACM,MAAM,CAAC;EAChD;EACA,IAAMC,MAAM,GAAG,IAAAC,cAAK,EAAC,CAAC,EAAEL,KAAK,EAAE,CAAC,CAAC,CAACM,GAAG,CAAC;IAAA,OAAO,CAAC,CAAC;EAAA,CAAC,CAAC;EAEjD,IAAIT,IAAI,CAACM,MAAM,GAAG,CAAC,EAAE;IACnB,OAAO,EAAE;EACX;EACA,IAAMI,WAAW,GAAG,CAACC,KAAK,CAACC,OAAO,CAACZ,IAAI,CAAC,CAAC,CAAC,CAAC;;EAE3C;EACAD,MAAM,CAACc,OAAO,CAAC,UAACC,KAAK,EAAEC,QAAQ,EAAK;IAClC;IACA,IAAIC,CAAC,GAAG,CAAC;IACT;IACA,IAAIC,CAAC,GAAG,CAAC;IAET,OAAOA,CAAC,GAAGd,KAAK,EAAE;MAChB,IAAIa,CAAC,IAAIhB,IAAI,CAACM,MAAM,EAAE;QACpB;QACAC,MAAM,CAACU,CAAC,CAAC,CAACH,KAAK,CAAC,GAAG,IAAI;QACvBG,CAAC,EAAE;MACL,CAAC,MAAM,IAAI,IAAAC,wBAAkB,EAAClB,IAAI,CAACgB,CAAC,CAAC,CAACN,WAAW,GAAGI,KAAK,GAAGC,QAAQ,CAAC,CAAC,EAAE;QACtE,IAAMI,KAAK,GAAGnB,IAAI,CAACgB,CAAC,CAAC,CAACN,WAAW,GAAGI,KAAK,GAAGC,QAAQ,CAAC;QACrDR,MAAM,CAACU,CAAC,CAAC,CAACH,KAAK,CAAC,GAAG,OAAOK,KAAK,KAAK,QAAQ,GAAGA,KAAK,CAACC,IAAI,CAAC,CAAC,GAAGD,KAAK;QACnEF,CAAC,EAAE;QACHD,CAAC,EAAE;MACL,CAAC,MAAM;QACLA,CAAC,EAAE;MACL;IACF;EACF,CAAC,CAAC;EAEF,OAAOT,MAAM;AACf;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,SAASc,4BAA4BA,CAC1CC,KAAoD,EACpDvB,MAAgB,EAET;EAAA,IADPG,WAAW,GAAAqB,SAAA,CAAAjB,MAAA,QAAAiB,SAAA,QAAAC,SAAA,GAAAD,SAAA,MAAG,EAAE;EAEhB,IAAME,OAAO,GAAG,CAACd,KAAK,CAACC,OAAO,CAACU,KAAK,CAAC;EAErC,IAAMI,OAAO,GAAGD,OAAO,GAAGH,KAAK,CAACI,OAAO,GAAGJ,KAAK,CAAC,CAAC,CAAC,CAAChB,MAAM;EACzD,IAAMqB,SAAS,GAAGF,OAAO,GAAG,UAAAG,KAAK;IAAA,OAAIN,KAAK,CAACO,UAAU,CAACD,KAAK,CAAC;EAAA,IAAG,UAAAA,KAAK;IAAA,OAAIN,KAAK,CAACM,KAAK,CAAC;EAAA;EAEpF,IAAMzB,KAAK,GAAGC,IAAI,CAACC,GAAG,CAACH,WAAW,EAAEwB,OAAO,CAAC;EAC5C,IAAMnB,MAAM,GAAG,IAAAC,cAAK,EAAC,CAAC,EAAEL,KAAK,EAAE,CAAC,CAAC,CAACM,GAAG,CAAC;IAAA,OAAO,CAAC,CAAC;EAAA,CAAC,CAAC;EAEjD,IAAIiB,OAAO,GAAG,CAAC,EAAE;IACf,OAAO,EAAE;EACX;;EAEA;EACA3B,MAAM,CAACc,OAAO,CAAC,UAACC,KAAK,EAAEC,QAAQ,EAAK;IAClC,IAAIe,QAAQ,GAAG,CAAC;IAChB,IAAIC,WAAW,GAAG,CAAC;IAEnB,OAAOA,WAAW,GAAG5B,KAAK,EAAE;MAAA,IAAA6B,UAAA;MAC1B,IAAIF,QAAQ,IAAIJ,OAAO,EAAE;QACvB;QACAnB,MAAM,CAACwB,WAAW,CAAC,CAACjB,KAAK,CAAC,GAAG,IAAI;QACjCiB,WAAW,EAAE;MACf,CAAC,MAAM,IAAI,IAAAb,wBAAkB,GAAAc,UAAA,GAACL,SAAS,CAACZ,QAAQ,CAAC,cAAAiB,UAAA,uBAAnBA,UAAA,CAAqBC,GAAG,CAACH,QAAQ,CAAC,CAAC,EAAE;QAAA,IAAAI,WAAA;QACjE,IAAMf,KAAK,IAAAe,WAAA,GAAGP,SAAS,CAACZ,QAAQ,CAAC,cAAAmB,WAAA,uBAAnBA,WAAA,CAAqBD,GAAG,CAACH,QAAQ,CAAC;QAChDvB,MAAM,CAACwB,WAAW,CAAC,CAACjB,KAAK,CAAC,GAAG,OAAOK,KAAK,KAAK,QAAQ,GAAGA,KAAK,CAACC,IAAI,CAAC,CAAC,GAAGD,KAAK;QAC7EY,WAAW,EAAE;QACbD,QAAQ,EAAE;MACZ,CAAC,MAAM;QACLA,QAAQ,EAAE;MACZ;IACF;EACF,CAAC,CAAC;EAEF,OAAOvB,MAAM;AACf;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,SAAS4B,uBAAuBA,CAACC,KAAa,EAAU;EAC7D,IACE3D,IAAI,GAcFD,wBAAkB,CAdpBC,IAAI;IACJC,IAAI,GAaFF,wBAAkB,CAbpBE,IAAI;IACJC,QAAQ,GAYNH,wBAAkB,CAZpBG,QAAQ;IACRC,MAAM,GAWJJ,wBAAkB,CAXpBI,MAAM;IACNC,GAAG,GAUDL,wBAAkB,CAVpBK,GAAG;IACHC,KAAK,GASHN,wBAAkB,CATpBM,KAAK;IACLC,OAAO,GAQLP,wBAAkB,CARpBO,OAAO;IACPC,MAAM,GAOJR,wBAAkB,CAPpBQ,MAAM;IACNC,QAAQ,GAMNT,wBAAkB,CANpBS,QAAQ;IACRC,oBAAoB,GAKlBV,wBAAkB,CALpBU,oBAAoB;IACpBC,yBAAyB,GAIvBX,wBAAkB,CAJpBW,yBAAyB;IACzBC,OAAO,GAGLZ,wBAAkB,CAHpBY,OAAO;IACPC,KAAK,GAEHb,wBAAkB,CAFpBa,KAAK;IACLC,MAAM,GACJd,wBAAkB,CADpBc,MAAM;;EAGR;EACA;EACA,QAAQ8C,KAAK;IACX,KAAK3D,IAAI;MACP,OAAO4D,0BAAe,CAACC,IAAI;IAC7B,KAAK5D,IAAI;IACT,KAAKC,QAAQ;MACX,OAAO0D,0BAAe,CAACE,SAAS;IAClC,KAAKzD,KAAK;MACR,OAAOuD,0BAAe,CAACG,IAAI;IAC7B,KAAK3D,GAAG;MACN,OAAOwD,0BAAe,CAACI,OAAO;IAChC,KAAK1D,OAAO;MACV,OAAOsD,0BAAe,WAAQ;IAChC,KAAKpD,QAAQ;IACb,KAAKC,oBAAoB;IACzB,KAAKC,yBAAyB;MAC5B,OAAOkD,0BAAe,CAACK,OAAO;IAChC,KAAKrD,KAAK;MACR,OAAOgD,0BAAe,CAACM,KAAK;IAC9B,KAAKrD,MAAM;MACT,OAAO+C,0BAAe,CAACO,MAAM;IAC/B,KAAKhE,MAAM;IACX,KAAKI,MAAM;IACX,KAAKI,OAAO;MACV,OAAOiD,0BAAe,CAACQ,MAAM;IAC/B,KAAKxE,gBAAgB;MACnB,OAAOgE,0BAAe,CAACS,EAAE;IAC3B;MACEC,eAAa,CAACC,IAAI,+BAAAC,MAAA,CAA+Bb,KAAK,CAAE,CAAC;MACzD,OAAOC,0BAAe,CAACQ,MAAM;EACjC;AACF;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,SAASK,iBAAiBA,CAACC,IAAa,EAAEC,UAAoB,EAAW;EAC9E;EACA,IAAMC,QAAQ,GAAGC,sBAAQ,CAACC,cAAc,CACtCJ,IAAI,EACJ,CACE;IAACK,KAAK,EAAE,uBAAuB;IAAEC,QAAQ,EAAE;EAAU,CAAC,EACtD;IAACD,KAAK,EAAE,WAAW;IAAEC,QAAQ,EAAE;EAAQ,CAAC,CACzC,EACD;IAACC,gBAAgB,EAAEnE;EAAiB,CACtC,CAAC;EAED,IAAAoE,qBAAA,GAAuBC,qBAAqB,CAACR,UAAU,CAAC;IAAjDS,YAAY,GAAAF,qBAAA,CAAZE,YAAY;EAEnB,IAAMC,MAAM,GAAGV,UAAU,CAAC3C,GAAG,CAAC,UAACK,KAAK,EAAEc,KAAK,EAAK;IAC9C,IAAMmC,IAAI,GAAGF,YAAY,CAACjC,KAAK,CAAC;IAEhC,IAAMoC,SAAS,GAAGX,QAAQ,CAACY,IAAI,CAAC,UAAAC,CAAC;MAAA,OAAIA,CAAC,CAACC,GAAG,KAAKrD,KAAK;IAAA,EAAC;;IAErD;IACA;IACA;IACA,IAAInB,IAAI,GAAG,CAAAqE,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAErE,IAAI,KAAI,QAAQ;IACtC,IAAMyE,MAAM,GAAG,CAAAJ,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEI,MAAM,KAAI,EAAE;;IAEtC;IACA,IAAIzE,IAAI,KAAKnB,wBAAkB,CAACQ,MAAM,EAAE;MACtC,KAAK,IAAIgC,CAAC,GAAG,CAAC,EAAEqD,CAAC,GAAGlB,IAAI,CAAC7C,MAAM,EAAEU,CAAC,GAAGqD,CAAC,EAAE,EAAErD,CAAC,EAAE;QAC3C,IAAI,IAAAE,wBAAkB,EAACiC,IAAI,CAACnC,CAAC,CAAC,CAAC+C,IAAI,CAAC,CAAC,EAAE;UACrCpE,IAAI,GAAG,IAAA2E,kBAAS,EAACnB,IAAI,CAACnC,CAAC,CAAC,CAAC+C,IAAI,CAAC,IAAI,EAAE,CAAC,GAAG1F,gBAAgB,GAAGsB,IAAI;UAC/D;QACF;MACF;IACF;;IAEA;IACA,IAAIA,IAAI,KAAKnB,wBAAkB,CAACQ,MAAM,EAAE;MACtCW,IAAI,GAAGwD,IAAI,CAACoB,IAAI,CAAC,UAAAC,CAAC;QAAA,OAAI,IAAAC,cAAQ,EAACD,CAAC,CAACT,IAAI,CAAC,CAAC;MAAA,EAAC,GAAGvF,wBAAkB,CAACS,QAAQ,GAAGU,IAAI;IAC/E;IAEA,OAAO;MACLoE,IAAI,EAAJA,IAAI;MACJW,EAAE,EAAEX,IAAI;MACRY,WAAW,EAAEZ,IAAI;MACjBK,MAAM,EAANA,MAAM;MACNrD,QAAQ,EAAEa,KAAK;MACfjC,IAAI,EAAEwC,uBAAuB,CAACxC,IAAI,CAAC;MACnCiF,YAAY,EAAEjF,IAAI;MAClBkF,aAAa,EAAE,SAAfA,aAAaA,CAAEC,EAAE;QAAA,OAAI,UAAAN,CAAC,EAAI;UACxB,OAAOM,EAAE,CAACC,OAAO,CAACP,CAAC,CAAC5C,KAAK,EAAEA,KAAK,CAAC;QACnC,CAAC;MAAA;IACH,CAAC;EACH,CAAC,CAAC;EAEF,OAAOkC,MAAM;AACf;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,SAASF,qBAAqBA,CAACR,UAAoB,EAGxD;EACA,OAAOA,UAAU,CAAC4B,MAAM,CACtB,UAACC,IAAI,EAAEnE,KAAK,EAAEE,CAAC,EAAK;IAClB,IAAOkE,QAAQ,GAAID,IAAI,CAAhBC,QAAQ;IACf,IAAIC,SAAS,GAAGrE,KAAK;;IAErB;IACA,IAAIoE,QAAQ,CAACtF,QAAQ,CAACkB,KAAK,CAAC,EAAE;MAC5B,IAAIsE,OAAO,GAAG,CAAC;MACf,OAAOF,QAAQ,CAACtF,QAAQ,IAAAqD,MAAA,CAAInC,KAAK,OAAAmC,MAAA,CAAImC,OAAO,CAAE,CAAC,EAAE;QAC/CA,OAAO,EAAE;MACX;MACAD,SAAS,MAAAlC,MAAA,CAAMnC,KAAK,OAAAmC,MAAA,CAAImC,OAAO,CAAE;IACnC;IAEAH,IAAI,CAACpB,YAAY,CAAC7C,CAAC,CAAC,GAAGmE,SAAS;IAChCF,IAAI,CAACC,QAAQ,CAACG,IAAI,CAACF,SAAS,CAAC;IAE7B,OAAOF,IAAI;EACb,CAAC,EACD;IAACC,QAAQ,EAAE,EAAE;IAAErB,YAAY,EAAE;EAAE,CACjC,CAAC;AACH","ignoreList":[]}