@vuu-ui/vuu-data-local 0.13.9 → 0.13.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (37) hide show
  1. package/cjs/array-data-source/aggregate-utils.js +237 -0
  2. package/cjs/array-data-source/aggregate-utils.js.map +1 -0
  3. package/cjs/array-data-source/array-data-source.js +669 -0
  4. package/cjs/array-data-source/array-data-source.js.map +1 -0
  5. package/cjs/array-data-source/array-data-utils.js +52 -0
  6. package/cjs/array-data-source/array-data-utils.js.map +1 -0
  7. package/cjs/array-data-source/group-utils.js +181 -0
  8. package/cjs/array-data-source/group-utils.js.map +1 -0
  9. package/cjs/array-data-source/sort-utils.js +54 -0
  10. package/cjs/array-data-source/sort-utils.js.map +1 -0
  11. package/cjs/index.js +6 -1992
  12. package/cjs/index.js.map +1 -1
  13. package/cjs/json-data-source/JsonDataSource.js +398 -0
  14. package/cjs/json-data-source/JsonDataSource.js.map +1 -0
  15. package/cjs/tree-data-source/IconProvider.js +31 -0
  16. package/cjs/tree-data-source/IconProvider.js.map +1 -0
  17. package/cjs/tree-data-source/TreeDataSource.js +421 -0
  18. package/cjs/tree-data-source/TreeDataSource.js.map +1 -0
  19. package/esm/array-data-source/aggregate-utils.js +235 -0
  20. package/esm/array-data-source/aggregate-utils.js.map +1 -0
  21. package/esm/array-data-source/array-data-source.js +667 -0
  22. package/esm/array-data-source/array-data-source.js.map +1 -0
  23. package/esm/array-data-source/array-data-utils.js +49 -0
  24. package/esm/array-data-source/array-data-utils.js.map +1 -0
  25. package/esm/array-data-source/group-utils.js +177 -0
  26. package/esm/array-data-source/group-utils.js.map +1 -0
  27. package/esm/array-data-source/sort-utils.js +52 -0
  28. package/esm/array-data-source/sort-utils.js.map +1 -0
  29. package/esm/index.js +3 -1993
  30. package/esm/index.js.map +1 -1
  31. package/esm/json-data-source/JsonDataSource.js +396 -0
  32. package/esm/json-data-source/JsonDataSource.js.map +1 -0
  33. package/esm/tree-data-source/IconProvider.js +29 -0
  34. package/esm/tree-data-source/IconProvider.js.map +1 -0
  35. package/esm/tree-data-source/TreeDataSource.js +419 -0
  36. package/esm/tree-data-source/TreeDataSource.js.map +1 -0
  37. package/package.json +7 -7
