@acorex/connectivity 21.0.0-next.1 → 21.0.0-next.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 (48) hide show
  1. package/api/index.d.ts +1 -59
  2. package/fesm2022/{acorex-connectivity-api-execute.command-SGNBLcOi.mjs → acorex-connectivity-api-execute.command-gIRQPxtq.mjs} +6 -6
  3. package/fesm2022/acorex-connectivity-api-execute.command-gIRQPxtq.mjs.map +1 -0
  4. package/fesm2022/acorex-connectivity-api.mjs +101 -185
  5. package/fesm2022/acorex-connectivity-api.mjs.map +1 -1
  6. package/fesm2022/{acorex-connectivity-mock-category-with-items.query-Dsxj98tX.mjs → acorex-connectivity-mock-category-with-items.query-Cl7T-rSS.mjs} +4 -4
  7. package/fesm2022/{acorex-connectivity-mock-category-with-items.query-Dsxj98tX.mjs.map → acorex-connectivity-mock-category-with-items.query-Cl7T-rSS.mjs.map} +1 -1
  8. package/fesm2022/acorex-connectivity-mock-complete-signature-process.command-MIKenDnl.mjs +80 -0
  9. package/fesm2022/acorex-connectivity-mock-complete-signature-process.command-MIKenDnl.mjs.map +1 -0
  10. package/fesm2022/{acorex-connectivity-mock-distribution-record.command-DRiDwlqN.mjs → acorex-connectivity-mock-distribution-record.command-D9MRsoPw.mjs} +4 -4
  11. package/fesm2022/{acorex-connectivity-mock-distribution-record.command-DRiDwlqN.mjs.map → acorex-connectivity-mock-distribution-record.command-D9MRsoPw.mjs.map} +1 -1
  12. package/fesm2022/acorex-connectivity-mock-get-application-versions-chart-data.query-H6rrh30t.mjs +115 -0
  13. package/fesm2022/acorex-connectivity-mock-get-application-versions-chart-data.query-H6rrh30t.mjs.map +1 -0
  14. package/fesm2022/acorex-connectivity-mock-get-application-versions-timeline.query-zuGKLAbn.mjs +163 -0
  15. package/fesm2022/acorex-connectivity-mock-get-application-versions-timeline.query-zuGKLAbn.mjs.map +1 -0
  16. package/fesm2022/acorex-connectivity-mock-get-product-chart-data.query-CQ75e_tN.mjs +186 -0
  17. package/fesm2022/acorex-connectivity-mock-get-product-chart-data.query-CQ75e_tN.mjs.map +1 -0
  18. package/fesm2022/acorex-connectivity-mock-get-product-list.query-OM16ygmJ.mjs +246 -0
  19. package/fesm2022/acorex-connectivity-mock-get-product-list.query-OM16ygmJ.mjs.map +1 -0
  20. package/fesm2022/acorex-connectivity-mock-get-product-pdf-data.query-DoR3awXg.mjs +192 -0
  21. package/fesm2022/acorex-connectivity-mock-get-product-pdf-data.query-DoR3awXg.mjs.map +1 -0
  22. package/fesm2022/acorex-connectivity-mock-get-subscriptions-chart-data.query-Dq779mtQ.mjs +56 -0
  23. package/fesm2022/acorex-connectivity-mock-get-subscriptions-chart-data.query-Dq779mtQ.mjs.map +1 -0
  24. package/fesm2022/acorex-connectivity-mock-get-subscriptions-timeline.query-gNwKFN0F.mjs +246 -0
  25. package/fesm2022/acorex-connectivity-mock-get-subscriptions-timeline.query-gNwKFN0F.mjs.map +1 -0
  26. package/fesm2022/acorex-connectivity-mock-get-tenant-application-access.query-C3OxqcSp.mjs +258 -0
  27. package/fesm2022/acorex-connectivity-mock-get-tenant-application-access.query-C3OxqcSp.mjs.map +1 -0
  28. package/fesm2022/acorex-connectivity-mock-get-tenant-registration-chart-data.query-v8jIyUEH.mjs +56 -0
  29. package/fesm2022/acorex-connectivity-mock-get-tenant-registration-chart-data.query-v8jIyUEH.mjs.map +1 -0
  30. package/fesm2022/acorex-connectivity-mock-get-tenant-registration-timeline.query-Da6nKdpq.mjs +294 -0
  31. package/fesm2022/acorex-connectivity-mock-get-tenant-registration-timeline.query-Da6nKdpq.mjs.map +1 -0
  32. package/fesm2022/acorex-connectivity-mock-get-tenant-user-distribution.query-T0qvGjtD.mjs +212 -0
  33. package/fesm2022/acorex-connectivity-mock-get-tenant-user-distribution.query-T0qvGjtD.mjs.map +1 -0
  34. package/fesm2022/acorex-connectivity-mock-notify-signers.command-CmXMibLx.mjs +69 -0
  35. package/fesm2022/acorex-connectivity-mock-notify-signers.command-CmXMibLx.mjs.map +1 -0
  36. package/fesm2022/acorex-connectivity-mock-request-signature.command-B6VZ5KeW.mjs +72 -0
  37. package/fesm2022/acorex-connectivity-mock-request-signature.command-B6VZ5KeW.mjs.map +1 -0
  38. package/fesm2022/{acorex-connectivity-mock-sample.command-CkH5bmEs.mjs → acorex-connectivity-mock-sample.command-BJJ67aLM.mjs} +4 -4
  39. package/fesm2022/{acorex-connectivity-mock-sample.command-CkH5bmEs.mjs.map → acorex-connectivity-mock-sample.command-BJJ67aLM.mjs.map} +1 -1
  40. package/fesm2022/acorex-connectivity-mock-validate-all-signatures.command-CG80T32a.mjs +81 -0
  41. package/fesm2022/acorex-connectivity-mock-validate-all-signatures.command-CG80T32a.mjs.map +1 -0
  42. package/fesm2022/acorex-connectivity-mock.mjs +46365 -46644
  43. package/fesm2022/acorex-connectivity-mock.mjs.map +1 -1
  44. package/fesm2022/acorex-connectivity-utils.mjs +7 -7
  45. package/fesm2022/acorex-connectivity-utils.mjs.map +1 -1
  46. package/mock/index.d.ts +336 -324
  47. package/package.json +2 -2
  48. package/fesm2022/acorex-connectivity-api-execute.command-SGNBLcOi.mjs.map +0 -1
