@acorex/connectivity 20.7.5 → 20.7.7

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.
@@ -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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"}
@@ -0,0 +1,209 @@
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/location-management';
5
+
6
+ //#endregion
7
+ class GetLocationListQuery {
8
+ constructor() {
9
+ this.entityService = inject(AXPEntityService);
10
+ this.locationService = this.entityService
11
+ .withEntity(`${RootConfig.module.name}.${RootConfig.entities.location.name}`)
12
+ .data();
13
+ }
14
+ async fetch(input) {
15
+ // Extract location-specific filters from AXPFilterClause format
16
+ const extractedFilters = this.extractLocationFilters(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 locations from storage with entity filters
25
+ const allLocationsResult = await this.locationService.query({
26
+ skip: 0,
27
+ take: 10000, // Get all locations for aggregation
28
+ filter: entityFilters.length > 0
29
+ ? {
30
+ logic: input.logic || 'and',
31
+ filters: entityFilters,
32
+ }
33
+ : undefined,
34
+ });
35
+ const allLocations = allLocationsResult.items;
36
+ // Group locations by country, province, and city
37
+ const locationGroups = new Map();
38
+ for (const location of allLocations) {
39
+ // Get geographic information
40
+ const countryId = location.countryId || 'unknown';
41
+ const countryTitle = location.country?.title || 'Unknown Country';
42
+ const provinceId = location.stateId || 'unknown';
43
+ const provinceTitle = location.state?.title || 'Unknown Province';
44
+ const cityId = location.cityId || 'unknown';
45
+ const cityTitle = location.city?.title || 'Unknown City';
46
+ // Create nested map structure: country -> province -> city -> locations[]
47
+ if (!locationGroups.has(countryId)) {
48
+ locationGroups.set(countryId, new Map());
49
+ }
50
+ const provinceMap = locationGroups.get(countryId);
51
+ if (!provinceMap.has(provinceId)) {
52
+ provinceMap.set(provinceId, new Map());
53
+ }
54
+ const cityMap = provinceMap.get(provinceId);
55
+ if (!cityMap.has(cityId)) {
56
+ cityMap.set(cityId, []);
57
+ }
58
+ cityMap.get(cityId).push(location);
59
+ }
60
+ // Aggregate data by country, province, and city
61
+ const aggregatedResults = [];
62
+ for (const [countryId, provinceMap] of locationGroups.entries()) {
63
+ const firstLocation = Array.from(provinceMap.values())[0]?.values().next().value?.[0];
64
+ const countryTitle = firstLocation?.country?.title || 'Unknown Country';
65
+ for (const [provinceId, cityMap] of provinceMap.entries()) {
66
+ const firstLocationInProvince = cityMap.values().next().value?.[0];
67
+ const provinceTitle = firstLocationInProvince?.state?.title || 'Unknown Province';
68
+ for (const [cityId, locations] of cityMap.entries()) {
69
+ const cityTitle = locations[0]?.city?.title || 'Unknown City';
70
+ aggregatedResults.push({
71
+ countryId,
72
+ countryTitle,
73
+ provinceId,
74
+ provinceTitle,
75
+ cityId,
76
+ cityTitle,
77
+ locationCount: locations.length,
78
+ totalLocations: locations.length,
79
+ });
80
+ }
81
+ }
82
+ }
83
+ // Apply sorting if provided
84
+ if (input.sort && input.sort.length > 0) {
85
+ aggregatedResults.sort((a, b) => {
86
+ for (const sortField of input.sort) {
87
+ const field = sortField.field;
88
+ const aValue = a[field];
89
+ const bValue = b[field];
90
+ const dir = sortField.dir === 'asc' ? 1 : -1;
91
+ // Handle undefined values
92
+ if (aValue === undefined && bValue === undefined)
93
+ continue;
94
+ if (aValue === undefined)
95
+ return 1 * dir;
96
+ if (bValue === undefined)
97
+ return -1 * dir;
98
+ if (aValue < bValue)
99
+ return -1 * dir;
100
+ if (aValue > bValue)
101
+ return 1 * dir;
102
+ }
103
+ return 0;
104
+ });
105
+ }
106
+ // Apply pagination
107
+ const skip = input.skip || 0;
108
+ const take = input.take || 10;
109
+ const total = aggregatedResults.length;
110
+ const items = aggregatedResults.slice(skip, skip + take);
111
+ return {
112
+ items,
113
+ total,
114
+ };
115
+ }
116
+ //#region ---- Filter Extraction ----
117
+ /**
118
+ * Extract location-specific filters from AXPFilterClause format
119
+ * Maps report parameter paths to location entity field names
120
+ */
121
+ extractLocationFilters(parameters) {
122
+ const filters = [];
123
+ const paramsAny = parameters;
124
+ if (!paramsAny?.filters || !Array.isArray(paramsAny.filters)) {
125
+ console.log('⚠️ [extractLocationFilters] No filters array found or not an array');
126
+ return filters;
127
+ }
128
+ for (const filter of paramsAny.filters) {
129
+ if (!filter?.field || filter?.value === undefined || filter?.value === null) {
130
+ continue;
131
+ }
132
+ const field = filter.field;
133
+ const value = filter.value;
134
+ const operator = filter.operator || { type: 'equal' };
135
+ // Handle location-specific field mappings
136
+ if (field === 'country') {
137
+ // Country filter
138
+ if (Array.isArray(value) && value.length > 0) {
139
+ filters.push({
140
+ field: 'countryId',
141
+ operator: { type: 'in' },
142
+ value: value,
143
+ });
144
+ }
145
+ else if (value) {
146
+ filters.push({
147
+ field: 'countryId',
148
+ operator: { type: 'equal' },
149
+ value: value,
150
+ });
151
+ }
152
+ }
153
+ else if (field === 'province') {
154
+ // Province/State filter
155
+ if (Array.isArray(value) && value.length > 0) {
156
+ filters.push({
157
+ field: 'stateId',
158
+ operator: { type: 'in' },
159
+ value: value,
160
+ });
161
+ }
162
+ else if (value) {
163
+ filters.push({
164
+ field: 'stateId',
165
+ operator: { type: 'equal' },
166
+ value: value,
167
+ });
168
+ console.log('✅ [extractLocationFilters] Added province filter (equal):', value);
169
+ }
170
+ }
171
+ else if (field === 'city') {
172
+ if (Array.isArray(value) && value.length > 0) {
173
+ filters.push({
174
+ field: 'cityId',
175
+ operator: { type: 'in' },
176
+ value: value,
177
+ });
178
+ }
179
+ else if (value) {
180
+ filters.push({
181
+ field: 'cityId',
182
+ operator: { type: 'equal' },
183
+ value: value,
184
+ });
185
+ }
186
+ }
187
+ else {
188
+ // Direct field mapping
189
+ filters.push({
190
+ field: field,
191
+ operator: operator,
192
+ value: value,
193
+ });
194
+ }
195
+ }
196
+ return filters;
197
+ }
198
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: GetLocationListQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
199
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: GetLocationListQuery, providedIn: 'root' }); }
200
+ }
201
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.16", ngImport: i0, type: GetLocationListQuery, decorators: [{
202
+ type: Injectable,
203
+ args: [{
204
+ providedIn: 'root',
205
+ }]
206
+ }] });
207
+
208
+ export { GetLocationListQuery };
209
+ //# sourceMappingURL=acorex-connectivity-mock-get-location-list.query-Cz55arFF.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"acorex-connectivity-mock-get-location-list.query-Cz55arFF.mjs","sources":["../tmp-esm2022/mock/lib/report-management/samples/get-location-list.query.js"],"sourcesContent":["import { inject, Injectable } from '@angular/core';\nimport { AXPEntityService } from '@acorex/platform/layout/entity';\nimport { RootConfig as LocationRootConfig } from '@acorex/modules/location-management';\nimport * as i0 from \"@angular/core\";\n//#endregion\nexport class GetLocationListQuery {\n constructor() {\n this.entityService = inject(AXPEntityService);\n this.locationService = this.entityService\n .withEntity(`${LocationRootConfig.module.name}.${LocationRootConfig.entities.location.name}`)\n .data();\n }\n async fetch(input) {\n // Extract location-specific filters from AXPFilterClause format\n const extractedFilters = this.extractLocationFilters(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 locations from storage with entity filters\n const allLocationsResult = await this.locationService.query({\n skip: 0,\n take: 10000, // Get all locations for aggregation\n filter: entityFilters.length > 0\n ? {\n logic: input.logic || 'and',\n filters: entityFilters,\n }\n : undefined,\n });\n const allLocations = allLocationsResult.items;\n // Group locations by country, province, and city\n const locationGroups = new Map();\n for (const location of allLocations) {\n // Get geographic information\n const countryId = location.countryId || 'unknown';\n const countryTitle = location.country?.title || 'Unknown Country';\n const provinceId = location.stateId || 'unknown';\n const provinceTitle = location.state?.title || 'Unknown Province';\n const cityId = location.cityId || 'unknown';\n const cityTitle = location.city?.title || 'Unknown City';\n // Create nested map structure: country -> province -> city -> locations[]\n if (!locationGroups.has(countryId)) {\n locationGroups.set(countryId, new Map());\n }\n const provinceMap = locationGroups.get(countryId);\n if (!provinceMap.has(provinceId)) {\n provinceMap.set(provinceId, new Map());\n }\n const cityMap = provinceMap.get(provinceId);\n if (!cityMap.has(cityId)) {\n cityMap.set(cityId, []);\n }\n cityMap.get(cityId).push(location);\n }\n // Aggregate data by country, province, and city\n const aggregatedResults = [];\n for (const [countryId, provinceMap] of locationGroups.entries()) {\n const firstLocation = Array.from(provinceMap.values())[0]?.values().next().value?.[0];\n const countryTitle = firstLocation?.country?.title || 'Unknown Country';\n for (const [provinceId, cityMap] of provinceMap.entries()) {\n const firstLocationInProvince = cityMap.values().next().value?.[0];\n const provinceTitle = firstLocationInProvince?.state?.title || 'Unknown Province';\n for (const [cityId, locations] of cityMap.entries()) {\n const cityTitle = locations[0]?.city?.title || 'Unknown City';\n aggregatedResults.push({\n countryId,\n countryTitle,\n provinceId,\n provinceTitle,\n cityId,\n cityTitle,\n locationCount: locations.length,\n totalLocations: locations.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;\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 location-specific filters from AXPFilterClause format\n * Maps report parameter paths to location entity field names\n */\n extractLocationFilters(parameters) {\n const filters = [];\n const paramsAny = parameters;\n if (!paramsAny?.filters || !Array.isArray(paramsAny.filters)) {\n console.log('⚠️ [extractLocationFilters] No filters array found or not an array');\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 location-specific field mappings\n if (field === 'country') {\n // Country filter\n if (Array.isArray(value) && value.length > 0) {\n filters.push({\n field: 'countryId',\n operator: { type: 'in' },\n value: value,\n });\n }\n else if (value) {\n filters.push({\n field: 'countryId',\n operator: { type: 'equal' },\n value: value,\n });\n }\n }\n else if (field === 'province') {\n // Province/State filter\n if (Array.isArray(value) && value.length > 0) {\n filters.push({\n field: 'stateId',\n operator: { type: 'in' },\n value: value,\n });\n }\n else if (value) {\n filters.push({\n field: 'stateId',\n operator: { type: 'equal' },\n value: value,\n });\n console.log('✅ [extractLocationFilters] Added province filter (equal):', value);\n }\n }\n else if (field === 'city') {\n if (Array.isArray(value) && value.length > 0) {\n filters.push({\n field: 'cityId',\n operator: { type: 'in' },\n value: value,\n });\n }\n else if (value) {\n filters.push({\n field: 'cityId',\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: GetLocationListQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.16\", ngImport: i0, type: GetLocationListQuery, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.16\", ngImport: i0, type: GetLocationListQuery, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root',\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"get-location-list.query.js","sourceRoot":"","sources":["../../../../../../../../libs/connectivity/mock/src/lib/report-management/samples/get-location-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 { AXMLocationManagementLocationEntityModel } from '@acorex/modules/location-management';\nimport { RootConfig as LocationRootConfig } from '@acorex/modules/location-management';\n\n//#region ----   Query Input/Output Types   ----\n\nexport interface GetLocationListQueryInput {\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 LocationByCityResult {\n  countryId?: string;\n  countryTitle?: string;\n  provinceId?: string;\n  provinceTitle?: string;\n  cityId?: string;\n  cityTitle?: string;\n  locationCount: number;\n  totalLocations: number;\n}\n\nexport interface GetLocationListQueryResult {\n  items: LocationByCityResult[];\n  total: number;\n}\n\n//#endregion\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class GetLocationListQuery implements AXPQuery<GetLocationListQueryInput, GetLocationListQueryResult> {\n  private readonly entityService = inject(AXPEntityService);\n  private locationService = this.entityService\n    .withEntity(`${LocationRootConfig.module.name}.${LocationRootConfig.entities.location.name}`)\n    .data<string, AXMLocationManagementLocationEntityModel>();\n\n  async fetch(input: GetLocationListQueryInput | any): Promise<GetLocationListQueryResult> {\n    // Extract location-specific filters from AXPFilterClause format\n    const extractedFilters = this.extractLocationFilters(input.filters);\n    // Separate custom filters from entity filters\n    const entityFilters: GetLocationListQueryInput['filters'] = [];\n\n    if (extractedFilters && extractedFilters.length > 0) {\n      for (const filter of extractedFilters) {\n        entityFilters.push(filter);\n      }\n    }\n    // Get all locations from storage with entity filters\n    const allLocationsResult = await this.locationService.query({\n      skip: 0,\n      take: 10000, // Get all locations 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 allLocations = allLocationsResult.items;\n\n    // Group locations by country, province, and city\n    const locationGroups = new Map<string, Map<string, Map<string, AXMLocationManagementLocationEntityModel[]>>>();\n\n    for (const location of allLocations) {\n      // Get geographic information\n      const countryId = (location as any).countryId || 'unknown';\n      const countryTitle = (location as any).country?.title || 'Unknown Country';\n\n      const provinceId = (location as any).stateId || 'unknown';\n      const provinceTitle = (location as any).state?.title || 'Unknown Province';\n\n      const cityId = (location as any).cityId || 'unknown';\n      const cityTitle = (location as any).city?.title || 'Unknown City';\n\n      // Create nested map structure: country -> province -> city -> locations[]\n      if (!locationGroups.has(countryId)) {\n        locationGroups.set(countryId, new Map());\n      }\n\n      const provinceMap = locationGroups.get(countryId)!;\n      if (!provinceMap.has(provinceId)) {\n        provinceMap.set(provinceId, new Map());\n      }\n\n      const cityMap = provinceMap.get(provinceId)!;\n      if (!cityMap.has(cityId)) {\n        cityMap.set(cityId, []);\n      }\n\n      cityMap.get(cityId)!.push(location);\n    }\n\n    // Aggregate data by country, province, and city\n    const aggregatedResults: LocationByCityResult[] = [];\n\n    for (const [countryId, provinceMap] of locationGroups.entries()) {\n      const firstLocation = Array.from(provinceMap.values())[0]?.values().next().value?.[0];\n      const countryTitle = (firstLocation as any)?.country?.title || 'Unknown Country';\n\n      for (const [provinceId, cityMap] of provinceMap.entries()) {\n        const firstLocationInProvince = cityMap.values().next().value?.[0];\n        const provinceTitle = (firstLocationInProvince as any)?.state?.title || 'Unknown Province';\n\n        for (const [cityId, locations] of cityMap.entries()) {\n          const cityTitle = (locations[0] as any)?.city?.title || 'Unknown City';\n\n          aggregatedResults.push({\n            countryId,\n            countryTitle,\n            provinceId,\n            provinceTitle,\n            cityId,\n            cityTitle,\n            locationCount: locations.length,\n            totalLocations: locations.length,\n          });\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 LocationByCityResult;\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 location-specific filters from AXPFilterClause format\n   * Maps report parameter paths to location entity field names\n   */\n  private extractLocationFilters(parameters: any): GetLocationListQueryInput['filters'] {\n    const filters: GetLocationListQueryInput['filters'] = [];\n    const paramsAny = parameters as any;\n\n    if (!paramsAny?.filters || !Array.isArray(paramsAny.filters)) {\n      console.log('⚠️ [extractLocationFilters] No filters array found or not an array');\n      return filters;\n    }\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 location-specific field mappings\n      if (field === 'country') {\n        // Country filter\n        if (Array.isArray(value) && value.length > 0) {\n          filters.push({\n            field: 'countryId',\n            operator: { type: 'in' },\n            value: value,\n          });\n        } else if (value) {\n          filters.push({\n            field: 'countryId',\n            operator: { type: 'equal' },\n            value: value,\n          });\n        }\n      } else if (field === 'province') {\n        // Province/State filter\n        if (Array.isArray(value) && value.length > 0) {\n          filters.push({\n            field: 'stateId',\n            operator: { type: 'in' },\n            value: value,\n          });\n        } else if (value) {\n          filters.push({\n            field: 'stateId',\n            operator: { type: 'equal' },\n            value: value,\n          });\n          console.log('✅ [extractLocationFilters] Added province filter (equal):', value);\n        }\n      } else if (field === 'city') {\n        if (Array.isArray(value) && value.length > 0) {\n          filters.push({\n            field: 'cityId',\n            operator: { type: 'in' },\n            value: value,\n          });\n        } else if (value) {\n          filters.push({\n            field: 'cityId',\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":["LocationRootConfig"],"mappings":"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"}