@agorapulse/ui-components 18.0.13 → 18.0.15
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/agorapulse-ui-components-18.0.15.tgz +0 -0
- package/avatar/avatar.component.d.ts +1 -1
- package/checkbox/checkbox.component.d.ts +1 -1
- package/esm2022/add-comment/add-comment.component.mjs +3 -3
- package/esm2022/checkbox/checkbox.component.mjs +5 -4
- package/esm2022/datepicker/datepicker.component.mjs +3 -3
- package/esm2022/labels/label-list.component.mjs +3 -3
- package/esm2022/labels-selector/labels-selector.component.mjs +3 -3
- package/esm2022/media-display-overlay/media-display-overlay-dialog.component.mjs +3 -3
- package/esm2022/modal/modal.component.mjs +3 -3
- package/esm2022/nav-selector/directives/nav-selector-popover-trigger.directive.mjs +71 -0
- package/esm2022/nav-selector/nav-selector-category/nav-selector-category.component.mjs +15 -12
- package/esm2022/nav-selector/nav-selector-group/nav-selector-group.component.mjs +17 -14
- package/esm2022/nav-selector/nav-selector-leaf/nav-selector-leaf.component.mjs +38 -94
- package/esm2022/nav-selector/nav-selector-leaf/nav-selector-leaf.presenter.mjs +2 -2
- package/esm2022/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.component.mjs +6 -6
- package/esm2022/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.component.mjs +12 -9
- package/esm2022/nav-selector/nav-selector-popover/nav-selector-popover-item.component.mjs +14 -0
- package/esm2022/nav-selector/nav-selector-popover/nav-selector-popover.component.mjs +127 -0
- package/esm2022/nav-selector/nav-selector.component.mjs +45 -23
- package/esm2022/nav-selector/nav-selector.mjs +1 -1
- package/esm2022/nav-selector/nav-selector.state.mjs +35 -11
- package/esm2022/nav-selector/utils/leaf.utils.mjs +12 -3
- package/esm2022/nav-selector/utils/nav-selector.accessibility.mjs +22 -14
- package/esm2022/nav-selector/utils/nav-selector.builder.mjs +4 -2
- package/esm2022/nav-selector/utils/nav-selector.filter.mjs +49 -11
- package/esm2022/nav-selector/utils/nav-selector.folding.mjs +26 -23
- package/esm2022/nav-selector/utils/nav-selector.merger.mjs +76 -0
- package/esm2022/nav-selector/utils/nav-selector.minifying.mjs +14 -9
- package/esm2022/nav-selector/utils/nav-selector.multi-select.mjs +2 -2
- package/esm2022/nav-selector/utils/nav-selector.single-select.mjs +46 -23
- package/esm2022/neo-datepicker/neo-datepicker.component.mjs +3 -3
- package/esm2022/notification/notification.component.mjs +3 -3
- package/esm2022/paginator/paginator-button/paginator-button.component.mjs +2 -2
- package/esm2022/password-input/password-input.component.mjs +3 -3
- package/esm2022/popmenu/popmenu.component.mjs +3 -3
- package/esm2022/slide-toggle/slide-toggle.component.mjs +3 -3
- package/esm2022/snackbars-thread/component/snackbars-thread.component.mjs +3 -3
- package/esm2022/stepper/stepper.component.mjs +3 -3
- package/fesm2022/agorapulse-ui-components-add-comment.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-add-comment.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-checkbox.mjs +4 -3
- package/fesm2022/agorapulse-ui-components-checkbox.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-datepicker.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-datepicker.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-labels-selector.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-labels-selector.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-labels.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-labels.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-media-display-overlay.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-media-display-overlay.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-modal.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-modal.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-nav-selector.mjs +599 -238
- package/fesm2022/agorapulse-ui-components-nav-selector.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-neo-datepicker.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-neo-datepicker.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-notification.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-notification.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-paginator.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-paginator.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-password-input.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-password-input.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-popmenu.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-popmenu.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-slide-toggle.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-slide-toggle.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-snackbars-thread.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-snackbars-thread.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-stepper.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-stepper.mjs.map +1 -1
- package/nav-selector/directives/nav-selector-popover-trigger.directive.d.ts +25 -0
- package/nav-selector/nav-selector-group/nav-selector-group.component.d.ts +1 -1
- package/nav-selector/nav-selector-leaf/nav-selector-leaf.component.d.ts +5 -20
- package/nav-selector/nav-selector-leaf/nav-selector-leaf.presenter.d.ts +1 -1
- package/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.component.d.ts +1 -1
- package/nav-selector/nav-selector-popover/nav-selector-popover-item.component.d.ts +6 -0
- package/nav-selector/nav-selector-popover/nav-selector-popover.component.d.ts +39 -0
- package/nav-selector/nav-selector.component.d.ts +6 -4
- package/nav-selector/nav-selector.d.ts +6 -0
- package/nav-selector/nav-selector.state.d.ts +3 -2
- package/nav-selector/utils/leaf.utils.d.ts +15 -2
- package/nav-selector/utils/nav-selector.accessibility.d.ts +1 -1
- package/nav-selector/utils/nav-selector.filter.d.ts +3 -1
- package/nav-selector/utils/nav-selector.folding.d.ts +6 -3
- package/nav-selector/utils/nav-selector.merger.d.ts +23 -0
- package/nav-selector/utils/nav-selector.minifying.d.ts +4 -2
- package/nav-selector/utils/nav-selector.single-select.d.ts +2 -0
- package/package.json +1 -1
- package/agorapulse-ui-components-18.0.13.tgz +0 -0
|
@@ -4,6 +4,7 @@ import { NavSelectorAccessibility } from './utils/nav-selector.accessibility';
|
|
|
4
4
|
import { NavSelectorBuilder } from './utils/nav-selector.builder';
|
|
5
5
|
import { NavSelectorFilter } from './utils/nav-selector.filter';
|
|
6
6
|
import { NavSelectorFolding } from './utils/nav-selector.folding';
|
|
7
|
+
import { NavSelectorMerger } from './utils/nav-selector.merger';
|
|
7
8
|
import { NavSelectorMinifying } from './utils/nav-selector.minifying';
|
|
8
9
|
import { NavSelectorMultiSelect } from './utils/nav-selector.multi-select';
|
|
9
10
|
import { NavSelectorSingleSelect } from './utils/nav-selector.single-select';
|
|
@@ -30,8 +31,7 @@ export class NavSelectorState {
|
|
|
30
31
|
lastSelectedUids = signal([]);
|
|
31
32
|
isMultipleModeEnabled = this.multipleModeEnabled;
|
|
32
33
|
search = signal('');
|
|
33
|
-
|
|
34
|
-
noResults = computed(() => this.filteredEntries().every(({ hidden }) => hidden));
|
|
34
|
+
noResults = computed(() => this.entries().every(({ hidden }) => hidden));
|
|
35
35
|
texts = this._texts.asReadonly();
|
|
36
36
|
leafActionProjection = signal(undefined);
|
|
37
37
|
expanded = signal(true);
|
|
@@ -45,12 +45,18 @@ export class NavSelectorState {
|
|
|
45
45
|
this.selectedUidsChangeCallback(newSelectedUids);
|
|
46
46
|
}
|
|
47
47
|
});
|
|
48
|
-
}
|
|
48
|
+
});
|
|
49
|
+
effect(() => {
|
|
50
|
+
const search = this.search();
|
|
51
|
+
untracked(() => {
|
|
52
|
+
this.entries.update(entries => NavSelectorFilter.filter(entries, search, this.multipleModeEnabled()));
|
|
53
|
+
});
|
|
54
|
+
});
|
|
49
55
|
}
|
|
50
56
|
updateMultiModeEnabled(enabled) {
|
|
51
57
|
this.multipleModeEnabled.set(enabled);
|
|
52
58
|
}
|
|
53
|
-
|
|
59
|
+
initEntries(entries, initialSelectedEntryUids, detailsDisplayedLimit) {
|
|
54
60
|
if (this.multipleModeEnabled()) {
|
|
55
61
|
this.entries.set(NavSelectorBuilder.buildInMultipleMode(entries, initialSelectedEntryUids, detailsDisplayedLimit));
|
|
56
62
|
}
|
|
@@ -58,8 +64,21 @@ export class NavSelectorState {
|
|
|
58
64
|
this.entries.set(NavSelectorBuilder.build(entries, initialSelectedEntryUids?.[0] ?? null, detailsDisplayedLimit));
|
|
59
65
|
}
|
|
60
66
|
}
|
|
67
|
+
updateEntries(entries, initialSelectedEntryUids, detailsDisplayedLimit) {
|
|
68
|
+
let newEntries;
|
|
69
|
+
if (this.multipleModeEnabled()) {
|
|
70
|
+
newEntries = NavSelectorBuilder.buildInMultipleMode(entries, initialSelectedEntryUids, detailsDisplayedLimit);
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
newEntries = NavSelectorBuilder.build(entries, initialSelectedEntryUids?.[0] ?? null, detailsDisplayedLimit);
|
|
74
|
+
}
|
|
75
|
+
this.entries.update(oldEntries => {
|
|
76
|
+
const mergeEntries = NavSelectorMerger.mergeInternalNavSelectorEntries(newEntries, oldEntries);
|
|
77
|
+
return NavSelectorFilter.filter(mergeEntries, this.search(), this.multipleModeEnabled());
|
|
78
|
+
});
|
|
79
|
+
}
|
|
61
80
|
onGroupToggleFolding(group) {
|
|
62
|
-
this.entries.update(entries => NavSelectorFolding.toggleFolding(entries, group.uid, !this.expanded()));
|
|
81
|
+
this.entries.update(entries => NavSelectorFolding.toggleFolding(entries, group.uid, this.multipleModeEnabled(), !this.expanded()));
|
|
63
82
|
}
|
|
64
83
|
onNodeSelect(node) {
|
|
65
84
|
this.entries.update(entries => NavSelectorMultiSelect.selectInMultipleMode(entries, node.uid));
|
|
@@ -76,7 +95,7 @@ export class NavSelectorState {
|
|
|
76
95
|
}
|
|
77
96
|
}
|
|
78
97
|
onLeafToggleFolding(leaf) {
|
|
79
|
-
this.entries.update(entries => NavSelectorFolding.toggleFolding(entries, leaf.uid, !this.expanded()));
|
|
98
|
+
this.entries.update(entries => NavSelectorFolding.toggleFolding(entries, leaf.uid, this.multipleModeEnabled(), !this.expanded()));
|
|
80
99
|
}
|
|
81
100
|
onLeafDetailClicked(leafDetail) {
|
|
82
101
|
this.entries.update(entries => NavSelectorSingleSelect.select(entries, leafDetail.uid));
|
|
@@ -91,9 +110,9 @@ export class NavSelectorState {
|
|
|
91
110
|
this.expanded.update(expanded => !expanded);
|
|
92
111
|
this.entries.update(entries => {
|
|
93
112
|
if (this.expanded()) {
|
|
94
|
-
return NavSelectorMinifying.expand(entries);
|
|
113
|
+
return NavSelectorMinifying.expand(entries, this.multipleModeEnabled());
|
|
95
114
|
}
|
|
96
|
-
return NavSelectorMinifying.minify(entries);
|
|
115
|
+
return NavSelectorMinifying.minify(entries, this.multipleModeEnabled());
|
|
97
116
|
});
|
|
98
117
|
if (!this.expanded()) {
|
|
99
118
|
setTimeout(() => this.expandedAfterDelay.set(this.expanded()), 150);
|
|
@@ -102,6 +121,11 @@ export class NavSelectorState {
|
|
|
102
121
|
this.expandedAfterDelay.set(this.expanded());
|
|
103
122
|
}
|
|
104
123
|
}
|
|
124
|
+
minify() {
|
|
125
|
+
if (this.expanded()) {
|
|
126
|
+
this.toggleExpanded();
|
|
127
|
+
}
|
|
128
|
+
}
|
|
105
129
|
onSelectionChange(uids) {
|
|
106
130
|
// Avoid infinite loop if you put unexisting uids as select will generate the same entries but with different reference
|
|
107
131
|
if (JSON.stringify(uids) === JSON.stringify(this.lastSelectedUids())) {
|
|
@@ -152,10 +176,10 @@ export class NavSelectorState {
|
|
|
152
176
|
this.leafActionProjection.set(leafActionProjection);
|
|
153
177
|
}
|
|
154
178
|
fold(entry) {
|
|
155
|
-
this.entries.update(entries => NavSelectorFolding.fold(entries, entry.uid, !this.expanded()));
|
|
179
|
+
this.entries.update(entries => NavSelectorFolding.fold(entries, entry.uid, this.multipleModeEnabled(), !this.expanded()));
|
|
156
180
|
}
|
|
157
181
|
unfold(entry) {
|
|
158
|
-
this.entries.update(entries => NavSelectorFolding.unfold(entries, entry.uid, !this.expanded()));
|
|
182
|
+
this.entries.update(entries => NavSelectorFolding.unfold(entries, entry.uid, this.multipleModeEnabled(), !this.expanded()));
|
|
159
183
|
}
|
|
160
184
|
updateDetailsDisplayedLimit(detailsDisplayedLimit) {
|
|
161
185
|
this.entries.update(entries => NavSelectorViewMore.changeViewMoreDetailsDisplayedLimit(entries, detailsDisplayedLimit));
|
|
@@ -172,4 +196,4 @@ export class NavSelectorState {
|
|
|
172
196
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorState, decorators: [{
|
|
173
197
|
type: Injectable
|
|
174
198
|
}], ctorParameters: () => [] });
|
|
175
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector.state.js","sourceRoot":"","sources":["../../../../libs/ui-components/nav-selector/src/nav-selector.state.ts"],"names":[],"mappings":"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","sourcesContent":["import { computed, effect, Injectable, signal, TemplateRef, untracked } from '@angular/core';\nimport {\n    InternalNavSelectorEntry,\n    InternalNavSelectorLeaf,\n    InternalNavSelectorLeafDetails,\n    isInternalNavSelectorEntryALeaf,\n    isInternalNavSelectorEntryANode,\n    NavSelectorEntry,\n    NavSelectorTranslatedTexts,\n} from './nav-selector';\nimport { NavSelectorAccessibility } from './utils/nav-selector.accessibility';\nimport { NavSelectorBuilder } from './utils/nav-selector.builder';\nimport { NavSelectorFilter } from './utils/nav-selector.filter';\nimport { NavSelectorFolding } from './utils/nav-selector.folding';\nimport { NavSelectorMinifying } from './utils/nav-selector.minifying';\nimport { NavSelectorMultiSelect } from './utils/nav-selector.multi-select';\nimport { NavSelectorSingleSelect } from './utils/nav-selector.single-select';\nimport { NavSelectorViewMore } from './utils/nav-selector.view-more';\n\n/**\n * NavSelectorState is a service that manages the state of the nav selector.\n *\n * It should be provided by the component to ensure that if many nav selectors are used in the same page, they don't share the same state.\n */\n@Injectable()\nexport class NavSelectorState {\n    private entries = signal<InternalNavSelectorEntry[]>([]);\n    private multipleModeEnabled = signal<boolean>(false);\n    private _texts = signal<NavSelectorTranslatedTexts>({\n        title: '',\n        only: '',\n        tokenInvalid: '',\n        featureLocked: '',\n        searchPlaceholder: '',\n        noResults: '',\n        viewMore: '',\n        viewLess: '',\n    });\n    private lastSelectedUids = signal<string[]>([]);\n\n    isMultipleModeEnabled = this.multipleModeEnabled;\n    search = signal<string>('');\n    filteredEntries = computed(() => NavSelectorFilter.filter(this.entries(), this.search()));\n    noResults = computed(() => this.filteredEntries().every(({ hidden }) => hidden));\n    texts = this._texts.asReadonly();\n\n    leafActionProjection = signal<ReadonlyArray<TemplateRef<unknown>> | undefined>(undefined);\n\n    expanded = signal(true);\n    expandedAfterDelay = signal(true);\n\n    selectedUidsChangeCallback: ((selectedUids: string[]) => void) | null = null;\n\n    constructor() {\n        effect(\n            () => {\n                const newSelectedUids = this.collectSelectedUids(this.entries());\n                untracked(() => {\n                    if (this.selectedUidsChangeCallback) {\n                        this.selectedUidsChangeCallback(newSelectedUids);\n                    }\n                });\n            },\n            { allowSignalWrites: true }\n        );\n    }\n\n    updateMultiModeEnabled(enabled: boolean) {\n        this.multipleModeEnabled.set(enabled);\n    }\n\n    updateEntries(entries: NavSelectorEntry[], initialSelectedEntryUids: string[], detailsDisplayedLimit: number) {\n        if (this.multipleModeEnabled()) {\n            this.entries.set(NavSelectorBuilder.buildInMultipleMode(entries, initialSelectedEntryUids, detailsDisplayedLimit));\n        } else {\n            this.entries.set(NavSelectorBuilder.build(entries, initialSelectedEntryUids?.[0] ?? null, detailsDisplayedLimit));\n        }\n    }\n\n    onGroupToggleFolding(group: InternalNavSelectorEntry) {\n        this.entries.update(entries => NavSelectorFolding.toggleFolding(entries, group.uid, !this.expanded()));\n    }\n\n    onNodeSelect(node: InternalNavSelectorEntry) {\n        this.entries.update(entries => NavSelectorMultiSelect.selectInMultipleMode(entries, node.uid));\n    }\n\n    onLeafClicked(leaf: InternalNavSelectorLeaf) {\n        if (!leaf.selectable) {\n            return;\n        }\n        if (this.multipleModeEnabled()) {\n            this.entries.update(entries => NavSelectorMultiSelect.selectInMultipleMode(entries, leaf.uid));\n        } else {\n            this.entries.update(entries => NavSelectorSingleSelect.select(entries, leaf.uid));\n        }\n    }\n\n    onLeafToggleFolding(leaf: InternalNavSelectorEntry) {\n        this.entries.update(entries => NavSelectorFolding.toggleFolding(entries, leaf.uid, !this.expanded()));\n    }\n\n    onLeafDetailClicked(leafDetail: InternalNavSelectorLeafDetails) {\n        this.entries.update(entries => NavSelectorSingleSelect.select(entries, leafDetail.uid));\n    }\n\n    updateTexts(texts: NavSelectorTranslatedTexts) {\n        this._texts.set(texts);\n    }\n\n    selectOnlyLeaf(leaf: InternalNavSelectorLeaf) {\n        this.entries.update(entries => NavSelectorMultiSelect.selectOnlyALeafInMultipleMode(entries, leaf.uid));\n    }\n\n    toggleExpanded() {\n        this.expanded.update(expanded => !expanded);\n        this.entries.update(entries => {\n            if (this.expanded()) {\n                return NavSelectorMinifying.expand(entries);\n            }\n            return NavSelectorMinifying.minify(entries);\n        });\n        if (!this.expanded()) {\n            setTimeout(() => this.expandedAfterDelay.set(this.expanded()), 150);\n        } else {\n            this.expandedAfterDelay.set(this.expanded());\n        }\n    }\n\n    onSelectionChange(uids: string[]) {\n        // Avoid infinite loop if you put unexisting uids as select will generate the same entries but with different reference\n        if (JSON.stringify(uids) === JSON.stringify(this.lastSelectedUids())) {\n            return;\n        }\n        this.lastSelectedUids.set(uids);\n        const selectedUids = this.collectSelectedUids(this.entries());\n        const uidToSelect = uids.filter(uid => selectedUids.every(selectedUid => selectedUid !== uid));\n        const uidToUnselect = selectedUids.filter(uid => uids.every(selectedUid => selectedUid !== uid));\n\n        if (!uidToSelect.length && !uidToUnselect.length) {\n            return;\n        }\n\n        let entries = this.entries();\n\n        if (this.multipleModeEnabled()) {\n            for (const uid of [...uidToSelect, ...uidToUnselect]) {\n                entries = NavSelectorMultiSelect.selectInMultipleMode(entries, uid);\n            }\n        } else {\n            entries = NavSelectorSingleSelect.select(entries, uids[0]);\n        }\n        this.entries.set(entries);\n    }\n\n    registerOnSelectedUidsChange(callback: (selectedUids: string[]) => void) {\n        this.selectedUidsChangeCallback = callback;\n    }\n\n    onArrowDown() {\n        this.entries.update(entries => NavSelectorAccessibility.focusNext(entries));\n    }\n\n    onArrowUp() {\n        this.entries.update(entries => NavSelectorAccessibility.focusPrevious(entries));\n    }\n\n    private collectSelectedUids(entries: InternalNavSelectorEntry[]): string[] {\n        return entries.flatMap(entry => {\n            if (isInternalNavSelectorEntryALeaf(entry)) {\n                if (entry.detailsDisplayable) {\n                    return entry.details.flatMap(detail => (detail.selected ? [detail.uid] : []));\n                }\n                return entry.selected ? [entry.uid] : [];\n            } else if (isInternalNavSelectorEntryANode(entry)) {\n                return this.collectSelectedUids(entry.children);\n            }\n            return [];\n        });\n    }\n\n    updateLeafAction(leafActionProjection: ReadonlyArray<TemplateRef<unknown>>) {\n        this.leafActionProjection.set(leafActionProjection);\n    }\n\n    fold(entry: InternalNavSelectorEntry) {\n        this.entries.update(entries => NavSelectorFolding.fold(entries, entry.uid, !this.expanded()));\n    }\n\n    unfold(entry: InternalNavSelectorEntry) {\n        this.entries.update(entries => NavSelectorFolding.unfold(entries, entry.uid, !this.expanded()));\n    }\n\n    updateDetailsDisplayedLimit(detailsDisplayedLimit: number) {\n        this.entries.update(entries => NavSelectorViewMore.changeViewMoreDetailsDisplayedLimit(entries, detailsDisplayedLimit));\n    }\n\n    viewMore(leaf: InternalNavSelectorLeaf) {\n        this.entries.update(entries => NavSelectorViewMore.viewMore(entries, leaf.uid));\n    }\n\n    viewLess(leaf: InternalNavSelectorLeaf) {\n        this.entries.update(entries => NavSelectorViewMore.viewLess(entries, leaf.uid));\n    }\n}\n"]}
|
|
199
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector.state.js","sourceRoot":"","sources":["../../../../libs/ui-components/nav-selector/src/nav-selector.state.ts"],"names":[],"mappings":"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","sourcesContent":["import { computed, effect, Injectable, signal, TemplateRef, untracked } from '@angular/core';\nimport {\n    InternalNavSelectorEntry,\n    InternalNavSelectorLeaf,\n    InternalNavSelectorLeafDetails,\n    isInternalNavSelectorEntryALeaf,\n    isInternalNavSelectorEntryANode,\n    NavSelectorEntry,\n    NavSelectorTranslatedTexts,\n} from './nav-selector';\nimport { NavSelectorAccessibility } from './utils/nav-selector.accessibility';\nimport { NavSelectorBuilder } from './utils/nav-selector.builder';\nimport { NavSelectorFilter } from './utils/nav-selector.filter';\nimport { NavSelectorFolding } from './utils/nav-selector.folding';\nimport { NavSelectorMerger } from './utils/nav-selector.merger';\nimport { NavSelectorMinifying } from './utils/nav-selector.minifying';\nimport { NavSelectorMultiSelect } from './utils/nav-selector.multi-select';\nimport { NavSelectorSingleSelect } from './utils/nav-selector.single-select';\nimport { NavSelectorViewMore } from './utils/nav-selector.view-more';\n\n/**\n * NavSelectorState is a service that manages the state of the nav selector.\n *\n * It should be provided by the component to ensure that if many nav selectors are used in the same page, they don't share the same state.\n */\n@Injectable()\nexport class NavSelectorState {\n    entries = signal<InternalNavSelectorEntry[]>([]);\n    private multipleModeEnabled = signal<boolean>(false);\n    private _texts = signal<NavSelectorTranslatedTexts>({\n        title: '',\n        only: '',\n        tokenInvalid: '',\n        featureLocked: '',\n        searchPlaceholder: '',\n        noResults: '',\n        viewMore: '',\n        viewLess: '',\n    });\n    private lastSelectedUids = signal<string[]>([]);\n\n    isMultipleModeEnabled = this.multipleModeEnabled;\n    search = signal<string>('');\n\n    noResults = computed(() => this.entries().every(({ hidden }) => hidden));\n    texts = this._texts.asReadonly();\n\n    leafActionProjection = signal<ReadonlyArray<TemplateRef<unknown>> | undefined>(undefined);\n\n    expanded = signal(true);\n    expandedAfterDelay = signal(true);\n\n    selectedUidsChangeCallback: ((selectedUids: string[]) => void) | null = null;\n\n    constructor() {\n        effect(() => {\n            const newSelectedUids = this.collectSelectedUids(this.entries());\n            untracked(() => {\n                if (this.selectedUidsChangeCallback) {\n                    this.selectedUidsChangeCallback(newSelectedUids);\n                }\n            });\n        });\n\n        effect(() => {\n            const search = this.search();\n            untracked(() => {\n                this.entries.update(entries => NavSelectorFilter.filter(entries, search, this.multipleModeEnabled()));\n            });\n        });\n    }\n\n    updateMultiModeEnabled(enabled: boolean) {\n        this.multipleModeEnabled.set(enabled);\n    }\n\n    initEntries(entries: NavSelectorEntry[], initialSelectedEntryUids: string[], detailsDisplayedLimit: number) {\n        if (this.multipleModeEnabled()) {\n            this.entries.set(NavSelectorBuilder.buildInMultipleMode(entries, initialSelectedEntryUids, detailsDisplayedLimit));\n        } else {\n            this.entries.set(NavSelectorBuilder.build(entries, initialSelectedEntryUids?.[0] ?? null, detailsDisplayedLimit));\n        }\n    }\n\n    updateEntries(entries: NavSelectorEntry[], initialSelectedEntryUids: string[], detailsDisplayedLimit: number) {\n        let newEntries: InternalNavSelectorEntry[];\n        if (this.multipleModeEnabled()) {\n            newEntries = NavSelectorBuilder.buildInMultipleMode(entries, initialSelectedEntryUids, detailsDisplayedLimit);\n        } else {\n            newEntries = NavSelectorBuilder.build(entries, initialSelectedEntryUids?.[0] ?? null, detailsDisplayedLimit);\n        }\n        this.entries.update(oldEntries => {\n            const mergeEntries = NavSelectorMerger.mergeInternalNavSelectorEntries(newEntries, oldEntries);\n            return NavSelectorFilter.filter(mergeEntries, this.search(), this.multipleModeEnabled());\n        });\n    }\n\n    onGroupToggleFolding(group: InternalNavSelectorEntry) {\n        this.entries.update(entries => NavSelectorFolding.toggleFolding(entries, group.uid, this.multipleModeEnabled(), !this.expanded()));\n    }\n\n    onNodeSelect(node: InternalNavSelectorEntry) {\n        this.entries.update(entries => NavSelectorMultiSelect.selectInMultipleMode(entries, node.uid));\n    }\n\n    onLeafClicked(leaf: InternalNavSelectorLeaf) {\n        if (!leaf.selectable) {\n            return;\n        }\n        if (this.multipleModeEnabled()) {\n            this.entries.update(entries => NavSelectorMultiSelect.selectInMultipleMode(entries, leaf.uid));\n        } else {\n            this.entries.update(entries => NavSelectorSingleSelect.select(entries, leaf.uid));\n        }\n    }\n\n    onLeafToggleFolding(leaf: InternalNavSelectorEntry) {\n        this.entries.update(entries => NavSelectorFolding.toggleFolding(entries, leaf.uid, this.multipleModeEnabled(), !this.expanded()));\n    }\n\n    onLeafDetailClicked(leafDetail: InternalNavSelectorLeafDetails) {\n        this.entries.update(entries => NavSelectorSingleSelect.select(entries, leafDetail.uid));\n    }\n\n    updateTexts(texts: NavSelectorTranslatedTexts) {\n        this._texts.set(texts);\n    }\n\n    selectOnlyLeaf(leaf: InternalNavSelectorLeaf) {\n        this.entries.update(entries => NavSelectorMultiSelect.selectOnlyALeafInMultipleMode(entries, leaf.uid));\n    }\n\n    toggleExpanded() {\n        this.expanded.update(expanded => !expanded);\n        this.entries.update(entries => {\n            if (this.expanded()) {\n                return NavSelectorMinifying.expand(entries, this.multipleModeEnabled());\n            }\n            return NavSelectorMinifying.minify(entries, this.multipleModeEnabled());\n        });\n        if (!this.expanded()) {\n            setTimeout(() => this.expandedAfterDelay.set(this.expanded()), 150);\n        } else {\n            this.expandedAfterDelay.set(this.expanded());\n        }\n    }\n\n    minify() {\n        if (this.expanded()) {\n            this.toggleExpanded();\n        }\n    }\n\n    onSelectionChange(uids: string[]) {\n        // Avoid infinite loop if you put unexisting uids as select will generate the same entries but with different reference\n        if (JSON.stringify(uids) === JSON.stringify(this.lastSelectedUids())) {\n            return;\n        }\n        this.lastSelectedUids.set(uids);\n        const selectedUids = this.collectSelectedUids(this.entries());\n        const uidToSelect = uids.filter(uid => selectedUids.every(selectedUid => selectedUid !== uid));\n        const uidToUnselect = selectedUids.filter(uid => uids.every(selectedUid => selectedUid !== uid));\n\n        if (!uidToSelect.length && !uidToUnselect.length) {\n            return;\n        }\n\n        let entries = this.entries();\n\n        if (this.multipleModeEnabled()) {\n            for (const uid of [...uidToSelect, ...uidToUnselect]) {\n                entries = NavSelectorMultiSelect.selectInMultipleMode(entries, uid);\n            }\n        } else {\n            entries = NavSelectorSingleSelect.select(entries, uids[0]);\n        }\n        this.entries.set(entries);\n    }\n\n    registerOnSelectedUidsChange(callback: (selectedUids: string[]) => void) {\n        this.selectedUidsChangeCallback = callback;\n    }\n\n    onArrowDown() {\n        this.entries.update(entries => NavSelectorAccessibility.focusNext(entries));\n    }\n\n    onArrowUp() {\n        this.entries.update(entries => NavSelectorAccessibility.focusPrevious(entries));\n    }\n\n    private collectSelectedUids(entries: InternalNavSelectorEntry[]): string[] {\n        return entries.flatMap(entry => {\n            if (isInternalNavSelectorEntryALeaf(entry)) {\n                if (entry.detailsDisplayable) {\n                    return entry.details.flatMap(detail => (detail.selected ? [detail.uid] : []));\n                }\n                return entry.selected ? [entry.uid] : [];\n            } else if (isInternalNavSelectorEntryANode(entry)) {\n                return this.collectSelectedUids(entry.children);\n            }\n            return [];\n        });\n    }\n\n    updateLeafAction(leafActionProjection: ReadonlyArray<TemplateRef<unknown>>) {\n        this.leafActionProjection.set(leafActionProjection);\n    }\n\n    fold(entry: InternalNavSelectorEntry) {\n        this.entries.update(entries => NavSelectorFolding.fold(entries, entry.uid, this.multipleModeEnabled(), !this.expanded()));\n    }\n\n    unfold(entry: InternalNavSelectorEntry) {\n        this.entries.update(entries => NavSelectorFolding.unfold(entries, entry.uid, this.multipleModeEnabled(), !this.expanded()));\n    }\n\n    updateDetailsDisplayedLimit(detailsDisplayedLimit: number) {\n        this.entries.update(entries => NavSelectorViewMore.changeViewMoreDetailsDisplayedLimit(entries, detailsDisplayedLimit));\n    }\n\n    viewMore(leaf: InternalNavSelectorLeaf) {\n        this.entries.update(entries => NavSelectorViewMore.viewMore(entries, leaf.uid));\n    }\n\n    viewLess(leaf: InternalNavSelectorLeaf) {\n        this.entries.update(entries => NavSelectorViewMore.viewLess(entries, leaf.uid));\n    }\n}\n"]}
|
|
@@ -1,10 +1,19 @@
|
|
|
1
|
-
|
|
1
|
+
/**
|
|
2
|
+
* Create a Record of key/value pairs from an array of objects
|
|
3
|
+
* @param array
|
|
4
|
+
* @param key attribute of the object to use as key
|
|
5
|
+
*/
|
|
6
|
+
export const associateBy = (array, key) => array.reduce((previousValue, currentValue) => {
|
|
7
|
+
previousValue[`${currentValue[key]}`] = currentValue;
|
|
8
|
+
return previousValue;
|
|
9
|
+
}, {});
|
|
10
|
+
export const isInternalNavSelectorEntryALeafFocusable = (leaf, { parentFolded, multipleMode }) => {
|
|
2
11
|
if (parentFolded) {
|
|
3
12
|
return false;
|
|
4
13
|
}
|
|
5
|
-
if (
|
|
14
|
+
if (multipleMode) {
|
|
6
15
|
return !leaf.disabled && !leaf.displayTokenInvalid && !leaf.displayFeatureLocked;
|
|
7
16
|
}
|
|
8
17
|
return !leaf.disabled;
|
|
9
18
|
};
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGVhZi51dGlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9uYXYtc2VsZWN0b3Ivc3JjL3V0aWxzL2xlYWYudXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBWUE7Ozs7R0FJRztBQUNILE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyxDQUFJLEtBQVUsRUFBRSxHQUF3QixFQUFxQixFQUFFLENBQ3RGLEtBQUssQ0FBQyxNQUFNLENBQ1IsQ0FBQyxhQUFhLEVBQUUsWUFBWSxFQUFFLEVBQUU7SUFDNUIsYUFBYSxDQUFDLEdBQUcsWUFBWSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxZQUFZLENBQUM7SUFDckQsT0FBTyxhQUFhLENBQUM7QUFDekIsQ0FBQyxFQUNELEVBQXVCLENBQzFCLENBQUM7QUFFTixNQUFNLENBQUMsTUFBTSx3Q0FBd0MsR0FBRyxDQUNwRCxJQUE2QixFQUM3QixFQUFFLFlBQVksRUFBRSxZQUFZLEVBQW9ELEVBQ3pFLEVBQUU7SUFDVCxJQUFJLFlBQVksRUFBRSxDQUFDO1FBQ2YsT0FBTyxLQUFLLENBQUM7SUFDakIsQ0FBQztJQUNELElBQUksWUFBWSxFQUFFLENBQUM7UUFDZixPQUFPLENBQUMsSUFBSSxDQUFDLFFBQVEsSUFBSSxDQUFDLElBQUksQ0FBQyxtQkFBbUIsSUFBSSxDQUFDLElBQUksQ0FBQyxvQkFBb0IsQ0FBQztJQUNyRixDQUFDO0lBQ0QsT0FBTyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUM7QUFDMUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW50ZXJuYWxOYXZTZWxlY3RvckxlYWYgfSBmcm9tICcuLi9uYXYtc2VsZWN0b3InO1xuXG4vKipcbiAqIFV0aWxpdHkgdHlwZSB0byBleHRyYWN0IGtleXMgb2YgYW4gb2JqZWN0IHRoYXQgYXJlIG9mIHR5cGUgc3RyaW5nLCBudW1iZXIgb3Igc3ltYm9sIHdoaWNoIGFyZSB0aGUgb25seSB0eXBlIGFsbG93ZWQgaW4gYSBSZWNvcmRcbiAqL1xudHlwZSBBbGxvd2VkS2V5PFQ+ID0gUGljazxcbiAgICBULFxuICAgIHtcbiAgICAgICAgW0sgaW4ga2V5b2YgVF06IFRbS10gZXh0ZW5kcyBzdHJpbmcgfCBudW1iZXIgfCBzeW1ib2wgPyBLIDogbmV2ZXI7XG4gICAgfVtrZXlvZiBUXVxuPjtcblxuLyoqXG4gKiBDcmVhdGUgYSBSZWNvcmQgb2Yga2V5L3ZhbHVlIHBhaXJzIGZyb20gYW4gYXJyYXkgb2Ygb2JqZWN0c1xuICogQHBhcmFtIGFycmF5XG4gKiBAcGFyYW0ga2V5IGF0dHJpYnV0ZSBvZiB0aGUgb2JqZWN0IHRvIHVzZSBhcyBrZXlcbiAqL1xuZXhwb3J0IGNvbnN0IGFzc29jaWF0ZUJ5ID0gPFQ+KGFycmF5OiBUW10sIGtleToga2V5b2YgQWxsb3dlZEtleTxUPik6IFJlY29yZDxzdHJpbmcsIFQ+ID0+XG4gICAgYXJyYXkucmVkdWNlKFxuICAgICAgICAocHJldmlvdXNWYWx1ZSwgY3VycmVudFZhbHVlKSA9PiB7XG4gICAgICAgICAgICBwcmV2aW91c1ZhbHVlW2Ake2N1cnJlbnRWYWx1ZVtrZXldfWBdID0gY3VycmVudFZhbHVlO1xuICAgICAgICAgICAgcmV0dXJuIHByZXZpb3VzVmFsdWU7XG4gICAgICAgIH0sXG4gICAgICAgIHt9IGFzIFJlY29yZDxzdHJpbmcsIFQ+XG4gICAgKTtcblxuZXhwb3J0IGNvbnN0IGlzSW50ZXJuYWxOYXZTZWxlY3RvckVudHJ5QUxlYWZGb2N1c2FibGUgPSAoXG4gICAgbGVhZjogSW50ZXJuYWxOYXZTZWxlY3RvckxlYWYsXG4gICAgeyBwYXJlbnRGb2xkZWQsIG11bHRpcGxlTW9kZSB9OiB7IHBhcmVudEZvbGRlZDogYm9vbGVhbjsgbXVsdGlwbGVNb2RlOiBib29sZWFuIH1cbik6IGJvb2xlYW4gPT4ge1xuICAgIGlmIChwYXJlbnRGb2xkZWQpIHtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgICBpZiAobXVsdGlwbGVNb2RlKSB7XG4gICAgICAgIHJldHVybiAhbGVhZi5kaXNhYmxlZCAmJiAhbGVhZi5kaXNwbGF5VG9rZW5JbnZhbGlkICYmICFsZWFmLmRpc3BsYXlGZWF0dXJlTG9ja2VkO1xuICAgIH1cbiAgICByZXR1cm4gIWxlYWYuZGlzYWJsZWQ7XG59O1xuIl19
|
|
@@ -8,15 +8,21 @@ export class NavSelectorAccessibility {
|
|
|
8
8
|
* @param entries nav selector entries
|
|
9
9
|
*/
|
|
10
10
|
static resetFocus(entries) {
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
11
|
+
const flattenEntries = this.flatten(entries);
|
|
12
|
+
let alreadyFocused = false;
|
|
13
|
+
for (const entry of flattenEntries) {
|
|
14
|
+
if (alreadyFocused) {
|
|
15
|
+
entry.accessibility.tabIndex = -1;
|
|
16
|
+
}
|
|
17
|
+
else if (entry.focusable) {
|
|
18
|
+
alreadyFocused = true;
|
|
19
|
+
entry.accessibility.tabIndex = 0;
|
|
14
20
|
}
|
|
15
|
-
|
|
16
|
-
|
|
21
|
+
else {
|
|
22
|
+
entry.accessibility.tabIndex = -1;
|
|
17
23
|
}
|
|
18
|
-
|
|
19
|
-
|
|
24
|
+
}
|
|
25
|
+
return this.unflatten(flattenEntries);
|
|
20
26
|
}
|
|
21
27
|
/**
|
|
22
28
|
* Focus the given entry and set tabIndex to 0 for the given uid and -1 for all other entries
|
|
@@ -72,7 +78,7 @@ export class NavSelectorAccessibility {
|
|
|
72
78
|
static focusPrevious(entries) {
|
|
73
79
|
const flattenEntries = this.flatten(entries);
|
|
74
80
|
const idxFocusedId = flattenEntries.findIndex(({ accessibility }) => accessibility.tabIndex === 0);
|
|
75
|
-
if (idxFocusedId === 0 || this.
|
|
81
|
+
if (idxFocusedId === 0 || this.noPreviousEntryFocusable(flattenEntries, idxFocusedId)) {
|
|
76
82
|
return entries;
|
|
77
83
|
}
|
|
78
84
|
const focusedEntry = flattenEntries[idxFocusedId];
|
|
@@ -104,12 +110,14 @@ export class NavSelectorAccessibility {
|
|
|
104
110
|
focusableFlattenEntries[idxFocusedId + 1].accessibility.tabIndex = 0;
|
|
105
111
|
return this.unflatten(flattenEntries);
|
|
106
112
|
}
|
|
107
|
-
static
|
|
108
|
-
|
|
109
|
-
const
|
|
110
|
-
|
|
113
|
+
static noPreviousEntryFocusable(flattenEntries, idxFocusedId) {
|
|
114
|
+
for (let i = idxFocusedId - 1; i >= 0; i--) {
|
|
115
|
+
const entry = flattenEntries[i];
|
|
116
|
+
if (entry.focusable) {
|
|
117
|
+
return false;
|
|
118
|
+
}
|
|
111
119
|
}
|
|
112
|
-
return
|
|
120
|
+
return true;
|
|
113
121
|
}
|
|
114
122
|
static focusAnEntry(entry, uid) {
|
|
115
123
|
return { ...entry, accessibility: { ...entry.accessibility, tabIndex: entry.uid === uid ? 0 : -1 } };
|
|
@@ -168,4 +176,4 @@ export class NavSelectorAccessibility {
|
|
|
168
176
|
}, []);
|
|
169
177
|
}
|
|
170
178
|
}
|
|
171
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector.accessibility.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/utils/nav-selector.accessibility.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    InternalNavSelectorEntry,\n    InternalNavSelectorGroup,\n    InternalNavSelectorLeaf,\n    InternalNavSelectorLeafDetails,\n    isInternalNavSelectorEntryACategory,\n    isInternalNavSelectorEntryAGroup,\n    isInternalNavSelectorEntryALeaf,\n    isInternalNavSelectorEntryALeafDetails,\n} from '../nav-selector';\n\n/**\n * NavSelectorAccessibility is a utility class that provides methods to manage the accessibility and the focusability of nav selector entries.\n */\nexport class NavSelectorAccessibility {\n    /**\n     * Set tabIndex to 0 for the first focusable entry and -1 for all other entries\n     * @param entries nav selector entries\n     */\n    static resetFocus(entries: InternalNavSelectorEntry[]): InternalNavSelectorEntry[] {\n        return entries.reduce((acc, entry) => {\n            if (!acc.length) {\n                return [{ ...entry, accessibility: { ...entry.accessibility, tabIndex: entry.focusable ? 0 : -1 } }];\n            }\n\n            if (acc.every(({ focusable }) => !focusable)) {\n                return [...acc, { ...entry, accessibility: { ...entry.accessibility, tabIndex: entry.focusable ? 0 : -1 } }];\n            }\n\n            return [...acc, entry];\n        }, [] as InternalNavSelectorEntry[]);\n    }\n\n    /**\n     * Focus the given entry and set tabIndex to 0 for the given uid and -1 for all other entries\n     * @param entries nav selector entries\n     * @param uid the uid of the entry to focus\n     */\n    static focus<T extends InternalNavSelectorEntry>(entries: T[], uid: string): InternalNavSelectorEntry[] {\n        return entries.map(entry => {\n            if (isInternalNavSelectorEntryAGroup(entry) || isInternalNavSelectorEntryACategory(entry)) {\n                return {\n                    ...this.focusAnEntry(entry, uid),\n                    children: NavSelectorAccessibility.focus(entry.children, uid),\n                } as InternalNavSelectorGroup;\n            }\n            if (isInternalNavSelectorEntryALeaf(entry)) {\n                return {\n                    ...this.focusAnEntry(entry, uid),\n                    details: entry.details.map(detail => this.focusAnEntry(detail, uid)),\n                } as InternalNavSelectorLeaf;\n            }\n            return this.focusAnEntry(entry, uid);\n        });\n    }\n\n    /**\n     * Unfocus the given entry and set tabIndex to -1 for the given uid and 0 for all other entries\n     * @param entries nav selector entries\n     * @param uid the uid of the entry to unfocus\n     */\n    static unfocus(entries: InternalNavSelectorEntry[], uid: string): InternalNavSelectorEntry[] {\n        return entries.map(entry => {\n            if (isInternalNavSelectorEntryAGroup(entry) || isInternalNavSelectorEntryACategory(entry)) {\n                return {\n                    ...this.unfocusAnEntry(entry, uid),\n                    children: NavSelectorAccessibility.unfocus(entry.children, uid),\n                } as InternalNavSelectorGroup;\n            }\n            if (isInternalNavSelectorEntryALeaf(entry)) {\n                return {\n                    ...this.unfocusAnEntry(entry, uid),\n                    details: entry.details.map(detail => this.unfocusAnEntry(detail, uid)),\n                } as InternalNavSelectorLeaf;\n            }\n            return this.unfocusAnEntry(entry, uid);\n        });\n    }\n\n    /**\n     * Focus the previous entry focusable and set tabIndex to 0 for the previous focusable entry and -1 for all other entries\n     *\n     * If not previous entries are focusable, entries will not be modified\n     *\n     * @param entries nav selector entries\n     */\n    static focusPrevious<T extends InternalNavSelectorEntry>(entries: T[]): InternalNavSelectorEntry[] {\n        const flattenEntries = this.flatten(entries);\n\n        const idxFocusedId = flattenEntries.findIndex(({ accessibility }) => accessibility.tabIndex === 0);\n\n        if (idxFocusedId === 0 || this.previousEntryIsFirstAndNotFocusable(flattenEntries, idxFocusedId)) {\n            return entries;\n        }\n\n        const focusedEntry = flattenEntries[idxFocusedId];\n        focusedEntry.accessibility.tabIndex = -1;\n\n        for (let i = idxFocusedId - 1; i >= 0; i--) {\n            const entry = flattenEntries[i];\n            if (entry.focusable) {\n                entry.accessibility.tabIndex = 0;\n                break;\n            }\n        }\n\n        return this.unflatten(flattenEntries);\n    }\n\n    /**\n     * Focus the next entry focusable and set tabIndex to 0 for the next focusable entry and -1 for all other entries\n     *\n     * If not next entries are focusable, entries will not be modified\n     *\n     * @param entries nav selector entries\n     */\n    static focusNext<T extends InternalNavSelectorEntry>(entries: T[]): InternalNavSelectorEntry[] {\n        const flattenEntries = this.flatten(entries);\n\n        const focusableFlattenEntries = flattenEntries.filter(entry => entry.focusable);\n\n        const idxFocusedId = focusableFlattenEntries.findIndex(({ accessibility }) => accessibility.tabIndex === 0);\n\n        if (focusableFlattenEntries.length - 1 <= idxFocusedId) {\n            return entries;\n        }\n\n        focusableFlattenEntries[idxFocusedId].accessibility.tabIndex = -1;\n\n        focusableFlattenEntries[idxFocusedId + 1].accessibility.tabIndex = 0;\n\n        return this.unflatten(flattenEntries);\n    }\n\n    private static previousEntryIsFirstAndNotFocusable(flattenEntries: InternalNavSelectorEntry[], idxFocusedId: number): boolean {\n        if (idxFocusedId - 1 === 0) {\n            const previous = flattenEntries[0];\n            return !previous.focusable;\n        }\n        return false;\n    }\n\n    private static focusAnEntry(entry: InternalNavSelectorEntry, uid: string): InternalNavSelectorEntry {\n        return { ...entry, accessibility: { ...entry.accessibility, tabIndex: entry.uid === uid ? 0 : -1 } };\n    }\n\n    private static unfocusAnEntry(entry: InternalNavSelectorEntry, uid: string): InternalNavSelectorEntry {\n        return { ...entry, accessibility: { ...entry.accessibility, tabIndex: entry.uid === uid ? -1 : entry.accessibility.tabIndex } };\n    }\n\n    /**\n     * Flatten the nav selector entries. It is easier to work with flat entries for the focus management as we need to know which is the previous or the next entry\n     * @param entries nav selector entries\n     */\n    private static flatten(entries: InternalNavSelectorEntry[]): InternalNavSelectorEntry[] {\n        return entries.flatMap(entry => {\n            if (isInternalNavSelectorEntryAGroup(entry) || isInternalNavSelectorEntryACategory(entry)) {\n                return [{ ...entry, children: [] }, ...this.flatten(entry.children)];\n            }\n            if (isInternalNavSelectorEntryALeaf(entry)) {\n                return [{ ...entry, details: [] }, ...entry.details.map(detail => ({ ...detail }))];\n            }\n            return [{ ...entry }];\n        });\n    }\n\n    /**\n     * Unflatten the nav selector entries\n     * @param entries nav selector entries\n     */\n    private static unflatten<T extends InternalNavSelectorEntry>(entries: T[]): InternalNavSelectorEntry[] {\n        return entries.reduceRight((acc, entry) => {\n            if (!acc.length) {\n                return [entry];\n            }\n            if (entry.accessibility.ariaLevel < acc[0].accessibility.ariaLevel) {\n                if (isInternalNavSelectorEntryALeaf(entry)) {\n                    return [\n                        {\n                            ...entry,\n                            details: acc\n                                .filter(it => isInternalNavSelectorEntryALeafDetails(it))\n                                // Force destroying the reference to the original object else Angular will not detect the change\n                                .map(it => ({ ...it })) as InternalNavSelectorLeafDetails[],\n                        },\n                        ...acc.filter(it => !isInternalNavSelectorEntryALeafDetails(it)),\n                    ];\n                } else if (isInternalNavSelectorEntryAGroup(entry) || isInternalNavSelectorEntryACategory(entry)) {\n                    return [\n                        {\n                            ...entry,\n                            children: acc.filter(\n                                ({ accessibility }) => accessibility.ariaLevel > entry.accessibility.ariaLevel\n                            ) as InternalNavSelectorLeaf[],\n                        },\n                        ...acc.filter(({ accessibility }) => accessibility.ariaLevel <= entry.accessibility.ariaLevel),\n                    ];\n                }\n            }\n            return [entry, ...acc];\n        }, [] as InternalNavSelectorEntry[]);\n    }\n}\n"]}
|
|
179
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector.accessibility.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/utils/nav-selector.accessibility.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    InternalNavSelectorEntry,\n    InternalNavSelectorGroup,\n    InternalNavSelectorLeaf,\n    InternalNavSelectorLeafDetails,\n    isInternalNavSelectorEntryACategory,\n    isInternalNavSelectorEntryAGroup,\n    isInternalNavSelectorEntryALeaf,\n    isInternalNavSelectorEntryALeafDetails,\n} from '../nav-selector';\n\n/**\n * NavSelectorAccessibility is a utility class that provides methods to manage the accessibility and the focusability of nav selector entries.\n */\nexport class NavSelectorAccessibility {\n    /**\n     * Set tabIndex to 0 for the first focusable entry and -1 for all other entries\n     * @param entries nav selector entries\n     */\n    static resetFocus(entries: InternalNavSelectorEntry[]): InternalNavSelectorEntry[] {\n        const flattenEntries = this.flatten(entries);\n\n        let alreadyFocused = false;\n\n        for (const entry of flattenEntries) {\n            if (alreadyFocused) {\n                entry.accessibility.tabIndex = -1;\n            } else if (entry.focusable) {\n                alreadyFocused = true;\n                entry.accessibility.tabIndex = 0;\n            } else {\n                entry.accessibility.tabIndex = -1;\n            }\n        }\n\n        return this.unflatten(flattenEntries);\n    }\n\n    /**\n     * Focus the given entry and set tabIndex to 0 for the given uid and -1 for all other entries\n     * @param entries nav selector entries\n     * @param uid the uid of the entry to focus\n     */\n    static focus<T extends InternalNavSelectorEntry>(entries: T[], uid: string): InternalNavSelectorEntry[] {\n        return entries.map(entry => {\n            if (isInternalNavSelectorEntryAGroup(entry) || isInternalNavSelectorEntryACategory(entry)) {\n                return {\n                    ...this.focusAnEntry(entry, uid),\n                    children: NavSelectorAccessibility.focus(entry.children, uid),\n                } as InternalNavSelectorGroup;\n            }\n            if (isInternalNavSelectorEntryALeaf(entry)) {\n                return {\n                    ...this.focusAnEntry(entry, uid),\n                    details: entry.details.map(detail => this.focusAnEntry(detail, uid)),\n                } as InternalNavSelectorLeaf;\n            }\n            return this.focusAnEntry(entry, uid);\n        });\n    }\n\n    /**\n     * Unfocus the given entry and set tabIndex to -1 for the given uid and 0 for all other entries\n     * @param entries nav selector entries\n     * @param uid the uid of the entry to unfocus\n     */\n    static unfocus(entries: InternalNavSelectorEntry[], uid: string): InternalNavSelectorEntry[] {\n        return entries.map(entry => {\n            if (isInternalNavSelectorEntryAGroup(entry) || isInternalNavSelectorEntryACategory(entry)) {\n                return {\n                    ...this.unfocusAnEntry(entry, uid),\n                    children: NavSelectorAccessibility.unfocus(entry.children, uid),\n                } as InternalNavSelectorGroup;\n            }\n            if (isInternalNavSelectorEntryALeaf(entry)) {\n                return {\n                    ...this.unfocusAnEntry(entry, uid),\n                    details: entry.details.map(detail => this.unfocusAnEntry(detail, uid)),\n                } as InternalNavSelectorLeaf;\n            }\n            return this.unfocusAnEntry(entry, uid);\n        });\n    }\n\n    /**\n     * Focus the previous entry focusable and set tabIndex to 0 for the previous focusable entry and -1 for all other entries\n     *\n     * If not previous entries are focusable, entries will not be modified\n     *\n     * @param entries nav selector entries\n     */\n    static focusPrevious<T extends InternalNavSelectorEntry>(entries: T[]): InternalNavSelectorEntry[] {\n        const flattenEntries = this.flatten(entries);\n\n        const idxFocusedId = flattenEntries.findIndex(({ accessibility }) => accessibility.tabIndex === 0);\n\n        if (idxFocusedId === 0 || this.noPreviousEntryFocusable(flattenEntries, idxFocusedId)) {\n            return entries;\n        }\n\n        const focusedEntry = flattenEntries[idxFocusedId];\n        focusedEntry.accessibility.tabIndex = -1;\n\n        for (let i = idxFocusedId - 1; i >= 0; i--) {\n            const entry = flattenEntries[i];\n            if (entry.focusable) {\n                entry.accessibility.tabIndex = 0;\n                break;\n            }\n        }\n\n        return this.unflatten(flattenEntries);\n    }\n\n    /**\n     * Focus the next entry focusable and set tabIndex to 0 for the next focusable entry and -1 for all other entries\n     *\n     * If not next entries are focusable, entries will not be modified\n     *\n     * @param entries nav selector entries\n     */\n    static focusNext<T extends InternalNavSelectorEntry>(entries: T[]): InternalNavSelectorEntry[] {\n        const flattenEntries = this.flatten(entries);\n\n        const focusableFlattenEntries = flattenEntries.filter(entry => entry.focusable);\n\n        const idxFocusedId = focusableFlattenEntries.findIndex(({ accessibility }) => accessibility.tabIndex === 0);\n\n        if (focusableFlattenEntries.length - 1 <= idxFocusedId) {\n            return entries;\n        }\n\n        focusableFlattenEntries[idxFocusedId].accessibility.tabIndex = -1;\n\n        focusableFlattenEntries[idxFocusedId + 1].accessibility.tabIndex = 0;\n\n        return this.unflatten(flattenEntries);\n    }\n\n    private static noPreviousEntryFocusable(flattenEntries: InternalNavSelectorEntry[], idxFocusedId: number): boolean {\n        for (let i = idxFocusedId - 1; i >= 0; i--) {\n            const entry = flattenEntries[i];\n            if (entry.focusable) {\n                return false;\n            }\n        }\n\n        return true;\n    }\n\n    private static focusAnEntry(entry: InternalNavSelectorEntry, uid: string): InternalNavSelectorEntry {\n        return { ...entry, accessibility: { ...entry.accessibility, tabIndex: entry.uid === uid ? 0 : -1 } };\n    }\n\n    private static unfocusAnEntry(entry: InternalNavSelectorEntry, uid: string): InternalNavSelectorEntry {\n        return { ...entry, accessibility: { ...entry.accessibility, tabIndex: entry.uid === uid ? -1 : entry.accessibility.tabIndex } };\n    }\n\n    /**\n     * Flatten the nav selector entries. It is easier to work with flat entries for the focus management as we need to know which is the previous or the next entry\n     * @param entries nav selector entries\n     */\n    private static flatten(entries: InternalNavSelectorEntry[]): InternalNavSelectorEntry[] {\n        return entries.flatMap(entry => {\n            if (isInternalNavSelectorEntryAGroup(entry) || isInternalNavSelectorEntryACategory(entry)) {\n                return [{ ...entry, children: [] }, ...this.flatten(entry.children)];\n            }\n            if (isInternalNavSelectorEntryALeaf(entry)) {\n                return [{ ...entry, details: [] }, ...entry.details.map(detail => ({ ...detail }))];\n            }\n            return [{ ...entry }];\n        });\n    }\n\n    /**\n     * Unflatten the nav selector entries\n     * @param entries nav selector entries\n     */\n    private static unflatten<T extends InternalNavSelectorEntry>(entries: T[]): InternalNavSelectorEntry[] {\n        return entries.reduceRight((acc, entry) => {\n            if (!acc.length) {\n                return [entry];\n            }\n            if (entry.accessibility.ariaLevel < acc[0].accessibility.ariaLevel) {\n                if (isInternalNavSelectorEntryALeaf(entry)) {\n                    return [\n                        {\n                            ...entry,\n                            details: acc\n                                .filter(it => isInternalNavSelectorEntryALeafDetails(it))\n                                // Force destroying the reference to the original object else Angular will not detect the change\n                                .map(it => ({ ...it })) as InternalNavSelectorLeafDetails[],\n                        },\n                        ...acc.filter(it => !isInternalNavSelectorEntryALeafDetails(it)),\n                    ];\n                } else if (isInternalNavSelectorEntryAGroup(entry) || isInternalNavSelectorEntryACategory(entry)) {\n                    return [\n                        {\n                            ...entry,\n                            children: acc.filter(\n                                ({ accessibility }) => accessibility.ariaLevel > entry.accessibility.ariaLevel\n                            ) as InternalNavSelectorLeaf[],\n                        },\n                        ...acc.filter(({ accessibility }) => accessibility.ariaLevel <= entry.accessibility.ariaLevel),\n                    ];\n                }\n            }\n            return [entry, ...acc];\n        }, [] as InternalNavSelectorEntry[]);\n    }\n}\n"]}
|
|
@@ -204,10 +204,12 @@ export class NavSelectorBuilder {
|
|
|
204
204
|
uid: leaf.uid,
|
|
205
205
|
alias: leaf.alias,
|
|
206
206
|
pictureUrl: leaf.pictureUrl,
|
|
207
|
+
actionsDisplayable: this.isLeafLogicValid(leaf, LeafLogics.COUNTER),
|
|
207
208
|
disabled,
|
|
208
209
|
disableReason: leaf.disableReason,
|
|
209
210
|
hidden: false,
|
|
210
|
-
focusable: focusable &&
|
|
211
|
+
focusable: focusable &&
|
|
212
|
+
((multipleModeEnabled && this.isLeafLogicValid(leaf, LeafLogics.COUNTER)) || (!multipleModeEnabled && !disabled)),
|
|
211
213
|
accessibility: {
|
|
212
214
|
tabIndex: -1,
|
|
213
215
|
ariaPosinset: idx + 1,
|
|
@@ -260,4 +262,4 @@ export class NavSelectorBuilder {
|
|
|
260
262
|
.every(([, logic]) => !logic(leaf));
|
|
261
263
|
}
|
|
262
264
|
}
|
|
263
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector.builder.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/utils/nav-selector.builder.ts"],"names":[],"mappings":"AAAA,OAAO,EAMH,+BAA+B,EAC/B,2BAA2B,EAC3B,wBAAwB,EACxB,uBAAuB,GAM1B,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,wBAAwB,EAAE,MAAM,qCAAqC,CAAC;AAC/E,OAAO,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;AAC5E,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AAEvE,MAAM,UAAU,GAAG;IACf,QAAQ,EAAE,UAAU;IACpB,cAAc,EAAE,gBAAgB;IAChC,aAAa,EAAE,eAAe;IAC9B,OAAO,EAAE,SAAS;CACZ,CAAC;AAGX;;;GAGG;AACH,MAAM,OAAO,kBAAkB;IAC3B,6CAA6C;IACrC,MAAM,CAAC,oBAAoB,GAA0D;QACzF,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAqB,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,KAAK,IAAI;QAC7E,CAAC,UAAU,CAAC,cAAc,CAAC,EAAE,CAAC,IAAqB,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa;QAC1E,CAAC,UAAU,CAAC,aAAa,CAAC,EAAE,CAAC,IAAqB,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY;QACxE,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC,IAAqB,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,KAAK,IAAI;KACzE,CAAC;IAEF;;;;;OAKG;IACH,MAAM,CAAC,KAAK,CAAC,OAA2B,EAAE,gBAA+B,EAAE,qBAA6B;QACpG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;QAC/B,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,KAAK,EAAE,CAAC,EAAE,qBAAqB,CAAC,CAAC;QACjF,IAAI,gBAAgB,EAAE,CAAC;YACnB,OAAO,uBAAuB,CAAC,MAAM,CAAC,YAAY,EAAE,gBAAgB,CAAC,CAAC;QAC1E,CAAC;QACD,OAAO,YAAY,CAAC;IACxB,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,mBAAmB,CACtB,OAA2B,EAC3B,iBAAkC,EAClC,qBAA6B;QAE7B,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QACrC,IAAI,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,qBAAqB,CAAC,CAAC;QAC9E,IAAI,iBAAiB,EAAE,CAAC;YACpB,KAAK,MAAM,gBAAgB,IAAI,iBAAiB,EAAE,CAAC;gBAC/C,YAAY,GAAG,sBAAsB,CAAC,oBAAoB,CAAC,YAAY,EAAE,gBAAgB,CAAC,CAAC;YAC/F,CAAC;QACL,CAAC;QACD,OAAO,YAAY,CAAC;IACxB,CAAC;IAEO,MAAM,CAAC,gBAAgB,CAAC,OAA2B,EAAE,mBAAmB,GAAG,KAAK;QACpF,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACpB,IAAI,wBAAwB,CAAC,KAAK,CAAC,IAAI,2BAA2B,CAAC,KAAK,CAAC,EAAE,CAAC;gBACxE,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,QAAQ,EAAE,mBAAmB,CAAC,CAAC;YAC/D,CAAC;iBAAM,IAAI,uBAAuB,CAAC,KAAK,CAAC,EAAE,CAAC;gBACxC,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,IAAI,mBAAmB,EAAE,CAAC;oBAC9C,OAAO,CAAC,KAAK,CAAC,4BAA4B,KAAK,CAAC,GAAG,+CAA+C,CAAC,CAAC;gBACxG,CAAC;YACL,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,MAAM,CAAC,YAAY,CACvB,OAA2B,EAC3B,mBAA4B,EAC5B,KAAK,GAAG,CAAC,EACT,qBAA6B;QAE7B,MAAM,UAAU,GAAG,OAAO;aACrB,GAAG,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAChB,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,EAAE,mBAAmB,EAAE,KAAK,EAAE,GAAG,EAAE,kBAAkB,EAAE,OAAO,CAAC,MAAM,EAAE,qBAAqB,EAAE,CAAC,CACzH;aACA,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,IAAI,CAAC,CAAC;QAC/B,OAAO,wBAAwB,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;IAC3D,CAAC;IAEO,MAAM,CAAC,UAAU,CACrB,KAAuB,EACvB,EACI,mBAAmB,EACnB,KAAK,EACL,GAAG,EACH,kBAAkB,EAClB,qBAAqB,GACiG;QAE1H,IAAI,uBAAuB,CAAC,KAAK,CAAC,EAAE,CAAC;YACjC,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE;gBACzB,mBAAmB;gBACnB,KAAK;gBACL,GAAG;gBACH,iBAAiB,EAAE,kBAAkB;gBACrC,SAAS,EAAE,IAAI;gBACf,qBAAqB;aACxB,CAAC,CAAC;QACP,CAAC;aAAM,IAAI,2BAA2B,CAAC,KAAK,CAAC,EAAE,CAAC;YAC5C,OAAO,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE;gBAC7B,mBAAmB;gBACnB,KAAK;gBACL,GAAG;gBACH,qBAAqB,EAAE,kBAAkB;gBACzC,qBAAqB;aACxB,CAAC,CAAC;QACP,CAAC;aAAM,CAAC;YACJ,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE;gBAC1B,mBAAmB;gBACnB,KAAK;gBACL,GAAG;gBACH,mBAAmB,EAAE,kBAAkB;gBACvC,SAAS,EAAE,IAAI;gBACf,qBAAqB;aACxB,CAAC,CAAC;QACP,CAAC;IACL,CAAC;IAEO,MAAM,CAAC,qBAAqB,CAChC,KAA0B,EAC1B,EACI,SAAS,EACT,mBAAmB,EACnB,aAAa,EACb,qBAAqB,GAMxB;QAED,OAAO,KAAK,CAAC,QAAQ;aAChB,GAAG,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;YAChB,IAAI,uBAAuB,CAAC,KAAK,CAAC,EAAE,CAAC;gBACjC,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE;oBACzB,SAAS;oBACT,mBAAmB;oBACnB,KAAK,EAAE,aAAa,GAAG,CAAC;oBACxB,GAAG;oBACH,iBAAiB,EAAE,KAAK,CAAC,QAAQ,CAAC,MAAM;oBACxC,qBAAqB;iBACxB,CAAC,CAAC;YACP,CAAC;iBAAM,CAAC;gBACJ,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE;oBAC1B,SAAS;oBACT,mBAAmB;oBACnB,KAAK,EAAE,aAAa,GAAG,CAAC;oBACxB,GAAG;oBACH,mBAAmB,EAAE,KAAK,CAAC,QAAQ,CAAC,MAAM;oBAC1C,qBAAqB;iBACxB,CAAC,CAAC;YACP,CAAC;QACL,CAAC,CAAC;aACD,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,IAAI,CAAC,CAAC;IACnC,CAAC;IAEO,MAAM,CAAC,aAAa,CACxB,IAAyB,EACzB,EACI,mBAAmB,EACnB,KAAK,EACL,GAAG,EACH,qBAAqB,EACrB,qBAAqB,GAOxB;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,qBAAqB,CAAC,IAAI,EAAE;YAC9C,SAAS,EAAE,CAAC,IAAI,CAAC,MAAM;YACvB,mBAAmB;YACnB,aAAa,EAAE,KAAK;YACpB,qBAAqB;SACxB,CAAC,CAAC;QAEH,OAAO;YACH,GAAG,EAAE,IAAI,CAAC,GAAG;YACb,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,QAAQ;YACR,MAAM,EAAE,KAAK;YACb,SAAS,EAAE,IAAI;YACf,aAAa,EAAE;gBACX,QAAQ,EAAE,CAAC,CAAC;gBACZ,SAAS,EAAE,KAAK;gBAChB,YAAY,EAAE,GAAG,GAAG,CAAC;gBACrB,WAAW,EAAE,qBAAqB;aACrC;YACD,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,IAAI,EAAE,IAAI,CAAC,IAAI;SAClB,CAAC;IACN,CAAC;IAEO,MAAM,CAAC,kBAAkB,CAC7B,KAAuB,EACvB,EACI,mBAAmB,EACnB,UAAU,EACV,SAAS,EACT,qBAAqB,GACiF;QAE1G,OAAO,KAAK,CAAC,QAAQ;aAChB,GAAG,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAChB,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE;YAClB,mBAAmB;YACnB,KAAK,EAAE,UAAU,GAAG,CAAC;YACrB,GAAG;YACH,iBAAiB,EAAE,KAAK,CAAC,QAAQ,CAAC,MAAM;YACxC,SAAS,EAAE,SAAS,IAAI,CAAC,KAAK,CAAC,MAAM;YACrC,qBAAqB;SACxB,CAAC,CACL;aACA,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,IAAI,CAAC,CAAC;IACnC,CAAC;IAEO,MAAM,CAAC,UAAU,CACrB,IAAsB,EACtB,EACI,SAAS,EACT,mBAAmB,EACnB,KAAK,EACL,GAAG,EACH,mBAAmB,EACnB,qBAAqB,GAQxB;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,EAAE,mBAAmB,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,qBAAqB,EAAE,CAAC,CAAC;QAC7H,MAAM,mBAAmB,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,EAAE,mBAAmB,EAAE,EAAE,EAAE,CAAC,mBAAmB,CAAC,CAAC;QAE5F,MAAM,qBAAqB,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC;QAEjF,OAAO;YACH,GAAG,EAAE,IAAI,CAAC,GAAG;YACb,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,QAAQ;YACR,wBAAwB,EAAE,QAAQ;iBAC7B,GAAG,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAChB,+BAA+B,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,KAAK,CAAC,UAAU,EAAE,OAAO,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAChH;iBACA,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,IAAI,CAAC;YAC9B,MAAM,EAAE,KAAK;YACb,aAAa,EAAE;gBACX,QAAQ,EAAE,CAAC,CAAC;gBACZ,YAAY,EAAE,GAAG,GAAG,CAAC;gBACrB,SAAS,EAAE,KAAK;gBAChB,WAAW,EAAE,mBAAmB;aACnC;YACD,SAAS;YACT,cAAc,EAAE,IAAI,CAAC,MAAM,IAAI,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,+BAA+B,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,OAAO,KAAK,CAAC,CAAC;YACpH,OAAO,EAAE,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,GAAG,GAAG,OAAO,EAAE,CAAC,CAAC;YAChE,mBAAmB;YACnB,QAAQ,EAAE,KAAK;YACf,UAAU,EAAE,mBAAmB,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAC,EAAE,UAAU,EAAE,EAAE,EAAE,CAAC,UAAU,CAAC;YAChF,qBAAqB,EAAE,qBAAqB,KAAK,QAAQ,CAAC,MAAM,IAAI,qBAAqB,GAAG,CAAC;YAC7F,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,IAAI,EAAE,IAAI,CAAC,IAAI;SAClB,CAAC;IACN,CAAC;IAEO,MAAM,CAAC,SAAS,CACpB,IAAqB,EACrB,EACI,SAAS,EACT,mBAAmB,EACnB,KAAK,EACL,GAAG,EACH,iBAAiB,EACjB,qBAAqB,GAQxB;QAED,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,OAAO,IAAI,CAAC;QAChB,CAAC;QAED,MAAM,kBAAkB,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC;QACpG,MAAM,QAAQ,GAAG,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,kBAAkB,CAAC;QAC7D,MAAM,MAAM,GAAG,IAAI,CAAC;QACpB,MAAM,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,OAAO,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC5G,MAAM,kBAAkB,GAAG,OAAO,KAAK,CAAC,IAAI,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC;QAE5F,MAAM,QAAQ,GAAG,IAAI,CAAC,aAAa,KAAK,IAAI,CAAC;QAE7C,MAAM,mBAAmB,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,qBAAqB,CAAC;QAExE,OAAO;YACH,GAAG,EAAE,IAAI,CAAC,GAAG;YACb,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,QAAQ;YACR,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,MAAM,EAAE,KAAK;YACb,SAAS,EAAE,SAAS,IAAI,CAAC,QAAQ;YACjC,aAAa,EAAE;gBACX,QAAQ,EAAE,CAAC,CAAC;gBACZ,YAAY,EAAE,GAAG,GAAG,CAAC;gBACrB,SAAS,EAAE,KAAK;gBAChB,WAAW,EAAE,iBAAiB;aACjC;YACD,QAAQ;YACR,MAAM;YACN,cAAc,EAAE,MAAM,IAAI,kBAAkB;YAC5C,kBAAkB;YAClB,OAAO;YACP,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,mBAAmB,EAAE,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,UAAU,CAAC,aAAa,EAAE,UAAU,CAAC,OAAO,CAAC;YACnH,oBAAoB,EAChB,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,UAAU,CAAC,cAAc,EAAE,UAAU,CAAC,aAAa,EAAE,UAAU,CAAC,OAAO,CAAC;YAC9H,QAAQ,EAAE,KAAK;YACf,UAAU,EAAE,mBAAmB;gBAC3B,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,UAAU,CAAC,OAAO,CAAC;gBACjD,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,UAAU,CAAC,cAAc,EAAE,UAAU,CAAC,aAAa,EAAE,UAAU,CAAC,OAAO,CAAC;YAC1G,kBAAkB;YAClB,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,KAAK,GAAG,CAAC,EAAE,SAAS,IAAI,CAAC,MAAM,CAAC,CAAC;YAClG,IAAI,EAAE,MAAM;YACZ,mBAAmB;YACnB,iBAAiB,EAAE,mBAAmB;YACtC,6BAA6B,EAAE,qBAAqB;SACvD,CAAC;IACN,CAAC;IAEO,MAAM,CAAC,eAAe,CAAC,MAA8B,EAAE,KAAa,EAAE,SAAkB;QAC5F,OAAO;YACH,GAAG,EAAE,MAAM,CAAC,GAAG;YACf,OAAO,EAAE,MAAM,CAAC,OAAO,IAAI,CAAC;YAC5B,cAAc,EAAE,MAAM,CAAC,OAAO,KAAK,IAAI;YACvC,KAAK,EAAE,MAAM,CAAC,IAAI;YAClB,MAAM,EAAE,KAAK;YACb,aAAa,EAAE;gBACX,QAAQ,EAAE,CAAC,CAAC;gBACZ,YAAY,EAAE,CAAC;gBACf,SAAS,EAAE,KAAK;gBAChB,WAAW,EAAE,CAAC;aACjB;YACD,SAAS;YACT,QAAQ,EAAE,KAAK;YACf,WAAW,EAAE,MAAM,CAAC,WAAW;YAC/B,YAAY,EAAE,MAAM,CAAC,WAAW,KAAK,IAAI;YACzC,IAAI,EAAE,cAAc;SACvB,CAAC;IACN,CAAC;IAEO,MAAM,CAAC,gBAAgB,CAAC,IAAqB,EAAE,GAAG,QAAsB;QAC5E,OAAO,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC;aAC3C,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAiB,CAAC,CAAC;aACxD,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC;IAC5C,CAAC","sourcesContent":["import {\n    InternalNavSelectorCategory,\n    InternalNavSelectorEntry,\n    InternalNavSelectorGroup,\n    InternalNavSelectorLeaf,\n    InternalNavSelectorLeafDetails,\n    isInternalNavSelectorEntryALeaf,\n    isNavSelectorEntryACategory,\n    isNavSelectorEntryAGroup,\n    isNavSelectorEntryALeaf,\n    NavSelectorCategory,\n    NavSelectorEntry,\n    NavSelectorGroup,\n    NavSelectorLeaf,\n    NavSelectorLeafDetails,\n} from '../nav-selector';\nimport { NavSelectorAccessibility } from '../utils/nav-selector.accessibility';\nimport { NavSelectorMultiSelect } from '../utils/nav-selector.multi-select';\nimport { NavSelectorSingleSelect } from './nav-selector.single-select';\n\nconst LeafLogics = {\n    DISABLED: 'DISABLED',\n    FEATURE_LOCKED: 'FEATURE_LOCKED',\n    TOKEN_INVALID: 'TOKEN_INVALID',\n    COUNTER: 'COUNTER',\n} as const;\ntype LeafLogics = keyof typeof LeafLogics;\n\n/**\n * NavSelectorBuilder is a utility class that builds the NavSelector entries for single and multiple select modes.\n * It also checks the structure of the entries to ensure they are valid.\n */\nexport class NavSelectorBuilder {\n    // /!\\/!\\ Order of logics is important /!\\/!\\\n    private static LEAF_LOGICS_PRIORITY: Record<LeafLogics, (lef: NavSelectorLeaf) => boolean> = {\n        [LeafLogics.DISABLED]: (leaf: NavSelectorLeaf) => leaf.disableReason !== null,\n        [LeafLogics.FEATURE_LOCKED]: (leaf: NavSelectorLeaf) => leaf.featureLocked,\n        [LeafLogics.TOKEN_INVALID]: (leaf: NavSelectorLeaf) => leaf.tokenInvalid,\n        [LeafLogics.COUNTER]: (leaf: NavSelectorLeaf) => leaf.counter !== null,\n    };\n\n    /**\n     * Builds the NavSelector entries for single select mode.\n     * @param entries nav selector entries\n     * @param selectedEntryUid selected entry uid\n     * @param detailsDisplayedLimit number of details displayed limit\n     */\n    static build(entries: NavSelectorEntry[], selectedEntryUid: string | null, detailsDisplayedLimit: number): InternalNavSelectorEntry[] {\n        this.structureChecker(entries);\n        const builtEntries = this.buildEntries(entries, false, 1, detailsDisplayedLimit);\n        if (selectedEntryUid) {\n            return NavSelectorSingleSelect.select(builtEntries, selectedEntryUid);\n        }\n        return builtEntries;\n    }\n\n    /**\n     * Builds the NavSelector entries for multiple select mode.\n     * @param entries nav selector entries\n     * @param selectedEntryUids selected entry uids\n     * @param detailsDisplayedLimit number of details displayed limit\n     */\n    static buildInMultipleMode(\n        entries: NavSelectorEntry[],\n        selectedEntryUids: string[] | null,\n        detailsDisplayedLimit: number\n    ): InternalNavSelectorEntry[] {\n        this.structureChecker(entries, true);\n        let builtEntries = this.buildEntries(entries, true, 1, detailsDisplayedLimit);\n        if (selectedEntryUids) {\n            for (const selectedEntryUid of selectedEntryUids) {\n                builtEntries = NavSelectorMultiSelect.selectInMultipleMode(builtEntries, selectedEntryUid);\n            }\n        }\n        return builtEntries;\n    }\n\n    private static structureChecker(entries: NavSelectorEntry[], multipleModeEnabled = false): void {\n        entries.forEach(entry => {\n            if (isNavSelectorEntryAGroup(entry) || isNavSelectorEntryACategory(entry)) {\n                this.structureChecker(entry.children, multipleModeEnabled);\n            } else if (isNavSelectorEntryALeaf(entry)) {\n                if (entry.details.length && multipleModeEnabled) {\n                    console.error(`NavSelectorBuilder: Leaf ${entry.uid} with details is not allowed in multiple mode`);\n                }\n            }\n        });\n    }\n\n    private static buildEntries(\n        entries: NavSelectorEntry[],\n        multipleModeEnabled: boolean,\n        level = 1,\n        detailsDisplayedLimit: number\n    ): InternalNavSelectorEntry[] {\n        const newEntries = entries\n            .map((entry, idx) =>\n                this.buildEntry(entry, { multipleModeEnabled, level, idx, totalNumberOfEntry: entries.length, detailsDisplayedLimit })\n            )\n            .filter(it => it !== null);\n        return NavSelectorAccessibility.resetFocus(newEntries);\n    }\n\n    private static buildEntry(\n        entry: NavSelectorEntry,\n        {\n            multipleModeEnabled,\n            level,\n            idx,\n            totalNumberOfEntry,\n            detailsDisplayedLimit,\n        }: { multipleModeEnabled: boolean; level: number; idx: number; totalNumberOfEntry: number; detailsDisplayedLimit: number }\n    ): InternalNavSelectorEntry | null {\n        if (isNavSelectorEntryALeaf(entry)) {\n            return this.buildLeaf(entry, {\n                multipleModeEnabled,\n                level,\n                idx,\n                totalNumberOfLeaf: totalNumberOfEntry,\n                focusable: true,\n                detailsDisplayedLimit,\n            });\n        } else if (isNavSelectorEntryACategory(entry)) {\n            return this.buildCategory(entry, {\n                multipleModeEnabled,\n                level,\n                idx,\n                totalNumberOfCategory: totalNumberOfEntry,\n                detailsDisplayedLimit,\n            });\n        } else {\n            return this.buildGroup(entry, {\n                multipleModeEnabled,\n                level,\n                idx,\n                totalNumberOfGroups: totalNumberOfEntry,\n                focusable: true,\n                detailsDisplayedLimit,\n            });\n        }\n    }\n\n    private static buildCategoryChildren(\n        entry: NavSelectorCategory,\n        {\n            focusable,\n            multipleModeEnabled,\n            categoryLevel,\n            detailsDisplayedLimit,\n        }: {\n            focusable: boolean;\n            multipleModeEnabled: boolean;\n            categoryLevel: number;\n            detailsDisplayedLimit: number;\n        }\n    ): (InternalNavSelectorGroup | InternalNavSelectorLeaf)[] {\n        return entry.children\n            .map((child, idx) => {\n                if (isNavSelectorEntryALeaf(child)) {\n                    return this.buildLeaf(child, {\n                        focusable,\n                        multipleModeEnabled,\n                        level: categoryLevel + 1,\n                        idx,\n                        totalNumberOfLeaf: entry.children.length,\n                        detailsDisplayedLimit,\n                    });\n                } else {\n                    return this.buildGroup(child, {\n                        focusable,\n                        multipleModeEnabled,\n                        level: categoryLevel + 1,\n                        idx,\n                        totalNumberOfGroups: entry.children.length,\n                        detailsDisplayedLimit,\n                    });\n                }\n            })\n            .filter(it => it !== null);\n    }\n\n    private static buildCategory(\n        node: NavSelectorCategory,\n        {\n            multipleModeEnabled,\n            level,\n            idx,\n            totalNumberOfCategory,\n            detailsDisplayedLimit,\n        }: {\n            multipleModeEnabled: boolean;\n            level: number;\n            idx: number;\n            totalNumberOfCategory: number;\n            detailsDisplayedLimit: number;\n        }\n    ): InternalNavSelectorCategory {\n        const children = this.buildCategoryChildren(node, {\n            focusable: !node.folded,\n            multipleModeEnabled,\n            categoryLevel: level,\n            detailsDisplayedLimit,\n        });\n\n        return {\n            uid: node.uid,\n            alias: node.alias,\n            children,\n            hidden: false,\n            focusable: true,\n            accessibility: {\n                tabIndex: -1,\n                ariaLevel: level,\n                ariaPosinset: idx + 1,\n                ariaSetsize: totalNumberOfCategory,\n            },\n            folded: node.folded,\n            type: node.type,\n        };\n    }\n\n    private static buildGroupChildren(\n        entry: NavSelectorGroup,\n        {\n            multipleModeEnabled,\n            groupLevel,\n            focusable,\n            detailsDisplayedLimit,\n        }: { multipleModeEnabled: boolean; groupLevel: number; focusable: boolean; detailsDisplayedLimit: number }\n    ): InternalNavSelectorLeaf[] {\n        return entry.children\n            .map((child, idx) =>\n                this.buildLeaf(child, {\n                    multipleModeEnabled,\n                    level: groupLevel + 1,\n                    idx,\n                    totalNumberOfLeaf: entry.children.length,\n                    focusable: focusable && !entry.folded,\n                    detailsDisplayedLimit,\n                })\n            )\n            .filter(it => it !== null);\n    }\n\n    private static buildGroup(\n        node: NavSelectorGroup,\n        {\n            focusable,\n            multipleModeEnabled,\n            level,\n            idx,\n            totalNumberOfGroups,\n            detailsDisplayedLimit,\n        }: {\n            focusable: boolean;\n            multipleModeEnabled: boolean;\n            level: number;\n            idx: number;\n            totalNumberOfGroups: number;\n            detailsDisplayedLimit: number;\n        }\n    ): InternalNavSelectorGroup {\n        const children = this.buildGroupChildren(node, { multipleModeEnabled, groupLevel: level, focusable, detailsDisplayedLimit });\n        const displayTokenInvalid = children.some(({ displayTokenInvalid }) => displayTokenInvalid);\n\n        const selectedChildrenCount = children.filter(({ selected }) => selected).length;\n\n        return {\n            uid: node.uid,\n            alias: node.alias,\n            children,\n            childrenPictureUrlSample: children\n                .map((child, idx) =>\n                    isInternalNavSelectorEntryALeaf(child) && idx < 4 ? { url: child.pictureUrl, initial: child.alias[0] } : null\n                )\n                .filter(it => it !== null),\n            hidden: false,\n            accessibility: {\n                tabIndex: -1,\n                ariaPosinset: idx + 1,\n                ariaLevel: level,\n                ariaSetsize: totalNumberOfGroups,\n            },\n            focusable,\n            displayCounter: node.folded && children.some(child => isInternalNavSelectorEntryALeaf(child) && child.counter !== 0),\n            counter: children.reduce((acc, { counter }) => acc + counter, 0),\n            displayTokenInvalid,\n            selected: false,\n            selectable: multipleModeEnabled && children.some(({ selectable }) => selectable),\n            undeterminedSelection: selectedChildrenCount !== children.length && selectedChildrenCount > 0,\n            folded: node.folded,\n            type: node.type,\n        };\n    }\n\n    private static buildLeaf(\n        leaf: NavSelectorLeaf,\n        {\n            focusable,\n            multipleModeEnabled,\n            level,\n            idx,\n            totalNumberOfLeaf,\n            detailsDisplayedLimit,\n        }: {\n            focusable: boolean;\n            multipleModeEnabled: boolean;\n            level: number;\n            idx: number;\n            totalNumberOfLeaf: number;\n            detailsDisplayedLimit: number;\n        }\n    ): InternalNavSelectorLeaf | null {\n        if (leaf.missingPermission) {\n            return null;\n        }\n\n        const detailsDisplayable = this.isLeafLogicValid(leaf, LeafLogics.COUNTER) && !!leaf.details.length;\n        const foldable = !!leaf.details.length && detailsDisplayable;\n        const folded = true;\n        const counter = (leaf.details.reduce((acc, detail) => acc + (detail.counter ?? 0), 0) || leaf.counter) ?? 0;\n        const counterDisplayable = counter !== 0 && this.isLeafLogicValid(leaf, LeafLogics.COUNTER);\n\n        const disabled = leaf.disableReason !== null;\n\n        const viewMoreDisplayable = leaf.details.length > detailsDisplayedLimit;\n\n        return {\n            uid: leaf.uid,\n            alias: leaf.alias,\n            pictureUrl: leaf.pictureUrl,\n            disabled,\n            disableReason: leaf.disableReason,\n            hidden: false,\n            focusable: focusable && !disabled,\n            accessibility: {\n                tabIndex: -1,\n                ariaPosinset: idx + 1,\n                ariaLevel: level,\n                ariaSetsize: totalNumberOfLeaf,\n            },\n            foldable,\n            folded,\n            displayCounter: folded && counterDisplayable,\n            counterDisplayable,\n            counter,\n            network: leaf.network,\n            displayTokenInvalid: leaf.tokenInvalid && this.isLeafLogicValid(leaf, LeafLogics.TOKEN_INVALID, LeafLogics.COUNTER),\n            displayFeatureLocked:\n                leaf.featureLocked && this.isLeafLogicValid(leaf, LeafLogics.FEATURE_LOCKED, LeafLogics.TOKEN_INVALID, LeafLogics.COUNTER),\n            selected: false,\n            selectable: multipleModeEnabled\n                ? this.isLeafLogicValid(leaf, LeafLogics.COUNTER)\n                : this.isLeafLogicValid(leaf, LeafLogics.FEATURE_LOCKED, LeafLogics.TOKEN_INVALID, LeafLogics.COUNTER),\n            detailsDisplayable,\n            details: leaf.details.map(detail => this.buildLeafDetail(detail, level + 1, focusable && !folded)),\n            type: 'LEAF',\n            viewMoreDisplayable,\n            viewMoreDisplayed: viewMoreDisplayable,\n            viewMoreDetailsDisplayedLimit: detailsDisplayedLimit,\n        };\n    }\n\n    private static buildLeafDetail(detail: NavSelectorLeafDetails, level: number, focusable: boolean): InternalNavSelectorLeafDetails {\n        return {\n            uid: detail.uid,\n            counter: detail.counter ?? 0,\n            displayCounter: detail.counter !== null,\n            alias: detail.name,\n            hidden: false,\n            accessibility: {\n                tabIndex: -1,\n                ariaPosinset: 1,\n                ariaLevel: level,\n                ariaSetsize: 1,\n            },\n            focusable,\n            selected: false,\n            errorReason: detail.errorReason,\n            displayError: detail.errorReason !== null,\n            type: 'LEAF_DETAILS',\n        };\n    }\n\n    private static isLeafLogicValid(leaf: NavSelectorLeaf, ...excludes: LeafLogics[]): boolean {\n        return Object.entries(this.LEAF_LOGICS_PRIORITY)\n            .filter(([key]) => !excludes.includes(key as LeafLogics))\n            .every(([, logic]) => !logic(leaf));\n    }\n}\n"]}
|
|
265
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector.builder.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/utils/nav-selector.builder.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    InternalNavSelectorCategory,\n    InternalNavSelectorEntry,\n    InternalNavSelectorGroup,\n    InternalNavSelectorLeaf,\n    InternalNavSelectorLeafDetails,\n    isInternalNavSelectorEntryALeaf,\n    isNavSelectorEntryACategory,\n    isNavSelectorEntryAGroup,\n    isNavSelectorEntryALeaf,\n    NavSelectorCategory,\n    NavSelectorEntry,\n    NavSelectorGroup,\n    NavSelectorLeaf,\n    NavSelectorLeafDetails,\n} from '../nav-selector';\nimport { NavSelectorAccessibility } from '../utils/nav-selector.accessibility';\nimport { NavSelectorMultiSelect } from '../utils/nav-selector.multi-select';\nimport { NavSelectorSingleSelect } from './nav-selector.single-select';\n\nconst LeafLogics = {\n    DISABLED: 'DISABLED',\n    FEATURE_LOCKED: 'FEATURE_LOCKED',\n    TOKEN_INVALID: 'TOKEN_INVALID',\n    COUNTER: 'COUNTER',\n} as const;\ntype LeafLogics = keyof typeof LeafLogics;\n\n/**\n * NavSelectorBuilder is a utility class that builds the NavSelector entries for single and multiple select modes.\n * It also checks the structure of the entries to ensure they are valid.\n */\nexport class NavSelectorBuilder {\n    // /!\\/!\\ Order of logics is important /!\\/!\\\n    private static LEAF_LOGICS_PRIORITY: Record<LeafLogics, (lef: NavSelectorLeaf) => boolean> = {\n        [LeafLogics.DISABLED]: (leaf: NavSelectorLeaf) => leaf.disableReason !== null,\n        [LeafLogics.FEATURE_LOCKED]: (leaf: NavSelectorLeaf) => leaf.featureLocked,\n        [LeafLogics.TOKEN_INVALID]: (leaf: NavSelectorLeaf) => leaf.tokenInvalid,\n        [LeafLogics.COUNTER]: (leaf: NavSelectorLeaf) => leaf.counter !== null,\n    };\n\n    /**\n     * Builds the NavSelector entries for single select mode.\n     * @param entries nav selector entries\n     * @param selectedEntryUid selected entry uid\n     * @param detailsDisplayedLimit number of details displayed limit\n     */\n    static build(entries: NavSelectorEntry[], selectedEntryUid: string | null, detailsDisplayedLimit: number): InternalNavSelectorEntry[] {\n        this.structureChecker(entries);\n        const builtEntries = this.buildEntries(entries, false, 1, detailsDisplayedLimit);\n        if (selectedEntryUid) {\n            return NavSelectorSingleSelect.select(builtEntries, selectedEntryUid);\n        }\n        return builtEntries;\n    }\n\n    /**\n     * Builds the NavSelector entries for multiple select mode.\n     * @param entries nav selector entries\n     * @param selectedEntryUids selected entry uids\n     * @param detailsDisplayedLimit number of details displayed limit\n     */\n    static buildInMultipleMode(\n        entries: NavSelectorEntry[],\n        selectedEntryUids: string[] | null,\n        detailsDisplayedLimit: number\n    ): InternalNavSelectorEntry[] {\n        this.structureChecker(entries, true);\n        let builtEntries = this.buildEntries(entries, true, 1, detailsDisplayedLimit);\n        if (selectedEntryUids) {\n            for (const selectedEntryUid of selectedEntryUids) {\n                builtEntries = NavSelectorMultiSelect.selectInMultipleMode(builtEntries, selectedEntryUid);\n            }\n        }\n        return builtEntries;\n    }\n\n    private static structureChecker(entries: NavSelectorEntry[], multipleModeEnabled = false): void {\n        entries.forEach(entry => {\n            if (isNavSelectorEntryAGroup(entry) || isNavSelectorEntryACategory(entry)) {\n                this.structureChecker(entry.children, multipleModeEnabled);\n            } else if (isNavSelectorEntryALeaf(entry)) {\n                if (entry.details.length && multipleModeEnabled) {\n                    console.error(`NavSelectorBuilder: Leaf ${entry.uid} with details is not allowed in multiple mode`);\n                }\n            }\n        });\n    }\n\n    private static buildEntries(\n        entries: NavSelectorEntry[],\n        multipleModeEnabled: boolean,\n        level = 1,\n        detailsDisplayedLimit: number\n    ): InternalNavSelectorEntry[] {\n        const newEntries = entries\n            .map((entry, idx) =>\n                this.buildEntry(entry, { multipleModeEnabled, level, idx, totalNumberOfEntry: entries.length, detailsDisplayedLimit })\n            )\n            .filter(it => it !== null);\n        return NavSelectorAccessibility.resetFocus(newEntries);\n    }\n\n    private static buildEntry(\n        entry: NavSelectorEntry,\n        {\n            multipleModeEnabled,\n            level,\n            idx,\n            totalNumberOfEntry,\n            detailsDisplayedLimit,\n        }: { multipleModeEnabled: boolean; level: number; idx: number; totalNumberOfEntry: number; detailsDisplayedLimit: number }\n    ): InternalNavSelectorEntry | null {\n        if (isNavSelectorEntryALeaf(entry)) {\n            return this.buildLeaf(entry, {\n                multipleModeEnabled,\n                level,\n                idx,\n                totalNumberOfLeaf: totalNumberOfEntry,\n                focusable: true,\n                detailsDisplayedLimit,\n            });\n        } else if (isNavSelectorEntryACategory(entry)) {\n            return this.buildCategory(entry, {\n                multipleModeEnabled,\n                level,\n                idx,\n                totalNumberOfCategory: totalNumberOfEntry,\n                detailsDisplayedLimit,\n            });\n        } else {\n            return this.buildGroup(entry, {\n                multipleModeEnabled,\n                level,\n                idx,\n                totalNumberOfGroups: totalNumberOfEntry,\n                focusable: true,\n                detailsDisplayedLimit,\n            });\n        }\n    }\n\n    private static buildCategoryChildren(\n        entry: NavSelectorCategory,\n        {\n            focusable,\n            multipleModeEnabled,\n            categoryLevel,\n            detailsDisplayedLimit,\n        }: {\n            focusable: boolean;\n            multipleModeEnabled: boolean;\n            categoryLevel: number;\n            detailsDisplayedLimit: number;\n        }\n    ): (InternalNavSelectorGroup | InternalNavSelectorLeaf)[] {\n        return entry.children\n            .map((child, idx) => {\n                if (isNavSelectorEntryALeaf(child)) {\n                    return this.buildLeaf(child, {\n                        focusable,\n                        multipleModeEnabled,\n                        level: categoryLevel + 1,\n                        idx,\n                        totalNumberOfLeaf: entry.children.length,\n                        detailsDisplayedLimit,\n                    });\n                } else {\n                    return this.buildGroup(child, {\n                        focusable,\n                        multipleModeEnabled,\n                        level: categoryLevel + 1,\n                        idx,\n                        totalNumberOfGroups: entry.children.length,\n                        detailsDisplayedLimit,\n                    });\n                }\n            })\n            .filter(it => it !== null);\n    }\n\n    private static buildCategory(\n        node: NavSelectorCategory,\n        {\n            multipleModeEnabled,\n            level,\n            idx,\n            totalNumberOfCategory,\n            detailsDisplayedLimit,\n        }: {\n            multipleModeEnabled: boolean;\n            level: number;\n            idx: number;\n            totalNumberOfCategory: number;\n            detailsDisplayedLimit: number;\n        }\n    ): InternalNavSelectorCategory {\n        const children = this.buildCategoryChildren(node, {\n            focusable: !node.folded,\n            multipleModeEnabled,\n            categoryLevel: level,\n            detailsDisplayedLimit,\n        });\n\n        return {\n            uid: node.uid,\n            alias: node.alias,\n            children,\n            hidden: false,\n            focusable: true,\n            accessibility: {\n                tabIndex: -1,\n                ariaLevel: level,\n                ariaPosinset: idx + 1,\n                ariaSetsize: totalNumberOfCategory,\n            },\n            folded: node.folded,\n            type: node.type,\n        };\n    }\n\n    private static buildGroupChildren(\n        entry: NavSelectorGroup,\n        {\n            multipleModeEnabled,\n            groupLevel,\n            focusable,\n            detailsDisplayedLimit,\n        }: { multipleModeEnabled: boolean; groupLevel: number; focusable: boolean; detailsDisplayedLimit: number }\n    ): InternalNavSelectorLeaf[] {\n        return entry.children\n            .map((child, idx) =>\n                this.buildLeaf(child, {\n                    multipleModeEnabled,\n                    level: groupLevel + 1,\n                    idx,\n                    totalNumberOfLeaf: entry.children.length,\n                    focusable: focusable && !entry.folded,\n                    detailsDisplayedLimit,\n                })\n            )\n            .filter(it => it !== null);\n    }\n\n    private static buildGroup(\n        node: NavSelectorGroup,\n        {\n            focusable,\n            multipleModeEnabled,\n            level,\n            idx,\n            totalNumberOfGroups,\n            detailsDisplayedLimit,\n        }: {\n            focusable: boolean;\n            multipleModeEnabled: boolean;\n            level: number;\n            idx: number;\n            totalNumberOfGroups: number;\n            detailsDisplayedLimit: number;\n        }\n    ): InternalNavSelectorGroup {\n        const children = this.buildGroupChildren(node, { multipleModeEnabled, groupLevel: level, focusable, detailsDisplayedLimit });\n        const displayTokenInvalid = children.some(({ displayTokenInvalid }) => displayTokenInvalid);\n\n        const selectedChildrenCount = children.filter(({ selected }) => selected).length;\n\n        return {\n            uid: node.uid,\n            alias: node.alias,\n            children,\n            childrenPictureUrlSample: children\n                .map((child, idx) =>\n                    isInternalNavSelectorEntryALeaf(child) && idx < 4 ? { url: child.pictureUrl, initial: child.alias[0] } : null\n                )\n                .filter(it => it !== null),\n            hidden: false,\n            accessibility: {\n                tabIndex: -1,\n                ariaPosinset: idx + 1,\n                ariaLevel: level,\n                ariaSetsize: totalNumberOfGroups,\n            },\n            focusable,\n            displayCounter: node.folded && children.some(child => isInternalNavSelectorEntryALeaf(child) && child.counter !== 0),\n            counter: children.reduce((acc, { counter }) => acc + counter, 0),\n            displayTokenInvalid,\n            selected: false,\n            selectable: multipleModeEnabled && children.some(({ selectable }) => selectable),\n            undeterminedSelection: selectedChildrenCount !== children.length && selectedChildrenCount > 0,\n            folded: node.folded,\n            type: node.type,\n        };\n    }\n\n    private static buildLeaf(\n        leaf: NavSelectorLeaf,\n        {\n            focusable,\n            multipleModeEnabled,\n            level,\n            idx,\n            totalNumberOfLeaf,\n            detailsDisplayedLimit,\n        }: {\n            focusable: boolean;\n            multipleModeEnabled: boolean;\n            level: number;\n            idx: number;\n            totalNumberOfLeaf: number;\n            detailsDisplayedLimit: number;\n        }\n    ): InternalNavSelectorLeaf | null {\n        if (leaf.missingPermission) {\n            return null;\n        }\n\n        const detailsDisplayable = this.isLeafLogicValid(leaf, LeafLogics.COUNTER) && !!leaf.details.length;\n        const foldable = !!leaf.details.length && detailsDisplayable;\n        const folded = true;\n        const counter = (leaf.details.reduce((acc, detail) => acc + (detail.counter ?? 0), 0) || leaf.counter) ?? 0;\n        const counterDisplayable = counter !== 0 && this.isLeafLogicValid(leaf, LeafLogics.COUNTER);\n\n        const disabled = leaf.disableReason !== null;\n\n        const viewMoreDisplayable = leaf.details.length > detailsDisplayedLimit;\n\n        return {\n            uid: leaf.uid,\n            alias: leaf.alias,\n            pictureUrl: leaf.pictureUrl,\n            actionsDisplayable: this.isLeafLogicValid(leaf, LeafLogics.COUNTER),\n            disabled,\n            disableReason: leaf.disableReason,\n            hidden: false,\n            focusable:\n                focusable &&\n                ((multipleModeEnabled && this.isLeafLogicValid(leaf, LeafLogics.COUNTER)) || (!multipleModeEnabled && !disabled)),\n            accessibility: {\n                tabIndex: -1,\n                ariaPosinset: idx + 1,\n                ariaLevel: level,\n                ariaSetsize: totalNumberOfLeaf,\n            },\n            foldable,\n            folded,\n            displayCounter: folded && counterDisplayable,\n            counterDisplayable,\n            counter,\n            network: leaf.network,\n            displayTokenInvalid: leaf.tokenInvalid && this.isLeafLogicValid(leaf, LeafLogics.TOKEN_INVALID, LeafLogics.COUNTER),\n            displayFeatureLocked:\n                leaf.featureLocked && this.isLeafLogicValid(leaf, LeafLogics.FEATURE_LOCKED, LeafLogics.TOKEN_INVALID, LeafLogics.COUNTER),\n            selected: false,\n            selectable: multipleModeEnabled\n                ? this.isLeafLogicValid(leaf, LeafLogics.COUNTER)\n                : this.isLeafLogicValid(leaf, LeafLogics.FEATURE_LOCKED, LeafLogics.TOKEN_INVALID, LeafLogics.COUNTER),\n            detailsDisplayable,\n            details: leaf.details.map(detail => this.buildLeafDetail(detail, level + 1, focusable && !folded)),\n            type: 'LEAF',\n            viewMoreDisplayable,\n            viewMoreDisplayed: viewMoreDisplayable,\n            viewMoreDetailsDisplayedLimit: detailsDisplayedLimit,\n        };\n    }\n\n    private static buildLeafDetail(detail: NavSelectorLeafDetails, level: number, focusable: boolean): InternalNavSelectorLeafDetails {\n        return {\n            uid: detail.uid,\n            counter: detail.counter ?? 0,\n            displayCounter: detail.counter !== null,\n            alias: detail.name,\n            hidden: false,\n            accessibility: {\n                tabIndex: -1,\n                ariaPosinset: 1,\n                ariaLevel: level,\n                ariaSetsize: 1,\n            },\n            focusable,\n            selected: false,\n            errorReason: detail.errorReason,\n            displayError: detail.errorReason !== null,\n            type: 'LEAF_DETAILS',\n        };\n    }\n\n    private static isLeafLogicValid(leaf: NavSelectorLeaf, ...excludes: LeafLogics[]): boolean {\n        return Object.entries(this.LEAF_LOGICS_PRIORITY)\n            .filter(([key]) => !excludes.includes(key as LeafLogics))\n            .every(([, logic]) => !logic(leaf));\n    }\n}\n"]}
|