@agorapulse/ui-components 18.0.8 → 18.0.10

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.
Files changed (92) hide show
  1. package/agorapulse-ui-components-18.0.10.tgz +0 -0
  2. package/avatar/avatar.component.d.ts +1 -1
  3. package/checkbox/checkbox.component.d.ts +3 -3
  4. package/close-button/close-button.component.d.ts +4 -4
  5. package/datepicker/datepicker.component.d.ts +1 -1
  6. package/esm2022/avatar/avatar.component.mjs +4 -3
  7. package/esm2022/checkbox/checkbox.component.mjs +7 -7
  8. package/esm2022/close-button/close-button.component.mjs +6 -6
  9. package/esm2022/datepicker/datepicker.component.mjs +2 -2
  10. package/esm2022/index.mjs +2 -1
  11. package/esm2022/infobox/infobox.component.mjs +1 -1
  12. package/esm2022/input-search/input-search.component.mjs +5 -4
  13. package/esm2022/labels/label.component.mjs +1 -1
  14. package/esm2022/nav-selector/agorapulse-ui-components-nav-selector.mjs +5 -0
  15. package/esm2022/nav-selector/directives/tree-node-accessibility.directive.mjs +30 -0
  16. package/esm2022/nav-selector/nav-selector-category/nav-selector-category.component.mjs +81 -0
  17. package/esm2022/nav-selector/nav-selector-category/nav-selector-category.presenter.mjs +29 -0
  18. package/esm2022/nav-selector/nav-selector-group/nav-selector-group.component.mjs +142 -0
  19. package/esm2022/nav-selector/nav-selector-group/nav-selector-group.presenter.mjs +31 -0
  20. package/esm2022/nav-selector/nav-selector-leaf/nav-selector-leaf.component.mjs +240 -0
  21. package/esm2022/nav-selector/nav-selector-leaf/nav-selector-leaf.presenter.mjs +35 -0
  22. package/esm2022/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.component.mjs +39 -0
  23. package/esm2022/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.presenter.mjs +18 -0
  24. package/esm2022/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.component.mjs +92 -0
  25. package/esm2022/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.presenter.mjs +31 -0
  26. package/esm2022/nav-selector/nav-selector.component.mjs +123 -0
  27. package/esm2022/nav-selector/nav-selector.mjs +9 -0
  28. package/esm2022/nav-selector/nav-selector.state.mjs +173 -0
  29. package/esm2022/nav-selector/public_api.mjs +2 -0
  30. package/esm2022/nav-selector/utils/leaf.utils.mjs +10 -0
  31. package/esm2022/nav-selector/utils/nav-selector.accessibility.mjs +171 -0
  32. package/esm2022/nav-selector/utils/nav-selector.builder.mjs +263 -0
  33. package/esm2022/nav-selector/utils/nav-selector.filter.mjs +102 -0
  34. package/esm2022/nav-selector/utils/nav-selector.folding.mjs +219 -0
  35. package/esm2022/nav-selector/utils/nav-selector.minifying.mjs +50 -0
  36. package/esm2022/nav-selector/utils/nav-selector.multi-select.mjs +208 -0
  37. package/esm2022/nav-selector/utils/nav-selector.single-select.mjs +91 -0
  38. package/esm2022/nav-selector/utils/nav-selector.view-more.mjs +98 -0
  39. package/esm2022/snackbars-thread/component/snackbars-thread.component.mjs +2 -2
  40. package/esm2022/tag/tag.component.mjs +7 -5
  41. package/fesm2022/agorapulse-ui-components-avatar.mjs +3 -2
  42. package/fesm2022/agorapulse-ui-components-avatar.mjs.map +1 -1
  43. package/fesm2022/agorapulse-ui-components-checkbox.mjs +6 -6
  44. package/fesm2022/agorapulse-ui-components-checkbox.mjs.map +1 -1
  45. package/fesm2022/agorapulse-ui-components-close-button.mjs +5 -5
  46. package/fesm2022/agorapulse-ui-components-close-button.mjs.map +1 -1
  47. package/fesm2022/agorapulse-ui-components-datepicker.mjs +1 -1
  48. package/fesm2022/agorapulse-ui-components-datepicker.mjs.map +1 -1
  49. package/fesm2022/agorapulse-ui-components-infobox.mjs +1 -1
  50. package/fesm2022/agorapulse-ui-components-infobox.mjs.map +1 -1
  51. package/fesm2022/agorapulse-ui-components-input-search.mjs +4 -3
  52. package/fesm2022/agorapulse-ui-components-input-search.mjs.map +1 -1
  53. package/fesm2022/agorapulse-ui-components-labels.mjs +1 -1
  54. package/fesm2022/agorapulse-ui-components-labels.mjs.map +1 -1
  55. package/fesm2022/agorapulse-ui-components-nav-selector.mjs +2198 -0
  56. package/fesm2022/agorapulse-ui-components-nav-selector.mjs.map +1 -0
  57. package/fesm2022/agorapulse-ui-components-snackbars-thread.mjs +1 -1
  58. package/fesm2022/agorapulse-ui-components-snackbars-thread.mjs.map +1 -1
  59. package/fesm2022/agorapulse-ui-components-tag.mjs +6 -4
  60. package/fesm2022/agorapulse-ui-components-tag.mjs.map +1 -1
  61. package/fesm2022/agorapulse-ui-components.mjs +1 -0
  62. package/fesm2022/agorapulse-ui-components.mjs.map +1 -1
  63. package/index.d.ts +1 -0
  64. package/input-search/input-search.component.d.ts +1 -1
  65. package/nav-selector/directives/tree-node-accessibility.directive.d.ts +9 -0
  66. package/nav-selector/index.d.ts +5 -0
  67. package/nav-selector/nav-selector-category/nav-selector-category.component.d.ts +16 -0
  68. package/nav-selector/nav-selector-category/nav-selector-category.presenter.d.ts +14 -0
  69. package/nav-selector/nav-selector-group/nav-selector-group.component.d.ts +29 -0
  70. package/nav-selector/nav-selector-group/nav-selector-group.presenter.d.ts +17 -0
  71. package/nav-selector/nav-selector-leaf/nav-selector-leaf.component.d.ts +51 -0
  72. package/nav-selector/nav-selector-leaf/nav-selector-leaf.presenter.d.ts +19 -0
  73. package/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.component.d.ts +13 -0
  74. package/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.presenter.d.ts +10 -0
  75. package/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.component.d.ts +24 -0
  76. package/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.presenter.d.ts +14 -0
  77. package/nav-selector/nav-selector.component.d.ts +29 -0
  78. package/nav-selector/nav-selector.d.ts +220 -0
  79. package/nav-selector/nav-selector.state.d.ts +47 -0
  80. package/nav-selector/public_api.d.ts +2 -0
  81. package/nav-selector/utils/leaf.utils.d.ts +5 -0
  82. package/nav-selector/utils/nav-selector.accessibility.d.ts +52 -0
  83. package/nav-selector/utils/nav-selector.builder.d.ts +32 -0
  84. package/nav-selector/utils/nav-selector.filter.d.ts +30 -0
  85. package/nav-selector/utils/nav-selector.folding.d.ts +47 -0
  86. package/nav-selector/utils/nav-selector.minifying.d.ts +27 -0
  87. package/nav-selector/utils/nav-selector.multi-select.d.ts +54 -0
  88. package/nav-selector/utils/nav-selector.single-select.d.ts +15 -0
  89. package/nav-selector/utils/nav-selector.view-more.d.ts +30 -0
  90. package/package.json +7 -1
  91. package/tag/tag.component.d.ts +3 -1
  92. package/agorapulse-ui-components-18.0.8.tgz +0 -0
