UNPKG

kepler.gl

Version:

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

240 lines (239 loc) 39.3 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.AddLayerToolComponent = AddLayerToolComponent; exports.addLayer = void 0; exports.guessDefaultLayer = guessDefaultLayer; var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof")); var _lib = require("/Users/ihordykhta/Desktop/unfolded/kepler.gl/node_modules/react-redux/lib"); var _src = require("/Users/ihordykhta/Desktop/unfolded/kepler.gl/src/layers/src"); var _src2 = require("/Users/ihordykhta/Desktop/unfolded/kepler.gl/src/reducers/src"); var _src3 = require("/Users/ihordykhta/Desktop/unfolded/kepler.gl/src/actions/src"); var _utils = require("@openassistant/utils"); var _zod = require("zod"); var _react = require("/Users/ihordykhta/Desktop/unfolded/kepler.gl/node_modules/react"); 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; } // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project var addLayer = exports.addLayer = (0, _utils.extendedTool)({ description: "Add a kepler.gl map layer from a dataset.\nYou can create basic map layer without color styling, or enhanced map layer with color visualization.\n\nFor basic maps:\n- Simply use datasetName, geometryColumn (if needed), latitudeColumn/longitudeColumn (for point maps), and mapType\n- Omit color-related parameters for simple visualization\n\nFor colored maps:\n- If user requests color visualization, use available columns in the dataset\n- Use dataClassify tool to classify data into bins or unique values when needed\n- If dataClassify tool returns a list of k breaks\n a. For a list of k break values, you must create k+1 entries in the colorMap, with the last value being null.\n b. For example: for breaks = [0, 3, 10], the colorMap could be [{value: 0, color: '##fff7bc', label: '< 0'}, {value: 3, color: '#fec44f', label: '[0-3)'}, {value: null, color: '#d95f0e', label: '>= 3'}]\n- If dataClassify tool returns a list of k unique values\n a. There should be k colors in the colorMap. For example: for uniqueValues = ['a', 'b', 'c'], the colorMap could be [{value: 'a', color: '#1b9e77'}, {value: 'b', color: '#d95f02'}, {value: 'c', color: '#7570b3'}]\n- Generate colorBrewer colors automatically if user doesn't specify colors\n\nFor geojson datasets:\n- Use geometryColumn: '_geojson' and mapType: 'geojson' even for point collections\n", parameters: _zod.z.object({ datasetName: _zod.z.string().describe('The name of the dataset. Note: please do NOT use the datasetId.'), latitudeColumn: _zod.z.string().optional(), longitudeColumn: _zod.z.string().optional(), layerName: _zod.z.string().optional().describe('If possible, generate a name for the layer based on the context.'), layerType: _zod.z["enum"](['point', 'arc', 'line', 'grid', 'hexagon', 'geojson', 'cluster', 'heatmap', 'h3', 'trip', 's2']), colorBy: _zod.z.string().optional(), colorType: _zod.z["enum"](['breaks', 'unique']).optional(), colorMap: _zod.z.array(_zod.z.object({ value: _zod.z.union([_zod.z.string(), _zod.z.number(), _zod.z["null"]()]), color: _zod.z.string() })).optional() }), execute: executeAddLayer, component: AddLayerToolComponent }); function isAddLayerArgs(args) { return (0, _typeof2["default"])(args) === 'object' && args !== null && 'datasetName' in args && 'layerType' in args; } function isAddLayerFunctionContext(context) { return context && typeof context.getDatasets === 'function'; } function executeAddLayer(_x, _x2) { return _executeAddLayer.apply(this, arguments); } function _executeAddLayer() { _executeAddLayer = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(args, options) { var _layer2, _layer3, datasetName, layerName, latitudeColumn, longitudeColumn, layerType, colorBy, colorType, colorMap, datasets, datasetId, dataset, layer, layerId, columns, newLayer, colorField, colorScale, colors, keplerColorMap, colorRange; return _regenerator["default"].wrap(function _callee$(_context) { while (1) switch (_context.prev = _context.next) { case 0: _context.prev = 0; if (isAddLayerArgs(args)) { _context.next = 3; break; } throw new Error('Invalid addLayer arguments'); case 3: if (isAddLayerFunctionContext(options.context)) { _context.next = 5; break; } throw new Error('Invalid addLayer context'); case 5: datasetName = args.datasetName, layerName = args.layerName, latitudeColumn = args.latitudeColumn, longitudeColumn = args.longitudeColumn, layerType = args.layerType, colorBy = args.colorBy, colorType = args.colorType, colorMap = args.colorMap; datasets = options.context.getDatasets(); // check if dataset exists in kepler.gl datasetId = Object.keys(datasets).find(function (dataId) { return datasets[dataId].label === datasetName; }); if (datasetId) { _context.next = 10; break; } throw new Error("Dataset ".concat(datasetName, " not found.")); case 10: // check if field exists in the dataset dataset = datasets[datasetId]; // check if layerType is valid layer = guessDefaultLayer(dataset, layerType); layerId = ((_layer2 = layer) === null || _layer2 === void 0 ? void 0 : _layer2.id) || "layer_".concat((0, _utils.generateId)()); if (!layer) { // for point layer, try to creat a point layer manually if LLM sugggests Lat/Lng fields if (layerType === 'point' && latitudeColumn && longitudeColumn) { layer = { id: layerId, type: 'point', config: { dataId: datasetId, label: layerName || "".concat(datasetName, "-").concat(layerType), columns: { lat: { value: latitudeColumn, fieldIdx: dataset.getColumnFieldIdx(latitudeColumn) }, lng: { value: longitudeColumn, fieldIdx: dataset.getColumnFieldIdx(longitudeColumn) } } }, visConfig: { colorRange: { name: 'Ice And Fire', type: 'diverging', category: 'Uber', colors: ['#D50255', '#FEAD54', '#FEEDB1', '#E8FEB5', '#49E3CE', '#0198BD'] } } }; } } if (layer) { _context.next = 16; break; } throw new Error("Invalid layer type: ".concat(layerType, ".")); case 16: columns = ((_layer3 = layer) === null || _layer3 === void 0 || (_layer3 = _layer3.config) === null || _layer3 === void 0 ? void 0 : _layer3.columns) || {}; // construct new layer config for addLayer() action newLayer = { id: layerId, type: layer.type, config: _objectSpread(_objectSpread({}, layer.config), {}, { dataId: datasetId, label: layerName || "".concat(datasetName, "-").concat(layerType), columns: Object.keys(columns).reduce(function (acc, key) { var column = columns[key]; if (column) { acc[key] = column.value; } return acc; }, {}) }) }; if (!colorBy) { _context.next = 33; break; } colorField = dataset.fields.find(function (f) { return f.name === colorBy; }); if (colorField) { _context.next = 22; break; } throw new Error("Field ".concat(colorBy, " not found.")); case 22: // create kepler.gl's colorMap from uniqueValues and breaks colorScale = colorType === 'breaks' ? 'custom' : 'customOrdinal'; colors = colorMap === null || colorMap === void 0 ? void 0 : colorMap.map(function (color) { return color.color; }); keplerColorMap = colorMap === null || colorMap === void 0 ? void 0 : colorMap.map(function (color) { return [color.value, color.color]; }); colorRange = { name: 'color.customPalette', type: 'custom', category: 'Custom', colors: colors, colorMap: keplerColorMap }; newLayer.config['colorScale'] = colorScale; newLayer.config['colorField'] = colorField; newLayer.config['strokeColorScale'] = colorScale; newLayer.config['strokeColorField'] = colorField; newLayer.config.visConfig['colorRange'] = colorRange; newLayer.config.visConfig['strokeColorRange'] = colorRange; newLayer.config['visualChannels'] = { colorField: { name: colorBy, type: colorField === null || colorField === void 0 ? void 0 : colorField.type }, colorScale: colorScale }; case 33: return _context.abrupt("return", { llmResult: { success: true, layer: JSON.stringify(newLayer), details: "map layer ".concat(layerId, " will be added to the map.") }, additionalData: { layer: newLayer, datasetId: datasetId } }); case 36: _context.prev = 36; _context.t0 = _context["catch"](0); return _context.abrupt("return", { llmResult: { success: false, error: _context.t0 instanceof Error ? _context.t0.message : 'Unknown error', instruction: 'Try to fix the error. If the error persists, pause the execution and ask the user to try with different prompt and context.' } }); case 39: case "end": return _context.stop(); } }, _callee, null, [[0, 36]]); })); return _executeAddLayer.apply(this, arguments); } function guessDefaultLayer(dataset, layerType) { // special case for hexagon layer, which could be implemented as findDefaultLayerProps() in hexagon-layer.tsx if (layerType === 'hexagon') { if (dataset.fieldPairs && dataset.fieldPairs.length > 0) { var props = dataset.fieldPairs.map(function (fieldPair) { return { isVisible: true, label: 'Hexbin', columns: fieldPair.pair }; }); var _layer = new _src.LayerClasses.hexagon(props[0]); return _layer; } } var defaultLayers = (0, _src2.findDefaultLayer)(dataset, _src.LayerClasses); var layer = defaultLayers.find(function (l) { return l.type === layerType; }); return layer || defaultLayers.length > 0 ? defaultLayers[0] : null; } function AddLayerToolComponent(_ref) { var layer = _ref.layer, datasetId = _ref.datasetId; var dispatch = (0, _lib.useDispatch)(); (0, _react.useEffect)(function () { dispatch((0, _src3.addLayer)(layer, datasetId)); // eslint-disable-next-line react-hooks/exhaustive-deps }, []); return null; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_lib","require","_src","_src2","_src3","_utils","_zod","_react","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","addLayer","exports","extendedTool","description","parameters","z","object","datasetName","string","describe","latitudeColumn","optional","longitudeColumn","layerName","layerType","colorBy","colorType","colorMap","array","value","union","number","color","execute","executeAddLayer","component","AddLayerToolComponent","isAddLayerArgs","args","_typeof2","isAddLayerFunctionContext","context","getDatasets","_x","_x2","_executeAddLayer","_asyncToGenerator2","_regenerator","mark","_callee","options","_layer2","_layer3","datasets","datasetId","dataset","layer","layerId","columns","newLayer","colorField","colorScale","colors","keplerColorMap","colorRange","wrap","_callee$","_context","prev","next","Error","find","dataId","label","concat","guessDefaultLayer","id","generateId","type","config","lat","fieldIdx","getColumnFieldIdx","lng","visConfig","name","category","reduce","acc","key","column","fields","f","map","abrupt","llmResult","success","JSON","stringify","details","additionalData","t0","error","message","instruction","stop","fieldPairs","props","fieldPair","isVisible","pair","LayerClasses","hexagon","defaultLayers","findDefaultLayer","l","_ref","dispatch","useDispatch","useEffect","addLayerAction"],"sources":["../../../../src/ai-assistant/src/tools/kepler-tools/layer-creation-tool.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {useDispatch} from 'react-redux';\nimport {LayerClasses} from '@kepler.gl/layers';\nimport KeplerTable, {Datasets} from '@kepler.gl/table';\nimport {findDefaultLayer} from '@kepler.gl/reducers';\nimport {addLayer as addLayerAction} from '@kepler.gl/actions';\nimport {extendedTool, generateId} from '@openassistant/utils';\nimport {z} from 'zod';\nimport {useEffect} from 'react';\n\nexport const addLayer = extendedTool<\n  // parameters\n  z.ZodObject<{\n    datasetName: z.ZodString;\n    latitudeColumn: z.ZodOptional<z.ZodString>;\n    longitudeColumn: z.ZodOptional<z.ZodString>;\n    layerType: z.ZodEnum<\n      [\n        'point',\n        'arc',\n        'line',\n        'grid',\n        'hexagon',\n        'geojson',\n        'cluster',\n        'heatmap',\n        'h3',\n        'trip',\n        's2'\n      ]\n    >;\n    colorBy: z.ZodOptional<z.ZodString>;\n    colorType: z.ZodOptional<z.ZodEnum<['breaks', 'unique']>>;\n    colorMap: z.ZodOptional<\n      z.ZodArray<\n        z.ZodObject<{\n          value: z.ZodUnion<[z.ZodString, z.ZodNumber, z.ZodNull]>;\n          color: z.ZodString;\n        }>\n      >\n    >;\n  }>,\n  // return type\n  ExecuteAddLayerResult['llmResult'],\n  // additional data\n  ExecuteAddLayerResult['additionalData'],\n  // context\n  AddLayerFunctionContext\n>({\n  description: `Add a kepler.gl map layer from a dataset.\nYou can create basic map layer without color styling, or enhanced map layer with color visualization.\n\nFor basic maps:\n- Simply use datasetName, geometryColumn (if needed), latitudeColumn/longitudeColumn (for point maps), and mapType\n- Omit color-related parameters for simple visualization\n\nFor colored maps:\n- If user requests color visualization, use available columns in the dataset\n- Use dataClassify tool to classify data into bins or unique values when needed\n- If dataClassify tool returns a list of k breaks\n  a. For a list of k break values, you must create k+1 entries in the colorMap, with the last value being null.\n  b. For example: for breaks = [0, 3, 10], the colorMap could be [{value: 0, color: '##fff7bc', label: '< 0'}, {value: 3, color: '#fec44f', label: '[0-3)'}, {value: null, color: '#d95f0e', label: '>= 3'}]\n- If dataClassify tool returns a list of k unique values\n  a. There should be k colors in the colorMap. For example: for uniqueValues = ['a', 'b', 'c'], the colorMap could be [{value: 'a', color: '#1b9e77'}, {value: 'b', color: '#d95f02'}, {value: 'c', color: '#7570b3'}]\n- Generate colorBrewer colors automatically if user doesn't specify colors\n\nFor geojson datasets:\n- Use geometryColumn: '_geojson' and mapType: 'geojson' even for point collections\n`,\n  parameters: z.object({\n    datasetName: z\n      .string()\n      .describe('The name of the dataset. Note: please do NOT use the datasetId.'),\n    latitudeColumn: z.string().optional(),\n    longitudeColumn: z.string().optional(),\n    layerName: z\n      .string()\n      .optional()\n      .describe('If possible, generate a name for the layer based on the context.'),\n    layerType: z.enum([\n      'point',\n      'arc',\n      'line',\n      'grid',\n      'hexagon',\n      'geojson',\n      'cluster',\n      'heatmap',\n      'h3',\n      'trip',\n      's2'\n    ]),\n    colorBy: z.string().optional(),\n    colorType: z.enum(['breaks', 'unique']).optional(),\n    colorMap: z\n      .array(\n        z.object({\n          value: z.union([z.string(), z.number(), z.null()]),\n          color: z.string()\n        })\n      )\n      .optional()\n  }),\n  execute: executeAddLayer,\n  component: AddLayerToolComponent\n});\n\nexport type AddLayerTool = typeof addLayer;\n\ntype AddLayerArgs = {\n  datasetName: string;\n  layerName?: string;\n  layerType: string;\n  latitudeColumn?: string;\n  longitudeColumn?: string;\n  colorBy?: string;\n  colorType?: string;\n  colorMap?: Array<{value: string | number | null; color: string; label?: string}>;\n};\n\nfunction isAddLayerArgs(args: any): args is AddLayerArgs {\n  return typeof args === 'object' && args !== null && 'datasetName' in args && 'layerType' in args;\n}\n\ntype AddLayerFunctionContext = {\n  getDatasets: () => Datasets;\n};\n\nfunction isAddLayerFunctionContext(context: any): context is AddLayerFunctionContext {\n  return context && typeof context.getDatasets === 'function';\n}\n\ntype ExecuteAddLayerResult = {\n  llmResult: {\n    success: boolean;\n    layer?: string;\n    details?: string;\n    error?: string;\n    instruction?: string;\n  };\n  additionalData?: {\n    layer: object;\n    datasetId: string;\n  };\n};\n\nasync function executeAddLayer(args, options): Promise<ExecuteAddLayerResult> {\n  try {\n    if (!isAddLayerArgs(args)) {\n      throw new Error('Invalid addLayer arguments');\n    }\n\n    if (!isAddLayerFunctionContext(options.context)) {\n      throw new Error('Invalid addLayer context');\n    }\n\n    const {\n      datasetName,\n      layerName,\n      latitudeColumn,\n      longitudeColumn,\n      layerType,\n      colorBy,\n      colorType,\n      colorMap\n    } = args;\n\n    const datasets = options.context.getDatasets();\n\n    // check if dataset exists in kepler.gl\n    const datasetId = Object.keys(datasets).find(dataId => datasets[dataId].label === datasetName);\n    if (!datasetId) {\n      throw new Error(`Dataset ${datasetName} not found.`);\n    }\n\n    // check if field exists in the dataset\n    const dataset = datasets[datasetId];\n\n    // check if layerType is valid\n    let layer = guessDefaultLayer(dataset, layerType);\n\n    const layerId = layer?.id || `layer_${generateId()}`;\n\n    if (!layer) {\n      // for point layer, try to creat a point layer manually if LLM sugggests Lat/Lng fields\n      if (layerType === 'point' && latitudeColumn && longitudeColumn) {\n        layer = {\n          id: layerId,\n          type: 'point',\n          config: {\n            dataId: datasetId,\n            label: layerName || `${datasetName}-${layerType}`,\n            columns: {\n              lat: {value: latitudeColumn, fieldIdx: dataset.getColumnFieldIdx(latitudeColumn)},\n              lng: {value: longitudeColumn, fieldIdx: dataset.getColumnFieldIdx(longitudeColumn)}\n            }\n          },\n          visConfig: {\n            colorRange: {\n              name: 'Ice And Fire',\n              type: 'diverging',\n              category: 'Uber',\n              colors: ['#D50255', '#FEAD54', '#FEEDB1', '#E8FEB5', '#49E3CE', '#0198BD']\n            }\n          }\n        } as any;\n      }\n    }\n    if (!layer) {\n      throw new Error(`Invalid layer type: ${layerType}.`);\n    }\n\n    const columns = layer?.config?.columns || {};\n\n    // construct new layer config for addLayer() action\n    const newLayer = {\n      id: layerId,\n      type: layer.type,\n      config: {\n        ...layer.config,\n        dataId: datasetId,\n        label: layerName || `${datasetName}-${layerType}`,\n        columns: Object.keys(columns).reduce((acc, key) => {\n          const column = columns[key];\n          if (column) {\n            acc[key] = column.value;\n          }\n          return acc;\n        }, {})\n      }\n    };\n\n    if (colorBy) {\n      const colorField = dataset.fields.find(f => f.name === colorBy);\n      if (!colorField) {\n        throw new Error(`Field ${colorBy} not found.`);\n      }\n      // create kepler.gl's colorMap from uniqueValues and breaks\n      const colorScale = colorType === 'breaks' ? 'custom' : 'customOrdinal';\n      const colors = colorMap?.map(color => color.color);\n      const keplerColorMap = colorMap?.map(color => [color.value, color.color]);\n      const colorRange = {\n        name: 'color.customPalette',\n        type: 'custom',\n        category: 'Custom',\n        colors,\n        colorMap: keplerColorMap\n      };\n\n      newLayer.config['colorScale'] = colorScale;\n      newLayer.config['colorField'] = colorField;\n      newLayer.config['strokeColorScale'] = colorScale;\n      newLayer.config['strokeColorField'] = colorField;\n      newLayer.config.visConfig['colorRange'] = colorRange;\n      newLayer.config.visConfig['strokeColorRange'] = colorRange;\n      newLayer.config['visualChannels'] = {\n        colorField: {\n          name: colorBy,\n          type: colorField?.type\n        },\n        colorScale\n      };\n    }\n\n    return {\n      llmResult: {\n        success: true,\n        layer: JSON.stringify(newLayer),\n        details: `map layer ${layerId} will be added to the map.`\n      },\n      additionalData: {\n        layer: newLayer,\n        datasetId\n      }\n    };\n  } catch (error) {\n    return {\n      llmResult: {\n        success: false,\n        error: error instanceof Error ? error.message : 'Unknown error',\n        instruction:\n          'Try to fix the error. If the error persists, pause the execution and ask the user to try with different prompt and context.'\n      }\n    };\n  }\n}\n\nexport function guessDefaultLayer(dataset: KeplerTable, layerType: string) {\n  // special case for hexagon layer, which could be implemented as findDefaultLayerProps() in hexagon-layer.tsx\n  if (layerType === 'hexagon') {\n    if (dataset.fieldPairs && dataset.fieldPairs.length > 0) {\n      const props = dataset.fieldPairs.map(fieldPair => ({\n        isVisible: true,\n        label: 'Hexbin',\n        columns: fieldPair.pair\n      }));\n      const layer = new LayerClasses.hexagon(props[0]);\n      return layer;\n    }\n  }\n  const defaultLayers = findDefaultLayer(dataset, LayerClasses);\n  const layer = defaultLayers.find(l => l.type === layerType);\n  return layer || defaultLayers.length > 0 ? defaultLayers[0] : null;\n}\n\nexport function AddLayerToolComponent({layer, datasetId}) {\n  const dispatch = useDispatch();\n\n  useEffect(() => {\n    dispatch(addLayerAction(layer, datasetId));\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, []);\n\n  return null;\n}\n"],"mappings":";;;;;;;;;;;;;AAGA,IAAAA,IAAA,GAAAC,OAAA;AACA,IAAAC,IAAA,GAAAD,OAAA;AAEA,IAAAE,KAAA,GAAAF,OAAA;AACA,IAAAG,KAAA,GAAAH,OAAA;AACA,IAAAI,MAAA,GAAAJ,OAAA;AACA,IAAAK,IAAA,GAAAL,OAAA;AACA,IAAAM,MAAA,GAAAN,OAAA;AAAgC,SAAAO,QAAAC,CAAA,EAAAC,CAAA,QAAAC,CAAA,GAAAC,MAAA,CAAAC,IAAA,CAAAJ,CAAA,OAAAG,MAAA,CAAAE,qBAAA,QAAAC,CAAA,GAAAH,MAAA,CAAAE,qBAAA,CAAAL,CAAA,GAAAC,CAAA,KAAAK,CAAA,GAAAA,CAAA,CAAAC,MAAA,WAAAN,CAAA,WAAAE,MAAA,CAAAK,wBAAA,CAAAR,CAAA,EAAAC,CAAA,EAAAQ,UAAA,OAAAP,CAAA,CAAAQ,IAAA,CAAAC,KAAA,CAAAT,CAAA,EAAAI,CAAA,YAAAJ,CAAA;AAAA,SAAAU,cAAAZ,CAAA,aAAAC,CAAA,MAAAA,CAAA,GAAAY,SAAA,CAAAC,MAAA,EAAAb,CAAA,UAAAC,CAAA,WAAAW,SAAA,CAAAZ,CAAA,IAAAY,SAAA,CAAAZ,CAAA,QAAAA,CAAA,OAAAF,OAAA,CAAAI,MAAA,CAAAD,CAAA,OAAAa,OAAA,WAAAd,CAAA,QAAAe,gBAAA,aAAAhB,CAAA,EAAAC,CAAA,EAAAC,CAAA,CAAAD,CAAA,SAAAE,MAAA,CAAAc,yBAAA,GAAAd,MAAA,CAAAe,gBAAA,CAAAlB,CAAA,EAAAG,MAAA,CAAAc,yBAAA,CAAAf,CAAA,KAAAH,OAAA,CAAAI,MAAA,CAAAD,CAAA,GAAAa,OAAA,WAAAd,CAAA,IAAAE,MAAA,CAAAgB,cAAA,CAAAnB,CAAA,EAAAC,CAAA,EAAAE,MAAA,CAAAK,wBAAA,CAAAN,CAAA,EAAAD,CAAA,iBAAAD,CAAA,IAVhC;AACA;AAWO,IAAMoB,QAAQ,GAAAC,OAAA,CAAAD,QAAA,GAAG,IAAAE,mBAAY,EAsClC;EACAC,WAAW,w0CAmBZ;EACCC,UAAU,EAAEC,MAAC,CAACC,MAAM,CAAC;IACnBC,WAAW,EAAEF,MAAC,CACXG,MAAM,CAAC,CAAC,CACRC,QAAQ,CAAC,iEAAiE,CAAC;IAC9EC,cAAc,EAAEL,MAAC,CAACG,MAAM,CAAC,CAAC,CAACG,QAAQ,CAAC,CAAC;IACrCC,eAAe,EAAEP,MAAC,CAACG,MAAM,CAAC,CAAC,CAACG,QAAQ,CAAC,CAAC;IACtCE,SAAS,EAAER,MAAC,CACTG,MAAM,CAAC,CAAC,CACRG,QAAQ,CAAC,CAAC,CACVF,QAAQ,CAAC,kEAAkE,CAAC;IAC/EK,SAAS,EAAET,MAAC,QAAK,CAAC,CAChB,OAAO,EACP,KAAK,EACL,MAAM,EACN,MAAM,EACN,SAAS,EACT,SAAS,EACT,SAAS,EACT,SAAS,EACT,IAAI,EACJ,MAAM,EACN,IAAI,CACL,CAAC;IACFU,OAAO,EAAEV,MAAC,CAACG,MAAM,CAAC,CAAC,CAACG,QAAQ,CAAC,CAAC;IAC9BK,SAAS,EAAEX,MAAC,QAAK,CAAC,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAACM,QAAQ,CAAC,CAAC;IAClDM,QAAQ,EAAEZ,MAAC,CACRa,KAAK,CACJb,MAAC,CAACC,MAAM,CAAC;MACPa,KAAK,EAAEd,MAAC,CAACe,KAAK,CAAC,CAACf,MAAC,CAACG,MAAM,CAAC,CAAC,EAAEH,MAAC,CAACgB,MAAM,CAAC,CAAC,EAAEhB,MAAC,QAAK,CAAC,CAAC,CAAC,CAAC;MAClDiB,KAAK,EAAEjB,MAAC,CAACG,MAAM,CAAC;IAClB,CAAC,CACH,CAAC,CACAG,QAAQ,CAAC;EACd,CAAC,CAAC;EACFY,OAAO,EAAEC,eAAe;EACxBC,SAAS,EAAEC;AACb,CAAC,CAAC;AAeF,SAASC,cAAcA,CAACC,IAAS,EAAwB;EACvD,OAAO,IAAAC,QAAA,aAAOD,IAAI,MAAK,QAAQ,IAAIA,IAAI,KAAK,IAAI,IAAI,aAAa,IAAIA,IAAI,IAAI,WAAW,IAAIA,IAAI;AAClG;AAMA,SAASE,yBAAyBA,CAACC,OAAY,EAAsC;EACnF,OAAOA,OAAO,IAAI,OAAOA,OAAO,CAACC,WAAW,KAAK,UAAU;AAC7D;AAAC,SAgBcR,eAAeA,CAAAS,EAAA,EAAAC,GAAA;EAAA,OAAAC,gBAAA,CAAA5C,KAAA,OAAAE,SAAA;AAAA;AAAA,SAAA0C,iBAAA;EAAAA,gBAAA,OAAAC,kBAAA,2BAAAC,YAAA,YAAAC,IAAA,CAA9B,SAAAC,QAA+BX,IAAI,EAAEY,OAAO;IAAA,IAAAC,OAAA,EAAAC,OAAA,EAAAnC,WAAA,EAAAM,SAAA,EAAAH,cAAA,EAAAE,eAAA,EAAAE,SAAA,EAAAC,OAAA,EAAAC,SAAA,EAAAC,QAAA,EAAA0B,QAAA,EAAAC,SAAA,EAAAC,OAAA,EAAAC,KAAA,EAAAC,OAAA,EAAAC,OAAA,EAAAC,QAAA,EAAAC,UAAA,EAAAC,UAAA,EAAAC,MAAA,EAAAC,cAAA,EAAAC,UAAA;IAAA,OAAAjB,YAAA,YAAAkB,IAAA,UAAAC,SAAAC,QAAA;MAAA,kBAAAA,QAAA,CAAAC,IAAA,GAAAD,QAAA,CAAAE,IAAA;QAAA;UAAAF,QAAA,CAAAC,IAAA;UAAA,IAEnC/B,cAAc,CAACC,IAAI,CAAC;YAAA6B,QAAA,CAAAE,IAAA;YAAA;UAAA;UAAA,MACjB,IAAIC,KAAK,CAAC,4BAA4B,CAAC;QAAA;UAAA,IAG1C9B,yBAAyB,CAACU,OAAO,CAACT,OAAO,CAAC;YAAA0B,QAAA,CAAAE,IAAA;YAAA;UAAA;UAAA,MACvC,IAAIC,KAAK,CAAC,0BAA0B,CAAC;QAAA;UAI3CrD,WAAW,GAQTqB,IAAI,CARNrB,WAAW,EACXM,SAAS,GAOPe,IAAI,CAPNf,SAAS,EACTH,cAAc,GAMZkB,IAAI,CANNlB,cAAc,EACdE,eAAe,GAKbgB,IAAI,CALNhB,eAAe,EACfE,SAAS,GAIPc,IAAI,CAJNd,SAAS,EACTC,OAAO,GAGLa,IAAI,CAHNb,OAAO,EACPC,SAAS,GAEPY,IAAI,CAFNZ,SAAS,EACTC,QAAQ,GACNW,IAAI,CADNX,QAAQ;UAGJ0B,QAAQ,GAAGH,OAAO,CAACT,OAAO,CAACC,WAAW,CAAC,CAAC,EAE9C;UACMY,SAAS,GAAG7D,MAAM,CAACC,IAAI,CAAC2D,QAAQ,CAAC,CAACkB,IAAI,CAAC,UAAAC,MAAM;YAAA,OAAInB,QAAQ,CAACmB,MAAM,CAAC,CAACC,KAAK,KAAKxD,WAAW;UAAA,EAAC;UAAA,IACzFqC,SAAS;YAAAa,QAAA,CAAAE,IAAA;YAAA;UAAA;UAAA,MACN,IAAIC,KAAK,YAAAI,MAAA,CAAYzD,WAAW,gBAAa,CAAC;QAAA;UAGtD;UACMsC,OAAO,GAAGF,QAAQ,CAACC,SAAS,CAAC,EAEnC;UACIE,KAAK,GAAGmB,iBAAiB,CAACpB,OAAO,EAAE/B,SAAS,CAAC;UAE3CiC,OAAO,GAAG,EAAAN,OAAA,GAAAK,KAAK,cAAAL,OAAA,uBAALA,OAAA,CAAOyB,EAAE,cAAAF,MAAA,CAAa,IAAAG,iBAAU,EAAC,CAAC,CAAE;UAEpD,IAAI,CAACrB,KAAK,EAAE;YACV;YACA,IAAIhC,SAAS,KAAK,OAAO,IAAIJ,cAAc,IAAIE,eAAe,EAAE;cAC9DkC,KAAK,GAAG;gBACNoB,EAAE,EAAEnB,OAAO;gBACXqB,IAAI,EAAE,OAAO;gBACbC,MAAM,EAAE;kBACNP,MAAM,EAAElB,SAAS;kBACjBmB,KAAK,EAAElD,SAAS,OAAAmD,MAAA,CAAOzD,WAAW,OAAAyD,MAAA,CAAIlD,SAAS,CAAE;kBACjDkC,OAAO,EAAE;oBACPsB,GAAG,EAAE;sBAACnD,KAAK,EAAET,cAAc;sBAAE6D,QAAQ,EAAE1B,OAAO,CAAC2B,iBAAiB,CAAC9D,cAAc;oBAAC,CAAC;oBACjF+D,GAAG,EAAE;sBAACtD,KAAK,EAAEP,eAAe;sBAAE2D,QAAQ,EAAE1B,OAAO,CAAC2B,iBAAiB,CAAC5D,eAAe;oBAAC;kBACpF;gBACF,CAAC;gBACD8D,SAAS,EAAE;kBACTpB,UAAU,EAAE;oBACVqB,IAAI,EAAE,cAAc;oBACpBP,IAAI,EAAE,WAAW;oBACjBQ,QAAQ,EAAE,MAAM;oBAChBxB,MAAM,EAAE,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS;kBAC3E;gBACF;cACF,CAAQ;YACV;UACF;UAAC,IACIN,KAAK;YAAAW,QAAA,CAAAE,IAAA;YAAA;UAAA;UAAA,MACF,IAAIC,KAAK,wBAAAI,MAAA,CAAwBlD,SAAS,MAAG,CAAC;QAAA;UAGhDkC,OAAO,GAAG,EAAAN,OAAA,GAAAI,KAAK,cAAAJ,OAAA,gBAAAA,OAAA,GAALA,OAAA,CAAO2B,MAAM,cAAA3B,OAAA,uBAAbA,OAAA,CAAeM,OAAO,KAAI,CAAC,CAAC,EAE5C;UACMC,QAAQ,GAAG;YACfiB,EAAE,EAAEnB,OAAO;YACXqB,IAAI,EAAEtB,KAAK,CAACsB,IAAI;YAChBC,MAAM,EAAA7E,aAAA,CAAAA,aAAA,KACDsD,KAAK,CAACuB,MAAM;cACfP,MAAM,EAAElB,SAAS;cACjBmB,KAAK,EAAElD,SAAS,OAAAmD,MAAA,CAAOzD,WAAW,OAAAyD,MAAA,CAAIlD,SAAS,CAAE;cACjDkC,OAAO,EAAEjE,MAAM,CAACC,IAAI,CAACgE,OAAO,CAAC,CAAC6B,MAAM,CAAC,UAACC,GAAG,EAAEC,GAAG,EAAK;gBACjD,IAAMC,MAAM,GAAGhC,OAAO,CAAC+B,GAAG,CAAC;gBAC3B,IAAIC,MAAM,EAAE;kBACVF,GAAG,CAACC,GAAG,CAAC,GAAGC,MAAM,CAAC7D,KAAK;gBACzB;gBACA,OAAO2D,GAAG;cACZ,CAAC,EAAE,CAAC,CAAC;YAAC;UAEV,CAAC;UAAA,KAEG/D,OAAO;YAAA0C,QAAA,CAAAE,IAAA;YAAA;UAAA;UACHT,UAAU,GAAGL,OAAO,CAACoC,MAAM,CAACpB,IAAI,CAAC,UAAAqB,CAAC;YAAA,OAAIA,CAAC,CAACP,IAAI,KAAK5D,OAAO;UAAA,EAAC;UAAA,IAC1DmC,UAAU;YAAAO,QAAA,CAAAE,IAAA;YAAA;UAAA;UAAA,MACP,IAAIC,KAAK,UAAAI,MAAA,CAAUjD,OAAO,gBAAa,CAAC;QAAA;UAEhD;UACMoC,UAAU,GAAGnC,SAAS,KAAK,QAAQ,GAAG,QAAQ,GAAG,eAAe;UAChEoC,MAAM,GAAGnC,QAAQ,aAARA,QAAQ,uBAARA,QAAQ,CAAEkE,GAAG,CAAC,UAAA7D,KAAK;YAAA,OAAIA,KAAK,CAACA,KAAK;UAAA,EAAC;UAC5C+B,cAAc,GAAGpC,QAAQ,aAARA,QAAQ,uBAARA,QAAQ,CAAEkE,GAAG,CAAC,UAAA7D,KAAK;YAAA,OAAI,CAACA,KAAK,CAACH,KAAK,EAAEG,KAAK,CAACA,KAAK,CAAC;UAAA,EAAC;UACnEgC,UAAU,GAAG;YACjBqB,IAAI,EAAE,qBAAqB;YAC3BP,IAAI,EAAE,QAAQ;YACdQ,QAAQ,EAAE,QAAQ;YAClBxB,MAAM,EAANA,MAAM;YACNnC,QAAQ,EAAEoC;UACZ,CAAC;UAEDJ,QAAQ,CAACoB,MAAM,CAAC,YAAY,CAAC,GAAGlB,UAAU;UAC1CF,QAAQ,CAACoB,MAAM,CAAC,YAAY,CAAC,GAAGnB,UAAU;UAC1CD,QAAQ,CAACoB,MAAM,CAAC,kBAAkB,CAAC,GAAGlB,UAAU;UAChDF,QAAQ,CAACoB,MAAM,CAAC,kBAAkB,CAAC,GAAGnB,UAAU;UAChDD,QAAQ,CAACoB,MAAM,CAACK,SAAS,CAAC,YAAY,CAAC,GAAGpB,UAAU;UACpDL,QAAQ,CAACoB,MAAM,CAACK,SAAS,CAAC,kBAAkB,CAAC,GAAGpB,UAAU;UAC1DL,QAAQ,CAACoB,MAAM,CAAC,gBAAgB,CAAC,GAAG;YAClCnB,UAAU,EAAE;cACVyB,IAAI,EAAE5D,OAAO;cACbqD,IAAI,EAAElB,UAAU,aAAVA,UAAU,uBAAVA,UAAU,CAAEkB;YACpB,CAAC;YACDjB,UAAU,EAAVA;UACF,CAAC;QAAC;UAAA,OAAAM,QAAA,CAAA2B,MAAA,WAGG;YACLC,SAAS,EAAE;cACTC,OAAO,EAAE,IAAI;cACbxC,KAAK,EAAEyC,IAAI,CAACC,SAAS,CAACvC,QAAQ,CAAC;cAC/BwC,OAAO,eAAAzB,MAAA,CAAejB,OAAO;YAC/B,CAAC;YACD2C,cAAc,EAAE;cACd5C,KAAK,EAAEG,QAAQ;cACfL,SAAS,EAATA;YACF;UACF,CAAC;QAAA;UAAAa,QAAA,CAAAC,IAAA;UAAAD,QAAA,CAAAkC,EAAA,GAAAlC,QAAA;UAAA,OAAAA,QAAA,CAAA2B,MAAA,WAEM;YACLC,SAAS,EAAE;cACTC,OAAO,EAAE,KAAK;cACdM,KAAK,EAAEnC,QAAA,CAAAkC,EAAA,YAAiB/B,KAAK,GAAGH,QAAA,CAAAkC,EAAA,CAAME,OAAO,GAAG,eAAe;cAC/DC,WAAW,EACT;YACJ;UACF,CAAC;QAAA;QAAA;UAAA,OAAArC,QAAA,CAAAsC,IAAA;MAAA;IAAA,GAAAxD,OAAA;EAAA,CAEJ;EAAA,OAAAJ,gBAAA,CAAA5C,KAAA,OAAAE,SAAA;AAAA;AAEM,SAASwE,iBAAiBA,CAACpB,OAAoB,EAAE/B,SAAiB,EAAE;EACzE;EACA,IAAIA,SAAS,KAAK,SAAS,EAAE;IAC3B,IAAI+B,OAAO,CAACmD,UAAU,IAAInD,OAAO,CAACmD,UAAU,CAACtG,MAAM,GAAG,CAAC,EAAE;MACvD,IAAMuG,KAAK,GAAGpD,OAAO,CAACmD,UAAU,CAACb,GAAG,CAAC,UAAAe,SAAS;QAAA,OAAK;UACjDC,SAAS,EAAE,IAAI;UACfpC,KAAK,EAAE,QAAQ;UACff,OAAO,EAAEkD,SAAS,CAACE;QACrB,CAAC;MAAA,CAAC,CAAC;MACH,IAAMtD,MAAK,GAAG,IAAIuD,iBAAY,CAACC,OAAO,CAACL,KAAK,CAAC,CAAC,CAAC,CAAC;MAChD,OAAOnD,MAAK;IACd;EACF;EACA,IAAMyD,aAAa,GAAG,IAAAC,sBAAgB,EAAC3D,OAAO,EAAEwD,iBAAY,CAAC;EAC7D,IAAMvD,KAAK,GAAGyD,aAAa,CAAC1C,IAAI,CAAC,UAAA4C,CAAC;IAAA,OAAIA,CAAC,CAACrC,IAAI,KAAKtD,SAAS;EAAA,EAAC;EAC3D,OAAOgC,KAAK,IAAIyD,aAAa,CAAC7G,MAAM,GAAG,CAAC,GAAG6G,aAAa,CAAC,CAAC,CAAC,GAAG,IAAI;AACpE;AAEO,SAAS7E,qBAAqBA,CAAAgF,IAAA,EAAqB;EAAA,IAAnB5D,KAAK,GAAA4D,IAAA,CAAL5D,KAAK;IAAEF,SAAS,GAAA8D,IAAA,CAAT9D,SAAS;EACrD,IAAM+D,QAAQ,GAAG,IAAAC,gBAAW,EAAC,CAAC;EAE9B,IAAAC,gBAAS,EAAC,YAAM;IACdF,QAAQ,CAAC,IAAAG,cAAc,EAAChE,KAAK,EAAEF,SAAS,CAAC,CAAC;IAC1C;EACF,CAAC,EAAE,EAAE,CAAC;EAEN,OAAO,IAAI;AACb","ignoreList":[]}