UNPKG

kepler.gl

Version:

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

171 lines (169 loc) 28 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports.SchemaPanelDropMessage = exports.SchemaPanel = void 0; var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator")); var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _reactRedux = require("react-redux"); var _styledComponents = _interopRequireDefault(require("styled-components")); var _components = require("@kepler.gl/components"); var _processors = require("@kepler.gl/processors"); var _utils = require("@kepler.gl/utils"); var _tree = require("./tree"); var _duckdbTableUtils = require("../table/duckdb-table-utils"); var _templateObject, _templateObject2, _templateObject3, _templateObject4; // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project 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; } // TODO note that demo state is available in demo-app, but not when add modules to dependencies in a custom map var StyledSchemaPanel = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-size: 12px;\n padding: 12px;\n font-family: ", ";\n height: 100%;\n"])), function (props) { return props.theme.textColor; }, function (props) { return props.theme.fontFamily; }); var StyledLoadingSpinnerWrapper = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: center;\n align-items: center;\n height: 100%;\n"]))); function getColumnSchema(_x, _x2) { return _getColumnSchema.apply(this, arguments); } function _getColumnSchema() { _getColumnSchema = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2(connection, tableName) { var columnResult, columnDescribe, keplerFields; return _regenerator["default"].wrap(function _callee2$(_context2) { while (1) switch (_context2.prev = _context2.next) { case 0: _context2.next = 2; return connection.query("Select * from '".concat(tableName, "' LIMIT 1;")); case 2: columnResult = _context2.sent; _context2.next = 5; return (0, _duckdbTableUtils.getDuckDBColumnTypes)(connection, tableName); case 5: columnDescribe = _context2.sent; keplerFields = (0, _processors.arrowSchemaToFields)(columnResult, (0, _duckdbTableUtils.getDuckDBColumnTypesMap)(columnDescribe)); return _context2.abrupt("return", { key: tableName, object: { type: 'dataset', tableName: tableName }, children: columnResult.schema.fields.map(function (field, fieldIndex) { return { key: field.name, object: { type: 'column', name: field.name, arrowType: field.type, fieldType: keplerFields[fieldIndex].type } }; }) }); case 8: case "end": return _context2.stop(); } }, _callee2); })); return _getColumnSchema.apply(this, arguments); } function getSchemaSuggestion(result) { return result.reduce(function (accu, data) { var columns = data.children.map(function (child) { return { column_name: child.key, table_name: data.key }; }); return accu.concat(columns); }, []); } var StyledSchemaPanelDropMessage = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: center;\n align-items: center;\n height: 100%;\n flex-direction: column;\n text-align: center;\n\n div {\n margin: 5px;\n }\n .header {\n font-size: 15px;\n }\n .bold {\n font-weight: 700;\n }\n"]))); var StyledAddIcon = (0, _styledComponents["default"])(_components.Icons.Add)(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline;\n margin-top: -3px;\n"]))); var SchemaPanelDropMessage = exports.SchemaPanelDropMessage = function SchemaPanelDropMessage() { return /*#__PURE__*/_react["default"].createElement(StyledSchemaPanelDropMessage, null, /*#__PURE__*/_react["default"].createElement("div", { className: "header" }, /*#__PURE__*/_react["default"].createElement(StyledAddIcon, null), " Add files to DuckDB"), /*#__PURE__*/_react["default"].createElement("div", { className: "bold" }, "Supported formats: "), /*#__PURE__*/_react["default"].createElement("div", null, ".csv, .json, .geojson, .parquet, .arrow"), /*#__PURE__*/_react["default"].createElement("div", null, "Files you add will stay local to your browser.")); }; var SchemaPanel = exports.SchemaPanel = function SchemaPanel(_ref) { var setTableSchema = _ref.setTableSchema, droppedFile = _ref.droppedFile, schemaUpdateTrigger = _ref.schemaUpdateTrigger; var _useState = (0, _react.useState)([]), _useState2 = (0, _slicedToArray2["default"])(_useState, 2), columnSchemas = _useState2[0], setColumnSchemas = _useState2[1]; var datasets = (0, _reactRedux.useSelector)(function (state) { var _state$demo; return state === null || state === void 0 || (_state$demo = state.demo) === null || _state$demo === void 0 || (_state$demo = _state$demo.keplerGl) === null || _state$demo === void 0 || (_state$demo = _state$demo.map) === null || _state$demo === void 0 ? void 0 : _state$demo.visState.datasets; }); var getTableSchema = (0, _react.useCallback)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() { var _tableResult$getChild, _ref3; var db, c, tableResult, tableNames, result, tableSchema; return _regenerator["default"].wrap(function _callee$(_context) { while (1) switch (_context.prev = _context.next) { case 0: db = (0, _utils.getApplicationConfig)().database; if (db) { _context.next = 4; break; } console.error('The database is not configured properly.'); return _context.abrupt("return"); case 4: _context.next = 6; return db.connect(); case 6: c = _context.sent; _context.next = 9; return c.query('SHOW TABLES;'); case 9: tableResult = _context.sent; tableNames = (_tableResult$getChild = tableResult.getChildAt(0)) === null || _tableResult$getChild === void 0 ? void 0 : _tableResult$getChild.toJSON(); _context.next = 13; return Promise.all((_ref3 = tableNames || []) === null || _ref3 === void 0 ? void 0 : _ref3.map(function (name) { return getColumnSchema(c, name); })); case 13: result = _context.sent; tableSchema = getSchemaSuggestion(result); setColumnSchemas(result); setTableSchema(tableSchema); _context.next = 19; return c.close(); case 19: case "end": return _context.stop(); } }, _callee); })), [setColumnSchemas, setTableSchema, schemaUpdateTrigger]); (0, _react.useEffect)(function () { getTableSchema(); }, [datasets, droppedFile, getTableSchema]); return /*#__PURE__*/_react["default"].createElement(StyledSchemaPanel, null, columnSchemas !== null && columnSchemas !== void 0 && columnSchemas.length ? columnSchemas.map(function (data) { return /*#__PURE__*/_react["default"].createElement(_tree.Tree, { key: data.key, treeData: data, renderNode: function renderNode(node) { if (node.object.type === 'dataset') { return /*#__PURE__*/_react["default"].createElement(_tree.DatasetNode, { node: node }); } else if (node.object.type === 'column') { return /*#__PURE__*/_react["default"].createElement(_tree.ColumnNode, { node: node }); } return null; } }); }) : droppedFile ? /*#__PURE__*/_react["default"].createElement(StyledLoadingSpinnerWrapper, null, /*#__PURE__*/_react["default"].createElement(_components.LoadingSpinner, null)) : /*#__PURE__*/_react["default"].createElement(SchemaPanelDropMessage, null)); }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_styledComponents","_interopRequireDefault","_components","_processors","_utils","_tree","_duckdbTableUtils","_templateObject","_templateObject2","_templateObject3","_templateObject4","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","StyledSchemaPanel","styled","div","_taggedTemplateLiteral2","props","theme","textColor","fontFamily","StyledLoadingSpinnerWrapper","getColumnSchema","_x","_x2","_getColumnSchema","apply","arguments","_asyncToGenerator2","_regenerator","mark","_callee2","connection","tableName","columnResult","columnDescribe","keplerFields","wrap","_callee2$","_context2","prev","next","query","concat","sent","getDuckDBColumnTypes","arrowSchemaToFields","getDuckDBColumnTypesMap","abrupt","key","object","type","children","schema","fields","map","field","fieldIndex","name","arrowType","fieldType","stop","getSchemaSuggestion","result","reduce","accu","data","columns","child","column_name","table_name","StyledSchemaPanelDropMessage","StyledAddIcon","Icons","Add","SchemaPanelDropMessage","exports","createElement","className","SchemaPanel","_ref","setTableSchema","droppedFile","schemaUpdateTrigger","_useState","useState","_useState2","_slicedToArray2","columnSchemas","setColumnSchemas","datasets","useSelector","state","_state$demo","demo","keplerGl","visState","getTableSchema","useCallback","_callee","_tableResult$getChild","_ref3","db","c","tableResult","tableNames","tableSchema","_callee$","_context","getApplicationConfig","database","console","error","connect","getChildAt","toJSON","Promise","all","close","useEffect","length","Tree","treeData","renderNode","node","DatasetNode","ColumnNode","LoadingSpinner"],"sources":["../../src/components/schema-panel.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useEffect, useState} from 'react';\nimport {useSelector} from 'react-redux';\nimport styled from 'styled-components';\n\nimport {LoadingSpinner, Icons} from '@kepler.gl/components';\nimport {arrowSchemaToFields} from '@kepler.gl/processors';\nimport {VisState} from '@kepler.gl/schemas';\nimport {getApplicationConfig, DatabaseConnection} from '@kepler.gl/utils';\n\nimport {Tree, DatasetNode, ColumnNode, TreeNodeData} from './tree';\nimport {getDuckDBColumnTypes, getDuckDBColumnTypesMap} from '../table/duckdb-table-utils';\n\n// TODO note that demo state is available in demo-app, but not when add modules to dependencies in a custom map\ntype State = {\n  demo?: {\n    keplerGl: {\n      map: {\n        visState: VisState;\n      };\n    };\n  };\n};\n\nconst StyledSchemaPanel = styled.div`\n  color: ${props => props.theme.textColor};\n  font-size: 12px;\n  padding: 12px;\n  font-family: ${props => props.theme.fontFamily};\n  height: 100%;\n`;\n\nconst StyledLoadingSpinnerWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  height: 100%;\n`;\n\nasync function getColumnSchema(connection: DatabaseConnection, tableName: string) {\n  const columnResult = await connection.query(`Select * from '${tableName}' LIMIT 1;`);\n\n  const columnDescribe = await getDuckDBColumnTypes(connection, tableName);\n  const keplerFields = arrowSchemaToFields(columnResult, getDuckDBColumnTypesMap(columnDescribe));\n\n  return {\n    key: tableName,\n    object: {\n      type: 'dataset',\n      tableName: tableName\n    },\n    children: columnResult.schema.fields.map((field, fieldIndex) => {\n      return {\n        key: field.name,\n        object: {\n          type: 'column',\n          name: field.name,\n          arrowType: field.type,\n          fieldType: keplerFields[fieldIndex].type\n        }\n      };\n    })\n  };\n}\n\nexport type SchemaSuggestion = {column_name: string; table_name: string};\n\nfunction getSchemaSuggestion(result: {key: string; children: {key: string}[]}[]) {\n  return result.reduce((accu, data) => {\n    const columns = data.children.map(child => ({\n      column_name: child.key,\n      table_name: data.key\n    }));\n    return accu.concat(columns);\n  }, [] as SchemaSuggestion[]);\n}\n\ntype SchemaPanelProps = {\n  setTableSchema: (tableSchema: SchemaSuggestion[]) => void;\n  droppedFile: File | null;\n  schemaUpdateTrigger: number;\n};\n\nconst StyledSchemaPanelDropMessage = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  height: 100%;\n  flex-direction: column;\n  text-align: center;\n\n  div {\n    margin: 5px;\n  }\n  .header {\n    font-size: 15px;\n  }\n  .bold {\n    font-weight: 700;\n  }\n`;\n\nconst StyledAddIcon = styled(Icons.Add)`\n  display: inline;\n  margin-top: -3px;\n`;\n\nexport const SchemaPanelDropMessage = () => {\n  return (\n    <StyledSchemaPanelDropMessage>\n      <div className=\"header\">\n        <StyledAddIcon /> Add files to DuckDB\n      </div>\n      <div className=\"bold\">Supported formats: </div>\n      <div>.csv, .json, .geojson, .parquet, .arrow</div>\n      <div>Files you add will stay local to your browser.</div>\n    </StyledSchemaPanelDropMessage>\n  );\n};\n\nexport const SchemaPanel = ({\n  setTableSchema,\n  droppedFile,\n  schemaUpdateTrigger\n}: SchemaPanelProps) => {\n  const [columnSchemas, setColumnSchemas] = useState<TreeNodeData<{type: string}>[]>([]);\n  const datasets = useSelector((state: State) => state?.demo?.keplerGl?.map?.visState.datasets);\n\n  const getTableSchema = useCallback(async () => {\n    const db = getApplicationConfig().database;\n    if (!db) {\n      console.error('The database is not configured properly.');\n      return;\n    }\n    const c = await db.connect();\n\n    const tableResult = await c.query('SHOW TABLES;');\n\n    const tableNames: string[] | undefined = tableResult.getChildAt(0)?.toJSON();\n\n    const result = await Promise.all((tableNames || [])?.map(name => getColumnSchema(c, name)));\n    const tableSchema = getSchemaSuggestion(result);\n\n    setColumnSchemas(result);\n    setTableSchema(tableSchema);\n    await c.close();\n\n    // schemaUpdateTrigger indicates possible change in DuckDB\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [setColumnSchemas, setTableSchema, schemaUpdateTrigger]);\n\n  useEffect(() => {\n    getTableSchema();\n  }, [datasets, droppedFile, getTableSchema]);\n\n  return (\n    <StyledSchemaPanel>\n      {columnSchemas?.length ? (\n        columnSchemas.map(data => (\n          <Tree\n            key={data.key}\n            treeData={data}\n            renderNode={node => {\n              if (node.object.type === 'dataset') {\n                return <DatasetNode node={node} />;\n              } else if (node.object.type === 'column') {\n                return <ColumnNode node={node} />;\n              }\n              return null;\n            }}\n          />\n        ))\n      ) : droppedFile ? (\n        <StyledLoadingSpinnerWrapper>\n          <LoadingSpinner />\n        </StyledLoadingSpinnerWrapper>\n      ) : (\n        <SchemaPanelDropMessage />\n      )}\n    </StyledSchemaPanel>\n  );\n};\n"],"mappings":";;;;;;;;;;;;AAGA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,WAAA,GAAAD,OAAA;AACA,IAAAE,iBAAA,GAAAC,sBAAA,CAAAH,OAAA;AAEA,IAAAI,WAAA,GAAAJ,OAAA;AACA,IAAAK,WAAA,GAAAL,OAAA;AAEA,IAAAM,MAAA,GAAAN,OAAA;AAEA,IAAAO,KAAA,GAAAP,OAAA;AACA,IAAAQ,iBAAA,GAAAR,OAAA;AAA0F,IAAAS,eAAA,EAAAC,gBAAA,EAAAC,gBAAA,EAAAC,gBAAA,EAb1F;AACA;AAAA,SAAAC,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,SAAAf,wBAAAe,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;AAcA;;AAWA,IAAMW,iBAAiB,GAAGC,4BAAM,CAACC,GAAG,CAAA1B,eAAA,KAAAA,eAAA,OAAA2B,uBAAA,oHACzB,UAAAC,KAAK;EAAA,OAAIA,KAAK,CAACC,KAAK,CAACC,SAAS;AAAA,GAGxB,UAAAF,KAAK;EAAA,OAAIA,KAAK,CAACC,KAAK,CAACE,UAAU;AAAA,EAE/C;AAED,IAAMC,2BAA2B,GAAGP,4BAAM,CAACC,GAAG,CAAAzB,gBAAA,KAAAA,gBAAA,OAAA0B,uBAAA,6GAK7C;AAAC,SAEaM,eAAeA,CAAAC,EAAA,EAAAC,GAAA;EAAA,OAAAC,gBAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA;AAAA,SAAAF,iBAAA;EAAAA,gBAAA,OAAAG,kBAAA,2BAAAC,YAAA,YAAAC,IAAA,CAA9B,SAAAC,SAA+BC,UAA8B,EAAEC,SAAiB;IAAA,IAAAC,YAAA,EAAAC,cAAA,EAAAC,YAAA;IAAA,OAAAP,YAAA,YAAAQ,IAAA,UAAAC,UAAAC,SAAA;MAAA,kBAAAA,SAAA,CAAAC,IAAA,GAAAD,SAAA,CAAAE,IAAA;QAAA;UAAAF,SAAA,CAAAE,IAAA;UAAA,OACnDT,UAAU,CAACU,KAAK,mBAAAC,MAAA,CAAmBV,SAAS,eAAY,CAAC;QAAA;UAA9EC,YAAY,GAAAK,SAAA,CAAAK,IAAA;UAAAL,SAAA,CAAAE,IAAA;UAAA,OAEW,IAAAI,sCAAoB,EAACb,UAAU,EAAEC,SAAS,CAAC;QAAA;UAAlEE,cAAc,GAAAI,SAAA,CAAAK,IAAA;UACdR,YAAY,GAAG,IAAAU,+BAAmB,EAACZ,YAAY,EAAE,IAAAa,yCAAuB,EAACZ,cAAc,CAAC,CAAC;UAAA,OAAAI,SAAA,CAAAS,MAAA,WAExF;YACLC,GAAG,EAAEhB,SAAS;YACdiB,MAAM,EAAE;cACNC,IAAI,EAAE,SAAS;cACflB,SAAS,EAAEA;YACb,CAAC;YACDmB,QAAQ,EAAElB,YAAY,CAACmB,MAAM,CAACC,MAAM,CAACC,GAAG,CAAC,UAACC,KAAK,EAAEC,UAAU,EAAK;cAC9D,OAAO;gBACLR,GAAG,EAAEO,KAAK,CAACE,IAAI;gBACfR,MAAM,EAAE;kBACNC,IAAI,EAAE,QAAQ;kBACdO,IAAI,EAAEF,KAAK,CAACE,IAAI;kBAChBC,SAAS,EAAEH,KAAK,CAACL,IAAI;kBACrBS,SAAS,EAAExB,YAAY,CAACqB,UAAU,CAAC,CAACN;gBACtC;cACF,CAAC;YACH,CAAC;UACH,CAAC;QAAA;QAAA;UAAA,OAAAZ,SAAA,CAAAsB,IAAA;MAAA;IAAA,GAAA9B,QAAA;EAAA,CACF;EAAA,OAAAN,gBAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA;AAID,SAASmC,mBAAmBA,CAACC,MAAkD,EAAE;EAC/E,OAAOA,MAAM,CAACC,MAAM,CAAC,UAACC,IAAI,EAAEC,IAAI,EAAK;IACnC,IAAMC,OAAO,GAAGD,IAAI,CAACd,QAAQ,CAACG,GAAG,CAAC,UAAAa,KAAK;MAAA,OAAK;QAC1CC,WAAW,EAAED,KAAK,CAACnB,GAAG;QACtBqB,UAAU,EAAEJ,IAAI,CAACjB;MACnB,CAAC;IAAA,CAAC,CAAC;IACH,OAAOgB,IAAI,CAACtB,MAAM,CAACwB,OAAO,CAAC;EAC7B,CAAC,EAAE,EAAwB,CAAC;AAC9B;AAQA,IAAMI,4BAA4B,GAAGzD,4BAAM,CAACC,GAAG,CAAAxB,gBAAA,KAAAA,gBAAA,OAAAyB,uBAAA,gRAiB9C;AAED,IAAMwD,aAAa,GAAG,IAAA1D,4BAAM,EAAC2D,iBAAK,CAACC,GAAG,CAAC,CAAAlF,gBAAA,KAAAA,gBAAA,OAAAwB,uBAAA,+DAGtC;AAEM,IAAM2D,sBAAsB,GAAAC,OAAA,CAAAD,sBAAA,GAAG,SAAzBA,sBAAsBA,CAAA,EAAS;EAC1C,oBACEjG,MAAA,YAAAmG,aAAA,CAACN,4BAA4B,qBAC3B7F,MAAA,YAAAmG,aAAA;IAAKC,SAAS,EAAC;EAAQ,gBACrBpG,MAAA,YAAAmG,aAAA,CAACL,aAAa,MAAE,CAAC,wBACd,CAAC,eACN9F,MAAA,YAAAmG,aAAA;IAAKC,SAAS,EAAC;EAAM,GAAC,qBAAwB,CAAC,eAC/CpG,MAAA,YAAAmG,aAAA,cAAK,yCAA4C,CAAC,eAClDnG,MAAA,YAAAmG,aAAA,cAAK,gDAAmD,CAC5B,CAAC;AAEnC,CAAC;AAEM,IAAME,WAAW,GAAAH,OAAA,CAAAG,WAAA,GAAG,SAAdA,WAAWA,CAAAC,IAAA,EAIA;EAAA,IAHtBC,cAAc,GAAAD,IAAA,CAAdC,cAAc;IACdC,WAAW,GAAAF,IAAA,CAAXE,WAAW;IACXC,mBAAmB,GAAAH,IAAA,CAAnBG,mBAAmB;EAEnB,IAAAC,SAAA,GAA0C,IAAAC,eAAQ,EAAiC,EAAE,CAAC;IAAAC,UAAA,OAAAC,eAAA,aAAAH,SAAA;IAA/EI,aAAa,GAAAF,UAAA;IAAEG,gBAAgB,GAAAH,UAAA;EACtC,IAAMI,QAAQ,GAAG,IAAAC,uBAAW,EAAC,UAACC,KAAY;IAAA,IAAAC,WAAA;IAAA,OAAKD,KAAK,aAALA,KAAK,gBAAAC,WAAA,GAALD,KAAK,CAAEE,IAAI,cAAAD,WAAA,gBAAAA,WAAA,GAAXA,WAAA,CAAaE,QAAQ,cAAAF,WAAA,gBAAAA,WAAA,GAArBA,WAAA,CAAuBtC,GAAG,cAAAsC,WAAA,uBAA1BA,WAAA,CAA4BG,QAAQ,CAACN,QAAQ;EAAA,EAAC;EAE7F,IAAMO,cAAc,GAAG,IAAAC,kBAAW,oBAAAtE,kBAAA,2BAAAC,YAAA,YAAAC,IAAA,CAAC,SAAAqE,QAAA;IAAA,IAAAC,qBAAA,EAAAC,KAAA;IAAA,IAAAC,EAAA,EAAAC,CAAA,EAAAC,WAAA,EAAAC,UAAA,EAAA1C,MAAA,EAAA2C,WAAA;IAAA,OAAA7E,YAAA,YAAAQ,IAAA,UAAAsE,SAAAC,QAAA;MAAA,kBAAAA,QAAA,CAAApE,IAAA,GAAAoE,QAAA,CAAAnE,IAAA;QAAA;UAC3B6D,EAAE,GAAG,IAAAO,2BAAoB,EAAC,CAAC,CAACC,QAAQ;UAAA,IACrCR,EAAE;YAAAM,QAAA,CAAAnE,IAAA;YAAA;UAAA;UACLsE,OAAO,CAACC,KAAK,CAAC,0CAA0C,CAAC;UAAC,OAAAJ,QAAA,CAAA5D,MAAA;QAAA;UAAA4D,QAAA,CAAAnE,IAAA;UAAA,OAG5C6D,EAAE,CAACW,OAAO,CAAC,CAAC;QAAA;UAAtBV,CAAC,GAAAK,QAAA,CAAAhE,IAAA;UAAAgE,QAAA,CAAAnE,IAAA;UAAA,OAEmB8D,CAAC,CAAC7D,KAAK,CAAC,cAAc,CAAC;QAAA;UAA3C8D,WAAW,GAAAI,QAAA,CAAAhE,IAAA;UAEX6D,UAAgC,IAAAL,qBAAA,GAAGI,WAAW,CAACU,UAAU,CAAC,CAAC,CAAC,cAAAd,qBAAA,uBAAzBA,qBAAA,CAA2Be,MAAM,CAAC,CAAC;UAAAP,QAAA,CAAAnE,IAAA;UAAA,OAEvD2E,OAAO,CAACC,GAAG,EAAAhB,KAAA,GAAEI,UAAU,IAAI,EAAE,cAAAJ,KAAA,uBAAjBA,KAAA,CAAoB9C,GAAG,CAAC,UAAAG,IAAI;YAAA,OAAIpC,eAAe,CAACiF,CAAC,EAAE7C,IAAI,CAAC;UAAA,EAAC,CAAC;QAAA;UAArFK,MAAM,GAAA6C,QAAA,CAAAhE,IAAA;UACN8D,WAAW,GAAG5C,mBAAmB,CAACC,MAAM,CAAC;UAE/C0B,gBAAgB,CAAC1B,MAAM,CAAC;UACxBkB,cAAc,CAACyB,WAAW,CAAC;UAACE,QAAA,CAAAnE,IAAA;UAAA,OACtB8D,CAAC,CAACe,KAAK,CAAC,CAAC;QAAA;QAAA;UAAA,OAAAV,QAAA,CAAA/C,IAAA;MAAA;IAAA,GAAAsC,OAAA;EAAA,CAIhB,IAAE,CAACV,gBAAgB,EAAER,cAAc,EAAEE,mBAAmB,CAAC,CAAC;EAE3D,IAAAoC,gBAAS,EAAC,YAAM;IACdtB,cAAc,CAAC,CAAC;EAClB,CAAC,EAAE,CAACP,QAAQ,EAAER,WAAW,EAAEe,cAAc,CAAC,CAAC;EAE3C,oBACEvH,MAAA,YAAAmG,aAAA,CAAChE,iBAAiB,QACf2E,aAAa,aAAbA,aAAa,eAAbA,aAAa,CAAEgC,MAAM,GACpBhC,aAAa,CAACjC,GAAG,CAAC,UAAAW,IAAI;IAAA,oBACpBxF,MAAA,YAAAmG,aAAA,CAAC1F,KAAA,CAAAsI,IAAI;MACHxE,GAAG,EAAEiB,IAAI,CAACjB,GAAI;MACdyE,QAAQ,EAAExD,IAAK;MACfyD,UAAU,EAAE,SAAZA,UAAUA,CAAEC,IAAI,EAAI;QAClB,IAAIA,IAAI,CAAC1E,MAAM,CAACC,IAAI,KAAK,SAAS,EAAE;UAClC,oBAAOzE,MAAA,YAAAmG,aAAA,CAAC1F,KAAA,CAAA0I,WAAW;YAACD,IAAI,EAAEA;UAAK,CAAE,CAAC;QACpC,CAAC,MAAM,IAAIA,IAAI,CAAC1E,MAAM,CAACC,IAAI,KAAK,QAAQ,EAAE;UACxC,oBAAOzE,MAAA,YAAAmG,aAAA,CAAC1F,KAAA,CAAA2I,UAAU;YAACF,IAAI,EAAEA;UAAK,CAAE,CAAC;QACnC;QACA,OAAO,IAAI;MACb;IAAE,CACH,CAAC;EAAA,CACH,CAAC,GACA1C,WAAW,gBACbxG,MAAA,YAAAmG,aAAA,CAACxD,2BAA2B,qBAC1B3C,MAAA,YAAAmG,aAAA,CAAC7F,WAAA,CAAA+I,cAAc,MAAE,CACU,CAAC,gBAE9BrJ,MAAA,YAAAmG,aAAA,CAACF,sBAAsB,MAAE,CAEV,CAAC;AAExB,CAAC","ignoreList":[]}