@@ -0,0 +1,263 @@
1
+ import { isInternalNavSelectorEntryALeaf, isNavSelectorEntryACategory, isNavSelectorEntryAGroup, isNavSelectorEntryALeaf, } from '../nav-selector';
2
+ import { NavSelectorAccessibility } from '../utils/nav-selector.accessibility';
3
+ import { NavSelectorMultiSelect } from '../utils/nav-selector.multi-select';
4
+ import { NavSelectorSingleSelect } from './nav-selector.single-select';
5
+ const LeafLogics = {
6
+ DISABLED: 'DISABLED',
7
+ FEATURE_LOCKED: 'FEATURE_LOCKED',
8
+ TOKEN_INVALID: 'TOKEN_INVALID',
9
+ COUNTER: 'COUNTER',
10
+ };
11
+ /**
12
+ * NavSelectorBuilder is a utility class that builds the NavSelector entries for single and multiple select modes.
13
+ * It also checks the structure of the entries to ensure they are valid.
14
+ */
15
+ export class NavSelectorBuilder {
16
+ // /!\/!\ Order of logics is important /!\/!\
17
+ static LEAF_LOGICS_PRIORITY = {
18
+ [LeafLogics.DISABLED]: (leaf) => leaf.disableReason !== null,
19
+ [LeafLogics.FEATURE_LOCKED]: (leaf) => leaf.featureLocked,
20
+ [LeafLogics.TOKEN_INVALID]: (leaf) => leaf.tokenInvalid,
21
+ [LeafLogics.COUNTER]: (leaf) => leaf.counter !== null,
22
+ };
23
+ /**
24
+ * Builds the NavSelector entries for single select mode.
25
+ * @param entries nav selector entries
26
+ * @param selectedEntryUid selected entry uid
27
+ * @param detailsDisplayedLimit number of details displayed limit
28
+ */
29
+ static build(entries, selectedEntryUid, detailsDisplayedLimit) {
30
+ this.structureChecker(entries);
31
+ const builtEntries = this.buildEntries(entries, false, 1, detailsDisplayedLimit);
32
+ if (selectedEntryUid) {
33
+ return NavSelectorSingleSelect.select(builtEntries, selectedEntryUid);
34
+ }
35
+ return builtEntries;
36
+ }
37
+ /**
38
+ * Builds the NavSelector entries for multiple select mode.
39
+ * @param entries nav selector entries
40
+ * @param selectedEntryUids selected entry uids
41
+ * @param detailsDisplayedLimit number of details displayed limit
42
+ */
43
+ static buildInMultipleMode(entries, selectedEntryUids, detailsDisplayedLimit) {
44
+ this.structureChecker(entries, true);
45
+ let builtEntries = this.buildEntries(entries, true, 1, detailsDisplayedLimit);
46
+ if (selectedEntryUids) {
47
+ for (const selectedEntryUid of selectedEntryUids) {
48
+ builtEntries = NavSelectorMultiSelect.selectInMultipleMode(builtEntries, selectedEntryUid);
49
+ }
50
+ }
51
+ return builtEntries;
52
+ }
53
+ static structureChecker(entries, multipleModeEnabled = false) {
54
+ entries.forEach(entry => {
55
+ if (isNavSelectorEntryAGroup(entry) || isNavSelectorEntryACategory(entry)) {
56
+ this.structureChecker(entry.children, multipleModeEnabled);
57
+ }
58
+ else if (isNavSelectorEntryALeaf(entry)) {
59
+ if (entry.details.length && multipleModeEnabled) {
60
+ console.error(`NavSelectorBuilder: Leaf ${entry.uid} with details is not allowed in multiple mode`);
61
+ }
62
+ }
63
+ });
64
+ }
65
+ static buildEntries(entries, multipleModeEnabled, level = 1, detailsDisplayedLimit) {
66
+ const newEntries = entries
67
+ .map((entry, idx) => this.buildEntry(entry, { multipleModeEnabled, level, idx, totalNumberOfEntry: entries.length, detailsDisplayedLimit }))
68
+ .filter(it => it !== null);
69
+ return NavSelectorAccessibility.resetFocus(newEntries);
70
+ }
71
+ static buildEntry(entry, { multipleModeEnabled, level, idx, totalNumberOfEntry, detailsDisplayedLimit, }) {
72
+ if (isNavSelectorEntryALeaf(entry)) {
73
+ return this.buildLeaf(entry, {
74
+ multipleModeEnabled,
75
+ level,
76
+ idx,
77
+ totalNumberOfLeaf: totalNumberOfEntry,
78
+ focusable: true,
79
+ detailsDisplayedLimit,
80
+ });
81
+ }
82
+ else if (isNavSelectorEntryACategory(entry)) {
83
+ return this.buildCategory(entry, {
84
+ multipleModeEnabled,
85
+ level,
86
+ idx,
87
+ totalNumberOfCategory: totalNumberOfEntry,
88
+ detailsDisplayedLimit,
89
+ });
90
+ }
91
+ else {
92
+ return this.buildGroup(entry, {
93
+ multipleModeEnabled,
94
+ level,
95
+ idx,
96
+ totalNumberOfGroups: totalNumberOfEntry,
97
+ focusable: true,
98
+ detailsDisplayedLimit,
99
+ });
100
+ }
101
+ }
102
+ static buildCategoryChildren(entry, { focusable, multipleModeEnabled, categoryLevel, detailsDisplayedLimit, }) {
103
+ return entry.children
104
+ .map((child, idx) => {
105
+ if (isNavSelectorEntryALeaf(child)) {
106
+ return this.buildLeaf(child, {
107
+ focusable,
108
+ multipleModeEnabled,
109
+ level: categoryLevel + 1,
110
+ idx,
111
+ totalNumberOfLeaf: entry.children.length,
112
+ detailsDisplayedLimit,
113
+ });
114
+ }
115
+ else {
116
+ return this.buildGroup(child, {
117
+ focusable,
118
+ multipleModeEnabled,
119
+ level: categoryLevel + 1,
120
+ idx,
121
+ totalNumberOfGroups: entry.children.length,
122
+ detailsDisplayedLimit,
123
+ });
124
+ }
125
+ })
126
+ .filter(it => it !== null);
127
+ }
128
+ static buildCategory(node, { multipleModeEnabled, level, idx, totalNumberOfCategory, detailsDisplayedLimit, }) {
129
+ const children = this.buildCategoryChildren(node, {
130
+ focusable: !node.folded,
131
+ multipleModeEnabled,
132
+ categoryLevel: level,
133
+ detailsDisplayedLimit,
134
+ });
135
+ return {
136
+ uid: node.uid,
137
+ alias: node.alias,
138
+ children,
139
+ hidden: false,
140
+ focusable: true,
141
+ accessibility: {
142
+ tabIndex: -1,
143
+ ariaLevel: level,
144
+ ariaPosinset: idx + 1,
145
+ ariaSetsize: totalNumberOfCategory,
146
+ },
147
+ folded: node.folded,
148
+ type: node.type,
149
+ };
150
+ }
151
+ static buildGroupChildren(entry, { multipleModeEnabled, groupLevel, focusable, detailsDisplayedLimit, }) {
152
+ return entry.children
153
+ .map((child, idx) => this.buildLeaf(child, {
154
+ multipleModeEnabled,
155
+ level: groupLevel + 1,
156
+ idx,
157
+ totalNumberOfLeaf: entry.children.length,
158
+ focusable: focusable && !entry.folded,
159
+ detailsDisplayedLimit,
160
+ }))
161
+ .filter(it => it !== null);
162
+ }
163
+ static buildGroup(node, { focusable, multipleModeEnabled, level, idx, totalNumberOfGroups, detailsDisplayedLimit, }) {
164
+ const children = this.buildGroupChildren(node, { multipleModeEnabled, groupLevel: level, focusable, detailsDisplayedLimit });
165
+ const displayTokenInvalid = children.some(({ displayTokenInvalid }) => displayTokenInvalid);
166
+ const selectedChildrenCount = children.filter(({ selected }) => selected).length;
167
+ return {
168
+ uid: node.uid,
169
+ alias: node.alias,
170
+ children,
171
+ childrenPictureUrlSample: children
172
+ .map((child, idx) => isInternalNavSelectorEntryALeaf(child) && idx < 4 ? { url: child.pictureUrl, initial: child.alias[0] } : null)
173
+ .filter(it => it !== null),
174
+ hidden: false,
175
+ accessibility: {
176
+ tabIndex: -1,
177
+ ariaPosinset: idx + 1,
178
+ ariaLevel: level,
179
+ ariaSetsize: totalNumberOfGroups,
180
+ },
181
+ focusable,
182
+ displayCounter: node.folded && children.some(child => isInternalNavSelectorEntryALeaf(child) && child.counter !== 0),
183
+ counter: children.reduce((acc, { counter }) => acc + counter, 0),
184
+ displayTokenInvalid,
185
+ selected: false,
186
+ selectable: multipleModeEnabled && children.some(({ selectable }) => selectable),
187
+ undeterminedSelection: selectedChildrenCount !== children.length && selectedChildrenCount > 0,
188
+ folded: node.folded,
189
+ type: node.type,
190
+ };
191
+ }
192
+ static buildLeaf(leaf, { focusable, multipleModeEnabled, level, idx, totalNumberOfLeaf, detailsDisplayedLimit, }) {
193
+ if (leaf.missingPermission) {
194
+ return null;
195
+ }
196
+ const detailsDisplayable = this.isLeafLogicValid(leaf, LeafLogics.COUNTER) && !!leaf.details.length;
197
+ const foldable = !!leaf.details.length && detailsDisplayable;
198
+ const folded = true;
199
+ const counter = (leaf.details.reduce((acc, detail) => acc + (detail.counter ?? 0), 0) || leaf.counter) ?? 0;
200
+ const counterDisplayable = counter !== 0 && this.isLeafLogicValid(leaf, LeafLogics.COUNTER);
201
+ const disabled = leaf.disableReason !== null;
202
+ const viewMoreDisplayable = leaf.details.length > detailsDisplayedLimit;
203
+ return {
204
+ uid: leaf.uid,
205
+ alias: leaf.alias,
206
+ pictureUrl: leaf.pictureUrl,
207
+ disabled,
208
+ disableReason: leaf.disableReason,
209
+ hidden: false,
210
+ focusable: focusable && !disabled,
211
+ accessibility: {
212
+ tabIndex: -1,
213
+ ariaPosinset: idx + 1,
214
+ ariaLevel: level,
215
+ ariaSetsize: totalNumberOfLeaf,
216
+ },
217
+ foldable,
218
+ folded,
219
+ displayCounter: folded && counterDisplayable,
220
+ counterDisplayable,
221
+ counter,
222
+ network: leaf.network,
223
+ displayTokenInvalid: leaf.tokenInvalid && this.isLeafLogicValid(leaf, LeafLogics.TOKEN_INVALID, LeafLogics.COUNTER),
224
+ displayFeatureLocked: leaf.featureLocked && this.isLeafLogicValid(leaf, LeafLogics.FEATURE_LOCKED, LeafLogics.TOKEN_INVALID, LeafLogics.COUNTER),
225
+ selected: false,
226
+ selectable: multipleModeEnabled
227
+ ? this.isLeafLogicValid(leaf, LeafLogics.COUNTER)
228
+ : this.isLeafLogicValid(leaf, LeafLogics.FEATURE_LOCKED, LeafLogics.TOKEN_INVALID, LeafLogics.COUNTER),
229
+ detailsDisplayable,
230
+ details: leaf.details.map(detail => this.buildLeafDetail(detail, level + 1, focusable && !folded)),
231
+ type: 'LEAF',
232
+ viewMoreDisplayable,
233
+ viewMoreDisplayed: viewMoreDisplayable,
234
+ viewMoreDetailsDisplayedLimit: detailsDisplayedLimit,
235
+ };
236
+ }
237
+ static buildLeafDetail(detail, level, focusable) {
238
+ return {
239
+ uid: detail.uid,
240
+ counter: detail.counter ?? 0,
241
+ displayCounter: detail.counter !== null,
242
+ alias: detail.name,
243
+ hidden: false,
244
+ accessibility: {
245
+ tabIndex: -1,
246
+ ariaPosinset: 1,
247
+ ariaLevel: level,
248
+ ariaSetsize: 1,
249
+ },
250
+ focusable,
251
+ selected: false,
252
+ errorReason: detail.errorReason,
253
+ displayError: detail.errorReason !== null,
254
+ type: 'LEAF_DETAILS',
255
+ };
256
+ }
257
+ static isLeafLogicValid(leaf, ...excludes) {
258
+ return Object.entries(this.LEAF_LOGICS_PRIORITY)
259
+ .filter(([key]) => !excludes.includes(key))
260
+ .every(([, logic]) => !logic(leaf));
261
+ }
262
+ }
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"]}
@@ -0,0 +1,102 @@
1
+ import { isInternalNavSelectorEntryACategory, isInternalNavSelectorEntryAGroup, isInternalNavSelectorEntryALeaf, isInternalNavSelectorEntryANode, } from '../nav-selector';
2
+ import { isInternalNavSelectorEntryALeafFocusable } from '../utils/leaf.utils';
3
+ import { NavSelectorAccessibility } from '../utils/nav-selector.accessibility';
4
+ /**
5
+ * NavSelectorFilter is a utility class that provides methods to filter entries
6
+ */
7
+ export class NavSelectorFilter {
8
+ /**
9
+ * Filters the entries based on the search string
10
+ *
11
+ * The search string is normalized and lowercase and trimmed.
12
+ *
13
+ * If a category matches the search string, all its children are unfolded, marked as focusable, and not hidden.
14
+ *
15
+ * If a group matches the search string, the group is unfolded and all its children are unfolded, marked as focusable, and not hidden.
16
+ *
17
+ * If a leaf matches the search string, it is marked as not hidden and focusable.
18
+ *
19
+ * Else the entry marked as hidden and not focusable.
20
+ *
21
+ * It also determines whenever counter and token invalid should be displayed on groups and leaves.
22
+ *
23
+ * @param entries The entries to filter.
24
+ * @param search The search string.
25
+ * @returns The filtered entries.
26
+ */
27
+ static filter(entries, search) {
28
+ const formattedSearch = this.cleanValue(search);
29
+ if (!formattedSearch) {
30
+ return entries;
31
+ }
32
+ return this.filterEntries(entries, formattedSearch);
33
+ }
34
+ static filterEntries(entries, formattedSearch) {
35
+ const newEntries = entries.map(entry => {
36
+ if (this.matches(entry.alias, formattedSearch)) {
37
+ return this.recursivelyUnfoldEntry(entry);
38
+ }
39
+ if (isInternalNavSelectorEntryANode(entry)) {
40
+ const children = this.filterEntries(entry.children, formattedSearch);
41
+ if (children.every(({ hidden }) => hidden)) {
42
+ return {
43
+ ...entry,
44
+ children,
45
+ hidden: true,
46
+ };
47
+ }
48
+ return {
49
+ ...entry,
50
+ hidden: false,
51
+ displayCounter: false,
52
+ displayTokenInvalid: false,
53
+ folded: false,
54
+ children,
55
+ };
56
+ }
57
+ return {
58
+ ...entry,
59
+ focusable: false,
60
+ hidden: true,
61
+ };
62
+ });
63
+ return NavSelectorAccessibility.resetFocus(newEntries);
64
+ }
65
+ static recursivelyUnfoldEntry(entry) {
66
+ if (isInternalNavSelectorEntryAGroup(entry)) {
67
+ const children = entry.children.map(child => this.recursivelyUnfoldEntry(child));
68
+ return {
69
+ ...entry,
70
+ folded: false,
71
+ children,
72
+ displayCounter: false,
73
+ displayTokenInvalid: false,
74
+ };
75
+ }
76
+ else if (isInternalNavSelectorEntryALeaf(entry)) {
77
+ return {
78
+ ...entry,
79
+ hidden: false,
80
+ focusable: isInternalNavSelectorEntryALeafFocusable(entry, { parentFolded: false, minified: false }),
81
+ displayCounter: entry.counterDisplayable,
82
+ };
83
+ }
84
+ else if (isInternalNavSelectorEntryACategory(entry)) {
85
+ const children = entry.children.map(child => this.recursivelyUnfoldEntry(child));
86
+ return {
87
+ ...entry,
88
+ folded: false,
89
+ hidden: false,
90
+ children,
91
+ };
92
+ }
93
+ return entry;
94
+ }
95
+ static matches(alias, formattedSearch) {
96
+ return this.cleanValue(alias).includes(formattedSearch);
97
+ }
98
+ static cleanValue(value) {
99
+ return value.trim().normalize('NFKC').toLowerCase();
100
+ }
101
+ }
102
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector.filter.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/utils/nav-selector.filter.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    InternalNavSelectorEntry,\n    InternalNavSelectorGroup,\n    InternalNavSelectorLeaf,\n    isInternalNavSelectorEntryACategory,\n    isInternalNavSelectorEntryAGroup,\n    isInternalNavSelectorEntryALeaf,\n    isInternalNavSelectorEntryANode,\n} from '../nav-selector';\nimport { isInternalNavSelectorEntryALeafFocusable } from '../utils/leaf.utils';\nimport { NavSelectorAccessibility } from '../utils/nav-selector.accessibility';\n\n/**\n * NavSelectorFilter is a utility class that provides methods to filter entries\n */\nexport class NavSelectorFilter {\n    /**\n     * Filters the entries based on the search string\n     *\n     * The search string is normalized and lowercase and trimmed.\n     *\n     * If a category matches the search string, all its children are unfolded, marked as focusable, and not hidden.\n     *\n     * If a group matches the search string, the group is unfolded and all its children are unfolded, marked as focusable, and not hidden.\n     *\n     * If a leaf matches the search string, it is marked as not hidden and focusable.\n     *\n     * Else the entry marked as hidden and not focusable.\n     *\n     * It also determines whenever counter and token invalid should be displayed on groups and leaves.\n     *\n     * @param entries The entries to filter.\n     * @param search The search string.\n     * @returns The filtered entries.\n     */\n    static filter(entries: InternalNavSelectorEntry[], search: string): InternalNavSelectorEntry[] {\n        const formattedSearch = this.cleanValue(search);\n        if (!formattedSearch) {\n            return entries;\n        }\n        return this.filterEntries(entries, formattedSearch);\n    }\n\n    private static filterEntries<T extends InternalNavSelectorEntry>(entries: T[], formattedSearch: string): InternalNavSelectorEntry[] {\n        const newEntries = entries.map(entry => {\n            if (this.matches(entry.alias, formattedSearch)) {\n                return this.recursivelyUnfoldEntry(entry);\n            }\n            if (isInternalNavSelectorEntryANode(entry)) {\n                const children = this.filterEntries(entry.children, formattedSearch);\n                if (children.every(({ hidden }) => hidden)) {\n                    return {\n                        ...entry,\n                        children,\n                        hidden: true,\n                    };\n                }\n                return {\n                    ...entry,\n                    hidden: false,\n                    displayCounter: false,\n                    displayTokenInvalid: false,\n                    folded: false,\n                    children,\n                };\n            }\n            return {\n                ...entry,\n                focusable: false,\n                hidden: true,\n            };\n        });\n        return NavSelectorAccessibility.resetFocus(newEntries);\n    }\n\n    private static recursivelyUnfoldEntry(entry: InternalNavSelectorEntry): InternalNavSelectorEntry {\n        if (isInternalNavSelectorEntryAGroup(entry)) {\n            const children = entry.children.map(child => this.recursivelyUnfoldEntry(child) as InternalNavSelectorLeaf);\n            return {\n                ...entry,\n                folded: false,\n                children,\n                displayCounter: false,\n                displayTokenInvalid: false,\n            };\n        } else if (isInternalNavSelectorEntryALeaf(entry)) {\n            return {\n                ...entry,\n                hidden: false,\n                focusable: isInternalNavSelectorEntryALeafFocusable(entry, { parentFolded: false, minified: false }),\n                displayCounter: entry.counterDisplayable,\n            };\n        } else if (isInternalNavSelectorEntryACategory(entry)) {\n            const children = entry.children.map(\n                child => this.recursivelyUnfoldEntry(child) as InternalNavSelectorGroup | InternalNavSelectorLeaf\n            );\n            return {\n                ...entry,\n                folded: false,\n                hidden: false,\n                children,\n            };\n        }\n        return entry;\n    }\n\n    private static matches(alias: string, formattedSearch: string): boolean {\n        return this.cleanValue(alias).includes(formattedSearch);\n    }\n\n    private static cleanValue(value: string): string {\n        return value.trim().normalize('NFKC').toLowerCase();\n    }\n}\n"]}