@proyecto-viviana/solidaria 0.2.4 → 0.2.8

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 (219) hide show
  1. package/LICENSE +21 -0
  2. package/dist/actiongroup/createActionGroup.d.ts +29 -0
  3. package/dist/actiongroup/createActionGroup.d.ts.map +1 -0
  4. package/dist/actiongroup/index.d.ts +2 -0
  5. package/dist/actiongroup/index.d.ts.map +1 -0
  6. package/dist/autocomplete/createAutocomplete.d.ts +6 -2
  7. package/dist/autocomplete/createAutocomplete.d.ts.map +1 -1
  8. package/dist/breadcrumbs/createBreadcrumbs.d.ts +2 -0
  9. package/dist/breadcrumbs/createBreadcrumbs.d.ts.map +1 -1
  10. package/dist/button/createToggleButtonGroup.d.ts +32 -0
  11. package/dist/button/createToggleButtonGroup.d.ts.map +1 -0
  12. package/dist/button/index.d.ts +2 -0
  13. package/dist/button/index.d.ts.map +1 -1
  14. package/dist/calendar/createCalendarCell.d.ts +2 -0
  15. package/dist/calendar/createCalendarCell.d.ts.map +1 -1
  16. package/dist/calendar/createCalendarGrid.d.ts.map +1 -1
  17. package/dist/calendar/createRangeCalendarCell.d.ts +3 -1
  18. package/dist/calendar/createRangeCalendarCell.d.ts.map +1 -1
  19. package/dist/checkbox/createCheckboxGroup.d.ts +5 -1
  20. package/dist/checkbox/createCheckboxGroup.d.ts.map +1 -1
  21. package/dist/collections/index.d.ts +56 -0
  22. package/dist/collections/index.d.ts.map +1 -0
  23. package/dist/color/createColorArea.d.ts.map +1 -1
  24. package/dist/color/createColorSlider.d.ts.map +1 -1
  25. package/dist/color/createColorWheel.d.ts.map +1 -1
  26. package/dist/combobox/createComboBox.d.ts +6 -0
  27. package/dist/combobox/createComboBox.d.ts.map +1 -1
  28. package/dist/datepicker/createDatePicker.d.ts +6 -0
  29. package/dist/datepicker/createDatePicker.d.ts.map +1 -1
  30. package/dist/datepicker/createDateRangePicker.d.ts +40 -0
  31. package/dist/datepicker/createDateRangePicker.d.ts.map +1 -0
  32. package/dist/datepicker/createDateSegment.d.ts +1 -1
  33. package/dist/datepicker/createDateSegment.d.ts.map +1 -1
  34. package/dist/datepicker/createTimeSegment.d.ts +29 -0
  35. package/dist/datepicker/createTimeSegment.d.ts.map +1 -0
  36. package/dist/datepicker/index.d.ts +2 -0
  37. package/dist/datepicker/index.d.ts.map +1 -1
  38. package/dist/disclosure/createDisclosureGroup.d.ts +2 -1
  39. package/dist/disclosure/createDisclosureGroup.d.ts.map +1 -1
  40. package/dist/dnd/createDrag.d.ts.map +1 -1
  41. package/dist/dnd/createDraggableCollection.d.ts +4 -0
  42. package/dist/dnd/createDraggableCollection.d.ts.map +1 -1
  43. package/dist/dnd/createDraggableItem.d.ts.map +1 -1
  44. package/dist/dnd/createDrop.d.ts.map +1 -1
  45. package/dist/dnd/createDroppableCollection.d.ts +32 -1
  46. package/dist/dnd/createDroppableCollection.d.ts.map +1 -1
  47. package/dist/dnd/createDroppableItem.d.ts.map +1 -1
  48. package/dist/dnd/index.d.ts +1 -1
  49. package/dist/dnd/index.d.ts.map +1 -1
  50. package/dist/grid/createGrid.d.ts.map +1 -1
  51. package/dist/gridlist/createGridList.d.ts.map +1 -1
  52. package/dist/index.d.ts +6 -4
  53. package/dist/index.d.ts.map +1 -1
  54. package/dist/index.js +4659 -3452
  55. package/dist/index.js.map +1 -7
  56. package/dist/index.ssr.js +4659 -3452
  57. package/dist/index.ssr.js.map +1 -7
  58. package/dist/interactions/createFocus.d.ts.map +1 -1
  59. package/dist/interactions/createFocusWithin.d.ts.map +1 -1
  60. package/dist/link/createLink.d.ts +10 -0
  61. package/dist/link/createLink.d.ts.map +1 -1
  62. package/dist/listbox/createListBox.d.ts +1 -0
  63. package/dist/listbox/createListBox.d.ts.map +1 -1
  64. package/dist/listbox/createOption.d.ts.map +1 -1
  65. package/dist/menu/createMenu.d.ts +1 -0
  66. package/dist/menu/createMenu.d.ts.map +1 -1
  67. package/dist/meter/createMeter.d.ts.map +1 -1
  68. package/dist/numberfield/createNumberField.d.ts +18 -0
  69. package/dist/numberfield/createNumberField.d.ts.map +1 -1
  70. package/dist/overlays/createModal.d.ts +16 -0
  71. package/dist/overlays/createModal.d.ts.map +1 -1
  72. package/dist/overlays/createOverlay.d.ts.map +1 -1
  73. package/dist/overlays/index.d.ts +1 -1
  74. package/dist/overlays/index.d.ts.map +1 -1
  75. package/dist/popover/createOverlayPosition.d.ts.map +1 -1
  76. package/dist/popover/createPopover.d.ts.map +1 -1
  77. package/dist/progress/createProgressBar.d.ts.map +1 -1
  78. package/dist/radio/createRadioGroup.d.ts +2 -2
  79. package/dist/radio/createRadioGroup.d.ts.map +1 -1
  80. package/dist/searchfield/createSearchField.d.ts.map +1 -1
  81. package/dist/select/createHiddenSelect.d.ts.map +1 -1
  82. package/dist/select/createSelect.d.ts.map +1 -1
  83. package/dist/slider/createSlider.d.ts.map +1 -1
  84. package/dist/table/createTable.d.ts.map +1 -1
  85. package/dist/tabs/createTabs.d.ts +1 -1
  86. package/dist/tabs/createTabs.d.ts.map +1 -1
  87. package/dist/tag/createTag.d.ts.map +1 -1
  88. package/dist/tag/createTagGroup.d.ts.map +1 -1
  89. package/dist/toast/createToast.d.ts +4 -0
  90. package/dist/toast/createToast.d.ts.map +1 -1
  91. package/dist/toast/createToastRegion.d.ts.map +1 -1
  92. package/dist/toolbar/createToolbar.d.ts.map +1 -1
  93. package/dist/tooltip/createTooltipTrigger.d.ts.map +1 -1
  94. package/dist/tree/createTree.d.ts.map +1 -1
  95. package/dist/tree/createTreeItem.d.ts.map +1 -1
  96. package/dist/tree/types.d.ts +4 -0
  97. package/dist/tree/types.d.ts.map +1 -1
  98. package/dist/utils/env.d.ts +1 -1
  99. package/dist/utils/env.d.ts.map +1 -1
  100. package/dist/utils/platform.d.ts.map +1 -1
  101. package/dist/visually-hidden/createVisuallyHidden.d.ts.map +1 -1
  102. package/package.json +8 -6
  103. package/src/actiongroup/createActionGroup.ts +324 -0
  104. package/src/actiongroup/index.ts +8 -0
  105. package/src/autocomplete/createAutocomplete.ts +32 -9
  106. package/src/breadcrumbs/createBreadcrumbs.ts +10 -15
  107. package/src/button/createButton.ts +1 -1
  108. package/src/button/createToggleButtonGroup.ts +128 -0
  109. package/src/button/index.ts +9 -0
  110. package/src/calendar/createCalendarCell.ts +6 -4
  111. package/src/calendar/createCalendarGrid.ts +27 -18
  112. package/src/calendar/createRangeCalendarCell.ts +26 -9
  113. package/src/checkbox/createCheckboxGroup.ts +21 -4
  114. package/src/collections/index.ts +242 -0
  115. package/src/color/createColorArea.ts +380 -314
  116. package/src/color/createColorField.ts +137 -137
  117. package/src/color/createColorSlider.ts +286 -197
  118. package/src/color/createColorSwatch.ts +40 -40
  119. package/src/color/createColorWheel.ts +218 -208
  120. package/src/color/index.ts +24 -24
  121. package/src/color/types.ts +116 -116
  122. package/src/combobox/createComboBox.ts +670 -647
  123. package/src/combobox/index.ts +6 -6
  124. package/src/datepicker/createDatePicker.ts +54 -16
  125. package/src/datepicker/createDateRangePicker.ts +246 -0
  126. package/src/datepicker/createDateSegment.ts +185 -31
  127. package/src/datepicker/createTimeSegment.ts +370 -0
  128. package/src/datepicker/index.ts +14 -0
  129. package/src/dialog/createDialog.ts +120 -120
  130. package/src/dialog/index.ts +2 -2
  131. package/src/dialog/types.ts +19 -19
  132. package/src/disclosure/createDisclosureGroup.ts +5 -2
  133. package/src/dnd/createDrag.ts +224 -209
  134. package/src/dnd/createDraggableCollection.ts +96 -63
  135. package/src/dnd/createDraggableItem.ts +259 -243
  136. package/src/dnd/createDrop.ts +322 -321
  137. package/src/dnd/createDroppableCollection.ts +682 -293
  138. package/src/dnd/createDroppableItem.ts +215 -213
  139. package/src/dnd/index.ts +55 -47
  140. package/src/dnd/types.ts +89 -89
  141. package/src/dnd/utils.ts +294 -294
  142. package/src/focus/createAutoFocus.ts +321 -321
  143. package/src/focus/createFocusRestore.ts +313 -313
  144. package/src/focus/createVirtualFocus.ts +396 -396
  145. package/src/form/createFormValidation.ts +224 -224
  146. package/src/form/index.ts +11 -11
  147. package/src/grid/createGrid.ts +3 -1
  148. package/src/gridlist/createGridList.ts +16 -0
  149. package/src/gridlist/createGridListItem.ts +1 -1
  150. package/src/i18n/NumberFormatter.ts +266 -266
  151. package/src/i18n/createCollator.ts +79 -79
  152. package/src/i18n/createDateFormatter.ts +83 -83
  153. package/src/i18n/createFilter.ts +131 -131
  154. package/src/i18n/createNumberFormatter.ts +52 -52
  155. package/src/i18n/index.ts +40 -40
  156. package/src/i18n/locale.tsx +188 -188
  157. package/src/i18n/utils.ts +99 -99
  158. package/src/index.ts +51 -0
  159. package/src/interactions/createFocus.ts +6 -5
  160. package/src/interactions/createFocusWithin.ts +6 -5
  161. package/src/interactions/createLongPress.ts +174 -174
  162. package/src/interactions/createMove.ts +289 -289
  163. package/src/interactions/createPress.ts +5 -5
  164. package/src/landmark/createLandmark.ts +377 -377
  165. package/src/landmark/index.ts +8 -8
  166. package/src/link/createLink.ts +23 -8
  167. package/src/listbox/createListBox.ts +308 -269
  168. package/src/listbox/createOption.ts +162 -151
  169. package/src/listbox/index.ts +12 -12
  170. package/src/live-announcer/announce.ts +322 -322
  171. package/src/live-announcer/index.ts +9 -9
  172. package/src/menu/createMenu.ts +405 -396
  173. package/src/menu/createMenuItem.ts +149 -149
  174. package/src/menu/createMenuTrigger.ts +88 -88
  175. package/src/menu/index.ts +18 -18
  176. package/src/meter/createMeter.ts +1 -6
  177. package/src/numberfield/createNumberField.ts +311 -268
  178. package/src/numberfield/index.ts +5 -5
  179. package/src/overlays/ariaHideOutside.ts +219 -219
  180. package/src/overlays/createInteractOutside.ts +149 -149
  181. package/src/overlays/createModal.tsx +238 -202
  182. package/src/overlays/createOverlay.ts +165 -155
  183. package/src/overlays/createOverlayTrigger.ts +85 -85
  184. package/src/overlays/createPreventScroll.ts +266 -266
  185. package/src/overlays/index.ts +48 -44
  186. package/src/popover/calculatePosition.ts +6 -6
  187. package/src/popover/createOverlayPosition.ts +7 -4
  188. package/src/popover/createPopover.ts +21 -7
  189. package/src/progress/createProgressBar.ts +6 -1
  190. package/src/radio/createRadioGroup.ts +88 -14
  191. package/src/searchfield/createSearchField.ts +241 -186
  192. package/src/searchfield/index.ts +2 -2
  193. package/src/select/createHiddenSelect.tsx +263 -236
  194. package/src/select/createSelect.ts +373 -395
  195. package/src/select/index.ts +14 -14
  196. package/src/slider/createSlider.ts +364 -349
  197. package/src/slider/index.ts +2 -2
  198. package/src/ssr/index.tsx +370 -370
  199. package/src/table/createTable.ts +3 -1
  200. package/src/table/createTableColumnHeader.ts +1 -1
  201. package/src/table/createTableRow.ts +1 -1
  202. package/src/tabs/createTabs.ts +80 -51
  203. package/src/tag/createTag.ts +135 -6
  204. package/src/tag/createTagGroup.ts +7 -2
  205. package/src/toast/createToast.ts +8 -2
  206. package/src/toast/createToastRegion.ts +0 -1
  207. package/src/toolbar/createToolbar.ts +75 -1
  208. package/src/tooltip/createTooltip.ts +79 -79
  209. package/src/tooltip/createTooltipTrigger.ts +226 -222
  210. package/src/tooltip/index.ts +6 -6
  211. package/src/tree/createTree.ts +261 -246
  212. package/src/tree/createTreeItem.ts +282 -233
  213. package/src/tree/createTreeSelectionCheckbox.ts +68 -68
  214. package/src/tree/index.ts +16 -16
  215. package/src/tree/types.ts +91 -87
  216. package/src/utils/env.ts +55 -54
  217. package/src/utils/platform.ts +16 -6
  218. package/src/visually-hidden/createVisuallyHidden.ts +139 -124
  219. package/src/visually-hidden/index.ts +6 -6
