@revisium/core 2.3.0-alpha.1 → 2.3.0-alpha.2

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 (29) hide show
  1. package/dist/package.json +2 -1
  2. package/dist/src/features/row/queries/handlers/get-rows.handler.d.ts +2 -4
  3. package/dist/src/features/row/queries/handlers/get-rows.handler.js +4 -24
  4. package/dist/src/features/row/queries/handlers/get-rows.handler.js.map +1 -1
  5. package/dist/src/features/row/queries/impl/get-rows.query.d.ts +3 -3
  6. package/dist/src/features/row/queries/impl/get-rows.query.js.map +1 -1
  7. package/dist/src/features/row/utils/get-rows-sql.d.ts +5 -0
  8. package/dist/src/features/row/utils/get-rows-sql.js +70 -0
  9. package/dist/src/features/row/utils/get-rows-sql.js.map +1 -0
  10. package/dist/tsconfig.build.tsbuildinfo +1 -1
  11. package/package.json +2 -1
  12. package/dist/src/utils/prisma-sql-generator/__tests__/shared-helpers.d.ts +0 -16
  13. package/dist/src/utils/prisma-sql-generator/__tests__/shared-helpers.js +0 -70
  14. package/dist/src/utils/prisma-sql-generator/__tests__/shared-helpers.js.map +0 -1
  15. package/dist/src/utils/prisma-sql-generator/__tests__/test-helpers.d.ts +0 -52
  16. package/dist/src/utils/prisma-sql-generator/__tests__/test-helpers.js +0 -531
  17. package/dist/src/utils/prisma-sql-generator/__tests__/test-helpers.js.map +0 -1
  18. package/dist/src/utils/prisma-sql-generator/index.d.ts +0 -2
  19. package/dist/src/utils/prisma-sql-generator/index.js +0 -22
  20. package/dist/src/utils/prisma-sql-generator/index.js.map +0 -1
  21. package/dist/src/utils/prisma-sql-generator/json-path.d.ts +0 -14
  22. package/dist/src/utils/prisma-sql-generator/json-path.js +0 -121
  23. package/dist/src/utils/prisma-sql-generator/json-path.js.map +0 -1
  24. package/dist/src/utils/prisma-sql-generator/types.d.ts +0 -105
  25. package/dist/src/utils/prisma-sql-generator/types.js +0 -3
  26. package/dist/src/utils/prisma-sql-generator/types.js.map +0 -1
  27. package/dist/src/utils/prisma-sql-generator/where-generator.prisma.d.ts +0 -21
  28. package/dist/src/utils/prisma-sql-generator/where-generator.prisma.js +0 -527
  29. package/dist/src/utils/prisma-sql-generator/where-generator.prisma.js.map +0 -1
