@agorapulse/ui-components 18.0.9 → 18.0.11
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.11.tgz +0 -0
- package/esm2022/datepicker/datepicker.component.mjs +1 -1
- package/esm2022/index.mjs +2 -1
- package/esm2022/input-search/input-search.component.mjs +5 -4
- package/esm2022/nav-selector/agorapulse-ui-components-nav-selector.mjs +5 -0
- package/esm2022/nav-selector/directives/tree-node-accessibility.directive.mjs +30 -0
- package/esm2022/nav-selector/nav-selector-category/nav-selector-category.component.mjs +81 -0
- package/esm2022/nav-selector/nav-selector-category/nav-selector-category.presenter.mjs +29 -0
- package/esm2022/nav-selector/nav-selector-group/nav-selector-group.component.mjs +142 -0
- package/esm2022/nav-selector/nav-selector-group/nav-selector-group.presenter.mjs +31 -0
- package/esm2022/nav-selector/nav-selector-leaf/nav-selector-leaf.component.mjs +240 -0
- package/esm2022/nav-selector/nav-selector-leaf/nav-selector-leaf.presenter.mjs +35 -0
- package/esm2022/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.component.mjs +39 -0
- package/esm2022/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.presenter.mjs +18 -0
- package/esm2022/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.component.mjs +92 -0
- package/esm2022/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.presenter.mjs +31 -0
- package/esm2022/nav-selector/nav-selector.component.mjs +123 -0
- package/esm2022/nav-selector/nav-selector.mjs +9 -0
- package/esm2022/nav-selector/nav-selector.state.mjs +173 -0
- package/esm2022/nav-selector/public_api.mjs +2 -0
- package/esm2022/nav-selector/utils/leaf.utils.mjs +10 -0
- package/esm2022/nav-selector/utils/nav-selector.accessibility.mjs +171 -0
- package/esm2022/nav-selector/utils/nav-selector.builder.mjs +263 -0
- package/esm2022/nav-selector/utils/nav-selector.filter.mjs +102 -0
- package/esm2022/nav-selector/utils/nav-selector.folding.mjs +219 -0
- package/esm2022/nav-selector/utils/nav-selector.minifying.mjs +50 -0
- package/esm2022/nav-selector/utils/nav-selector.multi-select.mjs +208 -0
- package/esm2022/nav-selector/utils/nav-selector.single-select.mjs +91 -0
- package/esm2022/nav-selector/utils/nav-selector.view-more.mjs +98 -0
- package/fesm2022/agorapulse-ui-components-datepicker.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-input-search.mjs +4 -3
- package/fesm2022/agorapulse-ui-components-input-search.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-nav-selector.mjs +2198 -0
- package/fesm2022/agorapulse-ui-components-nav-selector.mjs.map +1 -0
- package/fesm2022/agorapulse-ui-components.mjs +1 -0
- package/fesm2022/agorapulse-ui-components.mjs.map +1 -1
- package/index.d.ts +1 -0
- package/input-search/input-search.component.d.ts +1 -1
- package/nav-selector/directives/tree-node-accessibility.directive.d.ts +9 -0
- package/nav-selector/index.d.ts +5 -0
- package/nav-selector/nav-selector-category/nav-selector-category.component.d.ts +16 -0
- package/nav-selector/nav-selector-category/nav-selector-category.presenter.d.ts +14 -0
- package/nav-selector/nav-selector-group/nav-selector-group.component.d.ts +29 -0
- package/nav-selector/nav-selector-group/nav-selector-group.presenter.d.ts +17 -0
- package/nav-selector/nav-selector-leaf/nav-selector-leaf.component.d.ts +51 -0
- package/nav-selector/nav-selector-leaf/nav-selector-leaf.presenter.d.ts +19 -0
- package/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.component.d.ts +13 -0
- package/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.presenter.d.ts +10 -0
- package/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.component.d.ts +24 -0
- package/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.presenter.d.ts +14 -0
- package/nav-selector/nav-selector.component.d.ts +29 -0
- package/nav-selector/nav-selector.d.ts +220 -0
- package/nav-selector/nav-selector.state.d.ts +47 -0
- package/nav-selector/public_api.d.ts +2 -0
- package/nav-selector/utils/leaf.utils.d.ts +5 -0
- package/nav-selector/utils/nav-selector.accessibility.d.ts +52 -0
- package/nav-selector/utils/nav-selector.builder.d.ts +32 -0
- package/nav-selector/utils/nav-selector.filter.d.ts +30 -0
- package/nav-selector/utils/nav-selector.folding.d.ts +47 -0
- package/nav-selector/utils/nav-selector.minifying.d.ts +27 -0
- package/nav-selector/utils/nav-selector.multi-select.d.ts +54 -0
- package/nav-selector/utils/nav-selector.single-select.d.ts +15 -0
- package/nav-selector/utils/nav-selector.view-more.d.ts +30 -0
- package/package.json +13 -7
- package/agorapulse-ui-components-18.0.9.tgz +0 -0
|
@@ -0,0 +1,219 @@
|
|
|
1
|
+
import { isInternalNavSelectorEntryACategory, isInternalNavSelectorEntryAGroup, isInternalNavSelectorEntryALeaf, } from '../nav-selector';
|
|
2
|
+
import { isInternalNavSelectorEntryALeafFocusable } from '../utils/leaf.utils';
|
|
3
|
+
/**
|
|
4
|
+
* Class to handle the folding and unfolding of nav selector entries.
|
|
5
|
+
*/
|
|
6
|
+
export class NavSelectorFolding {
|
|
7
|
+
/**
|
|
8
|
+
* Toggle the folding state of an entry.
|
|
9
|
+
*
|
|
10
|
+
* @see {@link NavSelectorFolding.fold} and {@link NavSelectorFolding.unfold} for more information on folding and unfolding.
|
|
11
|
+
*
|
|
12
|
+
* @param entries nav selector entries
|
|
13
|
+
* @param entryUid the entry uid to toggle
|
|
14
|
+
* @param minified true if the nav selector is minified. Needed for leaf as they are not foldable in minified mode
|
|
15
|
+
*/
|
|
16
|
+
static toggleFolding(entries, entryUid, minified) {
|
|
17
|
+
return this.toggleEntryFolding(entries, entryUid, minified);
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Fold an entry.
|
|
21
|
+
*
|
|
22
|
+
* Set unfocusable on all children of the folded entry.
|
|
23
|
+
* Compute whenever the counter and token invalid should be displayed on groups and leaves.
|
|
24
|
+
*
|
|
25
|
+
* @param entries nav selector entries
|
|
26
|
+
* @param entryUid the entry uid to fold
|
|
27
|
+
* @param minified true if the nav selector is minified. Needed for leaf as they are not foldable in minified mode
|
|
28
|
+
*/
|
|
29
|
+
static fold(entries, entryUid, minified) {
|
|
30
|
+
return this.foldEntry(entries, entryUid, minified);
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Unfold an entry.
|
|
34
|
+
*
|
|
35
|
+
* Set focusable on all children of the folded entry.
|
|
36
|
+
* Compute whenever the counter and token invalid should be displayed on groups and leaves.
|
|
37
|
+
*
|
|
38
|
+
* @param entries nav selector entries
|
|
39
|
+
* @param entryUid the entry uid to unfold
|
|
40
|
+
* @param minified true if the nav selector is minified. Needed for leaf as they are not foldable in minified mode
|
|
41
|
+
*/
|
|
42
|
+
static unfold(entries, entryUid, minified) {
|
|
43
|
+
return this.unfoldEntry(entries, entryUid, minified);
|
|
44
|
+
}
|
|
45
|
+
static toggleEntryFolding(entries, entryUid, minified, parentFolded = false) {
|
|
46
|
+
return entries.map(entry => {
|
|
47
|
+
if (isInternalNavSelectorEntryACategory(entry)) {
|
|
48
|
+
if (entry.uid === entryUid) {
|
|
49
|
+
const folded = !entry.folded;
|
|
50
|
+
if (folded) {
|
|
51
|
+
return this.foldCategory(entry, minified);
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
return this.unfoldCategory(entry, minified);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
return {
|
|
58
|
+
...entry,
|
|
59
|
+
children: this.toggleEntryFolding(entry.children, entryUid, minified, entry.folded),
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
if (isInternalNavSelectorEntryAGroup(entry)) {
|
|
63
|
+
if (entry.uid === entryUid) {
|
|
64
|
+
const folded = !entry.folded;
|
|
65
|
+
if (folded) {
|
|
66
|
+
return this.foldGroup(entry, minified);
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
return this.unfoldGroup(entry, minified);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
return {
|
|
73
|
+
...entry,
|
|
74
|
+
children: this.toggleEntryFolding(entry.children, entryUid, minified, parentFolded || entry.folded),
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
if (isInternalNavSelectorEntryALeaf(entry)) {
|
|
78
|
+
if (entry.uid === entryUid) {
|
|
79
|
+
const folded = !entry.folded;
|
|
80
|
+
if (folded) {
|
|
81
|
+
return this.foldLeaf(entry, minified);
|
|
82
|
+
}
|
|
83
|
+
else {
|
|
84
|
+
return this.unfoldLeaf(entry, minified);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
return {
|
|
88
|
+
...entry,
|
|
89
|
+
focusable: isInternalNavSelectorEntryALeafFocusable(entry, { minified, parentFolded }),
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
return { ...entry, focusable: !parentFolded };
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
static foldEntry(entries, entryUid, minified, parentFolded = false) {
|
|
96
|
+
return entries.map(entry => {
|
|
97
|
+
if (isInternalNavSelectorEntryACategory(entry)) {
|
|
98
|
+
if (entry.uid === entryUid) {
|
|
99
|
+
return this.foldCategory(entry, minified);
|
|
100
|
+
}
|
|
101
|
+
return {
|
|
102
|
+
...entry,
|
|
103
|
+
children: this.foldEntry(entry.children, entryUid, minified, entry.folded),
|
|
104
|
+
};
|
|
105
|
+
}
|
|
106
|
+
if (isInternalNavSelectorEntryAGroup(entry)) {
|
|
107
|
+
if (entry.uid === entryUid) {
|
|
108
|
+
return this.foldGroup(entry, minified);
|
|
109
|
+
}
|
|
110
|
+
return {
|
|
111
|
+
...entry,
|
|
112
|
+
focusable: !parentFolded,
|
|
113
|
+
children: this.foldEntry(entry.children, entryUid, minified, parentFolded || entry.folded),
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
if (isInternalNavSelectorEntryALeaf(entry)) {
|
|
117
|
+
if (entry.uid === entryUid) {
|
|
118
|
+
return this.foldLeaf(entry, minified);
|
|
119
|
+
}
|
|
120
|
+
return {
|
|
121
|
+
...entry,
|
|
122
|
+
focusable: isInternalNavSelectorEntryALeafFocusable(entry, { minified, parentFolded }),
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
return { ...entry, focusable: !parentFolded };
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
static unfoldEntry(entries, entryUid, minified, parentFolded = false) {
|
|
129
|
+
return entries.map(entry => {
|
|
130
|
+
if (isInternalNavSelectorEntryACategory(entry)) {
|
|
131
|
+
if (entry.uid === entryUid) {
|
|
132
|
+
return this.unfoldCategory(entry, minified);
|
|
133
|
+
}
|
|
134
|
+
return {
|
|
135
|
+
...entry,
|
|
136
|
+
children: this.unfoldEntry(entry.children, entryUid, minified, entry.folded),
|
|
137
|
+
};
|
|
138
|
+
}
|
|
139
|
+
if (isInternalNavSelectorEntryAGroup(entry)) {
|
|
140
|
+
if (entry.uid === entryUid) {
|
|
141
|
+
return this.unfoldGroup(entry, minified);
|
|
142
|
+
}
|
|
143
|
+
return {
|
|
144
|
+
...entry,
|
|
145
|
+
children: this.unfoldEntry(entry.children, entryUid, minified, parentFolded || entry.folded),
|
|
146
|
+
focusable: !parentFolded,
|
|
147
|
+
};
|
|
148
|
+
}
|
|
149
|
+
if (isInternalNavSelectorEntryALeaf(entry)) {
|
|
150
|
+
if (entry.uid === entryUid) {
|
|
151
|
+
return this.unfoldLeaf(entry, minified);
|
|
152
|
+
}
|
|
153
|
+
return {
|
|
154
|
+
...entry,
|
|
155
|
+
focusable: isInternalNavSelectorEntryALeafFocusable(entry, { minified, parentFolded }),
|
|
156
|
+
};
|
|
157
|
+
}
|
|
158
|
+
return { ...entry, focusable: !parentFolded };
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
static foldCategory(category, minified) {
|
|
162
|
+
return {
|
|
163
|
+
...category,
|
|
164
|
+
folded: true,
|
|
165
|
+
children: this.foldEntry(category.children, category.uid, minified, true),
|
|
166
|
+
};
|
|
167
|
+
}
|
|
168
|
+
static unfoldCategory(category, minified) {
|
|
169
|
+
return {
|
|
170
|
+
...category,
|
|
171
|
+
folded: false,
|
|
172
|
+
children: this.unfoldEntry(category.children, category.uid, minified, false),
|
|
173
|
+
};
|
|
174
|
+
}
|
|
175
|
+
static foldGroup(group, minified) {
|
|
176
|
+
return {
|
|
177
|
+
...group,
|
|
178
|
+
folded: true,
|
|
179
|
+
children: this.foldEntry(group.children, group.uid, minified, true),
|
|
180
|
+
displayCounter: !!group.counter,
|
|
181
|
+
displayTokenInvalid: group.children.some(({ displayTokenInvalid }) => displayTokenInvalid),
|
|
182
|
+
};
|
|
183
|
+
}
|
|
184
|
+
static unfoldGroup(group, minified) {
|
|
185
|
+
return {
|
|
186
|
+
...group,
|
|
187
|
+
folded: false,
|
|
188
|
+
children: this.unfoldEntry(group.children, group.uid, minified, false),
|
|
189
|
+
displayCounter: false,
|
|
190
|
+
displayTokenInvalid: false,
|
|
191
|
+
};
|
|
192
|
+
}
|
|
193
|
+
static foldLeaf(leaf, minified) {
|
|
194
|
+
if (!leaf.foldable || minified) {
|
|
195
|
+
return leaf;
|
|
196
|
+
}
|
|
197
|
+
return {
|
|
198
|
+
...leaf,
|
|
199
|
+
displayCounter: true,
|
|
200
|
+
folded: true,
|
|
201
|
+
details: leaf.details.map(detail => ({ ...detail, focusable: false })),
|
|
202
|
+
};
|
|
203
|
+
}
|
|
204
|
+
static unfoldLeaf(leaf, minified) {
|
|
205
|
+
if (!leaf.foldable || minified) {
|
|
206
|
+
return leaf;
|
|
207
|
+
}
|
|
208
|
+
return {
|
|
209
|
+
...leaf,
|
|
210
|
+
displayCounter: false,
|
|
211
|
+
folded: false,
|
|
212
|
+
details: leaf.details.map((detail, idx) => ({
|
|
213
|
+
...detail,
|
|
214
|
+
focusable: idx < leaf.viewMoreDetailsDisplayedLimit,
|
|
215
|
+
})),
|
|
216
|
+
};
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector.folding.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/utils/nav-selector.folding.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    InternalNavSelectorCategory,\n    InternalNavSelectorEntry,\n    InternalNavSelectorGroup,\n    InternalNavSelectorLeaf,\n    isInternalNavSelectorEntryACategory,\n    isInternalNavSelectorEntryAGroup,\n    isInternalNavSelectorEntryALeaf,\n} from '../nav-selector';\nimport { isInternalNavSelectorEntryALeafFocusable } from '../utils/leaf.utils';\n\n/**\n * Class to handle the folding and unfolding of nav selector entries.\n */\nexport class NavSelectorFolding {\n    /**\n     * Toggle the folding state of an entry.\n     *\n     * @see {@link NavSelectorFolding.fold} and {@link NavSelectorFolding.unfold} for more information on folding and unfolding.\n     *\n     * @param entries nav selector entries\n     * @param entryUid the entry uid to toggle\n     * @param minified true if the nav selector is minified. Needed for leaf as they are not foldable in minified mode\n     */\n    static toggleFolding<T extends InternalNavSelectorEntry>(\n        entries: T[],\n        entryUid: string,\n        minified: boolean\n    ): InternalNavSelectorEntry[] {\n        return this.toggleEntryFolding(entries, entryUid, minified);\n    }\n\n    /**\n     * Fold an entry.\n     *\n     * Set unfocusable on all children of the folded entry.\n     * Compute whenever the counter and token invalid should be displayed on groups and leaves.\n     *\n     * @param entries nav selector entries\n     * @param entryUid the entry uid to fold\n     * @param minified true if the nav selector is minified. Needed for leaf as they are not foldable in minified mode\n     */\n    static fold<T extends InternalNavSelectorEntry>(entries: T[], entryUid: string, minified: boolean): InternalNavSelectorEntry[] {\n        return this.foldEntry(entries, entryUid, minified);\n    }\n\n    /**\n     * Unfold an entry.\n     *\n     * Set focusable on all children of the folded entry.\n     * Compute whenever the counter and token invalid should be displayed on groups and leaves.\n     *\n     * @param entries nav selector entries\n     * @param entryUid the entry uid to unfold\n     * @param minified true if the nav selector is minified. Needed for leaf as they are not foldable in minified mode\n     */\n    static unfold<T extends InternalNavSelectorEntry>(entries: T[], entryUid: string, minified: boolean): InternalNavSelectorEntry[] {\n        return this.unfoldEntry(entries, entryUid, minified);\n    }\n\n    private static toggleEntryFolding<T extends InternalNavSelectorEntry>(\n        entries: T[],\n        entryUid: string,\n        minified: boolean,\n        parentFolded = false\n    ): InternalNavSelectorEntry[] {\n        return entries.map(entry => {\n            if (isInternalNavSelectorEntryACategory(entry)) {\n                if (entry.uid === entryUid) {\n                    const folded = !entry.folded;\n                    if (folded) {\n                        return this.foldCategory(entry, minified);\n                    } else {\n                        return this.unfoldCategory(entry, minified);\n                    }\n                }\n                return {\n                    ...entry,\n                    children: this.toggleEntryFolding(entry.children, entryUid, minified, entry.folded),\n                };\n            }\n            if (isInternalNavSelectorEntryAGroup(entry)) {\n                if (entry.uid === entryUid) {\n                    const folded = !entry.folded;\n                    if (folded) {\n                        return this.foldGroup(entry, minified);\n                    } else {\n                        return this.unfoldGroup(entry, minified);\n                    }\n                }\n                return {\n                    ...entry,\n                    children: this.toggleEntryFolding(entry.children, entryUid, minified, parentFolded || entry.folded),\n                };\n            }\n            if (isInternalNavSelectorEntryALeaf(entry)) {\n                if (entry.uid === entryUid) {\n                    const folded = !entry.folded;\n                    if (folded) {\n                        return this.foldLeaf(entry, minified);\n                    } else {\n                        return this.unfoldLeaf(entry, minified);\n                    }\n                }\n                return {\n                    ...entry,\n                    focusable: isInternalNavSelectorEntryALeafFocusable(entry, { minified, parentFolded }),\n                };\n            }\n            return { ...entry, focusable: !parentFolded };\n        });\n    }\n\n    private static foldEntry<T extends InternalNavSelectorEntry>(\n        entries: T[],\n        entryUid: string,\n        minified: boolean,\n        parentFolded = false\n    ): InternalNavSelectorEntry[] {\n        return entries.map(entry => {\n            if (isInternalNavSelectorEntryACategory(entry)) {\n                if (entry.uid === entryUid) {\n                    return this.foldCategory(entry, minified);\n                }\n                return {\n                    ...entry,\n                    children: this.foldEntry(entry.children, entryUid, minified, entry.folded),\n                };\n            }\n            if (isInternalNavSelectorEntryAGroup(entry)) {\n                if (entry.uid === entryUid) {\n                    return this.foldGroup(entry, minified);\n                }\n                return {\n                    ...entry,\n                    focusable: !parentFolded,\n                    children: this.foldEntry(entry.children, entryUid, minified, parentFolded || entry.folded),\n                };\n            }\n            if (isInternalNavSelectorEntryALeaf(entry)) {\n                if (entry.uid === entryUid) {\n                    return this.foldLeaf(entry, minified);\n                }\n                return {\n                    ...entry,\n                    focusable: isInternalNavSelectorEntryALeafFocusable(entry, { minified, parentFolded }),\n                };\n            }\n            return { ...entry, focusable: !parentFolded };\n        });\n    }\n\n    private static unfoldEntry<T extends InternalNavSelectorEntry>(\n        entries: T[],\n        entryUid: string,\n        minified: boolean,\n        parentFolded = false\n    ): InternalNavSelectorEntry[] {\n        return entries.map(entry => {\n            if (isInternalNavSelectorEntryACategory(entry)) {\n                if (entry.uid === entryUid) {\n                    return this.unfoldCategory(entry, minified);\n                }\n                return {\n                    ...entry,\n                    children: this.unfoldEntry(entry.children, entryUid, minified, entry.folded),\n                };\n            }\n            if (isInternalNavSelectorEntryAGroup(entry)) {\n                if (entry.uid === entryUid) {\n                    return this.unfoldGroup(entry, minified);\n                }\n                return {\n                    ...entry,\n                    children: this.unfoldEntry(entry.children, entryUid, minified, parentFolded || entry.folded),\n                    focusable: !parentFolded,\n                };\n            }\n            if (isInternalNavSelectorEntryALeaf(entry)) {\n                if (entry.uid === entryUid) {\n                    return this.unfoldLeaf(entry, minified);\n                }\n                return {\n                    ...entry,\n                    focusable: isInternalNavSelectorEntryALeafFocusable(entry, { minified, parentFolded }),\n                };\n            }\n            return { ...entry, focusable: !parentFolded };\n        });\n    }\n\n    private static foldCategory(category: InternalNavSelectorCategory, minified: boolean): InternalNavSelectorCategory {\n        return {\n            ...category,\n            folded: true,\n            children: this.foldEntry(category.children, category.uid, minified, true) as (\n                | InternalNavSelectorLeaf\n                | InternalNavSelectorGroup\n            )[],\n        };\n    }\n\n    private static unfoldCategory(category: InternalNavSelectorCategory, minified: boolean): InternalNavSelectorCategory {\n        return {\n            ...category,\n            folded: false,\n            children: this.unfoldEntry(category.children, category.uid, minified, false) as (\n                | InternalNavSelectorLeaf\n                | InternalNavSelectorGroup\n            )[],\n        };\n    }\n\n    private static foldGroup(group: InternalNavSelectorGroup, minified: boolean): InternalNavSelectorGroup {\n        return {\n            ...group,\n            folded: true,\n            children: this.foldEntry(group.children, group.uid, minified, true) as InternalNavSelectorLeaf[],\n            displayCounter: !!group.counter,\n            displayTokenInvalid: group.children.some(({ displayTokenInvalid }) => displayTokenInvalid),\n        };\n    }\n\n    private static unfoldGroup(group: InternalNavSelectorGroup, minified: boolean): InternalNavSelectorGroup {\n        return {\n            ...group,\n            folded: false,\n            children: this.unfoldEntry(group.children, group.uid, minified, false) as InternalNavSelectorLeaf[],\n            displayCounter: false,\n            displayTokenInvalid: false,\n        };\n    }\n\n    private static foldLeaf(leaf: InternalNavSelectorLeaf, minified: boolean): InternalNavSelectorLeaf {\n        if (!leaf.foldable || minified) {\n            return leaf;\n        }\n        return {\n            ...leaf,\n            displayCounter: true,\n            folded: true,\n            details: leaf.details.map(detail => ({ ...detail, focusable: false })),\n        };\n    }\n\n    private static unfoldLeaf(leaf: InternalNavSelectorLeaf, minified: boolean): InternalNavSelectorLeaf {\n        if (!leaf.foldable || minified) {\n            return leaf;\n        }\n        return {\n            ...leaf,\n            displayCounter: false,\n            folded: false,\n            details: leaf.details.map((detail, idx) => ({\n                ...detail,\n                focusable: idx < leaf.viewMoreDetailsDisplayedLimit,\n            })),\n        };\n    }\n}\n"]}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { isInternalNavSelectorEntryALeafDetails, isInternalNavSelectorEntryANode, } from '../nav-selector';
|
|
2
|
+
import { isInternalNavSelectorEntryALeafFocusable } from '../utils/leaf.utils';
|
|
3
|
+
/**
|
|
4
|
+
* NavSelectorMinifying is a utility class that provides methods to apply rules on entries when minifying or expanded nav selector.
|
|
5
|
+
*/
|
|
6
|
+
export class NavSelectorMinifying {
|
|
7
|
+
/**
|
|
8
|
+
* When minifying the nav selector, compute the focusable state of the entries.
|
|
9
|
+
*
|
|
10
|
+
* Leaf are not focusable in any error state when minified.
|
|
11
|
+
* Detail are not focusable when minified.
|
|
12
|
+
*
|
|
13
|
+
* @param entries The entries to minify.
|
|
14
|
+
* @returns The modified entries.
|
|
15
|
+
*/
|
|
16
|
+
static minify(entries) {
|
|
17
|
+
return this.compute(entries, true);
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* When expanding the nav selector, compute the focusable state of the entries.
|
|
21
|
+
*
|
|
22
|
+
* Leaf are not focusable in disabled state when expanded.
|
|
23
|
+
* Detail are focusable when expanded.
|
|
24
|
+
*
|
|
25
|
+
* @param entries The entries to minify.
|
|
26
|
+
* @returns The modified entries.
|
|
27
|
+
*/
|
|
28
|
+
static expand(entries) {
|
|
29
|
+
return this.compute(entries, false);
|
|
30
|
+
}
|
|
31
|
+
static compute(entries, minified, parent = null) {
|
|
32
|
+
return entries.map(entry => {
|
|
33
|
+
if (isInternalNavSelectorEntryALeafDetails(entry)) {
|
|
34
|
+
return { ...entry, focusable: !minified };
|
|
35
|
+
}
|
|
36
|
+
if (isInternalNavSelectorEntryANode(entry)) {
|
|
37
|
+
return {
|
|
38
|
+
...entry,
|
|
39
|
+
children: this.compute(entry.children, minified, entry),
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
return {
|
|
43
|
+
...entry,
|
|
44
|
+
focusable: isInternalNavSelectorEntryALeafFocusable(entry, { parentFolded: parent?.folded === true, minified: minified }),
|
|
45
|
+
details: this.compute(entry.details, minified),
|
|
46
|
+
};
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2LXNlbGVjdG9yLm1pbmlmeWluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9uYXYtc2VsZWN0b3Ivc3JjL3V0aWxzL25hdi1zZWxlY3Rvci5taW5pZnlpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUlILHNDQUFzQyxFQUN0QywrQkFBK0IsR0FDbEMsTUFBTSxpQkFBaUIsQ0FBQztBQUN6QixPQUFPLEVBQUUsd0NBQXdDLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUUvRTs7R0FFRztBQUNILE1BQU0sT0FBTyxvQkFBb0I7SUFDN0I7Ozs7Ozs7O09BUUc7SUFDSCxNQUFNLENBQUMsTUFBTSxDQUFxQyxPQUFZO1FBQzFELE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQUVEOzs7Ozs7OztPQVFHO0lBQ0gsTUFBTSxDQUFDLE1BQU0sQ0FBcUMsT0FBWTtRQUMxRCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFFTyxNQUFNLENBQUMsT0FBTyxDQUNsQixPQUFZLEVBQ1osUUFBaUIsRUFDakIsU0FBd0UsSUFBSTtRQUU1RSxPQUFPLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDdkIsSUFBSSxzQ0FBc0MsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO2dCQUNoRCxPQUFPLEVBQUUsR0FBRyxLQUFLLEVBQUUsU0FBUyxFQUFFLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDOUMsQ0FBQztZQUNELElBQUksK0JBQStCLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztnQkFDekMsT0FBTztvQkFDSCxHQUFHLEtBQUs7b0JBQ1IsUUFBUSxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRSxRQUFRLEVBQUUsS0FBSyxDQUFDO2lCQUMxRCxDQUFDO1lBQ04sQ0FBQztZQUVELE9BQU87Z0JBQ0gsR0FBRyxLQUFLO2dCQUNSLFNBQVMsRUFBRSx3Q0FBd0MsQ0FBQyxLQUFLLEVBQUUsRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLE1BQU0sS0FBSyxJQUFJLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxDQUFDO2dCQUN6SCxPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFLFFBQVEsQ0FBQzthQUNqRCxDQUFDO1FBQ04sQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIEludGVybmFsTmF2U2VsZWN0b3JDYXRlZ29yeSxcbiAgICBJbnRlcm5hbE5hdlNlbGVjdG9yRW50cnksXG4gICAgSW50ZXJuYWxOYXZTZWxlY3Rvckdyb3VwLFxuICAgIGlzSW50ZXJuYWxOYXZTZWxlY3RvckVudHJ5QUxlYWZEZXRhaWxzLFxuICAgIGlzSW50ZXJuYWxOYXZTZWxlY3RvckVudHJ5QU5vZGUsXG59IGZyb20gJy4uL25hdi1zZWxlY3Rvcic7XG5pbXBvcnQgeyBpc0ludGVybmFsTmF2U2VsZWN0b3JFbnRyeUFMZWFmRm9jdXNhYmxlIH0gZnJvbSAnLi4vdXRpbHMvbGVhZi51dGlscyc7XG5cbi8qKlxuICogTmF2U2VsZWN0b3JNaW5pZnlpbmcgaXMgYSB1dGlsaXR5IGNsYXNzIHRoYXQgcHJvdmlkZXMgbWV0aG9kcyB0byBhcHBseSBydWxlcyBvbiBlbnRyaWVzIHdoZW4gbWluaWZ5aW5nIG9yIGV4cGFuZGVkIG5hdiBzZWxlY3Rvci5cbiAqL1xuZXhwb3J0IGNsYXNzIE5hdlNlbGVjdG9yTWluaWZ5aW5nIHtcbiAgICAvKipcbiAgICAgKiBXaGVuIG1pbmlmeWluZyB0aGUgbmF2IHNlbGVjdG9yLCBjb21wdXRlIHRoZSBmb2N1c2FibGUgc3RhdGUgb2YgdGhlIGVudHJpZXMuXG4gICAgICpcbiAgICAgKiBMZWFmIGFyZSBub3QgZm9jdXNhYmxlIGluIGFueSBlcnJvciBzdGF0ZSB3aGVuIG1pbmlmaWVkLlxuICAgICAqIERldGFpbCBhcmUgbm90IGZvY3VzYWJsZSB3aGVuIG1pbmlmaWVkLlxuICAgICAqXG4gICAgICogQHBhcmFtIGVudHJpZXMgVGhlIGVudHJpZXMgdG8gbWluaWZ5LlxuICAgICAqIEByZXR1cm5zIFRoZSBtb2RpZmllZCBlbnRyaWVzLlxuICAgICAqL1xuICAgIHN0YXRpYyBtaW5pZnk8VCBleHRlbmRzIEludGVybmFsTmF2U2VsZWN0b3JFbnRyeT4oZW50cmllczogVFtdKTogSW50ZXJuYWxOYXZTZWxlY3RvckVudHJ5W10ge1xuICAgICAgICByZXR1cm4gdGhpcy5jb21wdXRlKGVudHJpZXMsIHRydWUpO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFdoZW4gZXhwYW5kaW5nIHRoZSBuYXYgc2VsZWN0b3IsIGNvbXB1dGUgdGhlIGZvY3VzYWJsZSBzdGF0ZSBvZiB0aGUgZW50cmllcy5cbiAgICAgKlxuICAgICAqIExlYWYgYXJlIG5vdCBmb2N1c2FibGUgaW4gZGlzYWJsZWQgc3RhdGUgd2hlbiBleHBhbmRlZC5cbiAgICAgKiBEZXRhaWwgYXJlIGZvY3VzYWJsZSB3aGVuIGV4cGFuZGVkLlxuICAgICAqXG4gICAgICogQHBhcmFtIGVudHJpZXMgVGhlIGVudHJpZXMgdG8gbWluaWZ5LlxuICAgICAqIEByZXR1cm5zIFRoZSBtb2RpZmllZCBlbnRyaWVzLlxuICAgICAqL1xuICAgIHN0YXRpYyBleHBhbmQ8VCBleHRlbmRzIEludGVybmFsTmF2U2VsZWN0b3JFbnRyeT4oZW50cmllczogVFtdKTogSW50ZXJuYWxOYXZTZWxlY3RvckVudHJ5W10ge1xuICAgICAgICByZXR1cm4gdGhpcy5jb21wdXRlKGVudHJpZXMsIGZhbHNlKTtcbiAgICB9XG5cbiAgICBwcml2YXRlIHN0YXRpYyBjb21wdXRlPFQgZXh0ZW5kcyBJbnRlcm5hbE5hdlNlbGVjdG9yRW50cnk+KFxuICAgICAgICBlbnRyaWVzOiBUW10sXG4gICAgICAgIG1pbmlmaWVkOiBib29sZWFuLFxuICAgICAgICBwYXJlbnQ6IEludGVybmFsTmF2U2VsZWN0b3JHcm91cCB8IEludGVybmFsTmF2U2VsZWN0b3JDYXRlZ29yeSB8IG51bGwgPSBudWxsXG4gICAgKTogSW50ZXJuYWxOYXZTZWxlY3RvckVudHJ5W10ge1xuICAgICAgICByZXR1cm4gZW50cmllcy5tYXAoZW50cnkgPT4ge1xuICAgICAgICAgICAgaWYgKGlzSW50ZXJuYWxOYXZTZWxlY3RvckVudHJ5QUxlYWZEZXRhaWxzKGVudHJ5KSkge1xuICAgICAgICAgICAgICAgIHJldHVybiB7IC4uLmVudHJ5LCBmb2N1c2FibGU6ICFtaW5pZmllZCB9O1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgaWYgKGlzSW50ZXJuYWxOYXZTZWxlY3RvckVudHJ5QU5vZGUoZW50cnkpKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgICAgICAgICAgLi4uZW50cnksXG4gICAgICAgICAgICAgICAgICAgIGNoaWxkcmVuOiB0aGlzLmNvbXB1dGUoZW50cnkuY2hpbGRyZW4sIG1pbmlmaWVkLCBlbnRyeSksXG4gICAgICAgICAgICAgICAgfTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgICAgICAuLi5lbnRyeSxcbiAgICAgICAgICAgICAgICBmb2N1c2FibGU6IGlzSW50ZXJuYWxOYXZTZWxlY3RvckVudHJ5QUxlYWZGb2N1c2FibGUoZW50cnksIHsgcGFyZW50Rm9sZGVkOiBwYXJlbnQ/LmZvbGRlZCA9PT0gdHJ1ZSwgbWluaWZpZWQ6IG1pbmlmaWVkIH0pLFxuICAgICAgICAgICAgICAgIGRldGFpbHM6IHRoaXMuY29tcHV0ZShlbnRyeS5kZXRhaWxzLCBtaW5pZmllZCksXG4gICAgICAgICAgICB9O1xuICAgICAgICB9KTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,208 @@
|
|
|
1
|
+
import { isInternalNavSelectorEntryACategory, isInternalNavSelectorEntryAGroup, isInternalNavSelectorEntryALeaf, isInternalNavSelectorEntryANode, } from '../nav-selector';
|
|
2
|
+
/**
|
|
3
|
+
* NavSelectorMultiSelect is a utility class that provides methods to select an entry in multiple mode.
|
|
4
|
+
*/
|
|
5
|
+
export class NavSelectorMultiSelect {
|
|
6
|
+
/**
|
|
7
|
+
* Select an entry in multiple mode.
|
|
8
|
+
*
|
|
9
|
+
* Categories are not selectable.
|
|
10
|
+
*
|
|
11
|
+
* Groups and leaves are selectable.
|
|
12
|
+
*
|
|
13
|
+
* Groups may be in undetermined state if some of their children are selected and some are not.
|
|
14
|
+
* @param entries nav selector entries
|
|
15
|
+
* @param entryUid the entry uid to select
|
|
16
|
+
*/
|
|
17
|
+
static selectInMultipleMode(entries, entryUid) {
|
|
18
|
+
return entries.map(entry => {
|
|
19
|
+
if (isInternalNavSelectorEntryALeaf(entry)) {
|
|
20
|
+
return this.selectALeafInMultipleMode(entry, entryUid);
|
|
21
|
+
}
|
|
22
|
+
else if (isInternalNavSelectorEntryAGroup(entry)) {
|
|
23
|
+
return this.selectAGroupInMultipleMode(entry, entryUid);
|
|
24
|
+
}
|
|
25
|
+
else if (isInternalNavSelectorEntryACategory(entry)) {
|
|
26
|
+
return this.selectACategoryInMultipleMode(entry, entryUid);
|
|
27
|
+
}
|
|
28
|
+
return entry;
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Select only a leaf in multiple mode.
|
|
33
|
+
*
|
|
34
|
+
* Categories are not selectable.
|
|
35
|
+
*
|
|
36
|
+
* Groups may be in undetermined state if some of their children are selected and some are not.
|
|
37
|
+
* @param entries nav selector entries
|
|
38
|
+
* @param entryUid the entry uid to select
|
|
39
|
+
*/
|
|
40
|
+
static selectOnlyALeafInMultipleMode(entries, entryUid) {
|
|
41
|
+
return entries.map(entry => {
|
|
42
|
+
if (isInternalNavSelectorEntryALeaf(entry)) {
|
|
43
|
+
return {
|
|
44
|
+
...entry,
|
|
45
|
+
selected: entry.uid === entryUid,
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
else if (isInternalNavSelectorEntryACategory(entry)) {
|
|
49
|
+
return {
|
|
50
|
+
...entry,
|
|
51
|
+
children: this.selectOnlyALeafInMultipleMode(entry.children, entryUid),
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
else if (isInternalNavSelectorEntryAGroup(entry)) {
|
|
55
|
+
const children = entry.children.flatMap(child => this.selectOnlyALeafInMultipleMode([child], entryUid));
|
|
56
|
+
const selected = children.every(child => child.selected || (isInternalNavSelectorEntryALeaf(child) && !child.selectable));
|
|
57
|
+
return {
|
|
58
|
+
...entry,
|
|
59
|
+
children,
|
|
60
|
+
selected,
|
|
61
|
+
undeterminedSelection: !selected && children.some(child => child.selected),
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
return entry;
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Select all entries in multiple mode.
|
|
69
|
+
*
|
|
70
|
+
* Categories are not selectable.
|
|
71
|
+
*
|
|
72
|
+
* Groups and leaves are selectable.
|
|
73
|
+
* @param entries nav selector entries
|
|
74
|
+
*/
|
|
75
|
+
static selectAll(entries) {
|
|
76
|
+
return this.selectChildren(entries);
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Unselect all entries in multiple mode.
|
|
80
|
+
*
|
|
81
|
+
* Categories are not selectable.
|
|
82
|
+
*
|
|
83
|
+
* Groups and leaves are selectable.
|
|
84
|
+
* @param entries nav selector entries
|
|
85
|
+
*/
|
|
86
|
+
static unselectAll(entries) {
|
|
87
|
+
return this.unselectChildren(entries);
|
|
88
|
+
}
|
|
89
|
+
static selectALeafInMultipleMode(leaf, entryUid) {
|
|
90
|
+
let selected = false;
|
|
91
|
+
if (leaf.selectable) {
|
|
92
|
+
selected = leaf.uid === entryUid ? !leaf.selected : leaf.selected;
|
|
93
|
+
}
|
|
94
|
+
return {
|
|
95
|
+
...leaf,
|
|
96
|
+
selected,
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
static selectACategoryInMultipleMode(entry, entryUid) {
|
|
100
|
+
return {
|
|
101
|
+
...entry,
|
|
102
|
+
children: entry.children.map(child => {
|
|
103
|
+
if (isInternalNavSelectorEntryALeaf(child)) {
|
|
104
|
+
return this.selectALeafInMultipleMode(child, entryUid);
|
|
105
|
+
}
|
|
106
|
+
return this.selectAGroupInMultipleMode(child, entryUid);
|
|
107
|
+
}),
|
|
108
|
+
};
|
|
109
|
+
}
|
|
110
|
+
static selectAGroupInMultipleMode(entry, entryUid) {
|
|
111
|
+
if (!entry.selectable) {
|
|
112
|
+
return entry;
|
|
113
|
+
}
|
|
114
|
+
let selected;
|
|
115
|
+
let children;
|
|
116
|
+
let undeterminedSelection = false;
|
|
117
|
+
if (entry.uid === entryUid) {
|
|
118
|
+
selected = !entry.selected;
|
|
119
|
+
if (selected) {
|
|
120
|
+
children = this.selectLeafs(entry.children);
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
children = this.unselectLeafs(entry.children);
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
else {
|
|
127
|
+
children = entry.children.map(child => this.toggleSelectLeaf(child, entryUid));
|
|
128
|
+
selected = children.every(child => child.selected || (isInternalNavSelectorEntryALeaf(child) && !child.selectable));
|
|
129
|
+
undeterminedSelection = !selected && children.some(child => child.selected);
|
|
130
|
+
}
|
|
131
|
+
return {
|
|
132
|
+
...entry,
|
|
133
|
+
children,
|
|
134
|
+
selected,
|
|
135
|
+
undeterminedSelection,
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
static toggleSelectLeaf(leaf, uid) {
|
|
139
|
+
if (leaf.uid === uid) {
|
|
140
|
+
return {
|
|
141
|
+
...leaf,
|
|
142
|
+
selected: !leaf.selected,
|
|
143
|
+
};
|
|
144
|
+
}
|
|
145
|
+
return leaf;
|
|
146
|
+
}
|
|
147
|
+
static selectLeafs(leafs) {
|
|
148
|
+
return leafs.map(leaf => ({
|
|
149
|
+
...leaf,
|
|
150
|
+
selected: true,
|
|
151
|
+
}));
|
|
152
|
+
}
|
|
153
|
+
static unselectLeafs(leafs) {
|
|
154
|
+
return leafs.map(leaf => ({
|
|
155
|
+
...leaf,
|
|
156
|
+
selected: false,
|
|
157
|
+
}));
|
|
158
|
+
}
|
|
159
|
+
static unselectChildren(entry) {
|
|
160
|
+
return entry.map(child => {
|
|
161
|
+
if (isInternalNavSelectorEntryALeaf(child)) {
|
|
162
|
+
return {
|
|
163
|
+
...child,
|
|
164
|
+
selected: false,
|
|
165
|
+
};
|
|
166
|
+
}
|
|
167
|
+
else if (isInternalNavSelectorEntryACategory(child)) {
|
|
168
|
+
return {
|
|
169
|
+
...child,
|
|
170
|
+
children: this.unselectChildren(child.children),
|
|
171
|
+
};
|
|
172
|
+
}
|
|
173
|
+
else if (isInternalNavSelectorEntryANode(child)) {
|
|
174
|
+
return {
|
|
175
|
+
...child,
|
|
176
|
+
children: this.unselectChildren(child.children),
|
|
177
|
+
selected: false,
|
|
178
|
+
};
|
|
179
|
+
}
|
|
180
|
+
return child;
|
|
181
|
+
});
|
|
182
|
+
}
|
|
183
|
+
static selectChildren(entry) {
|
|
184
|
+
return entry.map(child => {
|
|
185
|
+
if (isInternalNavSelectorEntryALeaf(child)) {
|
|
186
|
+
return {
|
|
187
|
+
...child,
|
|
188
|
+
selected: child.selectable,
|
|
189
|
+
};
|
|
190
|
+
}
|
|
191
|
+
else if (isInternalNavSelectorEntryACategory(child)) {
|
|
192
|
+
return {
|
|
193
|
+
...child,
|
|
194
|
+
children: this.selectChildren(child.children),
|
|
195
|
+
};
|
|
196
|
+
}
|
|
197
|
+
else if (isInternalNavSelectorEntryAGroup(child)) {
|
|
198
|
+
return {
|
|
199
|
+
...child,
|
|
200
|
+
children: this.selectChildren(child.children),
|
|
201
|
+
selected: true,
|
|
202
|
+
};
|
|
203
|
+
}
|
|
204
|
+
return child;
|
|
205
|
+
});
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector.multi-select.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/utils/nav-selector.multi-select.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    InternalNavSelectorCategory,\n    InternalNavSelectorEntry,\n    InternalNavSelectorGroup,\n    InternalNavSelectorLeaf,\n    isInternalNavSelectorEntryACategory,\n    isInternalNavSelectorEntryAGroup,\n    isInternalNavSelectorEntryALeaf,\n    isInternalNavSelectorEntryANode,\n} from '../nav-selector';\n\n/**\n * NavSelectorMultiSelect is a utility class that provides methods to select an entry in multiple mode.\n */\nexport class NavSelectorMultiSelect {\n    /**\n     * Select an entry in multiple mode.\n     *\n     * Categories are not selectable.\n     *\n     * Groups and leaves are selectable.\n     *\n     * Groups may be in undetermined state if some of their children are selected and some are not.\n     * @param entries nav selector entries\n     * @param entryUid the entry uid to select\n     */\n    static selectInMultipleMode(entries: InternalNavSelectorEntry[], entryUid: string): InternalNavSelectorEntry[] {\n        return entries.map(entry => {\n            if (isInternalNavSelectorEntryALeaf(entry)) {\n                return this.selectALeafInMultipleMode(entry, entryUid);\n            } else if (isInternalNavSelectorEntryAGroup(entry)) {\n                return this.selectAGroupInMultipleMode(entry, entryUid);\n            } else if (isInternalNavSelectorEntryACategory(entry)) {\n                return this.selectACategoryInMultipleMode(entry, entryUid);\n            }\n            return entry;\n        });\n    }\n\n    /**\n     * Select only a leaf in multiple mode.\n     *\n     * Categories are not selectable.\n     *\n     * Groups may be in undetermined state if some of their children are selected and some are not.\n     * @param entries nav selector entries\n     * @param entryUid the entry uid to select\n     */\n    static selectOnlyALeafInMultipleMode<T extends InternalNavSelectorEntry>(entries: T[], entryUid: string): InternalNavSelectorEntry[] {\n        return entries.map(entry => {\n            if (isInternalNavSelectorEntryALeaf(entry)) {\n                return {\n                    ...entry,\n                    selected: entry.uid === entryUid,\n                };\n            } else if (isInternalNavSelectorEntryACategory(entry)) {\n                return {\n                    ...entry,\n                    children: this.selectOnlyALeafInMultipleMode(entry.children, entryUid),\n                };\n            } else if (isInternalNavSelectorEntryAGroup(entry)) {\n                const children = entry.children.flatMap(\n                    child => this.selectOnlyALeafInMultipleMode([child], entryUid) as InternalNavSelectorLeaf[]\n                );\n                const selected = children.every(child => child.selected || (isInternalNavSelectorEntryALeaf(child) && !child.selectable));\n                return {\n                    ...entry,\n                    children,\n                    selected,\n                    undeterminedSelection: !selected && children.some(child => child.selected),\n                };\n            }\n            return entry;\n        });\n    }\n\n    /**\n     * Select all entries in multiple mode.\n     *\n     * Categories are not selectable.\n     *\n     * Groups and leaves are selectable.\n     * @param entries nav selector entries\n     */\n    static selectAll(entries: InternalNavSelectorEntry[]): InternalNavSelectorEntry[] {\n        return this.selectChildren(entries);\n    }\n\n    /**\n     * Unselect all entries in multiple mode.\n     *\n     * Categories are not selectable.\n     *\n     * Groups and leaves are selectable.\n     * @param entries nav selector entries\n     */\n    static unselectAll(entries: InternalNavSelectorEntry[]): InternalNavSelectorEntry[] {\n        return this.unselectChildren(entries);\n    }\n\n    private static selectALeafInMultipleMode(leaf: InternalNavSelectorLeaf, entryUid: string): InternalNavSelectorLeaf {\n        let selected = false;\n        if (leaf.selectable) {\n            selected = leaf.uid === entryUid ? !leaf.selected : leaf.selected;\n        }\n        return {\n            ...leaf,\n            selected,\n        };\n    }\n\n    private static selectACategoryInMultipleMode(entry: InternalNavSelectorCategory, entryUid: string): InternalNavSelectorCategory {\n        return {\n            ...entry,\n            children: entry.children.map(child => {\n                if (isInternalNavSelectorEntryALeaf(child)) {\n                    return this.selectALeafInMultipleMode(child, entryUid);\n                }\n                return this.selectAGroupInMultipleMode(child, entryUid);\n            }),\n        };\n    }\n\n    private static selectAGroupInMultipleMode(entry: InternalNavSelectorGroup, entryUid: string): InternalNavSelectorGroup {\n        if (!entry.selectable) {\n            return entry;\n        }\n        let selected: boolean;\n        let children: InternalNavSelectorLeaf[];\n        let undeterminedSelection = false;\n        if (entry.uid === entryUid) {\n            selected = !entry.selected;\n            if (selected) {\n                children = this.selectLeafs(entry.children);\n            } else {\n                children = this.unselectLeafs(entry.children);\n            }\n        } else {\n            children = entry.children.map(child => this.toggleSelectLeaf(child, entryUid));\n            selected = children.every(child => child.selected || (isInternalNavSelectorEntryALeaf(child) && !child.selectable));\n            undeterminedSelection = !selected && children.some(child => child.selected);\n        }\n\n        return {\n            ...entry,\n            children,\n            selected,\n            undeterminedSelection,\n        };\n    }\n\n    private static toggleSelectLeaf(leaf: InternalNavSelectorLeaf, uid: string): InternalNavSelectorLeaf {\n        if (leaf.uid === uid) {\n            return {\n                ...leaf,\n                selected: !leaf.selected,\n            };\n        }\n        return leaf;\n    }\n\n    private static selectLeafs(leafs: InternalNavSelectorLeaf[]): InternalNavSelectorLeaf[] {\n        return leafs.map(leaf => ({\n            ...leaf,\n            selected: true,\n        }));\n    }\n\n    private static unselectLeafs(leafs: InternalNavSelectorLeaf[]): InternalNavSelectorLeaf[] {\n        return leafs.map(leaf => ({\n            ...leaf,\n            selected: false,\n        }));\n    }\n\n    private static unselectChildren<T extends InternalNavSelectorEntry>(entry: T[]): InternalNavSelectorEntry[] {\n        return entry.map(child => {\n            if (isInternalNavSelectorEntryALeaf(child)) {\n                return {\n                    ...child,\n                    selected: false,\n                };\n            } else if (isInternalNavSelectorEntryACategory(child)) {\n                return {\n                    ...child,\n                    children: this.unselectChildren(child.children),\n                };\n            } else if (isInternalNavSelectorEntryANode(child)) {\n                return {\n                    ...child,\n                    children: this.unselectChildren(child.children),\n                    selected: false,\n                };\n            }\n            return child;\n        });\n    }\n\n    private static selectChildren<T extends InternalNavSelectorEntry>(entry: T[]): InternalNavSelectorEntry[] {\n        return entry.map(child => {\n            if (isInternalNavSelectorEntryALeaf(child)) {\n                return {\n                    ...child,\n                    selected: child.selectable,\n                };\n            } else if (isInternalNavSelectorEntryACategory(child)) {\n                return {\n                    ...child,\n                    children: this.selectChildren(child.children),\n                };\n            } else if (isInternalNavSelectorEntryAGroup(child)) {\n                return {\n                    ...child,\n                    children: this.selectChildren(child.children),\n                    selected: true,\n                };\n            }\n            return child;\n        });\n    }\n}\n"]}
|