@acorex/modules 21.0.0-next.89 → 21.0.0-next.90
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-modules-common.mjs +9 -9
- package/fesm2022/acorex-modules-common.mjs.map +1 -1
- package/fesm2022/{acorex-modules-conversation-acorex-modules-conversation-B_JcAHvL.mjs → acorex-modules-conversation-acorex-modules-conversation-Dc8te-PO.mjs} +364 -237
- package/fesm2022/acorex-modules-conversation-acorex-modules-conversation-Dc8te-PO.mjs.map +1 -0
- package/fesm2022/{acorex-modules-conversation-after-message-sent.command-DcrS7_vV.mjs → acorex-modules-conversation-after-message-sent.command-DxDe6o9N.mjs} +2 -2
- package/fesm2022/{acorex-modules-conversation-after-message-sent.command-DcrS7_vV.mjs.map → acorex-modules-conversation-after-message-sent.command-DxDe6o9N.mjs.map} +1 -1
- package/fesm2022/{acorex-modules-conversation-assist-delegated-agent-detail-popup.component-BCkJEAmX.mjs → acorex-modules-conversation-assist-delegated-agent-detail-popup.component-Dyx_n0bi.mjs} +3 -3
- package/fesm2022/{acorex-modules-conversation-assist-delegated-agent-detail-popup.component-BCkJEAmX.mjs.map → acorex-modules-conversation-assist-delegated-agent-detail-popup.component-Dyx_n0bi.mjs.map} +1 -1
- package/fesm2022/{acorex-modules-conversation-comments-page.component-B6TJhe4T.mjs → acorex-modules-conversation-comments-page.component--g4ugC_L.mjs} +2 -2
- package/fesm2022/{acorex-modules-conversation-comments-page.component-B6TJhe4T.mjs.map → acorex-modules-conversation-comments-page.component--g4ugC_L.mjs.map} +1 -1
- package/fesm2022/{acorex-modules-conversation-emit-typing-indicator.command-CWRdPl-S.mjs → acorex-modules-conversation-emit-typing-indicator.command-BOldPLQ0.mjs} +2 -2
- package/fesm2022/{acorex-modules-conversation-emit-typing-indicator.command-CWRdPl-S.mjs.map → acorex-modules-conversation-emit-typing-indicator.command-BOldPLQ0.mjs.map} +1 -1
- package/fesm2022/{acorex-modules-conversation-mark-conversation-unread.command-CZlsLAsb.mjs → acorex-modules-conversation-mark-conversation-unread.command-O_zPrBQ0.mjs} +2 -2
- package/fesm2022/{acorex-modules-conversation-mark-conversation-unread.command-CZlsLAsb.mjs.map → acorex-modules-conversation-mark-conversation-unread.command-O_zPrBQ0.mjs.map} +1 -1
- package/fesm2022/{acorex-modules-conversation-retry-assist-response.command-Cly1-RKt.mjs → acorex-modules-conversation-retry-assist-response.command-DsB-CP3R.mjs} +2 -2
- package/fesm2022/{acorex-modules-conversation-retry-assist-response.command-Cly1-RKt.mjs.map → acorex-modules-conversation-retry-assist-response.command-DsB-CP3R.mjs.map} +1 -1
- package/fesm2022/{acorex-modules-conversation-send-assist-chat-message.command-D5QWTKqh.mjs → acorex-modules-conversation-send-assist-chat-message.command-g_NgPuxP.mjs} +2 -2
- package/fesm2022/{acorex-modules-conversation-send-assist-chat-message.command-D5QWTKqh.mjs.map → acorex-modules-conversation-send-assist-chat-message.command-g_NgPuxP.mjs.map} +1 -1
- package/fesm2022/{acorex-modules-conversation-start-assist-chat.command-DkSZj8fj.mjs → acorex-modules-conversation-start-assist-chat.command-DeMmJdd6.mjs} +2 -2
- package/fesm2022/{acorex-modules-conversation-start-assist-chat.command-DkSZj8fj.mjs.map → acorex-modules-conversation-start-assist-chat.command-DeMmJdd6.mjs.map} +1 -1
- package/fesm2022/{acorex-modules-conversation-sync-read-state.command-jiEsdxUB.mjs → acorex-modules-conversation-sync-read-state.command-4YxdwLaE.mjs} +2 -2
- package/fesm2022/{acorex-modules-conversation-sync-read-state.command-jiEsdxUB.mjs.map → acorex-modules-conversation-sync-read-state.command-4YxdwLaE.mjs.map} +1 -1
- package/fesm2022/acorex-modules-conversation.mjs +1 -1
- package/fesm2022/{acorex-modules-dashboard-management-acorex-modules-dashboard-management-DLuhOPFz.mjs → acorex-modules-dashboard-management-acorex-modules-dashboard-management-kph3UxDu.mjs} +94 -41
- package/fesm2022/acorex-modules-dashboard-management-acorex-modules-dashboard-management-kph3UxDu.mjs.map +1 -0
- package/fesm2022/{acorex-modules-dashboard-management-index-gjCiELmH.mjs → acorex-modules-dashboard-management-index-rp9dgARq.mjs} +2 -2
- package/fesm2022/{acorex-modules-dashboard-management-index-gjCiELmH.mjs.map → acorex-modules-dashboard-management-index-rp9dgARq.mjs.map} +1 -1
- package/fesm2022/acorex-modules-dashboard-management.mjs +1 -1
- package/fesm2022/{acorex-modules-document-management-drive-choose.component-DyJoXajP.mjs → acorex-modules-document-management-drive-choose.component-Dx1slMSA.mjs} +3 -3
- package/fesm2022/{acorex-modules-document-management-drive-choose.component-DyJoXajP.mjs.map → acorex-modules-document-management-drive-choose.component-Dx1slMSA.mjs.map} +1 -1
- package/fesm2022/acorex-modules-document-management.mjs +268 -351
- package/fesm2022/acorex-modules-document-management.mjs.map +1 -1
- package/fesm2022/{acorex-modules-human-capital-management-acorex-modules-human-capital-management-VJ2NUSm1.mjs → acorex-modules-human-capital-management-acorex-modules-human-capital-management-BZwLfZkb.mjs} +42 -21
- package/fesm2022/acorex-modules-human-capital-management-acorex-modules-human-capital-management-BZwLfZkb.mjs.map +1 -0
- package/fesm2022/{acorex-modules-human-capital-management-approve-leave-request.command-FgXkyZR_.mjs → acorex-modules-human-capital-management-approve-leave-request.command-B_EBDijL.mjs} +2 -2
- package/fesm2022/{acorex-modules-human-capital-management-approve-leave-request.command-FgXkyZR_.mjs.map → acorex-modules-human-capital-management-approve-leave-request.command-B_EBDijL.mjs.map} +1 -1
- package/fesm2022/{acorex-modules-human-capital-management-assign-position-assignment.command-D2yCvifI.mjs → acorex-modules-human-capital-management-assign-position-assignment.command-ZzWBeTv1.mjs} +2 -2
- package/fesm2022/{acorex-modules-human-capital-management-assign-position-assignment.command-D2yCvifI.mjs.map → acorex-modules-human-capital-management-assign-position-assignment.command-ZzWBeTv1.mjs.map} +1 -1
- package/fesm2022/{acorex-modules-human-capital-management-cancel-leave-request.command-DnmsVNwU.mjs → acorex-modules-human-capital-management-cancel-leave-request.command-Bd3RvlNm.mjs} +2 -2
- package/fesm2022/{acorex-modules-human-capital-management-cancel-leave-request.command-DnmsVNwU.mjs.map → acorex-modules-human-capital-management-cancel-leave-request.command-Bd3RvlNm.mjs.map} +1 -1
- package/fesm2022/{acorex-modules-human-capital-management-edit-personal-info.command-B0ZUfbqn.mjs → acorex-modules-human-capital-management-edit-personal-info.command-Drbi1WMd.mjs} +2 -2
- package/fesm2022/{acorex-modules-human-capital-management-edit-personal-info.command-B0ZUfbqn.mjs.map → acorex-modules-human-capital-management-edit-personal-info.command-Drbi1WMd.mjs.map} +1 -1
- package/fesm2022/{acorex-modules-human-capital-management-edit-signature.command-h2kTqSg0.mjs → acorex-modules-human-capital-management-edit-signature.command-CRPqnXIj.mjs} +2 -2
- package/fesm2022/{acorex-modules-human-capital-management-edit-signature.command-h2kTqSg0.mjs.map → acorex-modules-human-capital-management-edit-signature.command-CRPqnXIj.mjs.map} +1 -1
- package/fesm2022/{acorex-modules-human-capital-management-reject-leave-request.command-BdrdgvbN.mjs → acorex-modules-human-capital-management-reject-leave-request.command-BC-1Kixd.mjs} +2 -2
- package/fesm2022/{acorex-modules-human-capital-management-reject-leave-request.command-BdrdgvbN.mjs.map → acorex-modules-human-capital-management-reject-leave-request.command-BC-1Kixd.mjs.map} +1 -1
- package/fesm2022/{acorex-modules-human-capital-management-revoke-position-assignment.command-S7Px6Y4B.mjs → acorex-modules-human-capital-management-revoke-position-assignment.command-Caylq9Rv.mjs} +2 -2
- package/fesm2022/{acorex-modules-human-capital-management-revoke-position-assignment.command-S7Px6Y4B.mjs.map → acorex-modules-human-capital-management-revoke-position-assignment.command-Caylq9Rv.mjs.map} +1 -1
- package/fesm2022/{acorex-modules-human-capital-management-start-leave-request-flow.command-C_tE-D_Y.mjs → acorex-modules-human-capital-management-start-leave-request-flow.command-BsEwA1VM.mjs} +2 -2
- package/fesm2022/{acorex-modules-human-capital-management-start-leave-request-flow.command-C_tE-D_Y.mjs.map → acorex-modules-human-capital-management-start-leave-request-flow.command-BsEwA1VM.mjs.map} +1 -1
- package/fesm2022/{acorex-modules-human-capital-management-start-lifecycle-event-flow.command-mMP3Yy01.mjs → acorex-modules-human-capital-management-start-lifecycle-event-flow.command-B8xK2iTn.mjs} +2 -2
- package/fesm2022/{acorex-modules-human-capital-management-start-lifecycle-event-flow.command-mMP3Yy01.mjs.map → acorex-modules-human-capital-management-start-lifecycle-event-flow.command-B8xK2iTn.mjs.map} +1 -1
- package/fesm2022/acorex-modules-human-capital-management.mjs +1 -1
- package/fesm2022/acorex-modules-platform-dev-tools.mjs +2 -2
- package/fesm2022/acorex-modules-platform-dev-tools.mjs.map +1 -1
- package/fesm2022/acorex-modules-project-management.mjs +707 -424
- package/fesm2022/acorex-modules-project-management.mjs.map +1 -1
- package/fesm2022/acorex-modules-report-management.mjs +1 -1
- package/fesm2022/acorex-modules-report-management.mjs.map +1 -1
- package/fesm2022/acorex-modules-task-management-start-task-flow.command-HYdQOWDe.mjs +115 -0
- package/fesm2022/acorex-modules-task-management-start-task-flow.command-HYdQOWDe.mjs.map +1 -0
- package/fesm2022/{acorex-modules-task-management-task-board.page-DTWxd_vG.mjs → acorex-modules-task-management-task-board.page-BMTjJlry.mjs} +3 -3
- package/fesm2022/{acorex-modules-task-management-task-board.page-DTWxd_vG.mjs.map → acorex-modules-task-management-task-board.page-BMTjJlry.mjs.map} +1 -1
- package/fesm2022/acorex-modules-task-management.mjs +433 -460
- package/fesm2022/acorex-modules-task-management.mjs.map +1 -1
- package/fesm2022/{acorex-modules-timesheet-management-report-hours-by-project.query-z38wZLKJ.mjs → acorex-modules-timesheet-management-report-hours-by-project.query-CGc1Q6aB.mjs} +2 -2
- package/fesm2022/acorex-modules-timesheet-management-report-hours-by-project.query-CGc1Q6aB.mjs.map +1 -0
- package/fesm2022/{acorex-modules-timesheet-management-resolve-work-item-from-jira-issue.command-BDfvz6fH.mjs → acorex-modules-timesheet-management-resolve-work-item-from-jira-issue.command-AIcAUd3s.mjs} +2 -2
- package/fesm2022/{acorex-modules-timesheet-management-resolve-work-item-from-jira-issue.command-BDfvz6fH.mjs.map → acorex-modules-timesheet-management-resolve-work-item-from-jira-issue.command-AIcAUd3s.mjs.map} +1 -1
- package/fesm2022/acorex-modules-timesheet-management.mjs +8 -8
- package/fesm2022/acorex-modules-timesheet-management.mjs.map +1 -1
- package/fesm2022/acorex-modules-workplacesafety-management-control-hierarchy-diagram-widget-edit.component-CFF7X1MO.mjs +70 -0
- package/fesm2022/acorex-modules-workplacesafety-management-control-hierarchy-diagram-widget-edit.component-CFF7X1MO.mjs.map +1 -0
- package/fesm2022/acorex-modules-workplacesafety-management-control-hierarchy-diagram-widget-view.component-DwC2aHVt.mjs +70 -0
- package/fesm2022/acorex-modules-workplacesafety-management-control-hierarchy-diagram-widget-view.component-DwC2aHVt.mjs.map +1 -0
- package/fesm2022/acorex-modules-workplacesafety-management-control-hierarchy-diagram.types-DmzV305e.mjs +195 -0
- package/fesm2022/acorex-modules-workplacesafety-management-control-hierarchy-diagram.types-DmzV305e.mjs.map +1 -0
- package/fesm2022/acorex-modules-workplacesafety-management.mjs +139 -16
- package/fesm2022/acorex-modules-workplacesafety-management.mjs.map +1 -1
- package/package.json +2 -2
- package/types/acorex-modules-dashboard-management.d.ts +30 -11
- package/types/acorex-modules-document-management.d.ts +21 -5
- package/types/acorex-modules-human-capital-management.d.ts +4 -0
- package/types/acorex-modules-project-management.d.ts +46 -23
- package/types/acorex-modules-task-management.d.ts +80 -11
- package/types/acorex-modules-timesheet-management.d.ts +2 -2
- package/types/acorex-modules-workplacesafety-management.d.ts +7 -2
- package/fesm2022/acorex-modules-conversation-acorex-modules-conversation-B_JcAHvL.mjs.map +0 -1
- package/fesm2022/acorex-modules-dashboard-management-acorex-modules-dashboard-management-DLuhOPFz.mjs.map +0 -1
- package/fesm2022/acorex-modules-human-capital-management-acorex-modules-human-capital-management-VJ2NUSm1.mjs.map +0 -1
- package/fesm2022/acorex-modules-timesheet-management-report-hours-by-project.query-z38wZLKJ.mjs.map +0 -1
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { AXPBaseWidgetComponent } from '@acorex/platform/layout/widget-core';
|
|
2
|
+
import * as i0 from '@angular/core';
|
|
3
|
+
import { computed, ChangeDetectionStrategy, Component } from '@angular/core';
|
|
4
|
+
import { isBoolean, isString, get, defaultTo } from 'lodash-es';
|
|
5
|
+
import { r as resolveControlHierarchyDiagramViewType, A as AXMControlHierarchyDiagramComponent } from './acorex-modules-workplacesafety-management-control-hierarchy-diagram.types-DmzV305e.mjs';
|
|
6
|
+
|
|
7
|
+
//#region ---- Imports ----
|
|
8
|
+
//#endregion
|
|
9
|
+
//#region ---- Widget Edit Component ----
|
|
10
|
+
class AXMControlHierarchyDiagramWidgetEditComponent extends AXPBaseWidgetComponent {
|
|
11
|
+
constructor() {
|
|
12
|
+
super(...arguments);
|
|
13
|
+
//#region ---- Computed Properties ----
|
|
14
|
+
/** Designer/default initial layout only; runtime selection stays inside the diagram component. */
|
|
15
|
+
this.initialViewType = computed(() => resolveControlHierarchyDiagramViewType(this.options()['viewType']), ...(ngDevMode ? [{ debugName: "initialViewType" }] : /* istanbul ignore next */ []));
|
|
16
|
+
this.showViewTypeSelector = computed(() => this.resolveShowViewTypeSelector(), ...(ngDevMode ? [{ debugName: "showViewTypeSelector" }] : /* istanbul ignore next */ []));
|
|
17
|
+
this.showTitle = computed(() => this.options()['showTitle'] === true, ...(ngDevMode ? [{ debugName: "showTitle" }] : /* istanbul ignore next */ []));
|
|
18
|
+
this.highlightLevelId = computed(() => this.resolveHighlightLevelId(), ...(ngDevMode ? [{ debugName: "highlightLevelId" }] : /* istanbul ignore next */ []));
|
|
19
|
+
}
|
|
20
|
+
//#endregion
|
|
21
|
+
//#region ---- Utility Methods ----
|
|
22
|
+
resolveShowViewTypeSelector() {
|
|
23
|
+
const options = this.options();
|
|
24
|
+
if (isBoolean(options['showViewTypeSelector'])) {
|
|
25
|
+
return options['showViewTypeSelector'];
|
|
26
|
+
}
|
|
27
|
+
return true;
|
|
28
|
+
}
|
|
29
|
+
resolveHighlightLevelId() {
|
|
30
|
+
const options = this.options();
|
|
31
|
+
const fromOptions = options['highlightLevelId'];
|
|
32
|
+
if (isString(fromOptions) && fromOptions.length > 0) {
|
|
33
|
+
return fromOptions;
|
|
34
|
+
}
|
|
35
|
+
this.contextService.changeEvent();
|
|
36
|
+
const fromContext = get(this.contextService.data(), 'id');
|
|
37
|
+
return isString(fromContext) ? fromContext : defaultTo(fromContext != null ? String(fromContext) : null, null);
|
|
38
|
+
}
|
|
39
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: AXMControlHierarchyDiagramWidgetEditComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
40
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "21.2.9", type: AXMControlHierarchyDiagramWidgetEditComponent, isStandalone: true, selector: "axm-control-hierarchy-diagram-widget-edit", host: { classAttribute: "ax-block ax-w-full" }, usesInheritance: true, ngImport: i0, template: `
|
|
41
|
+
<axm-control-hierarchy-diagram
|
|
42
|
+
[viewType]="initialViewType()"
|
|
43
|
+
[highlightLevelId]="highlightLevelId()"
|
|
44
|
+
[showViewTypeSelector]="showViewTypeSelector()"
|
|
45
|
+
[showTitle]="showTitle()"
|
|
46
|
+
/>
|
|
47
|
+
`, isInline: true, dependencies: [{ kind: "component", type: AXMControlHierarchyDiagramComponent, selector: "axm-control-hierarchy-diagram", inputs: ["viewType", "items", "highlightLevelId", "showViewTypeSelector", "showTitle"], outputs: ["viewTypeChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
48
|
+
}
|
|
49
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: AXMControlHierarchyDiagramWidgetEditComponent, decorators: [{
|
|
50
|
+
type: Component,
|
|
51
|
+
args: [{
|
|
52
|
+
selector: 'axm-control-hierarchy-diagram-widget-edit',
|
|
53
|
+
template: `
|
|
54
|
+
<axm-control-hierarchy-diagram
|
|
55
|
+
[viewType]="initialViewType()"
|
|
56
|
+
[highlightLevelId]="highlightLevelId()"
|
|
57
|
+
[showViewTypeSelector]="showViewTypeSelector()"
|
|
58
|
+
[showTitle]="showTitle()"
|
|
59
|
+
/>
|
|
60
|
+
`,
|
|
61
|
+
host: {
|
|
62
|
+
class: 'ax-block ax-w-full',
|
|
63
|
+
},
|
|
64
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
65
|
+
imports: [AXMControlHierarchyDiagramComponent],
|
|
66
|
+
}]
|
|
67
|
+
}] });
|
|
68
|
+
|
|
69
|
+
export { AXMControlHierarchyDiagramWidgetEditComponent };
|
|
70
|
+
//# sourceMappingURL=acorex-modules-workplacesafety-management-control-hierarchy-diagram-widget-edit.component-CFF7X1MO.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"acorex-modules-workplacesafety-management-control-hierarchy-diagram-widget-edit.component-CFF7X1MO.mjs","sources":["../../../../libs/modules/workplacesafety-management/src/lib/features/control-hierarchy-diagram/control-hierarchy-diagram-widget-edit.component.ts"],"sourcesContent":["//#region ---- Imports ----\n\nimport { AXPBaseWidgetComponent } from '@acorex/platform/layout/widget-core';\nimport { ChangeDetectionStrategy, Component, computed } from '@angular/core';\nimport { defaultTo, get, isBoolean, isString } from 'lodash-es';\n\nimport { AXMControlHierarchyDiagramComponent } from './control-hierarchy-diagram.component';\nimport {\n resolveControlHierarchyDiagramViewType,\n type AXMControlHierarchyDiagramViewType,\n} from './control-hierarchy-diagram.types';\nimport { type AXMControlHierarchyDiagramWidgetOptions } from './control-hierarchy-diagram-widget.config';\n\n//#endregion\n\n//#region ---- Widget Edit Component ----\n\n@Component({\n selector: 'axm-control-hierarchy-diagram-widget-edit',\n template: `\n <axm-control-hierarchy-diagram\n [viewType]=\"initialViewType()\"\n [highlightLevelId]=\"highlightLevelId()\"\n [showViewTypeSelector]=\"showViewTypeSelector()\"\n [showTitle]=\"showTitle()\"\n />\n `,\n host: {\n class: 'ax-block ax-w-full',\n },\n changeDetection: ChangeDetectionStrategy.OnPush,\n imports: [AXMControlHierarchyDiagramComponent],\n})\nexport class AXMControlHierarchyDiagramWidgetEditComponent extends AXPBaseWidgetComponent<AXMControlHierarchyDiagramWidgetOptions> {\n //#region ---- Computed Properties ----\n\n /** Designer/default initial layout only; runtime selection stays inside the diagram component. */\n protected initialViewType = computed<AXMControlHierarchyDiagramViewType>(() =>\n resolveControlHierarchyDiagramViewType(this.options()['viewType']),\n );\n\n protected showViewTypeSelector = computed(() => this.resolveShowViewTypeSelector());\n\n protected showTitle = computed(() => this.options()['showTitle'] === true);\n\n protected highlightLevelId = computed<string | null>(() => this.resolveHighlightLevelId());\n\n //#endregion\n\n //#region ---- Utility Methods ----\n\n private resolveShowViewTypeSelector(): boolean {\n const options = this.options();\n if (isBoolean(options['showViewTypeSelector'])) {\n return options['showViewTypeSelector'];\n }\n return true;\n }\n\n private resolveHighlightLevelId(): string | null {\n const options = this.options();\n const fromOptions = options['highlightLevelId'];\n if (isString(fromOptions) && fromOptions.length > 0) {\n return fromOptions;\n }\n this.contextService.changeEvent();\n const fromContext = get(this.contextService.data(), 'id');\n return isString(fromContext) ? fromContext : defaultTo(fromContext != null ? String(fromContext) : null, null);\n }\n\n //#endregion\n}\n\n//#endregion\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { AXPBaseWidgetComponent } from '@acorex/platform/layout/widget-core';
|
|
2
|
+
import * as i0 from '@angular/core';
|
|
3
|
+
import { computed, ChangeDetectionStrategy, Component } from '@angular/core';
|
|
4
|
+
import { isBoolean, isString, get, defaultTo } from 'lodash-es';
|
|
5
|
+
import { r as resolveControlHierarchyDiagramViewType, A as AXMControlHierarchyDiagramComponent } from './acorex-modules-workplacesafety-management-control-hierarchy-diagram.types-DmzV305e.mjs';
|
|
6
|
+
|
|
7
|
+
//#region ---- Imports ----
|
|
8
|
+
//#endregion
|
|
9
|
+
//#region ---- Widget View Component ----
|
|
10
|
+
class AXMControlHierarchyDiagramWidgetViewComponent extends AXPBaseWidgetComponent {
|
|
11
|
+
constructor() {
|
|
12
|
+
super(...arguments);
|
|
13
|
+
//#region ---- Computed Properties ----
|
|
14
|
+
/** Designer/default initial layout only; runtime selection stays inside the diagram component. */
|
|
15
|
+
this.initialViewType = computed(() => resolveControlHierarchyDiagramViewType(this.options()['viewType']), ...(ngDevMode ? [{ debugName: "initialViewType" }] : /* istanbul ignore next */ []));
|
|
16
|
+
this.showViewTypeSelector = computed(() => this.resolveShowViewTypeSelector(), ...(ngDevMode ? [{ debugName: "showViewTypeSelector" }] : /* istanbul ignore next */ []));
|
|
17
|
+
this.showTitle = computed(() => this.options()['showTitle'] === true, ...(ngDevMode ? [{ debugName: "showTitle" }] : /* istanbul ignore next */ []));
|
|
18
|
+
this.highlightLevelId = computed(() => this.resolveHighlightLevelId(), ...(ngDevMode ? [{ debugName: "highlightLevelId" }] : /* istanbul ignore next */ []));
|
|
19
|
+
}
|
|
20
|
+
//#endregion
|
|
21
|
+
//#region ---- Utility Methods ----
|
|
22
|
+
resolveShowViewTypeSelector() {
|
|
23
|
+
const options = this.options();
|
|
24
|
+
if (isBoolean(options['showViewTypeSelector'])) {
|
|
25
|
+
return options['showViewTypeSelector'];
|
|
26
|
+
}
|
|
27
|
+
return true;
|
|
28
|
+
}
|
|
29
|
+
resolveHighlightLevelId() {
|
|
30
|
+
const options = this.options();
|
|
31
|
+
const fromOptions = options['highlightLevelId'];
|
|
32
|
+
if (isString(fromOptions) && fromOptions.length > 0) {
|
|
33
|
+
return fromOptions;
|
|
34
|
+
}
|
|
35
|
+
this.contextService.changeEvent();
|
|
36
|
+
const fromContext = get(this.contextService.data(), 'id');
|
|
37
|
+
return isString(fromContext) ? fromContext : defaultTo(fromContext != null ? String(fromContext) : null, null);
|
|
38
|
+
}
|
|
39
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: AXMControlHierarchyDiagramWidgetViewComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
40
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "21.2.9", type: AXMControlHierarchyDiagramWidgetViewComponent, isStandalone: true, selector: "axm-control-hierarchy-diagram-widget-view", host: { classAttribute: "ax-block ax-w-full" }, usesInheritance: true, ngImport: i0, template: `
|
|
41
|
+
<axm-control-hierarchy-diagram
|
|
42
|
+
[viewType]="initialViewType()"
|
|
43
|
+
[highlightLevelId]="highlightLevelId()"
|
|
44
|
+
[showViewTypeSelector]="showViewTypeSelector()"
|
|
45
|
+
[showTitle]="showTitle()"
|
|
46
|
+
/>
|
|
47
|
+
`, isInline: true, dependencies: [{ kind: "component", type: AXMControlHierarchyDiagramComponent, selector: "axm-control-hierarchy-diagram", inputs: ["viewType", "items", "highlightLevelId", "showViewTypeSelector", "showTitle"], outputs: ["viewTypeChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
48
|
+
}
|
|
49
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: AXMControlHierarchyDiagramWidgetViewComponent, decorators: [{
|
|
50
|
+
type: Component,
|
|
51
|
+
args: [{
|
|
52
|
+
selector: 'axm-control-hierarchy-diagram-widget-view',
|
|
53
|
+
template: `
|
|
54
|
+
<axm-control-hierarchy-diagram
|
|
55
|
+
[viewType]="initialViewType()"
|
|
56
|
+
[highlightLevelId]="highlightLevelId()"
|
|
57
|
+
[showViewTypeSelector]="showViewTypeSelector()"
|
|
58
|
+
[showTitle]="showTitle()"
|
|
59
|
+
/>
|
|
60
|
+
`,
|
|
61
|
+
host: {
|
|
62
|
+
class: 'ax-block ax-w-full',
|
|
63
|
+
},
|
|
64
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
65
|
+
imports: [AXMControlHierarchyDiagramComponent],
|
|
66
|
+
}]
|
|
67
|
+
}] });
|
|
68
|
+
|
|
69
|
+
export { AXMControlHierarchyDiagramWidgetViewComponent };
|
|
70
|
+
//# sourceMappingURL=acorex-modules-workplacesafety-management-control-hierarchy-diagram-widget-view.component-DwC2aHVt.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"acorex-modules-workplacesafety-management-control-hierarchy-diagram-widget-view.component-DwC2aHVt.mjs","sources":["../../../../libs/modules/workplacesafety-management/src/lib/features/control-hierarchy-diagram/control-hierarchy-diagram-widget-view.component.ts"],"sourcesContent":["//#region ---- Imports ----\n\nimport { AXPBaseWidgetComponent } from '@acorex/platform/layout/widget-core';\nimport { ChangeDetectionStrategy, Component, computed } from '@angular/core';\nimport { defaultTo, get, isBoolean, isString } from 'lodash-es';\n\nimport { AXMControlHierarchyDiagramComponent } from './control-hierarchy-diagram.component';\nimport {\n resolveControlHierarchyDiagramViewType,\n type AXMControlHierarchyDiagramViewType,\n} from './control-hierarchy-diagram.types';\nimport { type AXMControlHierarchyDiagramWidgetOptions } from './control-hierarchy-diagram-widget.config';\n\n//#endregion\n\n//#region ---- Widget View Component ----\n\n@Component({\n selector: 'axm-control-hierarchy-diagram-widget-view',\n template: `\n <axm-control-hierarchy-diagram\n [viewType]=\"initialViewType()\"\n [highlightLevelId]=\"highlightLevelId()\"\n [showViewTypeSelector]=\"showViewTypeSelector()\"\n [showTitle]=\"showTitle()\"\n />\n `,\n host: {\n class: 'ax-block ax-w-full',\n },\n changeDetection: ChangeDetectionStrategy.OnPush,\n imports: [AXMControlHierarchyDiagramComponent],\n})\nexport class AXMControlHierarchyDiagramWidgetViewComponent extends AXPBaseWidgetComponent<AXMControlHierarchyDiagramWidgetOptions> {\n //#region ---- Computed Properties ----\n\n /** Designer/default initial layout only; runtime selection stays inside the diagram component. */\n protected initialViewType = computed<AXMControlHierarchyDiagramViewType>(() =>\n resolveControlHierarchyDiagramViewType(this.options()['viewType']),\n );\n\n protected showViewTypeSelector = computed(() => this.resolveShowViewTypeSelector());\n\n protected showTitle = computed(() => this.options()['showTitle'] === true);\n\n protected highlightLevelId = computed<string | null>(() => this.resolveHighlightLevelId());\n\n //#endregion\n\n //#region ---- Utility Methods ----\n\n private resolveShowViewTypeSelector(): boolean {\n const options = this.options();\n if (isBoolean(options['showViewTypeSelector'])) {\n return options['showViewTypeSelector'];\n }\n return true;\n }\n\n private resolveHighlightLevelId(): string | null {\n const options = this.options();\n const fromOptions = options['highlightLevelId'];\n if (isString(fromOptions) && fromOptions.length > 0) {\n return fromOptions;\n }\n this.contextService.changeEvent();\n const fromContext = get(this.contextService.data(), 'id');\n return isString(fromContext) ? fromContext : defaultTo(fromContext != null ? String(fromContext) : null, null);\n }\n\n //#endregion\n}\n\n//#endregion\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,195 @@
|
|
|
1
|
+
import * as i2 from '@acorex/components/select-box';
|
|
2
|
+
import { AXSelectBoxModule } from '@acorex/components/select-box';
|
|
3
|
+
import * as i3 from '@acorex/core/translation';
|
|
4
|
+
import { AXTranslationService, resolveMultiLanguageString, AXTranslationModule } from '@acorex/core/translation';
|
|
5
|
+
import { AsyncPipe } from '@angular/common';
|
|
6
|
+
import * as i0 from '@angular/core';
|
|
7
|
+
import { inject, Injectable, input, output, signal, computed, effect, ChangeDetectionStrategy, ViewEncapsulation, Component } from '@angular/core';
|
|
8
|
+
import * as i1 from '@angular/forms';
|
|
9
|
+
import { FormsModule } from '@angular/forms';
|
|
10
|
+
import { defaultTo, orderBy, isEmpty } from 'lodash-es';
|
|
11
|
+
import { AXPSystemStatusType } from '@acorex/platform/contracts';
|
|
12
|
+
import { AXPEntityService } from '@acorex/platform/layout/entity';
|
|
13
|
+
import { RootConfig } from './acorex-modules-workplacesafety-management.mjs';
|
|
14
|
+
|
|
15
|
+
//#region ---- Imports ----
|
|
16
|
+
//#endregion
|
|
17
|
+
//#region ---- Service ----
|
|
18
|
+
class AXMControlHierarchyDiagramService {
|
|
19
|
+
constructor() {
|
|
20
|
+
//#region ---- Services & Dependencies ----
|
|
21
|
+
this.entityService = inject(AXPEntityService);
|
|
22
|
+
this.translationService = inject(AXTranslationService);
|
|
23
|
+
}
|
|
24
|
+
//#endregion
|
|
25
|
+
//#region ---- Public API ----
|
|
26
|
+
async loadActiveLevels() {
|
|
27
|
+
const result = await this.entityService
|
|
28
|
+
.withEntity(RootConfig.module.name, RootConfig.entities.controlHierarchyLevels.name)
|
|
29
|
+
.data()
|
|
30
|
+
.query({
|
|
31
|
+
skip: 0,
|
|
32
|
+
take: 100,
|
|
33
|
+
filter: {
|
|
34
|
+
field: 'status',
|
|
35
|
+
operator: { type: 'equal' },
|
|
36
|
+
value: AXPSystemStatusType.Active,
|
|
37
|
+
},
|
|
38
|
+
sort: [{ field: 'effectivenessLevel', dir: 'desc' }],
|
|
39
|
+
});
|
|
40
|
+
const items = defaultTo(result.items, []);
|
|
41
|
+
return orderBy(items, ['effectivenessLevel'], ['desc']).map((item) => ({
|
|
42
|
+
id: item.id,
|
|
43
|
+
code: item.code,
|
|
44
|
+
title: item.title,
|
|
45
|
+
description: item.description,
|
|
46
|
+
effectivenessLevel: item.effectivenessLevel,
|
|
47
|
+
color: item.color,
|
|
48
|
+
}));
|
|
49
|
+
}
|
|
50
|
+
resolveText(value) {
|
|
51
|
+
const locale = this.translationService.getActiveLang();
|
|
52
|
+
return resolveMultiLanguageString(value, locale);
|
|
53
|
+
}
|
|
54
|
+
getContrastTextColor(color) {
|
|
55
|
+
if (!color) {
|
|
56
|
+
return 'rgb(var(--ax-sys-color-on-surface))';
|
|
57
|
+
}
|
|
58
|
+
const hex = color.replace('#', '');
|
|
59
|
+
if (hex.length !== 6) {
|
|
60
|
+
return 'rgb(var(--ax-sys-color-on-surface))';
|
|
61
|
+
}
|
|
62
|
+
const r = parseInt(hex.slice(0, 2), 16);
|
|
63
|
+
const g = parseInt(hex.slice(2, 4), 16);
|
|
64
|
+
const b = parseInt(hex.slice(4, 6), 16);
|
|
65
|
+
const luminance = (0.299 * r + 0.587 * g + 0.114 * b) / 255;
|
|
66
|
+
return luminance > 0.62 ? 'rgb(var(--ax-sys-color-on-light-surface))' : 'rgb(var(--ax-sys-color-on-dark-surface))';
|
|
67
|
+
}
|
|
68
|
+
getViewTypeOptions() {
|
|
69
|
+
return [
|
|
70
|
+
{
|
|
71
|
+
id: 'horizontal',
|
|
72
|
+
title: '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.view-types.horizontal',
|
|
73
|
+
},
|
|
74
|
+
{
|
|
75
|
+
id: 'vertical',
|
|
76
|
+
title: '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.view-types.vertical',
|
|
77
|
+
},
|
|
78
|
+
{
|
|
79
|
+
id: 'horizontal-chevron',
|
|
80
|
+
title: '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.view-types.horizontal-chevron',
|
|
81
|
+
},
|
|
82
|
+
];
|
|
83
|
+
}
|
|
84
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: AXMControlHierarchyDiagramService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
85
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: AXMControlHierarchyDiagramService, providedIn: 'root' }); }
|
|
86
|
+
}
|
|
87
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: AXMControlHierarchyDiagramService, decorators: [{
|
|
88
|
+
type: Injectable,
|
|
89
|
+
args: [{ providedIn: 'root' }]
|
|
90
|
+
}] });
|
|
91
|
+
|
|
92
|
+
//#region ---- Imports ----
|
|
93
|
+
//#endregion
|
|
94
|
+
//#region ---- Component ----
|
|
95
|
+
class AXMControlHierarchyDiagramComponent {
|
|
96
|
+
//#endregion
|
|
97
|
+
//#region ---- Lifecycle ----
|
|
98
|
+
ngOnInit() {
|
|
99
|
+
this.selectedViewType.set(this.viewType());
|
|
100
|
+
}
|
|
101
|
+
constructor() {
|
|
102
|
+
//#region ---- Services & Dependencies ----
|
|
103
|
+
this.diagramService = inject(AXMControlHierarchyDiagramService);
|
|
104
|
+
//#endregion
|
|
105
|
+
//#region ---- Inputs / Outputs ----
|
|
106
|
+
this.viewType = input('horizontal', ...(ngDevMode ? [{ debugName: "viewType" }] : /* istanbul ignore next */ []));
|
|
107
|
+
this.items = input(null, ...(ngDevMode ? [{ debugName: "items" }] : /* istanbul ignore next */ []));
|
|
108
|
+
this.highlightLevelId = input(null, ...(ngDevMode ? [{ debugName: "highlightLevelId" }] : /* istanbul ignore next */ []));
|
|
109
|
+
this.showViewTypeSelector = input(true, ...(ngDevMode ? [{ debugName: "showViewTypeSelector" }] : /* istanbul ignore next */ []));
|
|
110
|
+
this.showTitle = input(false, ...(ngDevMode ? [{ debugName: "showTitle" }] : /* istanbul ignore next */ []));
|
|
111
|
+
this.viewTypeChange = output();
|
|
112
|
+
//#endregion
|
|
113
|
+
//#region ---- State ----
|
|
114
|
+
this.loading = signal(false, ...(ngDevMode ? [{ debugName: "loading" }] : /* istanbul ignore next */ []));
|
|
115
|
+
this.loadedItems = signal([], ...(ngDevMode ? [{ debugName: "loadedItems" }] : /* istanbul ignore next */ []));
|
|
116
|
+
this.selectedViewType = signal('horizontal', ...(ngDevMode ? [{ debugName: "selectedViewType" }] : /* istanbul ignore next */ []));
|
|
117
|
+
this.viewTypeOptions = computed(() => this.diagramService.getViewTypeOptions(), ...(ngDevMode ? [{ debugName: "viewTypeOptions" }] : /* istanbul ignore next */ []));
|
|
118
|
+
this.displayItems = computed(() => {
|
|
119
|
+
const external = this.items();
|
|
120
|
+
const items = external ?? this.loadedItems();
|
|
121
|
+
return orderBy(items, ['effectivenessLevel'], ['desc']);
|
|
122
|
+
}, ...(ngDevMode ? [{ debugName: "displayItems" }] : /* istanbul ignore next */ []));
|
|
123
|
+
this.pyramidWidths = computed(() => {
|
|
124
|
+
const count = this.displayItems().length;
|
|
125
|
+
if (count <= 1) {
|
|
126
|
+
return [100];
|
|
127
|
+
}
|
|
128
|
+
const step = 70 / (count - 1);
|
|
129
|
+
return this.displayItems().map((_item, index) => 100 - index * step);
|
|
130
|
+
}, ...(ngDevMode ? [{ debugName: "pyramidWidths" }] : /* istanbul ignore next */ []));
|
|
131
|
+
effect(() => {
|
|
132
|
+
if (this.items() != null) {
|
|
133
|
+
return;
|
|
134
|
+
}
|
|
135
|
+
void this.loadItems();
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
//#endregion
|
|
139
|
+
//#region ---- UI Handlers ----
|
|
140
|
+
resolveTitle(item) {
|
|
141
|
+
return this.diagramService.resolveText(item.title);
|
|
142
|
+
}
|
|
143
|
+
resolveDescription(item) {
|
|
144
|
+
return defaultTo(this.diagramService.resolveText(item.description ?? ''), '');
|
|
145
|
+
}
|
|
146
|
+
resolveTextColor(item) {
|
|
147
|
+
return this.diagramService.getContrastTextColor(item.color);
|
|
148
|
+
}
|
|
149
|
+
isHighlighted(item) {
|
|
150
|
+
const highlightId = this.highlightLevelId();
|
|
151
|
+
return !isEmpty(highlightId) && item.id === highlightId;
|
|
152
|
+
}
|
|
153
|
+
onViewTypeChanged(value) {
|
|
154
|
+
if (!value) {
|
|
155
|
+
return;
|
|
156
|
+
}
|
|
157
|
+
this.selectedViewType.set(value);
|
|
158
|
+
this.viewTypeChange.emit(value);
|
|
159
|
+
}
|
|
160
|
+
//#endregion
|
|
161
|
+
//#region ---- Data Loading ----
|
|
162
|
+
async loadItems() {
|
|
163
|
+
this.loading.set(true);
|
|
164
|
+
try {
|
|
165
|
+
const levels = await this.diagramService.loadActiveLevels();
|
|
166
|
+
this.loadedItems.set(levels);
|
|
167
|
+
}
|
|
168
|
+
finally {
|
|
169
|
+
this.loading.set(false);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: AXMControlHierarchyDiagramComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
173
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.2.9", type: AXMControlHierarchyDiagramComponent, isStandalone: true, selector: "axm-control-hierarchy-diagram", inputs: { viewType: { classPropertyName: "viewType", publicName: "viewType", isSignal: true, isRequired: false, transformFunction: null }, items: { classPropertyName: "items", publicName: "items", isSignal: true, isRequired: false, transformFunction: null }, highlightLevelId: { classPropertyName: "highlightLevelId", publicName: "highlightLevelId", isSignal: true, isRequired: false, transformFunction: null }, showViewTypeSelector: { classPropertyName: "showViewTypeSelector", publicName: "showViewTypeSelector", isSignal: true, isRequired: false, transformFunction: null }, showTitle: { classPropertyName: "showTitle", publicName: "showTitle", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { viewTypeChange: "viewTypeChange" }, host: { classAttribute: "axm-control-hierarchy-diagram ax-block ax-w-full" }, ngImport: i0, template: "@if (showViewTypeSelector()) {\n <div class=\"axm-control-hierarchy-diagram__header\">\n <ax-select-box\n class=\"axm-control-hierarchy-diagram__view-type\"\n [dataSource]=\"viewTypeOptions()\"\n [ngModel]=\"selectedViewType()\"\n (ngModelChange)=\"onViewTypeChanged($event)\"\n valueField=\"id\"\n textField=\"title\"\n />\n </div>\n}\n\n@if (loading()) {\n <div class=\"axm-control-hierarchy-diagram__loading\">\n {{ '@general:terms.interface.loading' | translate | async }}\n </div>\n} @else if (!displayItems().length) {\n <div class=\"axm-control-hierarchy-diagram__empty\">\n {{ '@general:terms.interface.no-data' | translate | async }}\n </div>\n} @else {\n @switch (selectedViewType()) {\n @case ('horizontal') {\n <div class=\"axm-control-hierarchy-diagram__horizontal\">\n <div class=\"axm-control-hierarchy-diagram__effectiveness-bar\">\n <span>{{ '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.most-effective' | translate | async }}</span>\n <div class=\"axm-control-hierarchy-diagram__gradient\"></div>\n <span>{{ '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.least-effective' | translate | async }}</span>\n </div>\n <div class=\"axm-control-hierarchy-diagram__cards\">\n @for (item of displayItems(); track item.id; let index = $index) {\n <article\n class=\"axm-control-hierarchy-diagram__card\"\n [class.axm-control-hierarchy-diagram__card--highlighted]=\"isHighlighted(item)\"\n [style.border-top-color]=\"item.color\"\n >\n <header\n class=\"axm-control-hierarchy-diagram__card-header\"\n [style.background]=\"item.color\"\n [style.color]=\"resolveTextColor(item)\"\n >\n ({{ index + 1 }}) {{ resolveTitle(item) }}\n </header>\n <p class=\"axm-control-hierarchy-diagram__card-body\">\n {{ resolveDescription(item) }}\n </p>\n </article>\n }\n </div>\n </div>\n }\n @case ('vertical') {\n <div class=\"axm-control-hierarchy-diagram__vertical\">\n <div class=\"axm-control-hierarchy-diagram__vertical-label axm-control-hierarchy-diagram__vertical-label--top\">\n {{ '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.most-effective' | translate | async }}\n </div>\n <div class=\"axm-control-hierarchy-diagram__pyramid\">\n @for (item of displayItems(); track item.id; let index = $index) {\n <div\n class=\"axm-control-hierarchy-diagram__pyramid-row\"\n [class.axm-control-hierarchy-diagram__pyramid-row--highlighted]=\"isHighlighted(item)\"\n [style.background]=\"item.color\"\n [style.color]=\"resolveTextColor(item)\"\n [style.width.%]=\"pyramidWidths()[index]\"\n >\n {{ resolveTitle(item) }}\n </div>\n }\n </div>\n <div class=\"axm-control-hierarchy-diagram__vertical-label axm-control-hierarchy-diagram__vertical-label--bottom\">\n {{ '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.least-effective' | translate | async }}\n </div>\n </div>\n }\n @case ('horizontal-chevron') {\n <div class=\"axm-control-hierarchy-diagram__chevron\">\n <div class=\"axm-control-hierarchy-diagram__chevron-effective\">\n {{ '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.most-effective' | translate | async }}\n </div>\n <div class=\"axm-control-hierarchy-diagram__chevron-track\">\n @for (item of displayItems(); track item.id) {\n <div\n class=\"axm-control-hierarchy-diagram__chevron-segment\"\n [class.axm-control-hierarchy-diagram__chevron-segment--highlighted]=\"isHighlighted(item)\"\n [style.background]=\"item.color\"\n [style.color]=\"resolveTextColor(item)\"\n >\n {{ resolveTitle(item) }}\n </div>\n }\n </div>\n <div class=\"axm-control-hierarchy-diagram__chevron-effective axm-control-hierarchy-diagram__chevron-effective--end\">\n {{ '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.least-effective' | translate | async }}\n </div>\n </div>\n }\n }\n}\n", styles: [".axm-control-hierarchy-diagram{display:flex;flex-direction:column;gap:1rem}.axm-control-hierarchy-diagram__header{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:.75rem}.axm-control-hierarchy-diagram__title{margin:0;font-size:1.125rem;line-height:1.75rem;font-weight:600;color:rgb(var(--ax-sys-color-on-surface))}.axm-control-hierarchy-diagram__view-type{min-width:13rem}.axm-control-hierarchy-diagram__loading,.axm-control-hierarchy-diagram__empty{display:flex;align-items:center;justify-content:center;border-radius:.5rem;border-width:1px;padding:2rem;font-size:.875rem;line-height:1.25rem;background:rgb(var(--ax-sys-color-light-surface));border-color:rgb(var(--ax-sys-color-border-light-surface));color:rgb(var(--ax-sys-color-on-light-surface))}.axm-control-hierarchy-diagram__effectiveness-bar{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;font-size:.75rem;line-height:1rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;color:rgb(var(--ax-sys-color-on-light-surface))}.axm-control-hierarchy-diagram__gradient{height:.5rem;border-radius:9999px;background:linear-gradient(90deg,rgb(var(--ax-sys-color-primary-500)),rgb(var(--ax-sys-color-success-500)) 35%,rgb(var(--ax-sys-color-warning-500)) 65%,rgb(var(--ax-sys-color-danger-500)))}.axm-control-hierarchy-diagram__cards{display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.axm-control-hierarchy-diagram__card{overflow:hidden;border-radius:.5rem;border-width:1px;border-top-width:4px;background:rgb(var(--ax-sys-color-surface));border-color:rgb(var(--ax-sys-color-border-surface))}.axm-control-hierarchy-diagram__card--highlighted{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000);--tw-ring-offset-width: 2px;ring-color:rgb(var(--ax-sys-color-primary-500))}.axm-control-hierarchy-diagram__card-header{padding:.5rem .75rem;font-size:.875rem;line-height:1.25rem;font-weight:600}.axm-control-hierarchy-diagram__card-body{margin:0;padding:.75rem;font-size:.875rem;line-height:1.25rem;color:rgb(var(--ax-sys-color-on-surface))}.axm-control-hierarchy-diagram__vertical{display:flex;flex-direction:column;align-items:center;gap:.75rem}.axm-control-hierarchy-diagram__vertical-label{font-size:.875rem;line-height:1.25rem;font-weight:700;text-transform:uppercase;letter-spacing:.025em;color:rgb(var(--ax-sys-color-on-surface))}.axm-control-hierarchy-diagram__vertical-label--top{margin-bottom:.25rem}.axm-control-hierarchy-diagram__vertical-label--bottom{margin-top:.25rem}.axm-control-hierarchy-diagram__pyramid{display:flex;width:100%;max-width:48rem;flex-direction:column;align-items:center;gap:.25rem}.axm-control-hierarchy-diagram__pyramid-row{display:flex;min-height:2.75rem;align-items:center;justify-content:center;border-radius:.125rem;padding-left:1rem;padding-right:1rem;text-align:center;font-size:.875rem;line-height:1.25rem;font-weight:600}.axm-control-hierarchy-diagram__pyramid-row--highlighted{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000);--tw-ring-offset-width: 2px;ring-color:rgb(var(--ax-sys-color-primary-500))}.axm-control-hierarchy-diagram__chevron{display:flex;width:100%;flex-wrap:wrap;align-items:stretch;gap:.5rem}.axm-control-hierarchy-diagram__chevron-title{display:flex;min-height:3.5rem;min-width:10rem;align-items:center;justify-content:center;border-radius:.375rem;padding-left:1rem;padding-right:1rem;text-align:center;font-size:.75rem;line-height:1rem;font-weight:700;text-transform:uppercase;background:rgb(var(--ax-sys-color-primary-700));color:rgb(var(--ax-sys-color-on-primary-700))}.axm-control-hierarchy-diagram__chevron-effective{display:flex;min-height:3.5rem;min-width:7rem;align-items:center;justify-content:center;border-radius:.375rem;border-width:1px;padding-left:.75rem;padding-right:.75rem;text-align:center;font-size:.75rem;line-height:1rem;font-weight:700;text-transform:uppercase;background:rgb(var(--ax-sys-color-surface));border-color:rgb(var(--ax-sys-color-border-surface));color:rgb(var(--ax-sys-color-on-surface))}.axm-control-hierarchy-diagram__chevron-effective--end{margin-left:auto}.axm-control-hierarchy-diagram__chevron-track{display:flex;min-height:3.5rem;flex:1 1 0%;flex-wrap:wrap;align-items:stretch;gap:0px;overflow:hidden;border-radius:.375rem}.axm-control-hierarchy-diagram__chevron-segment{position:relative;display:flex;min-height:3.5rem;min-width:6rem;flex:1 1 0%;align-items:center;justify-content:center;padding-left:1rem;padding-right:1rem;text-align:center;font-size:.75rem;line-height:1rem;font-weight:600;clip-path:polygon(0 0,calc(100% - 14px) 0,100% 50%,calc(100% - 14px) 100%,0 100%,14px 50%)}.axm-control-hierarchy-diagram__chevron-segment--highlighted{z-index:10;--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000);--tw-ring-offset-width: 1px;ring-color:rgb(var(--ax-sys-color-primary-500))}.axm-control-hierarchy-diagram__chevron-segment:first-child{clip-path:polygon(0 0,calc(100% - 14px) 0,100% 50%,calc(100% - 14px) 100%,0 100%)}.axm-control-hierarchy-diagram__chevron-segment:last-child{clip-path:polygon(0 0,100% 0,100% 100%,0 100%,14px 50%)}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: AXSelectBoxModule }, { kind: "component", type: i2.AXSelectBoxComponent, selector: "ax-select-box", inputs: ["disabled", "readonly", "tabIndex", "placeholder", "minValue", "maxValue", "value", "state", "name", "id", "type", "look", "multiple", "valueField", "textField", "disabledField", "textTemplate", "selectedItems", "isItemTruncated", "showItemTooltip", "itemHeight", "maxVisibleItems", "dataSource", "minRecordsForSearch", "caption", "itemTemplate", "selectedTemplate", "emptyTemplate", "loadingTemplate", "dropdownWidth", "searchBoxAutoFocus"], outputs: ["valueChange", "stateChange", "onValueChanged", "onBlur", "onFocus", "readonlyChange", "disabledChange", "onOpened", "onClosed", "onItemSelected", "onItemClick"] }, { kind: "ngmodule", type: AXTranslationModule }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "pipe", type: i3.AXTranslatorPipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
174
|
+
}
|
|
175
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.9", ngImport: i0, type: AXMControlHierarchyDiagramComponent, decorators: [{
|
|
176
|
+
type: Component,
|
|
177
|
+
args: [{ selector: 'axm-control-hierarchy-diagram', host: {
|
|
178
|
+
class: 'axm-control-hierarchy-diagram ax-block ax-w-full',
|
|
179
|
+
}, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, imports: [AsyncPipe, FormsModule, AXSelectBoxModule, AXTranslationModule], template: "@if (showViewTypeSelector()) {\n <div class=\"axm-control-hierarchy-diagram__header\">\n <ax-select-box\n class=\"axm-control-hierarchy-diagram__view-type\"\n [dataSource]=\"viewTypeOptions()\"\n [ngModel]=\"selectedViewType()\"\n (ngModelChange)=\"onViewTypeChanged($event)\"\n valueField=\"id\"\n textField=\"title\"\n />\n </div>\n}\n\n@if (loading()) {\n <div class=\"axm-control-hierarchy-diagram__loading\">\n {{ '@general:terms.interface.loading' | translate | async }}\n </div>\n} @else if (!displayItems().length) {\n <div class=\"axm-control-hierarchy-diagram__empty\">\n {{ '@general:terms.interface.no-data' | translate | async }}\n </div>\n} @else {\n @switch (selectedViewType()) {\n @case ('horizontal') {\n <div class=\"axm-control-hierarchy-diagram__horizontal\">\n <div class=\"axm-control-hierarchy-diagram__effectiveness-bar\">\n <span>{{ '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.most-effective' | translate | async }}</span>\n <div class=\"axm-control-hierarchy-diagram__gradient\"></div>\n <span>{{ '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.least-effective' | translate | async }}</span>\n </div>\n <div class=\"axm-control-hierarchy-diagram__cards\">\n @for (item of displayItems(); track item.id; let index = $index) {\n <article\n class=\"axm-control-hierarchy-diagram__card\"\n [class.axm-control-hierarchy-diagram__card--highlighted]=\"isHighlighted(item)\"\n [style.border-top-color]=\"item.color\"\n >\n <header\n class=\"axm-control-hierarchy-diagram__card-header\"\n [style.background]=\"item.color\"\n [style.color]=\"resolveTextColor(item)\"\n >\n ({{ index + 1 }}) {{ resolveTitle(item) }}\n </header>\n <p class=\"axm-control-hierarchy-diagram__card-body\">\n {{ resolveDescription(item) }}\n </p>\n </article>\n }\n </div>\n </div>\n }\n @case ('vertical') {\n <div class=\"axm-control-hierarchy-diagram__vertical\">\n <div class=\"axm-control-hierarchy-diagram__vertical-label axm-control-hierarchy-diagram__vertical-label--top\">\n {{ '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.most-effective' | translate | async }}\n </div>\n <div class=\"axm-control-hierarchy-diagram__pyramid\">\n @for (item of displayItems(); track item.id; let index = $index) {\n <div\n class=\"axm-control-hierarchy-diagram__pyramid-row\"\n [class.axm-control-hierarchy-diagram__pyramid-row--highlighted]=\"isHighlighted(item)\"\n [style.background]=\"item.color\"\n [style.color]=\"resolveTextColor(item)\"\n [style.width.%]=\"pyramidWidths()[index]\"\n >\n {{ resolveTitle(item) }}\n </div>\n }\n </div>\n <div class=\"axm-control-hierarchy-diagram__vertical-label axm-control-hierarchy-diagram__vertical-label--bottom\">\n {{ '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.least-effective' | translate | async }}\n </div>\n </div>\n }\n @case ('horizontal-chevron') {\n <div class=\"axm-control-hierarchy-diagram__chevron\">\n <div class=\"axm-control-hierarchy-diagram__chevron-effective\">\n {{ '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.most-effective' | translate | async }}\n </div>\n <div class=\"axm-control-hierarchy-diagram__chevron-track\">\n @for (item of displayItems(); track item.id) {\n <div\n class=\"axm-control-hierarchy-diagram__chevron-segment\"\n [class.axm-control-hierarchy-diagram__chevron-segment--highlighted]=\"isHighlighted(item)\"\n [style.background]=\"item.color\"\n [style.color]=\"resolveTextColor(item)\"\n >\n {{ resolveTitle(item) }}\n </div>\n }\n </div>\n <div class=\"axm-control-hierarchy-diagram__chevron-effective axm-control-hierarchy-diagram__chevron-effective--end\">\n {{ '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.least-effective' | translate | async }}\n </div>\n </div>\n }\n }\n}\n", styles: [".axm-control-hierarchy-diagram{display:flex;flex-direction:column;gap:1rem}.axm-control-hierarchy-diagram__header{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:.75rem}.axm-control-hierarchy-diagram__title{margin:0;font-size:1.125rem;line-height:1.75rem;font-weight:600;color:rgb(var(--ax-sys-color-on-surface))}.axm-control-hierarchy-diagram__view-type{min-width:13rem}.axm-control-hierarchy-diagram__loading,.axm-control-hierarchy-diagram__empty{display:flex;align-items:center;justify-content:center;border-radius:.5rem;border-width:1px;padding:2rem;font-size:.875rem;line-height:1.25rem;background:rgb(var(--ax-sys-color-light-surface));border-color:rgb(var(--ax-sys-color-border-light-surface));color:rgb(var(--ax-sys-color-on-light-surface))}.axm-control-hierarchy-diagram__effectiveness-bar{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;font-size:.75rem;line-height:1rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;color:rgb(var(--ax-sys-color-on-light-surface))}.axm-control-hierarchy-diagram__gradient{height:.5rem;border-radius:9999px;background:linear-gradient(90deg,rgb(var(--ax-sys-color-primary-500)),rgb(var(--ax-sys-color-success-500)) 35%,rgb(var(--ax-sys-color-warning-500)) 65%,rgb(var(--ax-sys-color-danger-500)))}.axm-control-hierarchy-diagram__cards{display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.axm-control-hierarchy-diagram__card{overflow:hidden;border-radius:.5rem;border-width:1px;border-top-width:4px;background:rgb(var(--ax-sys-color-surface));border-color:rgb(var(--ax-sys-color-border-surface))}.axm-control-hierarchy-diagram__card--highlighted{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000);--tw-ring-offset-width: 2px;ring-color:rgb(var(--ax-sys-color-primary-500))}.axm-control-hierarchy-diagram__card-header{padding:.5rem .75rem;font-size:.875rem;line-height:1.25rem;font-weight:600}.axm-control-hierarchy-diagram__card-body{margin:0;padding:.75rem;font-size:.875rem;line-height:1.25rem;color:rgb(var(--ax-sys-color-on-surface))}.axm-control-hierarchy-diagram__vertical{display:flex;flex-direction:column;align-items:center;gap:.75rem}.axm-control-hierarchy-diagram__vertical-label{font-size:.875rem;line-height:1.25rem;font-weight:700;text-transform:uppercase;letter-spacing:.025em;color:rgb(var(--ax-sys-color-on-surface))}.axm-control-hierarchy-diagram__vertical-label--top{margin-bottom:.25rem}.axm-control-hierarchy-diagram__vertical-label--bottom{margin-top:.25rem}.axm-control-hierarchy-diagram__pyramid{display:flex;width:100%;max-width:48rem;flex-direction:column;align-items:center;gap:.25rem}.axm-control-hierarchy-diagram__pyramid-row{display:flex;min-height:2.75rem;align-items:center;justify-content:center;border-radius:.125rem;padding-left:1rem;padding-right:1rem;text-align:center;font-size:.875rem;line-height:1.25rem;font-weight:600}.axm-control-hierarchy-diagram__pyramid-row--highlighted{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000);--tw-ring-offset-width: 2px;ring-color:rgb(var(--ax-sys-color-primary-500))}.axm-control-hierarchy-diagram__chevron{display:flex;width:100%;flex-wrap:wrap;align-items:stretch;gap:.5rem}.axm-control-hierarchy-diagram__chevron-title{display:flex;min-height:3.5rem;min-width:10rem;align-items:center;justify-content:center;border-radius:.375rem;padding-left:1rem;padding-right:1rem;text-align:center;font-size:.75rem;line-height:1rem;font-weight:700;text-transform:uppercase;background:rgb(var(--ax-sys-color-primary-700));color:rgb(var(--ax-sys-color-on-primary-700))}.axm-control-hierarchy-diagram__chevron-effective{display:flex;min-height:3.5rem;min-width:7rem;align-items:center;justify-content:center;border-radius:.375rem;border-width:1px;padding-left:.75rem;padding-right:.75rem;text-align:center;font-size:.75rem;line-height:1rem;font-weight:700;text-transform:uppercase;background:rgb(var(--ax-sys-color-surface));border-color:rgb(var(--ax-sys-color-border-surface));color:rgb(var(--ax-sys-color-on-surface))}.axm-control-hierarchy-diagram__chevron-effective--end{margin-left:auto}.axm-control-hierarchy-diagram__chevron-track{display:flex;min-height:3.5rem;flex:1 1 0%;flex-wrap:wrap;align-items:stretch;gap:0px;overflow:hidden;border-radius:.375rem}.axm-control-hierarchy-diagram__chevron-segment{position:relative;display:flex;min-height:3.5rem;min-width:6rem;flex:1 1 0%;align-items:center;justify-content:center;padding-left:1rem;padding-right:1rem;text-align:center;font-size:.75rem;line-height:1rem;font-weight:600;clip-path:polygon(0 0,calc(100% - 14px) 0,100% 50%,calc(100% - 14px) 100%,0 100%,14px 50%)}.axm-control-hierarchy-diagram__chevron-segment--highlighted{z-index:10;--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000);--tw-ring-offset-width: 1px;ring-color:rgb(var(--ax-sys-color-primary-500))}.axm-control-hierarchy-diagram__chevron-segment:first-child{clip-path:polygon(0 0,calc(100% - 14px) 0,100% 50%,calc(100% - 14px) 100%,0 100%)}.axm-control-hierarchy-diagram__chevron-segment:last-child{clip-path:polygon(0 0,100% 0,100% 100%,0 100%,14px 50%)}\n"] }]
|
|
180
|
+
}], ctorParameters: () => [], propDecorators: { viewType: [{ type: i0.Input, args: [{ isSignal: true, alias: "viewType", required: false }] }], items: [{ type: i0.Input, args: [{ isSignal: true, alias: "items", required: false }] }], highlightLevelId: [{ type: i0.Input, args: [{ isSignal: true, alias: "highlightLevelId", required: false }] }], showViewTypeSelector: [{ type: i0.Input, args: [{ isSignal: true, alias: "showViewTypeSelector", required: false }] }], showTitle: [{ type: i0.Input, args: [{ isSignal: true, alias: "showTitle", required: false }] }], viewTypeChange: [{ type: i0.Output, args: ["viewTypeChange"] }] } });
|
|
181
|
+
|
|
182
|
+
//#region ---- Imports ----
|
|
183
|
+
function resolveControlHierarchyDiagramViewType(value) {
|
|
184
|
+
if (!value) {
|
|
185
|
+
return 'horizontal';
|
|
186
|
+
}
|
|
187
|
+
if (typeof value === 'string') {
|
|
188
|
+
return value;
|
|
189
|
+
}
|
|
190
|
+
return value.id ?? 'horizontal';
|
|
191
|
+
}
|
|
192
|
+
//#endregion
|
|
193
|
+
|
|
194
|
+
export { AXMControlHierarchyDiagramComponent as A, resolveControlHierarchyDiagramViewType as r };
|
|
195
|
+
//# sourceMappingURL=acorex-modules-workplacesafety-management-control-hierarchy-diagram.types-DmzV305e.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"acorex-modules-workplacesafety-management-control-hierarchy-diagram.types-DmzV305e.mjs","sources":["../../../../libs/modules/workplacesafety-management/src/lib/features/control-hierarchy-diagram/control-hierarchy-diagram.service.ts","../../../../libs/modules/workplacesafety-management/src/lib/features/control-hierarchy-diagram/control-hierarchy-diagram.component.ts","../../../../libs/modules/workplacesafety-management/src/lib/features/control-hierarchy-diagram/control-hierarchy-diagram.component.html","../../../../libs/modules/workplacesafety-management/src/lib/features/control-hierarchy-diagram/control-hierarchy-diagram.types.ts"],"sourcesContent":["//#region ---- Imports ----\n\nimport { AXTranslationService, resolveMultiLanguageString } from '@acorex/core/translation';\nimport { AXPSystemStatusType } from '@acorex/platform/contracts';\nimport { AXPEntityService } from '@acorex/platform/layout/entity';\nimport { Injectable, inject } from '@angular/core';\nimport { defaultTo, orderBy } from 'lodash-es';\n\nimport { RootConfig } from '../../contracts';\nimport { type AXMWorkplaceSafetyManagementControlHierarchyLevelsEntityModel } from '../../entities/control-hierarchy-levels/control-hierarchy-levels.types';\nimport {\n type AXMControlHierarchyDiagramItem,\n type AXMControlHierarchyDiagramViewType,\n} from './control-hierarchy-diagram.types';\n\n//#endregion\n\n//#region ---- Service ----\n\n@Injectable({ providedIn: 'root' })\nexport class AXMControlHierarchyDiagramService {\n //#region ---- Services & Dependencies ----\n\n private readonly entityService = inject(AXPEntityService);\n private readonly translationService = inject(AXTranslationService);\n\n //#endregion\n\n //#region ---- Public API ----\n\n async loadActiveLevels(): Promise<AXMControlHierarchyDiagramItem[]> {\n const result = await this.entityService\n .withEntity(RootConfig.module.name, RootConfig.entities.controlHierarchyLevels.name)\n .data<string, AXMWorkplaceSafetyManagementControlHierarchyLevelsEntityModel>()\n .query({\n skip: 0,\n take: 100,\n filter: {\n field: 'status',\n operator: { type: 'equal' },\n value: AXPSystemStatusType.Active,\n },\n sort: [{ field: 'effectivenessLevel', dir: 'desc' }],\n });\n\n const items = defaultTo(result.items, []);\n return orderBy(items, ['effectivenessLevel'], ['desc']).map((item) => ({\n id: item.id,\n code: item.code,\n title: item.title,\n description: item.description,\n effectivenessLevel: item.effectivenessLevel,\n color: item.color,\n }));\n }\n\n resolveText(value: AXMControlHierarchyDiagramItem['title']): string {\n const locale = this.translationService.getActiveLang();\n return resolveMultiLanguageString(value, locale);\n }\n\n getContrastTextColor(color?: string): string {\n if (!color) {\n return 'rgb(var(--ax-sys-color-on-surface))';\n }\n const hex = color.replace('#', '');\n if (hex.length !== 6) {\n return 'rgb(var(--ax-sys-color-on-surface))';\n }\n const r = parseInt(hex.slice(0, 2), 16);\n const g = parseInt(hex.slice(2, 4), 16);\n const b = parseInt(hex.slice(4, 6), 16);\n const luminance = (0.299 * r + 0.587 * g + 0.114 * b) / 255;\n return luminance > 0.62 ? 'rgb(var(--ax-sys-color-on-light-surface))' : 'rgb(var(--ax-sys-color-on-dark-surface))';\n }\n\n getViewTypeOptions(): Array<{ id: AXMControlHierarchyDiagramViewType; title: string }> {\n return [\n {\n id: 'horizontal',\n title: '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.view-types.horizontal',\n },\n {\n id: 'vertical',\n title: '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.view-types.vertical',\n },\n {\n id: 'horizontal-chevron',\n title:\n '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.view-types.horizontal-chevron',\n },\n ];\n }\n\n //#endregion\n}\n\n//#endregion\n","//#region ---- Imports ----\n\nimport { AXSelectBoxModule } from '@acorex/components/select-box';\nimport { AXTranslationModule } from '@acorex/core/translation';\nimport { AsyncPipe } from '@angular/common';\nimport {\n ChangeDetectionStrategy,\n Component,\n computed,\n effect,\n inject,\n input,\n OnInit,\n output,\n signal,\n ViewEncapsulation,\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { defaultTo, isEmpty, orderBy } from 'lodash-es';\n\nimport {\n type AXMControlHierarchyDiagramItem,\n type AXMControlHierarchyDiagramViewType,\n} from './control-hierarchy-diagram.types';\nimport { AXMControlHierarchyDiagramService } from './control-hierarchy-diagram.service';\n\n//#endregion\n\n//#region ---- Component ----\n\n@Component({\n selector: 'axm-control-hierarchy-diagram',\n templateUrl: './control-hierarchy-diagram.component.html',\n styleUrl: './control-hierarchy-diagram.component.scss',\n host: {\n class: 'axm-control-hierarchy-diagram ax-block ax-w-full',\n },\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n imports: [AsyncPipe, FormsModule, AXSelectBoxModule, AXTranslationModule],\n})\nexport class AXMControlHierarchyDiagramComponent implements OnInit {\n //#region ---- Services & Dependencies ----\n\n protected readonly diagramService = inject(AXMControlHierarchyDiagramService);\n\n //#endregion\n\n //#region ---- Inputs / Outputs ----\n\n viewType = input<AXMControlHierarchyDiagramViewType>('horizontal');\n items = input<AXMControlHierarchyDiagramItem[] | null>(null);\n highlightLevelId = input<string | null>(null);\n showViewTypeSelector = input(true);\n showTitle = input(false);\n\n viewTypeChange = output<AXMControlHierarchyDiagramViewType>();\n\n //#endregion\n\n //#region ---- State ----\n\n protected readonly loading = signal(false);\n protected readonly loadedItems = signal<AXMControlHierarchyDiagramItem[]>([]);\n protected readonly selectedViewType = signal<AXMControlHierarchyDiagramViewType>('horizontal');\n\n protected readonly viewTypeOptions = computed(() => this.diagramService.getViewTypeOptions());\n\n protected readonly displayItems = computed(() => {\n const external = this.items();\n const items = external ?? this.loadedItems();\n return orderBy(items, ['effectivenessLevel'], ['desc']);\n });\n\n protected readonly pyramidWidths = computed(() => {\n const count = this.displayItems().length;\n if (count <= 1) {\n return [100];\n }\n const step = 70 / (count - 1);\n return this.displayItems().map((_item, index) => 100 - index * step);\n });\n\n //#endregion\n\n //#region ---- Lifecycle ----\n\n ngOnInit(): void {\n this.selectedViewType.set(this.viewType());\n }\n\n constructor() {\n effect(() => {\n if (this.items() != null) {\n return;\n }\n void this.loadItems();\n });\n }\n\n //#endregion\n\n //#region ---- UI Handlers ----\n\n protected resolveTitle(item: AXMControlHierarchyDiagramItem): string {\n return this.diagramService.resolveText(item.title);\n }\n\n protected resolveDescription(item: AXMControlHierarchyDiagramItem): string {\n return defaultTo(this.diagramService.resolveText(item.description ?? ''), '');\n }\n\n protected resolveTextColor(item: AXMControlHierarchyDiagramItem): string {\n return this.diagramService.getContrastTextColor(item.color);\n }\n\n protected isHighlighted(item: AXMControlHierarchyDiagramItem): boolean {\n const highlightId = this.highlightLevelId();\n return !isEmpty(highlightId) && item.id === highlightId;\n }\n\n protected onViewTypeChanged(value: AXMControlHierarchyDiagramViewType | null): void {\n if (!value) {\n return;\n }\n this.selectedViewType.set(value);\n this.viewTypeChange.emit(value);\n }\n\n //#endregion\n\n //#region ---- Data Loading ----\n\n private async loadItems(): Promise<void> {\n this.loading.set(true);\n try {\n const levels = await this.diagramService.loadActiveLevels();\n this.loadedItems.set(levels);\n } finally {\n this.loading.set(false);\n }\n }\n\n //#endregion\n}\n\n//#endregion\n","@if (showViewTypeSelector()) {\n <div class=\"axm-control-hierarchy-diagram__header\">\n <ax-select-box\n class=\"axm-control-hierarchy-diagram__view-type\"\n [dataSource]=\"viewTypeOptions()\"\n [ngModel]=\"selectedViewType()\"\n (ngModelChange)=\"onViewTypeChanged($event)\"\n valueField=\"id\"\n textField=\"title\"\n />\n </div>\n}\n\n@if (loading()) {\n <div class=\"axm-control-hierarchy-diagram__loading\">\n {{ '@general:terms.interface.loading' | translate | async }}\n </div>\n} @else if (!displayItems().length) {\n <div class=\"axm-control-hierarchy-diagram__empty\">\n {{ '@general:terms.interface.no-data' | translate | async }}\n </div>\n} @else {\n @switch (selectedViewType()) {\n @case ('horizontal') {\n <div class=\"axm-control-hierarchy-diagram__horizontal\">\n <div class=\"axm-control-hierarchy-diagram__effectiveness-bar\">\n <span>{{ '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.most-effective' | translate | async }}</span>\n <div class=\"axm-control-hierarchy-diagram__gradient\"></div>\n <span>{{ '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.least-effective' | translate | async }}</span>\n </div>\n <div class=\"axm-control-hierarchy-diagram__cards\">\n @for (item of displayItems(); track item.id; let index = $index) {\n <article\n class=\"axm-control-hierarchy-diagram__card\"\n [class.axm-control-hierarchy-diagram__card--highlighted]=\"isHighlighted(item)\"\n [style.border-top-color]=\"item.color\"\n >\n <header\n class=\"axm-control-hierarchy-diagram__card-header\"\n [style.background]=\"item.color\"\n [style.color]=\"resolveTextColor(item)\"\n >\n ({{ index + 1 }}) {{ resolveTitle(item) }}\n </header>\n <p class=\"axm-control-hierarchy-diagram__card-body\">\n {{ resolveDescription(item) }}\n </p>\n </article>\n }\n </div>\n </div>\n }\n @case ('vertical') {\n <div class=\"axm-control-hierarchy-diagram__vertical\">\n <div class=\"axm-control-hierarchy-diagram__vertical-label axm-control-hierarchy-diagram__vertical-label--top\">\n {{ '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.most-effective' | translate | async }}\n </div>\n <div class=\"axm-control-hierarchy-diagram__pyramid\">\n @for (item of displayItems(); track item.id; let index = $index) {\n <div\n class=\"axm-control-hierarchy-diagram__pyramid-row\"\n [class.axm-control-hierarchy-diagram__pyramid-row--highlighted]=\"isHighlighted(item)\"\n [style.background]=\"item.color\"\n [style.color]=\"resolveTextColor(item)\"\n [style.width.%]=\"pyramidWidths()[index]\"\n >\n {{ resolveTitle(item) }}\n </div>\n }\n </div>\n <div class=\"axm-control-hierarchy-diagram__vertical-label axm-control-hierarchy-diagram__vertical-label--bottom\">\n {{ '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.least-effective' | translate | async }}\n </div>\n </div>\n }\n @case ('horizontal-chevron') {\n <div class=\"axm-control-hierarchy-diagram__chevron\">\n <div class=\"axm-control-hierarchy-diagram__chevron-effective\">\n {{ '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.most-effective' | translate | async }}\n </div>\n <div class=\"axm-control-hierarchy-diagram__chevron-track\">\n @for (item of displayItems(); track item.id) {\n <div\n class=\"axm-control-hierarchy-diagram__chevron-segment\"\n [class.axm-control-hierarchy-diagram__chevron-segment--highlighted]=\"isHighlighted(item)\"\n [style.background]=\"item.color\"\n [style.color]=\"resolveTextColor(item)\"\n >\n {{ resolveTitle(item) }}\n </div>\n }\n </div>\n <div class=\"axm-control-hierarchy-diagram__chevron-effective axm-control-hierarchy-diagram__chevron-effective--end\">\n {{ '@workplacesafety-management:control-measure-types.components.control-hierarchy-diagram.least-effective' | translate | async }}\n </div>\n </div>\n }\n }\n}\n","//#region ---- Imports ----\n\nimport { type AXPMultiLanguageString } from '@acorex/platform/contracts';\n\n//#endregion\n\n//#region ---- View types ----\n\nexport type AXMControlHierarchyDiagramViewType = 'vertical' | 'horizontal' | 'horizontal-chevron';\n\nexport type AXMControlHierarchyDiagramViewTypeOption =\n | AXMControlHierarchyDiagramViewType\n | { id: AXMControlHierarchyDiagramViewType; title?: string };\n\nexport function resolveControlHierarchyDiagramViewType(\n value: AXMControlHierarchyDiagramViewTypeOption | undefined,\n): AXMControlHierarchyDiagramViewType {\n if (!value) {\n return 'horizontal';\n }\n if (typeof value === 'string') {\n return value;\n }\n return value.id ?? 'horizontal';\n}\n\n//#endregion\n\n//#region ---- Diagram item ----\n\nexport interface AXMControlHierarchyDiagramItem {\n id: string;\n code: string;\n title: AXPMultiLanguageString;\n description?: AXPMultiLanguageString;\n effectivenessLevel: number;\n color?: string;\n}\n\n//#endregion\n"],"names":[],"mappings":"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"}
|