@@ -1,527 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.WhereGeneratorPrisma = void 0;
4
- exports.generateGetRowsQueryPrisma = generateGetRowsQueryPrisma;
5
- const client_1 = require("@prisma/client");
6
- const json_path_1 = require("./json-path");
7
- class WhereGeneratorPrisma {
8
- generateWhere(conditions) {
9
- if (!conditions || Object.keys(conditions).length === 0) {
10
- return client_1.Prisma.sql `TRUE`;
11
- }
12
- return this.processConditions(conditions);
13
- }
14
- processConditions(conditions) {
15
- const clauses = [];
16
- if (Array.isArray(conditions.AND) && conditions.AND.length > 0) {
17
- const andClauses = conditions.AND.map((cond) => this.processConditions(cond)).filter((c) => c.inspect().sql !== 'TRUE');
18
- if (andClauses.length > 0) {
19
- clauses.push(client_1.Prisma.sql `(${this.combineWithAnd(andClauses)})`);
20
- }
21
- }
22
- if (Array.isArray(conditions.OR) && conditions.OR.length > 0) {
23
- const orClauses = conditions.OR.map((cond) => this.processConditions(cond)).filter((c) => c.inspect().sql !== 'TRUE');
24
- if (orClauses.length > 0) {
25
- clauses.push(client_1.Prisma.sql `(${this.combineWithOr(orClauses)})`);
26
- }
27
- }
28
- if (conditions.NOT) {
29
- const notClause = this.processConditions(conditions.NOT);
30
- clauses.push(client_1.Prisma.sql `NOT (${notClause})`);
31
- }
32
- if (conditions.versionId !== undefined) {
33
- clauses.push(this.processStringField('versionId', conditions.versionId));
34
- }
35
- if (conditions.createdId !== undefined) {
36
- clauses.push(this.processStringField('createdId', conditions.createdId));
37
- }
38
- if (conditions.id !== undefined) {
39
- clauses.push(this.processStringField('id', conditions.id));
40
- }
41
- if (conditions.hash !== undefined) {
42
- clauses.push(this.processStringField('hash', conditions.hash));
43
- }
44
- if (conditions.schemaHash !== undefined) {
45
- clauses.push(this.processStringField('schemaHash', conditions.schemaHash));
46
- }
47
- if (conditions.readonly !== undefined) {
48
- clauses.push(this.processBoolField('readonly', conditions.readonly));
49
- }
50
- if (conditions.createdAt !== undefined) {
51
- clauses.push(this.processDateField('createdAt', conditions.createdAt));
52
- }
53
- if (conditions.updatedAt !== undefined) {
54
- clauses.push(this.processDateField('updatedAt', conditions.updatedAt));
55
- }
56
- if (conditions.publishedAt !== undefined) {
57
- clauses.push(this.processDateField('publishedAt', conditions.publishedAt));
58
- }
59
- if (conditions.data !== undefined) {
60
- clauses.push(this.processJsonField('data', conditions.data));
61
- }
62
- if (conditions.meta !== undefined) {
63
- clauses.push(this.processJsonField('meta', conditions.meta));
64
- }
65
- if (clauses.length === 0) {
66
- return client_1.Prisma.sql `TRUE`;
67
- }
68
- if (clauses.length === 1) {
69
- return clauses[0];
70
- }
71
- return this.combineWithAnd(clauses);
72
- }
73
- combineWithAnd(clauses) {
74
- if (clauses.length === 0) {
75
- return client_1.Prisma.sql `TRUE`;
76
- }
77
- if (clauses.length === 1) {
78
- return clauses[0];
79
- }
80
- let result = clauses[0];
81
- for (let i = 1; i < clauses.length; i++) {
82
- result = client_1.Prisma.sql `${result} AND ${clauses[i]}`;
83
- }
84
- return result;
85
- }
86
- combineWithOr(clauses) {
87
- if (clauses.length === 0) {
88
- return client_1.Prisma.sql `FALSE`;
89
- }
90
- if (clauses.length === 1) {
91
- return clauses[0];
92
- }
93
- let result = clauses[0];
94
- for (let i = 1; i < clauses.length; i++) {
95
- result = client_1.Prisma.sql `${result} OR ${clauses[i]}`;
96
- }
97
- return result;
98
- }
99
- generateOrderBy(orderBy) {
100
- if (!orderBy || orderBy.length === 0) {
101
- return client_1.Prisma.sql `r."createdAt" DESC`;
102
- }
103
- const orderClauses = [];
104
- for (const orderItem of orderBy) {
105
- for (const [field, direction] of Object.entries(orderItem)) {
106
- if (typeof direction === 'string') {
107
- const fieldRef = this.getFieldReference(field);
108
- const sortOrder = client_1.Prisma.raw(direction.toUpperCase());
109
- orderClauses.push(client_1.Prisma.sql `${fieldRef} ${sortOrder}`);
110
- }
111
- else if (typeof direction === 'object' && direction !== null) {
112
- const jsonOrderClause = this.generateJsonOrderBy(field, direction);
113
- orderClauses.push(jsonOrderClause);
114
- }
115
- }
116
- }
117
- return orderClauses.length > 0
118
- ? this.combineOrderBy(orderClauses)
119
- : client_1.Prisma.sql `r."createdAt" DESC`;
120
- }
121
- processStringField(field, condition) {
122
- const fieldRef = client_1.Prisma.raw(`r."${field}"`);
123
- if (typeof condition === 'string') {
124
- return client_1.Prisma.sql `${fieldRef} = ${condition}`;
125
- }
126
- const filter = condition;
127
- const mode = filter.mode || 'default';
128
- const isInsensitive = mode === 'insensitive';
129
- if (filter.equals !== undefined) {
130
- if (isInsensitive) {
131
- return client_1.Prisma.sql `${fieldRef} ILIKE ${filter.equals}`;
132
- }
133
- return client_1.Prisma.sql `${fieldRef} = ${filter.equals}`;
134
- }
135
- if (filter.contains !== undefined) {
136
- const pattern = `%${filter.contains}%`;
137
- if (isInsensitive) {
138
- return client_1.Prisma.sql `${fieldRef} ILIKE ${pattern}`;
139
- }
140
- return client_1.Prisma.sql `${fieldRef} LIKE ${pattern}`;
141
- }
142
- if (filter.startsWith !== undefined) {
143
- const pattern = `${filter.startsWith}%`;
144
- if (isInsensitive) {
145
- return client_1.Prisma.sql `${fieldRef} ILIKE ${pattern}`;
146
- }
147
- return client_1.Prisma.sql `${fieldRef} LIKE ${pattern}`;
148
- }
149
- if (filter.endsWith !== undefined) {
150
- const pattern = `%${filter.endsWith}`;
151
- if (isInsensitive) {
152
- return client_1.Prisma.sql `${fieldRef} ILIKE ${pattern}`;
153
- }
154
- return client_1.Prisma.sql `${fieldRef} LIKE ${pattern}`;
155
- }
156
- if (filter.in !== undefined) {
157
- if (Array.isArray(filter.in) && filter.in.length === 0) {
158
- return client_1.Prisma.sql `FALSE`;
159
- }
160
- return client_1.Prisma.sql `${fieldRef} IN (${client_1.Prisma.join(filter.in)})`;
161
- }
162
- if (filter.notIn !== undefined) {
163
- if (Array.isArray(filter.notIn) && filter.notIn.length === 0) {
164
- return client_1.Prisma.sql `TRUE`;
165
- }
166
- return client_1.Prisma.sql `${fieldRef} NOT IN (${client_1.Prisma.join(filter.notIn)})`;
167
- }
168
- if (filter.gt !== undefined) {
169
- return client_1.Prisma.sql `${fieldRef} > ${filter.gt}`;
170
- }
171
- if (filter.gte !== undefined) {
172
- return client_1.Prisma.sql `${fieldRef} >= ${filter.gte}`;
173
- }
174
- if (filter.lt !== undefined) {
175
- return client_1.Prisma.sql `${fieldRef} < ${filter.lt}`;
176
- }
177
- if (filter.lte !== undefined) {
178
- return client_1.Prisma.sql `${fieldRef} <= ${filter.lte}`;
179
- }
180
- if (filter.not !== undefined) {
181
- return client_1.Prisma.sql `${fieldRef} != ${filter.not}`;
182
- }
183
- if (filter.search !== undefined) {
184
- if (typeof filter.search !== 'string') {
185
- throw new Error('Full-text search term must be a string');
186
- }
187
- if (filter.search.length > 1000) {
188
- throw new Error('Full-text search term too long (max 1000 characters)');
189
- }
190
- return client_1.Prisma.sql `to_tsvector('simple', ${fieldRef}) @@ plainto_tsquery('simple', ${filter.search})`;
191
- }
192
- throw new Error(`Unsupported StringFilter: ${JSON.stringify(filter)}`);
193
- }
194
- processBoolField(field, condition) {
195
- const fieldRef = client_1.Prisma.raw(`r."${field}"`);
196
- if (typeof condition === 'boolean') {
197
- return client_1.Prisma.sql `${fieldRef} = ${condition}`;
198
- }
199
- const filter = condition;
200
- if (filter.equals !== undefined) {
201
- return client_1.Prisma.sql `${fieldRef} = ${filter.equals}`;
202
- }
203
- if (filter.not !== undefined) {
204
- return client_1.Prisma.sql `${fieldRef} != ${filter.not}`;
205
- }
206
- throw new Error(`Unsupported BoolFilter: ${JSON.stringify(filter)}`);
207
- }
208
- processDateField(field, condition) {
209
- const fieldRef = client_1.Prisma.raw(`r."${field}"`);
210
- if (typeof condition === 'string' || condition instanceof Date) {
211
- const dateStr = condition instanceof Date ? condition.toISOString() : condition;
212
- return client_1.Prisma.sql `${fieldRef} = ${dateStr}::timestamp`;
213
- }
214
- const filter = condition;
215
- const clauses = [];
216
- if (filter.equals !== undefined) {
217
- const dateStr = filter.equals instanceof Date
218
- ? filter.equals.toISOString()
219
- : filter.equals;
220
- return client_1.Prisma.sql `${fieldRef} = ${dateStr}::timestamp`;
221
- }
222
- if (filter.gt !== undefined) {
223
- const dateStr = filter.gt instanceof Date ? filter.gt.toISOString() : filter.gt;
224
- clauses.push(client_1.Prisma.sql `${fieldRef} > ${dateStr}::timestamp`);
225
- }
226
- if (filter.gte !== undefined) {
227
- const dateStr = filter.gte instanceof Date ? filter.gte.toISOString() : filter.gte;
228
- clauses.push(client_1.Prisma.sql `${fieldRef} >= ${dateStr}::timestamp`);
229
- }
230
- if (filter.lt !== undefined) {
231
- const dateStr = filter.lt instanceof Date ? filter.lt.toISOString() : filter.lt;
232
- clauses.push(client_1.Prisma.sql `${fieldRef} < ${dateStr}::timestamp`);
233
- }
234
- if (filter.lte !== undefined) {
235
- const dateStr = filter.lte instanceof Date ? filter.lte.toISOString() : filter.lte;
236
- clauses.push(client_1.Prisma.sql `${fieldRef} <= ${dateStr}::timestamp`);
237
- }
238
- if (clauses.length > 0) {
239
- return this.combineWithAnd(clauses);
240
- }
241
- if (filter.in !== undefined) {
242
- if (Array.isArray(filter.in) && filter.in.length === 0) {
243
- return client_1.Prisma.sql `FALSE`;
244
- }
245
- const dateStrs = filter.in.map((d) => d instanceof Date ? d.toISOString() : d);
246
- const castDates = dateStrs.map((d) => client_1.Prisma.sql `${d}::timestamp`);
247
- return client_1.Prisma.sql `${fieldRef} IN (${client_1.Prisma.join(castDates)})`;
248
- }
249
- if (filter.notIn !== undefined) {
250
- if (Array.isArray(filter.notIn) && filter.notIn.length === 0) {
251
- return client_1.Prisma.sql `TRUE`;
252
- }
253
- const dateStrs = filter.notIn.map((d) => d instanceof Date ? d.toISOString() : d);
254
- const castDates = dateStrs.map((d) => client_1.Prisma.sql `${d}::timestamp`);
255
- return client_1.Prisma.sql `${fieldRef} NOT IN (${client_1.Prisma.join(castDates)})`;
256
- }
257
- throw new Error(`Unsupported DateFilter: ${JSON.stringify(filter)}`);
258
- }
259
- processJsonField(field, condition) {
260
- const fieldRef = client_1.Prisma.raw(`r."${field}"`);
261
- const { path, mode = 'default' } = condition;
262
- const isInsensitive = mode === 'insensitive';
263
- const pathParam = path.length === 1 ? path[0] : `{${path.join(',')}}`;
264
- const jsonTextPath = path.length === 1
265
- ? client_1.Prisma.sql `${fieldRef}->>${pathParam}`
266
- : client_1.Prisma.sql `${fieldRef}#>>${pathParam}`;
267
- if (condition.equals !== undefined) {
268
- if (typeof condition.equals === 'string' && isInsensitive) {
269
- return client_1.Prisma.sql `LOWER(${jsonTextPath}) = LOWER(${condition.equals})`;
270
- }
271
- if (typeof condition.equals === 'string') {
272
- return client_1.Prisma.sql `${jsonTextPath} = ${condition.equals}`;
273
- }
274
- const jsonValue = JSON.stringify(condition.equals);
275
- return client_1.Prisma.sql `${jsonTextPath} = ${jsonValue}`;
276
- }
277
- if (condition.string_contains !== undefined) {
278
- const pattern = `%${condition.string_contains}%`;
279
- if (isInsensitive) {
280
- return client_1.Prisma.sql `${jsonTextPath} ILIKE ${pattern}`;
281
- }
282
- return client_1.Prisma.sql `${jsonTextPath} LIKE ${pattern}`;
283
- }
284
- if (condition.string_starts_with !== undefined) {
285
- const pattern = `${condition.string_starts_with}%`;
286
- if (isInsensitive) {
287
- return client_1.Prisma.sql `${jsonTextPath} ILIKE ${pattern}`;
288
- }
289
- return client_1.Prisma.sql `${jsonTextPath} LIKE ${pattern}`;
290
- }
291
- if (condition.string_ends_with !== undefined) {
292
- const pattern = `%${condition.string_ends_with}`;
293
- if (isInsensitive) {
294
- return client_1.Prisma.sql `${jsonTextPath} ILIKE ${pattern}`;
295
- }
296
- return client_1.Prisma.sql `${jsonTextPath} LIKE ${pattern}`;
297
- }
298
- if (condition.gt !== undefined) {
299
- return client_1.Prisma.sql `(${jsonTextPath})::numeric > ${condition.gt}`;
300
- }
301
- if (condition.gte !== undefined) {
302
- return client_1.Prisma.sql `(${jsonTextPath})::numeric >= ${condition.gte}`;
303
- }
304
- if (condition.lt !== undefined) {
305
- return client_1.Prisma.sql `(${jsonTextPath})::numeric < ${condition.lt}`;
306
- }
307
- if (condition.lte !== undefined) {
308
- return client_1.Prisma.sql `(${jsonTextPath})::numeric <= ${condition.lte}`;
309
- }
310
- if (condition.array_contains !== undefined) {
311
- const pathArray = path.map((p) => String(p));
312
- const arrayPath = client_1.Prisma.sql `ARRAY[${client_1.Prisma.join(pathArray)}]::text[]`;
313
- if (isInsensitive && typeof condition.array_contains === 'string') {
314
- return client_1.Prisma.sql `EXISTS (
315
- SELECT 1 FROM jsonb_array_elements_text((${fieldRef}#>${arrayPath})::jsonb) AS elem
316
- WHERE LOWER(elem) = LOWER(${condition.array_contains})
317
- ) AND JSONB_TYPEOF((${fieldRef}#>${arrayPath})::jsonb) = 'array'`;
318
- }
319
- const jsonValue = JSON.stringify(condition.array_contains);
320
- return client_1.Prisma.sql `(${fieldRef}#>${arrayPath})::jsonb @> ${jsonValue}::jsonb AND JSONB_TYPEOF((${fieldRef}#>${arrayPath})::jsonb) = 'array'`;
321
- }
322
- if (condition.array_starts_with !== undefined) {
323
- const pathArray = path.map((p) => String(p));
324
- const arrayPath = client_1.Prisma.sql `ARRAY[${client_1.Prisma.join(pathArray)}]::text[]`;
325
- const jsonValue = JSON.stringify(condition.array_starts_with);
326
- if (isInsensitive && typeof condition.array_starts_with === 'string') {
327
- const quotedValue = JSON.stringify(condition.array_starts_with);
328
- return client_1.Prisma.sql `LOWER(((${fieldRef}#>${arrayPath})::jsonb->0)::text) = LOWER(${quotedValue}) AND JSONB_TYPEOF((${fieldRef}#>${arrayPath})::jsonb) = 'array'`;
329
- }
330
- return client_1.Prisma.sql `((${fieldRef}#>${arrayPath})::jsonb->0)::jsonb = ${jsonValue}::jsonb AND JSONB_TYPEOF((${fieldRef}#>${arrayPath})::jsonb) = 'array'`;
331
- }
332
- if (condition.array_ends_with !== undefined) {
333
- const pathArray = path.map((p) => String(p));
334
- const arrayPath = client_1.Prisma.sql `ARRAY[${client_1.Prisma.join(pathArray)}]::text[]`;
335
- const jsonValue = JSON.stringify(condition.array_ends_with);
336
- if (isInsensitive && typeof condition.array_ends_with === 'string') {
337
- const quotedValue = JSON.stringify(condition.array_ends_with);
338
- return client_1.Prisma.sql `LOWER(((${fieldRef}#>${arrayPath})::jsonb->-1)::text) = LOWER(${quotedValue}) AND JSONB_TYPEOF((${fieldRef}#>${arrayPath})::jsonb) = 'array'`;
339
- }
340
- return client_1.Prisma.sql `((${fieldRef}#>${arrayPath})::jsonb->-1)::jsonb = ${jsonValue}::jsonb AND JSONB_TYPEOF((${fieldRef}#>${arrayPath})::jsonb) = 'array'`;
341
- }
342
- if (condition.in !== undefined) {
343
- if (Array.isArray(condition.in) && condition.in.length === 0) {
344
- return client_1.Prisma.sql `FALSE`;
345
- }
346
- const values = condition.in.map((val) => typeof val === 'string' ? val : JSON.stringify(val));
347
- return client_1.Prisma.sql `${jsonTextPath} IN (${client_1.Prisma.join(values)})`;
348
- }
349
- if (condition.notIn !== undefined) {
350
- if (Array.isArray(condition.notIn) && condition.notIn.length === 0) {
351
- return client_1.Prisma.sql `TRUE`;
352
- }
353
- const values = condition.notIn.map((val) => typeof val === 'string' ? val : JSON.stringify(val));
354
- return client_1.Prisma.sql `${jsonTextPath} NOT IN (${client_1.Prisma.join(values)})`;
355
- }
356
- if (condition.not !== undefined) {
357
- if (typeof condition.not === 'string') {
358
- return client_1.Prisma.sql `${jsonTextPath} != ${condition.not}`;
359
- }
360
- const jsonValue = JSON.stringify(condition.not);
361
- return client_1.Prisma.sql `${jsonTextPath} != ${jsonValue}`;
362
- }
363
- throw new Error(`Unsupported JsonFilter: ${JSON.stringify(condition)}`);
364
- }
365
- getFieldReference(fieldName) {
366
- if (!WhereGeneratorPrisma.VALID_ORDER_FIELDS.has(fieldName)) {
367
- throw new Error(`Invalid ORDER BY field: ${fieldName}. Allowed fields: ${Array.from(WhereGeneratorPrisma.VALID_ORDER_FIELDS).join(', ')}`);
368
- }
369
- return client_1.Prisma.raw(`r."${fieldName}"`);
370
- }
371
- combineOrderBy(clauses) {
372
- if (clauses.length === 0) {
373
- return client_1.Prisma.sql `r."createdAt" DESC`;
374
- }
375
- if (clauses.length === 1) {
376
- return clauses[0];
377
- }
378
- let result = clauses[0];
379
- for (let i = 1; i < clauses.length; i++) {
380
- result = client_1.Prisma.sql `${result}, ${clauses[i]}`;
381
- }
382
- return result;
383
- }
384
- generateJsonOrderBy(field, jsonOrder) {
385
- const { path, direction = 'asc', type = 'text', aggregation = 'first', } = jsonOrder;
386
- const fieldRef = client_1.Prisma.raw(`r."${field}"`);
387
- const sortOrder = client_1.Prisma.raw(direction.toUpperCase());
388
- const pgPath = typeof path === 'string' ? (0, json_path_1.parseJsonPath)(path) : path;
389
- (0, json_path_1.validateJsonPath)(pgPath);
390
- if ((0, json_path_1.hasArrayWildcard)(path) || aggregation !== 'first') {
391
- return this.generateArrayAggregationOrder(fieldRef, pgPath, type, aggregation, sortOrder);
392
- }
393
- const pathParam = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(pgPath)}'`);
394
- const sqlType = (0, json_path_1.getSqlType)(type);
395
- return client_1.Prisma.sql `(${fieldRef}#>>${pathParam})::${client_1.Prisma.raw(sqlType)} ${sortOrder}`;
396
- }
397
- generateArrayAggregationOrder(fieldRef, pgPath, type, aggregation, sortOrder) {
398
- const sqlType = (0, json_path_1.getSqlType)(type);
399
- const { beforeStar, afterStar, starIndex } = (0, json_path_1.splitPathAtWildcard)(pgPath);
400
- if (starIndex === -1) {
401
- const modifiedPath = (0, json_path_1.handleArrayAggregation)(pgPath, aggregation);
402
- const pathParam = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(modifiedPath)}'`);
403
- return client_1.Prisma.sql `(${fieldRef}#>>${pathParam})::${client_1.Prisma.raw(sqlType)} ${sortOrder}`;
404
- }
405
- const arrayPath = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(beforeStar)}'`);
406
- switch (aggregation) {
407
- case 'min':
408
- if (afterStar.length > 0) {
409
- const subPath = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(afterStar)}'`);
410
- return client_1.Prisma.sql `(SELECT MIN((value#>>${subPath})::${client_1.Prisma.raw(sqlType)}) FROM jsonb_array_elements(${fieldRef}#>${arrayPath}) AS value) ${sortOrder}`;
411
- }
412
- else {
413
- return client_1.Prisma.sql `(SELECT MIN(value::${client_1.Prisma.raw(sqlType)}) FROM jsonb_array_elements_text(${fieldRef}#>${arrayPath}) AS value) ${sortOrder}`;
414
- }
415
- case 'max':
416
- if (afterStar.length > 0) {
417
- const subPath = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(afterStar)}'`);
418
- return client_1.Prisma.sql `(SELECT MAX((value#>>${subPath})::${client_1.Prisma.raw(sqlType)}) FROM jsonb_array_elements(${fieldRef}#>${arrayPath}) AS value) ${sortOrder}`;
419
- }
420
- else {
421
- return client_1.Prisma.sql `(SELECT MAX(value::${client_1.Prisma.raw(sqlType)}) FROM jsonb_array_elements_text(${fieldRef}#>${arrayPath}) AS value) ${sortOrder}`;
422
- }
423
- case 'avg':
424
- if (afterStar.length > 0) {
425
- const subPath = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(afterStar)}'`);
426
- return client_1.Prisma.sql `(SELECT AVG((value#>>${subPath})::${client_1.Prisma.raw(sqlType)}) FROM jsonb_array_elements(${fieldRef}#>${arrayPath}) AS value) ${sortOrder}`;
427
- }
428
- else {
429
- return client_1.Prisma.sql `(SELECT AVG(value::${client_1.Prisma.raw(sqlType)}) FROM jsonb_array_elements_text(${fieldRef}#>${arrayPath}) AS value) ${sortOrder}`;
430
- }
431
- case 'last': {
432
- const lastPath = [...beforeStar, '-1', ...afterStar];
433
- const pathParam = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(lastPath)}'`);
434
- return client_1.Prisma.sql `(${fieldRef}#>>${pathParam})::${client_1.Prisma.raw(sqlType)} ${sortOrder}`;
435
- }
436
- case 'first':
437
- default: {
438
- const firstPath = [...beforeStar, '0', ...afterStar];
439
- const pathParam = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(firstPath)}'`);
440
- return client_1.Prisma.sql `(${fieldRef}#>>${pathParam})::${client_1.Prisma.raw(sqlType)} ${sortOrder}`;
441
- }
442
- }
443
- }
444
- generateGetRowsQueryPrisma(tableId, options = {}) {
445
- const takeNum = Number(options.take ?? 50);
446
- const take = Math.max(1, Math.min(500, isNaN(takeNum) ? 50 : takeNum));
447
- const skipNum = Number(options.skip ?? 0);
448
- const skip = Math.max(0, isNaN(skipNum) ? 0 : skipNum);
449
- const orderByArray = Array.isArray(options.orderBy)
450
- ? options.orderBy
451
- : options.orderBy
452
- ? [options.orderBy]
453
- : [];
454
- const whereSql = this.generateWhere(options.where || {});
455
- const orderSql = this.generateOrderBy(orderByArray);
456
- return client_1.Prisma.sql `
457
- SELECT
458
- r."versionId",
459
- r."createdId",
460
- r."id",
461
- r."readonly",
462
- r."createdAt",
463
- r."updatedAt",
464
- r."publishedAt",
465
- r."data",
466
- r."meta",
467
- r."hash",
468
- r."schemaHash"
469
- FROM "Row" r
470
- INNER JOIN "_RowToTable" rt ON rt."A" = r."versionId"
471
- WHERE rt."B" = ${tableId}
472
- AND ${whereSql}
473
- ORDER BY ${orderSql}
474
- LIMIT ${take}
475
- OFFSET ${skip}
476
- `;
477
- }
478
- generateGetRowsQuery(tableId, take, skip, whereConditions, orderBy) {
479
- return this.generateGetRowsQueryPrisma(tableId, {
480
- take,
481
- skip,
482
- where: whereConditions,
483
- orderBy,
484
- });
485
- }
486
- }
487
- exports.WhereGeneratorPrisma = WhereGeneratorPrisma;
488
- WhereGeneratorPrisma.VALID_ORDER_FIELDS = new Set([
489
- 'versionId',
490
- 'createdId',
491
- 'id',
492
- 'hash',
493
- 'schemaHash',
494
- 'readonly',
495
- 'createdAt',
496
- 'updatedAt',
497
- 'publishedAt',
498
- 'data',
499
- 'meta',
500
- ]);
501
- function generateGetRowsQueryPrisma(tableId, take, skip, whereConditions, orderBy) {
502
- const generator = new WhereGeneratorPrisma();
503
- const whereClause = generator.generateWhere(whereConditions || {});
504
- const orderByClause = generator.generateOrderBy(orderBy || []);
505
- return client_1.Prisma.sql `
506
- SELECT
507
- r."versionId",
508
- r."createdId",
509
- r."id",
510
- r."readonly",
511
- r."createdAt",
512
- r."updatedAt",
513
- r."publishedAt",
514
- r."data",
515
- r."meta",
516
- r."hash",
517
- r."schemaHash"
518
- FROM "Row" r
519
- INNER JOIN "_RowToTable" rt ON r."versionId" = rt."A"
520
- WHERE rt."B" = ${tableId}
521
- AND (${whereClause})
522
- ORDER BY ${orderByClause}
523
- LIMIT ${take}
524
- OFFSET ${skip}
525
- `;
526
- }
527
- //# sourceMappingURL=where-generator.prisma.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"where-generator.prisma.js","sourceRoot":"","sources":["../../../../src/utils/prisma-sql-generator/where-generator.prisma.ts"],"names":[],"mappings":";;;AA0vBA,gEAiCC;AA3xBD,2CAAwC;AAUxC,2CAQqB;AAMrB,MAAa,oBAAoB;IAK/B,aAAa,CAAC,UAA4B;QACxC,IAAI,CAAC,UAAU,IAAI,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACxD,OAAO,eAAM,CAAC,GAAG,CAAA,MAAM,CAAC;QAC1B,CAAC;QAED,OAAO,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;IAC5C,CAAC;IAKO,iBAAiB,CAAC,UAA2B;QACnD,MAAM,OAAO,GAAiB,EAAE,CAAC;QAEjC,IAAI,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,UAAU,CAAC,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC/D,MAAM,UAAU,GAAG,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAC7C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAC7B,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,GAAG,KAAK,MAAM,CAAC,CAAC;YAC5C,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC1B,OAAO,CAAC,IAAI,CAAC,eAAM,CAAC,GAAG,CAAA,IAAI,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;YACjE,CAAC;QACH,CAAC;QAED,IAAI,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,CAAC,IAAI,UAAU,CAAC,EAAE,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC7D,MAAM,SAAS,GAAG,UAAU,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAC3C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAC7B,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,GAAG,KAAK,MAAM,CAAC,CAAC;YAC5C,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACzB,OAAO,CAAC,IAAI,CAAC,eAAM,CAAC,GAAG,CAAA,IAAI,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;YAC/D,CAAC;QACH,CAAC;QAED,IAAI,UAAU,CAAC,GAAG,EAAE,CAAC;YACnB,MAAM,SAAS,GAAG,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;YACzD,OAAO,CAAC,IAAI,CAAC,eAAM,CAAC,GAAG,CAAA,QAAQ,SAAS,GAAG,CAAC,CAAC;QAC/C,CAAC;QAED,IAAI,UAAU,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;YACvC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,WAAW,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC;QAC3E,CAAC;QACD,IAAI,UAAU,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;YACvC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,WAAW,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC;QAC3E,CAAC;QACD,IAAI,UAAU,CAAC,EAAE,KAAK,SAAS,EAAE,CAAC;YAChC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC;QAC7D,CAAC;QACD,IAAI,UAAU,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YAClC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;QACjE,CAAC;QACD,IAAI,UAAU,CAAC,UAAU,KAAK,SAAS,EAAE,CAAC;YACxC,OAAO,CAAC,IAAI,CACV,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,UAAU,CAAC,UAAU,CAAC,CAC7D,CAAC;QACJ,CAAC;QAED,IAAI,UAAU,CAAC,QAAQ,KAAK,SAAS,EAAE,CAAC;YACtC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,UAAU,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC;QACvE,CAAC;QAED,IAAI,UAAU,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;YACvC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC;QACzE,CAAC;QACD,IAAI,UAAU,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;YACvC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC;QACzE,CAAC;QACD,IAAI,UAAU,CAAC,WAAW,KAAK,SAAS,EAAE,CAAC;YACzC,OAAO,CAAC,IAAI,CACV,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,UAAU,CAAC,WAAW,CAAC,CAC7D,CAAC;QACJ,CAAC;QAED,IAAI,UAAU,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YAClC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;QAC/D,CAAC;QACD,IAAI,UAAU,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YAClC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;QAC/D,CAAC;QAED,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzB,OAAO,eAAM,CAAC,GAAG,CAAA,MAAM,CAAC;QAC1B,CAAC;QAED,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzB,OAAO,OAAO,CAAC,CAAC,CAAC,CAAC;QACpB,CAAC;QAGD,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;IACtC,CAAC;IAKO,cAAc,CAAC,OAAqB;QAC1C,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzB,OAAO,eAAM,CAAC,GAAG,CAAA,MAAM,CAAC;QAC1B,CAAC;QAED,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzB,OAAO,OAAO,CAAC,CAAC,CAAC,CAAC;QACpB,CAAC;QAGD,IAAI,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;QACxB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACxC,MAAM,GAAG,eAAM,CAAC,GAAG,CAAA,GAAG,MAAM,QAAQ,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC;QACnD,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAKO,aAAa,CAAC,OAAqB;QACzC,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzB,OAAO,eAAM,CAAC,GAAG,CAAA,OAAO,CAAC;QAC3B,CAAC;QAED,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzB,OAAO,OAAO,CAAC,CAAC,CAAC,CAAC;QACpB,CAAC;QAGD,IAAI,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;QACxB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACxC,MAAM,GAAG,eAAM,CAAC,GAAG,CAAA,GAAG,MAAM,OAAO,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC;QAClD,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAKD,eAAe,CAAC,OAAe;QAC7B,IAAI,CAAC,OAAO,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACrC,OAAO,eAAM,CAAC,GAAG,CAAA,oBAAoB,CAAC;QACxC,CAAC;QAED,MAAM,YAAY,GAAiB,EAAE,CAAC;QAEtC,KAAK,MAAM,SAAS,IAAI,OAAO,EAAE,CAAC;YAChC,KAAK,MAAM,CAAC,KAAK,EAAE,SAAS,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC;gBAC3D,IAAI,OAAO,SAAS,KAAK,QAAQ,EAAE,CAAC;oBAClC,MAAM,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;oBAC/C,MAAM,SAAS,GAAG,eAAM,CAAC,GAAG,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC,CAAC;oBACtD,YAAY,CAAC,IAAI,CAAC,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,IAAI,SAAS,EAAE,CAAC,CAAC;gBAC1D,CAAC;qBAAM,IAAI,OAAO,SAAS,KAAK,QAAQ,IAAI,SAAS,KAAK,IAAI,EAAE,CAAC;oBAC/D,MAAM,eAAe,GAAG,IAAI,CAAC,mBAAmB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;oBACnE,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;gBACrC,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO,YAAY,CAAC,MAAM,GAAG,CAAC;YAC5B,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC;YACnC,CAAC,CAAC,eAAM,CAAC,GAAG,CAAA,oBAAoB,CAAC;IACrC,CAAC;IAKO,kBAAkB,CACxB,KAAa,EACb,SAAgC;QAEhC,MAAM,QAAQ,GAAG,eAAM,CAAC,GAAG,CAAC,MAAM,KAAK,GAAG,CAAC,CAAC;QAE5C,IAAI,OAAO,SAAS,KAAK,QAAQ,EAAE,CAAC;YAElC,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,MAAM,SAAS,EAAE,CAAC;QAChD,CAAC;QAGD,MAAM,MAAM,GAAG,SAAyB,CAAC;QACzC,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,IAAI,SAAS,CAAC;QACtC,MAAM,aAAa,GAAG,IAAI,KAAK,aAAa,CAAC;QAE7C,IAAI,MAAM,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAChC,IAAI,aAAa,EAAE,CAAC;gBAClB,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,UAAU,MAAM,CAAC,MAAM,EAAE,CAAC;YACxD,CAAC;YACD,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,MAAM,MAAM,CAAC,MAAM,EAAE,CAAC;QACpD,CAAC;QAED,IAAI,MAAM,CAAC,QAAQ,KAAK,SAAS,EAAE,CAAC;YAClC,MAAM,OAAO,GAAG,IAAI,MAAM,CAAC,QAAQ,GAAG,CAAC;YACvC,IAAI,aAAa,EAAE,CAAC;gBAClB,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,UAAU,OAAO,EAAE,CAAC;YAClD,CAAC;YACD,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,SAAS,OAAO,EAAE,CAAC;QACjD,CAAC;QAED,IAAI,MAAM,CAAC,UAAU,KAAK,SAAS,EAAE,CAAC;YACpC,MAAM,OAAO,GAAG,GAAG,MAAM,CAAC,UAAU,GAAG,CAAC;YACxC,IAAI,aAAa,EAAE,CAAC;gBAClB,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,UAAU,OAAO,EAAE,CAAC;YAClD,CAAC;YACD,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,SAAS,OAAO,EAAE,CAAC;QACjD,CAAC;QAED,IAAI,MAAM,CAAC,QAAQ,KAAK,SAAS,EAAE,CAAC;YAClC,MAAM,OAAO,GAAG,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;YACtC,IAAI,aAAa,EAAE,CAAC;gBAClB,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,UAAU,OAAO,EAAE,CAAC;YAClD,CAAC;YACD,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,SAAS,OAAO,EAAE,CAAC;QACjD,CAAC;QAED,IAAI,MAAM,CAAC,EAAE,KAAK,SAAS,EAAE,CAAC;YAC5B,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,MAAM,CAAC,EAAE,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACvD,OAAO,eAAM,CAAC,GAAG,CAAA,OAAO,CAAC;YAC3B,CAAC;YACD,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,QAAQ,eAAM,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC;QAChE,CAAC;QAED,IAAI,MAAM,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YAC/B,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC7D,OAAO,eAAM,CAAC,GAAG,CAAA,MAAM,CAAC;YAC1B,CAAC;YACD,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,YAAY,eAAM,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC;QACvE,CAAC;QAED,IAAI,MAAM,CAAC,EAAE,KAAK,SAAS,EAAE,CAAC;YAC5B,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,MAAM,MAAM,CAAC,EAAE,EAAE,CAAC;QAChD,CAAC;QAED,IAAI,MAAM,CAAC,GAAG,KAAK,SAAS,EAAE,CAAC;YAC7B,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,OAAO,MAAM,CAAC,GAAG,EAAE,CAAC;QAClD,CAAC;QAED,IAAI,MAAM,CAAC,EAAE,KAAK,SAAS,EAAE,CAAC;YAC5B,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,MAAM,MAAM,CAAC,EAAE,EAAE,CAAC;QAChD,CAAC;QAED,IAAI,MAAM,CAAC,GAAG,KAAK,SAAS,EAAE,CAAC;YAC7B,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,OAAO,MAAM,CAAC,GAAG,EAAE,CAAC;QAClD,CAAC;QAED,IAAI,MAAM,CAAC,GAAG,KAAK,SAAS,EAAE,CAAC;YAC7B,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,OAAO,MAAM,CAAC,GAAG,EAAE,CAAC;QAClD,CAAC;QAED,IAAI,MAAM,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAEhC,IAAI,OAAO,MAAM,CAAC,MAAM,KAAK,QAAQ,EAAE,CAAC;gBACtC,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;YAC5D,CAAC;YACD,IAAI,MAAM,CAAC,MAAM,CAAC,MAAM,GAAG,IAAI,EAAE,CAAC;gBAChC,MAAM,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAC;YAC1E,CAAC;YAED,OAAO,eAAM,CAAC,GAAG,CAAA,yBAAyB,QAAQ,kCAAkC,MAAM,CAAC,MAAM,GAAG,CAAC;QACvG,CAAC;QAED,MAAM,IAAI,KAAK,CAAC,6BAA6B,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IACzE,CAAC;IAKO,gBAAgB,CACtB,KAAa,EACb,SAA+B;QAE/B,MAAM,QAAQ,GAAG,eAAM,CAAC,GAAG,CAAC,MAAM,KAAK,GAAG,CAAC,CAAC;QAE5C,IAAI,OAAO,SAAS,KAAK,SAAS,EAAE,CAAC;YACnC,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,MAAM,SAAS,EAAE,CAAC;QAChD,CAAC;QAED,MAAM,MAAM,GAAG,SAAuB,CAAC;QACvC,IAAI,MAAM,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAChC,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,MAAM,MAAM,CAAC,MAAM,EAAE,CAAC;QACpD,CAAC;QAED,IAAI,MAAM,CAAC,GAAG,KAAK,SAAS,EAAE,CAAC;YAC7B,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,OAAO,MAAM,CAAC,GAAG,EAAE,CAAC;QAClD,CAAC;QAED,MAAM,IAAI,KAAK,CAAC,2BAA2B,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IACvE,CAAC;IAKO,gBAAgB,CACtB,KAAa,EACb,SAAqC;QAErC,MAAM,QAAQ,GAAG,eAAM,CAAC,GAAG,CAAC,MAAM,KAAK,GAAG,CAAC,CAAC;QAE5C,IAAI,OAAO,SAAS,KAAK,QAAQ,IAAI,SAAS,YAAY,IAAI,EAAE,CAAC;YAC/D,MAAM,OAAO,GACX,SAAS,YAAY,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;YAClE,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,MAAM,OAAO,aAAa,CAAC;QACzD,CAAC;QAED,MAAM,MAAM,GAAG,SAAuB,CAAC;QACvC,MAAM,OAAO,GAAiB,EAAE,CAAC;QAEjC,IAAI,MAAM,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAChC,MAAM,OAAO,GACX,MAAM,CAAC,MAAM,YAAY,IAAI;gBAC3B,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,EAAE;gBAC7B,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC;YACpB,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,MAAM,OAAO,aAAa,CAAC;QACzD,CAAC;QAED,IAAI,MAAM,CAAC,EAAE,KAAK,SAAS,EAAE,CAAC;YAC5B,MAAM,OAAO,GACX,MAAM,CAAC,EAAE,YAAY,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC;YAClE,OAAO,CAAC,IAAI,CAAC,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,MAAM,OAAO,aAAa,CAAC,CAAC;QAChE,CAAC;QAED,IAAI,MAAM,CAAC,GAAG,KAAK,SAAS,EAAE,CAAC;YAC7B,MAAM,OAAO,GACX,MAAM,CAAC,GAAG,YAAY,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC;YACrE,OAAO,CAAC,IAAI,CAAC,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,OAAO,OAAO,aAAa,CAAC,CAAC;QACjE,CAAC;QAED,IAAI,MAAM,CAAC,EAAE,KAAK,SAAS,EAAE,CAAC;YAC5B,MAAM,OAAO,GACX,MAAM,CAAC,EAAE,YAAY,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC;YAClE,OAAO,CAAC,IAAI,CAAC,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,MAAM,OAAO,aAAa,CAAC,CAAC;QAChE,CAAC;QAED,IAAI,MAAM,CAAC,GAAG,KAAK,SAAS,EAAE,CAAC;YAC7B,MAAM,OAAO,GACX,MAAM,CAAC,GAAG,YAAY,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC;YACrE,OAAO,CAAC,IAAI,CAAC,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,OAAO,OAAO,aAAa,CAAC,CAAC;QACjE,CAAC;QAGD,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACvB,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;QACtC,CAAC;QAED,IAAI,MAAM,CAAC,EAAE,KAAK,SAAS,EAAE,CAAC;YAC5B,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,MAAM,CAAC,EAAE,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACvD,OAAO,eAAM,CAAC,GAAG,CAAA,OAAO,CAAC;YAC3B,CAAC;YACD,MAAM,QAAQ,GAAG,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CACnC,CAAC,YAAY,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC,CACxC,CAAC;YACF,MAAM,SAAS,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,eAAM,CAAC,GAAG,CAAA,GAAG,CAAC,aAAa,CAAC,CAAC;YACnE,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,QAAQ,eAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC;QAChE,CAAC;QAED,IAAI,MAAM,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YAC/B,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC7D,OAAO,eAAM,CAAC,GAAG,CAAA,MAAM,CAAC;YAC1B,CAAC;YACD,MAAM,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CACtC,CAAC,YAAY,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC,CACxC,CAAC;YACF,MAAM,SAAS,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,eAAM,CAAC,GAAG,CAAA,GAAG,CAAC,aAAa,CAAC,CAAC;YACnE,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,YAAY,eAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC;QACpE,CAAC;QAED,MAAM,IAAI,KAAK,CAAC,2BAA2B,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IACvE,CAAC;IAKO,gBAAgB,CAAC,KAAa,EAAE,SAAqB;QAC3D,MAAM,QAAQ,GAAG,eAAM,CAAC,GAAG,CAAC,MAAM,KAAK,GAAG,CAAC,CAAC;QAC5C,MAAM,EAAE,IAAI,EAAE,IAAI,GAAG,SAAS,EAAE,GAAG,SAAS,CAAC;QAC7C,MAAM,aAAa,GAAG,IAAI,KAAK,aAAa,CAAC;QAI7C,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC;QACtE,MAAM,YAAY,GAChB,IAAI,CAAC,MAAM,KAAK,CAAC;YACf,CAAC,CAAC,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,MAAM,SAAS,EAAE;YACxC,CAAC,CAAC,eAAM,CAAC,GAAG,CAAA,GAAG,QAAQ,MAAM,SAAS,EAAE,CAAC;QAE7C,IAAI,SAAS,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YACnC,IAAI,OAAO,SAAS,CAAC,MAAM,KAAK,QAAQ,IAAI,aAAa,EAAE,CAAC;gBAC1D,OAAO,eAAM,CAAC,GAAG,CAAA,SAAS,YAAY,aAAa,SAAS,CAAC,MAAM,GAAG,CAAC;YACzE,CAAC;YAED,IAAI,OAAO,SAAS,CAAC,MAAM,KAAK,QAAQ,EAAE,CAAC;gBACzC,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,YAAY,MAAM,SAAS,CAAC,MAAM,EAAE,CAAC;YAC3D,CAAC;YAED,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;YACnD,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,YAAY,MAAM,SAAS,EAAE,CAAC;QACpD,CAAC;QAED,IAAI,SAAS,CAAC,eAAe,KAAK,SAAS,EAAE,CAAC;YAC5C,MAAM,OAAO,GAAG,IAAI,SAAS,CAAC,eAAe,GAAG,CAAC;YACjD,IAAI,aAAa,EAAE,CAAC;gBAClB,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,YAAY,UAAU,OAAO,EAAE,CAAC;YACtD,CAAC;YACD,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,YAAY,SAAS,OAAO,EAAE,CAAC;QACrD,CAAC;QAED,IAAI,SAAS,CAAC,kBAAkB,KAAK,SAAS,EAAE,CAAC;YAC/C,MAAM,OAAO,GAAG,GAAG,SAAS,CAAC,kBAAkB,GAAG,CAAC;YACnD,IAAI,aAAa,EAAE,CAAC;gBAClB,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,YAAY,UAAU,OAAO,EAAE,CAAC;YACtD,CAAC;YACD,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,YAAY,SAAS,OAAO,EAAE,CAAC;QACrD,CAAC;QAED,IAAI,SAAS,CAAC,gBAAgB,KAAK,SAAS,EAAE,CAAC;YAC7C,MAAM,OAAO,GAAG,IAAI,SAAS,CAAC,gBAAgB,EAAE,CAAC;YACjD,IAAI,aAAa,EAAE,CAAC;gBAClB,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,YAAY,UAAU,OAAO,EAAE,CAAC;YACtD,CAAC;YACD,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,YAAY,SAAS,OAAO,EAAE,CAAC;QACrD,CAAC;QAED,IAAI,SAAS,CAAC,EAAE,KAAK,SAAS,EAAE,CAAC;YAC/B,OAAO,eAAM,CAAC,GAAG,CAAA,IAAI,YAAY,gBAAgB,SAAS,CAAC,EAAE,EAAE,CAAC;QAClE,CAAC;QAED,IAAI,SAAS,CAAC,GAAG,KAAK,SAAS,EAAE,CAAC;YAChC,OAAO,eAAM,CAAC,GAAG,CAAA,IAAI,YAAY,iBAAiB,SAAS,CAAC,GAAG,EAAE,CAAC;QACpE,CAAC;QAED,IAAI,SAAS,CAAC,EAAE,KAAK,SAAS,EAAE,CAAC;YAC/B,OAAO,eAAM,CAAC,GAAG,CAAA,IAAI,YAAY,gBAAgB,SAAS,CAAC,EAAE,EAAE,CAAC;QAClE,CAAC;QAED,IAAI,SAAS,CAAC,GAAG,KAAK,SAAS,EAAE,CAAC;YAChC,OAAO,eAAM,CAAC,GAAG,CAAA,IAAI,YAAY,iBAAiB,SAAS,CAAC,GAAG,EAAE,CAAC;QACpE,CAAC;QAED,IAAI,SAAS,CAAC,cAAc,KAAK,SAAS,EAAE,CAAC;YAG3C,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;YAC7C,MAAM,SAAS,GAAG,eAAM,CAAC,GAAG,CAAA,SAAS,eAAM,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC;YAEvE,IAAI,aAAa,IAAI,OAAO,SAAS,CAAC,cAAc,KAAK,QAAQ,EAAE,CAAC;gBAElE,OAAO,eAAM,CAAC,GAAG,CAAA;qDAC4B,QAAQ,KAAK,SAAS;sCACrC,SAAS,CAAC,cAAc;8BAChC,QAAQ,KAAK,SAAS,qBAAqB,CAAC;YACpE,CAAC;YAGD,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;YAC3D,OAAO,eAAM,CAAC,GAAG,CAAA,IAAI,QAAQ,KAAK,SAAS,eAAe,SAAS,6BAA6B,QAAQ,KAAK,SAAS,qBAAqB,CAAC;QAC9I,CAAC;QAED,IAAI,SAAS,CAAC,iBAAiB,KAAK,SAAS,EAAE,CAAC;YAE9C,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;YAC7C,MAAM,SAAS,GAAG,eAAM,CAAC,GAAG,CAAA,SAAS,eAAM,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC;YACvE,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,iBAAiB,CAAC,CAAC;YAE9D,IAAI,aAAa,IAAI,OAAO,SAAS,CAAC,iBAAiB,KAAK,QAAQ,EAAE,CAAC;gBAGrE,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,iBAAiB,CAAC,CAAC;gBAChE,OAAO,eAAM,CAAC,GAAG,CAAA,WAAW,QAAQ,KAAK,SAAS,+BAA+B,WAAW,uBAAuB,QAAQ,KAAK,SAAS,qBAAqB,CAAC;YACjK,CAAC;YAED,OAAO,eAAM,CAAC,GAAG,CAAA,KAAK,QAAQ,KAAK,SAAS,yBAAyB,SAAS,6BAA6B,QAAQ,KAAK,SAAS,qBAAqB,CAAC;QACzJ,CAAC;QAED,IAAI,SAAS,CAAC,eAAe,KAAK,SAAS,EAAE,CAAC;YAE5C,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;YAC7C,MAAM,SAAS,GAAG,eAAM,CAAC,GAAG,CAAA,SAAS,eAAM,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC;YACvE,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC;YAE5D,IAAI,aAAa,IAAI,OAAO,SAAS,CAAC,eAAe,KAAK,QAAQ,EAAE,CAAC;gBAGnE,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC;gBAC9D,OAAO,eAAM,CAAC,GAAG,CAAA,WAAW,QAAQ,KAAK,SAAS,gCAAgC,WAAW,uBAAuB,QAAQ,KAAK,SAAS,qBAAqB,CAAC;YAClK,CAAC;YAED,OAAO,eAAM,CAAC,GAAG,CAAA,KAAK,QAAQ,KAAK,SAAS,0BAA0B,SAAS,6BAA6B,QAAQ,KAAK,SAAS,qBAAqB,CAAC;QAC1J,CAAC;QAED,IAAI,SAAS,CAAC,EAAE,KAAK,SAAS,EAAE,CAAC;YAC/B,IAAI,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC,IAAI,SAAS,CAAC,EAAE,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC7D,OAAO,eAAM,CAAC,GAAG,CAAA,OAAO,CAAC;YAC3B,CAAC;YACD,MAAM,MAAM,GAAG,SAAS,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CACtC,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CACpD,CAAC;YACF,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,YAAY,QAAQ,eAAM,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC;QACjE,CAAC;QAED,IAAI,SAAS,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YAClC,IAAI,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,SAAS,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACnE,OAAO,eAAM,CAAC,GAAG,CAAA,MAAM,CAAC;YAC1B,CAAC;YACD,MAAM,MAAM,GAAG,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CACzC,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CACpD,CAAC;YACF,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,YAAY,YAAY,eAAM,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC;QACrE,CAAC;QAED,IAAI,SAAS,CAAC,GAAG,KAAK,SAAS,EAAE,CAAC;YAChC,IAAI,OAAO,SAAS,CAAC,GAAG,KAAK,QAAQ,EAAE,CAAC;gBACtC,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,YAAY,OAAO,SAAS,CAAC,GAAG,EAAE,CAAC;YACzD,CAAC;YACD,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;YAChD,OAAO,eAAM,CAAC,GAAG,CAAA,GAAG,YAAY,OAAO,SAAS,EAAE,CAAC;QACrD,CAAC;QAED,MAAM,IAAI,KAAK,CAAC,2BAA2B,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;IAC1E,CAAC;IAsBO,iBAAiB,CAAC,SAAiB;QACzC,IAAI,CAAC,oBAAoB,CAAC,kBAAkB,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC;YAC5D,MAAM,IAAI,KAAK,CACb,2BAA2B,SAAS,qBAAqB,KAAK,CAAC,IAAI,CAAC,oBAAoB,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAC1H,CAAC;QACJ,CAAC;QACD,OAAO,eAAM,CAAC,GAAG,CAAC,MAAM,SAAS,GAAG,CAAC,CAAC;IACxC,CAAC;IAKO,cAAc,CAAC,OAAqB;QAC1C,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzB,OAAO,eAAM,CAAC,GAAG,CAAA,oBAAoB,CAAC;QACxC,CAAC;QAED,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzB,OAAO,OAAO,CAAC,CAAC,CAAC,CAAC;QACpB,CAAC;QAGD,IAAI,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;QACxB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACxC,MAAM,GAAG,eAAM,CAAC,GAAG,CAAA,GAAG,MAAM,KAAK,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC;QAChD,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAKO,mBAAmB,CAAC,KAAa,EAAE,SAAc;QACvD,MAAM,EACJ,IAAI,EACJ,SAAS,GAAG,KAAK,EACjB,IAAI,GAAG,MAAM,EACb,WAAW,GAAG,OAAO,GACtB,GAAG,SAAS,CAAC;QACd,MAAM,QAAQ,GAAG,eAAM,CAAC,GAAG,CAAC,MAAM,KAAK,GAAG,CAAC,CAAC;QAC5C,MAAM,SAAS,GAAG,eAAM,CAAC,GAAG,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC,CAAC;QAGtD,MAAM,MAAM,GAAG,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAA,yBAAa,EAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QACrE,IAAA,4BAAgB,EAAC,MAAM,CAAC,CAAC;QAGzB,IAAI,IAAA,4BAAgB,EAAC,IAAI,CAAC,IAAI,WAAW,KAAK,OAAO,EAAE,CAAC;YACtD,OAAO,IAAI,CAAC,6BAA6B,CACvC,QAAQ,EACR,MAAM,EACN,IAAI,EACJ,WAAW,EACX,SAAS,CACV,CAAC;QACJ,CAAC;QAGD,MAAM,SAAS,GAAG,eAAM,CAAC,GAAG,CAAC,IAAI,IAAA,8BAAkB,EAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAChE,MAAM,OAAO,GAAG,IAAA,sBAAU,EAAC,IAAI,CAAC,CAAC;QAEjC,OAAO,eAAM,CAAC,GAAG,CAAA,IAAI,QAAQ,MAAM,SAAS,MAAM,eAAM,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,SAAS,EAAE,CAAC;IACvF,CAAC;IAOO,6BAA6B,CACnC,QAAoB,EACpB,MAAgB,EAChB,IAAY,EACZ,WAAmB,EACnB,SAAqB;QAErB,MAAM,OAAO,GAAG,IAAA,sBAAU,EAAC,IAAI,CAAC,CAAC;QACjC,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,IAAA,+BAAmB,EAAC,MAAM,CAAC,CAAC;QAEzE,IAAI,SAAS,KAAK,CAAC,CAAC,EAAE,CAAC;YAErB,MAAM,YAAY,GAAG,IAAA,kCAAsB,EAAC,MAAM,EAAE,WAAkB,CAAC,CAAC;YACxE,MAAM,SAAS,GAAG,eAAM,CAAC,GAAG,CAAC,IAAI,IAAA,8BAAkB,EAAC,YAAY,CAAC,GAAG,CAAC,CAAC;YACtE,OAAO,eAAM,CAAC,GAAG,CAAA,IAAI,QAAQ,MAAM,SAAS,MAAM,eAAM,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,SAAS,EAAE,CAAC;QACvF,CAAC;QAGD,MAAM,SAAS,GAAG,eAAM,CAAC,GAAG,CAAC,IAAI,IAAA,8BAAkB,EAAC,UAAU,CAAC,GAAG,CAAC,CAAC;QAEpE,QAAQ,WAAW,EAAE,CAAC;YACpB,KAAK,KAAK;gBACR,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACzB,MAAM,OAAO,GAAG,eAAM,CAAC,GAAG,CAAC,IAAI,IAAA,8BAAkB,EAAC,SAAS,CAAC,GAAG,CAAC,CAAC;oBACjE,OAAO,eAAM,CAAC,GAAG,CAAA,wBAAwB,OAAO,MAAM,eAAM,CAAC,GAAG,CAAC,OAAO,CAAC,+BAA+B,QAAQ,KAAK,SAAS,eAAe,SAAS,EAAE,CAAC;gBAC3J,CAAC;qBAAM,CAAC;oBACN,OAAO,eAAM,CAAC,GAAG,CAAA,sBAAsB,eAAM,CAAC,GAAG,CAAC,OAAO,CAAC,oCAAoC,QAAQ,KAAK,SAAS,eAAe,SAAS,EAAE,CAAC;gBACjJ,CAAC;YAEH,KAAK,KAAK;gBACR,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACzB,MAAM,OAAO,GAAG,eAAM,CAAC,GAAG,CAAC,IAAI,IAAA,8BAAkB,EAAC,SAAS,CAAC,GAAG,CAAC,CAAC;oBACjE,OAAO,eAAM,CAAC,GAAG,CAAA,wBAAwB,OAAO,MAAM,eAAM,CAAC,GAAG,CAAC,OAAO,CAAC,+BAA+B,QAAQ,KAAK,SAAS,eAAe,SAAS,EAAE,CAAC;gBAC3J,CAAC;qBAAM,CAAC;oBACN,OAAO,eAAM,CAAC,GAAG,CAAA,sBAAsB,eAAM,CAAC,GAAG,CAAC,OAAO,CAAC,oCAAoC,QAAQ,KAAK,SAAS,eAAe,SAAS,EAAE,CAAC;gBACjJ,CAAC;YAEH,KAAK,KAAK;gBACR,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACzB,MAAM,OAAO,GAAG,eAAM,CAAC,GAAG,CAAC,IAAI,IAAA,8BAAkB,EAAC,SAAS,CAAC,GAAG,CAAC,CAAC;oBACjE,OAAO,eAAM,CAAC,GAAG,CAAA,wBAAwB,OAAO,MAAM,eAAM,CAAC,GAAG,CAAC,OAAO,CAAC,+BAA+B,QAAQ,KAAK,SAAS,eAAe,SAAS,EAAE,CAAC;gBAC3J,CAAC;qBAAM,CAAC;oBACN,OAAO,eAAM,CAAC,GAAG,CAAA,sBAAsB,eAAM,CAAC,GAAG,CAAC,OAAO,CAAC,oCAAoC,QAAQ,KAAK,SAAS,eAAe,SAAS,EAAE,CAAC;gBACjJ,CAAC;YAEH,KAAK,MAAM,CAAC,CAAC,CAAC;gBAEZ,MAAM,QAAQ,GAAG,CAAC,GAAG,UAAU,EAAE,IAAI,EAAE,GAAG,SAAS,CAAC,CAAC;gBACrD,MAAM,SAAS,GAAG,eAAM,CAAC,GAAG,CAAC,IAAI,IAAA,8BAAkB,EAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;gBAClE,OAAO,eAAM,CAAC,GAAG,CAAA,IAAI,QAAQ,MAAM,SAAS,MAAM,eAAM,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,SAAS,EAAE,CAAC;YACvF,CAAC;YAED,KAAK,OAAO,CAAC;YACb,OAAO,CAAC,CAAC,CAAC;gBAER,MAAM,SAAS,GAAG,CAAC,GAAG,UAAU,EAAE,GAAG,EAAE,GAAG,SAAS,CAAC,CAAC;gBACrD,MAAM,SAAS,GAAG,eAAM,CAAC,GAAG,CAAC,IAAI,IAAA,8BAAkB,EAAC,SAAS,CAAC,GAAG,CAAC,CAAC;gBACnE,OAAO,eAAM,CAAC,GAAG,CAAA,IAAI,QAAQ,MAAM,SAAS,MAAM,eAAM,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,SAAS,EAAE,CAAC;YACvF,CAAC;QACH,CAAC;IACH,CAAC;IAMD,0BAA0B,CACxB,OAAe,EACf,UAA0B,EAAE;QAG5B,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;QAC3C,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;QACvE,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC;QAC1C,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;QACvD,MAAM,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC;YACjD,CAAC,CAAC,OAAO,CAAC,OAAO;YACjB,CAAC,CAAC,OAAO,CAAC,OAAO;gBACf,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC;gBACnB,CAAC,CAAC,EAAE,CAAC;QAGT,MAAM,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC;QACzD,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC,CAAC;QAEpD,OAAO,eAAM,CAAC,GAAG,CAAA;;;;;;;;;;;;;;;uBAeE,OAAO;cAChB,QAAQ;iBACL,QAAQ;cACX,IAAI;eACH,IAAI;KACd,CAAC;IACJ,CAAC;IAKD,oBAAoB,CAClB,OAAe,EACf,IAAY,EACZ,IAAY,EACZ,eAAiC,EACjC,OAAyB;QAEzB,OAAO,IAAI,CAAC,0BAA0B,CAAC,OAAO,EAAE;YAC9C,IAAI;YACJ,IAAI;YACJ,KAAK,EAAE,eAAe;YACtB,OAAO;SACR,CAAC,CAAC;IACL,CAAC;;AA3tBH,oDA4tBC;AAnNyB,uCAAkB,GAAG,IAAI,GAAG,CAAC;IACnD,WAAW;IACX,WAAW;IACX,IAAI;IACJ,MAAM;IACN,YAAY;IACZ,UAAU;IACV,WAAW;IACX,WAAW;IACX,aAAa;IACb,MAAM;IACN,MAAM;CACP,CAAC,CAAC;AA6ML,SAAgB,0BAA0B,CACxC,OAAe,EACf,IAAY,EACZ,IAAY,EACZ,eAAiC,EACjC,OAAe;IAEf,MAAM,SAAS,GAAG,IAAI,oBAAoB,EAAE,CAAC;IAC7C,MAAM,WAAW,GAAG,SAAS,CAAC,aAAa,CAAC,eAAe,IAAI,EAAE,CAAC,CAAC;IACnE,MAAM,aAAa,GAAG,SAAS,CAAC,eAAe,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC;IAG/D,OAAO,eAAM,CAAC,GAAG,CAAA;;;;;;;;;;;;;;;qBAeE,OAAO;aACf,WAAW;eACT,aAAa;YAChB,IAAI;aACH,IAAI;GACd,CAAC;AACJ,CAAC"}