@acorex/connectivity 20.3.0-next.2 → 20.3.0-next.3
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/fesm2022/{acorex-connectivity-mock-category-with-items.query-DXt3OWKg.mjs → acorex-connectivity-mock-category-with-items.query-DEY9R9q2.mjs} +35 -5
- package/fesm2022/acorex-connectivity-mock-category-with-items.query-DEY9R9q2.mjs.map +1 -0
- package/fesm2022/acorex-connectivity-mock.mjs +71 -20
- package/fesm2022/acorex-connectivity-mock.mjs.map +1 -1
- package/package.json +1 -1
- package/fesm2022/acorex-connectivity-mock-category-with-items.query-DXt3OWKg.mjs.map +0 -1
|
@@ -28,8 +28,32 @@ class AXCQueryCategoryWithItemsQuery {
|
|
|
28
28
|
],
|
|
29
29
|
},
|
|
30
30
|
});
|
|
31
|
-
|
|
32
|
-
|
|
31
|
+
// Build the tree and prune empty categories (no children and no items)
|
|
32
|
+
const builtRoots = await Promise.all(rootCategories.items.map((category) => this.buildCategoryTree(category)));
|
|
33
|
+
const categories = builtRoots.filter((c) => Boolean(c));
|
|
34
|
+
// Aggregate all items across remaining categories
|
|
35
|
+
const allItems = [];
|
|
36
|
+
const collectItems = (nodes) => {
|
|
37
|
+
for (const node of nodes) {
|
|
38
|
+
if (node.items?.length) {
|
|
39
|
+
allItems.push(...node.items);
|
|
40
|
+
}
|
|
41
|
+
if (node.children?.length) {
|
|
42
|
+
collectItems(node.children);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
collectItems(categories);
|
|
47
|
+
// Add synthetic 'All' node at the beginning
|
|
48
|
+
const allNode = {
|
|
49
|
+
id: 'all',
|
|
50
|
+
title: 'All',
|
|
51
|
+
childCount: 0,
|
|
52
|
+
items: allItems,
|
|
53
|
+
children: [],
|
|
54
|
+
categories: []
|
|
55
|
+
};
|
|
56
|
+
return [allNode, ...categories];
|
|
33
57
|
}
|
|
34
58
|
async buildCategoryTree(category) {
|
|
35
59
|
const itemsResult = await this.metaDataService.query({
|
|
@@ -64,13 +88,19 @@ class AXCQueryCategoryWithItemsQuery {
|
|
|
64
88
|
take: 1000,
|
|
65
89
|
skip: 0,
|
|
66
90
|
});
|
|
67
|
-
const
|
|
68
|
-
|
|
91
|
+
const builtChildren = await Promise.all(childCategoriesResult.items.map((child) => this.buildCategoryTree(child)));
|
|
92
|
+
const children = builtChildren.filter((c) => Boolean(c));
|
|
93
|
+
const node = {
|
|
69
94
|
...category,
|
|
70
95
|
items: itemsResult.items,
|
|
71
96
|
categories: children,
|
|
72
97
|
children: children,
|
|
73
98
|
};
|
|
99
|
+
// Prune node if it has no items and no children
|
|
100
|
+
if ((!node.items || node.items.length === 0) && (!node.children || node.children.length === 0)) {
|
|
101
|
+
return null;
|
|
102
|
+
}
|
|
103
|
+
return node;
|
|
74
104
|
}
|
|
75
105
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.1.8", ngImport: i0, type: AXCQueryCategoryWithItemsQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
76
106
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.1.8", ngImport: i0, type: AXCQueryCategoryWithItemsQuery, providedIn: 'root' }); }
|
|
@@ -83,4 +113,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.8", ngImpor
|
|
|
83
113
|
}] });
|
|
84
114
|
|
|
85
115
|
export { AXCQueryCategoryWithItemsQuery };
|
|
86
|
-
//# sourceMappingURL=acorex-connectivity-mock-category-with-items.query-
|
|
116
|
+
//# sourceMappingURL=acorex-connectivity-mock-category-with-items.query-DEY9R9q2.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"acorex-connectivity-mock-category-with-items.query-DEY9R9q2.mjs","sources":["../tmp-esm2022/mock/lib/data-management/metadata/category-with-items.query.js"],"sourcesContent":["import { AXMMetaDataDefinitionService, RootConfig } from '@acorex/modules/data-management';\nimport { AXMEntityCrudServiceImpl } from '@acorex/platform/layout/entity';\nimport { inject, Injectable, Injector, runInInjectionContext } from '@angular/core';\nimport * as i0 from \"@angular/core\";\nexport class AXCQueryCategoryWithItemsQuery {\n constructor() {\n this.injector = inject(Injector);\n this.categoryEntityService = runInInjectionContext(this.injector, () => new AXMEntityCrudServiceImpl(`${RootConfig.module.name}.${RootConfig.entities.metaDataDefinition.name}Category`));\n this.metaDataService = inject(AXMMetaDataDefinitionService);\n }\n fetch() {\n return this.getAllWithItems();\n }\n async getAllWithItems() {\n const rootCategories = await this.categoryEntityService.query({\n take: 1000,\n skip: 0,\n filter: {\n logic: 'and',\n filters: [\n {\n field: 'parentId',\n operator: {\n type: 'isNull',\n },\n },\n ],\n },\n });\n // Build the tree and prune empty categories (no children and no items)\n const builtRoots = await Promise.all(rootCategories.items.map((category) => this.buildCategoryTree(category)));\n const categories = builtRoots.filter((c) => Boolean(c));\n // Aggregate all items across remaining categories\n const allItems = [];\n const collectItems = (nodes) => {\n for (const node of nodes) {\n if (node.items?.length) {\n allItems.push(...node.items);\n }\n if (node.children?.length) {\n collectItems(node.children);\n }\n }\n };\n collectItems(categories);\n // Add synthetic 'All' node at the beginning\n const allNode = {\n id: 'all',\n title: 'All',\n childCount: 0,\n items: allItems,\n children: [],\n categories: []\n };\n return [allNode, ...categories];\n }\n async buildCategoryTree(category) {\n const itemsResult = await this.metaDataService.query({\n filter: {\n logic: 'and',\n filters: [\n {\n field: 'categoryIds',\n operator: {\n type: 'contains',\n },\n value: category.id,\n },\n ],\n },\n take: 1000,\n skip: 0,\n });\n const childCategoriesResult = await this.categoryEntityService.query({\n filter: {\n logic: 'and',\n filters: [\n {\n field: 'parentId',\n operator: {\n type: 'equal',\n },\n value: category.id,\n },\n ],\n },\n take: 1000,\n skip: 0,\n });\n const builtChildren = await Promise.all(childCategoriesResult.items.map((child) => this.buildCategoryTree(child)));\n const children = builtChildren.filter((c) => Boolean(c));\n const node = {\n ...category,\n items: itemsResult.items,\n categories: children,\n children: children,\n };\n // Prune node if it has no items and no children\n if ((!node.items || node.items.length === 0) && (!node.children || node.children.length === 0)) {\n return null;\n }\n return node;\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.1.8\", ngImport: i0, type: AXCQueryCategoryWithItemsQuery, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.1.8\", ngImport: i0, type: AXCQueryCategoryWithItemsQuery, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.1.8\", ngImport: i0, type: AXCQueryCategoryWithItemsQuery, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root'\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"category-with-items.query.js","sourceRoot":"","sources":["../../../../../../../../libs/connectivity/mock/src/lib/data-management/metadata/category-with-items.query.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXMMetaDataDefinitionEntityModel, AXMMetaDataDefinitionService, RootConfig } from '@acorex/modules/data-management';\nimport { AXPCategoryEntityWithItems } from '@acorex/platform/core';\nimport { AXMEntityCrudServiceImpl } from '@acorex/platform/layout/entity';\nimport { AXPQuery } from '@acorex/platform/runtime';\nimport { inject, Injectable, Injector, runInInjectionContext } from '@angular/core';\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class AXCQueryCategoryWithItemsQuery implements AXPQuery<void, AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel>[]> {\n\n    private injector = inject(Injector);\n    private categoryEntityService = runInInjectionContext(this.injector, () => new AXMEntityCrudServiceImpl<any, any>(`${RootConfig.module.name}.${RootConfig.entities.metaDataDefinition.name}Category`));\n    private metaDataService = inject(AXMMetaDataDefinitionService);\n\n\n    fetch(): Promise<any> {\n        return this.getAllWithItems();\n    }\n\n    private async getAllWithItems(): Promise<AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel>[]> {\n        const rootCategories = await this.categoryEntityService.query({\n            take: 1000,\n            skip: 0,\n            filter: {\n                logic: 'and',\n                filters: [\n                    {\n                        field: 'parentId',\n                        operator: {\n                            type: 'isNull',\n                        },\n                    },\n                ],\n            },\n        });\n\n        // Build the tree and prune empty categories (no children and no items)\n        const builtRoots = await Promise.all(rootCategories.items.map((category) => this.buildCategoryTree(category)));\n        const categories = builtRoots.filter((c): c is AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel> => Boolean(c));\n\n        // Aggregate all items across remaining categories\n        const allItems: AXMMetaDataDefinitionEntityModel[] = [];\n        const collectItems = (nodes: AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel>[]) => {\n            for (const node of nodes) {\n                if (node.items?.length) {\n                    allItems.push(...node.items);\n                }\n                if (node.children?.length) {\n                    collectItems(node.children);\n                }\n            }\n        };\n        collectItems(categories);\n\n        // Add synthetic 'All' node at the beginning\n        const allNode: AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel> & { categories?: any[] } = {\n            id: 'all',\n            title: 'All',\n            childCount: 0,\n            items: allItems,\n            children: [],\n            categories: []\n        };\n\n        return [allNode, ...categories];\n    }\n\n    private async buildCategoryTree(category: any): Promise<AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel> | null> {\n        const itemsResult = await this.metaDataService.query({\n            filter: {\n                logic: 'and',\n                filters: [\n                    {\n                        field: 'categoryIds',\n                        operator: {\n                            type: 'contains',\n                        },\n                        value: category.id,\n                    },\n                ],\n            },\n            take: 1000,\n            skip: 0,\n        });\n\n        const childCategoriesResult = await this.categoryEntityService.query({\n            filter: {\n                logic: 'and',\n                filters: [\n                    {\n                        field: 'parentId',\n                        operator: {\n                            type: 'equal',\n                        },\n                        value: category.id,\n                    },\n                ],\n            },\n            take: 1000,\n            skip: 0,\n        });\n\n        const builtChildren = await Promise.all(childCategoriesResult.items.map((child) => this.buildCategoryTree(child)));\n        const children = builtChildren.filter((c): c is AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel> => Boolean(c));\n\n        const node: AXPCategoryEntityWithItems<AXMMetaDataDefinitionEntityModel> & { categories?: any[] } = {\n            ...category,\n            items: itemsResult.items,\n            categories: children,\n            children: children,\n        };\n\n        // Prune node if it has no items and no children\n        if ((!node.items || node.items.length === 0) && (!node.children || node.children.length === 0)) {\n            return null;\n        }\n\n        return node;\n    }\n\n\n\n}"]}"],"names":[],"mappings":"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"}
|
|
@@ -248,7 +248,7 @@ class MockApplicationLoader {
|
|
|
248
248
|
const demo_app = {
|
|
249
249
|
id: '1',
|
|
250
250
|
name: 'demo',
|
|
251
|
-
title: '
|
|
251
|
+
title: 'Safetyminder Application',
|
|
252
252
|
version: '1.0.0',
|
|
253
253
|
editionName: 'Standard',
|
|
254
254
|
};
|
|
@@ -304,21 +304,10 @@ class MockPermissionLoader {
|
|
|
304
304
|
AXMPermissionsKeys$1.Issue.MyReportedIssues.Management,
|
|
305
305
|
];
|
|
306
306
|
this.adminPermissions = [...this.userPermissions, ...['admin', 'demo.admin.settings']];
|
|
307
|
-
this.rootPermissions = [
|
|
308
|
-
...this.adminPermissions,
|
|
309
|
-
...[
|
|
310
|
-
'platform',
|
|
311
|
-
'platform.reports',
|
|
312
|
-
'document-management:manage',
|
|
313
|
-
'document-management:document-type:manage',
|
|
314
|
-
'document-management:driver:manage',
|
|
315
|
-
],
|
|
316
|
-
AXMPermissionsKeys$1.Issue.ReportedIssues.Management,
|
|
317
|
-
];
|
|
318
307
|
}
|
|
319
308
|
getList(context) {
|
|
320
309
|
if (context.user?.name == 'root') {
|
|
321
|
-
return of(
|
|
310
|
+
return of();
|
|
322
311
|
}
|
|
323
312
|
else if (context.user?.name == 'admin') {
|
|
324
313
|
return of(this.adminPermissions);
|
|
@@ -339,12 +328,12 @@ class MockTenantLoader {
|
|
|
339
328
|
const acorex_tenant = {
|
|
340
329
|
id: '99',
|
|
341
330
|
name: 'acorex-tenant',
|
|
342
|
-
title: '
|
|
331
|
+
title: 'Platform Tenant',
|
|
343
332
|
};
|
|
344
333
|
const demo_tenant = {
|
|
345
334
|
id: '1',
|
|
346
335
|
name: 'demo-tenant',
|
|
347
|
-
title: '
|
|
336
|
+
title: 'Safetyminder Company',
|
|
348
337
|
};
|
|
349
338
|
// return of([demo_tenant]).pipe(delay(500));
|
|
350
339
|
// return of([acorex_tenant]).pipe(delay(500));
|
|
@@ -4508,7 +4497,7 @@ class AXCDataManagementMockModule {
|
|
|
4508
4497
|
provideQuerySetups([
|
|
4509
4498
|
{
|
|
4510
4499
|
key: 'category-with-items',
|
|
4511
|
-
loader: () => import('./acorex-connectivity-mock-category-with-items.query-
|
|
4500
|
+
loader: () => import('./acorex-connectivity-mock-category-with-items.query-DEY9R9q2.mjs').then(m => m.AXCQueryCategoryWithItemsQuery),
|
|
4512
4501
|
}
|
|
4513
4502
|
])
|
|
4514
4503
|
] }); }
|
|
@@ -4533,7 +4522,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.8", ngImpor
|
|
|
4533
4522
|
provideQuerySetups([
|
|
4534
4523
|
{
|
|
4535
4524
|
key: 'category-with-items',
|
|
4536
|
-
loader: () => import('./acorex-connectivity-mock-category-with-items.query-
|
|
4525
|
+
loader: () => import('./acorex-connectivity-mock-category-with-items.query-DEY9R9q2.mjs').then(m => m.AXCQueryCategoryWithItemsQuery),
|
|
4537
4526
|
}
|
|
4538
4527
|
])
|
|
4539
4528
|
],
|
|
@@ -32950,6 +32939,14 @@ const createFileCastMiddleware = {
|
|
|
32950
32939
|
return undefined;
|
|
32951
32940
|
}
|
|
32952
32941
|
})();
|
|
32942
|
+
const folderService = (() => {
|
|
32943
|
+
try {
|
|
32944
|
+
return inject(AXMFolderService);
|
|
32945
|
+
}
|
|
32946
|
+
catch {
|
|
32947
|
+
return undefined;
|
|
32948
|
+
}
|
|
32949
|
+
})();
|
|
32953
32950
|
// Helper Functions
|
|
32954
32951
|
const isFileListItem = (obj) => {
|
|
32955
32952
|
// Must have name as string
|
|
@@ -33067,11 +33064,9 @@ const createFileCastMiddleware = {
|
|
|
33067
33064
|
return { id: docId, kind: 'document' };
|
|
33068
33065
|
}
|
|
33069
33066
|
catch (error) {
|
|
33070
|
-
console.warn(`[file-cast] ⚠️ Failed to create document for existing file, falling back to file`, { cleanFileId, error });
|
|
33071
33067
|
}
|
|
33072
33068
|
}
|
|
33073
33069
|
else {
|
|
33074
|
-
console.warn(`[file-cast] ⚠️ Document service unavailable; returning file reference`, { cleanFileId });
|
|
33075
33070
|
}
|
|
33076
33071
|
}
|
|
33077
33072
|
return { id: cleanFileId, kind: 'file' };
|
|
@@ -33166,13 +33161,69 @@ const createFileCastMiddleware = {
|
|
|
33166
33161
|
typeof m.name === 'string' && typeof m.title === 'string' && typeof m.value === 'string');
|
|
33167
33162
|
};
|
|
33168
33163
|
const ensureDocumentRecord = async (svc, payload) => {
|
|
33169
|
-
//
|
|
33164
|
+
// Resolve or create folder hierarchy: <Entity>/<Record Title|Name>
|
|
33165
|
+
let parentId;
|
|
33166
|
+
try {
|
|
33167
|
+
if (folderService) {
|
|
33168
|
+
const findFolderByName = async (name, parent) => {
|
|
33169
|
+
const filters = [
|
|
33170
|
+
{ field: 'name', operator: { type: 'equal' }, value: name },
|
|
33171
|
+
];
|
|
33172
|
+
if (parent) {
|
|
33173
|
+
filters.push({ field: 'parentId', operator: { type: 'equal' }, value: parent });
|
|
33174
|
+
}
|
|
33175
|
+
else {
|
|
33176
|
+
filters.push({ field: 'parentId', operator: { type: 'isnull' } });
|
|
33177
|
+
}
|
|
33178
|
+
const result = await folderService.query({
|
|
33179
|
+
skip: 0,
|
|
33180
|
+
take: 1,
|
|
33181
|
+
filter: { logic: 'and', filters },
|
|
33182
|
+
});
|
|
33183
|
+
return result?.items?.[0] ?? null;
|
|
33184
|
+
};
|
|
33185
|
+
const ensureFolder = async (name, parent) => {
|
|
33186
|
+
const exists = await findFolderByName(name, parent);
|
|
33187
|
+
if (exists?.id)
|
|
33188
|
+
return exists.id;
|
|
33189
|
+
const createPayload = {
|
|
33190
|
+
name,
|
|
33191
|
+
color: '#FFFFFF',
|
|
33192
|
+
size: 0,
|
|
33193
|
+
parentId: parent,
|
|
33194
|
+
inherit: 'Extends',
|
|
33195
|
+
};
|
|
33196
|
+
const newId = await folderService.insertOne(createPayload);
|
|
33197
|
+
return newId;
|
|
33198
|
+
};
|
|
33199
|
+
// Find a root (folder with no parent)
|
|
33200
|
+
const rootQuery = await folderService.query({
|
|
33201
|
+
skip: 0,
|
|
33202
|
+
take: 1,
|
|
33203
|
+
filter: { logic: 'and', filters: [{ field: 'parentId', operator: { type: 'isnull' } }] },
|
|
33204
|
+
});
|
|
33205
|
+
const root = rootQuery?.items?.[0];
|
|
33206
|
+
if (root?.id) {
|
|
33207
|
+
const entityFullName = ctx.entityName || 'Entity';
|
|
33208
|
+
const entityNameOnly = entityFullName.split('.').pop() || entityFullName;
|
|
33209
|
+
const recordFolderName = (ctx?.data?.title || ctx?.data?.name || payload.name || 'Record').toString();
|
|
33210
|
+
const entityFolderId = await ensureFolder(entityNameOnly, root.id);
|
|
33211
|
+
parentId = await ensureFolder(recordFolderName, entityFolderId);
|
|
33212
|
+
}
|
|
33213
|
+
}
|
|
33214
|
+
}
|
|
33215
|
+
catch (e) {
|
|
33216
|
+
// Fallback: if anything fails, we will try to insert without parentId; mock may reject
|
|
33217
|
+
console.warn('[file-cast] ⚠️ Failed to ensure folder path for document, inserting without parentId');
|
|
33218
|
+
}
|
|
33219
|
+
// Insert document record with resolved parent folder if available
|
|
33170
33220
|
const id = await svc.insertOne({
|
|
33171
33221
|
fileId: addFilePrefix(payload.fileId),
|
|
33172
33222
|
name: payload.name,
|
|
33173
33223
|
title: payload.title,
|
|
33174
33224
|
size: payload.size,
|
|
33175
33225
|
meta: payload.meta,
|
|
33226
|
+
parentId,
|
|
33176
33227
|
});
|
|
33177
33228
|
return id;
|
|
33178
33229
|
};
|