@@ -1,219 +1,219 @@
1
- /**
2
- * Hides all elements in the DOM outside the given targets from screen readers.
3
- * Based on @react-aria/overlays ariaHideOutside.
4
- */
5
-
6
- import { getOwnerWindow } from '../utils';
7
-
8
- const supportsInert = typeof HTMLElement !== 'undefined' && 'inert' in HTMLElement.prototype;
9
-
10
- export interface AriaHideOutsideOptions {
11
- /** The root element to start hiding from. */
12
- root?: Element;
13
- /** Whether to use the `inert` attribute instead of `aria-hidden`. */
14
- shouldUseInert?: boolean;
15
- }
16
-
17
- // Keeps a ref count of all hidden elements. Added to when hiding an element, and
18
- // subtracted from when showing it again. When it reaches zero, aria-hidden is removed.
19
- const refCountMap = new WeakMap<Element, number>();
20
-
21
- interface ObserverWrapper {
22
- visibleNodes: Set<Element>;
23
- hiddenNodes: Set<Element>;
24
- observe: () => void;
25
- disconnect: () => void;
26
- }
27
-
28
- const observerStack: ObserverWrapper[] = [];
29
-
30
- /**
31
- * Hides all elements in the DOM outside the given targets from screen readers using aria-hidden,
32
- * and returns a function to revert these changes. In addition, changes to the DOM are watched
33
- * and new elements outside the targets are automatically hidden.
34
- * @param targets - The elements that should remain visible.
35
- * @param options - Options for hiding behavior.
36
- * @returns - A function to restore all hidden elements.
37
- */
38
- export function ariaHideOutside(
39
- targets: Element[],
40
- options?: AriaHideOutsideOptions | Element
41
- ): () => void {
42
- const windowObj = getOwnerWindow(targets?.[0]);
43
- const opts = options instanceof windowObj.Element ? { root: options } : options;
44
- const root = opts?.root ?? document.body;
45
- const shouldUseInert = opts?.shouldUseInert && supportsInert;
46
- const visibleNodes = new Set<Element>(targets);
47
- const hiddenNodes = new Set<Element>();
48
-
49
- const getHidden = (element: Element): boolean => {
50
- return shouldUseInert && element instanceof windowObj.HTMLElement
51
- ? element.inert
52
- : element.getAttribute('aria-hidden') === 'true';
53
- };
54
-
55
- const setHidden = (element: Element, hidden: boolean): void => {
56
- if (shouldUseInert && element instanceof windowObj.HTMLElement) {
57
- element.inert = hidden;
58
- } else if (hidden) {
59
- element.setAttribute('aria-hidden', 'true');
60
- } else {
61
- element.removeAttribute('aria-hidden');
62
- if (element instanceof windowObj.HTMLElement) {
63
- // We only ever call setHidden with hidden = false when the nodeCount is 1 aka
64
- // we are trying to make the element visible to screen readers again, so remove inert as well
65
- element.inert = false;
66
- }
67
- }
68
- };
69
-
70
- const hide = (node: Element): void => {
71
- let refCount = refCountMap.get(node) ?? 0;
72
-
73
- // If already aria-hidden, and the ref count is zero, then this element
74
- // was already hidden and there's nothing for us to do.
75
- if (getHidden(node) && refCount === 0) {
76
- return;
77
- }
78
-
79
- if (refCount === 0) {
80
- setHidden(node, true);
81
- }
82
-
83
- hiddenNodes.add(node);
84
- refCountMap.set(node, refCount + 1);
85
- };
86
-
87
- const walk = (walkRoot: Element): void => {
88
- // Keep live announcer and top layer elements (e.g. toasts) visible.
89
- for (const element of walkRoot.querySelectorAll('[data-live-announcer], [data-solidaria-top-layer]')) {
90
- visibleNodes.add(element);
91
- }
92
-
93
- const acceptNode = (node: Element): number => {
94
- // Skip this node and its children if it is one of the target nodes, or a live announcer.
95
- // Also skip children of already hidden nodes, as aria-hidden is recursive. An exception is
96
- // made for elements with role="row" since VoiceOver on iOS has issues hiding elements with role="row".
97
- // For that case we want to hide the cells inside as well (https://bugs.webkit.org/show_bug.cgi?id=222623).
98
- if (
99
- hiddenNodes.has(node) ||
100
- visibleNodes.has(node) ||
101
- (node.parentElement && hiddenNodes.has(node.parentElement) && node.parentElement.getAttribute('role') !== 'row')
102
- ) {
103
- return NodeFilter.FILTER_REJECT;
104
- }
105
-
106
- // Skip this node but continue to children if one of the targets is inside the node.
107
- for (const target of visibleNodes) {
108
- if (node.contains(target)) {
109
- return NodeFilter.FILTER_SKIP;
110
- }
111
- }
112
-
113
- return NodeFilter.FILTER_ACCEPT;
114
- };
115
-
116
- const walker = document.createTreeWalker(walkRoot, NodeFilter.SHOW_ELEMENT, { acceptNode });
117
-
118
- // TreeWalker does not include the root.
119
- const acceptRoot = acceptNode(walkRoot);
120
- if (acceptRoot === NodeFilter.FILTER_ACCEPT) {
121
- hide(walkRoot);
122
- }
123
-
124
- if (acceptRoot !== NodeFilter.FILTER_REJECT) {
125
- let node = walker.nextNode() as Element;
126
- while (node != null) {
127
- hide(node);
128
- node = walker.nextNode() as Element;
129
- }
130
- }
131
- };
132
-
133
- // If there is already a MutationObserver listening from a previous call,
134
- // disconnect it so the new one takes over.
135
- if (observerStack.length) {
136
- observerStack[observerStack.length - 1].disconnect();
137
- }
138
-
139
- walk(root);
140
-
141
- const observer = new MutationObserver((changes) => {
142
- for (const change of changes) {
143
- if (change.type !== 'childList') {
144
- continue;
145
- }
146
-
147
- // If the parent element of the added nodes is not within one of the targets,
148
- // and not already inside a hidden node, hide all of the new children.
149
- if (![...visibleNodes, ...hiddenNodes].some((node) => node.contains(change.target))) {
150
- for (const node of change.addedNodes) {
151
- if (
152
- (node instanceof HTMLElement || node instanceof SVGElement) &&
153
- (node.dataset.liveAnnouncer === 'true' || node.dataset.solidariaTopLayer === 'true')
154
- ) {
155
- visibleNodes.add(node);
156
- } else if (node instanceof Element) {
157
- walk(node);
158
- }
159
- }
160
- }
161
- }
162
- });
163
-
164
- observer.observe(root, { childList: true, subtree: true });
165
-
166
- const observerWrapper: ObserverWrapper = {
167
- visibleNodes,
168
- hiddenNodes,
169
- observe() {
170
- observer.observe(root, { childList: true, subtree: true });
171
- },
172
- disconnect() {
173
- observer.disconnect();
174
- },
175
- };
176
-
177
- observerStack.push(observerWrapper);
178
-
179
- return (): void => {
180
- observer.disconnect();
181
-
182
- for (const node of hiddenNodes) {
183
- const count = refCountMap.get(node);
184
- if (count == null) {
185
- continue;
186
- }
187
- if (count === 1) {
188
- setHidden(node, false);
189
- refCountMap.delete(node);
190
- } else {
191
- refCountMap.set(node, count - 1);
192
- }
193
- }
194
-
195
- // Remove this observer from the stack, and start the previous one.
196
- if (observerWrapper === observerStack[observerStack.length - 1]) {
197
- observerStack.pop();
198
- if (observerStack.length) {
199
- observerStack[observerStack.length - 1].observe();
200
- }
201
- } else {
202
- observerStack.splice(observerStack.indexOf(observerWrapper), 1);
203
- }
204
- };
205
- }
206
-
207
- /**
208
- * Keeps an element visible when aria-hiding is active.
209
- * Used for elements like live regions that should remain accessible.
210
- */
211
- export function keepVisible(element: Element): (() => void) | undefined {
212
- const observer = observerStack[observerStack.length - 1];
213
- if (observer && !observer.visibleNodes.has(element)) {
214
- observer.visibleNodes.add(element);
215
- return () => {
216
- observer.visibleNodes.delete(element);
217
- };
218
- }
219
- }
1
+ /**
2
+ * Hides all elements in the DOM outside the given targets from screen readers.
3
+ * Based on @react-aria/overlays ariaHideOutside.
4
+ */
5
+
6
+ import { getOwnerWindow } from '../utils';
7
+
8
+ const supportsInert = typeof HTMLElement !== 'undefined' && 'inert' in HTMLElement.prototype;
9
+
10
+ export interface AriaHideOutsideOptions {
11
+ /** The root element to start hiding from. */
12
+ root?: Element;
13
+ /** Whether to use the `inert` attribute instead of `aria-hidden`. */
14
+ shouldUseInert?: boolean;
15
+ }
16
+
17
+ // Keeps a ref count of all hidden elements. Added to when hiding an element, and
18
+ // subtracted from when showing it again. When it reaches zero, aria-hidden is removed.
19
+ const refCountMap = new WeakMap<Element, number>();
20
+
21
+ interface ObserverWrapper {
22
+ visibleNodes: Set<Element>;
23
+ hiddenNodes: Set<Element>;
24
+ observe: () => void;
25
+ disconnect: () => void;
26
+ }
27
+
28
+ const observerStack: ObserverWrapper[] = [];
29
+
30
+ /**
31
+ * Hides all elements in the DOM outside the given targets from screen readers using aria-hidden,
32
+ * and returns a function to revert these changes. In addition, changes to the DOM are watched
33
+ * and new elements outside the targets are automatically hidden.
34
+ * @param targets - The elements that should remain visible.
35
+ * @param options - Options for hiding behavior.
36
+ * @returns - A function to restore all hidden elements.
37
+ */
38
+ export function ariaHideOutside(
39
+ targets: Element[],
40
+ options?: AriaHideOutsideOptions | Element
41
+ ): () => void {
42
+ const windowObj = getOwnerWindow(targets?.[0]);
43
+ const opts = options instanceof windowObj.Element ? { root: options } : options;
44
+ const root = opts?.root ?? document.body;
45
+ const shouldUseInert = opts?.shouldUseInert && supportsInert;
46
+ const visibleNodes = new Set<Element>(targets);
47
+ const hiddenNodes = new Set<Element>();
48
+
49
+ const getHidden = (element: Element): boolean => {
50
+ return shouldUseInert && element instanceof windowObj.HTMLElement
51
+ ? element.inert
52
+ : element.getAttribute('aria-hidden') === 'true';
53
+ };
54
+
55
+ const setHidden = (element: Element, hidden: boolean): void => {
56
+ if (shouldUseInert && element instanceof windowObj.HTMLElement) {
57
+ element.inert = hidden;
58
+ } else if (hidden) {
59
+ element.setAttribute('aria-hidden', 'true');
60
+ } else {
61
+ element.removeAttribute('aria-hidden');
62
+ if (element instanceof windowObj.HTMLElement) {
63
+ // We only ever call setHidden with hidden = false when the nodeCount is 1 aka
64
+ // we are trying to make the element visible to screen readers again, so remove inert as well
65
+ element.inert = false;
66
+ }
67
+ }
68
+ };
69
+
70
+ const hide = (node: Element): void => {
71
+ let refCount = refCountMap.get(node) ?? 0;
72
+
73
+ // If already aria-hidden, and the ref count is zero, then this element
74
+ // was already hidden and there's nothing for us to do.
75
+ if (getHidden(node) && refCount === 0) {
76
+ return;
77
+ }
78
+
79
+ if (refCount === 0) {
80
+ setHidden(node, true);
81
+ }
82
+
83
+ hiddenNodes.add(node);
84
+ refCountMap.set(node, refCount + 1);
85
+ };
86
+
87
+ const walk = (walkRoot: Element): void => {
88
+ // Keep live announcer and top layer elements (e.g. toasts) visible.
89
+ for (const element of walkRoot.querySelectorAll('[data-live-announcer], [data-solidaria-top-layer]')) {
90
+ visibleNodes.add(element);
91
+ }
92
+
93
+ const acceptNode = (node: Element): number => {
94
+ // Skip this node and its children if it is one of the target nodes, or a live announcer.
95
+ // Also skip children of already hidden nodes, as aria-hidden is recursive. An exception is
96
+ // made for elements with role="row" since VoiceOver on iOS has issues hiding elements with role="row".
97
+ // For that case we want to hide the cells inside as well (https://bugs.webkit.org/show_bug.cgi?id=222623).
98
+ if (
99
+ hiddenNodes.has(node) ||
100
+ visibleNodes.has(node) ||
101
+ (node.parentElement && hiddenNodes.has(node.parentElement) && node.parentElement.getAttribute('role') !== 'row')
102
+ ) {
103
+ return NodeFilter.FILTER_REJECT;
104
+ }
105
+
106
+ // Skip this node but continue to children if one of the targets is inside the node.
107
+ for (const target of visibleNodes) {
108
+ if (node.contains(target)) {
109
+ return NodeFilter.FILTER_SKIP;
110
+ }
111
+ }
112
+
113
+ return NodeFilter.FILTER_ACCEPT;
114
+ };
115
+
116
+ const walker = document.createTreeWalker(walkRoot, NodeFilter.SHOW_ELEMENT, { acceptNode });
117
+
118
+ // TreeWalker does not include the root.
119
+ const acceptRoot = acceptNode(walkRoot);
120
+ if (acceptRoot === NodeFilter.FILTER_ACCEPT) {
121
+ hide(walkRoot);
122
+ }
123
+
124
+ if (acceptRoot !== NodeFilter.FILTER_REJECT) {
125
+ let node = walker.nextNode() as Element;
126
+ while (node != null) {
127
+ hide(node);
128
+ node = walker.nextNode() as Element;
129
+ }
130
+ }
131
+ };
132
+
133
+ // If there is already a MutationObserver listening from a previous call,
134
+ // disconnect it so the new one takes over.
135
+ if (observerStack.length) {
136
+ observerStack[observerStack.length - 1].disconnect();
137
+ }
138
+
139
+ walk(root);
140
+
141
+ const observer = new MutationObserver((changes) => {
142
+ for (const change of changes) {
143
+ if (change.type !== 'childList') {
144
+ continue;
145
+ }
146
+
147
+ // If the parent element of the added nodes is not within one of the targets,
148
+ // and not already inside a hidden node, hide all of the new children.
149
+ if (![...visibleNodes, ...hiddenNodes].some((node) => node.contains(change.target))) {
150
+ for (const node of change.addedNodes) {
151
+ if (
152
+ (node instanceof HTMLElement || node instanceof SVGElement) &&
153
+ (node.dataset.liveAnnouncer === 'true' || node.dataset.solidariaTopLayer === 'true')
154
+ ) {
155
+ visibleNodes.add(node);
156
+ } else if (node instanceof Element) {
157
+ walk(node);
158
+ }
159
+ }
160
+ }
161
+ }
162
+ });
163
+
164
+ observer.observe(root, { childList: true, subtree: true });
165
+
166
+ const observerWrapper: ObserverWrapper = {
167
+ visibleNodes,
168
+ hiddenNodes,
169
+ observe() {
170
+ observer.observe(root, { childList: true, subtree: true });
171
+ },
172
+ disconnect() {
173
+ observer.disconnect();
174
+ },
175
+ };
176
+
177
+ observerStack.push(observerWrapper);
178
+
179
+ return (): void => {
180
+ observer.disconnect();
181
+
182
+ for (const node of hiddenNodes) {
183
+ const count = refCountMap.get(node);
184
+ if (count == null) {
185
+ continue;
186
+ }
187
+ if (count === 1) {
188
+ setHidden(node, false);
189
+ refCountMap.delete(node);
190
+ } else {
191
+ refCountMap.set(node, count - 1);
192
+ }
193
+ }
194
+
195
+ // Remove this observer from the stack, and start the previous one.
196
+ if (observerWrapper === observerStack[observerStack.length - 1]) {
197
+ observerStack.pop();
198
+ if (observerStack.length) {
199
+ observerStack[observerStack.length - 1].observe();
200
+ }
201
+ } else {
202
+ observerStack.splice(observerStack.indexOf(observerWrapper), 1);
203
+ }
204
+ };
205
+ }
206
+
207
+ /**
208
+ * Keeps an element visible when aria-hiding is active.
209
+ * Used for elements like live regions that should remain accessible.
210
+ */
211
+ export function keepVisible(element: Element): (() => void) | undefined {
212
+ const observer = observerStack[observerStack.length - 1];
213
+ if (observer && !observer.visibleNodes.has(element)) {
214
+ observer.visibleNodes.add(element);
215
+ return () => {
216
+ observer.visibleNodes.delete(element);
217
+ };
218
+ }
219
+ }