@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.
- package/api/index.d.ts +6 -65
- package/fesm2022/{acorex-connectivity-api-execute.command-CQt_HF1B.mjs → acorex-connectivity-api-execute.command-Di850KiF.mjs} +7 -7
- package/fesm2022/acorex-connectivity-api-execute.command-Di850KiF.mjs.map +1 -0
- package/fesm2022/acorex-connectivity-api.mjs +128 -206
- package/fesm2022/acorex-connectivity-api.mjs.map +1 -1
- package/fesm2022/acorex-connectivity-mock-assign-to-manager.command-T6-ao4e9.mjs +66 -0
- package/fesm2022/acorex-connectivity-mock-assign-to-manager.command-T6-ao4e9.mjs.map +1 -0
- package/fesm2022/{acorex-connectivity-mock-category-with-items.query-Dsxj98tX.mjs → acorex-connectivity-mock-category-with-items.query-KB7GIYeb.mjs} +4 -4
- package/fesm2022/{acorex-connectivity-mock-category-with-items.query-Dsxj98tX.mjs.map → acorex-connectivity-mock-category-with-items.query-KB7GIYeb.mjs.map} +1 -1
- package/fesm2022/acorex-connectivity-mock-check-permission.command-C-AZTcHP.mjs +53 -0
- package/fesm2022/acorex-connectivity-mock-check-permission.command-C-AZTcHP.mjs.map +1 -0
- package/fesm2022/acorex-connectivity-mock-complete-signature-process.command-CHci1rOa.mjs +80 -0
- package/fesm2022/acorex-connectivity-mock-complete-signature-process.command-CHci1rOa.mjs.map +1 -0
- package/fesm2022/{acorex-connectivity-mock-distribution-record.command-DRiDwlqN.mjs → acorex-connectivity-mock-distribution-record.command-DMoZvago.mjs} +4 -4
- package/fesm2022/{acorex-connectivity-mock-distribution-record.command-DRiDwlqN.mjs.map → acorex-connectivity-mock-distribution-record.command-DMoZvago.mjs.map} +1 -1
- package/fesm2022/acorex-connectivity-mock-get-application-versions-chart-data.query-B1TrIBvU.mjs +115 -0
- package/fesm2022/acorex-connectivity-mock-get-application-versions-chart-data.query-B1TrIBvU.mjs.map +1 -0
- package/fesm2022/acorex-connectivity-mock-get-application-versions-timeline.query-CvNjA4OH.mjs +163 -0
- package/fesm2022/acorex-connectivity-mock-get-application-versions-timeline.query-CvNjA4OH.mjs.map +1 -0
- package/fesm2022/acorex-connectivity-mock-get-employee-list.query--f2M5RgC.mjs +213 -0
- package/fesm2022/acorex-connectivity-mock-get-employee-list.query--f2M5RgC.mjs.map +1 -0
- package/fesm2022/acorex-connectivity-mock-get-location-list.query-Cz55arFF.mjs +209 -0
- package/fesm2022/acorex-connectivity-mock-get-location-list.query-Cz55arFF.mjs.map +1 -0
- package/fesm2022/acorex-connectivity-mock-get-product-chart-data.query-C7v7D4ep.mjs +186 -0
- package/fesm2022/acorex-connectivity-mock-get-product-chart-data.query-C7v7D4ep.mjs.map +1 -0
- package/fesm2022/acorex-connectivity-mock-get-product-list.query-DTj8RYwR.mjs +246 -0
- package/fesm2022/acorex-connectivity-mock-get-product-list.query-DTj8RYwR.mjs.map +1 -0
- package/fesm2022/acorex-connectivity-mock-get-product-pdf-data.query-DdLhRbP5.mjs +192 -0
- package/fesm2022/acorex-connectivity-mock-get-product-pdf-data.query-DdLhRbP5.mjs.map +1 -0
- package/fesm2022/acorex-connectivity-mock-get-subscriptions-chart-data.query-ybmzmVl5.mjs +56 -0
- package/fesm2022/acorex-connectivity-mock-get-subscriptions-chart-data.query-ybmzmVl5.mjs.map +1 -0
- package/fesm2022/acorex-connectivity-mock-get-subscriptions-timeline.query-kciEUx7d.mjs +246 -0
- package/fesm2022/acorex-connectivity-mock-get-subscriptions-timeline.query-kciEUx7d.mjs.map +1 -0
- package/fesm2022/acorex-connectivity-mock-get-tenant-application-access.query-BDfrwf5Z.mjs +258 -0
- package/fesm2022/acorex-connectivity-mock-get-tenant-application-access.query-BDfrwf5Z.mjs.map +1 -0
- package/fesm2022/acorex-connectivity-mock-get-tenant-registration-chart-data.query-BD4T2loB.mjs +56 -0
- package/fesm2022/acorex-connectivity-mock-get-tenant-registration-chart-data.query-BD4T2loB.mjs.map +1 -0
- package/fesm2022/acorex-connectivity-mock-get-tenant-registration-timeline.query-CMJ8W3Ns.mjs +294 -0
- package/fesm2022/acorex-connectivity-mock-get-tenant-registration-timeline.query-CMJ8W3Ns.mjs.map +1 -0
- package/fesm2022/acorex-connectivity-mock-get-tenant-user-distribution.query-C-gCUjbX.mjs +212 -0
- package/fesm2022/acorex-connectivity-mock-get-tenant-user-distribution.query-C-gCUjbX.mjs.map +1 -0
- package/fesm2022/acorex-connectivity-mock-notify-signers.command-DLMsWjWQ.mjs +69 -0
- package/fesm2022/acorex-connectivity-mock-notify-signers.command-DLMsWjWQ.mjs.map +1 -0
- package/fesm2022/acorex-connectivity-mock-request-signature.command-JNkj9-Yz.mjs +72 -0
- package/fesm2022/acorex-connectivity-mock-request-signature.command-JNkj9-Yz.mjs.map +1 -0
- package/fesm2022/{acorex-connectivity-mock-sample.command-CkH5bmEs.mjs → acorex-connectivity-mock-sample.command-CyrjdvEA.mjs} +4 -4
- package/fesm2022/{acorex-connectivity-mock-sample.command-CkH5bmEs.mjs.map → acorex-connectivity-mock-sample.command-CyrjdvEA.mjs.map} +1 -1
- package/fesm2022/acorex-connectivity-mock-validate-all-signatures.command-xKr94NrA.mjs +81 -0
- package/fesm2022/acorex-connectivity-mock-validate-all-signatures.command-xKr94NrA.mjs.map +1 -0
- package/fesm2022/acorex-connectivity-mock.mjs +63874 -45210
- package/fesm2022/acorex-connectivity-mock.mjs.map +1 -1
- package/fesm2022/acorex-connectivity-utils.mjs +7 -7
- package/fesm2022/acorex-connectivity-utils.mjs.map +1 -1
- package/mock/index.d.ts +986 -1839
- package/package.json +6 -6
- package/fesm2022/acorex-connectivity-api-execute.command-CQt_HF1B.mjs.map +0 -1
package/fesm2022/acorex-connectivity-mock-get-application-versions-chart-data.query-B1TrIBvU.mjs.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"acorex-connectivity-mock-get-application-versions-chart-data.query-B1TrIBvU.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.16\", ngImport: i0, type: GetApplicationVersionsChartDataQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.16\", ngImport: i0, type: GetApplicationVersionsChartDataQuery, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.16\", 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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"}
|
package/fesm2022/acorex-connectivity-mock-get-application-versions-timeline.query-CvNjA4OH.mjs
ADDED
|
@@ -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.16", ngImport: i0, type: GetApplicationVersionsTimelineQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
153
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: GetApplicationVersionsTimelineQuery, providedIn: 'root' }); }
|
|
154
|
+
}
|
|
155
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.16", 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-CvNjA4OH.mjs.map
|
package/fesm2022/acorex-connectivity-mock-get-application-versions-timeline.query-CvNjA4OH.mjs.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"acorex-connectivity-mock-get-application-versions-timeline.query-CvNjA4OH.mjs","sources":["../tmp-esm2022/mock/lib/application-management/reports/get-application-versions-timeline.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 GetApplicationVersionsTimelineQuery {\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\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 date range filter if provided\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 time period (month/quarter/year)\n const periodGroups = 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 quarter = Math.ceil(month / 3);\n const monthName = publishDate.toLocaleString('en-US', { month: 'long' });\n const quarterName = `Q${quarter}`;\n const periodKey = `${year}-${String(month).padStart(2, '0')}`;\n if (!periodGroups.has(periodKey)) {\n periodGroups.set(periodKey, []);\n }\n periodGroups.get(periodKey).push(version);\n }\n // Create timeline results\n const timelineResults = [];\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 quarter = Math.ceil(month / 3);\n const monthName = publishDate.toLocaleString('en-US', { month: 'long' });\n const quarterName = `Q${quarter}`;\n const periodKey = `${year}-${String(month).padStart(2, '0')}`;\n const versionsInPeriod = periodGroups.get(periodKey)?.length || 0;\n timelineResults.push({\n versionNumber: version.versionNumber,\n publishDate: version.publishDate,\n publishDateObj: publishDate,\n year,\n month: monthName,\n monthNumber: month,\n quarter: quarterName,\n versionCount: versionsInPeriod,\n });\n }\n // Apply sorting if provided\n if (input.sort && input.sort.length > 0) {\n timelineResults.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 // Handle undefined values\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 === 'publishDateObj') {\n const aDate = a.publishDateObj.getTime();\n const bDate = b.publishDateObj.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 publish date descending (newest first)\n timelineResults.sort((a, b) => {\n return b.publishDateObj.getTime() - a.publishDateObj.getTime();\n });\n }\n // Apply pagination\n const skip = input.skip || 0;\n const take = input.take || 10;\n const total = timelineResults.length;\n const items = timelineResults.slice(skip, skip + take);\n return {\n items,\n total,\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.16\", ngImport: i0, type: GetApplicationVersionsTimelineQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.16\", ngImport: i0, type: GetApplicationVersionsTimelineQuery, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.16\", ngImport: i0, type: GetApplicationVersionsTimelineQuery, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root',\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"get-application-versions-timeline.query.js","sourceRoot":"","sources":["../../../../../../../../libs/connectivity/mock/src/lib/application-management/reports/get-application-versions-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 { AXMAppVersionEntityModel } from '@acorex/modules/application-management';\nimport { RootConfig } from '@acorex/modules/application-management';\n\n//#region ----   Query Input/Output Types   ----\n\nexport interface GetApplicationVersionsTimelineQueryInput {\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 ApplicationVersionTimelineResult {\n  versionNumber: string;\n  publishDate: string;\n  publishDateObj: Date;\n  year: number;\n  month: string;\n  monthNumber: number;\n  quarter: string;\n  versionCount: number;\n}\n\nexport interface GetApplicationVersionsTimelineQueryResult {\n  items: ApplicationVersionTimelineResult[];\n  total: number;\n}\n\n//#endregion\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class GetApplicationVersionsTimelineQuery\n  implements AXPQuery<GetApplicationVersionsTimelineQueryInput, GetApplicationVersionsTimelineQueryResult> {\n\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(input: GetApplicationVersionsTimelineQueryInput): Promise<GetApplicationVersionsTimelineQueryResult> {\n    // Get all app versions from storage\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 date range filter if provided\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 time period (month/quarter/year)\n    const periodGroups = 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 quarter = Math.ceil(month / 3);\n      const monthName = publishDate.toLocaleString('en-US', { month: 'long' });\n      const quarterName = `Q${quarter}`;\n      const periodKey = `${year}-${String(month).padStart(2, '0')}`;\n\n      if (!periodGroups.has(periodKey)) {\n        periodGroups.set(periodKey, []);\n      }\n\n      periodGroups.get(periodKey)!.push(version);\n    }\n\n    // Create timeline results\n    const timelineResults: ApplicationVersionTimelineResult[] = [];\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 quarter = Math.ceil(month / 3);\n      const monthName = publishDate.toLocaleString('en-US', { month: 'long' });\n      const quarterName = `Q${quarter}`;\n      const periodKey = `${year}-${String(month).padStart(2, '0')}`;\n\n      const versionsInPeriod = periodGroups.get(periodKey)?.length || 0;\n\n      timelineResults.push({\n        versionNumber: version.versionNumber,\n        publishDate: version.publishDate,\n        publishDateObj: publishDate,\n        year,\n        month: monthName,\n        monthNumber: month,\n        quarter: quarterName,\n        versionCount: versionsInPeriod,\n      });\n    }\n\n    // Apply sorting if provided\n    if (input.sort && input.sort.length > 0) {\n      timelineResults.sort((a, b) => {\n        for (const sortField of input.sort!) {\n          const field = sortField.field as keyof ApplicationVersionTimelineResult;\n          const aValue = a[field];\n          const bValue = b[field];\n          const dir = sortField.dir === 'asc' ? 1 : -1;\n\n          // Handle undefined values\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 === 'publishDateObj') {\n            const aDate = a.publishDateObj.getTime();\n            const bDate = b.publishDateObj.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 publish date descending (newest first)\n      timelineResults.sort((a, b) => {\n        return b.publishDateObj.getTime() - a.publishDateObj.getTime();\n      });\n    }\n\n    // Apply pagination\n    const skip = input.skip || 0;\n    const take = input.take || 10;\n    const total = timelineResults.length;\n    const items = timelineResults.slice(skip, skip + take);\n\n    return {\n      items,\n      total,\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,213 @@
|
|
|
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/human-capital-management';
|
|
5
|
+
|
|
6
|
+
//#endregion
|
|
7
|
+
class GetEmployeeListQuery {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.entityService = inject(AXPEntityService);
|
|
10
|
+
this.employeeService = this.entityService
|
|
11
|
+
.withEntity(`${RootConfig.module.name}.${RootConfig.entities.employee.name}`)
|
|
12
|
+
.data();
|
|
13
|
+
}
|
|
14
|
+
async fetch(input) {
|
|
15
|
+
// Extract employee-specific filters from AXPFilterClause format
|
|
16
|
+
const extractedFilters = this.extractEmployeeFilters(input.filters);
|
|
17
|
+
// Separate custom filters from entity filters
|
|
18
|
+
const entityFilters = [];
|
|
19
|
+
if (extractedFilters && extractedFilters.length > 0) {
|
|
20
|
+
for (const filter of extractedFilters) {
|
|
21
|
+
entityFilters.push(filter);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
// Get all employees from storage with entity filters
|
|
25
|
+
const allEmployeesResult = await this.employeeService.query({
|
|
26
|
+
skip: 0,
|
|
27
|
+
take: 10000, // Get all employees for aggregation
|
|
28
|
+
filter: entityFilters.length > 0
|
|
29
|
+
? {
|
|
30
|
+
logic: input.logic || 'and',
|
|
31
|
+
filters: entityFilters,
|
|
32
|
+
}
|
|
33
|
+
: undefined,
|
|
34
|
+
});
|
|
35
|
+
const allEmployees = allEmployeesResult.items;
|
|
36
|
+
// Group employees by department and team
|
|
37
|
+
const departmentGroups = new Map();
|
|
38
|
+
for (const employee of allEmployees) {
|
|
39
|
+
// Get department from position (assuming position has departmentId)
|
|
40
|
+
const departmentId = employee.position?.departmentId || employee.departmentId || 'unknown';
|
|
41
|
+
const departmentTitle = employee.position?.department?.title || 'Unknown Department';
|
|
42
|
+
// Get team from team memberships (assuming employee has teamId or teamMemberships)
|
|
43
|
+
const teamId = employee.teamId || employee.teamMemberships?.[0]?.teamId || undefined;
|
|
44
|
+
const teamTitle = employee.team?.title || employee.teamMemberships?.[0]?.team?.title || undefined;
|
|
45
|
+
const teamKey = teamId || 'no-team';
|
|
46
|
+
if (!departmentGroups.has(departmentId)) {
|
|
47
|
+
departmentGroups.set(departmentId, new Map());
|
|
48
|
+
}
|
|
49
|
+
const teamMap = departmentGroups.get(departmentId);
|
|
50
|
+
if (!teamMap.has(teamKey)) {
|
|
51
|
+
teamMap.set(teamKey, []);
|
|
52
|
+
}
|
|
53
|
+
teamMap.get(teamKey).push(employee);
|
|
54
|
+
}
|
|
55
|
+
// Aggregate data by department and team
|
|
56
|
+
const aggregatedResults = [];
|
|
57
|
+
for (const [departmentId, teamMap] of departmentGroups.entries()) {
|
|
58
|
+
const firstEmployee = Array.from(teamMap.values())[0]?.[0];
|
|
59
|
+
const departmentTitle = firstEmployee?.position?.department?.title || 'Unknown Department';
|
|
60
|
+
for (const [teamKey, employees] of teamMap.entries()) {
|
|
61
|
+
const teamId = teamKey !== 'no-team' ? teamKey : undefined;
|
|
62
|
+
const teamTitle = teamKey !== 'no-team' ? employees[0]?.team?.title || employees[0]?.teamMemberships?.[0]?.team?.title : undefined;
|
|
63
|
+
// Calculate average experience (years since hire date)
|
|
64
|
+
const now = new Date();
|
|
65
|
+
const experiences = employees
|
|
66
|
+
.map((emp) => {
|
|
67
|
+
if (!emp.hireDate)
|
|
68
|
+
return 0;
|
|
69
|
+
const hireDate = new Date(emp.hireDate);
|
|
70
|
+
const diffTime = Math.abs(now.getTime() - hireDate.getTime());
|
|
71
|
+
return diffTime / (1000 * 60 * 60 * 24 * 365.25); // Convert to years
|
|
72
|
+
})
|
|
73
|
+
.filter((exp) => exp > 0);
|
|
74
|
+
const averageExperience = experiences.length > 0 ? experiences.reduce((sum, exp) => sum + exp, 0) / experiences.length : 0;
|
|
75
|
+
// Get unique employment types
|
|
76
|
+
const employmentTypeSet = new Set();
|
|
77
|
+
for (const employee of employees) {
|
|
78
|
+
if (employee.employmentType?.title) {
|
|
79
|
+
employmentTypeSet.add(employee.employmentType.title);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
const employmentTypes = Array.from(employmentTypeSet).join(', ') || 'N/A';
|
|
83
|
+
aggregatedResults.push({
|
|
84
|
+
departmentId,
|
|
85
|
+
departmentTitle,
|
|
86
|
+
teamId,
|
|
87
|
+
teamTitle,
|
|
88
|
+
employeeCount: employees.length,
|
|
89
|
+
employmentTypes,
|
|
90
|
+
averageExperience: Number(averageExperience.toFixed(2)),
|
|
91
|
+
totalEmployees: employees.length,
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
// Apply sorting if provided
|
|
96
|
+
if (input.sort && input.sort.length > 0) {
|
|
97
|
+
aggregatedResults.sort((a, b) => {
|
|
98
|
+
for (const sortField of input.sort) {
|
|
99
|
+
const field = sortField.field;
|
|
100
|
+
const aValue = a[field];
|
|
101
|
+
const bValue = b[field];
|
|
102
|
+
const dir = sortField.dir === 'asc' ? 1 : -1;
|
|
103
|
+
// Handle undefined values
|
|
104
|
+
if (aValue === undefined && bValue === undefined)
|
|
105
|
+
continue;
|
|
106
|
+
if (aValue === undefined)
|
|
107
|
+
return 1 * dir;
|
|
108
|
+
if (bValue === undefined)
|
|
109
|
+
return -1 * dir;
|
|
110
|
+
if (aValue < bValue)
|
|
111
|
+
return -1 * dir;
|
|
112
|
+
if (aValue > bValue)
|
|
113
|
+
return 1 * dir;
|
|
114
|
+
}
|
|
115
|
+
return 0;
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
// Apply pagination
|
|
119
|
+
const skip = input.skip || 0;
|
|
120
|
+
const take = input.take || 10;
|
|
121
|
+
const total = aggregatedResults.length;
|
|
122
|
+
const items = aggregatedResults.slice(skip, skip + take);
|
|
123
|
+
return {
|
|
124
|
+
items,
|
|
125
|
+
total,
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
//#region ---- Filter Extraction ----
|
|
129
|
+
/**
|
|
130
|
+
* Extract employee-specific filters from AXPFilterClause format
|
|
131
|
+
* Maps report parameter paths to employee entity field names
|
|
132
|
+
*/
|
|
133
|
+
extractEmployeeFilters(parameters) {
|
|
134
|
+
const filters = [];
|
|
135
|
+
const paramsAny = parameters;
|
|
136
|
+
if (!paramsAny?.filters || !Array.isArray(paramsAny.filters)) {
|
|
137
|
+
return filters;
|
|
138
|
+
}
|
|
139
|
+
for (const filter of paramsAny.filters) {
|
|
140
|
+
if (!filter?.field || filter?.value === undefined || filter?.value === null) {
|
|
141
|
+
continue;
|
|
142
|
+
}
|
|
143
|
+
const field = filter.field;
|
|
144
|
+
const value = filter.value;
|
|
145
|
+
const operator = filter.operator || { type: 'equal' };
|
|
146
|
+
// Handle employee-specific field mappings
|
|
147
|
+
if (field === 'department') {
|
|
148
|
+
// Department filter - can be array of IDs or single ID
|
|
149
|
+
if (Array.isArray(value) && value.length > 0) {
|
|
150
|
+
filters.push({
|
|
151
|
+
field: 'position.departmentId', // Assuming position has departmentId
|
|
152
|
+
operator: { type: 'in' },
|
|
153
|
+
value: value,
|
|
154
|
+
});
|
|
155
|
+
}
|
|
156
|
+
else if (value) {
|
|
157
|
+
filters.push({
|
|
158
|
+
field: 'position.departmentId',
|
|
159
|
+
operator: { type: 'equal' },
|
|
160
|
+
value: value,
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
else if (field === 'team') {
|
|
165
|
+
// Team filter - can be array of IDs or single ID
|
|
166
|
+
if (Array.isArray(value) && value.length > 0) {
|
|
167
|
+
filters.push({
|
|
168
|
+
field: 'teamId', // Assuming employee has teamId or teamMemberships
|
|
169
|
+
operator: { type: 'in' },
|
|
170
|
+
value: value,
|
|
171
|
+
});
|
|
172
|
+
}
|
|
173
|
+
else if (value) {
|
|
174
|
+
filters.push({
|
|
175
|
+
field: 'teamId',
|
|
176
|
+
operator: { type: 'equal' },
|
|
177
|
+
value: value,
|
|
178
|
+
});
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
else if (field === 'employmentType') {
|
|
182
|
+
// Employment type filter - skip 'all' value
|
|
183
|
+
if (value && value !== 'all') {
|
|
184
|
+
filters.push({
|
|
185
|
+
field: 'employmentTypeId',
|
|
186
|
+
operator: { type: 'equal' },
|
|
187
|
+
value: value,
|
|
188
|
+
});
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
else {
|
|
192
|
+
// Direct field mapping
|
|
193
|
+
filters.push({
|
|
194
|
+
field: field,
|
|
195
|
+
operator: operator,
|
|
196
|
+
value: value,
|
|
197
|
+
});
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
return filters;
|
|
201
|
+
}
|
|
202
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: GetEmployeeListQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
203
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: GetEmployeeListQuery, providedIn: 'root' }); }
|
|
204
|
+
}
|
|
205
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: GetEmployeeListQuery, decorators: [{
|
|
206
|
+
type: Injectable,
|
|
207
|
+
args: [{
|
|
208
|
+
providedIn: 'root',
|
|
209
|
+
}]
|
|
210
|
+
}] });
|
|
211
|
+
|
|
212
|
+
export { GetEmployeeListQuery };
|
|
213
|
+
//# sourceMappingURL=acorex-connectivity-mock-get-employee-list.query--f2M5RgC.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"acorex-connectivity-mock-get-employee-list.query--f2M5RgC.mjs","sources":["../tmp-esm2022/mock/lib/report-management/samples/get-employee-list.query.js"],"sourcesContent":["import { inject, Injectable } from '@angular/core';\nimport { AXPEntityService } from '@acorex/platform/layout/entity';\nimport { RootConfig as HumanCapitalRootConfig } from '@acorex/modules/human-capital-management';\nimport * as i0 from \"@angular/core\";\n//#endregion\nexport class GetEmployeeListQuery {\n constructor() {\n this.entityService = inject(AXPEntityService);\n this.employeeService = this.entityService\n .withEntity(`${HumanCapitalRootConfig.module.name}.${HumanCapitalRootConfig.entities.employee.name}`)\n .data();\n }\n async fetch(input) {\n // Extract employee-specific filters from AXPFilterClause format\n const extractedFilters = this.extractEmployeeFilters(input.filters);\n // Separate custom filters from entity filters\n const entityFilters = [];\n if (extractedFilters && extractedFilters.length > 0) {\n for (const filter of extractedFilters) {\n entityFilters.push(filter);\n }\n }\n // Get all employees from storage with entity filters\n const allEmployeesResult = await this.employeeService.query({\n skip: 0,\n take: 10000, // Get all employees for aggregation\n filter: entityFilters.length > 0\n ? {\n logic: input.logic || 'and',\n filters: entityFilters,\n }\n : undefined,\n });\n const allEmployees = allEmployeesResult.items;\n // Group employees by department and team\n const departmentGroups = new Map();\n for (const employee of allEmployees) {\n // Get department from position (assuming position has departmentId)\n const departmentId = employee.position?.departmentId || employee.departmentId || 'unknown';\n const departmentTitle = employee.position?.department?.title || 'Unknown Department';\n // Get team from team memberships (assuming employee has teamId or teamMemberships)\n const teamId = employee.teamId || employee.teamMemberships?.[0]?.teamId || undefined;\n const teamTitle = employee.team?.title || employee.teamMemberships?.[0]?.team?.title || undefined;\n const teamKey = teamId || 'no-team';\n if (!departmentGroups.has(departmentId)) {\n departmentGroups.set(departmentId, new Map());\n }\n const teamMap = departmentGroups.get(departmentId);\n if (!teamMap.has(teamKey)) {\n teamMap.set(teamKey, []);\n }\n teamMap.get(teamKey).push(employee);\n }\n // Aggregate data by department and team\n const aggregatedResults = [];\n for (const [departmentId, teamMap] of departmentGroups.entries()) {\n const firstEmployee = Array.from(teamMap.values())[0]?.[0];\n const departmentTitle = firstEmployee?.position?.department?.title || 'Unknown Department';\n for (const [teamKey, employees] of teamMap.entries()) {\n const teamId = teamKey !== 'no-team' ? teamKey : undefined;\n const teamTitle = teamKey !== 'no-team' ? employees[0]?.team?.title || employees[0]?.teamMemberships?.[0]?.team?.title : undefined;\n // Calculate average experience (years since hire date)\n const now = new Date();\n const experiences = employees\n .map((emp) => {\n if (!emp.hireDate)\n return 0;\n const hireDate = new Date(emp.hireDate);\n const diffTime = Math.abs(now.getTime() - hireDate.getTime());\n return diffTime / (1000 * 60 * 60 * 24 * 365.25); // Convert to years\n })\n .filter((exp) => exp > 0);\n const averageExperience = experiences.length > 0 ? experiences.reduce((sum, exp) => sum + exp, 0) / experiences.length : 0;\n // Get unique employment types\n const employmentTypeSet = new Set();\n for (const employee of employees) {\n if (employee.employmentType?.title) {\n employmentTypeSet.add(employee.employmentType.title);\n }\n }\n const employmentTypes = Array.from(employmentTypeSet).join(', ') || 'N/A';\n aggregatedResults.push({\n departmentId,\n departmentTitle,\n teamId,\n teamTitle,\n employeeCount: employees.length,\n employmentTypes,\n averageExperience: Number(averageExperience.toFixed(2)),\n totalEmployees: employees.length,\n });\n }\n }\n // Apply sorting if provided\n if (input.sort && input.sort.length > 0) {\n aggregatedResults.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 // Handle undefined values\n if (aValue === undefined && bValue === undefined)\n continue;\n if (aValue === undefined)\n return 1 * dir;\n if (bValue === undefined)\n return -1 * dir;\n if (aValue < bValue)\n return -1 * dir;\n if (aValue > bValue)\n return 1 * dir;\n }\n return 0;\n });\n }\n // Apply pagination\n const skip = input.skip || 0;\n const take = input.take || 10;\n const total = aggregatedResults.length;\n const items = aggregatedResults.slice(skip, skip + take);\n return {\n items,\n total,\n };\n }\n //#region ---- Filter Extraction ----\n /**\n * Extract employee-specific filters from AXPFilterClause format\n * Maps report parameter paths to employee entity field names\n */\n extractEmployeeFilters(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 employee-specific field mappings\n if (field === 'department') {\n // Department filter - can be array of IDs or single ID\n if (Array.isArray(value) && value.length > 0) {\n filters.push({\n field: 'position.departmentId', // Assuming position has departmentId\n operator: { type: 'in' },\n value: value,\n });\n }\n else if (value) {\n filters.push({\n field: 'position.departmentId',\n operator: { type: 'equal' },\n value: value,\n });\n }\n }\n else if (field === 'team') {\n // Team filter - can be array of IDs or single ID\n if (Array.isArray(value) && value.length > 0) {\n filters.push({\n field: 'teamId', // Assuming employee has teamId or teamMemberships\n operator: { type: 'in' },\n value: value,\n });\n }\n else if (value) {\n filters.push({\n field: 'teamId',\n operator: { type: 'equal' },\n value: value,\n });\n }\n }\n else if (field === 'employmentType') {\n // Employment type filter - skip 'all' value\n if (value && value !== 'all') {\n filters.push({\n field: 'employmentTypeId',\n operator: { type: 'equal' },\n value: value,\n });\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 static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.16\", ngImport: i0, type: GetEmployeeListQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.16\", ngImport: i0, type: GetEmployeeListQuery, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.16\", ngImport: i0, type: GetEmployeeListQuery, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root',\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"get-employee-list.query.js","sourceRoot":"","sources":["../../../../../../../../libs/connectivity/mock/src/lib/report-management/samples/get-employee-list.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 { AXMHumanCapitalManagementEmployeeEntityModel } from '@acorex/modules/human-capital-management';\nimport { RootConfig as HumanCapitalRootConfig } from '@acorex/modules/human-capital-management';\nimport { RootConfig as OrganizationRootConfig } from '@acorex/modules/organization-management';\n\n//#region ----   Query Input/Output Types   ----\n\nexport interface GetEmployeeListQueryInput {\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 EmployeeByDepartmentResult {\n  departmentId: string;\n  departmentTitle: string;\n  teamId?: string;\n  teamTitle?: string;\n  employeeCount: number;\n  employmentTypes: string;\n  averageExperience: number;\n  totalEmployees: number;\n}\n\nexport interface GetEmployeeListQueryResult {\n  items: EmployeeByDepartmentResult[];\n  total: number;\n}\n\n//#endregion\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class GetEmployeeListQuery implements AXPQuery<GetEmployeeListQueryInput, GetEmployeeListQueryResult> {\n  private readonly entityService = inject(AXPEntityService);\n  private employeeService = this.entityService\n    .withEntity(`${HumanCapitalRootConfig.module.name}.${HumanCapitalRootConfig.entities.employee.name}`)\n    .data<string, AXMHumanCapitalManagementEmployeeEntityModel>();\n\n  async fetch(input: GetEmployeeListQueryInput | any): Promise<GetEmployeeListQueryResult> {\n    // Extract employee-specific filters from AXPFilterClause format\n    const extractedFilters = this.extractEmployeeFilters(input.filters);\n\n    // Separate custom filters from entity filters\n    const entityFilters: GetEmployeeListQueryInput['filters'] = [];\n\n    if (extractedFilters && extractedFilters.length > 0) {\n      for (const filter of extractedFilters) {\n        entityFilters.push(filter);\n      }\n    }\n\n    // Get all employees from storage with entity filters\n    const allEmployeesResult = await this.employeeService.query({\n      skip: 0,\n      take: 10000, // Get all employees for aggregation\n      filter:\n        entityFilters.length > 0\n          ? ({\n              logic: input.logic || 'and',\n              filters: entityFilters,\n            } as any)\n          : undefined,\n    });\n\n    const allEmployees = allEmployeesResult.items;\n\n    // Group employees by department and team\n    const departmentGroups = new Map<string, Map<string, AXMHumanCapitalManagementEmployeeEntityModel[]>>();\n\n    for (const employee of allEmployees) {\n      // Get department from position (assuming position has departmentId)\n      const departmentId = (employee as any).position?.departmentId || (employee as any).departmentId || 'unknown';\n      const departmentTitle = (employee as any).position?.department?.title || 'Unknown Department';\n\n      // Get team from team memberships (assuming employee has teamId or teamMemberships)\n      const teamId = (employee as any).teamId || (employee as any).teamMemberships?.[0]?.teamId || undefined;\n      const teamTitle = (employee as any).team?.title || (employee as any).teamMemberships?.[0]?.team?.title || undefined;\n\n      const teamKey = teamId || 'no-team';\n\n      if (!departmentGroups.has(departmentId)) {\n        departmentGroups.set(departmentId, new Map());\n      }\n\n      const teamMap = departmentGroups.get(departmentId)!;\n      if (!teamMap.has(teamKey)) {\n        teamMap.set(teamKey, []);\n      }\n\n      teamMap.get(teamKey)!.push(employee);\n    }\n\n    // Aggregate data by department and team\n    const aggregatedResults: EmployeeByDepartmentResult[] = [];\n\n    for (const [departmentId, teamMap] of departmentGroups.entries()) {\n      const firstEmployee = Array.from(teamMap.values())[0]?.[0];\n      const departmentTitle = (firstEmployee as any)?.position?.department?.title || 'Unknown Department';\n\n      for (const [teamKey, employees] of teamMap.entries()) {\n        const teamId = teamKey !== 'no-team' ? teamKey : undefined;\n        const teamTitle =\n          teamKey !== 'no-team' ? (employees[0] as any)?.team?.title || (employees[0] as any)?.teamMemberships?.[0]?.team?.title : undefined;\n\n        // Calculate average experience (years since hire date)\n        const now = new Date();\n        const experiences = employees\n          .map((emp) => {\n            if (!emp.hireDate) return 0;\n            const hireDate = new Date(emp.hireDate);\n            const diffTime = Math.abs(now.getTime() - hireDate.getTime());\n            return diffTime / (1000 * 60 * 60 * 24 * 365.25); // Convert to years\n          })\n          .filter((exp) => exp > 0);\n\n        const averageExperience = experiences.length > 0 ? experiences.reduce((sum, exp) => sum + exp, 0) / experiences.length : 0;\n\n        // Get unique employment types\n        const employmentTypeSet = new Set<string>();\n        for (const employee of employees) {\n          if ((employee as any).employmentType?.title) {\n            employmentTypeSet.add((employee as any).employmentType.title);\n          }\n        }\n        const employmentTypes = Array.from(employmentTypeSet).join(', ') || 'N/A';\n\n        aggregatedResults.push({\n          departmentId,\n          departmentTitle,\n          teamId,\n          teamTitle,\n          employeeCount: employees.length,\n          employmentTypes,\n          averageExperience: Number(averageExperience.toFixed(2)),\n          totalEmployees: employees.length,\n        });\n      }\n    }\n\n    // Apply sorting if provided\n    if (input.sort && input.sort.length > 0) {\n      aggregatedResults.sort((a, b) => {\n        for (const sortField of input.sort!) {\n          const field = sortField.field as keyof EmployeeByDepartmentResult;\n          const aValue = a[field];\n          const bValue = b[field];\n          const dir = sortField.dir === 'asc' ? 1 : -1;\n\n          // Handle undefined values\n          if (aValue === undefined && bValue === undefined) continue;\n          if (aValue === undefined) return 1 * dir;\n          if (bValue === undefined) return -1 * dir;\n\n          if (aValue < bValue) return -1 * dir;\n          if (aValue > bValue) return 1 * dir;\n        }\n        return 0;\n      });\n    }\n\n    // Apply pagination\n    const skip = input.skip || 0;\n    const take = input.take || 10;\n    const total = aggregatedResults.length;\n    const items = aggregatedResults.slice(skip, skip + take);\n\n    return {\n      items,\n      total,\n    };\n  }\n\n  //#region ----   Filter Extraction   ----\n\n  /**\n   * Extract employee-specific filters from AXPFilterClause format\n   * Maps report parameter paths to employee entity field names\n   */\n  private extractEmployeeFilters(parameters: any): GetEmployeeListQueryInput['filters'] {\n    const filters: GetEmployeeListQueryInput['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 employee-specific field mappings\n      if (field === 'department') {\n        // Department filter - can be array of IDs or single ID\n        if (Array.isArray(value) && value.length > 0) {\n          filters.push({\n            field: 'position.departmentId', // Assuming position has departmentId\n            operator: { type: 'in' },\n            value: value,\n          });\n        } else if (value) {\n          filters.push({\n            field: 'position.departmentId',\n            operator: { type: 'equal' },\n            value: value,\n          });\n        }\n      } else if (field === 'team') {\n        // Team filter - can be array of IDs or single ID\n        if (Array.isArray(value) && value.length > 0) {\n          filters.push({\n            field: 'teamId', // Assuming employee has teamId or teamMemberships\n            operator: { type: 'in' },\n            value: value,\n          });\n        } else if (value) {\n          filters.push({\n            field: 'teamId',\n            operator: { type: 'equal' },\n            value: value,\n          });\n        }\n      } else if (field === 'employmentType') {\n        // Employment type filter - skip 'all' value\n        if (value && value !== 'all') {\n          filters.push({\n            field: 'employmentTypeId',\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\n    return filters;\n  }\n\n  //#endregion\n}\n"]}"],"names":["HumanCapitalRootConfig"],"mappings":"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"}
|