@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
@@ -102,10 +102,10 @@ class AXCQueryCategoryWithItemsQuery {
102
102
  }
103
103
  return node;
104
104
  }
105
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.12", ngImport: i0, type: AXCQueryCategoryWithItemsQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
106
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.12", ngImport: i0, type: AXCQueryCategoryWithItemsQuery, providedIn: 'root' }); }
105
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXCQueryCategoryWithItemsQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
106
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXCQueryCategoryWithItemsQuery, providedIn: 'root' }); }
107
107
  }
108
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.12", ngImport: i0, type: AXCQueryCategoryWithItemsQuery, decorators: [{
108
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXCQueryCategoryWithItemsQuery, decorators: [{
109
109
  type: Injectable,
110
110
  args: [{
111
111
  providedIn: 'root'
@@ -113,4 +113,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.12", ngImpo
113
113
  }] });
114
114
 
115
115
  export { AXCQueryCategoryWithItemsQuery };
116
- //# sourceMappingURL=acorex-connectivity-mock-category-with-items.query-Dsxj98tX.mjs.map
116
+ //# sourceMappingURL=acorex-connectivity-mock-category-with-items.query-Cl7T-rSS.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"acorex-connectivity-mock-category-with-items.query-Dsxj98tX.mjs","sources":["../tmp-esm2022/mock/lib/data-management/metadata/category-with-items.query.js"],"sourcesContent":["import { AXMMetaDataDefinitionService, RootConfig } from '@acorex/modules/data-management';\nimport { AXMEntityCrudServiceImpl } from '@acorex/platform/layout/entity';\nimport { inject, Injectable, Injector, runInInjectionContext } from '@angular/core';\nimport * as i0 from \"@angular/core\";\nexport class AXCQueryCategoryWithItemsQuery {\n constructor() {\n this.injector = inject(Injector);\n this.categoryEntityService = runInInjectionContext(this.injector, () => new AXMEntityCrudServiceImpl(`${RootConfig.module.name}.${RootConfig.entities.metaDataDefinition.name}Category`));\n this.metaDataService = inject(AXMMetaDataDefinitionService);\n }\n fetch() {\n return this.getAllWithItems();\n }\n async getAllWithItems() {\n const rootCategories = await this.categoryEntityService.query({\n take: 1000,\n skip: 0,\n filter: {\n logic: 'and',\n filters: [\n {\n field: 'parentId',\n operator: {\n type: 'isNull',\n },\n },\n ],\n },\n });\n // Build the tree and prune empty categories (no children and no items)\n const builtRoots = await Promise.all(rootCategories.items.map((category) => this.buildCategoryTree(category)));\n const categories = builtRoots.filter((c) => Boolean(c));\n // Aggregate all items across remaining categories\n const allItems = [];\n const collectItems = (nodes) => {\n for (const node of nodes) {\n if (node.items?.length) {\n allItems.push(...node.items);\n }\n if (node.children?.length) {\n collectItems(node.children);\n }\n }\n };\n collectItems(categories);\n // Add synthetic 'All' node at the beginning\n const allNode = {\n id: 'all',\n title: 'All',\n childrenCount: 0,\n items: allItems,\n children: [],\n categories: []\n };\n return [allNode, ...categories];\n }\n async buildCategoryTree(category) {\n const itemsResult = await this.metaDataService.query({\n filter: {\n logic: 'and',\n filters: [\n {\n field: 'categoryIds',\n operator: {\n type: 'contains',\n },\n value: category.id,\n },\n ],\n },\n take: 1000,\n skip: 0,\n });\n const childCategoriesResult = await this.categoryEntityService.query({\n filter: {\n logic: 'and',\n filters: [\n {\n field: 'parentId',\n operator: {\n type: 'equal',\n },\n value: category.id,\n },\n ],\n },\n take: 1000,\n skip: 0,\n });\n const builtChildren = await Promise.all(childCategoriesResult.items.map((child) => this.buildCategoryTree(child)));\n const children = builtChildren.filter((c) => Boolean(c));\n const node = {\n ...category,\n items: itemsResult.items,\n categories: children,\n children: children,\n };\n // Prune node if it has no items and no children\n if ((!node.items || node.items.length === 0) && (!node.children || node.children.length === 0)) {\n return null;\n }\n return node;\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.12\", ngImport: i0, type: AXCQueryCategoryWithItemsQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.12\", ngImport: i0, type: AXCQueryCategoryWithItemsQuery, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.12\", ngImport: i0, type: AXCQueryCategoryWithItemsQuery, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root'\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"category-with-items.query.js","sourceRoot":"","sources":["../../../../../../../../libs/connectivity/mock/src/lib/data-management/metadata/category-with-items.query.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXMMetaDataDefinitionEntityModel, AXMMetaDataDefinitionService, RootConfig } from '@acorex/modules/data-management';\nimport { AXPCategoryEntityWithItems } from '@acorex/platform/core';\nimport { AXMEntityCrudServiceImpl } from '@acorex/platform/layout/entity';\nimport { AXPQuery } from '@acorex/platform/runtime';\nimport { inject, Injectable, Injector, runInInjectionContext } from '@angular/core';\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class AXCQueryCategoryWithItemsQuery implements AXPQuery<void, AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel>[]> {\n\n    private injector = inject(Injector);\n    private categoryEntityService = runInInjectionContext(this.injector, () => new AXMEntityCrudServiceImpl<any, any>(`${RootConfig.module.name}.${RootConfig.entities.metaDataDefinition.name}Category`));\n    private metaDataService = inject(AXMMetaDataDefinitionService);\n\n\n    fetch(): Promise<any> {\n        return this.getAllWithItems();\n    }\n\n    private async getAllWithItems(): Promise<AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel>[]> {\n        const rootCategories = await this.categoryEntityService.query({\n            take: 1000,\n            skip: 0,\n            filter: {\n                logic: 'and',\n                filters: [\n                    {\n                        field: 'parentId',\n                        operator: {\n                            type: 'isNull',\n                        },\n                    },\n                ],\n            },\n        });\n\n        // Build the tree and prune empty categories (no children and no items)\n        const builtRoots = await Promise.all(rootCategories.items.map((category) => this.buildCategoryTree(category)));\n        const categories = builtRoots.filter((c): c is AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel> => Boolean(c));\n\n        // Aggregate all items across remaining categories\n        const allItems: AXMMetaDataDefinitionEntityModel[] = [];\n        const collectItems = (nodes: AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel>[]) => {\n            for (const node of nodes) {\n                if (node.items?.length) {\n                    allItems.push(...node.items);\n                }\n                if (node.children?.length) {\n                    collectItems(node.children);\n                }\n            }\n        };\n        collectItems(categories);\n\n        // Add synthetic 'All' node at the beginning\n        const allNode: AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel> & { categories?: any[] } = {\n            id: 'all',\n            title: 'All',\n            childrenCount: 0,\n            items: allItems,\n            children: [],\n            categories: []\n        };\n\n        return [allNode, ...categories];\n    }\n\n    private async buildCategoryTree(category: any): Promise<AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel> | null> {\n        const itemsResult = await this.metaDataService.query({\n            filter: {\n                logic: 'and',\n                filters: [\n                    {\n                        field: 'categoryIds',\n                        operator: {\n                            type: 'contains',\n                        },\n                        value: category.id,\n                    },\n                ],\n            },\n            take: 1000,\n            skip: 0,\n        });\n\n        const childCategoriesResult = await this.categoryEntityService.query({\n            filter: {\n                logic: 'and',\n                filters: [\n                    {\n                        field: 'parentId',\n                        operator: {\n                            type: 'equal',\n                        },\n                        value: category.id,\n                    },\n                ],\n            },\n            take: 1000,\n            skip: 0,\n        });\n\n        const builtChildren = await Promise.all(childCategoriesResult.items.map((child) => this.buildCategoryTree(child)));\n        const children = builtChildren.filter((c): c is AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel> => Boolean(c));\n\n        const node: AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel> & { categories?: any[] } = {\n            ...category,\n            items: itemsResult.items,\n            categories: children,\n            children: children,\n        };\n\n        // Prune node if it has no items and no children\n        if ((!node.items || node.items.length === 0) && (!node.children || node.children.length === 0)) {\n            return null;\n        }\n\n        return node;\n    }\n\n\n\n}"]}"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"acorex-connectivity-mock-category-with-items.query-Cl7T-rSS.mjs","sources":["../tmp-esm2022/mock/lib/data-management/metadata/category-with-items.query.js"],"sourcesContent":["import { AXMMetaDataDefinitionService, RootConfig } from '@acorex/modules/data-management';\nimport { AXMEntityCrudServiceImpl } from '@acorex/platform/layout/entity';\nimport { inject, Injectable, Injector, runInInjectionContext } from '@angular/core';\nimport * as i0 from \"@angular/core\";\nexport class AXCQueryCategoryWithItemsQuery {\n constructor() {\n this.injector = inject(Injector);\n this.categoryEntityService = runInInjectionContext(this.injector, () => new AXMEntityCrudServiceImpl(`${RootConfig.module.name}.${RootConfig.entities.metaDataDefinition.name}Category`));\n this.metaDataService = inject(AXMMetaDataDefinitionService);\n }\n fetch() {\n return this.getAllWithItems();\n }\n async getAllWithItems() {\n const rootCategories = await this.categoryEntityService.query({\n take: 1000,\n skip: 0,\n filter: {\n logic: 'and',\n filters: [\n {\n field: 'parentId',\n operator: {\n type: 'isNull',\n },\n },\n ],\n },\n });\n // Build the tree and prune empty categories (no children and no items)\n const builtRoots = await Promise.all(rootCategories.items.map((category) => this.buildCategoryTree(category)));\n const categories = builtRoots.filter((c) => Boolean(c));\n // Aggregate all items across remaining categories\n const allItems = [];\n const collectItems = (nodes) => {\n for (const node of nodes) {\n if (node.items?.length) {\n allItems.push(...node.items);\n }\n if (node.children?.length) {\n collectItems(node.children);\n }\n }\n };\n collectItems(categories);\n // Add synthetic 'All' node at the beginning\n const allNode = {\n id: 'all',\n title: 'All',\n childrenCount: 0,\n items: allItems,\n children: [],\n categories: []\n };\n return [allNode, ...categories];\n }\n async buildCategoryTree(category) {\n const itemsResult = await this.metaDataService.query({\n filter: {\n logic: 'and',\n filters: [\n {\n field: 'categoryIds',\n operator: {\n type: 'contains',\n },\n value: category.id,\n },\n ],\n },\n take: 1000,\n skip: 0,\n });\n const childCategoriesResult = await this.categoryEntityService.query({\n filter: {\n logic: 'and',\n filters: [\n {\n field: 'parentId',\n operator: {\n type: 'equal',\n },\n value: category.id,\n },\n ],\n },\n take: 1000,\n skip: 0,\n });\n const builtChildren = await Promise.all(childCategoriesResult.items.map((child) => this.buildCategoryTree(child)));\n const children = builtChildren.filter((c) => Boolean(c));\n const node = {\n ...category,\n items: itemsResult.items,\n categories: children,\n children: children,\n };\n // Prune node if it has no items and no children\n if ((!node.items || node.items.length === 0) && (!node.children || node.children.length === 0)) {\n return null;\n }\n return node;\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: AXCQueryCategoryWithItemsQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: AXCQueryCategoryWithItemsQuery, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: AXCQueryCategoryWithItemsQuery, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root'\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"category-with-items.query.js","sourceRoot":"","sources":["../../../../../../../../libs/connectivity/mock/src/lib/data-management/metadata/category-with-items.query.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXMMetaDataDefinitionEntityModel, AXMMetaDataDefinitionService, RootConfig } from '@acorex/modules/data-management';\nimport { AXPCategoryEntityWithItems } from '@acorex/platform/core';\nimport { AXMEntityCrudServiceImpl } from '@acorex/platform/layout/entity';\nimport { AXPQuery } from '@acorex/platform/runtime';\nimport { inject, Injectable, Injector, runInInjectionContext } from '@angular/core';\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class AXCQueryCategoryWithItemsQuery implements AXPQuery<void, AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel>[]> {\n\n    private injector = inject(Injector);\n    private categoryEntityService = runInInjectionContext(this.injector, () => new AXMEntityCrudServiceImpl<any, any>(`${RootConfig.module.name}.${RootConfig.entities.metaDataDefinition.name}Category`));\n    private metaDataService = inject(AXMMetaDataDefinitionService);\n\n\n    fetch(): Promise<any> {\n        return this.getAllWithItems();\n    }\n\n    private async getAllWithItems(): Promise<AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel>[]> {\n        const rootCategories = await this.categoryEntityService.query({\n            take: 1000,\n            skip: 0,\n            filter: {\n                logic: 'and',\n                filters: [\n                    {\n                        field: 'parentId',\n                        operator: {\n                            type: 'isNull',\n                        },\n                    },\n                ],\n            },\n        });\n\n        // Build the tree and prune empty categories (no children and no items)\n        const builtRoots = await Promise.all(rootCategories.items.map((category) => this.buildCategoryTree(category)));\n        const categories = builtRoots.filter((c): c is AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel> => Boolean(c));\n\n        // Aggregate all items across remaining categories\n        const allItems: AXMMetaDataDefinitionEntityModel[] = [];\n        const collectItems = (nodes: AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel>[]) => {\n            for (const node of nodes) {\n                if (node.items?.length) {\n                    allItems.push(...node.items);\n                }\n                if (node.children?.length) {\n                    collectItems(node.children);\n                }\n            }\n        };\n        collectItems(categories);\n\n        // Add synthetic 'All' node at the beginning\n        const allNode: AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel> & { categories?: any[] } = {\n            id: 'all',\n            title: 'All',\n            childrenCount: 0,\n            items: allItems,\n            children: [],\n            categories: []\n        };\n\n        return [allNode, ...categories];\n    }\n\n    private async buildCategoryTree(category: any): Promise<AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel> | null> {\n        const itemsResult = await this.metaDataService.query({\n            filter: {\n                logic: 'and',\n                filters: [\n                    {\n                        field: 'categoryIds',\n                        operator: {\n                            type: 'contains',\n                        },\n                        value: category.id,\n                    },\n                ],\n            },\n            take: 1000,\n            skip: 0,\n        });\n\n        const childCategoriesResult = await this.categoryEntityService.query({\n            filter: {\n                logic: 'and',\n                filters: [\n                    {\n                        field: 'parentId',\n                        operator: {\n                            type: 'equal',\n                        },\n                        value: category.id,\n                    },\n                ],\n            },\n            take: 1000,\n            skip: 0,\n        });\n\n        const builtChildren = await Promise.all(childCategoriesResult.items.map((child) => this.buildCategoryTree(child)));\n        const children = builtChildren.filter((c): c is AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel> => Boolean(c));\n\n        const node: AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel> & { categories?: any[] } = {\n            ...category,\n            items: itemsResult.items,\n            categories: children,\n            children: children,\n        };\n\n        // Prune node if it has no items and no children\n        if ((!node.items || node.items.length === 0) && (!node.children || node.children.length === 0)) {\n            return null;\n        }\n\n        return node;\n    }\n\n\n\n}"]}"],"names":[],"mappings":"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"}
@@ -0,0 +1,80 @@
1
+ import * as i0 from '@angular/core';
2
+ import { inject, Injectable } from '@angular/core';
3
+ import { AXPEntityStorageService } from '@acorex/platform/layout/entity';
4
+
5
+ //#endregion
6
+ /**
7
+ * Complete Signature Process Command (Backend - Mock)
8
+ *
9
+ * Completes the signature process and updates the entity record.
10
+ * This command runs on the backend and finalizes the signature workflow.
11
+ */
12
+ class AXCCompleteSignatureProcessCommand {
13
+ constructor() {
14
+ //#region ---- Services & Dependencies ----
15
+ this.storageService = inject(AXPEntityStorageService);
16
+ }
17
+ //#endregion
18
+ //#region ---- AXPCommand Implementation ----
19
+ async execute(input) {
20
+ try {
21
+ console.log(`[AXCCompleteSignatureProcessCommand] Completing signature process for ${input.refType}:${input.refId}`);
22
+ // Validate inputs
23
+ if (!input.signatureRequestId || !input.refId || !input.refType) {
24
+ throw new Error('Invalid input: signatureRequestId, refId, and refType are required');
25
+ }
26
+ // In a real implementation, this would:
27
+ // 1. Mark signature request as completed
28
+ // 2. Update entity record with signature status
29
+ // 3. Store all signatures in the entity
30
+ // 4. Update audit trail
31
+ // 5. Send completion notifications
32
+ // Mock: simulate completion
33
+ // In production, we would update the entity record:
34
+ // await this.storageService.updateOne(input.refType, input.refId, {
35
+ // signatureStatus: 'completed',
36
+ // signatureCompletedAt: new Date().toISOString(),
37
+ // });
38
+ console.log(`[AXCCompleteSignatureProcessCommand] Signature process completed successfully`);
39
+ return {
40
+ success: true,
41
+ data: {
42
+ output: {
43
+ completed: true,
44
+ },
45
+ outcomes: {
46
+ Done: true,
47
+ },
48
+ },
49
+ };
50
+ }
51
+ catch (error) {
52
+ console.error(`[AXCCompleteSignatureProcessCommand] Failed to complete signature process:`, error);
53
+ return {
54
+ success: false,
55
+ message: {
56
+ text: error.message || 'Failed to complete signature process',
57
+ },
58
+ data: {
59
+ output: {
60
+ completed: false,
61
+ },
62
+ outcomes: {
63
+ Failed: true,
64
+ },
65
+ },
66
+ };
67
+ }
68
+ }
69
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXCCompleteSignatureProcessCommand, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
70
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXCCompleteSignatureProcessCommand, providedIn: 'root' }); }
71
+ }
72
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXCCompleteSignatureProcessCommand, decorators: [{
73
+ type: Injectable,
74
+ args: [{
75
+ providedIn: 'root',
76
+ }]
77
+ }] });
78
+
79
+ export { AXCCompleteSignatureProcessCommand };
80
+ //# sourceMappingURL=acorex-connectivity-mock-complete-signature-process.command-MIKenDnl.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"acorex-connectivity-mock-complete-signature-process.command-MIKenDnl.mjs","sources":["../tmp-esm2022/mock/lib/workflow-management/commands/complete-signature-process.command.js"],"sourcesContent":["import { Injectable } from '@angular/core';\nimport { AXPEntityStorageService } from '@acorex/platform/layout/entity';\nimport { inject } from '@angular/core';\nimport * as i0 from \"@angular/core\";\n//#endregion\n/**\n * Complete Signature Process Command (Backend - Mock)\n *\n * Completes the signature process and updates the entity record.\n * This command runs on the backend and finalizes the signature workflow.\n */\nexport class AXCCompleteSignatureProcessCommand {\n constructor() {\n //#region ---- Services & Dependencies ----\n this.storageService = inject(AXPEntityStorageService);\n }\n //#endregion\n //#region ---- AXPCommand Implementation ----\n async execute(input) {\n try {\n console.log(`[AXCCompleteSignatureProcessCommand] Completing signature process for ${input.refType}:${input.refId}`);\n // Validate inputs\n if (!input.signatureRequestId || !input.refId || !input.refType) {\n throw new Error('Invalid input: signatureRequestId, refId, and refType are required');\n }\n // In a real implementation, this would:\n // 1. Mark signature request as completed\n // 2. Update entity record with signature status\n // 3. Store all signatures in the entity\n // 4. Update audit trail\n // 5. Send completion notifications\n // Mock: simulate completion\n // In production, we would update the entity record:\n // await this.storageService.updateOne(input.refType, input.refId, {\n // signatureStatus: 'completed',\n // signatureCompletedAt: new Date().toISOString(),\n // });\n console.log(`[AXCCompleteSignatureProcessCommand] Signature process completed successfully`);\n return {\n success: true,\n data: {\n output: {\n completed: true,\n },\n outcomes: {\n Done: true,\n },\n },\n };\n }\n catch (error) {\n console.error(`[AXCCompleteSignatureProcessCommand] Failed to complete signature process:`, error);\n return {\n success: false,\n message: {\n text: error.message || 'Failed to complete signature process',\n },\n data: {\n output: {\n completed: false,\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: AXCCompleteSignatureProcessCommand, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: AXCCompleteSignatureProcessCommand, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: AXCCompleteSignatureProcessCommand, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root',\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcGxldGUtc2lnbmF0dXJlLXByb2Nlc3MuY29tbWFuZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29ubmVjdGl2aXR5L21vY2svc3JjL2xpYi93b3JrZmxvdy1tYW5hZ2VtZW50L2NvbW1hbmRzL2NvbXBsZXRlLXNpZ25hdHVyZS1wcm9jZXNzLmNvbW1hbmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUczQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN6RSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQWN2QyxZQUFZO0FBRVo7Ozs7O0dBS0c7QUFJSCxNQUFNLE9BQU8sa0NBQWtDO0lBSC9DO1FBS0UsK0NBQStDO1FBRTlCLG1CQUFjLEdBQUcsTUFBTSxDQUFDLHVCQUF1QixDQUFDLENBQUM7S0FtRW5FO0lBakVDLFlBQVk7SUFFWixpREFBaUQ7SUFFakQsS0FBSyxDQUFDLE9BQU8sQ0FDWCxLQUEyQztRQUUzQyxJQUFJLENBQUM7WUFDSCxPQUFPLENBQUMsR0FBRyxDQUNULHlFQUF5RSxLQUFLLENBQUMsT0FBTyxJQUFJLEtBQUssQ0FBQyxLQUFLLEVBQUUsQ0FDeEcsQ0FBQztZQUVGLGtCQUFrQjtZQUNsQixJQUFJLENBQUMsS0FBSyxDQUFDLGtCQUFrQixJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQztnQkFDaEUsTUFBTSxJQUFJLEtBQUssQ0FBQyxvRUFBb0UsQ0FBQyxDQUFDO1lBQ3hGLENBQUM7WUFFRCx3Q0FBd0M7WUFDeEMseUNBQXlDO1lBQ3pDLGdEQUFnRDtZQUNoRCx3Q0FBd0M7WUFDeEMsd0JBQXdCO1lBQ3hCLG1DQUFtQztZQUVuQyw0QkFBNEI7WUFDNUIsb0RBQW9EO1lBQ3BELG9FQUFvRTtZQUNwRSxrQ0FBa0M7WUFDbEMsb0RBQW9EO1lBQ3BELE1BQU07WUFFTixPQUFPLENBQUMsR0FBRyxDQUFDLCtFQUErRSxDQUFDLENBQUM7WUFFN0YsT0FBTztnQkFDTCxPQUFPLEVBQUUsSUFBSTtnQkFDYixJQUFJLEVBQUU7b0JBQ0osTUFBTSxFQUFFO3dCQUNOLFNBQVMsRUFBRSxJQUFJO3FCQUNoQjtvQkFDRCxRQUFRLEVBQUU7d0JBQ1IsSUFBSSxFQUFFLElBQUk7cUJBQ1g7aUJBQ0Y7YUFDRixDQUFDO1FBQ0osQ0FBQztRQUFDLE9BQU8sS0FBVSxFQUFFLENBQUM7WUFDcEIsT0FBTyxDQUFDLEtBQUssQ0FBQyw0RUFBNEUsRUFBRSxLQUFLLENBQUMsQ0FBQztZQUVuRyxPQUFPO2dCQUNMLE9BQU8sRUFBRSxLQUFLO2dCQUNkLE9BQU8sRUFBRTtvQkFDUCxJQUFJLEVBQUUsS0FBSyxDQUFDLE9BQU8sSUFBSSxzQ0FBc0M7aUJBQzlEO2dCQUNELElBQUksRUFBRTtvQkFDSixNQUFNLEVBQUU7d0JBQ04sU0FBUyxFQUFFLEtBQUs7cUJBQ2pCO29CQUNELFFBQVEsRUFBRTt3QkFDUixNQUFNLEVBQUUsSUFBSTtxQkFDYjtpQkFDRjthQUNGLENBQUM7UUFDSixDQUFDO0lBQ0gsQ0FBQzsrR0FwRVUsa0NBQWtDO21IQUFsQyxrQ0FBa0MsY0FGakMsTUFBTTs7NEZBRVAsa0NBQWtDO2tCQUg5QyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFYUEV4ZWN1dGVDb21tYW5kUmVzdWx0IH0gZnJvbSAnQGFjb3JleC9wbGF0Zm9ybS9jb3JlJztcbmltcG9ydCB7IEFYUENvbW1hbmQgfSBmcm9tICdAYWNvcmV4L3BsYXRmb3JtL3J1bnRpbWUnO1xuaW1wb3J0IHsgQVhQRW50aXR5U3RvcmFnZVNlcnZpY2UgfSBmcm9tICdAYWNvcmV4L3BsYXRmb3JtL2xheW91dC9lbnRpdHknO1xuaW1wb3J0IHsgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8vI3JlZ2lvbiAtLS0tICAgVHlwZXMgICAtLS0tXG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29tcGxldGVTaWduYXR1cmVQcm9jZXNzQ29tbWFuZElucHV0IHtcbiAgc2lnbmF0dXJlUmVxdWVzdElkOiBzdHJpbmc7XG4gIHJlZklkOiBzdHJpbmc7XG4gIHJlZlR5cGU6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDb21wbGV0ZVNpZ25hdHVyZVByb2Nlc3NDb21tYW5kT3V0cHV0IHtcbiAgY29tcGxldGVkOiBib29sZWFuO1xufVxuXG4vLyNlbmRyZWdpb25cblxuLyoqXG4gKiBDb21wbGV0ZSBTaWduYXR1cmUgUHJvY2VzcyBDb21tYW5kIChCYWNrZW5kIC0gTW9jaylcbiAqIFxuICogQ29tcGxldGVzIHRoZSBzaWduYXR1cmUgcHJvY2VzcyBhbmQgdXBkYXRlcyB0aGUgZW50aXR5IHJlY29yZC5cbiAqIFRoaXMgY29tbWFuZCBydW5zIG9uIHRoZSBiYWNrZW5kIGFuZCBmaW5hbGl6ZXMgdGhlIHNpZ25hdHVyZSB3b3JrZmxvdy5cbiAqL1xuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIEFYQ0NvbXBsZXRlU2lnbmF0dXJlUHJvY2Vzc0NvbW1hbmRcbiAgaW1wbGVtZW50cyBBWFBDb21tYW5kPENvbXBsZXRlU2lnbmF0dXJlUHJvY2Vzc0NvbW1hbmRJbnB1dCwgeyBvdXRwdXQ6IENvbXBsZXRlU2lnbmF0dXJlUHJvY2Vzc0NvbW1hbmRPdXRwdXQ7IG91dGNvbWVzOiBSZWNvcmQ8c3RyaW5nLCBhbnk+IH0+IHtcbiAgLy8jcmVnaW9uIC0tLS0gICBTZXJ2aWNlcyAmIERlcGVuZGVuY2llcyAgIC0tLS1cblxuICBwcml2YXRlIHJlYWRvbmx5IHN0b3JhZ2VTZXJ2aWNlID0gaW5qZWN0KEFYUEVudGl0eVN0b3JhZ2VTZXJ2aWNlKTtcblxuICAvLyNlbmRyZWdpb25cblxuICAvLyNyZWdpb24gLS0tLSAgIEFYUENvbW1hbmQgSW1wbGVtZW50YXRpb24gICAtLS0tXG5cbiAgYXN5bmMgZXhlY3V0ZShcbiAgICBpbnB1dDogQ29tcGxldGVTaWduYXR1cmVQcm9jZXNzQ29tbWFuZElucHV0LFxuICApOiBQcm9taXNlPEFYUEV4ZWN1dGVDb21tYW5kUmVzdWx0PHsgb3V0cHV0OiBDb21wbGV0ZVNpZ25hdHVyZVByb2Nlc3NDb21tYW5kT3V0cHV0OyBvdXRjb21lczogUmVjb3JkPHN0cmluZywgYW55PiB9Pj4ge1xuICAgIHRyeSB7XG4gICAgICBjb25zb2xlLmxvZyhcbiAgICAgICAgYFtBWENDb21wbGV0ZVNpZ25hdHVyZVByb2Nlc3NDb21tYW5kXSBDb21wbGV0aW5nIHNpZ25hdHVyZSBwcm9jZXNzIGZvciAke2lucHV0LnJlZlR5cGV9OiR7aW5wdXQucmVmSWR9YCxcbiAgICAgICk7XG5cbiAgICAgIC8vIFZhbGlkYXRlIGlucHV0c1xuICAgICAgaWYgKCFpbnB1dC5zaWduYXR1cmVSZXF1ZXN0SWQgfHwgIWlucHV0LnJlZklkIHx8ICFpbnB1dC5yZWZUeXBlKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcignSW52YWxpZCBpbnB1dDogc2lnbmF0dXJlUmVxdWVzdElkLCByZWZJZCwgYW5kIHJlZlR5cGUgYXJlIHJlcXVpcmVkJyk7XG4gICAgICB9XG5cbiAgICAgIC8vIEluIGEgcmVhbCBpbXBsZW1lbnRhdGlvbiwgdGhpcyB3b3VsZDpcbiAgICAgIC8vIDEuIE1hcmsgc2lnbmF0dXJlIHJlcXVlc3QgYXMgY29tcGxldGVkXG4gICAgICAvLyAyLiBVcGRhdGUgZW50aXR5IHJlY29yZCB3aXRoIHNpZ25hdHVyZSBzdGF0dXNcbiAgICAgIC8vIDMuIFN0b3JlIGFsbCBzaWduYXR1cmVzIGluIHRoZSBlbnRpdHlcbiAgICAgIC8vIDQuIFVwZGF0ZSBhdWRpdCB0cmFpbFxuICAgICAgLy8gNS4gU2VuZCBjb21wbGV0aW9uIG5vdGlmaWNhdGlvbnNcblxuICAgICAgLy8gTW9jazogc2ltdWxhdGUgY29tcGxldGlvblxuICAgICAgLy8gSW4gcHJvZHVjdGlvbiwgd2Ugd291bGQgdXBkYXRlIHRoZSBlbnRpdHkgcmVjb3JkOlxuICAgICAgLy8gYXdhaXQgdGhpcy5zdG9yYWdlU2VydmljZS51cGRhdGVPbmUoaW5wdXQucmVmVHlwZSwgaW5wdXQucmVmSWQsIHtcbiAgICAgIC8vICAgc2lnbmF0dXJlU3RhdHVzOiAnY29tcGxldGVkJyxcbiAgICAgIC8vICAgc2lnbmF0dXJlQ29tcGxldGVkQXQ6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcbiAgICAgIC8vIH0pO1xuXG4gICAgICBjb25zb2xlLmxvZyhgW0FYQ0NvbXBsZXRlU2lnbmF0dXJlUHJvY2Vzc0NvbW1hbmRdIFNpZ25hdHVyZSBwcm9jZXNzIGNvbXBsZXRlZCBzdWNjZXNzZnVsbHlgKTtcblxuICAgICAgcmV0dXJuIHtcbiAgICAgICAgc3VjY2VzczogdHJ1ZSxcbiAgICAgICAgZGF0YToge1xuICAgICAgICAgIG91dHB1dDoge1xuICAgICAgICAgICAgY29tcGxldGVkOiB0cnVlLFxuICAgICAgICAgIH0sXG4gICAgICAgICAgb3V0Y29tZXM6IHtcbiAgICAgICAgICAgIERvbmU6IHRydWUsXG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgIH07XG4gICAgfSBjYXRjaCAoZXJyb3I6IGFueSkge1xuICAgICAgY29uc29sZS5lcnJvcihgW0FYQ0NvbXBsZXRlU2lnbmF0dXJlUHJvY2Vzc0NvbW1hbmRdIEZhaWxlZCB0byBjb21wbGV0ZSBzaWduYXR1cmUgcHJvY2VzczpgLCBlcnJvcik7XG5cbiAgICAgIHJldHVybiB7XG4gICAgICAgIHN1Y2Nlc3M6IGZhbHNlLFxuICAgICAgICBtZXNzYWdlOiB7XG4gICAgICAgICAgdGV4dDogZXJyb3IubWVzc2FnZSB8fCAnRmFpbGVkIHRvIGNvbXBsZXRlIHNpZ25hdHVyZSBwcm9jZXNzJyxcbiAgICAgICAgfSxcbiAgICAgICAgZGF0YToge1xuICAgICAgICAgIG91dHB1dDoge1xuICAgICAgICAgICAgY29tcGxldGVkOiBmYWxzZSxcbiAgICAgICAgICB9LFxuICAgICAgICAgIG91dGNvbWVzOiB7XG4gICAgICAgICAgICBGYWlsZWQ6IHRydWUsXG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgIH07XG4gICAgfVxuICB9XG5cbiAgLy8jZW5kcmVnaW9uXG59XG5cbiJdfQ=="],"names":[],"mappings":";;;;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,MAAM,kCAAkC,CAAC;AAChD,IAAI,WAAW,GAAG;AAClB;AACA,QAAQ,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,uBAAuB,CAAC;AAC7D,IAAI;AACJ;AACA;AACA,IAAI,MAAM,OAAO,CAAC,KAAK,EAAE;AACzB,QAAQ,IAAI;AACZ,YAAY,OAAO,CAAC,GAAG,CAAC,CAAC,sEAAsE,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;AAChI;AACA,YAAY,IAAI,CAAC,KAAK,CAAC,kBAAkB,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE;AAC7E,gBAAgB,MAAM,IAAI,KAAK,CAAC,oEAAoE,CAAC;AACrG,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,OAAO,CAAC,GAAG,CAAC,CAAC,6EAA6E,CAAC,CAAC;AACxG,YAAY,OAAO;AACnB,gBAAgB,OAAO,EAAE,IAAI;AAC7B,gBAAgB,IAAI,EAAE;AACtB,oBAAoB,MAAM,EAAE;AAC5B,wBAAwB,SAAS,EAAE,IAAI;AACvC,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,0EAA0E,CAAC,EAAE,KAAK,CAAC;AAC9G,YAAY,OAAO;AACnB,gBAAgB,OAAO,EAAE,KAAK;AAC9B,gBAAgB,OAAO,EAAE;AACzB,oBAAoB,IAAI,EAAE,KAAK,CAAC,OAAO,IAAI,sCAAsC;AACjF,iBAAiB;AACjB,gBAAgB,IAAI,EAAE;AACtB,oBAAoB,MAAM,EAAE;AAC5B,wBAAwB,SAAS,EAAE,KAAK;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,kCAAkC,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,CAAC,eAAe,CAAC,UAAU,EAAE,CAAC,CAAC;AACtM,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,kCAAkC,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC,CAAC;AAC7K;AACA,EAAE,CAAC,wBAAwB,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,kCAAkC,EAAE,UAAU,EAAE,CAAC;AAC7I,YAAY,IAAI,EAAE,UAAU;AAC5B,YAAY,IAAI,EAAE,CAAC;AACnB,oBAAoB,UAAU,EAAE,MAAM;AACtC,iBAAiB;AACjB,SAAS,CAAC,EAAE,CAAC;;;;"}
@@ -44,10 +44,10 @@ class AXCDistributionCommand {
44
44
  };
