@memberjunction/server 2.73.0 → 2.74.0
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.
- package/dist/generated/generated.d.ts +78 -0
- package/dist/generated/generated.d.ts.map +1 -1
- package/dist/generated/generated.js +821 -368
- package/dist/generated/generated.js.map +1 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -1
- package/dist/resolvers/AskSkipResolver.d.ts +1 -0
- package/dist/resolvers/AskSkipResolver.d.ts.map +1 -1
- package/dist/resolvers/AskSkipResolver.js +10 -0
- package/dist/resolvers/AskSkipResolver.js.map +1 -1
- package/dist/resolvers/CreateQueryResolver.d.ts +33 -0
- package/dist/resolvers/CreateQueryResolver.d.ts.map +1 -0
- package/dist/resolvers/CreateQueryResolver.js +251 -0
- package/dist/resolvers/CreateQueryResolver.js.map +1 -0
- package/dist/resolvers/QueryResolver.d.ts +7 -5
- package/dist/resolvers/QueryResolver.d.ts.map +1 -1
- package/dist/resolvers/QueryResolver.js +133 -64
- package/dist/resolvers/QueryResolver.js.map +1 -1
- package/package.json +34 -34
- package/src/generated/generated.ts +652 -369
- package/src/index.ts +2 -1
- package/src/resolvers/AskSkipResolver.ts +15 -0
- package/src/resolvers/CreateQueryResolver.ts +257 -0
- package/src/resolvers/QueryResolver.ts +128 -56
|
@@ -0,0 +1,251 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
|
+
};
|
|
10
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
11
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
12
|
+
};
|
|
13
|
+
import { Arg, Ctx, Field, InputType, Mutation, ObjectType, registerEnumType } from 'type-graphql';
|
|
14
|
+
import { LogError, Metadata, RunView } from '@memberjunction/core';
|
|
15
|
+
import { RequireSystemUser } from '../directives/RequireSystemUser.js';
|
|
16
|
+
export var QueryStatus;
|
|
17
|
+
(function (QueryStatus) {
|
|
18
|
+
QueryStatus["Pending"] = "Pending";
|
|
19
|
+
QueryStatus["Approved"] = "Approved";
|
|
20
|
+
QueryStatus["Rejected"] = "Rejected";
|
|
21
|
+
QueryStatus["Expired"] = "Expired";
|
|
22
|
+
})(QueryStatus || (QueryStatus = {}));
|
|
23
|
+
registerEnumType(QueryStatus, {
|
|
24
|
+
name: "QueryStatus",
|
|
25
|
+
description: "Status of a query: Pending, Approved, Rejected, or Expired"
|
|
26
|
+
});
|
|
27
|
+
let CreateQueryInputType = class CreateQueryInputType {
|
|
28
|
+
Name;
|
|
29
|
+
CategoryID;
|
|
30
|
+
CategoryPath;
|
|
31
|
+
UserQuestion;
|
|
32
|
+
Description;
|
|
33
|
+
SQL;
|
|
34
|
+
TechnicalDescription;
|
|
35
|
+
OriginalSQL;
|
|
36
|
+
Feedback;
|
|
37
|
+
Status;
|
|
38
|
+
QualityRank;
|
|
39
|
+
ExecutionCostRank;
|
|
40
|
+
UsesTemplate;
|
|
41
|
+
};
|
|
42
|
+
__decorate([
|
|
43
|
+
Field(() => String),
|
|
44
|
+
__metadata("design:type", String)
|
|
45
|
+
], CreateQueryInputType.prototype, "Name", void 0);
|
|
46
|
+
__decorate([
|
|
47
|
+
Field(() => String, { nullable: true }),
|
|
48
|
+
__metadata("design:type", String)
|
|
49
|
+
], CreateQueryInputType.prototype, "CategoryID", void 0);
|
|
50
|
+
__decorate([
|
|
51
|
+
Field(() => String, { nullable: true }),
|
|
52
|
+
__metadata("design:type", String)
|
|
53
|
+
], CreateQueryInputType.prototype, "CategoryPath", void 0);
|
|
54
|
+
__decorate([
|
|
55
|
+
Field(() => String, { nullable: true }),
|
|
56
|
+
__metadata("design:type", String)
|
|
57
|
+
], CreateQueryInputType.prototype, "UserQuestion", void 0);
|
|
58
|
+
__decorate([
|
|
59
|
+
Field(() => String, { nullable: true }),
|
|
60
|
+
__metadata("design:type", String)
|
|
61
|
+
], CreateQueryInputType.prototype, "Description", void 0);
|
|
62
|
+
__decorate([
|
|
63
|
+
Field(() => String, { nullable: true }),
|
|
64
|
+
__metadata("design:type", String)
|
|
65
|
+
], CreateQueryInputType.prototype, "SQL", void 0);
|
|
66
|
+
__decorate([
|
|
67
|
+
Field(() => String, { nullable: true }),
|
|
68
|
+
__metadata("design:type", String)
|
|
69
|
+
], CreateQueryInputType.prototype, "TechnicalDescription", void 0);
|
|
70
|
+
__decorate([
|
|
71
|
+
Field(() => String, { nullable: true }),
|
|
72
|
+
__metadata("design:type", String)
|
|
73
|
+
], CreateQueryInputType.prototype, "OriginalSQL", void 0);
|
|
74
|
+
__decorate([
|
|
75
|
+
Field(() => String, { nullable: true }),
|
|
76
|
+
__metadata("design:type", String)
|
|
77
|
+
], CreateQueryInputType.prototype, "Feedback", void 0);
|
|
78
|
+
__decorate([
|
|
79
|
+
Field(() => QueryStatus, { nullable: true, defaultValue: QueryStatus.Pending }),
|
|
80
|
+
__metadata("design:type", String)
|
|
81
|
+
], CreateQueryInputType.prototype, "Status", void 0);
|
|
82
|
+
__decorate([
|
|
83
|
+
Field(() => Number, { nullable: true }),
|
|
84
|
+
__metadata("design:type", Number)
|
|
85
|
+
], CreateQueryInputType.prototype, "QualityRank", void 0);
|
|
86
|
+
__decorate([
|
|
87
|
+
Field(() => Number, { nullable: true }),
|
|
88
|
+
__metadata("design:type", Number)
|
|
89
|
+
], CreateQueryInputType.prototype, "ExecutionCostRank", void 0);
|
|
90
|
+
__decorate([
|
|
91
|
+
Field(() => Boolean, { nullable: true }),
|
|
92
|
+
__metadata("design:type", Boolean)
|
|
93
|
+
], CreateQueryInputType.prototype, "UsesTemplate", void 0);
|
|
94
|
+
CreateQueryInputType = __decorate([
|
|
95
|
+
InputType()
|
|
96
|
+
], CreateQueryInputType);
|
|
97
|
+
export { CreateQueryInputType };
|
|
98
|
+
let CreateQueryResultType = class CreateQueryResultType {
|
|
99
|
+
Success;
|
|
100
|
+
ErrorMessage;
|
|
101
|
+
QueryData;
|
|
102
|
+
};
|
|
103
|
+
__decorate([
|
|
104
|
+
Field(() => Boolean),
|
|
105
|
+
__metadata("design:type", Boolean)
|
|
106
|
+
], CreateQueryResultType.prototype, "Success", void 0);
|
|
107
|
+
__decorate([
|
|
108
|
+
Field(() => String, { nullable: true }),
|
|
109
|
+
__metadata("design:type", String)
|
|
110
|
+
], CreateQueryResultType.prototype, "ErrorMessage", void 0);
|
|
111
|
+
__decorate([
|
|
112
|
+
Field(() => String, { nullable: true }),
|
|
113
|
+
__metadata("design:type", String)
|
|
114
|
+
], CreateQueryResultType.prototype, "QueryData", void 0);
|
|
115
|
+
CreateQueryResultType = __decorate([
|
|
116
|
+
ObjectType()
|
|
117
|
+
], CreateQueryResultType);
|
|
118
|
+
export { CreateQueryResultType };
|
|
119
|
+
export class CreateQueryResolver {
|
|
120
|
+
async CreateQuery(input, context) {
|
|
121
|
+
try {
|
|
122
|
+
const md = new Metadata();
|
|
123
|
+
const newQuery = await md.GetEntityObject("Queries", context.userPayload.userRecord);
|
|
124
|
+
let finalCategoryID = input.CategoryID;
|
|
125
|
+
if (input.CategoryPath) {
|
|
126
|
+
finalCategoryID = await this.findOrCreateCategoryPath(input.CategoryPath, md, context.userPayload.userRecord);
|
|
127
|
+
}
|
|
128
|
+
newQuery.Name = input.Name;
|
|
129
|
+
if (finalCategoryID != null) {
|
|
130
|
+
newQuery.CategoryID = finalCategoryID;
|
|
131
|
+
}
|
|
132
|
+
if (input.UserQuestion != null) {
|
|
133
|
+
newQuery.UserQuestion = input.UserQuestion;
|
|
134
|
+
}
|
|
135
|
+
if (input.Description != null) {
|
|
136
|
+
newQuery.Description = input.Description;
|
|
137
|
+
}
|
|
138
|
+
if (input.SQL != null) {
|
|
139
|
+
newQuery.SQL = input.SQL;
|
|
140
|
+
}
|
|
141
|
+
if (input.TechnicalDescription != null) {
|
|
142
|
+
newQuery.TechnicalDescription = input.TechnicalDescription;
|
|
143
|
+
}
|
|
144
|
+
if (input.OriginalSQL != null) {
|
|
145
|
+
newQuery.OriginalSQL = input.OriginalSQL;
|
|
146
|
+
}
|
|
147
|
+
if (input.Feedback != null) {
|
|
148
|
+
newQuery.Feedback = input.Feedback;
|
|
149
|
+
}
|
|
150
|
+
if (input.Status != null) {
|
|
151
|
+
newQuery.Status = input.Status;
|
|
152
|
+
}
|
|
153
|
+
if (input.QualityRank != null) {
|
|
154
|
+
newQuery.QualityRank = input.QualityRank;
|
|
155
|
+
}
|
|
156
|
+
if (input.ExecutionCostRank != null) {
|
|
157
|
+
newQuery.ExecutionCostRank = input.ExecutionCostRank;
|
|
158
|
+
}
|
|
159
|
+
if (input.UsesTemplate != null) {
|
|
160
|
+
newQuery.UsesTemplate = input.UsesTemplate;
|
|
161
|
+
}
|
|
162
|
+
const saveResult = await newQuery.Save();
|
|
163
|
+
if (saveResult) {
|
|
164
|
+
return {
|
|
165
|
+
Success: true,
|
|
166
|
+
QueryData: JSON.stringify(newQuery.GetAll())
|
|
167
|
+
};
|
|
168
|
+
}
|
|
169
|
+
else {
|
|
170
|
+
return {
|
|
171
|
+
Success: false,
|
|
172
|
+
ErrorMessage: `Failed to save query: ${newQuery.LatestResult?.Message || 'Unknown error'}`
|
|
173
|
+
};
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
catch (err) {
|
|
177
|
+
LogError(err);
|
|
178
|
+
return {
|
|
179
|
+
Success: false,
|
|
180
|
+
ErrorMessage: `CreateQueryResolver::CreateQuery --- Error creating query: ${err instanceof Error ? err.message : String(err)}`
|
|
181
|
+
};
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
async findOrCreateCategoryPath(categoryPath, md, contextUser) {
|
|
185
|
+
if (!categoryPath || categoryPath.trim() === '') {
|
|
186
|
+
throw new Error('CategoryPath cannot be empty');
|
|
187
|
+
}
|
|
188
|
+
const pathParts = categoryPath.split('/').map(part => part.trim()).filter(part => part.length > 0);
|
|
189
|
+
if (pathParts.length === 0) {
|
|
190
|
+
throw new Error('CategoryPath must contain at least one valid category name');
|
|
191
|
+
}
|
|
192
|
+
let currentParentID = null;
|
|
193
|
+
let currentCategoryID = null;
|
|
194
|
+
for (let i = 0; i < pathParts.length; i++) {
|
|
195
|
+
const categoryName = pathParts[i];
|
|
196
|
+
const existingCategory = await this.findCategoryByNameAndParent(categoryName, currentParentID, contextUser);
|
|
197
|
+
if (existingCategory) {
|
|
198
|
+
currentCategoryID = existingCategory.ID;
|
|
199
|
+
currentParentID = existingCategory.ID;
|
|
200
|
+
}
|
|
201
|
+
else {
|
|
202
|
+
const newCategory = await md.GetEntityObject("Query Categories", contextUser);
|
|
203
|
+
newCategory.Name = categoryName;
|
|
204
|
+
newCategory.ParentID = currentParentID;
|
|
205
|
+
newCategory.UserID = contextUser.ID;
|
|
206
|
+
newCategory.Description = `Auto-created category from path: ${categoryPath}`;
|
|
207
|
+
const saveResult = await newCategory.Save();
|
|
208
|
+
if (!saveResult) {
|
|
209
|
+
throw new Error(`Failed to create category '${categoryName}': ${newCategory.LatestResult?.Message || 'Unknown error'}`);
|
|
210
|
+
}
|
|
211
|
+
currentCategoryID = newCategory.ID;
|
|
212
|
+
currentParentID = newCategory.ID;
|
|
213
|
+
await md.Refresh();
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
if (!currentCategoryID) {
|
|
217
|
+
throw new Error('Failed to determine final category ID');
|
|
218
|
+
}
|
|
219
|
+
return currentCategoryID;
|
|
220
|
+
}
|
|
221
|
+
async findCategoryByNameAndParent(categoryName, parentID, contextUser) {
|
|
222
|
+
try {
|
|
223
|
+
const rv = new RunView();
|
|
224
|
+
const parentFilter = parentID ? `ParentID='${parentID}'` : 'ParentID IS NULL';
|
|
225
|
+
const nameFilter = `LOWER(Name) = LOWER('${categoryName.replace(/'/g, "''")}')`;
|
|
226
|
+
const result = await rv.RunView({
|
|
227
|
+
EntityName: 'Query Categories',
|
|
228
|
+
ExtraFilter: `${nameFilter} AND ${parentFilter}`,
|
|
229
|
+
ResultType: 'entity_object'
|
|
230
|
+
}, contextUser);
|
|
231
|
+
if (result.Success && result.Results && result.Results.length > 0) {
|
|
232
|
+
return result.Results[0];
|
|
233
|
+
}
|
|
234
|
+
return null;
|
|
235
|
+
}
|
|
236
|
+
catch (error) {
|
|
237
|
+
LogError(error);
|
|
238
|
+
return null;
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
__decorate([
|
|
243
|
+
RequireSystemUser(),
|
|
244
|
+
Mutation(() => CreateQueryResultType),
|
|
245
|
+
__param(0, Arg('input', () => CreateQueryInputType)),
|
|
246
|
+
__param(1, Ctx()),
|
|
247
|
+
__metadata("design:type", Function),
|
|
248
|
+
__metadata("design:paramtypes", [CreateQueryInputType, Object]),
|
|
249
|
+
__metadata("design:returntype", Promise)
|
|
250
|
+
], CreateQueryResolver.prototype, "CreateQuery", null);
|
|
251
|
+
//# sourceMappingURL=CreateQueryResolver.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CreateQueryResolver.js","sourceRoot":"","sources":["../../src/resolvers/CreateQueryResolver.ts"],"names":[],"mappings":"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"}
|
|
@@ -5,13 +5,15 @@ export declare class RunQueryResultType {
|
|
|
5
5
|
Success: boolean;
|
|
6
6
|
Results: string;
|
|
7
7
|
RowCount: number;
|
|
8
|
+
TotalRowCount: number;
|
|
8
9
|
ExecutionTime: number;
|
|
9
10
|
ErrorMessage: string;
|
|
11
|
+
AppliedParameters?: string;
|
|
10
12
|
}
|
|
11
|
-
export declare class
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
13
|
+
export declare class RunQueryResolver {
|
|
14
|
+
private findQuery;
|
|
15
|
+
GetQueryData(QueryID: string, context: AppContext, CategoryID?: string, CategoryName?: string, Parameters?: Record<string, any>, MaxRows?: number, StartRow?: number): Promise<RunQueryResultType>;
|
|
16
|
+
GetQueryDataByName(QueryName: string, context: AppContext, CategoryID?: string, CategoryName?: string, Parameters?: Record<string, any>, MaxRows?: number, StartRow?: number): Promise<RunQueryResultType>;
|
|
17
|
+
GetQueryDataSystemUser(QueryID: string, context: AppContext, CategoryID?: string, CategoryName?: string, Parameters?: Record<string, any>, MaxRows?: number, StartRow?: number): Promise<RunQueryResultType>;
|
|
16
18
|
}
|
|
17
19
|
//# sourceMappingURL=QueryResolver.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"QueryResolver.d.ts","sourceRoot":"","sources":["../../src/resolvers/QueryResolver.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"QueryResolver.d.ts","sourceRoot":"","sources":["../../src/resolvers/QueryResolver.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAMzC,qBACa,kBAAkB;IAE7B,OAAO,EAAE,MAAM,CAAC;IAGhB,SAAS,EAAE,MAAM,CAAC;IAGlB,OAAO,EAAE,OAAO,CAAC;IAGjB,OAAO,EAAE,MAAM,CAAC;IAGhB,QAAQ,EAAE,MAAM,CAAC;IAGjB,aAAa,EAAE,MAAM,CAAC;IAGtB,aAAa,EAAE,MAAM,CAAC;IAGtB,YAAY,EAAE,MAAM,CAAC;IAGrB,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B;AAED,qBACa,gBAAgB;YACb,SAAS;IAmCjB,YAAY,CAA+B,OAAO,EAAE,MAAM,EACtC,OAAO,EAAE,UAAU,EACyB,UAAU,CAAC,EAAE,MAAM,EACjB,YAAY,CAAC,EAAE,MAAM,EACZ,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EACjD,OAAO,CAAC,EAAE,MAAM,EACf,QAAQ,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC;IA8C1G,kBAAkB,CAAiC,SAAS,EAAE,MAAM,EAC1C,OAAO,EAAE,UAAU,EACyB,UAAU,CAAC,EAAE,MAAM,EACjB,YAAY,CAAC,EAAE,MAAM,EACZ,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EACjD,OAAO,CAAC,EAAE,MAAM,EACf,QAAQ,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC;IA4BhH,sBAAsB,CAA+B,OAAO,EAAE,MAAM,EACtC,OAAO,EAAE,UAAU,EACyB,UAAU,CAAC,EAAE,MAAM,EACjB,YAAY,CAAC,EAAE,MAAM,EACZ,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EACjD,OAAO,CAAC,EAAE,MAAM,EACf,QAAQ,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC;CAsC3H"}
|
|
@@ -10,17 +10,21 @@ var __metadata = (this && this.__metadata) || function (k, v) {
|
|
|
10
10
|
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
11
11
|
return function (target, key) { decorator(target, key, paramIndex); }
|
|
12
12
|
};
|
|
13
|
+
import { Arg, Ctx, ObjectType, Query, Resolver, Field, Int } from 'type-graphql';
|
|
13
14
|
import { RunQuery } from '@memberjunction/core';
|
|
14
|
-
import { Arg, Ctx, Field, ObjectType, Query, Resolver } from 'type-graphql';
|
|
15
15
|
import { RequireSystemUser } from '../directives/RequireSystemUser.js';
|
|
16
|
+
import { GraphQLJSONObject } from 'graphql-type-json';
|
|
17
|
+
import { Metadata } from '@memberjunction/core';
|
|
16
18
|
let RunQueryResultType = class RunQueryResultType {
|
|
17
19
|
QueryID;
|
|
18
20
|
QueryName;
|
|
19
21
|
Success;
|
|
20
22
|
Results;
|
|
21
23
|
RowCount;
|
|
24
|
+
TotalRowCount;
|
|
22
25
|
ExecutionTime;
|
|
23
26
|
ErrorMessage;
|
|
27
|
+
AppliedParameters;
|
|
24
28
|
};
|
|
25
29
|
__decorate([
|
|
26
30
|
Field(),
|
|
@@ -42,6 +46,10 @@ __decorate([
|
|
|
42
46
|
Field(),
|
|
43
47
|
__metadata("design:type", Number)
|
|
44
48
|
], RunQueryResultType.prototype, "RowCount", void 0);
|
|
49
|
+
__decorate([
|
|
50
|
+
Field(),
|
|
51
|
+
__metadata("design:type", Number)
|
|
52
|
+
], RunQueryResultType.prototype, "TotalRowCount", void 0);
|
|
45
53
|
__decorate([
|
|
46
54
|
Field(),
|
|
47
55
|
__metadata("design:type", Number)
|
|
@@ -50,77 +58,140 @@ __decorate([
|
|
|
50
58
|
Field(),
|
|
51
59
|
__metadata("design:type", String)
|
|
52
60
|
], RunQueryResultType.prototype, "ErrorMessage", void 0);
|
|
61
|
+
__decorate([
|
|
62
|
+
Field(() => String, { nullable: true }),
|
|
63
|
+
__metadata("design:type", String)
|
|
64
|
+
], RunQueryResultType.prototype, "AppliedParameters", void 0);
|
|
53
65
|
RunQueryResultType = __decorate([
|
|
54
66
|
ObjectType()
|
|
55
67
|
], RunQueryResultType);
|
|
56
68
|
export { RunQueryResultType };
|
|
57
|
-
let
|
|
58
|
-
async
|
|
69
|
+
let RunQueryResolver = class RunQueryResolver {
|
|
70
|
+
async findQuery(QueryID, QueryName, CategoryID, CategoryName, refreshMetadataIfNotFound = false) {
|
|
71
|
+
const md = new Metadata();
|
|
72
|
+
const queries = md.Queries.filter(q => {
|
|
73
|
+
if (QueryID) {
|
|
74
|
+
return q.ID.trim().toLowerCase() === QueryID.trim().toLowerCase();
|
|
75
|
+
}
|
|
76
|
+
else if (QueryName) {
|
|
77
|
+
let matches = q.Name.trim().toLowerCase() === QueryName.trim().toLowerCase();
|
|
78
|
+
if (CategoryID) {
|
|
79
|
+
matches = matches && q.CategoryID?.trim().toLowerCase() === CategoryID.trim().toLowerCase();
|
|
80
|
+
}
|
|
81
|
+
if (CategoryName) {
|
|
82
|
+
matches = matches && q.Category?.trim().toLowerCase() === CategoryName.trim().toLowerCase();
|
|
83
|
+
}
|
|
84
|
+
return matches;
|
|
85
|
+
}
|
|
86
|
+
return false;
|
|
87
|
+
});
|
|
88
|
+
if (queries.length === 0) {
|
|
89
|
+
if (refreshMetadataIfNotFound) {
|
|
90
|
+
await md.Refresh();
|
|
91
|
+
return this.findQuery(QueryID, QueryName, CategoryID, CategoryName, false);
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
return null;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
else {
|
|
98
|
+
return queries[0];
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
async GetQueryData(QueryID, context, CategoryID, CategoryName, Parameters, MaxRows, StartRow) {
|
|
59
102
|
const runQuery = new RunQuery();
|
|
103
|
+
console.log('GetQueryData called with:', { QueryID, Parameters, MaxRows, StartRow });
|
|
60
104
|
const result = await runQuery.RunQuery({
|
|
61
105
|
QueryID: QueryID,
|
|
62
106
|
CategoryID: CategoryID,
|
|
63
|
-
CategoryName: CategoryName
|
|
107
|
+
CategoryName: CategoryName,
|
|
108
|
+
Parameters: Parameters,
|
|
109
|
+
MaxRows: MaxRows,
|
|
110
|
+
StartRow: StartRow
|
|
64
111
|
}, context.userPayload.userRecord);
|
|
65
|
-
|
|
66
|
-
QueryID: QueryID,
|
|
67
|
-
QueryName: result.QueryName,
|
|
112
|
+
console.log('RunQuery result:', {
|
|
68
113
|
Success: result.Success,
|
|
69
|
-
Results: JSON.stringify(result.Results),
|
|
70
|
-
RowCount: result.RowCount,
|
|
71
|
-
ExecutionTime: result.ExecutionTime,
|
|
72
114
|
ErrorMessage: result.ErrorMessage,
|
|
115
|
+
AppliedParameters: result.AppliedParameters
|
|
116
|
+
});
|
|
117
|
+
let queryName = result.QueryName;
|
|
118
|
+
if (!queryName) {
|
|
119
|
+
try {
|
|
120
|
+
const queryInfo = await this.findQuery(QueryID, undefined, CategoryID, CategoryName, true);
|
|
121
|
+
if (queryInfo) {
|
|
122
|
+
queryName = queryInfo.Name;
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
catch (error) {
|
|
126
|
+
console.error('Error finding query to get name:', error);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
return {
|
|
130
|
+
QueryID: QueryID,
|
|
131
|
+
QueryName: queryName || 'Unknown Query',
|
|
132
|
+
Success: result.Success ?? false,
|
|
133
|
+
Results: JSON.stringify(result.Results ?? null),
|
|
134
|
+
RowCount: result.RowCount ?? 0,
|
|
135
|
+
TotalRowCount: result.TotalRowCount ?? 0,
|
|
136
|
+
ExecutionTime: result.ExecutionTime ?? 0,
|
|
137
|
+
ErrorMessage: result.ErrorMessage || '',
|
|
138
|
+
AppliedParameters: result.AppliedParameters ? JSON.stringify(result.AppliedParameters) : undefined
|
|
73
139
|
};
|
|
74
140
|
}
|
|
75
|
-
async GetQueryDataByName(QueryName, context, CategoryID, CategoryName) {
|
|
141
|
+
async GetQueryDataByName(QueryName, context, CategoryID, CategoryName, Parameters, MaxRows, StartRow) {
|
|
76
142
|
const runQuery = new RunQuery();
|
|
77
143
|
const result = await runQuery.RunQuery({
|
|
78
144
|
QueryName: QueryName,
|
|
79
145
|
CategoryID: CategoryID,
|
|
80
|
-
CategoryName: CategoryName
|
|
146
|
+
CategoryName: CategoryName,
|
|
147
|
+
Parameters: Parameters,
|
|
148
|
+
MaxRows: MaxRows,
|
|
149
|
+
StartRow: StartRow
|
|
81
150
|
}, context.userPayload.userRecord);
|
|
82
151
|
return {
|
|
83
|
-
QueryID: result.QueryID,
|
|
152
|
+
QueryID: result.QueryID || '',
|
|
84
153
|
QueryName: QueryName,
|
|
85
|
-
Success: result.Success,
|
|
86
|
-
Results: JSON.stringify(result.Results),
|
|
87
|
-
RowCount: result.RowCount,
|
|
88
|
-
|
|
89
|
-
|
|
154
|
+
Success: result.Success ?? false,
|
|
155
|
+
Results: JSON.stringify(result.Results ?? null),
|
|
156
|
+
RowCount: result.RowCount ?? 0,
|
|
157
|
+
TotalRowCount: result.TotalRowCount ?? 0,
|
|
158
|
+
ExecutionTime: result.ExecutionTime ?? 0,
|
|
159
|
+
ErrorMessage: result.ErrorMessage || '',
|
|
160
|
+
AppliedParameters: result.AppliedParameters ? JSON.stringify(result.AppliedParameters) : undefined
|
|
90
161
|
};
|
|
91
162
|
}
|
|
92
|
-
async GetQueryDataSystemUser(QueryID, context, CategoryID, CategoryName) {
|
|
163
|
+
async GetQueryDataSystemUser(QueryID, context, CategoryID, CategoryName, Parameters, MaxRows, StartRow) {
|
|
93
164
|
const runQuery = new RunQuery();
|
|
94
165
|
const result = await runQuery.RunQuery({
|
|
95
166
|
QueryID: QueryID,
|
|
96
167
|
CategoryID: CategoryID,
|
|
97
|
-
CategoryName: CategoryName
|
|
168
|
+
CategoryName: CategoryName,
|
|
169
|
+
Parameters: Parameters,
|
|
170
|
+
MaxRows: MaxRows,
|
|
171
|
+
StartRow: StartRow
|
|
98
172
|
}, context.userPayload.userRecord);
|
|
173
|
+
let queryName = result.QueryName;
|
|
174
|
+
if (!queryName) {
|
|
175
|
+
try {
|
|
176
|
+
const queryInfo = await this.findQuery(QueryID, undefined, CategoryID, CategoryName, true);
|
|
177
|
+
if (queryInfo) {
|
|
178
|
+
queryName = queryInfo.Name;
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
catch (error) {
|
|
182
|
+
console.error('Error finding query to get name:', error);
|
|
183
|
+
}
|
|
184
|
+
}
|
|
99
185
|
return {
|
|
100
186
|
QueryID: QueryID,
|
|
101
|
-
QueryName:
|
|
102
|
-
Success: result.Success,
|
|
103
|
-
Results: JSON.stringify(result.Results),
|
|
104
|
-
RowCount: result.RowCount,
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
async GetQueryDataByNameSystemUser(QueryName, context, CategoryID, CategoryName) {
|
|
110
|
-
const runQuery = new RunQuery();
|
|
111
|
-
const result = await runQuery.RunQuery({
|
|
112
|
-
QueryName: QueryName,
|
|
113
|
-
CategoryID: CategoryID,
|
|
114
|
-
CategoryName: CategoryName
|
|
115
|
-
}, context.userPayload.userRecord);
|
|
116
|
-
return {
|
|
117
|
-
QueryID: result.QueryID,
|
|
118
|
-
QueryName: QueryName,
|
|
119
|
-
Success: result.Success,
|
|
120
|
-
Results: JSON.stringify(result.Results),
|
|
121
|
-
RowCount: result.RowCount,
|
|
122
|
-
ExecutionTime: result.ExecutionTime,
|
|
123
|
-
ErrorMessage: result.ErrorMessage,
|
|
187
|
+
QueryName: queryName || 'Unknown Query',
|
|
188
|
+
Success: result.Success ?? false,
|
|
189
|
+
Results: JSON.stringify(result.Results ?? null),
|
|
190
|
+
RowCount: result.RowCount ?? 0,
|
|
191
|
+
TotalRowCount: result.TotalRowCount ?? 0,
|
|
192
|
+
ExecutionTime: result.ExecutionTime ?? 0,
|
|
193
|
+
ErrorMessage: result.ErrorMessage || '',
|
|
194
|
+
AppliedParameters: result.AppliedParameters ? JSON.stringify(result.AppliedParameters) : undefined
|
|
124
195
|
};
|
|
125
196
|
}
|
|
126
197
|
};
|
|
@@ -130,20 +201,26 @@ __decorate([
|
|
|
130
201
|
__param(1, Ctx()),
|
|
131
202
|
__param(2, Arg('CategoryID', () => String, { nullable: true })),
|
|
132
203
|
__param(3, Arg('CategoryName', () => String, { nullable: true })),
|
|
204
|
+
__param(4, Arg('Parameters', () => GraphQLJSONObject, { nullable: true })),
|
|
205
|
+
__param(5, Arg('MaxRows', () => Int, { nullable: true })),
|
|
206
|
+
__param(6, Arg('StartRow', () => Int, { nullable: true })),
|
|
133
207
|
__metadata("design:type", Function),
|
|
134
|
-
__metadata("design:paramtypes", [String, Object, String, String]),
|
|
208
|
+
__metadata("design:paramtypes", [String, Object, String, String, Object, Number, Number]),
|
|
135
209
|
__metadata("design:returntype", Promise)
|
|
136
|
-
],
|
|
210
|
+
], RunQueryResolver.prototype, "GetQueryData", null);
|
|
137
211
|
__decorate([
|
|
138
212
|
Query(() => RunQueryResultType),
|
|
139
213
|
__param(0, Arg('QueryName', () => String)),
|
|
140
214
|
__param(1, Ctx()),
|
|
141
215
|
__param(2, Arg('CategoryID', () => String, { nullable: true })),
|
|
142
216
|
__param(3, Arg('CategoryName', () => String, { nullable: true })),
|
|
217
|
+
__param(4, Arg('Parameters', () => GraphQLJSONObject, { nullable: true })),
|
|
218
|
+
__param(5, Arg('MaxRows', () => Int, { nullable: true })),
|
|
219
|
+
__param(6, Arg('StartRow', () => Int, { nullable: true })),
|
|
143
220
|
__metadata("design:type", Function),
|
|
144
|
-
__metadata("design:paramtypes", [String, Object, String, String]),
|
|
221
|
+
__metadata("design:paramtypes", [String, Object, String, String, Object, Number, Number]),
|
|
145
222
|
__metadata("design:returntype", Promise)
|
|
146
|
-
],
|
|
223
|
+
], RunQueryResolver.prototype, "GetQueryDataByName", null);
|
|
147
224
|
__decorate([
|
|
148
225
|
RequireSystemUser(),
|
|
149
226
|
Query(() => RunQueryResultType),
|
|
@@ -151,23 +228,15 @@ __decorate([
|
|
|
151
228
|
__param(1, Ctx()),
|
|
152
229
|
__param(2, Arg('CategoryID', () => String, { nullable: true })),
|
|
153
230
|
__param(3, Arg('CategoryName', () => String, { nullable: true })),
|
|
231
|
+
__param(4, Arg('Parameters', () => GraphQLJSONObject, { nullable: true })),
|
|
232
|
+
__param(5, Arg('MaxRows', () => Int, { nullable: true })),
|
|
233
|
+
__param(6, Arg('StartRow', () => Int, { nullable: true })),
|
|
154
234
|
__metadata("design:type", Function),
|
|
155
|
-
__metadata("design:paramtypes", [String, Object, String, String]),
|
|
156
|
-
__metadata("design:returntype", Promise)
|
|
157
|
-
], ReportResolver.prototype, "GetQueryDataSystemUser", null);
|
|
158
|
-
__decorate([
|
|
159
|
-
RequireSystemUser(),
|
|
160
|
-
Query(() => RunQueryResultType),
|
|
161
|
-
__param(0, Arg('QueryName', () => String)),
|
|
162
|
-
__param(1, Ctx()),
|
|
163
|
-
__param(2, Arg('CategoryID', () => String, { nullable: true })),
|
|
164
|
-
__param(3, Arg('CategoryName', () => String, { nullable: true })),
|
|
165
|
-
__metadata("design:type", Function),
|
|
166
|
-
__metadata("design:paramtypes", [String, Object, String, String]),
|
|
235
|
+
__metadata("design:paramtypes", [String, Object, String, String, Object, Number, Number]),
|
|
167
236
|
__metadata("design:returntype", Promise)
|
|
168
|
-
],
|
|
169
|
-
|
|
170
|
-
Resolver(
|
|
171
|
-
],
|
|
172
|
-
export {
|
|
237
|
+
], RunQueryResolver.prototype, "GetQueryDataSystemUser", null);
|
|
238
|
+
RunQueryResolver = __decorate([
|
|
239
|
+
Resolver()
|
|
240
|
+
], RunQueryResolver);
|
|
241
|
+
export { RunQueryResolver };
|
|
173
242
|
//# sourceMappingURL=QueryResolver.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"QueryResolver.js","sourceRoot":"","sources":["../../src/resolvers/QueryResolver.ts"],"names":[],"mappings":";;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"QueryResolver.js","sourceRoot":"","sources":["../../src/resolvers/QueryResolver.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,UAAU,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,EAAE,MAAM,cAAc,CAAC;AACjF,OAAO,EAAE,QAAQ,EAAa,MAAM,sBAAsB,CAAC;AAE3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AAEtD,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAGzC,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;IAE7B,OAAO,CAAS;IAGhB,SAAS,CAAS;IAGlB,OAAO,CAAU;IAGjB,OAAO,CAAS;IAGhB,QAAQ,CAAS;IAGjB,aAAa,CAAS;IAGtB,aAAa,CAAS;IAGtB,YAAY,CAAS;IAGrB,iBAAiB,CAAU;CAC5B,CAAA;AAzBC;IADC,KAAK,EAAE;;mDACQ;AAGhB;IADC,KAAK,EAAE;;qDACU;AAGlB;IADC,KAAK,EAAE;;mDACS;AAGjB;IADC,KAAK,EAAE;;mDACQ;AAGhB;IADC,KAAK,EAAE;;oDACS;AAGjB;IADC,KAAK,EAAE;;yDACc;AAGtB;IADC,KAAK,EAAE;;yDACc;AAGtB;IADC,KAAK,EAAE;;wDACa;AAGrB;IADC,KAAK,CAAC,GAAG,EAAE,CAAC,MAAM,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;6DACb;AA1BhB,kBAAkB;IAD9B,UAAU,EAAE;GACA,kBAAkB,CA2B9B;;AAGM,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;IACnB,KAAK,CAAC,SAAS,CAAC,OAAe,EAAE,SAAkB,EAAE,UAAmB,EAAE,YAAqB,EAAE,4BAAqC,KAAK;QACjJ,MAAM,EAAE,GAAG,IAAI,QAAQ,EAAE,CAAC;QAG1B,MAAM,OAAO,GAAG,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE;YACpC,IAAI,OAAO,EAAE,CAAC;gBACZ,OAAO,CAAC,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,KAAK,OAAO,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;YACpE,CAAC;iBAAM,IAAI,SAAS,EAAE,CAAC;gBACrB,IAAI,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,KAAK,SAAS,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;gBAC7E,IAAI,UAAU,EAAE,CAAC;oBACf,OAAO,GAAG,OAAO,IAAI,CAAC,CAAC,UAAU,EAAE,IAAI,EAAE,CAAC,WAAW,EAAE,KAAK,UAAU,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;gBAC9F,CAAC;gBACD,IAAI,YAAY,EAAE,CAAC;oBACjB,OAAO,GAAG,OAAO,IAAI,CAAC,CAAC,QAAQ,EAAE,IAAI,EAAE,CAAC,WAAW,EAAE,KAAK,YAAY,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;gBAC9F,CAAC;gBACD,OAAO,OAAO,CAAC;YACjB,CAAC;YACD,OAAO,KAAK,CAAC;QACf,CAAC,CAAC,CAAC;QAEH,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzB,IAAI,yBAAyB,EAAE,CAAC;gBAE9B,MAAM,EAAE,CAAC,OAAO,EAAE,CAAC;gBACnB,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,YAAY,EAAE,KAAK,CAAC,CAAC;YAC7E,CAAC;iBACI,CAAC;gBACJ,OAAO,IAAI,CAAC;YACd,CAAC;QACH,CAAC;aACI,CAAC;YACJ,OAAO,OAAO,CAAC,CAAC,CAAC,CAAC;QACpB,CAAC;IACH,CAAC;IAEK,AAAN,KAAK,CAAC,YAAY,CAA+B,OAAe,EACtC,OAAmB,EACyB,UAAmB,EACjB,YAAqB,EACZ,UAAgC,EACjD,OAAgB,EACf,QAAiB;QAChF,MAAM,QAAQ,GAAG,IAAI,QAAQ,EAAE,CAAC;QAChC,OAAO,CAAC,GAAG,CAAC,2BAA2B,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAC;QACrF,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,QAAQ,CACpC;YACE,OAAO,EAAE,OAAO;YAChB,UAAU,EAAE,UAAU;YACtB,YAAY,EAAE,YAAY;YAC1B,UAAU,EAAE,UAAU;YACtB,OAAO,EAAE,OAAO;YAChB,QAAQ,EAAE,QAAQ;SACnB,EACD,OAAO,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;QAClC,OAAO,CAAC,GAAG,CAAC,kBAAkB,EAAE;YAC9B,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,YAAY,EAAE,MAAM,CAAC,YAAY;YACjC,iBAAiB,EAAE,MAAM,CAAC,iBAAiB;SAC5C,CAAC,CAAC;QAGH,IAAI,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC;QACjC,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,IAAI,CAAC;gBACH,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,YAAY,EAAE,IAAI,CAAC,CAAC;gBAC3F,IAAI,SAAS,EAAE,CAAC;oBACd,SAAS,GAAG,SAAS,CAAC,IAAI,CAAC;gBAC7B,CAAC;YACH,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,OAAO,CAAC,KAAK,CAAC,kCAAkC,EAAE,KAAK,CAAC,CAAC;YAC3D,CAAC;QACH,CAAC;QAED,OAAO;YACL,OAAO,EAAE,OAAO;YAChB,SAAS,EAAE,SAAS,IAAI,eAAe;YACvC,OAAO,EAAE,MAAM,CAAC,OAAO,IAAI,KAAK;YAChC,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,IAAI,IAAI,CAAC;YAC/C,QAAQ,EAAE,MAAM,CAAC,QAAQ,IAAI,CAAC;YAC9B,aAAa,EAAE,MAAM,CAAC,aAAa,IAAI,CAAC;YACxC,aAAa,EAAE,MAAM,CAAC,aAAa,IAAI,CAAC;YACxC,YAAY,EAAE,MAAM,CAAC,YAAY,IAAI,EAAE;YACvC,iBAAiB,EAAE,MAAM,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,SAAS;SACnG,CAAC;IACJ,CAAC;IAGK,AAAN,KAAK,CAAC,kBAAkB,CAAiC,SAAiB,EAC1C,OAAmB,EACyB,UAAmB,EACjB,YAAqB,EACZ,UAAgC,EACjD,OAAgB,EACf,QAAiB;QACtF,MAAM,QAAQ,GAAG,IAAI,QAAQ,EAAE,CAAC;QAChC,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,QAAQ,CACpC;YACE,SAAS,EAAE,SAAS;YACpB,UAAU,EAAE,UAAU;YACtB,YAAY,EAAE,YAAY;YAC1B,UAAU,EAAE,UAAU;YACtB,OAAO,EAAE,OAAO;YAChB,QAAQ,EAAE,QAAQ;SACnB,EACD,OAAO,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;QAElC,OAAO;YACL,OAAO,EAAE,MAAM,CAAC,OAAO,IAAI,EAAE;YAC7B,SAAS,EAAE,SAAS;YACpB,OAAO,EAAE,MAAM,CAAC,OAAO,IAAI,KAAK;YAChC,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,IAAI,IAAI,CAAC;YAC/C,QAAQ,EAAE,MAAM,CAAC,QAAQ,IAAI,CAAC;YAC9B,aAAa,EAAE,MAAM,CAAC,aAAa,IAAI,CAAC;YACxC,aAAa,EAAE,MAAM,CAAC,aAAa,IAAI,CAAC;YACxC,YAAY,EAAE,MAAM,CAAC,YAAY,IAAI,EAAE;YACvC,iBAAiB,EAAE,MAAM,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,SAAS;SACnG,CAAC;IACJ,CAAC;IAIK,AAAN,KAAK,CAAC,sBAAsB,CAA+B,OAAe,EACtC,OAAmB,EACyB,UAAmB,EACjB,YAAqB,EACZ,UAAgC,EACjD,OAAgB,EACf,QAAiB;QAC1F,MAAM,QAAQ,GAAG,IAAI,QAAQ,EAAE,CAAC;QAChC,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,QAAQ,CACpC;YACE,OAAO,EAAE,OAAO;YAChB,UAAU,EAAE,UAAU;YACtB,YAAY,EAAE,YAAY;YAC1B,UAAU,EAAE,UAAU;YACtB,OAAO,EAAE,OAAO;YAChB,QAAQ,EAAE,QAAQ;SACnB,EACD,OAAO,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;QAGlC,IAAI,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC;QACjC,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,IAAI,CAAC;gBACH,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,YAAY,EAAE,IAAI,CAAC,CAAC;gBAC3F,IAAI,SAAS,EAAE,CAAC;oBACd,SAAS,GAAG,SAAS,CAAC,IAAI,CAAC;gBAC7B,CAAC;YACH,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,OAAO,CAAC,KAAK,CAAC,kCAAkC,EAAE,KAAK,CAAC,CAAC;YAC3D,CAAC;QACH,CAAC;QAED,OAAO;YACL,OAAO,EAAE,OAAO;YAChB,SAAS,EAAE,SAAS,IAAI,eAAe;YACvC,OAAO,EAAE,MAAM,CAAC,OAAO,IAAI,KAAK;YAChC,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,IAAI,IAAI,CAAC;YAC/C,QAAQ,EAAE,MAAM,CAAC,QAAQ,IAAI,CAAC;YAC9B,aAAa,EAAE,MAAM,CAAC,aAAa,IAAI,CAAC;YACxC,aAAa,EAAE,MAAM,CAAC,aAAa,IAAI,CAAC;YACxC,YAAY,EAAE,MAAM,CAAC,YAAY,IAAI,EAAE;YACvC,iBAAiB,EAAE,MAAM,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,SAAS;SACnG,CAAC;IACJ,CAAC;CACF,CAAA;AAlIO;IADL,KAAK,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC;IACZ,WAAA,GAAG,CAAC,SAAS,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,CAAA;IAC5B,WAAA,GAAG,EAAE,CAAA;IACL,WAAA,GAAG,CAAC,YAAY,EAAE,GAAG,EAAE,CAAC,MAAM,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAA;IACjD,WAAA,GAAG,CAAC,cAAc,EAAE,GAAG,EAAE,CAAC,MAAM,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAA;IACnD,WAAA,GAAG,CAAC,YAAY,EAAE,GAAG,EAAE,CAAC,iBAAiB,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAA;IAC5D,WAAA,GAAG,CAAC,SAAS,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAA;IAC3C,WAAA,GAAG,CAAC,UAAU,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAA;;;;oDA2C/D;AAGK;IADL,KAAK,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC;IACN,WAAA,GAAG,CAAC,WAAW,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,CAAA;IAC9B,WAAA,GAAG,EAAE,CAAA;IACL,WAAA,GAAG,CAAC,YAAY,EAAE,GAAG,EAAE,CAAC,MAAM,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAA;IACjD,WAAA,GAAG,CAAC,cAAc,EAAE,GAAG,EAAE,CAAC,MAAM,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAA;IACnD,WAAA,GAAG,CAAC,YAAY,EAAE,GAAG,EAAE,CAAC,iBAAiB,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAA;IAC5D,WAAA,GAAG,CAAC,SAAS,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAA;IAC3C,WAAA,GAAG,CAAC,UAAU,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAA;;;;0DAwBrE;AAIK;IAFL,iBAAiB,EAAE;IACnB,KAAK,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC;IACF,WAAA,GAAG,CAAC,SAAS,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,CAAA;IAC5B,WAAA,GAAG,EAAE,CAAA;IACL,WAAA,GAAG,CAAC,YAAY,EAAE,GAAG,EAAE,CAAC,MAAM,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAA;IACjD,WAAA,GAAG,CAAC,cAAc,EAAE,GAAG,EAAE,CAAC,MAAM,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAA;IACnD,WAAA,GAAG,CAAC,YAAY,EAAE,GAAG,EAAE,CAAC,iBAAiB,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAA;IAC5D,WAAA,GAAG,CAAC,SAAS,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAA;IAC3C,WAAA,GAAG,CAAC,UAAU,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAA;;;;8DAqCzE;AArKU,gBAAgB;IAD5B,QAAQ,EAAE;GACE,gBAAgB,CAsK5B"}
|