@@ -0,0 +1,212 @@
1
+ import * as i0 from '@angular/core';
2
+ import { inject, Injectable } from '@angular/core';
3
+ import { AXPEntityService } from '@acorex/platform/layout/entity';
4
+ import { AXPSystemStatusType } from '@acorex/platform/common';
5
+ import { RootConfig } from '@acorex/modules/tenant-management';
6
+
7
+ //#endregion
8
+ class GetTenantUserDistributionQuery {
9
+ constructor() {
10
+ this.entityService = inject(AXPEntityService);
11
+ this.tenantService = this.entityService
12
+ .withEntity(`${RootConfig.module.name}.${RootConfig.entities.tenant.name}`)
13
+ .data();
14
+ this.tenantUserService = this.entityService
15
+ .withEntity(`${RootConfig.module.name}.${RootConfig.entities.tenantUser.name}`)
16
+ .data();
17
+ }
18
+ async fetch(input) {
19
+ // Extract filters from AXPFilterClause format
20
+ const extractedFilters = this.extractTenantFilters(input.filters);
21
+ const filterLogic = input.filters?.logic || input.logic || 'and';
22
+ // Separate custom filters from entity filters
23
+ const entityFilters = [];
24
+ let dateRangeFilter;
25
+ if (extractedFilters && extractedFilters.length > 0) {
26
+ for (const filter of extractedFilters) {
27
+ if (filter.field === 'dateRange') {
28
+ dateRangeFilter = filter.value;
29
+ }
30
+ else {
31
+ entityFilters.push(filter);
32
+ }
33
+ }
34
+ }
35
+ // Get all tenants
36
+ const tenantsResult = await this.tenantService.query({
37
+ skip: 0,
38
+ take: 10000,
39
+ filter: entityFilters.length > 0
40
+ ? {
41
+ logic: filterLogic,
42
+ filters: entityFilters,
43
+ }
44
+ : undefined,
45
+ });
46
+ let tenants = tenantsResult.items;
47
+ // Apply date range filter if provided
48
+ if (dateRangeFilter) {
49
+ tenants = this.applyDateRangeFilter(tenants, dateRangeFilter);
50
+ }
51
+ // Get all tenant users
52
+ const tenantUsersResult = await this.tenantUserService.query({
53
+ skip: 0,
54
+ take: 10000,
55
+ });
56
+ const tenantUsers = tenantUsersResult.items;
57
+ // Build results for each tenant
58
+ const results = [];
59
+ for (const tenant of tenants) {
60
+ // Get tenant's users
61
+ const tenantUsersList = tenantUsers.filter((tu) => tu.tenantId === tenant.id);
62
+ // Count active and inactive users
63
+ const activeUsers = tenantUsersList.filter((tu) => tu.statusId === AXPSystemStatusType.Active);
64
+ const inactiveUsers = tenantUsersList.filter((tu) => tu.statusId !== AXPSystemStatusType.Active);
65
+ // Calculate utilization percentage
66
+ const maxUsers = tenant.maxUsers;
67
+ const utilizationPercent = maxUsers && maxUsers > 0 ? Math.round((tenantUsersList.length / maxUsers) * 100) : 0;
68
+ results.push({
69
+ tenantId: tenant.id,
70
+ tenantName: tenant.title,
71
+ tenantStatus: tenant.statusId || 'Unknown',
72
+ totalUsersCount: tenantUsersList.length,
73
+ activeUsersCount: activeUsers.length,
74
+ inactiveUsersCount: inactiveUsers.length,
75
+ maxUsers: maxUsers,
76
+ utilizationPercent: utilizationPercent,
77
+ registrationDate: tenant.registrationDate,
78
+ registrationDateStr: tenant.registrationDate?.toISOString(),
79
+ });
80
+ }
81
+ // Apply sorting if provided
82
+ if (input.sort && input.sort.length > 0) {
83
+ results.sort((a, b) => {
84
+ for (const sortField of input.sort) {
85
+ const field = sortField.field;
86
+ const aValue = a[field];
87
+ const bValue = b[field];
88
+ const dir = sortField.dir === 'asc' ? 1 : -1;
89
+ if (aValue === undefined && bValue === undefined)
90
+ continue;
91
+ if (aValue === undefined)
92
+ return 1 * dir;
93
+ if (bValue === undefined)
94
+ return -1 * dir;
95
+ if (aValue < bValue)
96
+ return -1 * dir;
97
+ if (aValue > bValue)
98
+ return 1 * dir;
99
+ }
100
+ return 0;
101
+ });
102
+ }
103
+ else {
104
+ // Default sort by tenant name
105
+ results.sort((a, b) => a.tenantName.localeCompare(b.tenantName));
106
+ }
107
+ // Apply pagination
108
+ const skip = input.skip || 0;
109
+ const take = input.take || 10;
110
+ const total = results.length;
111
+ const items = results.slice(skip, skip + take);
112
+ return {
113
+ items,
114
+ total,
115
+ };
116
+ }
117
+ //#region ---- Filter Extraction ----
118
+ /**
119
+ * Extract tenant-specific filters from AXPFilterClause format
120
+ * Maps report parameter paths to tenant entity field names
121
+ */
122
+ extractTenantFilters(parameters) {
123
+ const filters = [];
124
+ const paramsAny = parameters;
125
+ if (!paramsAny?.filters || !Array.isArray(paramsAny.filters)) {
126
+ return filters;
127
+ }
128
+ for (const filter of paramsAny.filters) {
129
+ if (!filter?.field || filter?.value === undefined || filter?.value === null) {
130
+ continue;
131
+ }
132
+ const field = filter.field;
133
+ const value = filter.value;
134
+ const operator = filter.operator || { type: 'equal' };
135
+ // Handle tenant-specific field mappings
136
+ if (field === 'tenantId') {
137
+ // Tenant ID filter - can be array of IDs or single ID
138
+ if (Array.isArray(value) && value.length > 0) {
139
+ filters.push({
140
+ field: 'id',
141
+ operator: { type: 'in' },
142
+ value: value,
143
+ });
144
+ }
145
+ else if (value) {
146
+ filters.push({
147
+ field: 'id',
148
+ operator: { type: 'equal' },
149
+ value: value,
150
+ });
151
+ }
152
+ }
153
+ else if (field === 'statusId') {
154
+ // Status filter - skip 'all' value
155
+ if (value && value !== 'all') {
156
+ filters.push({
157
+ field: 'statusId',
158
+ operator: { type: 'equal' },
159
+ value: value,
160
+ });
161
+ }
162
+ }
163
+ else if (field === 'dateRange') {
164
+ // Date range filter - custom logic handled in query
165
+ filters.push({
166
+ field: 'dateRange',
167
+ operator: { type: 'equal' },
168
+ value: value,
169
+ });
170
+ }
171
+ else {
172
+ // Direct field mapping
173
+ filters.push({
174
+ field: field,
175
+ operator: operator,
176
+ value: value,
177
+ });
178
+ }
179
+ }
180
+ return filters;
181
+ }
182
+ //#endregion
183
+ //#region ---- Custom Filter Handlers ----
184
+ /**
185
+ * Apply date range filter to tenants
186
+ */
187
+ applyDateRangeFilter(tenants, dateRange) {
188
+ if (!dateRange || !dateRange.start || !dateRange.end) {
189
+ return tenants;
190
+ }
191
+ const startDate = new Date(dateRange.start);
192
+ const endDate = new Date(dateRange.end);
193
+ endDate.setHours(23, 59, 59, 999);
194
+ return tenants.filter((tenant) => {
195
+ if (!tenant.registrationDate)
196
+ return false;
197
+ const regDate = new Date(tenant.registrationDate);
198
+ return regDate >= startDate && regDate <= endDate;
199
+ });
200
+ }
201
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: GetTenantUserDistributionQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
202
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: GetTenantUserDistributionQuery, providedIn: 'root' }); }
203
+ }
204
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: GetTenantUserDistributionQuery, decorators: [{
205
+ type: Injectable,
206
+ args: [{
207
+ providedIn: 'root',
208
+ }]
209
+ }] });
210
+
211
+ export { GetTenantUserDistributionQuery };
212
+ //# sourceMappingURL=acorex-connectivity-mock-get-tenant-user-distribution.query-T0qvGjtD.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"acorex-connectivity-mock-get-tenant-user-distribution.query-T0qvGjtD.mjs","sources":["../tmp-esm2022/mock/lib/tenant-management/reports/get-tenant-user-distribution.query.js"],"sourcesContent":["import { inject, Injectable } from '@angular/core';\nimport { AXPEntityService } from '@acorex/platform/layout/entity';\nimport { AXPSystemStatusType } from '@acorex/platform/common';\nimport { RootConfig as TenantRootConfig } from '@acorex/modules/tenant-management';\nimport * as i0 from \"@angular/core\";\n//#endregion\nexport class GetTenantUserDistributionQuery {\n constructor() {\n this.entityService = inject(AXPEntityService);\n this.tenantService = this.entityService\n .withEntity(`${TenantRootConfig.module.name}.${TenantRootConfig.entities.tenant.name}`)\n .data();\n this.tenantUserService = this.entityService\n .withEntity(`${TenantRootConfig.module.name}.${TenantRootConfig.entities.tenantUser.name}`)\n .data();\n }\n async fetch(input) {\n // Extract filters from AXPFilterClause format\n const extractedFilters = this.extractTenantFilters(input.filters);\n const filterLogic = input.filters?.logic || input.logic || 'and';\n // Separate custom filters from entity filters\n const entityFilters = [];\n let dateRangeFilter;\n if (extractedFilters && extractedFilters.length > 0) {\n for (const filter of extractedFilters) {\n if (filter.field === 'dateRange') {\n dateRangeFilter = filter.value;\n }\n else {\n entityFilters.push(filter);\n }\n }\n }\n // Get all tenants\n const tenantsResult = await this.tenantService.query({\n skip: 0,\n take: 10000,\n filter: entityFilters.length > 0\n ? {\n logic: filterLogic,\n filters: entityFilters,\n }\n : undefined,\n });\n let tenants = tenantsResult.items;\n // Apply date range filter if provided\n if (dateRangeFilter) {\n tenants = this.applyDateRangeFilter(tenants, dateRangeFilter);\n }\n // Get all tenant users\n const tenantUsersResult = await this.tenantUserService.query({\n skip: 0,\n take: 10000,\n });\n const tenantUsers = tenantUsersResult.items;\n // Build results for each tenant\n const results = [];\n for (const tenant of tenants) {\n // Get tenant's users\n const tenantUsersList = tenantUsers.filter((tu) => tu.tenantId === tenant.id);\n // Count active and inactive users\n const activeUsers = tenantUsersList.filter((tu) => tu.statusId === AXPSystemStatusType.Active);\n const inactiveUsers = tenantUsersList.filter((tu) => tu.statusId !== AXPSystemStatusType.Active);\n // Calculate utilization percentage\n const maxUsers = tenant.maxUsers;\n const utilizationPercent = maxUsers && maxUsers > 0 ? Math.round((tenantUsersList.length / maxUsers) * 100) : 0;\n results.push({\n tenantId: tenant.id,\n tenantName: tenant.title,\n tenantStatus: tenant.statusId || 'Unknown',\n totalUsersCount: tenantUsersList.length,\n activeUsersCount: activeUsers.length,\n inactiveUsersCount: inactiveUsers.length,\n maxUsers: maxUsers,\n utilizationPercent: utilizationPercent,\n registrationDate: tenant.registrationDate,\n registrationDateStr: tenant.registrationDate?.toISOString(),\n });\n }\n // Apply sorting if provided\n if (input.sort && input.sort.length > 0) {\n results.sort((a, b) => {\n for (const sortField of input.sort) {\n const field = sortField.field;\n const aValue = a[field];\n const bValue = b[field];\n const dir = sortField.dir === 'asc' ? 1 : -1;\n if (aValue === undefined && bValue === undefined)\n continue;\n if (aValue === undefined)\n return 1 * dir;\n if (bValue === undefined)\n return -1 * dir;\n if (aValue < bValue)\n return -1 * dir;\n if (aValue > bValue)\n return 1 * dir;\n }\n return 0;\n });\n }\n else {\n // Default sort by tenant name\n results.sort((a, b) => a.tenantName.localeCompare(b.tenantName));\n }\n // Apply pagination\n const skip = input.skip || 0;\n const take = input.take || 10;\n const total = results.length;\n const items = results.slice(skip, skip + take);\n return {\n items,\n total,\n };\n }\n //#region ---- Filter Extraction ----\n /**\n * Extract tenant-specific filters from AXPFilterClause format\n * Maps report parameter paths to tenant entity field names\n */\n extractTenantFilters(parameters) {\n const filters = [];\n const paramsAny = parameters;\n if (!paramsAny?.filters || !Array.isArray(paramsAny.filters)) {\n return filters;\n }\n for (const filter of paramsAny.filters) {\n if (!filter?.field || filter?.value === undefined || filter?.value === null) {\n continue;\n }\n const field = filter.field;\n const value = filter.value;\n const operator = filter.operator || { type: 'equal' };\n // Handle tenant-specific field mappings\n if (field === 'tenantId') {\n // Tenant ID filter - can be array of IDs or single ID\n if (Array.isArray(value) && value.length > 0) {\n filters.push({\n field: 'id',\n operator: { type: 'in' },\n value: value,\n });\n }\n else if (value) {\n filters.push({\n field: 'id',\n operator: { type: 'equal' },\n value: value,\n });\n }\n }\n else if (field === 'statusId') {\n // Status filter - skip 'all' value\n if (value && value !== 'all') {\n filters.push({\n field: 'statusId',\n operator: { type: 'equal' },\n value: value,\n });\n }\n }\n else if (field === 'dateRange') {\n // Date range filter - custom logic handled in query\n filters.push({\n field: 'dateRange',\n operator: { type: 'equal' },\n value: value,\n });\n }\n else {\n // Direct field mapping\n filters.push({\n field: field,\n operator: operator,\n value: value,\n });\n }\n }\n return filters;\n }\n //#endregion\n //#region ---- Custom Filter Handlers ----\n /**\n * Apply date range filter to tenants\n */\n applyDateRangeFilter(tenants, dateRange) {\n if (!dateRange || !dateRange.start || !dateRange.end) {\n return tenants;\n }\n const startDate = new Date(dateRange.start);\n const endDate = new Date(dateRange.end);\n endDate.setHours(23, 59, 59, 999);\n return tenants.filter((tenant) => {\n if (!tenant.registrationDate)\n return false;\n const regDate = new Date(tenant.registrationDate);\n return regDate >= startDate && regDate <= endDate;\n });\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: GetTenantUserDistributionQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: GetTenantUserDistributionQuery, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: GetTenantUserDistributionQuery, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root',\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"get-tenant-user-distribution.query.js","sourceRoot":"","sources":["../../../../../../../../libs/connectivity/mock/src/lib/tenant-management/reports/get-tenant-user-distribution.query.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injectable } from '@angular/core';\nimport { AXPQuery } from '@acorex/platform/runtime';\nimport { AXPEntityService } from '@acorex/platform/layout/entity';\nimport { AXMTenantManagementTenantEntityModel } from '@acorex/modules/tenant-management';\nimport { AXMTenantManagementTenantUserEntityModel } from '@acorex/modules/tenant-management';\nimport { AXPSystemStatusType } from '@acorex/platform/common';\nimport { RootConfig as TenantRootConfig } from '@acorex/modules/tenant-management';\n\n//#region ----   Query Input/Output Types   ----\n\nexport interface GetTenantUserDistributionQueryInput {\n  skip?: number;\n  take?: number;\n  sort?: Array<{ field: string; dir: 'asc' | 'desc' }>;\n  filters?: Array<{\n    field: string;\n    operator: { type: string };\n    value: any;\n  }>;\n  logic?: 'and' | 'or';\n}\n\nexport interface TenantUserDistributionResult {\n  tenantId: string;\n  tenantName: string;\n  tenantStatus: string;\n  totalUsersCount: number;\n  activeUsersCount: number;\n  inactiveUsersCount: number;\n  maxUsers?: number;\n  utilizationPercent: number;\n  registrationDate?: Date;\n  registrationDateStr?: string;\n}\n\nexport interface GetTenantUserDistributionQueryResult {\n  items: TenantUserDistributionResult[];\n  total: number;\n}\n\n//#endregion\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class GetTenantUserDistributionQuery\n  implements AXPQuery<GetTenantUserDistributionQueryInput, GetTenantUserDistributionQueryResult>\n{\n  private readonly entityService = inject(AXPEntityService);\n  private tenantService = this.entityService\n    .withEntity(`${TenantRootConfig.module.name}.${TenantRootConfig.entities.tenant.name}`)\n    .data<string, AXMTenantManagementTenantEntityModel>();\n  private tenantUserService = this.entityService\n    .withEntity(`${TenantRootConfig.module.name}.${TenantRootConfig.entities.tenantUser.name}`)\n    .data<string, AXMTenantManagementTenantUserEntityModel>();\n\n  async fetch(input: GetTenantUserDistributionQueryInput | any): Promise<GetTenantUserDistributionQueryResult> {\n    // Extract filters from AXPFilterClause format\n    const extractedFilters = this.extractTenantFilters(input.filters);\n    const filterLogic = (input.filters as any)?.logic || input.logic || 'and';\n\n    // Separate custom filters from entity filters\n    const entityFilters: GetTenantUserDistributionQueryInput['filters'] = [];\n    let dateRangeFilter: any;\n\n    if (extractedFilters && extractedFilters.length > 0) {\n      for (const filter of extractedFilters) {\n        if (filter.field === 'dateRange') {\n          dateRangeFilter = filter.value;\n        } else {\n          entityFilters.push(filter);\n        }\n      }\n    }\n\n    // Get all tenants\n    const tenantsResult = await this.tenantService.query({\n      skip: 0,\n      take: 10000,\n      filter:\n        entityFilters.length > 0\n          ? ({\n            logic: filterLogic,\n            filters: entityFilters,\n          } as any)\n          : undefined,\n    });\n\n    let tenants = tenantsResult.items;\n\n    // Apply date range filter if provided\n    if (dateRangeFilter) {\n      tenants = this.applyDateRangeFilter(tenants, dateRangeFilter);\n    }\n\n    // Get all tenant users\n    const tenantUsersResult = await this.tenantUserService.query({\n      skip: 0,\n      take: 10000,\n    });\n    const tenantUsers = tenantUsersResult.items;\n\n    // Build results for each tenant\n    const results: TenantUserDistributionResult[] = [];\n\n    for (const tenant of tenants) {\n      // Get tenant's users\n      const tenantUsersList = tenantUsers.filter((tu) => tu.tenantId === tenant.id);\n\n      // Count active and inactive users\n      const activeUsers = tenantUsersList.filter(\n        (tu) => tu.statusId === AXPSystemStatusType.Active\n      );\n      const inactiveUsers = tenantUsersList.filter(\n        (tu) => tu.statusId !== AXPSystemStatusType.Active\n      );\n\n      // Calculate utilization percentage\n      const maxUsers = tenant.maxUsers;\n      const utilizationPercent =\n        maxUsers && maxUsers > 0 ? Math.round((tenantUsersList.length / maxUsers) * 100) : 0;\n\n      results.push({\n        tenantId: tenant.id,\n        tenantName: tenant.title,\n        tenantStatus: tenant.statusId || 'Unknown',\n        totalUsersCount: tenantUsersList.length,\n        activeUsersCount: activeUsers.length,\n        inactiveUsersCount: inactiveUsers.length,\n        maxUsers: maxUsers,\n        utilizationPercent: utilizationPercent,\n        registrationDate: tenant.registrationDate,\n        registrationDateStr: tenant.registrationDate?.toISOString(),\n      });\n    }\n\n    // Apply sorting if provided\n    if (input.sort && input.sort.length > 0) {\n      results.sort((a, b) => {\n        for (const sortField of input.sort!) {\n          const field = sortField.field as keyof TenantUserDistributionResult;\n          const aValue = a[field];\n          const bValue = b[field];\n          const dir = sortField.dir === 'asc' ? 1 : -1;\n\n          if (aValue === undefined && bValue === undefined) continue;\n          if (aValue === undefined) return 1 * dir;\n          if (bValue === undefined) return -1 * dir;\n\n          if (aValue < bValue) return -1 * dir;\n          if (aValue > bValue) return 1 * dir;\n        }\n        return 0;\n      });\n    } else {\n      // Default sort by tenant name\n      results.sort((a, b) => a.tenantName.localeCompare(b.tenantName));\n    }\n\n    // Apply pagination\n    const skip = input.skip || 0;\n    const take = input.take || 10;\n    const total = results.length;\n    const items = results.slice(skip, skip + take);\n\n    return {\n      items,\n      total,\n    };\n  }\n\n  //#region ----   Filter Extraction   ----\n\n  /**\n   * Extract tenant-specific filters from AXPFilterClause format\n   * Maps report parameter paths to tenant entity field names\n   */\n  private extractTenantFilters(parameters: any): GetTenantUserDistributionQueryInput['filters'] {\n    const filters: GetTenantUserDistributionQueryInput['filters'] = [];\n    const paramsAny = parameters as any;\n\n    if (!paramsAny?.filters || !Array.isArray(paramsAny.filters)) {\n      return filters;\n    }\n\n    for (const filter of paramsAny.filters) {\n      if (!filter?.field || filter?.value === undefined || filter?.value === null) {\n        continue;\n      }\n\n      const field = filter.field;\n      const value = filter.value;\n      const operator = filter.operator || { type: 'equal' };\n\n      // Handle tenant-specific field mappings\n      if (field === 'tenantId') {\n        // Tenant ID filter - can be array of IDs or single ID\n        if (Array.isArray(value) && value.length > 0) {\n          filters.push({\n            field: 'id',\n            operator: { type: 'in' },\n            value: value,\n          });\n        } else if (value) {\n          filters.push({\n            field: 'id',\n            operator: { type: 'equal' },\n            value: value,\n          });\n        }\n      } else if (field === 'statusId') {\n        // Status filter - skip 'all' value\n        if (value && value !== 'all') {\n          filters.push({\n            field: 'statusId',\n            operator: { type: 'equal' },\n            value: value,\n          });\n        }\n      } else if (field === 'dateRange') {\n        // Date range filter - custom logic handled in query\n        filters.push({\n          field: 'dateRange',\n          operator: { type: 'equal' },\n          value: value,\n        });\n      } else {\n        // Direct field mapping\n        filters.push({\n          field: field,\n          operator: operator,\n          value: value,\n        });\n      }\n    }\n\n    return filters;\n  }\n\n  //#endregion\n\n  //#region ----   Custom Filter Handlers   ----\n\n  /**\n   * Apply date range filter to tenants\n   */\n  private applyDateRangeFilter(\n    tenants: AXMTenantManagementTenantEntityModel[],\n    dateRange: any\n  ): AXMTenantManagementTenantEntityModel[] {\n    if (!dateRange || !dateRange.start || !dateRange.end) {\n      return tenants;\n    }\n\n    const startDate = new Date(dateRange.start);\n    const endDate = new Date(dateRange.end);\n    endDate.setHours(23, 59, 59, 999);\n\n    return tenants.filter((tenant) => {\n      if (!tenant.registrationDate) return false;\n      const regDate = new Date(tenant.registrationDate);\n      return regDate >= startDate && regDate <= endDate;\n    });\n  }\n\n  //#endregion\n}\n\n"]}"],"names":["TenantRootConfig"],"mappings":"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"}
@@ -0,0 +1,69 @@
1
+ import * as i0 from '@angular/core';
2
+ import { Injectable } from '@angular/core';
3
+
4
+ //#endregion
5
+ /**
6
+ * Notify Signers Command (Backend - Mock)
7
+ *
8
+ * Sends notifications to signers about the signature request.
9
+ * This command runs on the backend and handles notification delivery.
10
+ */
11
+ class AXCNotifySignersCommand {
12
+ //#region ---- AXPCommand Implementation ----
13
+ async execute(input) {
14
+ try {
15
+ console.log(`[AXCNotifySignersCommand] Notifying ${input.signers.length} signers for request: ${input.signatureRequestId}`);
16
+ // Validate inputs
17
+ if (!input.signatureRequestId || !input.signers || input.signers.length === 0) {
18
+ throw new Error('Invalid input: signatureRequestId and at least one signer are required');
19
+ }
20
+ // In a real implementation, this would:
21
+ // 1. Send email notifications to each signer
22
+ // 2. Send in-app notifications
23
+ // 3. Create notification records
24
+ // 4. Track notification delivery status
25
+ // Mock: simulate notification sending
26
+ const notifiedCount = input.signers.length;
27
+ console.log(`[AXCNotifySignersCommand] Successfully notified ${notifiedCount} signers`);
28
+ return {
29
+ success: true,
30
+ data: {
31
+ output: {
32
+ notifiedCount,
33
+ },
34
+ outcomes: {
35
+ Done: true,
36
+ },
37
+ },
38
+ };
39
+ }
40
+ catch (error) {
41
+ console.error(`[AXCNotifySignersCommand] Failed to notify signers:`, error);
42
+ return {
43
+ success: false,
44
+ message: {
45
+ text: error.message || 'Failed to notify signers',
46
+ },
47
+ data: {
48
+ output: {
49
+ notifiedCount: 0,
50
+ },
51
+ outcomes: {
52
+ Failed: true,
53
+ },
54
+ },
55
+ };
56
+ }
57
+ }
58
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXCNotifySignersCommand, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
59
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXCNotifySignersCommand, providedIn: 'root' }); }
60
+ }
61
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXCNotifySignersCommand, decorators: [{
62
+ type: Injectable,
63
+ args: [{
64
+ providedIn: 'root',
65
+ }]
66
+ }] });
67
+
68
+ export { AXCNotifySignersCommand };
69
+ //# sourceMappingURL=acorex-connectivity-mock-notify-signers.command-CmXMibLx.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"acorex-connectivity-mock-notify-signers.command-CmXMibLx.mjs","sources":["../tmp-esm2022/mock/lib/workflow-management/commands/notify-signers.command.js"],"sourcesContent":["import { Injectable } from '@angular/core';\nimport * as i0 from \"@angular/core\";\n//#endregion\n/**\n * Notify Signers Command (Backend - Mock)\n *\n * Sends notifications to signers about the signature request.\n * This command runs on the backend and handles notification delivery.\n */\nexport class AXCNotifySignersCommand {\n //#region ---- AXPCommand Implementation ----\n async execute(input) {\n try {\n console.log(`[AXCNotifySignersCommand] Notifying ${input.signers.length} signers for request: ${input.signatureRequestId}`);\n // Validate inputs\n if (!input.signatureRequestId || !input.signers || input.signers.length === 0) {\n throw new Error('Invalid input: signatureRequestId and at least one signer are required');\n }\n // In a real implementation, this would:\n // 1. Send email notifications to each signer\n // 2. Send in-app notifications\n // 3. Create notification records\n // 4. Track notification delivery status\n // Mock: simulate notification sending\n const notifiedCount = input.signers.length;\n console.log(`[AXCNotifySignersCommand] Successfully notified ${notifiedCount} signers`);\n return {\n success: true,\n data: {\n output: {\n notifiedCount,\n },\n outcomes: {\n Done: true,\n },\n },\n };\n }\n catch (error) {\n console.error(`[AXCNotifySignersCommand] Failed to notify signers:`, error);\n return {\n success: false,\n message: {\n text: error.message || 'Failed to notify signers',\n },\n data: {\n output: {\n notifiedCount: 0,\n },\n outcomes: {\n Failed: true,\n },\n },\n };\n }\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: AXCNotifySignersCommand, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: AXCNotifySignersCommand, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: AXCNotifySignersCommand, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root',\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZ5LXNpZ25lcnMuY29tbWFuZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29ubmVjdGl2aXR5L21vY2svc3JjL2xpYi93b3JrZmxvdy1tYW5hZ2VtZW50L2NvbW1hbmRzL25vdGlmeS1zaWduZXJzLmNvbW1hbmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFnQjNDLFlBQVk7QUFFWjs7Ozs7R0FLRztBQUlILE1BQU0sT0FBTyx1QkFBdUI7SUFFbEMsaURBQWlEO0lBRWpELEtBQUssQ0FBQyxPQUFPLENBQ1gsS0FBZ0M7UUFFaEMsSUFBSSxDQUFDO1lBQ0gsT0FBTyxDQUFDLEdBQUcsQ0FBQyx1Q0FBdUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxNQUFNLHlCQUF5QixLQUFLLENBQUMsa0JBQWtCLEVBQUUsQ0FBQyxDQUFDO1lBRTVILGtCQUFrQjtZQUNsQixJQUFJLENBQUMsS0FBSyxDQUFDLGtCQUFrQixJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUUsQ0FBQztnQkFDOUUsTUFBTSxJQUFJLEtBQUssQ0FBQyx3RUFBd0UsQ0FBQyxDQUFDO1lBQzVGLENBQUM7WUFFRCx3Q0FBd0M7WUFDeEMsNkNBQTZDO1lBQzdDLCtCQUErQjtZQUMvQixpQ0FBaUM7WUFDakMsd0NBQXdDO1lBRXhDLHNDQUFzQztZQUN0QyxNQUFNLGFBQWEsR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQztZQUUzQyxPQUFPLENBQUMsR0FBRyxDQUFDLG1EQUFtRCxhQUFhLFVBQVUsQ0FBQyxDQUFDO1lBRXhGLE9BQU87Z0JBQ0wsT0FBTyxFQUFFLElBQUk7Z0JBQ2IsSUFBSSxFQUFFO29CQUNKLE1BQU0sRUFBRTt3QkFDTixhQUFhO3FCQUNkO29CQUNELFFBQVEsRUFBRTt3QkFDUixJQUFJLEVBQUUsSUFBSTtxQkFDWDtpQkFDRjthQUNGLENBQUM7UUFDSixDQUFDO1FBQUMsT0FBTyxLQUFVLEVBQUUsQ0FBQztZQUNwQixPQUFPLENBQUMsS0FBSyxDQUFDLHFEQUFxRCxFQUFFLEtBQUssQ0FBQyxDQUFDO1lBRTVFLE9BQU87Z0JBQ0wsT0FBTyxFQUFFLEtBQUs7Z0JBQ2QsT0FBTyxFQUFFO29CQUNQLElBQUksRUFBRSxLQUFLLENBQUMsT0FBTyxJQUFJLDBCQUEwQjtpQkFDbEQ7Z0JBQ0QsSUFBSSxFQUFFO29CQUNKLE1BQU0sRUFBRTt3QkFDTixhQUFhLEVBQUUsQ0FBQztxQkFDakI7b0JBQ0QsUUFBUSxFQUFFO3dCQUNSLE1BQU0sRUFBRSxJQUFJO3FCQUNiO2lCQUNGO2FBQ0YsQ0FBQztRQUNKLENBQUM7SUFDSCxDQUFDOytHQXZEVSx1QkFBdUI7bUhBQXZCLHVCQUF1QixjQUZ0QixNQUFNOzs0RkFFUCx1QkFBdUI7a0JBSG5DLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQVhQRXhlY3V0ZUNvbW1hbmRSZXN1bHQgfSBmcm9tICdAYWNvcmV4L3BsYXRmb3JtL2NvcmUnO1xuaW1wb3J0IHsgQVhQQ29tbWFuZCB9IGZyb20gJ0BhY29yZXgvcGxhdGZvcm0vcnVudGltZSc7XG5cbi8vI3JlZ2lvbiAtLS0tICAgVHlwZXMgICAtLS0tXG5cbmV4cG9ydCBpbnRlcmZhY2UgTm90aWZ5U2lnbmVyc0NvbW1hbmRJbnB1dCB7XG4gIHNpZ25hdHVyZVJlcXVlc3RJZDogc3RyaW5nO1xuICBzaWduZXJzOiBzdHJpbmdbXTtcbiAgbWVzc2FnZT86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBOb3RpZnlTaWduZXJzQ29tbWFuZE91dHB1dCB7XG4gIG5vdGlmaWVkQ291bnQ6IG51bWJlcjtcbn1cblxuLy8jZW5kcmVnaW9uXG5cbi8qKlxuICogTm90aWZ5IFNpZ25lcnMgQ29tbWFuZCAoQmFja2VuZCAtIE1vY2spXG4gKiBcbiAqIFNlbmRzIG5vdGlmaWNhdGlvbnMgdG8gc2lnbmVycyBhYm91dCB0aGUgc2lnbmF0dXJlIHJlcXVlc3QuXG4gKiBUaGlzIGNvbW1hbmQgcnVucyBvbiB0aGUgYmFja2VuZCBhbmQgaGFuZGxlcyBub3RpZmljYXRpb24gZGVsaXZlcnkuXG4gKi9cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBBWENOb3RpZnlTaWduZXJzQ29tbWFuZFxuICBpbXBsZW1lbnRzIEFYUENvbW1hbmQ8Tm90aWZ5U2lnbmVyc0NvbW1hbmRJbnB1dCwgeyBvdXRwdXQ6IE5vdGlmeVNpZ25lcnNDb21tYW5kT3V0cHV0OyBvdXRjb21lczogUmVjb3JkPHN0cmluZywgYW55PiB9PiB7XG4gIC8vI3JlZ2lvbiAtLS0tICAgQVhQQ29tbWFuZCBJbXBsZW1lbnRhdGlvbiAgIC0tLS1cblxuICBhc3luYyBleGVjdXRlKFxuICAgIGlucHV0OiBOb3RpZnlTaWduZXJzQ29tbWFuZElucHV0LFxuICApOiBQcm9taXNlPEFYUEV4ZWN1dGVDb21tYW5kUmVzdWx0PHsgb3V0cHV0OiBOb3RpZnlTaWduZXJzQ29tbWFuZE91dHB1dDsgb3V0Y29tZXM6IFJlY29yZDxzdHJpbmcsIGFueT4gfT4+IHtcbiAgICB0cnkge1xuICAgICAgY29uc29sZS5sb2coYFtBWENOb3RpZnlTaWduZXJzQ29tbWFuZF0gTm90aWZ5aW5nICR7aW5wdXQuc2lnbmVycy5sZW5ndGh9IHNpZ25lcnMgZm9yIHJlcXVlc3Q6ICR7aW5wdXQuc2lnbmF0dXJlUmVxdWVzdElkfWApO1xuXG4gICAgICAvLyBWYWxpZGF0ZSBpbnB1dHNcbiAgICAgIGlmICghaW5wdXQuc2lnbmF0dXJlUmVxdWVzdElkIHx8ICFpbnB1dC5zaWduZXJzIHx8IGlucHV0LnNpZ25lcnMubGVuZ3RoID09PSAwKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcignSW52YWxpZCBpbnB1dDogc2lnbmF0dXJlUmVxdWVzdElkIGFuZCBhdCBsZWFzdCBvbmUgc2lnbmVyIGFyZSByZXF1aXJlZCcpO1xuICAgICAgfVxuXG4gICAgICAvLyBJbiBhIHJlYWwgaW1wbGVtZW50YXRpb24sIHRoaXMgd291bGQ6XG4gICAgICAvLyAxLiBTZW5kIGVtYWlsIG5vdGlmaWNhdGlvbnMgdG8gZWFjaCBzaWduZXJcbiAgICAgIC8vIDIuIFNlbmQgaW4tYXBwIG5vdGlmaWNhdGlvbnNcbiAgICAgIC8vIDMuIENyZWF0ZSBub3RpZmljYXRpb24gcmVjb3Jkc1xuICAgICAgLy8gNC4gVHJhY2sgbm90aWZpY2F0aW9uIGRlbGl2ZXJ5IHN0YXR1c1xuXG4gICAgICAvLyBNb2NrOiBzaW11bGF0ZSBub3RpZmljYXRpb24gc2VuZGluZ1xuICAgICAgY29uc3Qgbm90aWZpZWRDb3VudCA9IGlucHV0LnNpZ25lcnMubGVuZ3RoO1xuXG4gICAgICBjb25zb2xlLmxvZyhgW0FYQ05vdGlmeVNpZ25lcnNDb21tYW5kXSBTdWNjZXNzZnVsbHkgbm90aWZpZWQgJHtub3RpZmllZENvdW50fSBzaWduZXJzYCk7XG5cbiAgICAgIHJldHVybiB7XG4gICAgICAgIHN1Y2Nlc3M6IHRydWUsXG4gICAgICAgIGRhdGE6IHtcbiAgICAgICAgICBvdXRwdXQ6IHtcbiAgICAgICAgICAgIG5vdGlmaWVkQ291bnQsXG4gICAgICAgICAgfSxcbiAgICAgICAgICBvdXRjb21lczoge1xuICAgICAgICAgICAgRG9uZTogdHJ1ZSxcbiAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgICAgfTtcbiAgICB9IGNhdGNoIChlcnJvcjogYW55KSB7XG4gICAgICBjb25zb2xlLmVycm9yKGBbQVhDTm90aWZ5U2lnbmVyc0NvbW1hbmRdIEZhaWxlZCB0byBub3RpZnkgc2lnbmVyczpgLCBlcnJvcik7XG5cbiAgICAgIHJldHVybiB7XG4gICAgICAgIHN1Y2Nlc3M6IGZhbHNlLFxuICAgICAgICBtZXNzYWdlOiB7XG4gICAgICAgICAgdGV4dDogZXJyb3IubWVzc2FnZSB8fCAnRmFpbGVkIHRvIG5vdGlmeSBzaWduZXJzJyxcbiAgICAgICAgfSxcbiAgICAgICAgZGF0YToge1xuICAgICAgICAgIG91dHB1dDoge1xuICAgICAgICAgICAgbm90aWZpZWRDb3VudDogMCxcbiAgICAgICAgICB9LFxuICAgICAgICAgIG91dGNvbWVzOiB7XG4gICAgICAgICAgICBGYWlsZWQ6IHRydWUsXG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgIH07XG4gICAgfVxuICB9XG5cbiAgLy8jZW5kcmVnaW9uXG59XG5cbiJdfQ=="],"names":[],"mappings":";;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,MAAM,uBAAuB,CAAC;AACrC;AACA,IAAI,MAAM,OAAO,CAAC,KAAK,EAAE;AACzB,QAAQ,IAAI;AACZ,YAAY,OAAO,CAAC,GAAG,CAAC,CAAC,oCAAoC,EAAE,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,sBAAsB,EAAE,KAAK,CAAC,kBAAkB,CAAC,CAAC,CAAC;AACvI;AACA,YAAY,IAAI,CAAC,KAAK,CAAC,kBAAkB,IAAI,CAAC,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;AAC3F,gBAAgB,MAAM,IAAI,KAAK,CAAC,wEAAwE,CAAC;AACzG,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,MAAM,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM;AACtD,YAAY,OAAO,CAAC,GAAG,CAAC,CAAC,gDAAgD,EAAE,aAAa,CAAC,QAAQ,CAAC,CAAC;AACnG,YAAY,OAAO;AACnB,gBAAgB,OAAO,EAAE,IAAI;AAC7B,gBAAgB,IAAI,EAAE;AACtB,oBAAoB,MAAM,EAAE;AAC5B,wBAAwB,aAAa;AACrC,qBAAqB;AACrB,oBAAoB,QAAQ,EAAE;AAC9B,wBAAwB,IAAI,EAAE,IAAI;AAClC,qBAAqB;AACrB,iBAAiB;AACjB,aAAa;AACb,QAAQ;AACR,QAAQ,OAAO,KAAK,EAAE;AACtB,YAAY,OAAO,CAAC,KAAK,CAAC,CAAC,mDAAmD,CAAC,EAAE,KAAK,CAAC;AACvF,YAAY,OAAO;AACnB,gBAAgB,OAAO,EAAE,KAAK;AAC9B,gBAAgB,OAAO,EAAE;AACzB,oBAAoB,IAAI,EAAE,KAAK,CAAC,OAAO,IAAI,0BAA0B;AACrE,iBAAiB;AACjB,gBAAgB,IAAI,EAAE;AACtB,oBAAoB,MAAM,EAAE;AAC5B,wBAAwB,aAAa,EAAE,CAAC;AACxC,qBAAqB;AACrB,oBAAoB,QAAQ,EAAE;AAC9B,wBAAwB,MAAM,EAAE,IAAI;AACpC,qBAAqB;AACrB,iBAAiB;AACjB,aAAa;AACb,QAAQ;AACR,IAAI;AACJ,IAAI,SAAS,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC,kBAAkB,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,uBAAuB,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,CAAC,eAAe,CAAC,UAAU,EAAE,CAAC,CAAC;AAC3L,IAAI,SAAS,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC,qBAAqB,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,uBAAuB,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC,CAAC;AAClK;AACA,EAAE,CAAC,wBAAwB,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,uBAAuB,EAAE,UAAU,EAAE,CAAC;AAClI,YAAY,IAAI,EAAE,UAAU;AAC5B,YAAY,IAAI,EAAE,CAAC;AACnB,oBAAoB,UAAU,EAAE,MAAM;AACtC,iBAAiB;AACjB,SAAS,CAAC,EAAE,CAAC;;;;"}
@@ -0,0 +1,72 @@
1
+ import * as i0 from '@angular/core';
2
+ import { Injectable } from '@angular/core';
3
+ import { AXPDataGenerator } from '@acorex/platform/core';
4
+
5
+ //#endregion
6
+ /**
7
+ * Request Signature Command (Backend - Mock)
8
+ *
9
+ * Creates a new signature request for an entity record.
10
+ * This command runs on the backend and initializes the signature process.
11
+ */
12
+ class AXCRequestSignatureCommand {
13
+ //#region ---- AXPCommand Implementation ----
14
+ async execute(input) {
15
+ try {
16
+ console.log(`[AXCRequestSignatureCommand] Creating signature request for ${input.refType}:${input.refId}`);
17
+ // Validate inputs
18
+ if (!input.refId || !input.refType || !input.signers || input.signers.length === 0) {
19
+ throw new Error('Invalid input: refId, refType, and at least one signer are required');
20
+ }
21
+ // Generate unique signature request ID
22
+ const signatureRequestId = AXPDataGenerator.uuid();
23
+ // In a real implementation, this would:
24
+ // 1. Create a signature request record in the database
25
+ // 2. Initialize signature tracking for each signer
26
+ // 3. Set initial status to 'pending'
27
+ // 4. Store workflow instance ID if provided
28
+ console.log(`[AXCRequestSignatureCommand] Created signature request: ${signatureRequestId} for ${input.signers.length} signers`);
29
+ return {
30
+ success: true,
31
+ data: {
32
+ output: {
33
+ signatureRequestId,
34
+ workflowInstanceId: input.workflowName ? `${input.workflowName}-${signatureRequestId}` : undefined,
35
+ },
36
+ outcomes: {
37
+ Done: true,
38
+ },
39
+ },
40
+ };
41
+ }
42
+ catch (error) {
43
+ console.error(`[AXCRequestSignatureCommand] Failed to create signature request:`, error);
44
+ return {
45
+ success: false,
46
+ message: {
47
+ text: error.message || 'Failed to create signature request',
48
+ },
49
+ data: {
50
+ output: {
51
+ signatureRequestId: '',
52
+ workflowInstanceId: undefined,
53
+ },
54
+ outcomes: {
55
+ Failed: true,
56
+ },
57
+ },
58
+ };
59
+ }
60
+ }
61
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXCRequestSignatureCommand, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
62
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXCRequestSignatureCommand, providedIn: 'root' }); }
63
+ }
64
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXCRequestSignatureCommand, decorators: [{
65
+ type: Injectable,
66
+ args: [{
67
+ providedIn: 'root',
68
+ }]
69
+ }] });
70
+
71
+ export { AXCRequestSignatureCommand };
72
+ //# sourceMappingURL=acorex-connectivity-mock-request-signature.command-B6VZ5KeW.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"acorex-connectivity-mock-request-signature.command-B6VZ5KeW.mjs","sources":["../tmp-esm2022/mock/lib/workflow-management/commands/request-signature.command.js"],"sourcesContent":["import { Injectable } from '@angular/core';\nimport { AXPDataGenerator } from '@acorex/platform/core';\nimport * as i0 from \"@angular/core\";\n//#endregion\n/**\n * Request Signature Command (Backend - Mock)\n *\n * Creates a new signature request for an entity record.\n * This command runs on the backend and initializes the signature process.\n */\nexport class AXCRequestSignatureCommand {\n //#region ---- AXPCommand Implementation ----\n async execute(input) {\n try {\n console.log(`[AXCRequestSignatureCommand] Creating signature request for ${input.refType}:${input.refId}`);\n // Validate inputs\n if (!input.refId || !input.refType || !input.signers || input.signers.length === 0) {\n throw new Error('Invalid input: refId, refType, and at least one signer are required');\n }\n // Generate unique signature request ID\n const signatureRequestId = AXPDataGenerator.uuid();\n // In a real implementation, this would:\n // 1. Create a signature request record in the database\n // 2. Initialize signature tracking for each signer\n // 3. Set initial status to 'pending'\n // 4. Store workflow instance ID if provided\n console.log(`[AXCRequestSignatureCommand] Created signature request: ${signatureRequestId} for ${input.signers.length} signers`);\n return {\n success: true,\n data: {\n output: {\n signatureRequestId,\n workflowInstanceId: input.workflowName ? `${input.workflowName}-${signatureRequestId}` : undefined,\n },\n outcomes: {\n Done: true,\n },\n },\n };\n }\n catch (error) {\n console.error(`[AXCRequestSignatureCommand] Failed to create signature request:`, error);\n return {\n success: false,\n message: {\n text: error.message || 'Failed to create signature request',\n },\n data: {\n output: {\n signatureRequestId: '',\n workflowInstanceId: undefined,\n },\n outcomes: {\n Failed: true,\n },\n },\n };\n }\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: AXCRequestSignatureCommand, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: AXCRequestSignatureCommand, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: AXCRequestSignatureCommand, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root',\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVxdWVzdC1zaWduYXR1cmUuY29tbWFuZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29ubmVjdGl2aXR5L21vY2svc3JjL2xpYi93b3JrZmxvdy1tYW5hZ2VtZW50L2NvbW1hbmRzL3JlcXVlc3Qtc2lnbmF0dXJlLmNvbW1hbmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQTJCLGdCQUFnQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7O0FBaUJsRixZQUFZO0FBRVo7Ozs7O0dBS0c7QUFJSCxNQUFNLE9BQU8sMEJBQTBCO0lBRXJDLGlEQUFpRDtJQUVqRCxLQUFLLENBQUMsT0FBTyxDQUNYLEtBQW1DO1FBRW5DLElBQUksQ0FBQztZQUNILE9BQU8sQ0FBQyxHQUFHLENBQUMsK0RBQStELEtBQUssQ0FBQyxPQUFPLElBQUksS0FBSyxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7WUFFM0csa0JBQWtCO1lBQ2xCLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFLENBQUM7Z0JBQ25GLE1BQU0sSUFBSSxLQUFLLENBQUMscUVBQXFFLENBQUMsQ0FBQztZQUN6RixDQUFDO1lBRUQsdUNBQXVDO1lBQ3ZDLE1BQU0sa0JBQWtCLEdBQUcsZ0JBQWdCLENBQUMsSUFBSSxFQUFFLENBQUM7WUFFbkQsd0NBQXdDO1lBQ3hDLHVEQUF1RDtZQUN2RCxtREFBbUQ7WUFDbkQscUNBQXFDO1lBQ3JDLDRDQUE0QztZQUU1QyxPQUFPLENBQUMsR0FBRyxDQUFDLDJEQUEyRCxrQkFBa0IsUUFBUSxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sVUFBVSxDQUFDLENBQUM7WUFFakksT0FBTztnQkFDTCxPQUFPLEVBQUUsSUFBSTtnQkFDYixJQUFJLEVBQUU7b0JBQ0osTUFBTSxFQUFFO3dCQUNOLGtCQUFrQjt3QkFDbEIsa0JBQWtCLEVBQUUsS0FBSyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsR0FBRyxLQUFLLENBQUMsWUFBWSxJQUFJLGtCQUFrQixFQUFFLENBQUMsQ0FBQyxDQUFDLFNBQVM7cUJBQ25HO29CQUNELFFBQVEsRUFBRTt3QkFDUixJQUFJLEVBQUUsSUFBSTtxQkFDWDtpQkFDRjthQUNGLENBQUM7UUFDSixDQUFDO1FBQUMsT0FBTyxLQUFVLEVBQUUsQ0FBQztZQUNwQixPQUFPLENBQUMsS0FBSyxDQUFDLGtFQUFrRSxFQUFFLEtBQUssQ0FBQyxDQUFDO1lBRXpGLE9BQU87Z0JBQ0wsT0FBTyxFQUFFLEtBQUs7Z0JBQ2QsT0FBTyxFQUFFO29CQUNQLElBQUksRUFBRSxLQUFLLENBQUMsT0FBTyxJQUFJLG9DQUFvQztpQkFDNUQ7Z0JBQ0QsSUFBSSxFQUFFO29CQUNKLE1BQU0sRUFBRTt3QkFDTixrQkFBa0IsRUFBRSxFQUFFO3dCQUN0QixrQkFBa0IsRUFBRSxTQUFTO3FCQUM5QjtvQkFDRCxRQUFRLEVBQUU7d0JBQ1IsTUFBTSxFQUFFLElBQUk7cUJBQ2I7aUJBQ0Y7YUFDRixDQUFDO1FBQ0osQ0FBQztJQUNILENBQUM7K0dBekRVLDBCQUEwQjttSEFBMUIsMEJBQTBCLGNBRnpCLE1BQU07OzRGQUVQLDBCQUEwQjtrQkFIdEMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBWFBFeGVjdXRlQ29tbWFuZFJlc3VsdCwgQVhQRGF0YUdlbmVyYXRvciB9IGZyb20gJ0BhY29yZXgvcGxhdGZvcm0vY29yZSc7XG5pbXBvcnQgeyBBWFBDb21tYW5kIH0gZnJvbSAnQGFjb3JleC9wbGF0Zm9ybS9ydW50aW1lJztcblxuLy8jcmVnaW9uIC0tLS0gICBUeXBlcyAgIC0tLS1cblxuZXhwb3J0IGludGVyZmFjZSBSZXF1ZXN0U2lnbmF0dXJlQ29tbWFuZElucHV0IHtcbiAgcmVmSWQ6IHN0cmluZztcbiAgcmVmVHlwZTogc3RyaW5nO1xuICBzaWduZXJzOiBzdHJpbmdbXTtcbiAgd29ya2Zsb3dOYW1lPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlcXVlc3RTaWduYXR1cmVDb21tYW5kT3V0cHV0IHtcbiAgc2lnbmF0dXJlUmVxdWVzdElkOiBzdHJpbmc7XG4gIHdvcmtmbG93SW5zdGFuY2VJZD86IHN0cmluZztcbn1cblxuLy8jZW5kcmVnaW9uXG5cbi8qKlxuICogUmVxdWVzdCBTaWduYXR1cmUgQ29tbWFuZCAoQmFja2VuZCAtIE1vY2spXG4gKiBcbiAqIENyZWF0ZXMgYSBuZXcgc2lnbmF0dXJlIHJlcXVlc3QgZm9yIGFuIGVudGl0eSByZWNvcmQuXG4gKiBUaGlzIGNvbW1hbmQgcnVucyBvbiB0aGUgYmFja2VuZCBhbmQgaW5pdGlhbGl6ZXMgdGhlIHNpZ25hdHVyZSBwcm9jZXNzLlxuICovXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgQVhDUmVxdWVzdFNpZ25hdHVyZUNvbW1hbmRcbiAgaW1wbGVtZW50cyBBWFBDb21tYW5kPFJlcXVlc3RTaWduYXR1cmVDb21tYW5kSW5wdXQsIHsgb3V0cHV0OiBSZXF1ZXN0U2lnbmF0dXJlQ29tbWFuZE91dHB1dDsgb3V0Y29tZXM6IFJlY29yZDxzdHJpbmcsIGFueT4gfT4ge1xuICAvLyNyZWdpb24gLS0tLSAgIEFYUENvbW1hbmQgSW1wbGVtZW50YXRpb24gICAtLS0tXG5cbiAgYXN5bmMgZXhlY3V0ZShcbiAgICBpbnB1dDogUmVxdWVzdFNpZ25hdHVyZUNvbW1hbmRJbnB1dCxcbiAgKTogUHJvbWlzZTxBWFBFeGVjdXRlQ29tbWFuZFJlc3VsdDx7IG91dHB1dDogUmVxdWVzdFNpZ25hdHVyZUNvbW1hbmRPdXRwdXQ7IG91dGNvbWVzOiBSZWNvcmQ8c3RyaW5nLCBhbnk+IH0+PiB7XG4gICAgdHJ5IHtcbiAgICAgIGNvbnNvbGUubG9nKGBbQVhDUmVxdWVzdFNpZ25hdHVyZUNvbW1hbmRdIENyZWF0aW5nIHNpZ25hdHVyZSByZXF1ZXN0IGZvciAke2lucHV0LnJlZlR5cGV9OiR7aW5wdXQucmVmSWR9YCk7XG5cbiAgICAgIC8vIFZhbGlkYXRlIGlucHV0c1xuICAgICAgaWYgKCFpbnB1dC5yZWZJZCB8fCAhaW5wdXQucmVmVHlwZSB8fCAhaW5wdXQuc2lnbmVycyB8fCBpbnB1dC5zaWduZXJzLmxlbmd0aCA9PT0gMCkge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ0ludmFsaWQgaW5wdXQ6IHJlZklkLCByZWZUeXBlLCBhbmQgYXQgbGVhc3Qgb25lIHNpZ25lciBhcmUgcmVxdWlyZWQnKTtcbiAgICAgIH1cblxuICAgICAgLy8gR2VuZXJhdGUgdW5pcXVlIHNpZ25hdHVyZSByZXF1ZXN0IElEXG4gICAgICBjb25zdCBzaWduYXR1cmVSZXF1ZXN0SWQgPSBBWFBEYXRhR2VuZXJhdG9yLnV1aWQoKTtcblxuICAgICAgLy8gSW4gYSByZWFsIGltcGxlbWVudGF0aW9uLCB0aGlzIHdvdWxkOlxuICAgICAgLy8gMS4gQ3JlYXRlIGEgc2lnbmF0dXJlIHJlcXVlc3QgcmVjb3JkIGluIHRoZSBkYXRhYmFzZVxuICAgICAgLy8gMi4gSW5pdGlhbGl6ZSBzaWduYXR1cmUgdHJhY2tpbmcgZm9yIGVhY2ggc2lnbmVyXG4gICAgICAvLyAzLiBTZXQgaW5pdGlhbCBzdGF0dXMgdG8gJ3BlbmRpbmcnXG4gICAgICAvLyA0LiBTdG9yZSB3b3JrZmxvdyBpbnN0YW5jZSBJRCBpZiBwcm92aWRlZFxuXG4gICAgICBjb25zb2xlLmxvZyhgW0FYQ1JlcXVlc3RTaWduYXR1cmVDb21tYW5kXSBDcmVhdGVkIHNpZ25hdHVyZSByZXF1ZXN0OiAke3NpZ25hdHVyZVJlcXVlc3RJZH0gZm9yICR7aW5wdXQuc2lnbmVycy5sZW5ndGh9IHNpZ25lcnNgKTtcblxuICAgICAgcmV0dXJuIHtcbiAgICAgICAgc3VjY2VzczogdHJ1ZSxcbiAgICAgICAgZGF0YToge1xuICAgICAgICAgIG91dHB1dDoge1xuICAgICAgICAgICAgc2lnbmF0dXJlUmVxdWVzdElkLFxuICAgICAgICAgICAgd29ya2Zsb3dJbnN0YW5jZUlkOiBpbnB1dC53b3JrZmxvd05hbWUgPyBgJHtpbnB1dC53b3JrZmxvd05hbWV9LSR7c2lnbmF0dXJlUmVxdWVzdElkfWAgOiB1bmRlZmluZWQsXG4gICAgICAgICAgfSxcbiAgICAgICAgICBvdXRjb21lczoge1xuICAgICAgICAgICAgRG9uZTogdHJ1ZSxcbiAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgICAgfTtcbiAgICB9IGNhdGNoIChlcnJvcjogYW55KSB7XG4gICAgICBjb25zb2xlLmVycm9yKGBbQVhDUmVxdWVzdFNpZ25hdHVyZUNvbW1hbmRdIEZhaWxlZCB0byBjcmVhdGUgc2lnbmF0dXJlIHJlcXVlc3Q6YCwgZXJyb3IpO1xuXG4gICAgICByZXR1cm4ge1xuICAgICAgICBzdWNjZXNzOiBmYWxzZSxcbiAgICAgICAgbWVzc2FnZToge1xuICAgICAgICAgIHRleHQ6IGVycm9yLm1lc3NhZ2UgfHwgJ0ZhaWxlZCB0byBjcmVhdGUgc2lnbmF0dXJlIHJlcXVlc3QnLFxuICAgICAgICB9LFxuICAgICAgICBkYXRhOiB7XG4gICAgICAgICAgb3V0cHV0OiB7XG4gICAgICAgICAgICBzaWduYXR1cmVSZXF1ZXN0SWQ6ICcnLFxuICAgICAgICAgICAgd29ya2Zsb3dJbnN0YW5jZUlkOiB1bmRlZmluZWQsXG4gICAgICAgICAgfSxcbiAgICAgICAgICBvdXRjb21lczoge1xuICAgICAgICAgICAgRmFpbGVkOiB0cnVlLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0sXG4gICAgICB9O1xuICAgIH1cbiAgfVxuXG4gIC8vI2VuZHJlZ2lvblxufVxuXG4iXX0="],"names":[],"mappings":"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"}
@@ -9,10 +9,10 @@ class AXMReportSampleActionExecuteCommand {
9
9
  success: true,
10
10
  };