45
45
  }
46
46
  }
47
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.12", ngImport: i0, type: AXCDistributionCommand, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
48
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.12", ngImport: i0, type: AXCDistributionCommand, providedIn: 'root' }); }
47
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXCDistributionCommand, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
48
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXCDistributionCommand, providedIn: 'root' }); }
49
49
  }
50
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.12", ngImport: i0, type: AXCDistributionCommand, decorators: [{
50
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AXCDistributionCommand, decorators: [{
51
51
  type: Injectable,
52
52
  args: [{
53
53
  providedIn: 'root',
@@ -55,4 +55,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.12", ngImpo
55
55
  }] });
56
56
 
57
57
  export { AXCDistributionCommand };
58
- //# sourceMappingURL=acorex-connectivity-mock-distribution-record.command-DRiDwlqN.mjs.map
58
+ //# sourceMappingURL=acorex-connectivity-mock-distribution-record.command-D9MRsoPw.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"acorex-connectivity-mock-distribution-record.command-DRiDwlqN.mjs","sources":["../tmp-esm2022/mock/lib/workflow-management/commands/distribution-record.command.js"],"sourcesContent":["import { AXMEntityCrudServiceImpl } from '@acorex/platform/layout/entity';\nimport { inject, Injectable, Injector, runInInjectionContext } from '@angular/core';\nimport * as i0 from \"@angular/core\";\nexport class AXCDistributionCommand {\n constructor() {\n this.injector = inject(Injector);\n }\n async execute(input) {\n const dataService = runInInjectionContext(this.injector, () => new AXMEntityCrudServiceImpl(`${input.refType}Distribution`));\n const dataServiceEntity = runInInjectionContext(this.injector, () => new AXMEntityCrudServiceImpl(input.refType));\n try {\n for (const user of input.assignedTo) {\n await dataService.insertOne({\n distributionRefId: input.refId,\n assignedId: user,\n distributionDate: new Date(),\n });\n await dataServiceEntity.updateOne(input.refId, {\n stateInfo: {\n ...(await dataServiceEntity.getOne(input.refId)).stateInfo,\n isDistributed: true,\n },\n });\n }\n return {\n success: true,\n data: {\n success: true,\n message: 'Distribution records created successfully',\n },\n };\n }\n catch (error) {\n return {\n success: false,\n message: {\n text: error instanceof Error ? error.message : 'Failed to create distribution records',\n },\n data: {\n success: false,\n message: 'Failed to create distribution records',\n },\n };\n }\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.12\", ngImport: i0, type: AXCDistributionCommand, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.12\", ngImport: i0, type: AXCDistributionCommand, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.12\", ngImport: i0, type: AXCDistributionCommand, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root',\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzdHJpYnV0aW9uLXJlY29yZC5jb21tYW5kLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb25uZWN0aXZpdHkvbW9jay9zcmMvbGliL3dvcmtmbG93LW1hbmFnZW1lbnQvY29tbWFuZHMvZGlzdHJpYnV0aW9uLXJlY29yZC5jb21tYW5kLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBRzFFLE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFnQnBGLE1BQU0sT0FBTyxzQkFBc0I7SUFIbkM7UUFLbUIsYUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztLQWlEOUM7SUEvQ0MsS0FBSyxDQUFDLE9BQU8sQ0FDWCxLQUF3QztRQUV4QyxNQUFNLFdBQVcsR0FBRyxxQkFBcUIsQ0FDdkMsSUFBSSxDQUFDLFFBQVEsRUFDYixHQUFHLEVBQUUsQ0FBQyxJQUFJLHdCQUF3QixDQUFXLEdBQUcsS0FBSyxDQUFDLE9BQU8sY0FBYyxDQUFDLENBQzdFLENBQUM7UUFFRixNQUFNLGlCQUFpQixHQUFHLHFCQUFxQixDQUM3QyxJQUFJLENBQUMsUUFBUSxFQUNiLEdBQUcsRUFBRSxDQUFDLElBQUksd0JBQXdCLENBQVcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUM1RCxDQUFDO1FBRUYsSUFBSSxDQUFDO1lBQ0gsS0FBSyxNQUFNLElBQUksSUFBSSxLQUFLLENBQUMsVUFBVSxFQUFFLENBQUM7Z0JBQ3BDLE1BQU0sV0FBVyxDQUFDLFNBQVMsQ0FBQztvQkFDMUIsaUJBQWlCLEVBQUUsS0FBSyxDQUFDLEtBQUs7b0JBQzlCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixnQkFBZ0IsRUFBRSxJQUFJLElBQUksRUFBRTtpQkFDN0IsQ0FBQyxDQUFDO2dCQUNILE1BQU0saUJBQWlCLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxLQUFLLEVBQUU7b0JBQzdDLFNBQVMsRUFBRTt3QkFDVCxHQUFHLENBQUMsTUFBTSxpQkFBaUIsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsU0FBUzt3QkFDMUQsYUFBYSxFQUFFLElBQUk7cUJBQ3BCO2lCQUNGLENBQUMsQ0FBQztZQUNMLENBQUM7WUFDRCxPQUFPO2dCQUNMLE9BQU8sRUFBRSxJQUFJO2dCQUNiLElBQUksRUFBRTtvQkFDSixPQUFPLEVBQUUsSUFBSTtvQkFDYixPQUFPLEVBQUUsMkNBQTJDO2lCQUNyRDthQUNGLENBQUM7UUFDSixDQUFDO1FBQUMsT0FBTyxLQUFLLEVBQUUsQ0FBQztZQUNmLE9BQU87Z0JBQ0wsT0FBTyxFQUFFLEtBQUs7Z0JBQ2QsT0FBTyxFQUFFO29CQUNQLElBQUksRUFBRSxLQUFLLFlBQVksS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyx1Q0FBdUM7aUJBQ3ZGO2dCQUNELElBQUksRUFBRTtvQkFDSixPQUFPLEVBQUUsS0FBSztvQkFDZCxPQUFPLEVBQUUsdUNBQXVDO2lCQUNqRDthQUNGLENBQUM7UUFDSixDQUFDO0lBQ0gsQ0FBQzsrR0FsRFUsc0JBQXNCO21IQUF0QixzQkFBc0IsY0FGckIsTUFBTTs7NEZBRVAsc0JBQXNCO2tCQUhsQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFYTUVudGl0eUNydWRTZXJ2aWNlSW1wbCB9IGZyb20gJ0BhY29yZXgvcGxhdGZvcm0vbGF5b3V0L2VudGl0eSc7XG5pbXBvcnQgeyBBWFBFeGVjdXRlQ29tbWFuZFJlc3VsdCB9IGZyb20gJ0BhY29yZXgvcGxhdGZvcm0vY29yZSc7XG5pbXBvcnQgeyBBWFBDb21tYW5kIH0gZnJvbSAnQGFjb3JleC9wbGF0Zm9ybS9ydW50aW1lJztcbmltcG9ydCB7IGluamVjdCwgSW5qZWN0YWJsZSwgSW5qZWN0b3IsIHJ1bkluSW5qZWN0aW9uQ29udGV4dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEFYQ0Rpc3RyaWJ1dGlvblJlY29yZENvbW1hbmRJbnB1dCB7XG4gIHJlZklkOiBzdHJpbmc7XG4gIHJlZlR5cGU6IHN0cmluZztcbiAgYXNzaWduZWRUbzogc3RyaW5nW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQVhDRGlzdHJpYnV0aW9uUmVjb3JkQ29tbWFuZE91dHB1dCB7XG4gIHN1Y2Nlc3M6IGJvb2xlYW47XG4gIG1lc3NhZ2U6IHN0cmluZztcbn1cblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIEFYQ0Rpc3RyaWJ1dGlvbkNvbW1hbmRcbiAgaW1wbGVtZW50cyBBWFBDb21tYW5kPEFYQ0Rpc3RyaWJ1dGlvblJlY29yZENvbW1hbmRJbnB1dCwgQVhDRGlzdHJpYnV0aW9uUmVjb3JkQ29tbWFuZE91dHB1dD4ge1xuICBwcml2YXRlIHJlYWRvbmx5IGluamVjdG9yID0gaW5qZWN0KEluamVjdG9yKTtcblxuICBhc3luYyBleGVjdXRlKFxuICAgIGlucHV0OiBBWENEaXN0cmlidXRpb25SZWNvcmRDb21tYW5kSW5wdXQsXG4gICk6IFByb21pc2U8QVhQRXhlY3V0ZUNvbW1hbmRSZXN1bHQ8QVhDRGlzdHJpYnV0aW9uUmVjb3JkQ29tbWFuZE91dHB1dD4+IHtcbiAgICBjb25zdCBkYXRhU2VydmljZSA9IHJ1bkluSW5qZWN0aW9uQ29udGV4dChcbiAgICAgIHRoaXMuaW5qZWN0b3IsXG4gICAgICAoKSA9PiBuZXcgQVhNRW50aXR5Q3J1ZFNlcnZpY2VJbXBsPGFueSwgYW55PihgJHtpbnB1dC5yZWZUeXBlfURpc3RyaWJ1dGlvbmApLFxuICAgICk7XG5cbiAgICBjb25zdCBkYXRhU2VydmljZUVudGl0eSA9IHJ1bkluSW5qZWN0aW9uQ29udGV4dChcbiAgICAgIHRoaXMuaW5qZWN0b3IsXG4gICAgICAoKSA9PiBuZXcgQVhNRW50aXR5Q3J1ZFNlcnZpY2VJbXBsPGFueSwgYW55PihpbnB1dC5yZWZUeXBlKSxcbiAgICApO1xuXG4gICAgdHJ5IHtcbiAgICAgIGZvciAoY29uc3QgdXNlciBvZiBpbnB1dC5hc3NpZ25lZFRvKSB7XG4gICAgICAgIGF3YWl0IGRhdGFTZXJ2aWNlLmluc2VydE9uZSh7XG4gICAgICAgICAgZGlzdHJpYnV0aW9uUmVmSWQ6IGlucHV0LnJlZklkLFxuICAgICAgICAgIGFzc2lnbmVkSWQ6IHVzZXIsXG4gICAgICAgICAgZGlzdHJpYnV0aW9uRGF0ZTogbmV3IERhdGUoKSxcbiAgICAgICAgfSk7XG4gICAgICAgIGF3YWl0IGRhdGFTZXJ2aWNlRW50aXR5LnVwZGF0ZU9uZShpbnB1dC5yZWZJZCwge1xuICAgICAgICAgIHN0YXRlSW5mbzoge1xuICAgICAgICAgICAgLi4uKGF3YWl0IGRhdGFTZXJ2aWNlRW50aXR5LmdldE9uZShpbnB1dC5yZWZJZCkpLnN0YXRlSW5mbyxcbiAgICAgICAgICAgIGlzRGlzdHJpYnV0ZWQ6IHRydWUsXG4gICAgICAgICAgfSxcbiAgICAgICAgfSk7XG4gICAgICB9XG4gICAgICByZXR1cm4ge1xuICAgICAgICBzdWNjZXNzOiB0cnVlLFxuICAgICAgICBkYXRhOiB7XG4gICAgICAgICAgc3VjY2VzczogdHJ1ZSxcbiAgICAgICAgICBtZXNzYWdlOiAnRGlzdHJpYnV0aW9uIHJlY29yZHMgY3JlYXRlZCBzdWNjZXNzZnVsbHknLFxuICAgICAgICB9LFxuICAgICAgfTtcbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgcmV0dXJuIHtcbiAgICAgICAgc3VjY2VzczogZmFsc2UsXG4gICAgICAgIG1lc3NhZ2U6IHtcbiAgICAgICAgICB0ZXh0OiBlcnJvciBpbnN0YW5jZW9mIEVycm9yID8gZXJyb3IubWVzc2FnZSA6ICdGYWlsZWQgdG8gY3JlYXRlIGRpc3RyaWJ1dGlvbiByZWNvcmRzJyxcbiAgICAgICAgfSxcbiAgICAgICAgZGF0YToge1xuICAgICAgICAgIHN1Y2Nlc3M6IGZhbHNlLFxuICAgICAgICAgIG1lc3NhZ2U6ICdGYWlsZWQgdG8gY3JlYXRlIGRpc3RyaWJ1dGlvbiByZWNvcmRzJyxcbiAgICAgICAgfSxcbiAgICAgIH07XG4gICAgfVxuICB9XG59XG4iXX0="],"names":[],"mappings":";;;;AAGO,MAAM,sBAAsB,CAAC;AACpC,IAAI,WAAW,GAAG;AAClB,QAAQ,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;AACxC,IAAI;AACJ,IAAI,MAAM,OAAO,CAAC,KAAK,EAAE;AACzB,QAAQ,MAAM,WAAW,GAAG,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EAAE,MAAM,IAAI,wBAAwB,CAAC,CAAC,EAAE,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC;AACpI,QAAQ,MAAM,iBAAiB,GAAG,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EAAE,MAAM,IAAI,wBAAwB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;AACzH,QAAQ,IAAI;AACZ,YAAY,KAAK,MAAM,IAAI,IAAI,KAAK,CAAC,UAAU,EAAE;AACjD,gBAAgB,MAAM,WAAW,CAAC,SAAS,CAAC;AAC5C,oBAAoB,iBAAiB,EAAE,KAAK,CAAC,KAAK;AAClD,oBAAoB,UAAU,EAAE,IAAI;AACpC,oBAAoB,gBAAgB,EAAE,IAAI,IAAI,EAAE;AAChD,iBAAiB,CAAC;AAClB,gBAAgB,MAAM,iBAAiB,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,EAAE;AAC/D,oBAAoB,SAAS,EAAE;AAC/B,wBAAwB,GAAG,CAAC,MAAM,iBAAiB,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,SAAS;AAClF,wBAAwB,aAAa,EAAE,IAAI;AAC3C,qBAAqB;AACrB,iBAAiB,CAAC;AAClB,YAAY;AACZ,YAAY,OAAO;AACnB,gBAAgB,OAAO,EAAE,IAAI;AAC7B,gBAAgB,IAAI,EAAE;AACtB,oBAAoB,OAAO,EAAE,IAAI;AACjC,oBAAoB,OAAO,EAAE,2CAA2C;AACxE,iBAAiB;AACjB,aAAa;AACb,QAAQ;AACR,QAAQ,OAAO,KAAK,EAAE;AACtB,YAAY,OAAO;AACnB,gBAAgB,OAAO,EAAE,KAAK;AAC9B,gBAAgB,OAAO,EAAE;AACzB,oBAAoB,IAAI,EAAE,KAAK,YAAY,KAAK,GAAG,KAAK,CAAC,OAAO,GAAG,uCAAuC;AAC1G,iBAAiB;AACjB,gBAAgB,IAAI,EAAE;AACtB,oBAAoB,OAAO,EAAE,KAAK;AAClC,oBAAoB,OAAO,EAAE,uCAAuC;AACpE,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,sBAAsB,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,CAAC,eAAe,CAAC,UAAU,EAAE,CAAC,CAAC;AAC1L,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,sBAAsB,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC,CAAC;AACjK;AACA,EAAE,CAAC,wBAAwB,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,sBAAsB,EAAE,UAAU,EAAE,CAAC;AACjI,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-distribution-record.command-D9MRsoPw.mjs","sources":["../tmp-esm2022/mock/lib/workflow-management/commands/distribution-record.command.js"],"sourcesContent":["import { AXMEntityCrudServiceImpl } from '@acorex/platform/layout/entity';\nimport { inject, Injectable, Injector, runInInjectionContext } from '@angular/core';\nimport * as i0 from \"@angular/core\";\nexport class AXCDistributionCommand {\n constructor() {\n this.injector = inject(Injector);\n }\n async execute(input) {\n const dataService = runInInjectionContext(this.injector, () => new AXMEntityCrudServiceImpl(`${input.refType}Distribution`));\n const dataServiceEntity = runInInjectionContext(this.injector, () => new AXMEntityCrudServiceImpl(input.refType));\n try {\n for (const user of input.assignedTo) {\n await dataService.insertOne({\n distributionRefId: input.refId,\n assignedId: user,\n distributionDate: new Date(),\n });\n await dataServiceEntity.updateOne(input.refId, {\n stateInfo: {\n ...(await dataServiceEntity.getOne(input.refId)).stateInfo,\n isDistributed: true,\n },\n });\n }\n return {\n success: true,\n data: {\n success: true,\n message: 'Distribution records created successfully',\n },\n };\n }\n catch (error) {\n return {\n success: false,\n message: {\n text: error instanceof Error ? error.message : 'Failed to create distribution records',\n },\n data: {\n success: false,\n message: 'Failed to create distribution records',\n },\n };\n }\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: AXCDistributionCommand, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: AXCDistributionCommand, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: AXCDistributionCommand, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root',\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzdHJpYnV0aW9uLXJlY29yZC5jb21tYW5kLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb25uZWN0aXZpdHkvbW9jay9zcmMvbGliL3dvcmtmbG93LW1hbmFnZW1lbnQvY29tbWFuZHMvZGlzdHJpYnV0aW9uLXJlY29yZC5jb21tYW5kLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBRzFFLE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFnQnBGLE1BQU0sT0FBTyxzQkFBc0I7SUFIbkM7UUFLbUIsYUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztLQWlEOUM7SUEvQ0MsS0FBSyxDQUFDLE9BQU8sQ0FDWCxLQUF3QztRQUV4QyxNQUFNLFdBQVcsR0FBRyxxQkFBcUIsQ0FDdkMsSUFBSSxDQUFDLFFBQVEsRUFDYixHQUFHLEVBQUUsQ0FBQyxJQUFJLHdCQUF3QixDQUFXLEdBQUcsS0FBSyxDQUFDLE9BQU8sY0FBYyxDQUFDLENBQzdFLENBQUM7UUFFRixNQUFNLGlCQUFpQixHQUFHLHFCQUFxQixDQUM3QyxJQUFJLENBQUMsUUFBUSxFQUNiLEdBQUcsRUFBRSxDQUFDLElBQUksd0JBQXdCLENBQVcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUM1RCxDQUFDO1FBRUYsSUFBSSxDQUFDO1lBQ0gsS0FBSyxNQUFNLElBQUksSUFBSSxLQUFLLENBQUMsVUFBVSxFQUFFLENBQUM7Z0JBQ3BDLE1BQU0sV0FBVyxDQUFDLFNBQVMsQ0FBQztvQkFDMUIsaUJBQWlCLEVBQUUsS0FBSyxDQUFDLEtBQUs7b0JBQzlCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixnQkFBZ0IsRUFBRSxJQUFJLElBQUksRUFBRTtpQkFDN0IsQ0FBQyxDQUFDO2dCQUNILE1BQU0saUJBQWlCLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxLQUFLLEVBQUU7b0JBQzdDLFNBQVMsRUFBRTt3QkFDVCxHQUFHLENBQUMsTUFBTSxpQkFBaUIsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsU0FBUzt3QkFDMUQsYUFBYSxFQUFFLElBQUk7cUJBQ3BCO2lCQUNGLENBQUMsQ0FBQztZQUNMLENBQUM7WUFDRCxPQUFPO2dCQUNMLE9BQU8sRUFBRSxJQUFJO2dCQUNiLElBQUksRUFBRTtvQkFDSixPQUFPLEVBQUUsSUFBSTtvQkFDYixPQUFPLEVBQUUsMkNBQTJDO2lCQUNyRDthQUNGLENBQUM7UUFDSixDQUFDO1FBQUMsT0FBTyxLQUFLLEVBQUUsQ0FBQztZQUNmLE9BQU87Z0JBQ0wsT0FBTyxFQUFFLEtBQUs7Z0JBQ2QsT0FBTyxFQUFFO29CQUNQLElBQUksRUFBRSxLQUFLLFlBQVksS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyx1Q0FBdUM7aUJBQ3ZGO2dCQUNELElBQUksRUFBRTtvQkFDSixPQUFPLEVBQUUsS0FBSztvQkFDZCxPQUFPLEVBQUUsdUNBQXVDO2lCQUNqRDthQUNGLENBQUM7UUFDSixDQUFDO0lBQ0gsQ0FBQzsrR0FsRFUsc0JBQXNCO21IQUF0QixzQkFBc0IsY0FGckIsTUFBTTs7NEZBRVAsc0JBQXNCO2tCQUhsQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFYTUVudGl0eUNydWRTZXJ2aWNlSW1wbCB9IGZyb20gJ0BhY29yZXgvcGxhdGZvcm0vbGF5b3V0L2VudGl0eSc7XG5pbXBvcnQgeyBBWFBFeGVjdXRlQ29tbWFuZFJlc3VsdCB9IGZyb20gJ0BhY29yZXgvcGxhdGZvcm0vY29yZSc7XG5pbXBvcnQgeyBBWFBDb21tYW5kIH0gZnJvbSAnQGFjb3JleC9wbGF0Zm9ybS9ydW50aW1lJztcbmltcG9ydCB7IGluamVjdCwgSW5qZWN0YWJsZSwgSW5qZWN0b3IsIHJ1bkluSW5qZWN0aW9uQ29udGV4dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEFYQ0Rpc3RyaWJ1dGlvblJlY29yZENvbW1hbmRJbnB1dCB7XG4gIHJlZklkOiBzdHJpbmc7XG4gIHJlZlR5cGU6IHN0cmluZztcbiAgYXNzaWduZWRUbzogc3RyaW5nW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQVhDRGlzdHJpYnV0aW9uUmVjb3JkQ29tbWFuZE91dHB1dCB7XG4gIHN1Y2Nlc3M6IGJvb2xlYW47XG4gIG1lc3NhZ2U6IHN0cmluZztcbn1cblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIEFYQ0Rpc3RyaWJ1dGlvbkNvbW1hbmRcbiAgaW1wbGVtZW50cyBBWFBDb21tYW5kPEFYQ0Rpc3RyaWJ1dGlvblJlY29yZENvbW1hbmRJbnB1dCwgQVhDRGlzdHJpYnV0aW9uUmVjb3JkQ29tbWFuZE91dHB1dD4ge1xuICBwcml2YXRlIHJlYWRvbmx5IGluamVjdG9yID0gaW5qZWN0KEluamVjdG9yKTtcblxuICBhc3luYyBleGVjdXRlKFxuICAgIGlucHV0OiBBWENEaXN0cmlidXRpb25SZWNvcmRDb21tYW5kSW5wdXQsXG4gICk6IFByb21pc2U8QVhQRXhlY3V0ZUNvbW1hbmRSZXN1bHQ8QVhDRGlzdHJpYnV0aW9uUmVjb3JkQ29tbWFuZE91dHB1dD4+IHtcbiAgICBjb25zdCBkYXRhU2VydmljZSA9IHJ1bkluSW5qZWN0aW9uQ29udGV4dChcbiAgICAgIHRoaXMuaW5qZWN0b3IsXG4gICAgICAoKSA9PiBuZXcgQVhNRW50aXR5Q3J1ZFNlcnZpY2VJbXBsPGFueSwgYW55PihgJHtpbnB1dC5yZWZUeXBlfURpc3RyaWJ1dGlvbmApLFxuICAgICk7XG5cbiAgICBjb25zdCBkYXRhU2VydmljZUVudGl0eSA9IHJ1bkluSW5qZWN0aW9uQ29udGV4dChcbiAgICAgIHRoaXMuaW5qZWN0b3IsXG4gICAgICAoKSA9PiBuZXcgQVhNRW50aXR5Q3J1ZFNlcnZpY2VJbXBsPGFueSwgYW55PihpbnB1dC5yZWZUeXBlKSxcbiAgICApO1xuXG4gICAgdHJ5IHtcbiAgICAgIGZvciAoY29uc3QgdXNlciBvZiBpbnB1dC5hc3NpZ25lZFRvKSB7XG4gICAgICAgIGF3YWl0IGRhdGFTZXJ2aWNlLmluc2VydE9uZSh7XG4gICAgICAgICAgZGlzdHJpYnV0aW9uUmVmSWQ6IGlucHV0LnJlZklkLFxuICAgICAgICAgIGFzc2lnbmVkSWQ6IHVzZXIsXG4gICAgICAgICAgZGlzdHJpYnV0aW9uRGF0ZTogbmV3IERhdGUoKSxcbiAgICAgICAgfSk7XG4gICAgICAgIGF3YWl0IGRhdGFTZXJ2aWNlRW50aXR5LnVwZGF0ZU9uZShpbnB1dC5yZWZJZCwge1xuICAgICAgICAgIHN0YXRlSW5mbzoge1xuICAgICAgICAgICAgLi4uKGF3YWl0IGRhdGFTZXJ2aWNlRW50aXR5LmdldE9uZShpbnB1dC5yZWZJZCkpLnN0YXRlSW5mbyxcbiAgICAgICAgICAgIGlzRGlzdHJpYnV0ZWQ6IHRydWUsXG4gICAgICAgICAgfSxcbiAgICAgICAgfSk7XG4gICAgICB9XG4gICAgICByZXR1cm4ge1xuICAgICAgICBzdWNjZXNzOiB0cnVlLFxuICAgICAgICBkYXRhOiB7XG4gICAgICAgICAgc3VjY2VzczogdHJ1ZSxcbiAgICAgICAgICBtZXNzYWdlOiAnRGlzdHJpYnV0aW9uIHJlY29yZHMgY3JlYXRlZCBzdWNjZXNzZnVsbHknLFxuICAgICAgICB9LFxuICAgICAgfTtcbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgcmV0dXJuIHtcbiAgICAgICAgc3VjY2VzczogZmFsc2UsXG4gICAgICAgIG1lc3NhZ2U6IHtcbiAgICAgICAgICB0ZXh0OiBlcnJvciBpbnN0YW5jZW9mIEVycm9yID8gZXJyb3IubWVzc2FnZSA6ICdGYWlsZWQgdG8gY3JlYXRlIGRpc3RyaWJ1dGlvbiByZWNvcmRzJyxcbiAgICAgICAgfSxcbiAgICAgICAgZGF0YToge1xuICAgICAgICAgIHN1Y2Nlc3M6IGZhbHNlLFxuICAgICAgICAgIG1lc3NhZ2U6ICdGYWlsZWQgdG8gY3JlYXRlIGRpc3RyaWJ1dGlvbiByZWNvcmRzJyxcbiAgICAgICAgfSxcbiAgICAgIH07XG4gICAgfVxuICB9XG59XG4iXX0="],"names":[],"mappings":";;;;AAGO,MAAM,sBAAsB,CAAC;AACpC,IAAI,WAAW,GAAG;AAClB,QAAQ,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;AACxC,IAAI;AACJ,IAAI,MAAM,OAAO,CAAC,KAAK,EAAE;AACzB,QAAQ,MAAM,WAAW,GAAG,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EAAE,MAAM,IAAI,wBAAwB,CAAC,CAAC,EAAE,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC;AACpI,QAAQ,MAAM,iBAAiB,GAAG,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EAAE,MAAM,IAAI,wBAAwB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;AACzH,QAAQ,IAAI;AACZ,YAAY,KAAK,MAAM,IAAI,IAAI,KAAK,CAAC,UAAU,EAAE;AACjD,gBAAgB,MAAM,WAAW,CAAC,SAAS,CAAC;AAC5C,oBAAoB,iBAAiB,EAAE,KAAK,CAAC,KAAK;AAClD,oBAAoB,UAAU,EAAE,IAAI;AACpC,oBAAoB,gBAAgB,EAAE,IAAI,IAAI,EAAE;AAChD,iBAAiB,CAAC;AAClB,gBAAgB,MAAM,iBAAiB,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,EAAE;AAC/D,oBAAoB,SAAS,EAAE;AAC/B,wBAAwB,GAAG,CAAC,MAAM,iBAAiB,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,SAAS;AAClF,wBAAwB,aAAa,EAAE,IAAI;AAC3C,qBAAqB;AACrB,iBAAiB,CAAC;AAClB,YAAY;AACZ,YAAY,OAAO;AACnB,gBAAgB,OAAO,EAAE,IAAI;AAC7B,gBAAgB,IAAI,EAAE;AACtB,oBAAoB,OAAO,EAAE,IAAI;AACjC,oBAAoB,OAAO,EAAE,2CAA2C;AACxE,iBAAiB;AACjB,aAAa;AACb,QAAQ;AACR,QAAQ,OAAO,KAAK,EAAE;AACtB,YAAY,OAAO;AACnB,gBAAgB,OAAO,EAAE,KAAK;AAC9B,gBAAgB,OAAO,EAAE;AACzB,oBAAoB,IAAI,EAAE,KAAK,YAAY,KAAK,GAAG,KAAK,CAAC,OAAO,GAAG,uCAAuC;AAC1G,iBAAiB;AACjB,gBAAgB,IAAI,EAAE;AACtB,oBAAoB,OAAO,EAAE,KAAK;AAClC,oBAAoB,OAAO,EAAE,uCAAuC;AACpE,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,sBAAsB,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,CAAC,eAAe,CAAC,UAAU,EAAE,CAAC,CAAC;AAC1L,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,sBAAsB,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC,CAAC;AACjK;AACA,EAAE,CAAC,wBAAwB,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,sBAAsB,EAAE,UAAU,EAAE,CAAC;AACjI,YAAY,IAAI,EAAE,UAAU;AAC5B,YAAY,IAAI,EAAE,CAAC;AACnB,oBAAoB,UAAU,EAAE,MAAM;AACtC,iBAAiB;AACjB,SAAS,CAAC,EAAE,CAAC;;;;"}
@@ -0,0 +1,115 @@
1
+ import * as i0 from '@angular/core';
2
+ import { inject, Injectable } from '@angular/core';
3
+ import { AXPEntityService } from '@acorex/platform/layout/entity';
4
+ import { RootConfig } from '@acorex/modules/application-management';
5
+
6
+ //#endregion
7
+ class GetApplicationVersionsChartDataQuery {
8
+ constructor() {
9
+ this.entityService = inject(AXPEntityService);
10
+ this.appVersionService = this.entityService
11
+ .withEntity(`${RootConfig.module.name}.${RootConfig.entities.appVersion.name}`)
12
+ .data();
13
+ }
14
+ async fetch(input) {
15
+ // Get all app versions from storage (no pagination for charts)
16
+ const allVersionsResult = await this.appVersionService.query({
17
+ skip: 0,
18
+ take: 10000, // Get all versions for aggregation
19
+ filter: input.filters && input.filters.length > 0
20
+ ? {
21
+ logic: input.logic || 'and',
22
+ filters: input.filters,
23
+ }
24
+ : undefined,
25
+ });
26
+ let allVersions = allVersionsResult.items;
27
+ // Apply custom filters after fetching
28
+ if (input.filters) {
29
+ for (const filter of input.filters) {
30
+ if (filter.field === 'dateRange' && filter.value) {
31
+ allVersions = this.applyDateRangeFilter(allVersions, filter.value);
32
+ }
33
+ if (filter.field === 'versionNumber' && filter.value) {
34
+ allVersions = this.applyVersionNumberFilter(allVersions, filter.value);
35
+ }
36
+ }
37
+ }
38
+ // Group versions by month for chart aggregation
39
+ const monthGroups = new Map();
40
+ for (const version of allVersions) {
41
+ const publishDate = new Date(version.publishDate);
42
+ const year = publishDate.getFullYear();
43
+ const month = publishDate.getMonth() + 1;
44
+ const monthKey = `${year}-${String(month).padStart(2, '0')}`;
45
+ if (!monthGroups.has(monthKey)) {
46
+ monthGroups.set(monthKey, []);
47
+ }
48
+ monthGroups.get(monthKey).push(version);
49
+ }
50
+ // Aggregate data by month for chart
51
+ const chartResults = [];
52
+ for (const [monthKey, versions] of monthGroups.entries()) {
53
+ const [year, month] = monthKey.split('-');
54
+ const publishDate = new Date(parseInt(year), parseInt(month) - 1, 1);
55
+ const monthName = publishDate.toLocaleString('en-US', { month: 'long' });
56
+ const quarter = Math.ceil(parseInt(month) / 3);
57
+ const quarterName = `Q${quarter}`;
58
+ chartResults.push({
59
+ publishDate: publishDate.toISOString(),
60
+ month: monthName,
61
+ year: parseInt(year),
62
+ quarter: quarterName,
63
+ versionCount: versions.length,
64
+ });
65
+ }
66
+ // Sort by date ascending for timeline
67
+ chartResults.sort((a, b) => {
68
+ const dateA = new Date(a.publishDate).getTime();
69
+ const dateB = new Date(b.publishDate).getTime();
70
+ return dateA - dateB;
71
+ });
72
+ return {
73
+ items: chartResults,
74
+ };
75
+ }
76
+ //#region ---- Custom Filter Handlers ----
77
+ /**
78
+ * Apply date range filter to versions
79
+ */
80
+ applyDateRangeFilter(versions, dateRange) {
81
+ if (!dateRange || !dateRange.start || !dateRange.end) {
82
+ return versions;
83
+ }
84
+ const startDate = new Date(dateRange.start);
85
+ const endDate = new Date(dateRange.end);
86
+ endDate.setHours(23, 59, 59, 999); // Include the entire end date
87
+ return versions.filter((version) => {
88
+ const publishDate = new Date(version.publishDate);
89
+ return publishDate >= startDate && publishDate <= endDate;
90
+ });
91
+ }
92
+ /**
93
+ * Apply version number filter to versions
94
+ */
95
+ applyVersionNumberFilter(versions, versionNumber) {
96
+ if (!versionNumber) {
97
+ return versions;
98
+ }
99
+ const searchTerm = versionNumber.toLowerCase().trim();
100
+ return versions.filter((version) => {
101
+ return version.versionNumber.toLowerCase().includes(searchTerm);
102
+ });
103
+ }
104
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: GetApplicationVersionsChartDataQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
105
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: GetApplicationVersionsChartDataQuery, providedIn: 'root' }); }
106
+ }
107
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: GetApplicationVersionsChartDataQuery, decorators: [{
108
+ type: Injectable,
109
+ args: [{
110
+ providedIn: 'root',
111
+ }]
112
+ }] });
113
+
114
+ export { GetApplicationVersionsChartDataQuery };
115
+ //# sourceMappingURL=acorex-connectivity-mock-get-application-versions-chart-data.query-H6rrh30t.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"acorex-connectivity-mock-get-application-versions-chart-data.query-H6rrh30t.mjs","sources":["../tmp-esm2022/mock/lib/application-management/reports/get-application-versions-chart-data.query.js"],"sourcesContent":["import { inject, Injectable } from '@angular/core';\nimport { AXPEntityService } from '@acorex/platform/layout/entity';\nimport { RootConfig } from '@acorex/modules/application-management';\nimport * as i0 from \"@angular/core\";\n//#endregion\nexport class GetApplicationVersionsChartDataQuery {\n constructor() {\n this.entityService = inject(AXPEntityService);\n this.appVersionService = this.entityService\n .withEntity(`${RootConfig.module.name}.${RootConfig.entities.appVersion.name}`)\n .data();\n }\n async fetch(input) {\n // Get all app versions from storage (no pagination for charts)\n const allVersionsResult = await this.appVersionService.query({\n skip: 0,\n take: 10000, // Get all versions for aggregation\n filter: input.filters && input.filters.length > 0\n ? {\n logic: input.logic || 'and',\n filters: input.filters,\n }\n : undefined,\n });\n let allVersions = allVersionsResult.items;\n // Apply custom filters after fetching\n if (input.filters) {\n for (const filter of input.filters) {\n if (filter.field === 'dateRange' && filter.value) {\n allVersions = this.applyDateRangeFilter(allVersions, filter.value);\n }\n if (filter.field === 'versionNumber' && filter.value) {\n allVersions = this.applyVersionNumberFilter(allVersions, filter.value);\n }\n }\n }\n // Group versions by month for chart aggregation\n const monthGroups = new Map();\n for (const version of allVersions) {\n const publishDate = new Date(version.publishDate);\n const year = publishDate.getFullYear();\n const month = publishDate.getMonth() + 1;\n const monthKey = `${year}-${String(month).padStart(2, '0')}`;\n if (!monthGroups.has(monthKey)) {\n monthGroups.set(monthKey, []);\n }\n monthGroups.get(monthKey).push(version);\n }\n // Aggregate data by month for chart\n const chartResults = [];\n for (const [monthKey, versions] of monthGroups.entries()) {\n const [year, month] = monthKey.split('-');\n const publishDate = new Date(parseInt(year), parseInt(month) - 1, 1);\n const monthName = publishDate.toLocaleString('en-US', { month: 'long' });\n const quarter = Math.ceil(parseInt(month) / 3);\n const quarterName = `Q${quarter}`;\n chartResults.push({\n publishDate: publishDate.toISOString(),\n month: monthName,\n year: parseInt(year),\n quarter: quarterName,\n versionCount: versions.length,\n });\n }\n // Sort by date ascending for timeline\n chartResults.sort((a, b) => {\n const dateA = new Date(a.publishDate).getTime();\n const dateB = new Date(b.publishDate).getTime();\n return dateA - dateB;\n });\n return {\n items: chartResults,\n };\n }\n //#region ---- Custom Filter Handlers ----\n /**\n * Apply date range filter to versions\n */\n applyDateRangeFilter(versions, dateRange) {\n if (!dateRange || !dateRange.start || !dateRange.end) {\n return versions;\n }\n const startDate = new Date(dateRange.start);\n const endDate = new Date(dateRange.end);\n endDate.setHours(23, 59, 59, 999); // Include the entire end date\n return versions.filter((version) => {\n const publishDate = new Date(version.publishDate);\n return publishDate >= startDate && publishDate <= endDate;\n });\n }\n /**\n * Apply version number filter to versions\n */\n applyVersionNumberFilter(versions, versionNumber) {\n if (!versionNumber) {\n return versions;\n }\n const searchTerm = versionNumber.toLowerCase().trim();\n return versions.filter((version) => {\n return version.versionNumber.toLowerCase().includes(searchTerm);\n });\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: GetApplicationVersionsChartDataQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: GetApplicationVersionsChartDataQuery, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.15\", ngImport: i0, type: GetApplicationVersionsChartDataQuery, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root',\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"get-application-versions-chart-data.query.js","sourceRoot":"","sources":["../../../../../../../../libs/connectivity/mock/src/lib/application-management/reports/get-application-versions-chart-data.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 { AXMAppVersionEntityModel } from '@acorex/modules/application-management';\nimport { RootConfig } from '@acorex/modules/application-management';\nimport { GetApplicationVersionsTimelineQueryInput } from './get-application-versions-timeline.query';\n\n//#region ----   Query Input/Output Types   ----\n\nexport interface GetApplicationVersionsChartDataQueryInput {\n  filters?: Array<{\n    field: string;\n    operator: { type: string };\n    value: any;\n  }>;\n  logic?: 'and' | 'or';\n}\n\nexport interface ApplicationVersionChartDataResult {\n  publishDate: string;\n  month: string;\n  year: number;\n  quarter: string;\n  versionCount: number;\n}\n\nexport interface GetApplicationVersionsChartDataQueryResult {\n  items: ApplicationVersionChartDataResult[];\n}\n\n//#endregion\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class GetApplicationVersionsChartDataQuery\n  implements AXPQuery<GetApplicationVersionsChartDataQueryInput, GetApplicationVersionsChartDataQueryResult>\n{\n  private readonly entityService = inject(AXPEntityService);\n  private appVersionService = this.entityService\n    .withEntity(`${RootConfig.module.name}.${RootConfig.entities.appVersion.name}`)\n    .data<string, AXMAppVersionEntityModel>();\n\n  async fetch(\n    input: GetApplicationVersionsChartDataQueryInput\n  ): Promise<GetApplicationVersionsChartDataQueryResult> {\n    // Get all app versions from storage (no pagination for charts)\n    const allVersionsResult = await this.appVersionService.query({\n      skip: 0,\n      take: 10000, // Get all versions for aggregation\n      filter:\n        input.filters && input.filters.length > 0\n          ? ({\n              logic: input.logic || 'and',\n              filters: input.filters,\n            } as any)\n          : undefined,\n    });\n\n    let allVersions = allVersionsResult.items;\n\n    // Apply custom filters after fetching\n    if (input.filters) {\n      for (const filter of input.filters) {\n        if (filter.field === 'dateRange' && filter.value) {\n          allVersions = this.applyDateRangeFilter(allVersions, filter.value);\n        }\n        if (filter.field === 'versionNumber' && filter.value) {\n          allVersions = this.applyVersionNumberFilter(allVersions, filter.value);\n        }\n      }\n    }\n\n    // Group versions by month for chart aggregation\n    const monthGroups = new Map<string, AXMAppVersionEntityModel[]>();\n\n    for (const version of allVersions) {\n      const publishDate = new Date(version.publishDate);\n      const year = publishDate.getFullYear();\n      const month = publishDate.getMonth() + 1;\n      const monthKey = `${year}-${String(month).padStart(2, '0')}`;\n\n      if (!monthGroups.has(monthKey)) {\n        monthGroups.set(monthKey, []);\n      }\n\n      monthGroups.get(monthKey)!.push(version);\n    }\n\n    // Aggregate data by month for chart\n    const chartResults: ApplicationVersionChartDataResult[] = [];\n\n    for (const [monthKey, versions] of monthGroups.entries()) {\n      const [year, month] = monthKey.split('-');\n      const publishDate = new Date(parseInt(year), parseInt(month) - 1, 1);\n      const monthName = publishDate.toLocaleString('en-US', { month: 'long' });\n      const quarter = Math.ceil(parseInt(month) / 3);\n      const quarterName = `Q${quarter}`;\n\n      chartResults.push({\n        publishDate: publishDate.toISOString(),\n        month: monthName,\n        year: parseInt(year),\n        quarter: quarterName,\n        versionCount: versions.length,\n      });\n    }\n\n    // Sort by date ascending for timeline\n    chartResults.sort((a, b) => {\n      const dateA = new Date(a.publishDate).getTime();\n      const dateB = new Date(b.publishDate).getTime();\n      return dateA - dateB;\n    });\n\n    return {\n      items: chartResults,\n    };\n  }\n\n  //#region ----   Custom Filter Handlers   ----\n\n  /**\n   * Apply date range filter to versions\n   */\n  private applyDateRangeFilter(versions: AXMAppVersionEntityModel[], dateRange: any): AXMAppVersionEntityModel[] {\n    if (!dateRange || !dateRange.start || !dateRange.end) {\n      return versions;\n    }\n\n    const startDate = new Date(dateRange.start);\n    const endDate = new Date(dateRange.end);\n    endDate.setHours(23, 59, 59, 999); // Include the entire end date\n\n    return versions.filter((version) => {\n      const publishDate = new Date(version.publishDate);\n      return publishDate >= startDate && publishDate <= endDate;\n    });\n  }\n\n  /**\n   * Apply version number filter to versions\n   */\n  private applyVersionNumberFilter(\n    versions: AXMAppVersionEntityModel[],\n    versionNumber: string\n  ): AXMAppVersionEntityModel[] {\n    if (!versionNumber) {\n      return versions;\n    }\n\n    const searchTerm = versionNumber.toLowerCase().trim();\n\n    return versions.filter((version) => {\n      return version.versionNumber.toLowerCase().includes(searchTerm);\n    });\n  }\n\n  //#endregion\n}\n\n"]}"],"names":[],"mappings":"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"}
@@ -0,0 +1,163 @@
1
+ import * as i0 from '@angular/core';
2
+ import { inject, Injectable } from '@angular/core';
3
+ import { AXPEntityService } from '@acorex/platform/layout/entity';
4
+ import { RootConfig } from '@acorex/modules/application-management';
5
+
6
+ //#endregion
7
+ class GetApplicationVersionsTimelineQuery {
8
+ constructor() {
9
+ this.entityService = inject(AXPEntityService);
10
+ this.appVersionService = this.entityService
11
+ .withEntity(`${RootConfig.module.name}.${RootConfig.entities.appVersion.name}`)
12
+ .data();
13
+ }
14
+ async fetch(input) {
15
+ // Get all app versions from storage
16
+ const allVersionsResult = await this.appVersionService.query({
17
+ skip: 0,
18
+ take: 10000, // Get all versions for aggregation
19
+ filter: input.filters && input.filters.length > 0
20
+ ? {
21
+ logic: input.logic || 'and',
22
+ filters: input.filters,
23
+ }
24
+ : undefined,
25
+ });
26
+ let allVersions = allVersionsResult.items;
27
+ // Apply date range filter if provided
28
+ if (input.filters) {
29
+ for (const filter of input.filters) {
30
+ if (filter.field === 'dateRange' && filter.value) {
31
+ allVersions = this.applyDateRangeFilter(allVersions, filter.value);
32
+ }
33
+ if (filter.field === 'versionNumber' && filter.value) {
34
+ allVersions = this.applyVersionNumberFilter(allVersions, filter.value);
35
+ }
36
+ }
37
+ }
38
+ // Group versions by time period (month/quarter/year)
39
+ const periodGroups = new Map();
40
+ for (const version of allVersions) {
41
+ const publishDate = new Date(version.publishDate);
42
+ const year = publishDate.getFullYear();
43
+ const month = publishDate.getMonth() + 1;
44
+ const quarter = Math.ceil(month / 3);
45
+ const monthName = publishDate.toLocaleString('en-US', { month: 'long' });
46
+ const quarterName = `Q${quarter}`;
47
+ const periodKey = `${year}-${String(month).padStart(2, '0')}`;
48
+ if (!periodGroups.has(periodKey)) {
49
+ periodGroups.set(periodKey, []);
50
+ }
51
+ periodGroups.get(periodKey).push(version);
52
+ }
53
+ // Create timeline results
54
+ const timelineResults = [];
55
+ for (const version of allVersions) {
56
+ const publishDate = new Date(version.publishDate);
57
+ const year = publishDate.getFullYear();
58
+ const month = publishDate.getMonth() + 1;
59
+ const quarter = Math.ceil(month / 3);
60
+ const monthName = publishDate.toLocaleString('en-US', { month: 'long' });
61
+ const quarterName = `Q${quarter}`;
62
+ const periodKey = `${year}-${String(month).padStart(2, '0')}`;
63
+ const versionsInPeriod = periodGroups.get(periodKey)?.length || 0;
64
+ timelineResults.push({
65
+ versionNumber: version.versionNumber,
66
+ publishDate: version.publishDate,
67
+ publishDateObj: publishDate,
68
+ year,
69
+ month: monthName,
70
+ monthNumber: month,
71
+ quarter: quarterName,
72
+ versionCount: versionsInPeriod,
73
+ });
74
+ }
75
+ // Apply sorting if provided
76
+ if (input.sort && input.sort.length > 0) {
77
+ timelineResults.sort((a, b) => {
78
+ for (const sortField of input.sort) {
79
+ const field = sortField.field;
80
+ const aValue = a[field];
81
+ const bValue = b[field];
82
+ const dir = sortField.dir === 'asc' ? 1 : -1;
83
+ // Handle undefined values
84
+ if (aValue === undefined && bValue === undefined)
85
+ continue;
86
+ if (aValue === undefined)
87
+ return 1 * dir;
88
+ if (bValue === undefined)
89
+ return -1 * dir;
90
+ // Handle date comparison
91
+ if (field === 'publishDateObj') {
92
+ const aDate = a.publishDateObj.getTime();
93
+ const bDate = b.publishDateObj.getTime();
94
+ if (aDate < bDate)
95
+ return -1 * dir;
96
+ if (aDate > bDate)
97
+ return 1 * dir;
98
+ continue;
99
+ }
100
+ if (aValue < bValue)
101
+ return -1 * dir;
102
+ if (aValue > bValue)
103
+ return 1 * dir;
104
+ }
105
+ return 0;
106
+ });
107
+ }
108
+ else {
109
+ // Default sort by publish date descending (newest first)
110
+ timelineResults.sort((a, b) => {
111
+ return b.publishDateObj.getTime() - a.publishDateObj.getTime();
112
+ });
113
+ }
114
+ // Apply pagination
115
+ const skip = input.skip || 0;
116
+ const take = input.take || 10;
117
+ const total = timelineResults.length;
118
+ const items = timelineResults.slice(skip, skip + take);
119
+ return {
120
+ items,
121
+ total,
122
+ };
123
+ }
124
+ //#region ---- Custom Filter Handlers ----
125
+ /**
126
+ * Apply date range filter to versions
127
+ */
128
+ applyDateRangeFilter(versions, dateRange) {
129
+ if (!dateRange || !dateRange.start || !dateRange.end) {
130
+ return versions;
131
+ }
132
+ const startDate = new Date(dateRange.start);
133
+ const endDate = new Date(dateRange.end);
134
+ endDate.setHours(23, 59, 59, 999); // Include the entire end date
135
+ return versions.filter((version) => {
136
+ const publishDate = new Date(version.publishDate);
137
+ return publishDate >= startDate && publishDate <= endDate;
138
+ });
139
+ }
140
+ /**
141
+ * Apply version number filter to versions
142
+ */
143
+ applyVersionNumberFilter(versions, versionNumber) {
144
+ if (!versionNumber) {
145
+ return versions;
146
+ }
147
+ const searchTerm = versionNumber.toLowerCase().trim();
148
+ return versions.filter((version) => {
149
+ return version.versionNumber.toLowerCase().includes(searchTerm);
150
+ });
151
+ }
152
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: GetApplicationVersionsTimelineQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
153
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: GetApplicationVersionsTimelineQuery, providedIn: 'root' }); }
154
+ }
155
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: GetApplicationVersionsTimelineQuery, decorators: [{
156
+ type: Injectable,
157
+ args: [{
158
+ providedIn: 'root',
159
+ }]
160
+ }] });
161
+
162
+ export { GetApplicationVersionsTimelineQuery };
163
+ //# sourceMappingURL=acorex-connectivity-mock-get-application-versions-timeline.query-zuGKLAbn.mjs.map