@acorex/connectivity 21.0.0-next.2 → 21.0.0-next.21

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 (56) hide show
  1. package/api/index.d.ts +6 -65
  2. package/fesm2022/{acorex-connectivity-api-execute.command-CQt_HF1B.mjs → acorex-connectivity-api-execute.command-Di850KiF.mjs} +7 -7
  3. package/fesm2022/acorex-connectivity-api-execute.command-Di850KiF.mjs.map +1 -0
  4. package/fesm2022/acorex-connectivity-api.mjs +128 -206
  5. package/fesm2022/acorex-connectivity-api.mjs.map +1 -1
  6. package/fesm2022/acorex-connectivity-mock-assign-to-manager.command-T6-ao4e9.mjs +66 -0
  7. package/fesm2022/acorex-connectivity-mock-assign-to-manager.command-T6-ao4e9.mjs.map +1 -0
  8. package/fesm2022/{acorex-connectivity-mock-category-with-items.query-Dsxj98tX.mjs → acorex-connectivity-mock-category-with-items.query-KB7GIYeb.mjs} +4 -4
  9. package/fesm2022/{acorex-connectivity-mock-category-with-items.query-Dsxj98tX.mjs.map → acorex-connectivity-mock-category-with-items.query-KB7GIYeb.mjs.map} +1 -1
  10. package/fesm2022/acorex-connectivity-mock-check-permission.command-C-AZTcHP.mjs +53 -0
  11. package/fesm2022/acorex-connectivity-mock-check-permission.command-C-AZTcHP.mjs.map +1 -0
  12. package/fesm2022/acorex-connectivity-mock-complete-signature-process.command-CHci1rOa.mjs +80 -0
  13. package/fesm2022/acorex-connectivity-mock-complete-signature-process.command-CHci1rOa.mjs.map +1 -0
  14. package/fesm2022/{acorex-connectivity-mock-distribution-record.command-DRiDwlqN.mjs → acorex-connectivity-mock-distribution-record.command-DMoZvago.mjs} +4 -4
  15. package/fesm2022/{acorex-connectivity-mock-distribution-record.command-DRiDwlqN.mjs.map → acorex-connectivity-mock-distribution-record.command-DMoZvago.mjs.map} +1 -1
  16. package/fesm2022/acorex-connectivity-mock-get-application-versions-chart-data.query-B1TrIBvU.mjs +115 -0
  17. package/fesm2022/acorex-connectivity-mock-get-application-versions-chart-data.query-B1TrIBvU.mjs.map +1 -0
  18. package/fesm2022/acorex-connectivity-mock-get-application-versions-timeline.query-CvNjA4OH.mjs +163 -0
  19. package/fesm2022/acorex-connectivity-mock-get-application-versions-timeline.query-CvNjA4OH.mjs.map +1 -0
  20. package/fesm2022/acorex-connectivity-mock-get-employee-list.query--f2M5RgC.mjs +213 -0
  21. package/fesm2022/acorex-connectivity-mock-get-employee-list.query--f2M5RgC.mjs.map +1 -0
  22. package/fesm2022/acorex-connectivity-mock-get-location-list.query-Cz55arFF.mjs +209 -0
  23. package/fesm2022/acorex-connectivity-mock-get-location-list.query-Cz55arFF.mjs.map +1 -0
  24. package/fesm2022/acorex-connectivity-mock-get-product-chart-data.query-C7v7D4ep.mjs +186 -0
  25. package/fesm2022/acorex-connectivity-mock-get-product-chart-data.query-C7v7D4ep.mjs.map +1 -0
  26. package/fesm2022/acorex-connectivity-mock-get-product-list.query-DTj8RYwR.mjs +246 -0
  27. package/fesm2022/acorex-connectivity-mock-get-product-list.query-DTj8RYwR.mjs.map +1 -0
  28. package/fesm2022/acorex-connectivity-mock-get-product-pdf-data.query-DdLhRbP5.mjs +192 -0
  29. package/fesm2022/acorex-connectivity-mock-get-product-pdf-data.query-DdLhRbP5.mjs.map +1 -0
  30. package/fesm2022/acorex-connectivity-mock-get-subscriptions-chart-data.query-ybmzmVl5.mjs +56 -0
  31. package/fesm2022/acorex-connectivity-mock-get-subscriptions-chart-data.query-ybmzmVl5.mjs.map +1 -0
  32. package/fesm2022/acorex-connectivity-mock-get-subscriptions-timeline.query-kciEUx7d.mjs +246 -0
  33. package/fesm2022/acorex-connectivity-mock-get-subscriptions-timeline.query-kciEUx7d.mjs.map +1 -0
  34. package/fesm2022/acorex-connectivity-mock-get-tenant-application-access.query-BDfrwf5Z.mjs +258 -0
  35. package/fesm2022/acorex-connectivity-mock-get-tenant-application-access.query-BDfrwf5Z.mjs.map +1 -0
  36. package/fesm2022/acorex-connectivity-mock-get-tenant-registration-chart-data.query-BD4T2loB.mjs +56 -0
  37. package/fesm2022/acorex-connectivity-mock-get-tenant-registration-chart-data.query-BD4T2loB.mjs.map +1 -0
  38. package/fesm2022/acorex-connectivity-mock-get-tenant-registration-timeline.query-CMJ8W3Ns.mjs +294 -0
  39. package/fesm2022/acorex-connectivity-mock-get-tenant-registration-timeline.query-CMJ8W3Ns.mjs.map +1 -0
  40. package/fesm2022/acorex-connectivity-mock-get-tenant-user-distribution.query-C-gCUjbX.mjs +212 -0
  41. package/fesm2022/acorex-connectivity-mock-get-tenant-user-distribution.query-C-gCUjbX.mjs.map +1 -0
  42. package/fesm2022/acorex-connectivity-mock-notify-signers.command-DLMsWjWQ.mjs +69 -0
  43. package/fesm2022/acorex-connectivity-mock-notify-signers.command-DLMsWjWQ.mjs.map +1 -0
  44. package/fesm2022/acorex-connectivity-mock-request-signature.command-JNkj9-Yz.mjs +72 -0
  45. package/fesm2022/acorex-connectivity-mock-request-signature.command-JNkj9-Yz.mjs.map +1 -0
  46. package/fesm2022/{acorex-connectivity-mock-sample.command-CkH5bmEs.mjs → acorex-connectivity-mock-sample.command-CyrjdvEA.mjs} +4 -4
  47. package/fesm2022/{acorex-connectivity-mock-sample.command-CkH5bmEs.mjs.map → acorex-connectivity-mock-sample.command-CyrjdvEA.mjs.map} +1 -1
  48. package/fesm2022/acorex-connectivity-mock-validate-all-signatures.command-xKr94NrA.mjs +81 -0
  49. package/fesm2022/acorex-connectivity-mock-validate-all-signatures.command-xKr94NrA.mjs.map +1 -0
  50. package/fesm2022/acorex-connectivity-mock.mjs +63874 -45210
  51. package/fesm2022/acorex-connectivity-mock.mjs.map +1 -1
  52. package/fesm2022/acorex-connectivity-utils.mjs +7 -7
  53. package/fesm2022/acorex-connectivity-utils.mjs.map +1 -1
  54. package/mock/index.d.ts +986 -1839
  55. package/package.json +6 -6
  56. package/fesm2022/acorex-connectivity-api-execute.command-CQt_HF1B.mjs.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"acorex-connectivity-mock-get-subscriptions-chart-data.query-ybmzmVl5.mjs","sources":["../tmp-esm2022/mock/lib/tenant-management/reports/get-subscriptions-chart-data.query.js"],"sourcesContent":["import { inject, Injectable } from '@angular/core';\nimport { GetSubscriptionsTimelineQuery } from './get-subscriptions-timeline.query';\nimport * as i0 from \"@angular/core\";\n//#endregion\nexport class GetSubscriptionsChartDataQuery {\n constructor() {\n this.subscriptionsTimelineQuery = inject(GetSubscriptionsTimelineQuery);\n }\n async fetch(input) {\n // Get all subscription timeline data (no pagination for charts)\n const timelineResult = await this.subscriptionsTimelineQuery.fetch({\n skip: 0,\n take: 10000,\n filters: input.filters,\n logic: input.logic,\n });\n // Group by month\n const monthGroups = new Map();\n for (const item of timelineResult.items) {\n const monthKey = `${item.year}-${String(item.monthNumber).padStart(2, '0')}`;\n if (!monthGroups.has(monthKey)) {\n monthGroups.set(monthKey, {\n month: item.month,\n year: item.year,\n quarter: item.quarter,\n subscriptionCount: 0,\n });\n }\n const group = monthGroups.get(monthKey);\n group.subscriptionCount++;\n }\n // Convert to array and sort by date\n const results = Array.from(monthGroups.values()).sort((a, b) => {\n if (a.year !== b.year)\n return a.year - b.year;\n const monthA = new Date(`${a.month} 1, ${a.year}`).getMonth();\n const monthB = new Date(`${b.month} 1, ${b.year}`).getMonth();\n return monthA - monthB;\n });\n return {\n items: results,\n };\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.16\", ngImport: i0, type: GetSubscriptionsChartDataQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.16\", ngImport: i0, type: GetSubscriptionsChartDataQuery, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.16\", ngImport: i0, type: GetSubscriptionsChartDataQuery, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root',\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LXN1YnNjcmlwdGlvbnMtY2hhcnQtZGF0YS5xdWVyeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29ubmVjdGl2aXR5L21vY2svc3JjL2xpYi90ZW5hbnQtbWFuYWdlbWVudC9yZXBvcnRzL2dldC1zdWJzY3JpcHRpb25zLWNoYXJ0LWRhdGEucXVlcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHbkQsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sb0NBQW9DLENBQUM7O0FBd0JuRixZQUFZO0FBS1osTUFBTSxPQUFPLDhCQUE4QjtJQUgzQztRQU1tQiwrQkFBMEIsR0FBRyxNQUFNLENBQUMsNkJBQTZCLENBQUMsQ0FBQztLQTBDckY7SUF4Q0MsS0FBSyxDQUFDLEtBQUssQ0FBQyxLQUFnRDtRQUMxRCxnRUFBZ0U7UUFDaEUsTUFBTSxjQUFjLEdBQUcsTUFBTSxJQUFJLENBQUMsMEJBQTBCLENBQUMsS0FBSyxDQUFDO1lBQ2pFLElBQUksRUFBRSxDQUFDO1lBQ1AsSUFBSSxFQUFFLEtBQUs7WUFDWCxPQUFPLEVBQUUsS0FBSyxDQUFDLE9BQU87WUFDdEIsS0FBSyxFQUFFLEtBQUssQ0FBQyxLQUFLO1NBQ25CLENBQUMsQ0FBQztRQUVILGlCQUFpQjtRQUNqQixNQUFNLFdBQVcsR0FBRyxJQUFJLEdBQUcsRUFBd0MsQ0FBQztRQUVwRSxLQUFLLE1BQU0sSUFBSSxJQUFJLGNBQWMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUN4QyxNQUFNLFFBQVEsR0FBRyxHQUFHLElBQUksQ0FBQyxJQUFJLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFFN0UsSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQztnQkFDL0IsV0FBVyxDQUFDLEdBQUcsQ0FBQyxRQUFRLEVBQUU7b0JBQ3hCLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSztvQkFDakIsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJO29CQUNmLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTztvQkFDckIsaUJBQWlCLEVBQUUsQ0FBQztpQkFDckIsQ0FBQyxDQUFDO1lBQ0wsQ0FBQztZQUVELE1BQU0sS0FBSyxHQUFHLFdBQVcsQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFFLENBQUM7WUFDekMsS0FBSyxDQUFDLGlCQUFpQixFQUFFLENBQUM7UUFDNUIsQ0FBQztRQUVELG9DQUFvQztRQUNwQyxNQUFNLE9BQU8sR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRTtZQUM3RCxJQUFJLENBQUMsQ0FBQyxJQUFJLEtBQUssQ0FBQyxDQUFDLElBQUk7Z0JBQUUsT0FBTyxDQUFDLENBQUMsSUFBSSxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUM7WUFDOUMsTUFBTSxNQUFNLEdBQUcsSUFBSSxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsS0FBSyxPQUFPLENBQUMsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQzlELE1BQU0sTUFBTSxHQUFHLElBQUksSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQUssT0FBTyxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUM5RCxPQUFPLE1BQU0sR0FBRyxNQUFNLENBQUM7UUFDekIsQ0FBQyxDQUFDLENBQUM7UUFFSCxPQUFPO1lBQ0wsS0FBSyxFQUFFLE9BQU87U0FDZixDQUFDO0lBQ0osQ0FBQzsrR0E1Q1UsOEJBQThCO21IQUE5Qiw4QkFBOEIsY0FGN0IsTUFBTTs7NEZBRVAsOEJBQThCO2tCQUgxQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQVhQUXVlcnkgfSBmcm9tICdAYWNvcmV4L3BsYXRmb3JtL3J1bnRpbWUnO1xuaW1wb3J0IHsgR2V0U3Vic2NyaXB0aW9uc1RpbWVsaW5lUXVlcnlJbnB1dCB9IGZyb20gJy4vZ2V0LXN1YnNjcmlwdGlvbnMtdGltZWxpbmUucXVlcnknO1xuaW1wb3J0IHsgR2V0U3Vic2NyaXB0aW9uc1RpbWVsaW5lUXVlcnkgfSBmcm9tICcuL2dldC1zdWJzY3JpcHRpb25zLXRpbWVsaW5lLnF1ZXJ5JztcblxuLy8jcmVnaW9uIC0tLS0gICBRdWVyeSBJbnB1dC9PdXRwdXQgVHlwZXMgICAtLS0tXG5cbmV4cG9ydCBpbnRlcmZhY2UgR2V0U3Vic2NyaXB0aW9uc0NoYXJ0RGF0YVF1ZXJ5SW5wdXQge1xuICBmaWx0ZXJzPzogQXJyYXk8e1xuICAgIGZpZWxkOiBzdHJpbmc7XG4gICAgb3BlcmF0b3I6IHsgdHlwZTogc3RyaW5nIH07XG4gICAgdmFsdWU6IGFueTtcbiAgfT47XG4gIGxvZ2ljPzogJ2FuZCcgfCAnb3InO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFN1YnNjcmlwdGlvbnNDaGFydERhdGFSZXN1bHQge1xuICBtb250aDogc3RyaW5nO1xuICB5ZWFyOiBudW1iZXI7XG4gIHF1YXJ0ZXI6IHN0cmluZztcbiAgc3Vic2NyaXB0aW9uQ291bnQ6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBHZXRTdWJzY3JpcHRpb25zQ2hhcnREYXRhUXVlcnlSZXN1bHQge1xuICBpdGVtczogU3Vic2NyaXB0aW9uc0NoYXJ0RGF0YVJlc3VsdFtdO1xufVxuXG4vLyNlbmRyZWdpb25cblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIEdldFN1YnNjcmlwdGlvbnNDaGFydERhdGFRdWVyeVxuICBpbXBsZW1lbnRzIEFYUFF1ZXJ5PEdldFN1YnNjcmlwdGlvbnNDaGFydERhdGFRdWVyeUlucHV0LCBHZXRTdWJzY3JpcHRpb25zQ2hhcnREYXRhUXVlcnlSZXN1bHQ+XG57XG4gIHByaXZhdGUgcmVhZG9ubHkgc3Vic2NyaXB0aW9uc1RpbWVsaW5lUXVlcnkgPSBpbmplY3QoR2V0U3Vic2NyaXB0aW9uc1RpbWVsaW5lUXVlcnkpO1xuXG4gIGFzeW5jIGZldGNoKGlucHV0OiBHZXRTdWJzY3JpcHRpb25zQ2hhcnREYXRhUXVlcnlJbnB1dCB8IGFueSk6IFByb21pc2U8R2V0U3Vic2NyaXB0aW9uc0NoYXJ0RGF0YVF1ZXJ5UmVzdWx0PiB7XG4gICAgLy8gR2V0IGFsbCBzdWJzY3JpcHRpb24gdGltZWxpbmUgZGF0YSAobm8gcGFnaW5hdGlvbiBmb3IgY2hhcnRzKVxuICAgIGNvbnN0IHRpbWVsaW5lUmVzdWx0ID0gYXdhaXQgdGhpcy5zdWJzY3JpcHRpb25zVGltZWxpbmVRdWVyeS5mZXRjaCh7XG4gICAgICBza2lwOiAwLFxuICAgICAgdGFrZTogMTAwMDAsXG4gICAgICBmaWx0ZXJzOiBpbnB1dC5maWx0ZXJzLFxuICAgICAgbG9naWM6IGlucHV0LmxvZ2ljLFxuICAgIH0pO1xuXG4gICAgLy8gR3JvdXAgYnkgbW9udGhcbiAgICBjb25zdCBtb250aEdyb3VwcyA9IG5ldyBNYXA8c3RyaW5nLCBTdWJzY3JpcHRpb25zQ2hhcnREYXRhUmVzdWx0PigpO1xuXG4gICAgZm9yIChjb25zdCBpdGVtIG9mIHRpbWVsaW5lUmVzdWx0Lml0ZW1zKSB7XG4gICAgICBjb25zdCBtb250aEtleSA9IGAke2l0ZW0ueWVhcn0tJHtTdHJpbmcoaXRlbS5tb250aE51bWJlcikucGFkU3RhcnQoMiwgJzAnKX1gO1xuXG4gICAgICBpZiAoIW1vbnRoR3JvdXBzLmhhcyhtb250aEtleSkpIHtcbiAgICAgICAgbW9udGhHcm91cHMuc2V0KG1vbnRoS2V5LCB7XG4gICAgICAgICAgbW9udGg6IGl0ZW0ubW9udGgsXG4gICAgICAgICAgeWVhcjogaXRlbS55ZWFyLFxuICAgICAgICAgIHF1YXJ0ZXI6IGl0ZW0ucXVhcnRlcixcbiAgICAgICAgICBzdWJzY3JpcHRpb25Db3VudDogMCxcbiAgICAgICAgfSk7XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IGdyb3VwID0gbW9udGhHcm91cHMuZ2V0KG1vbnRoS2V5KSE7XG4gICAgICBncm91cC5zdWJzY3JpcHRpb25Db3VudCsrO1xuICAgIH1cblxuICAgIC8vIENvbnZlcnQgdG8gYXJyYXkgYW5kIHNvcnQgYnkgZGF0ZVxuICAgIGNvbnN0IHJlc3VsdHMgPSBBcnJheS5mcm9tKG1vbnRoR3JvdXBzLnZhbHVlcygpKS5zb3J0KChhLCBiKSA9PiB7XG4gICAgICBpZiAoYS55ZWFyICE9PSBiLnllYXIpIHJldHVybiBhLnllYXIgLSBiLnllYXI7XG4gICAgICBjb25zdCBtb250aEEgPSBuZXcgRGF0ZShgJHthLm1vbnRofSAxLCAke2EueWVhcn1gKS5nZXRNb250aCgpO1xuICAgICAgY29uc3QgbW9udGhCID0gbmV3IERhdGUoYCR7Yi5tb250aH0gMSwgJHtiLnllYXJ9YCkuZ2V0TW9udGgoKTtcbiAgICAgIHJldHVybiBtb250aEEgLSBtb250aEI7XG4gICAgfSk7XG5cbiAgICByZXR1cm4ge1xuICAgICAgaXRlbXM6IHJlc3VsdHMsXG4gICAgfTtcbiAgfVxufVxuXG4iXX0="],"names":[],"mappings":"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"}