11
11
  }
12
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.12", ngImport: i0, type: AXMReportSampleActionExecuteCommand, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
13
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.12", ngImport: i0, type: AXMReportSampleActionExecuteCommand, providedIn: 'root' }); }
12
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXMReportSampleActionExecuteCommand, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
13
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXMReportSampleActionExecuteCommand, providedIn: 'root' }); }
14
14
  }
15
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.12", ngImport: i0, type: AXMReportSampleActionExecuteCommand, decorators: [{
15
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXMReportSampleActionExecuteCommand, decorators: [{
16
16
  type: Injectable,
17
17
  args: [{
18
18
  providedIn: 'root',
@@ -20,4 +20,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.12", ngImpo
20
20
  }] });
21
21
 
22
22
  export { AXMReportSampleActionExecuteCommand };
23
- //# sourceMappingURL=acorex-connectivity-mock-sample.command-CkH5bmEs.mjs.map
23
+ //# sourceMappingURL=acorex-connectivity-mock-sample.command-BJJ67aLM.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"acorex-connectivity-mock-sample.command-CkH5bmEs.mjs","sources":["../tmp-esm2022/mock/lib/report-management/sample.command.js"],"sourcesContent":["import { Injectable } from '@angular/core';\nimport * as i0 from \"@angular/core\";\nexport class AXMReportSampleActionExecuteCommand {\n //#region ---- Command Implementation ----\n async execute(context) {\n console.log('ReportManagement.Report:SampleAction', context);\n return {\n success: true,\n };\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.12\", ngImport: i0, type: AXMReportSampleActionExecuteCommand, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.12\", ngImport: i0, type: AXMReportSampleActionExecuteCommand, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.12\", ngImport: i0, type: AXMReportSampleActionExecuteCommand, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root',\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2FtcGxlLmNvbW1hbmQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2Nvbm5lY3Rpdml0eS9tb2NrL3NyYy9saWIvcmVwb3J0LW1hbmFnZW1lbnQvc2FtcGxlLmNvbW1hbmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFTM0MsTUFBTSxPQUFPLG1DQUFtQztJQUc5Qyw4Q0FBOEM7SUFFOUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxPQUFZO1FBQ3hCLE9BQU8sQ0FBQyxHQUFHLENBQUMsc0NBQXNDLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDN0QsT0FBTztZQUNMLE9BQU8sRUFBRSxJQUFJO1NBQ2QsQ0FBQztJQUNKLENBQUM7K0dBVlUsbUNBQW1DO21IQUFuQyxtQ0FBbUMsY0FGbEMsTUFBTTs7NEZBRVAsbUNBQW1DO2tCQUgvQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFYUEV4ZWN1dGVDb21tYW5kUmVzdWx0IH0gZnJvbSAnQGFjb3JleC9wbGF0Zm9ybS9jb3JlJztcbmltcG9ydCB7IEFYUENvbW1hbmQgfSBmcm9tICdAYWNvcmV4L3BsYXRmb3JtL3J1bnRpbWUnO1xuXG5cblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIEFYTVJlcG9ydFNhbXBsZUFjdGlvbkV4ZWN1dGVDb21tYW5kIGltcGxlbWVudHMgQVhQQ29tbWFuZDxhbnksIHZvaWQ+IHtcblxuXG4gIC8vI3JlZ2lvbiAtLS0tICAgQ29tbWFuZCBJbXBsZW1lbnRhdGlvbiAgIC0tLS1cblxuICBhc3luYyBleGVjdXRlKGNvbnRleHQ6IGFueSk6IFByb21pc2U8QVhQRXhlY3V0ZUNvbW1hbmRSZXN1bHQ8dm9pZD4+IHtcbiAgICBjb25zb2xlLmxvZygnUmVwb3J0TWFuYWdlbWVudC5SZXBvcnQ6U2FtcGxlQWN0aW9uJywgY29udGV4dCk7XG4gICAgcmV0dXJuIHtcbiAgICAgIHN1Y2Nlc3M6IHRydWUsXG4gICAgfTtcbiAgfVxuXG4gIC8vI2VuZHJlZ2lvblxufSAiXX0="],"names":[],"mappings":";;;AAEO,MAAM,mCAAmC,CAAC;AACjD;AACA,IAAI,MAAM,OAAO,CAAC,OAAO,EAAE;AAC3B,QAAQ,OAAO,CAAC,GAAG,CAAC,sCAAsC,EAAE,OAAO,CAAC;AACpE,QAAQ,OAAO;AACf,YAAY,OAAO,EAAE,IAAI;AACzB,SAAS;AACT,IAAI;AACJ,IAAI,SAAS,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC,kBAAkB,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,mCAAmC,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,CAAC,eAAe,CAAC,UAAU,EAAE,CAAC,CAAC;AACvM,IAAI,SAAS,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC,qBAAqB,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,mCAAmC,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC,CAAC;AAC9K;AACA,EAAE,CAAC,wBAAwB,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,mCAAmC,EAAE,UAAU,EAAE,CAAC;AAC9I,YAAY,IAAI,EAAE,UAAU;AAC5B,YAAY,IAAI,EAAE,CAAC;AACnB,oBAAoB,UAAU,EAAE,MAAM;AACtC,iBAAiB;AACjB,SAAS,CAAC,EAAE,CAAC;;;;"}
1
+ {"version":3,"file":"acorex-connectivity-mock-sample.command-BJJ67aLM.mjs","sources":["../tmp-esm2022/mock/lib/report-management/sample.command.js"],"sourcesContent":["import { Injectable } from '@angular/core';\nimport * as i0 from \"@angular/core\";\nexport class AXMReportSampleActionExecuteCommand {\n //#region ---- Command Implementation ----\n async execute(context) {\n console.log('ReportManagement.Report:SampleAction', context);\n return {\n success: true,\n };\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: AXMReportSampleActionExecuteCommand, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: AXMReportSampleActionExecuteCommand, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: AXMReportSampleActionExecuteCommand, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root',\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2FtcGxlLmNvbW1hbmQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2Nvbm5lY3Rpdml0eS9tb2NrL3NyYy9saWIvcmVwb3J0LW1hbmFnZW1lbnQvc2FtcGxlLmNvbW1hbmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFTM0MsTUFBTSxPQUFPLG1DQUFtQztJQUc5Qyw4Q0FBOEM7SUFFOUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxPQUFZO1FBQ3hCLE9BQU8sQ0FBQyxHQUFHLENBQUMsc0NBQXNDLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDN0QsT0FBTztZQUNMLE9BQU8sRUFBRSxJQUFJO1NBQ2QsQ0FBQztJQUNKLENBQUM7K0dBVlUsbUNBQW1DO21IQUFuQyxtQ0FBbUMsY0FGbEMsTUFBTTs7NEZBRVAsbUNBQW1DO2tCQUgvQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFYUEV4ZWN1dGVDb21tYW5kUmVzdWx0IH0gZnJvbSAnQGFjb3JleC9wbGF0Zm9ybS9jb3JlJztcbmltcG9ydCB7IEFYUENvbW1hbmQgfSBmcm9tICdAYWNvcmV4L3BsYXRmb3JtL3J1bnRpbWUnO1xuXG5cblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIEFYTVJlcG9ydFNhbXBsZUFjdGlvbkV4ZWN1dGVDb21tYW5kIGltcGxlbWVudHMgQVhQQ29tbWFuZDxhbnksIHZvaWQ+IHtcblxuXG4gIC8vI3JlZ2lvbiAtLS0tICAgQ29tbWFuZCBJbXBsZW1lbnRhdGlvbiAgIC0tLS1cblxuICBhc3luYyBleGVjdXRlKGNvbnRleHQ6IGFueSk6IFByb21pc2U8QVhQRXhlY3V0ZUNvbW1hbmRSZXN1bHQ8dm9pZD4+IHtcbiAgICBjb25zb2xlLmxvZygnUmVwb3J0TWFuYWdlbWVudC5SZXBvcnQ6U2FtcGxlQWN0aW9uJywgY29udGV4dCk7XG4gICAgcmV0dXJuIHtcbiAgICAgIHN1Y2Nlc3M6IHRydWUsXG4gICAgfTtcbiAgfVxuXG4gIC8vI2VuZHJlZ2lvblxufSAiXX0="],"names":[],"mappings":";;;AAEO,MAAM,mCAAmC,CAAC;AACjD;AACA,IAAI,MAAM,OAAO,CAAC,OAAO,EAAE;AAC3B,QAAQ,OAAO,CAAC,GAAG,CAAC,sCAAsC,EAAE,OAAO,CAAC;AACpE,QAAQ,OAAO;AACf,YAAY,OAAO,EAAE,IAAI;AACzB,SAAS;AACT,IAAI;AACJ,IAAI,SAAS,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC,kBAAkB,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,mCAAmC,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,CAAC,eAAe,CAAC,UAAU,EAAE,CAAC,CAAC;AACvM,IAAI,SAAS,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC,qBAAqB,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,mCAAmC,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC,CAAC;AAC9K;AACA,EAAE,CAAC,wBAAwB,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,mCAAmC,EAAE,UAAU,EAAE,CAAC;AAC9I,YAAY,IAAI,EAAE,UAAU;AAC5B,YAAY,IAAI,EAAE,CAAC;AACnB,oBAAoB,UAAU,EAAE,MAAM;AACtC,iBAAiB;AACjB,SAAS,CAAC,EAAE,CAAC;;;;"}
@@ -0,0 +1,81 @@
1
+ import * as i0 from '@angular/core';
2
+ import { Injectable } from '@angular/core';
3
+
4
+ //#endregion
5
+ /**
6
+ * Validate All Signatures Command (Backend - Mock)
7
+ *
8
+ * Validates whether all required signatures have been collected.
9
+ * This command runs on the backend and checks signature status.
10
+ */
11
+ class AXCValidateAllSignaturesCommand {
12
+ //#region ---- AXPCommand Implementation ----
13
+ async execute(input) {
14
+ try {
15
+ console.log(`[AXCValidateAllSignaturesCommand] Validating signatures for request: ${input.signatureRequestId}, required: ${input.requiredSigners}`);
16
+ // Validate inputs
17
+ if (!input.signatureRequestId || input.requiredSigners < 1) {
18
+ throw new Error('Invalid input: signatureRequestId and requiredSigners >= 1 are required');
19
+ }
20
+ // In a real implementation, this would:
21
+ // 1. Query the database for signature request
22
+ // 2. Count collected signatures
23
+ // 3. Compare with required count
24
+ // 4. Check signature validity
25
+ // Mock: simulate signature validation
26
+ // For now, we'll use a simple approach where we track signatures in workflow state
27
+ // In a real system, this would query the database
28
+ // TODO: This should track actual signatures from workflow state or database
29
+ const signedCount = Math.floor(Math.random() * (input.requiredSigners + 1)); // Mock: random for demo
30
+ const allSigned = signedCount >= input.requiredSigners;
31
+ console.log(`[AXCValidateAllSignaturesCommand] Validation result: ${signedCount}/${input.requiredSigners} signatures collected, allSigned: ${allSigned}`);
32
+ // Determine outcome
33
+ let outcome;
34
+ if (allSigned) {
35
+ outcome = { AllSigned: true };
36
+ }
37
+ else {
38
+ outcome = { Pending: true };
39
+ }
40
+ return {
41
+ success: true,
42
+ data: {
43
+ output: {
44
+ allSigned,
45
+ signedCount,
46
+ },
47
+ outcomes: outcome,
48
+ },
49
+ };
50
+ }
51
+ catch (error) {
52
+ console.error(`[AXCValidateAllSignaturesCommand] Failed to validate signatures:`, error);
53
+ return {
54
+ success: false,
55
+ message: {
56
+ text: error.message || 'Failed to validate signatures',
57
+ },
58
+ data: {
59
+ output: {
60
+ allSigned: false,
61
+ signedCount: 0,
62
+ },
63
+ outcomes: {
64
+ Failed: true,
65
+ },
66
+ },
67
+ };
68
+ }
69
+ }
70
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXCValidateAllSignaturesCommand, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
71
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXCValidateAllSignaturesCommand, providedIn: 'root' }); }
72
+ }
73
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXCValidateAllSignaturesCommand, decorators: [{
74
+ type: Injectable,
75
+ args: [{
76
+ providedIn: 'root',
77
+ }]
78
+ }] });
79
+
80
+ export { AXCValidateAllSignaturesCommand };
81
+ //# sourceMappingURL=acorex-connectivity-mock-validate-all-signatures.command-CG80T32a.mjs.map