@@ -0,0 +1,237 @@
1
+ 'use strict';
2
+
3
+ const aggregateData = (aggregations, targetData, groupBy, leafData, columnMap, groupMap) => {
4
+ const aggType = aggregations[aggregations.length - 1].aggType;
5
+ const groupIndices = groupBy.map((column) => columnMap[column]);
6
+ switch (aggType) {
7
+ case 1:
8
+ return aggregateSum(
9
+ groupMap,
10
+ leafData,
11
+ columnMap,
12
+ aggregations,
13
+ targetData,
14
+ groupIndices
15
+ );
16
+ case 2:
17
+ return aggregateAverage(
18
+ groupMap,
19
+ leafData,
20
+ columnMap,
21
+ aggregations,
22
+ targetData,
23
+ groupIndices
24
+ );
25
+ case 3:
26
+ return aggregateCount(
27
+ groupMap,
28
+ columnMap,
29
+ aggregations,
30
+ targetData,
31
+ groupIndices
32
+ );
33
+ case 4:
34
+ return aggregateHigh(
35
+ groupMap,
36
+ leafData,
37
+ columnMap,
38
+ aggregations,
39
+ targetData,
40
+ groupIndices
41
+ );
42
+ case 5:
43
+ return aggregateLow(
44
+ groupMap,
45
+ leafData,
46
+ columnMap,
47
+ aggregations,
48
+ targetData,
49
+ groupIndices
50
+ );
51
+ case 6:
52
+ return aggregateDistinct(
53
+ groupMap,
54
+ leafData,
55
+ columnMap,
56
+ aggregations,
57
+ targetData,
58
+ groupIndices
59
+ );
60
+ }
61
+ };
62
+ function aggregateCount(groupMap, columnMap, aggregations, targetData, groupIndices) {
63
+ const counts = {};
64
+ const aggColumn = getAggColumn(columnMap, aggregations);
65
+ function countRecursive(map) {
66
+ if (Array.isArray(map)) {
67
+ return map.length;
68
+ } else {
69
+ let count2 = 0;
70
+ for (const key in map) {
71
+ count2 += 1 + countRecursive(map[key]);
72
+ }
73
+ return count2;
74
+ }
75
+ }
76
+ for (const key in groupMap) {
77
+ const count2 = countRecursive(groupMap[key]);
78
+ counts[key] = count2;
79
+ }
80
+ for (let index = 0; index < targetData.length; index++) {
81
+ for (const key in counts) {
82
+ if (targetData[index][groupIndices[0]] === key) {
83
+ targetData[index][aggColumn] = counts[key];
84
+ }
85
+ }
86
+ }
87
+ return counts;
88
+ }
89
+ function getAggColumn(columnMap, aggregations) {
90
+ const columnName = aggregations[aggregations.length - 1].column;
91
+ const columnNumber = columnMap[columnName];
92
+ return columnNumber;
93
+ }
94
+ function aggregateSum(groupMap, leafData, columnMap, aggregations, targetData, groupIndices) {
95
+ const sums = {};
96
+ const aggColumn = getAggColumn(columnMap, aggregations);
97
+ function sumRecursive(map, leafData2, aggColumn2) {
98
+ if (Array.isArray(map)) {
99
+ let sum = 0;
100
+ for (const key of map) {
101
+ sum += Number(leafData2[key][aggColumn2]);
102
+ }
103
+ return sum;
104
+ } else {
105
+ let sum = 0;
106
+ for (const key in map) {
107
+ sum += sumRecursive(map[key], leafData2, aggColumn2);
108
+ }
109
+ return sum;
110
+ }
111
+ }
112
+ for (const key in groupMap) {
113
+ const sum = Number(sumRecursive(groupMap[key], leafData, aggColumn));
114
+ sums[key] = sum;
115
+ }
116
+ for (let index = 0; index < targetData.length; index++) {
117
+ for (const key in sums) {
118
+ if (targetData[index][groupIndices[0]] === key) {
119
+ targetData[index][aggColumn] = sums[key];
120
+ }
121
+ }
122
+ }
123
+ return sums;
124
+ }
125
+ function aggregateAverage(groupMap, leafData, columnMap, aggregations, targetData, groupIndices) {
126
+ const averages = {};
127
+ const aggColumn = getAggColumn(columnMap, aggregations);
128
+ const count2 = aggregateCount(
129
+ groupMap,
130
+ columnMap,
131
+ aggregations,
132
+ targetData,
133
+ groupIndices
134
+ );
135
+ const sum = aggregateSum(
136
+ groupMap,
137
+ leafData,
138
+ columnMap,
139
+ aggregations,
140
+ targetData,
141
+ groupIndices
142
+ );
143
+ for (const key in count2) {
144
+ let average = 0;
145
+ average = sum[key] / count2[key];
146
+ averages[key] = average;
147
+ }
148
+ for (let index = 0; index < targetData.length; index++) {
149
+ for (const key in averages) {
150
+ if (targetData[index][groupIndices[0]] === key) {
151
+ targetData[index][aggColumn] = averages[key];
152
+ }
153
+ }
154
+ }
155
+ console.log("!!!! targetData", targetData);
156
+ console.log("!!!! averages", averages);
157
+ return averages;
158
+ }
159
+ function getLeafColumnData(map, leafData, aggColumn) {
160
+ const data = [];
161
+ if (Array.isArray(map)) {
162
+ for (const key of map) {
163
+ data.push(leafData[key][aggColumn]);
164
+ }
165
+ } else {
166
+ for (const key in map) {
167
+ data.push(...getLeafColumnData(map[key], leafData, aggColumn));
168
+ }
169
+ }
170
+ return data;
171
+ }
172
+ function aggregateDistinct(groupMap, leafData, columnMap, aggregations, targetData, groupIndices) {
173
+ const distincts = {};
174
+ const aggColumn = getAggColumn(columnMap, aggregations);
175
+ for (const key in groupMap) {
176
+ const leafColumnData = getLeafColumnData(
177
+ groupMap[key],
178
+ leafData,
179
+ aggColumn
180
+ );
181
+ const distinct = [...new Set(leafColumnData)];
182
+ distincts[key] = distinct.length;
183
+ }
184
+ for (let index = 0; index < targetData.length; index++) {
185
+ for (const key in distincts) {
186
+ if (targetData[index][groupIndices[0]] === key) {
187
+ targetData[index][aggColumn] = distincts[key];
188
+ }
189
+ }
190
+ }
191
+ return distincts;
192
+ }
193
+ function aggregateHigh(groupMap, leafData, columnMap, aggregations, targetData, groupIndices) {
194
+ const highs = {};
195
+ const aggColumn = getAggColumn(columnMap, aggregations);
196
+ for (const key in groupMap) {
197
+ const leafColumnData = getLeafColumnData(
198
+ groupMap[key],
199
+ leafData,
200
+ aggColumn
201
+ );
202
+ const maxNumber = Math.max(...leafColumnData);
203
+ highs[key] = maxNumber;
204
+ }
205
+ for (let index = 0; index < targetData.length; index++) {
206
+ for (const key in highs) {
207
+ if (targetData[index][groupIndices[0]] === key) {
208
+ targetData[index][aggColumn] = highs[key];
209
+ }
210
+ }
211
+ }
212
+ return highs;
213
+ }
214
+ function aggregateLow(groupMap, leafData, columnMap, aggregations, targetData, groupIndices) {
215
+ const mins = {};
216
+ const aggColumn = getAggColumn(columnMap, aggregations);
217
+ for (const key in groupMap) {
218
+ const leafColumnData = getLeafColumnData(
219
+ groupMap[key],
220
+ leafData,
221
+ aggColumn
222
+ );
223
+ const minNumber = Math.min(...leafColumnData);
224
+ mins[key] = minNumber;
225
+ }
226
+ for (let index = 0; index < targetData.length; index++) {
227
+ for (const key in mins) {
228
+ if (targetData[index][groupIndices[0]] === key) {
229
+ targetData[index][aggColumn] = mins[key];
230
+ }
231
+ }
232
+ }
233
+ return mins;
234
+ }
235
+
236
+ exports.aggregateData = aggregateData;
237
+ //# sourceMappingURL=aggregate-utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"aggregate-utils.js","sources":["../../src/array-data-source/aggregate-utils.ts"],"sourcesContent":["import type { DataSourceRow } from \"@vuu-ui/vuu-data-types\";\nimport type { VuuAggregation, VuuGroupBy } from \"@vuu-ui/vuu-protocol-types\";\nimport type { ColumnMap } from \"@vuu-ui/vuu-utils\";\nimport type { GroupMap, KeyList } from \"./group-utils\";\n\nexport const count = (arr: unknown[]) => arr.length;\n\nexport const aggregateData = (\n aggregations: VuuAggregation[],\n targetData: readonly DataSourceRow[],\n groupBy: VuuGroupBy,\n leafData: readonly DataSourceRow[],\n columnMap: ColumnMap,\n groupMap: GroupMap,\n) => {\n const aggType = aggregations[aggregations.length - 1].aggType;\n const groupIndices = groupBy.map<number>((column) => columnMap[column]);\n\n switch (aggType) {\n case 1:\n return aggregateSum(\n groupMap,\n leafData,\n columnMap,\n aggregations,\n targetData,\n groupIndices,\n );\n case 2:\n return aggregateAverage(\n groupMap,\n leafData,\n columnMap,\n aggregations,\n targetData,\n groupIndices,\n );\n case 3:\n return aggregateCount(\n groupMap,\n columnMap,\n aggregations,\n targetData,\n groupIndices,\n );\n case 4:\n return aggregateHigh(\n groupMap,\n leafData,\n columnMap,\n aggregations,\n targetData,\n groupIndices,\n );\n case 5:\n return aggregateLow(\n groupMap,\n leafData,\n columnMap,\n aggregations,\n targetData,\n groupIndices,\n );\n case 6:\n return aggregateDistinct(\n groupMap,\n leafData,\n columnMap,\n aggregations,\n targetData,\n groupIndices,\n );\n }\n};\n\nfunction aggregateCount(\n groupMap: GroupMap,\n columnMap: ColumnMap,\n aggregations: VuuAggregation[],\n targetData: readonly DataSourceRow[],\n groupIndices: number[],\n): { [key: string]: number } {\n const counts: { [key: string]: number } = {};\n const aggColumn = getAggColumn(columnMap, aggregations);\n\n function countRecursive(map: GroupMap | KeyList) {\n if (Array.isArray(map)) {\n return map.length;\n } else {\n let count = 0;\n for (const key in map) {\n count += 1 + countRecursive(map[key]);\n }\n return count;\n }\n }\n\n for (const key in groupMap) {\n const count = countRecursive(groupMap[key]);\n counts[key] = count;\n }\n\n for (let index = 0; index < targetData.length; index++) {\n for (const key in counts) {\n if (targetData[index][groupIndices[0]] === key) {\n targetData[index][aggColumn] = counts[key];\n }\n }\n }\n\n return counts;\n}\n\nfunction getAggColumn(columnMap: ColumnMap, aggregations: VuuAggregation[]) {\n const columnName = aggregations[aggregations.length - 1].column;\n const columnNumber = columnMap[columnName];\n return columnNumber;\n}\n\nfunction aggregateSum(\n groupMap: GroupMap,\n leafData: readonly DataSourceRow[],\n columnMap: ColumnMap,\n aggregations: VuuAggregation[],\n targetData: readonly DataSourceRow[],\n groupIndices: number[],\n): { [key: string]: number } {\n const sums: { [key: string]: number } = {};\n const aggColumn = getAggColumn(columnMap, aggregations);\n\n function sumRecursive(\n map: GroupMap | KeyList,\n leafData: readonly DataSourceRow[],\n aggColumn: number,\n ) {\n if (Array.isArray(map)) {\n let sum = 0;\n for (const key of map) {\n sum += Number(leafData[key][aggColumn]);\n }\n return sum;\n } else {\n let sum = 0;\n for (const key in map) {\n sum += sumRecursive(map[key], leafData, aggColumn);\n }\n return sum;\n }\n }\n\n for (const key in groupMap) {\n const sum = Number(sumRecursive(groupMap[key], leafData, aggColumn));\n sums[key] = sum;\n }\n\n for (let index = 0; index < targetData.length; index++) {\n for (const key in sums) {\n if (targetData[index][groupIndices[0]] === key) {\n targetData[index][aggColumn] = sums[key];\n }\n }\n }\n\n return sums;\n}\n\nfunction aggregateAverage(\n groupMap: GroupMap,\n leafData: readonly DataSourceRow[],\n columnMap: ColumnMap,\n aggregations: VuuAggregation[],\n targetData: readonly DataSourceRow[],\n groupIndices: number[],\n): { [key: string]: number } {\n const averages: { [key: string]: number } = {};\n const aggColumn = getAggColumn(columnMap, aggregations);\n\n const count = aggregateCount(\n groupMap,\n columnMap,\n aggregations,\n targetData,\n groupIndices,\n );\n const sum = aggregateSum(\n groupMap,\n leafData,\n columnMap,\n aggregations,\n targetData,\n groupIndices,\n );\n\n for (const key in count) {\n let average = 0;\n average = sum[key] / count[key];\n averages[key] = average;\n }\n\n for (let index = 0; index < targetData.length; index++) {\n for (const key in averages) {\n if (targetData[index][groupIndices[0]] === key) {\n targetData[index][aggColumn] = averages[key];\n }\n }\n }\n\n console.log(\"!!!! targetData\", targetData);\n console.log(\"!!!! averages\", averages);\n return averages;\n}\n\nfunction getLeafColumnData(\n map: GroupMap | KeyList,\n leafData: readonly DataSourceRow[],\n aggColumn: number,\n): number[] {\n const data: number[] = [];\n\n if (Array.isArray(map)) {\n for (const key of map) {\n data.push(leafData[key][aggColumn] as number);\n }\n } else {\n for (const key in map) {\n data.push(...getLeafColumnData(map[key], leafData, aggColumn));\n }\n }\n\n return data;\n}\n\nfunction aggregateDistinct(\n groupMap: GroupMap,\n leafData: readonly DataSourceRow[],\n columnMap: ColumnMap,\n aggregations: VuuAggregation[],\n targetData: readonly DataSourceRow[],\n groupIndices: number[],\n): { [key: string]: number } {\n const distincts: { [key: string]: number } = {};\n const aggColumn = getAggColumn(columnMap, aggregations);\n\n for (const key in groupMap) {\n const leafColumnData = getLeafColumnData(\n groupMap[key],\n leafData,\n aggColumn,\n );\n const distinct = [...new Set(leafColumnData)];\n\n distincts[key] = distinct.length;\n }\n\n for (let index = 0; index < targetData.length; index++) {\n for (const key in distincts) {\n if (targetData[index][groupIndices[0]] === key) {\n targetData[index][aggColumn] = distincts[key];\n }\n }\n }\n\n return distincts;\n}\n\nfunction aggregateHigh(\n groupMap: GroupMap,\n leafData: readonly DataSourceRow[],\n columnMap: ColumnMap,\n aggregations: VuuAggregation[],\n targetData: readonly DataSourceRow[],\n groupIndices: number[],\n): { [key: string]: number } {\n const highs: { [key: string]: number } = {};\n const aggColumn = getAggColumn(columnMap, aggregations);\n\n for (const key in groupMap) {\n const leafColumnData = getLeafColumnData(\n groupMap[key],\n leafData,\n aggColumn,\n );\n const maxNumber = Math.max(...leafColumnData);\n\n highs[key] = maxNumber;\n }\n for (let index = 0; index < targetData.length; index++) {\n for (const key in highs) {\n if (targetData[index][groupIndices[0]] === key) {\n targetData[index][aggColumn] = highs[key];\n }\n }\n }\n\n return highs;\n}\n\nfunction aggregateLow(\n groupMap: GroupMap,\n leafData: readonly DataSourceRow[],\n columnMap: ColumnMap,\n aggregations: VuuAggregation[],\n targetData: readonly DataSourceRow[],\n groupIndices: number[],\n): { [key: string]: number } {\n const mins: { [key: string]: number } = {};\n const aggColumn = getAggColumn(columnMap, aggregations);\n\n for (const key in groupMap) {\n const leafColumnData = getLeafColumnData(\n groupMap[key],\n leafData,\n aggColumn,\n );\n const minNumber = Math.min(...leafColumnData);\n mins[key] = minNumber;\n }\n\n for (let index = 0; index < targetData.length; index++) {\n for (const key in mins) {\n if (targetData[index][groupIndices[0]] === key) {\n targetData[index][aggColumn] = mins[key];\n }\n }\n }\n\n return mins;\n}\n"],"names":["count","leafData","aggColumn"],"mappings":";;AAOO,MAAM,gBAAgB,CAC3B,YAAA,EACA,YACA,OACA,EAAA,QAAA,EACA,WACA,QACG,KAAA;AACH,EAAA,MAAM,OAAU,GAAA,YAAA,CAAa,YAAa,CAAA,MAAA,GAAS,CAAC,CAAE,CAAA,OAAA;AACtD,EAAA,MAAM,eAAe,OAAQ,CAAA,GAAA,CAAY,CAAC,MAAW,KAAA,SAAA,CAAU,MAAM,CAAC,CAAA;AAEtE,EAAA,QAAQ,OAAS;AAAA,IACf,KAAK,CAAA;AACH,MAAO,OAAA,YAAA;AAAA,QACL,QAAA;AAAA,QACA,QAAA;AAAA,QACA,SAAA;AAAA,QACA,YAAA;AAAA,QACA,UAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF,KAAK,CAAA;AACH,MAAO,OAAA,gBAAA;AAAA,QACL,QAAA;AAAA,QACA,QAAA;AAAA,QACA,SAAA;AAAA,QACA,YAAA;AAAA,QACA,UAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF,KAAK,CAAA;AACH,MAAO,OAAA,cAAA;AAAA,QACL,QAAA;AAAA,QACA,SAAA;AAAA,QACA,YAAA;AAAA,QACA,UAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF,KAAK,CAAA;AACH,MAAO,OAAA,aAAA;AAAA,QACL,QAAA;AAAA,QACA,QAAA;AAAA,QACA,SAAA;AAAA,QACA,YAAA;AAAA,QACA,UAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF,KAAK,CAAA;AACH,MAAO,OAAA,YAAA;AAAA,QACL,QAAA;AAAA,QACA,QAAA;AAAA,QACA,SAAA;AAAA,QACA,YAAA;AAAA,QACA,UAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF,KAAK,CAAA;AACH,MAAO,OAAA,iBAAA;AAAA,QACL,QAAA;AAAA,QACA,QAAA;AAAA,QACA,SAAA;AAAA,QACA,YAAA;AAAA,QACA,UAAA;AAAA,QACA;AAAA,OACF;AAAA;AAEN;AAEA,SAAS,cACP,CAAA,QAAA,EACA,SACA,EAAA,YAAA,EACA,YACA,YAC2B,EAAA;AAC3B,EAAA,MAAM,SAAoC,EAAC;AAC3C,EAAM,MAAA,SAAA,GAAY,YAAa,CAAA,SAAA,EAAW,YAAY,CAAA;AAEtD,EAAA,SAAS,eAAe,GAAyB,EAAA;AAC/C,IAAI,IAAA,KAAA,CAAM,OAAQ,CAAA,GAAG,CAAG,EAAA;AACtB,MAAA,OAAO,GAAI,CAAA,MAAA;AAAA,KACN,MAAA;AACL,MAAA,IAAIA,MAAQ,GAAA,CAAA;AACZ,MAAA,KAAA,MAAW,OAAO,GAAK,EAAA;AACrB,QAAAA,MAAS,IAAA,CAAA,GAAI,cAAe,CAAA,GAAA,CAAI,GAAG,CAAC,CAAA;AAAA;AAEtC,MAAOA,OAAAA,MAAAA;AAAA;AACT;AAGF,EAAA,KAAA,MAAW,OAAO,QAAU,EAAA;AAC1B,IAAA,MAAMA,MAAQ,GAAA,cAAA,CAAe,QAAS,CAAA,GAAG,CAAC,CAAA;AAC1C,IAAA,MAAA,CAAO,GAAG,CAAIA,GAAAA,MAAAA;AAAA;AAGhB,EAAA,KAAA,IAAS,KAAQ,GAAA,CAAA,EAAG,KAAQ,GAAA,UAAA,CAAW,QAAQ,KAAS,EAAA,EAAA;AACtD,IAAA,KAAA,MAAW,OAAO,MAAQ,EAAA;AACxB,MAAA,IAAI,WAAW,KAAK,CAAA,CAAE,aAAa,CAAC,CAAC,MAAM,GAAK,EAAA;AAC9C,QAAA,UAAA,CAAW,KAAK,CAAA,CAAE,SAAS,CAAA,GAAI,OAAO,GAAG,CAAA;AAAA;AAC3C;AACF;AAGF,EAAO,OAAA,MAAA;AACT;AAEA,SAAS,YAAA,CAAa,WAAsB,YAAgC,EAAA;AAC1E,EAAA,MAAM,UAAa,GAAA,YAAA,CAAa,YAAa,CAAA,MAAA,GAAS,CAAC,CAAE,CAAA,MAAA;AACzD,EAAM,MAAA,YAAA,GAAe,UAAU,UAAU,CAAA;AACzC,EAAO,OAAA,YAAA;AACT;AAEA,SAAS,aACP,QACA,EAAA,QAAA,EACA,SACA,EAAA,YAAA,EACA,YACA,YAC2B,EAAA;AAC3B,EAAA,MAAM,OAAkC,EAAC;AACzC,EAAM,MAAA,SAAA,GAAY,YAAa,CAAA,SAAA,EAAW,YAAY,CAAA;AAEtD,EAAS,SAAA,YAAA,CACP,GACAC,EAAAA,SAAAA,EACAC,UACA,EAAA;AACA,IAAI,IAAA,KAAA,CAAM,OAAQ,CAAA,GAAG,CAAG,EAAA;AACtB,MAAA,IAAI,GAAM,GAAA,CAAA;AACV,MAAA,KAAA,MAAW,OAAO,GAAK,EAAA;AACrB,QAAA,GAAA,IAAO,MAAOD,CAAAA,SAAAA,CAAS,GAAG,CAAA,CAAEC,UAAS,CAAC,CAAA;AAAA;AAExC,MAAO,OAAA,GAAA;AAAA,KACF,MAAA;AACL,MAAA,IAAI,GAAM,GAAA,CAAA;AACV,MAAA,KAAA,MAAW,OAAO,GAAK,EAAA;AACrB,QAAA,GAAA,IAAO,YAAa,CAAA,GAAA,CAAI,GAAG,CAAA,EAAGD,WAAUC,UAAS,CAAA;AAAA;AAEnD,MAAO,OAAA,GAAA;AAAA;AACT;AAGF,EAAA,KAAA,MAAW,OAAO,QAAU,EAAA;AAC1B,IAAM,MAAA,GAAA,GAAM,OAAO,YAAa,CAAA,QAAA,CAAS,GAAG,CAAG,EAAA,QAAA,EAAU,SAAS,CAAC,CAAA;AACnE,IAAA,IAAA,CAAK,GAAG,CAAI,GAAA,GAAA;AAAA;AAGd,EAAA,KAAA,IAAS,KAAQ,GAAA,CAAA,EAAG,KAAQ,GAAA,UAAA,CAAW,QAAQ,KAAS,EAAA,EAAA;AACtD,IAAA,KAAA,MAAW,OAAO,IAAM,EAAA;AACtB,MAAA,IAAI,WAAW,KAAK,CAAA,CAAE,aAAa,CAAC,CAAC,MAAM,GAAK,EAAA;AAC9C,QAAA,UAAA,CAAW,KAAK,CAAA,CAAE,SAAS,CAAA,GAAI,KAAK,GAAG,CAAA;AAAA;AACzC;AACF;AAGF,EAAO,OAAA,IAAA;AACT;AAEA,SAAS,iBACP,QACA,EAAA,QAAA,EACA,SACA,EAAA,YAAA,EACA,YACA,YAC2B,EAAA;AAC3B,EAAA,MAAM,WAAsC,EAAC;AAC7C,EAAM,MAAA,SAAA,GAAY,YAAa,CAAA,SAAA,EAAW,YAAY,CAAA;AAEtD,EAAA,MAAMF,MAAQ,GAAA,cAAA;AAAA,IACZ,QAAA;AAAA,IACA,SAAA;AAAA,IACA,YAAA;AAAA,IACA,UAAA;AAAA,IACA;AAAA,GACF;AACA,EAAA,MAAM,GAAM,GAAA,YAAA;AAAA,IACV,QAAA;AAAA,IACA,QAAA;AAAA,IACA,SAAA;AAAA,IACA,YAAA;AAAA,IACA,UAAA;AAAA,IACA;AAAA,GACF;AAEA,EAAA,KAAA,MAAW,OAAOA,MAAO,EAAA;AACvB,IAAA,IAAI,OAAU,GAAA,CAAA;AACd,IAAA,OAAA,GAAU,GAAI,CAAA,GAAG,CAAIA,GAAAA,MAAAA,CAAM,GAAG,CAAA;AAC9B,IAAA,QAAA,CAAS,GAAG,CAAI,GAAA,OAAA;AAAA;AAGlB,EAAA,KAAA,IAAS,KAAQ,GAAA,CAAA,EAAG,KAAQ,GAAA,UAAA,CAAW,QAAQ,KAAS,EAAA,EAAA;AACtD,IAAA,KAAA,MAAW,OAAO,QAAU,EAAA;AAC1B,MAAA,IAAI,WAAW,KAAK,CAAA,CAAE,aAAa,CAAC,CAAC,MAAM,GAAK,EAAA;AAC9C,QAAA,UAAA,CAAW,KAAK,CAAA,CAAE,SAAS,CAAA,GAAI,SAAS,GAAG,CAAA;AAAA;AAC7C;AACF;AAGF,EAAQ,OAAA,CAAA,GAAA,CAAI,mBAAmB,UAAU,CAAA;AACzC,EAAQ,OAAA,CAAA,GAAA,CAAI,iBAAiB,QAAQ,CAAA;AACrC,EAAO,OAAA,QAAA;AACT;AAEA,SAAS,iBAAA,CACP,GACA,EAAA,QAAA,EACA,SACU,EAAA;AACV,EAAA,MAAM,OAAiB,EAAC;AAExB,EAAI,IAAA,KAAA,CAAM,OAAQ,CAAA,GAAG,CAAG,EAAA;AACtB,IAAA,KAAA,MAAW,OAAO,GAAK,EAAA;AACrB,MAAA,IAAA,CAAK,IAAK,CAAA,QAAA,CAAS,GAAG,CAAA,CAAE,SAAS,CAAW,CAAA;AAAA;AAC9C,GACK,MAAA;AACL,IAAA,KAAA,MAAW,OAAO,GAAK,EAAA;AACrB,MAAK,IAAA,CAAA,IAAA,CAAK,GAAG,iBAAkB,CAAA,GAAA,CAAI,GAAG,CAAG,EAAA,QAAA,EAAU,SAAS,CAAC,CAAA;AAAA;AAC/D;AAGF,EAAO,OAAA,IAAA;AACT;AAEA,SAAS,kBACP,QACA,EAAA,QAAA,EACA,SACA,EAAA,YAAA,EACA,YACA,YAC2B,EAAA;AAC3B,EAAA,MAAM,YAAuC,EAAC;AAC9C,EAAM,MAAA,SAAA,GAAY,YAAa,CAAA,SAAA,EAAW,YAAY,CAAA;AAEtD,EAAA,KAAA,MAAW,OAAO,QAAU,EAAA;AAC1B,IAAA,MAAM,cAAiB,GAAA,iBAAA;AAAA,MACrB,SAAS,GAAG,CAAA;AAAA,MACZ,QAAA;AAAA,MACA;AAAA,KACF;AACA,IAAA,MAAM,WAAW,CAAC,GAAG,IAAI,GAAA,CAAI,cAAc,CAAC,CAAA;AAE5C,IAAU,SAAA,CAAA,GAAG,IAAI,QAAS,CAAA,MAAA;AAAA;AAG5B,EAAA,KAAA,IAAS,KAAQ,GAAA,CAAA,EAAG,KAAQ,GAAA,UAAA,CAAW,QAAQ,KAAS,EAAA,EAAA;AACtD,IAAA,KAAA,MAAW,OAAO,SAAW,EAAA;AAC3B,MAAA,IAAI,WAAW,KAAK,CAAA,CAAE,aAAa,CAAC,CAAC,MAAM,GAAK,EAAA;AAC9C,QAAA,UAAA,CAAW,KAAK,CAAA,CAAE,SAAS,CAAA,GAAI,UAAU,GAAG,CAAA;AAAA;AAC9C;AACF;AAGF,EAAO,OAAA,SAAA;AACT;AAEA,SAAS,cACP,QACA,EAAA,QAAA,EACA,SACA,EAAA,YAAA,EACA,YACA,YAC2B,EAAA;AAC3B,EAAA,MAAM,QAAmC,EAAC;AAC1C,EAAM,MAAA,SAAA,GAAY,YAAa,CAAA,SAAA,EAAW,YAAY,CAAA;AAEtD,EAAA,KAAA,MAAW,OAAO,QAAU,EAAA;AAC1B,IAAA,MAAM,cAAiB,GAAA,iBAAA;AAAA,MACrB,SAAS,GAAG,CAAA;AAAA,MACZ,QAAA;AAAA,MACA;AAAA,KACF;AACA,IAAA,MAAM,SAAY,GAAA,IAAA,CAAK,GAAI,CAAA,GAAG,cAAc,CAAA;AAE5C,IAAA,KAAA,CAAM,GAAG,CAAI,GAAA,SAAA;AAAA;AAEf,EAAA,KAAA,IAAS,KAAQ,GAAA,CAAA,EAAG,KAAQ,GAAA,UAAA,CAAW,QAAQ,KAAS,EAAA,EAAA;AACtD,IAAA,KAAA,MAAW,OAAO,KAAO,EAAA;AACvB,MAAA,IAAI,WAAW,KAAK,CAAA,CAAE,aAAa,CAAC,CAAC,MAAM,GAAK,EAAA;AAC9C,QAAA,UAAA,CAAW,KAAK,CAAA,CAAE,SAAS,CAAA,GAAI,MAAM,GAAG,CAAA;AAAA;AAC1C;AACF;AAGF,EAAO,OAAA,KAAA;AACT;AAEA,SAAS,aACP,QACA,EAAA,QAAA,EACA,SACA,EAAA,YAAA,EACA,YACA,YAC2B,EAAA;AAC3B,EAAA,MAAM,OAAkC,EAAC;AACzC,EAAM,MAAA,SAAA,GAAY,YAAa,CAAA,SAAA,EAAW,YAAY,CAAA;AAEtD,EAAA,KAAA,MAAW,OAAO,QAAU,EAAA;AAC1B,IAAA,MAAM,cAAiB,GAAA,iBAAA;AAAA,MACrB,SAAS,GAAG,CAAA;AAAA,MACZ,QAAA;AAAA,MACA;AAAA,KACF;AACA,IAAA,MAAM,SAAY,GAAA,IAAA,CAAK,GAAI,CAAA,GAAG,cAAc,CAAA;AAC5C,IAAA,IAAA,CAAK,GAAG,CAAI,GAAA,SAAA;AAAA;AAGd,EAAA,KAAA,IAAS,KAAQ,GAAA,CAAA,EAAG,KAAQ,GAAA,UAAA,CAAW,QAAQ,KAAS,EAAA,EAAA;AACtD,IAAA,KAAA,MAAW,OAAO,IAAM,EAAA;AACtB,MAAA,IAAI,WAAW,KAAK,CAAA,CAAE,aAAa,CAAC,CAAC,MAAM,GAAK,EAAA;AAC9C,QAAA,UAAA,CAAW,KAAK,CAAA,CAAE,SAAS,CAAA,GAAI,KAAK,GAAG,CAAA;AAAA;AACzC;AACF;AAGF,EAAO,OAAA,IAAA;AACT;;;;"}