@@ -0,0 +1,246 @@
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/subscription-management';
6
+ import { RootConfig as RootConfig$1 } from '@acorex/modules/tenant-management';
7
+
8
+ //#endregion
9
+ class GetSubscriptionsTimelineQuery {
10
+ constructor() {
11
+ this.entityService = inject(AXPEntityService);
12
+ this.subscriptionService = this.entityService
13
+ .withEntity(`${RootConfig.module.name}.${RootConfig.entities.subscription.name}`)
14
+ .data();
15
+ this.tenantService = this.entityService
16
+ .withEntity(`${RootConfig$1.module.name}.${RootConfig$1.entities.tenant.name}`)
17
+ .data();
18
+ }
19
+ async fetch(input) {
20
+ // Extract filters from AXPFilterClause format
21
+ const extractedFilters = this.extractSubscriptionFilters(input.filters);
22
+ const filterLogic = input.filters?.logic || input.logic || 'and';
23
+ // Separate custom filters from entity filters
24
+ const entityFilters = [];
25
+ let dateRangeFilter;
26
+ if (extractedFilters && extractedFilters.length > 0) {
27
+ for (const filter of extractedFilters) {
28
+ if (filter.field === 'dateRange') {
29
+ dateRangeFilter = filter.value;
30
+ }
31
+ else {
32
+ entityFilters.push(filter);
33
+ }
34
+ }
35
+ }
36
+ // Get all subscriptions
37
+ const subscriptionsResult = await this.subscriptionService.query({
38
+ skip: 0,
39
+ take: 10000,
40
+ filter: entityFilters.length > 0
41
+ ? {
42
+ logic: filterLogic,
43
+ filters: entityFilters,
44
+ }
45
+ : undefined,
46
+ });
47
+ let subscriptions = subscriptionsResult.items.filter((s) => s.subscriberType === 'Tenant');
48
+ // Get all tenants for lookup
49
+ const tenantsResult = await this.tenantService.query({
50
+ skip: 0,
51
+ take: 10000,
52
+ });
53
+ const tenants = tenantsResult.items;
54
+ const tenantMap = new Map(tenants.map((t) => [t.id, t]));
55
+ // Apply date range filter if provided
56
+ if (dateRangeFilter) {
57
+ subscriptions = this.applyDateRangeFilter(subscriptions, dateRangeFilter);
58
+ }
59
+ const now = new Date();
60
+ // Build results
61
+ const results = [];
62
+ for (const subscription of subscriptions) {
63
+ const startDate = new Date(subscription.startDate);
64
+ const endDate = subscription.endDate ? new Date(subscription.endDate) : undefined;
65
+ // Calculate duration in days
66
+ const durationDays = endDate
67
+ ? Math.ceil((endDate.getTime() - startDate.getTime()) / (1000 * 60 * 60 * 24))
68
+ : Math.ceil((now.getTime() - startDate.getTime()) / (1000 * 60 * 60 * 24));
69
+ // Extract time period info from start date
70
+ const year = startDate.getFullYear();
71
+ const month = startDate.getMonth() + 1;
72
+ const monthName = startDate.toLocaleString('en-US', { month: 'long' });
73
+ const quarter = Math.ceil(month / 3);
74
+ const quarterName = `Q${quarter}`;
75
+ // Check if subscription is currently active
76
+ const isActive = subscription.statusId === AXPSystemStatusType.Active &&
77
+ startDate <= now &&
78
+ (!endDate || endDate >= now);
79
+ // Get tenant name
80
+ const tenant = tenantMap.get(subscription.subscriberId);
81
+ results.push({
82
+ subscriptionId: subscription.id,
83
+ subscriptionTitle: subscription.title || `${tenant?.title || 'Unknown'} - ${subscription.plan?.title || 'Unknown Plan'}`,
84
+ tenantId: subscription.subscriberId,
85
+ tenantName: tenant?.title || 'Unknown',
86
+ planId: subscription.planId,
87
+ planName: subscription.plan?.title || 'Unknown',
88
+ status: subscription.statusId || 'Unknown',
89
+ startDate: startDate,
90
+ startDateStr: startDate.toISOString(),
91
+ endDate: endDate,
92
+ endDateStr: endDate?.toISOString(),
93
+ durationDays: durationDays,
94
+ month: monthName,
95
+ monthNumber: month,
96
+ quarter: quarterName,
97
+ year: year,
98
+ isActive: isActive,
99
+ });
100
+ }
101
+ // Apply sorting if provided
102
+ if (input.sort && input.sort.length > 0) {
103
+ results.sort((a, b) => {
104
+ for (const sortField of input.sort) {
105
+ const field = sortField.field;
106
+ const aValue = a[field];
107
+ const bValue = b[field];
108
+ const dir = sortField.dir === 'asc' ? 1 : -1;
109
+ if (aValue === undefined && bValue === undefined)
110
+ continue;
111
+ if (aValue === undefined)
112
+ return 1 * dir;
113
+ if (bValue === undefined)
114
+ return -1 * dir;
115
+ // Handle date comparison
116
+ if (field === 'startDate') {
117
+ const aDate = a.startDate.getTime();
118
+ const bDate = b.startDate.getTime();
119
+ if (aDate < bDate)
120
+ return -1 * dir;
121
+ if (aDate > bDate)
122
+ return 1 * dir;
123
+ continue;
124
+ }
125
+ if (aValue < bValue)
126
+ return -1 * dir;
127
+ if (aValue > bValue)
128
+ return 1 * dir;
129
+ }
130
+ return 0;
131
+ });
132
+ }
133
+ else {
134
+ // Default sort by start date descending (newest first)
135
+ results.sort((a, b) => {
136
+ return b.startDate.getTime() - a.startDate.getTime();
137
+ });
138
+ }
139
+ // Apply pagination
140
+ const skip = input.skip || 0;
141
+ const take = input.take || 10;
142
+ const total = results.length;
143
+ const items = results.slice(skip, skip + take);
144
+ return {
145
+ items,
146
+ total,
147
+ };
148
+ }
149
+ //#region ---- Filter Extraction ----
150
+ /**
151
+ * Extract subscription-specific filters from AXPFilterClause format
152
+ * Maps report parameter paths to subscription entity field names
153
+ */
154
+ extractSubscriptionFilters(parameters) {
155
+ const filters = [];
156
+ const paramsAny = parameters;
157
+ if (!paramsAny?.filters || !Array.isArray(paramsAny.filters)) {
158
+ return filters;
159
+ }
160
+ for (const filter of paramsAny.filters) {
161
+ if (!filter?.field || filter?.value === undefined || filter?.value === null) {
162
+ continue;
163
+ }
164
+ const field = filter.field;
165
+ const value = filter.value;
166
+ const operator = filter.operator || { type: 'equal' };
167
+ // Handle subscription-specific field mappings
168
+ if (field === 'planId') {
169
+ // Plan ID filter - can be array of IDs or single ID
170
+ if (Array.isArray(value) && value.length > 0) {
171
+ filters.push({
172
+ field: 'planId',
173
+ operator: { type: 'in' },
174
+ value: value,
175
+ });
176
+ }
177
+ else if (value) {
178
+ filters.push({
179
+ field: 'planId',
180
+ operator: { type: 'equal' },
181
+ value: value,
182
+ });
183
+ }
184
+ }
185
+ else if (field === 'statusId') {
186
+ // Status filter - skip 'all' value
187
+ if (value && value !== 'all') {
188
+ filters.push({
189
+ field: 'statusId',
190
+ operator: { type: 'equal' },
191
+ value: value,
192
+ });
193
+ }
194
+ }
195
+ else if (field === 'dateRange') {
196
+ // Date range filter - custom logic handled in query
197
+ filters.push({
198
+ field: 'dateRange',
199
+ operator: { type: 'equal' },
200
+ value: value,
201
+ });
202
+ }
203
+ else {
204
+ // Direct field mapping
205
+ filters.push({
206
+ field: field,
207
+ operator: operator,
208
+ value: value,
209
+ });
210
+ }
211
+ }
212
+ return filters;
213
+ }
214
+ //#endregion
215
+ //#region ---- Custom Filter Handlers ----
216
+ /**
217
+ * Apply date range filter to subscriptions
218
+ */
219
+ applyDateRangeFilter(subscriptions, dateRange) {
220
+ if (!dateRange || !dateRange.start || !dateRange.end) {
221
+ return subscriptions;
222
+ }
223
+ const startDate = new Date(dateRange.start);
224
+ const endDate = new Date(dateRange.end);
225
+ endDate.setHours(23, 59, 59, 999);
226
+ return subscriptions.filter((subscription) => {
227
+ const subStartDate = new Date(subscription.startDate);
228
+ const subEndDate = subscription.endDate ? new Date(subscription.endDate) : null;
229
+ // Check if subscription overlaps with the date range
230
+ return ((subStartDate >= startDate && subStartDate <= endDate) ||
231
+ (subEndDate && subEndDate >= startDate && subEndDate <= endDate) ||
232
+ (subStartDate <= startDate && (!subEndDate || subEndDate >= endDate)));
233
+ });
234
+ }
235
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: GetSubscriptionsTimelineQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
236
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: GetSubscriptionsTimelineQuery, providedIn: 'root' }); }
237
+ }
238
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: GetSubscriptionsTimelineQuery, decorators: [{
239
+ type: Injectable,
240
+ args: [{
241
+ providedIn: 'root',
242
+ }]
243
+ }] });
244
+
245
+ export { GetSubscriptionsTimelineQuery };
246
+ //# sourceMappingURL=acorex-connectivity-mock-get-subscriptions-timeline.query-kciEUx7d.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"acorex-connectivity-mock-get-subscriptions-timeline.query-kciEUx7d.mjs","sources":["../tmp-esm2022/mock/lib/tenant-management/reports/get-subscriptions-timeline.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 SubscriptionRootConfig } from '@acorex/modules/subscription-management';\nimport { RootConfig as TenantRootConfig } from '@acorex/modules/tenant-management';\nimport * as i0 from \"@angular/core\";\n//#endregion\nexport class GetSubscriptionsTimelineQuery {\n constructor() {\n this.entityService = inject(AXPEntityService);\n this.subscriptionService = this.entityService\n .withEntity(`${SubscriptionRootConfig.module.name}.${SubscriptionRootConfig.entities.subscription.name}`)\n .data();\n this.tenantService = this.entityService\n .withEntity(`${TenantRootConfig.module.name}.${TenantRootConfig.entities.tenant.name}`)\n .data();\n }\n async fetch(input) {\n // Extract filters from AXPFilterClause format\n const extractedFilters = this.extractSubscriptionFilters(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 subscriptions\n const subscriptionsResult = await this.subscriptionService.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 subscriptions = subscriptionsResult.items.filter((s) => s.subscriberType === 'Tenant');\n // Get all tenants for lookup\n const tenantsResult = await this.tenantService.query({\n skip: 0,\n take: 10000,\n });\n const tenants = tenantsResult.items;\n const tenantMap = new Map(tenants.map((t) => [t.id, t]));\n // Apply date range filter if provided\n if (dateRangeFilter) {\n subscriptions = this.applyDateRangeFilter(subscriptions, dateRangeFilter);\n }\n const now = new Date();\n // Build results\n const results = [];\n for (const subscription of subscriptions) {\n const startDate = new Date(subscription.startDate);\n const endDate = subscription.endDate ? new Date(subscription.endDate) : undefined;\n // Calculate duration in days\n const durationDays = endDate\n ? Math.ceil((endDate.getTime() - startDate.getTime()) / (1000 * 60 * 60 * 24))\n : Math.ceil((now.getTime() - startDate.getTime()) / (1000 * 60 * 60 * 24));\n // Extract time period info from start date\n const year = startDate.getFullYear();\n const month = startDate.getMonth() + 1;\n const monthName = startDate.toLocaleString('en-US', { month: 'long' });\n const quarter = Math.ceil(month / 3);\n const quarterName = `Q${quarter}`;\n // Check if subscription is currently active\n const isActive = subscription.statusId === AXPSystemStatusType.Active &&\n startDate <= now &&\n (!endDate || endDate >= now);\n // Get tenant name\n const tenant = tenantMap.get(subscription.subscriberId);\n results.push({\n subscriptionId: subscription.id,\n subscriptionTitle: subscription.title || `${tenant?.title || 'Unknown'} - ${subscription.plan?.title || 'Unknown Plan'}`,\n tenantId: subscription.subscriberId,\n tenantName: tenant?.title || 'Unknown',\n planId: subscription.planId,\n planName: subscription.plan?.title || 'Unknown',\n status: subscription.statusId || 'Unknown',\n startDate: startDate,\n startDateStr: startDate.toISOString(),\n endDate: endDate,\n endDateStr: endDate?.toISOString(),\n durationDays: durationDays,\n month: monthName,\n monthNumber: month,\n quarter: quarterName,\n year: year,\n isActive: isActive,\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 // Handle date comparison\n if (field === 'startDate') {\n const aDate = a.startDate.getTime();\n const bDate = b.startDate.getTime();\n if (aDate < bDate)\n return -1 * dir;\n if (aDate > bDate)\n return 1 * dir;\n continue;\n }\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 start date descending (newest first)\n results.sort((a, b) => {\n return b.startDate.getTime() - a.startDate.getTime();\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 return {\n items,\n total,\n };\n }\n //#region ---- Filter Extraction ----\n /**\n * Extract subscription-specific filters from AXPFilterClause format\n * Maps report parameter paths to subscription entity field names\n */\n extractSubscriptionFilters(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 subscription-specific field mappings\n if (field === 'planId') {\n // Plan ID filter - can be array of IDs or single ID\n if (Array.isArray(value) && value.length > 0) {\n filters.push({\n field: 'planId',\n operator: { type: 'in' },\n value: value,\n });\n }\n else if (value) {\n filters.push({\n field: 'planId',\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 subscriptions\n */\n applyDateRangeFilter(subscriptions, dateRange) {\n if (!dateRange || !dateRange.start || !dateRange.end) {\n return subscriptions;\n }\n const startDate = new Date(dateRange.start);\n const endDate = new Date(dateRange.end);\n endDate.setHours(23, 59, 59, 999);\n return subscriptions.filter((subscription) => {\n const subStartDate = new Date(subscription.startDate);\n const subEndDate = subscription.endDate ? new Date(subscription.endDate) : null;\n // Check if subscription overlaps with the date range\n return ((subStartDate >= startDate && subStartDate <= endDate) ||\n (subEndDate && subEndDate >= startDate && subEndDate <= endDate) ||\n (subStartDate <= startDate && (!subEndDate || subEndDate >= endDate)));\n });\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.16\", ngImport: i0, type: GetSubscriptionsTimelineQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.16\", ngImport: i0, type: GetSubscriptionsTimelineQuery, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.16\", ngImport: i0, type: GetSubscriptionsTimelineQuery, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root',\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"get-subscriptions-timeline.query.js","sourceRoot":"","sources":["../../../../../../../../libs/connectivity/mock/src/lib/tenant-management/reports/get-subscriptions-timeline.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 { AXMSubscriptionManagementSubscriptionEntityModel } from '@acorex/modules/subscription-management';\nimport { AXMTenantManagementTenantEntityModel } from '@acorex/modules/tenant-management';\nimport { AXPSystemStatusType } from '@acorex/platform/common';\nimport { RootConfig as SubscriptionRootConfig } from '@acorex/modules/subscription-management';\nimport { RootConfig as TenantRootConfig } from '@acorex/modules/tenant-management';\n\n//#region ----   Query Input/Output Types   ----\n\nexport interface GetSubscriptionsTimelineQueryInput {\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 SubscriptionsTimelineResult {\n  subscriptionId: string;\n  subscriptionTitle: string;\n  tenantId: string;\n  tenantName: string;\n  planId?: string;\n  planName: string;\n  status: string;\n  startDate: Date;\n  startDateStr: string;\n  endDate?: Date;\n  endDateStr?: string;\n  durationDays: number;\n  month: string;\n  monthNumber: number;\n  quarter: string;\n  year: number;\n  isActive: boolean;\n}\n\nexport interface GetSubscriptionsTimelineQueryResult {\n  items: SubscriptionsTimelineResult[];\n  total: number;\n}\n\n//#endregion\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class GetSubscriptionsTimelineQuery\n  implements AXPQuery<GetSubscriptionsTimelineQueryInput, GetSubscriptionsTimelineQueryResult>\n{\n  private readonly entityService = inject(AXPEntityService);\n  private subscriptionService = this.entityService\n    .withEntity(`${SubscriptionRootConfig.module.name}.${SubscriptionRootConfig.entities.subscription.name}`)\n    .data<string, AXMSubscriptionManagementSubscriptionEntityModel>();\n  private tenantService = this.entityService\n    .withEntity(`${TenantRootConfig.module.name}.${TenantRootConfig.entities.tenant.name}`)\n    .data<string, AXMTenantManagementTenantEntityModel>();\n\n  async fetch(input: GetSubscriptionsTimelineQueryInput | any): Promise<GetSubscriptionsTimelineQueryResult> {\n    // Extract filters from AXPFilterClause format\n    const extractedFilters = this.extractSubscriptionFilters(input.filters);\n    const filterLogic = (input.filters as any)?.logic || input.logic || 'and';\n\n    // Separate custom filters from entity filters\n    const entityFilters: GetSubscriptionsTimelineQueryInput['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 subscriptions\n    const subscriptionsResult = await this.subscriptionService.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 subscriptions = subscriptionsResult.items.filter((s) => s.subscriberType === 'Tenant');\n\n    // Get all tenants for lookup\n    const tenantsResult = await this.tenantService.query({\n      skip: 0,\n      take: 10000,\n    });\n    const tenants = tenantsResult.items;\n    const tenantMap = new Map(tenants.map((t) => [t.id, t]));\n\n    // Apply date range filter if provided\n    if (dateRangeFilter) {\n      subscriptions = this.applyDateRangeFilter(subscriptions, dateRangeFilter);\n    }\n\n    const now = new Date();\n\n    // Build results\n    const results: SubscriptionsTimelineResult[] = [];\n\n    for (const subscription of subscriptions) {\n      const startDate = new Date(subscription.startDate);\n      const endDate = subscription.endDate ? new Date(subscription.endDate) : undefined;\n\n      // Calculate duration in days\n      const durationDays = endDate\n        ? Math.ceil((endDate.getTime() - startDate.getTime()) / (1000 * 60 * 60 * 24))\n        : Math.ceil((now.getTime() - startDate.getTime()) / (1000 * 60 * 60 * 24));\n\n      // Extract time period info from start date\n      const year = startDate.getFullYear();\n      const month = startDate.getMonth() + 1;\n      const monthName = startDate.toLocaleString('en-US', { month: 'long' });\n      const quarter = Math.ceil(month / 3);\n      const quarterName = `Q${quarter}`;\n\n      // Check if subscription is currently active\n      const isActive =\n        subscription.statusId === AXPSystemStatusType.Active &&\n        startDate <= now &&\n        (!endDate || endDate >= now);\n\n      // Get tenant name\n      const tenant = tenantMap.get(subscription.subscriberId);\n\n      results.push({\n        subscriptionId: subscription.id,\n        subscriptionTitle: subscription.title || `${tenant?.title || 'Unknown'} - ${subscription.plan?.title || 'Unknown Plan'}`,\n        tenantId: subscription.subscriberId,\n        tenantName: tenant?.title || 'Unknown',\n        planId: subscription.planId,\n        planName: subscription.plan?.title || 'Unknown',\n        status: subscription.statusId || 'Unknown',\n        startDate: startDate,\n        startDateStr: startDate.toISOString(),\n        endDate: endDate,\n        endDateStr: endDate?.toISOString(),\n        durationDays: durationDays,\n        month: monthName,\n        monthNumber: month,\n        quarter: quarterName,\n        year: year,\n        isActive: isActive,\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 SubscriptionsTimelineResult;\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          // Handle date comparison\n          if (field === 'startDate') {\n            const aDate = a.startDate.getTime();\n            const bDate = b.startDate.getTime();\n            if (aDate < bDate) return -1 * dir;\n            if (aDate > bDate) return 1 * dir;\n            continue;\n          }\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 start date descending (newest first)\n      results.sort((a, b) => {\n        return b.startDate.getTime() - a.startDate.getTime();\n      });\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 subscription-specific filters from AXPFilterClause format\n   * Maps report parameter paths to subscription entity field names\n   */\n  private extractSubscriptionFilters(parameters: any): GetSubscriptionsTimelineQueryInput['filters'] {\n    const filters: GetSubscriptionsTimelineQueryInput['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 subscription-specific field mappings\n      if (field === 'planId') {\n        // Plan ID filter - can be array of IDs or single ID\n        if (Array.isArray(value) && value.length > 0) {\n          filters.push({\n            field: 'planId',\n            operator: { type: 'in' },\n            value: value,\n          });\n        } else if (value) {\n          filters.push({\n            field: 'planId',\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 subscriptions\n   */\n  private applyDateRangeFilter(\n    subscriptions: AXMSubscriptionManagementSubscriptionEntityModel[],\n    dateRange: any\n  ): AXMSubscriptionManagementSubscriptionEntityModel[] {\n    if (!dateRange || !dateRange.start || !dateRange.end) {\n      return subscriptions;\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 subscriptions.filter((subscription) => {\n      const subStartDate = new Date(subscription.startDate);\n      const subEndDate = subscription.endDate ? new Date(subscription.endDate) : null;\n\n      // Check if subscription overlaps with the date range\n      return (\n        (subStartDate >= startDate && subStartDate <= endDate) ||\n        (subEndDate && subEndDate >= startDate && subEndDate <= endDate) ||\n        (subStartDate <= startDate && (!subEndDate || subEndDate >= endDate))\n      );\n    });\n  }\n\n  //#endregion\n}\n\n"]}"],"names":["SubscriptionRootConfig","TenantRootConfig"],"mappings":"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"}
@@ -0,0 +1,258 @@
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
+ import { RootConfig as RootConfig$1 } from '@acorex/modules/subscription-management';
7
+ import { RootConfig as RootConfig$2 } from '@acorex/modules/application-management';
8
+
9
+ //#endregion
10
+ class GetTenantApplicationAccessQuery {
11
+ constructor() {
12
+ this.entityService = inject(AXPEntityService);
13
+ this.tenantService = this.entityService
14
+ .withEntity(`${RootConfig.module.name}.${RootConfig.entities.tenant.name}`)
15
+ .data();
16
+ this.subscriptionService = this.entityService
17
+ .withEntity(`${RootConfig$1.module.name}.${RootConfig$1.entities.subscription.name}`)
18
+ .data();
19
+ this.planService = this.entityService
20
+ .withEntity(`${RootConfig$1.module.name}.${RootConfig$1.entities.subscriptionPlan.name}`)
21
+ .data();
22
+ this.planItemService = this.entityService
23
+ .withEntity(`${RootConfig$1.module.name}.${RootConfig$1.entities.subscriptionPlanItem.name}`)
24
+ .data();
25
+ this.applicationService = this.entityService
26
+ .withEntity(`${RootConfig$2.module.name}.${RootConfig$2.entities.application.name}`)
27
+ .data();
28
+ }
29
+ async fetch(input) {
30
+ // Extract filters from AXPFilterClause format
31
+ const extractedFilters = this.extractTenantFilters(input.filters);
32
+ const filterLogic = input.filters?.logic || input.logic || 'and';
33
+ // Separate custom filters from entity filters
34
+ const entityFilters = [];
35
+ let dateRangeFilter;
36
+ if (extractedFilters && extractedFilters.length > 0) {
37
+ for (const filter of extractedFilters) {
38
+ if (filter.field === 'dateRange') {
39
+ dateRangeFilter = filter.value;
40
+ }
41
+ else {
42
+ entityFilters.push(filter);
43
+ }
44
+ }
45
+ }
46
+ // Get all tenants
47
+ const tenantsResult = await this.tenantService.query({
48
+ skip: 0,
49
+ take: 10000,
50
+ filter: entityFilters.length > 0
51
+ ? {
52
+ logic: filterLogic,
53
+ filters: entityFilters,
54
+ }
55
+ : undefined,
56
+ });
57
+ let tenants = tenantsResult.items;
58
+ // Apply date range filter if provided
59
+ if (dateRangeFilter) {
60
+ tenants = this.applyDateRangeFilter(tenants, dateRangeFilter);
61
+ }
62
+ // Get all subscriptions
63
+ const subscriptionsResult = await this.subscriptionService.query({
64
+ skip: 0,
65
+ take: 10000,
66
+ });
67
+ const subscriptions = subscriptionsResult.items.filter((s) => s.subscriberType === 'Tenant');
68
+ // Get all plans
69
+ const plansResult = await this.planService.query({
70
+ skip: 0,
71
+ take: 10000,
72
+ });
73
+ const plans = plansResult.items;
74
+ // Get all plan items
75
+ const planItemsResult = await this.planItemService.query({
76
+ skip: 0,
77
+ take: 10000,
78
+ });
79
+ const planItems = planItemsResult.items;
80
+ // Get all applications
81
+ const applicationsResult = await this.applicationService.query({
82
+ skip: 0,
83
+ take: 10000,
84
+ });
85
+ const applications = applicationsResult.items;
86
+ // Build results for each tenant
87
+ const results = [];
88
+ for (const tenant of tenants) {
89
+ // Get tenant's subscriptions
90
+ const tenantSubscriptions = subscriptions.filter((s) => s.subscriberId === tenant.id);
91
+ // Get unique applications through subscriptions → plans → plan items → editions → applications
92
+ const applicationSet = new Set();
93
+ const applicationNames = [];
94
+ for (const subscription of tenantSubscriptions) {
95
+ if (!subscription.planId)
96
+ continue;
97
+ // Get plan items for this plan
98
+ const planPlanItems = planItems.filter((pi) => pi.planId === subscription.planId);
99
+ for (const planItem of planPlanItems) {
100
+ if (!planItem.editionId)
101
+ continue;
102
+ // Find applications that have this edition
103
+ for (const application of applications) {
104
+ if (application.editionIds && application.editionIds.includes(planItem.editionId)) {
105
+ if (!applicationSet.has(application.id)) {
106
+ applicationSet.add(application.id);
107
+ applicationNames.push(application.title);
108
+ }
109
+ }
110
+ }
111
+ }
112
+ }
113
+ // Count active subscriptions
114
+ const activeSubscriptions = tenantSubscriptions.filter((s) => s.statusId === AXPSystemStatusType.Active);
115
+ results.push({
116
+ tenantId: tenant.id,
117
+ tenantName: tenant.title,
118
+ tenantStatus: tenant.statusId || 'Unknown',
119
+ subscriptionCount: tenantSubscriptions.length,
120
+ applicationsCount: applicationSet.size,
121
+ applicationsList: applicationNames.join(', '),
122
+ activeSubscriptionsCount: activeSubscriptions.length,
123
+ registrationDate: tenant.registrationDate,
124
+ registrationDateStr: tenant.registrationDate?.toISOString(),
125
+ });
126
+ }
127
+ // Apply sorting if provided
128
+ if (input.sort && input.sort.length > 0) {
129
+ results.sort((a, b) => {
130
+ for (const sortField of input.sort) {
131
+ const field = sortField.field;
132
+ const aValue = a[field];
133
+ const bValue = b[field];
134
+ const dir = sortField.dir === 'asc' ? 1 : -1;
135
+ if (aValue === undefined && bValue === undefined)
136
+ continue;
137
+ if (aValue === undefined)
138
+ return 1 * dir;
139
+ if (bValue === undefined)
140
+ return -1 * dir;
141
+ if (aValue < bValue)
142
+ return -1 * dir;
143
+ if (aValue > bValue)
144
+ return 1 * dir;
145
+ }
146
+ return 0;
147
+ });
148
+ }
149
+ else {
150
+ // Default sort by tenant name
151
+ results.sort((a, b) => a.tenantName.localeCompare(b.tenantName));
152
+ }
153
+ // Apply pagination
154
+ const skip = input.skip || 0;
155
+ const take = input.take || 10;
156
+ const total = results.length;
157
+ const items = results.slice(skip, skip + take);
158
+ return {
159
+ items,
160
+ total,
161
+ };
162
+ }
163
+ //#region ---- Filter Extraction ----
164
+ /**
165
+ * Extract tenant-specific filters from AXPFilterClause format
166
+ * Maps report parameter paths to tenant entity field names
167
+ */
168
+ extractTenantFilters(parameters) {
169
+ const filters = [];
170
+ const paramsAny = parameters;
171
+ if (!paramsAny?.filters || !Array.isArray(paramsAny.filters)) {
172
+ return filters;
173
+ }
174
+ for (const filter of paramsAny.filters) {
175
+ if (!filter?.field || filter?.value === undefined || filter?.value === null) {
176
+ continue;
177
+ }
178
+ const field = filter.field;
179
+ const value = filter.value;
180
+ const operator = filter.operator || { type: 'equal' };
181
+ // Handle tenant-specific field mappings
182
+ if (field === 'tenantId') {
183
+ // Tenant ID filter - can be array of IDs or single ID
184
+ if (Array.isArray(value) && value.length > 0) {
185
+ filters.push({
186
+ field: 'id',
187
+ operator: { type: 'in' },
188
+ value: value,
189
+ });
190
+ }
191
+ else if (value) {
192
+ filters.push({
193
+ field: 'id',
194
+ operator: { type: 'equal' },
195
+ value: value,
196
+ });
197
+ }
198
+ }
199
+ else if (field === 'statusId') {
200
+ // Status filter - skip 'all' value
201
+ if (value && value !== 'all') {
202
+ filters.push({
203
+ field: 'statusId',
204
+ operator: { type: 'equal' },
205
+ value: value,
206
+ });
207
+ }
208
+ }
209
+ else if (field === 'dateRange') {
210
+ // Date range filter - custom logic handled in query
211
+ filters.push({
212
+ field: 'dateRange',
213
+ operator: { type: 'equal' },
214
+ value: value,
215
+ });
216
+ }
217
+ else {
218
+ // Direct field mapping
219
+ filters.push({
220
+ field: field,
221
+ operator: operator,
222
+ value: value,
223
+ });
224
+ }
225
+ }
226
+ return filters;
227
+ }
228
+ //#endregion
229
+ //#region ---- Custom Filter Handlers ----
230
+ /**
231
+ * Apply date range filter to tenants
232
+ */
233
+ applyDateRangeFilter(tenants, dateRange) {
234
+ if (!dateRange || !dateRange.start || !dateRange.end) {
235
+ return tenants;
236
+ }
237
+ const startDate = new Date(dateRange.start);
238
+ const endDate = new Date(dateRange.end);
239
+ endDate.setHours(23, 59, 59, 999);
240
+ return tenants.filter((tenant) => {
241
+ if (!tenant.registrationDate)
242
+ return false;
243
+ const regDate = new Date(tenant.registrationDate);
244
+ return regDate >= startDate && regDate <= endDate;
245
+ });
246
+ }
247
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: GetTenantApplicationAccessQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
248
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: GetTenantApplicationAccessQuery, providedIn: 'root' }); }
249
+ }
250
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: GetTenantApplicationAccessQuery, decorators: [{
251
+ type: Injectable,
252
+ args: [{
253
+ providedIn: 'root',
254
+ }]
255
+ }] });
256
+
257
+ export { GetTenantApplicationAccessQuery };
258
+ //# sourceMappingURL=acorex-connectivity-mock-get-tenant-application-access.query-BDfrwf5Z.mjs.map