@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.
- package/LICENSE +21 -0
- package/dist/actiongroup/createActionGroup.d.ts +29 -0
- package/dist/actiongroup/createActionGroup.d.ts.map +1 -0
- package/dist/actiongroup/index.d.ts +2 -0
- package/dist/actiongroup/index.d.ts.map +1 -0
- package/dist/autocomplete/createAutocomplete.d.ts +6 -2
- package/dist/autocomplete/createAutocomplete.d.ts.map +1 -1
- package/dist/breadcrumbs/createBreadcrumbs.d.ts +2 -0
- package/dist/breadcrumbs/createBreadcrumbs.d.ts.map +1 -1
- package/dist/button/createToggleButtonGroup.d.ts +32 -0
- package/dist/button/createToggleButtonGroup.d.ts.map +1 -0
- package/dist/button/index.d.ts +2 -0
- package/dist/button/index.d.ts.map +1 -1
- package/dist/calendar/createCalendarCell.d.ts +2 -0
- package/dist/calendar/createCalendarCell.d.ts.map +1 -1
- package/dist/calendar/createCalendarGrid.d.ts.map +1 -1
- package/dist/calendar/createRangeCalendarCell.d.ts +3 -1
- package/dist/calendar/createRangeCalendarCell.d.ts.map +1 -1
- package/dist/checkbox/createCheckboxGroup.d.ts +5 -1
- package/dist/checkbox/createCheckboxGroup.d.ts.map +1 -1
- package/dist/collections/index.d.ts +56 -0
- package/dist/collections/index.d.ts.map +1 -0
- package/dist/color/createColorArea.d.ts.map +1 -1
- package/dist/color/createColorSlider.d.ts.map +1 -1
- package/dist/color/createColorWheel.d.ts.map +1 -1
- package/dist/combobox/createComboBox.d.ts +6 -0
- package/dist/combobox/createComboBox.d.ts.map +1 -1
- package/dist/datepicker/createDatePicker.d.ts +6 -0
- package/dist/datepicker/createDatePicker.d.ts.map +1 -1
- package/dist/datepicker/createDateRangePicker.d.ts +40 -0
- package/dist/datepicker/createDateRangePicker.d.ts.map +1 -0
- package/dist/datepicker/createDateSegment.d.ts +1 -1
- package/dist/datepicker/createDateSegment.d.ts.map +1 -1
- package/dist/datepicker/createTimeSegment.d.ts +29 -0
- package/dist/datepicker/createTimeSegment.d.ts.map +1 -0
- package/dist/datepicker/index.d.ts +2 -0
- package/dist/datepicker/index.d.ts.map +1 -1
- package/dist/disclosure/createDisclosureGroup.d.ts +2 -1
- package/dist/disclosure/createDisclosureGroup.d.ts.map +1 -1
- package/dist/dnd/createDrag.d.ts.map +1 -1
- package/dist/dnd/createDraggableCollection.d.ts +4 -0
- package/dist/dnd/createDraggableCollection.d.ts.map +1 -1
- package/dist/dnd/createDraggableItem.d.ts.map +1 -1
- package/dist/dnd/createDrop.d.ts.map +1 -1
- package/dist/dnd/createDroppableCollection.d.ts +32 -1
- package/dist/dnd/createDroppableCollection.d.ts.map +1 -1
- package/dist/dnd/createDroppableItem.d.ts.map +1 -1
- package/dist/dnd/index.d.ts +1 -1
- package/dist/dnd/index.d.ts.map +1 -1
- package/dist/grid/createGrid.d.ts.map +1 -1
- package/dist/gridlist/createGridList.d.ts.map +1 -1
- package/dist/index.d.ts +6 -4
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +4659 -3452
- package/dist/index.js.map +1 -7
- package/dist/index.ssr.js +4659 -3452
- package/dist/index.ssr.js.map +1 -7
- package/dist/interactions/createFocus.d.ts.map +1 -1
- package/dist/interactions/createFocusWithin.d.ts.map +1 -1
- package/dist/link/createLink.d.ts +10 -0
- package/dist/link/createLink.d.ts.map +1 -1
- package/dist/listbox/createListBox.d.ts +1 -0
- package/dist/listbox/createListBox.d.ts.map +1 -1
- package/dist/listbox/createOption.d.ts.map +1 -1
- package/dist/menu/createMenu.d.ts +1 -0
- package/dist/menu/createMenu.d.ts.map +1 -1
- package/dist/meter/createMeter.d.ts.map +1 -1
- package/dist/numberfield/createNumberField.d.ts +18 -0
- package/dist/numberfield/createNumberField.d.ts.map +1 -1
- package/dist/overlays/createModal.d.ts +16 -0
- package/dist/overlays/createModal.d.ts.map +1 -1
- package/dist/overlays/createOverlay.d.ts.map +1 -1
- package/dist/overlays/index.d.ts +1 -1
- package/dist/overlays/index.d.ts.map +1 -1
- package/dist/popover/createOverlayPosition.d.ts.map +1 -1
- package/dist/popover/createPopover.d.ts.map +1 -1
- package/dist/progress/createProgressBar.d.ts.map +1 -1
- package/dist/radio/createRadioGroup.d.ts +2 -2
- package/dist/radio/createRadioGroup.d.ts.map +1 -1
- package/dist/searchfield/createSearchField.d.ts.map +1 -1
- package/dist/select/createHiddenSelect.d.ts.map +1 -1
- package/dist/select/createSelect.d.ts.map +1 -1
- package/dist/slider/createSlider.d.ts.map +1 -1
- package/dist/table/createTable.d.ts.map +1 -1
- package/dist/tabs/createTabs.d.ts +1 -1
- package/dist/tabs/createTabs.d.ts.map +1 -1
- package/dist/tag/createTag.d.ts.map +1 -1
- package/dist/tag/createTagGroup.d.ts.map +1 -1
- package/dist/toast/createToast.d.ts +4 -0
- package/dist/toast/createToast.d.ts.map +1 -1
- package/dist/toast/createToastRegion.d.ts.map +1 -1
- package/dist/toolbar/createToolbar.d.ts.map +1 -1
- package/dist/tooltip/createTooltipTrigger.d.ts.map +1 -1
- package/dist/tree/createTree.d.ts.map +1 -1
- package/dist/tree/createTreeItem.d.ts.map +1 -1
- package/dist/tree/types.d.ts +4 -0
- package/dist/tree/types.d.ts.map +1 -1
- package/dist/utils/env.d.ts +1 -1
- package/dist/utils/env.d.ts.map +1 -1
- package/dist/utils/platform.d.ts.map +1 -1
- package/dist/visually-hidden/createVisuallyHidden.d.ts.map +1 -1
- package/package.json +8 -6
- package/src/actiongroup/createActionGroup.ts +324 -0
- package/src/actiongroup/index.ts +8 -0
- package/src/autocomplete/createAutocomplete.ts +32 -9
- package/src/breadcrumbs/createBreadcrumbs.ts +10 -15
- package/src/button/createButton.ts +1 -1
- package/src/button/createToggleButtonGroup.ts +128 -0
- package/src/button/index.ts +9 -0
- package/src/calendar/createCalendarCell.ts +6 -4
- package/src/calendar/createCalendarGrid.ts +27 -18
- package/src/calendar/createRangeCalendarCell.ts +26 -9
- package/src/checkbox/createCheckboxGroup.ts +21 -4
- package/src/collections/index.ts +242 -0
- package/src/color/createColorArea.ts +380 -314
- package/src/color/createColorField.ts +137 -137
- package/src/color/createColorSlider.ts +286 -197
- package/src/color/createColorSwatch.ts +40 -40
- package/src/color/createColorWheel.ts +218 -208
- package/src/color/index.ts +24 -24
- package/src/color/types.ts +116 -116
- package/src/combobox/createComboBox.ts +670 -647
- package/src/combobox/index.ts +6 -6
- package/src/datepicker/createDatePicker.ts +54 -16
- package/src/datepicker/createDateRangePicker.ts +246 -0
- package/src/datepicker/createDateSegment.ts +185 -31
- package/src/datepicker/createTimeSegment.ts +370 -0
- package/src/datepicker/index.ts +14 -0
- package/src/dialog/createDialog.ts +120 -120
- package/src/dialog/index.ts +2 -2
- package/src/dialog/types.ts +19 -19
- package/src/disclosure/createDisclosureGroup.ts +5 -2
- package/src/dnd/createDrag.ts +224 -209
- package/src/dnd/createDraggableCollection.ts +96 -63
- package/src/dnd/createDraggableItem.ts +259 -243
- package/src/dnd/createDrop.ts +322 -321
- package/src/dnd/createDroppableCollection.ts +682 -293
- package/src/dnd/createDroppableItem.ts +215 -213
- package/src/dnd/index.ts +55 -47
- package/src/dnd/types.ts +89 -89
- package/src/dnd/utils.ts +294 -294
- package/src/focus/createAutoFocus.ts +321 -321
- package/src/focus/createFocusRestore.ts +313 -313
- package/src/focus/createVirtualFocus.ts +396 -396
- package/src/form/createFormValidation.ts +224 -224
- package/src/form/index.ts +11 -11
- package/src/grid/createGrid.ts +3 -1
- package/src/gridlist/createGridList.ts +16 -0
- package/src/gridlist/createGridListItem.ts +1 -1
- package/src/i18n/NumberFormatter.ts +266 -266
- package/src/i18n/createCollator.ts +79 -79
- package/src/i18n/createDateFormatter.ts +83 -83
- package/src/i18n/createFilter.ts +131 -131
- package/src/i18n/createNumberFormatter.ts +52 -52
- package/src/i18n/index.ts +40 -40
- package/src/i18n/locale.tsx +188 -188
- package/src/i18n/utils.ts +99 -99
- package/src/index.ts +51 -0
- package/src/interactions/createFocus.ts +6 -5
- package/src/interactions/createFocusWithin.ts +6 -5
- package/src/interactions/createLongPress.ts +174 -174
- package/src/interactions/createMove.ts +289 -289
- package/src/interactions/createPress.ts +5 -5
- package/src/landmark/createLandmark.ts +377 -377
- package/src/landmark/index.ts +8 -8
- package/src/link/createLink.ts +23 -8
- package/src/listbox/createListBox.ts +308 -269
- package/src/listbox/createOption.ts +162 -151
- package/src/listbox/index.ts +12 -12
- package/src/live-announcer/announce.ts +322 -322
- package/src/live-announcer/index.ts +9 -9
- package/src/menu/createMenu.ts +405 -396
- package/src/menu/createMenuItem.ts +149 -149
- package/src/menu/createMenuTrigger.ts +88 -88
- package/src/menu/index.ts +18 -18
- package/src/meter/createMeter.ts +1 -6
- package/src/numberfield/createNumberField.ts +311 -268
- package/src/numberfield/index.ts +5 -5
- package/src/overlays/ariaHideOutside.ts +219 -219
- package/src/overlays/createInteractOutside.ts +149 -149
- package/src/overlays/createModal.tsx +238 -202
- package/src/overlays/createOverlay.ts +165 -155
- package/src/overlays/createOverlayTrigger.ts +85 -85
- package/src/overlays/createPreventScroll.ts +266 -266
- package/src/overlays/index.ts +48 -44
- package/src/popover/calculatePosition.ts +6 -6
- package/src/popover/createOverlayPosition.ts +7 -4
- package/src/popover/createPopover.ts +21 -7
- package/src/progress/createProgressBar.ts +6 -1
- package/src/radio/createRadioGroup.ts +88 -14
- package/src/searchfield/createSearchField.ts +241 -186
- package/src/searchfield/index.ts +2 -2
- package/src/select/createHiddenSelect.tsx +263 -236
- package/src/select/createSelect.ts +373 -395
- package/src/select/index.ts +14 -14
- package/src/slider/createSlider.ts +364 -349
- package/src/slider/index.ts +2 -2
- package/src/ssr/index.tsx +370 -370
- package/src/table/createTable.ts +3 -1
- package/src/table/createTableColumnHeader.ts +1 -1
- package/src/table/createTableRow.ts +1 -1
- package/src/tabs/createTabs.ts +80 -51
- package/src/tag/createTag.ts +135 -6
- package/src/tag/createTagGroup.ts +7 -2
- package/src/toast/createToast.ts +8 -2
- package/src/toast/createToastRegion.ts +0 -1
- package/src/toolbar/createToolbar.ts +75 -1
- package/src/tooltip/createTooltip.ts +79 -79
- package/src/tooltip/createTooltipTrigger.ts +226 -222
- package/src/tooltip/index.ts +6 -6
- package/src/tree/createTree.ts +261 -246
- package/src/tree/createTreeItem.ts +282 -233
- package/src/tree/createTreeSelectionCheckbox.ts +68 -68
- package/src/tree/index.ts +16 -16
- package/src/tree/types.ts +91 -87
- package/src/utils/env.ts +55 -54
- package/src/utils/platform.ts +16 -6
- package/src/visually-hidden/createVisuallyHidden.ts +139 -124
- package/src/visually-hidden/index.ts +6 -6
|
@@ -1,202 +1,238 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Modal context and hooks for managing modal accessibility.
|
|
3
|
-
* Based on @react-aria/overlays useModal.
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
import {
|
|
7
|
-
createContext,
|
|
8
|
-
createSignal,
|
|
9
|
-
useContext,
|
|
10
|
-
createEffect,
|
|
11
|
-
onCleanup,
|
|
12
|
-
type JSX,
|
|
13
|
-
type Accessor,
|
|
14
|
-
type ParentComponent,
|
|
15
|
-
} from 'solid-js';
|
|
16
|
-
import { Portal } from 'solid-js/web';
|
|
17
|
-
import { isServer } from 'solid-js/web';
|
|
18
|
-
|
|
19
|
-
export interface ModalProviderProps {
|
|
20
|
-
children: JSX.Element;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
interface
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
};
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
);
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
const
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
1
|
+
/**
|
|
2
|
+
* Modal context and hooks for managing modal accessibility.
|
|
3
|
+
* Based on @react-aria/overlays useModal.
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import {
|
|
7
|
+
createContext,
|
|
8
|
+
createSignal,
|
|
9
|
+
useContext,
|
|
10
|
+
createEffect,
|
|
11
|
+
onCleanup,
|
|
12
|
+
type JSX,
|
|
13
|
+
type Accessor,
|
|
14
|
+
type ParentComponent,
|
|
15
|
+
} from 'solid-js';
|
|
16
|
+
import { Portal } from 'solid-js/web';
|
|
17
|
+
import { isServer } from 'solid-js/web';
|
|
18
|
+
|
|
19
|
+
export interface ModalProviderProps {
|
|
20
|
+
children: JSX.Element;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export interface PortalProviderProps {
|
|
24
|
+
/** Returns the element where overlays should portal. Pass null to clear inherited context. */
|
|
25
|
+
getContainer?: (() => Element | null) | null;
|
|
26
|
+
children: JSX.Element;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export interface PortalProviderContextValue {
|
|
30
|
+
getContainer?: () => Element | null;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
interface ModalContext {
|
|
34
|
+
parent: ModalContext | null;
|
|
35
|
+
modalCount: Accessor<number>;
|
|
36
|
+
addModal: () => void;
|
|
37
|
+
removeModal: () => void;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
const ModalContext = createContext<ModalContext | null>(null);
|
|
41
|
+
const PortalContext = createContext<PortalProviderContextValue>({});
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* Each ModalProvider tracks how many modals are open in its subtree. On mount, the modals
|
|
45
|
+
* trigger `addModal` to increment the count, and trigger `removeModal` on unmount to decrement it.
|
|
46
|
+
* This is done recursively so that all parent providers are incremented and decremented.
|
|
47
|
+
* If the modal count is greater than zero, we add `aria-hidden` to this provider to hide its
|
|
48
|
+
* subtree from screen readers. This is done using SolidJS context in order to account for things
|
|
49
|
+
* like portals, which can cause the component tree and the DOM tree to differ significantly in structure.
|
|
50
|
+
*/
|
|
51
|
+
export const ModalProvider: ParentComponent<ModalProviderProps> = (props) => {
|
|
52
|
+
const parent = useContext(ModalContext);
|
|
53
|
+
const [modalCount, setModalCount] = createSignal(0);
|
|
54
|
+
|
|
55
|
+
const context: ModalContext = {
|
|
56
|
+
parent,
|
|
57
|
+
modalCount,
|
|
58
|
+
addModal() {
|
|
59
|
+
setModalCount((count) => count + 1);
|
|
60
|
+
if (parent) {
|
|
61
|
+
parent.addModal();
|
|
62
|
+
}
|
|
63
|
+
},
|
|
64
|
+
removeModal() {
|
|
65
|
+
setModalCount((count) => count - 1);
|
|
66
|
+
if (parent) {
|
|
67
|
+
parent.removeModal();
|
|
68
|
+
}
|
|
69
|
+
},
|
|
70
|
+
};
|
|
71
|
+
|
|
72
|
+
return (
|
|
73
|
+
<ModalContext.Provider value={context}>
|
|
74
|
+
{props.children}
|
|
75
|
+
</ModalContext.Provider>
|
|
76
|
+
);
|
|
77
|
+
};
|
|
78
|
+
|
|
79
|
+
/**
|
|
80
|
+
* Sets the portal container for overlays rendered by descendants.
|
|
81
|
+
*/
|
|
82
|
+
export const UNSAFE_PortalProvider: ParentComponent<PortalProviderProps> = (props) => {
|
|
83
|
+
const parent = useUNSAFE_PortalContext();
|
|
84
|
+
|
|
85
|
+
return (
|
|
86
|
+
<PortalContext.Provider
|
|
87
|
+
value={{
|
|
88
|
+
getContainer: props.getContainer === null ? undefined : props.getContainer ?? parent.getContainer,
|
|
89
|
+
}}
|
|
90
|
+
>
|
|
91
|
+
{props.children}
|
|
92
|
+
</PortalContext.Provider>
|
|
93
|
+
);
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
/**
|
|
97
|
+
* Returns the portal container configuration inherited from the nearest provider.
|
|
98
|
+
*/
|
|
99
|
+
export function useUNSAFE_PortalContext(): PortalProviderContextValue {
|
|
100
|
+
return useContext(PortalContext) ?? {};
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
export interface ModalProviderAria {
|
|
104
|
+
/** Props to be spread on the container element. */
|
|
105
|
+
modalProviderProps: {
|
|
106
|
+
'aria-hidden'?: true;
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
/**
|
|
111
|
+
* Used to determine if the tree should be aria-hidden based on how many
|
|
112
|
+
* modals are open.
|
|
113
|
+
*/
|
|
114
|
+
export function useModalProvider(): ModalProviderAria {
|
|
115
|
+
const context = useContext(ModalContext);
|
|
116
|
+
return {
|
|
117
|
+
modalProviderProps: {
|
|
118
|
+
get 'aria-hidden'() {
|
|
119
|
+
return context && context.modalCount() > 0 ? true : undefined;
|
|
120
|
+
},
|
|
121
|
+
},
|
|
122
|
+
};
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
/**
|
|
126
|
+
* Creates a root node that will be aria-hidden if there are other modals open.
|
|
127
|
+
*/
|
|
128
|
+
const OverlayContainerDOM: ParentComponent<ModalProviderProps> = (props) => {
|
|
129
|
+
const { modalProviderProps } = useModalProvider();
|
|
130
|
+
return (
|
|
131
|
+
<div data-overlay-container {...modalProviderProps}>
|
|
132
|
+
{props.children}
|
|
133
|
+
</div>
|
|
134
|
+
);
|
|
135
|
+
};
|
|
136
|
+
|
|
137
|
+
/**
|
|
138
|
+
* An OverlayProvider acts as a container for the top-level application.
|
|
139
|
+
* Any application that uses modal dialogs or other overlays should
|
|
140
|
+
* be wrapped in a `<OverlayProvider>`. This is used to ensure that
|
|
141
|
+
* the main content of the application is hidden from screen readers
|
|
142
|
+
* if a modal or other overlay is opened. Only the top-most modal or
|
|
143
|
+
* overlay should be accessible at once.
|
|
144
|
+
*/
|
|
145
|
+
export const OverlayProvider: ParentComponent<ModalProviderProps> = (props) => {
|
|
146
|
+
return (
|
|
147
|
+
<ModalProvider>
|
|
148
|
+
<OverlayContainerDOM>{props.children}</OverlayContainerDOM>
|
|
149
|
+
</ModalProvider>
|
|
150
|
+
);
|
|
151
|
+
};
|
|
152
|
+
|
|
153
|
+
export interface OverlayContainerProps extends ModalProviderProps {
|
|
154
|
+
/**
|
|
155
|
+
* The container element in which the overlay portal will be placed.
|
|
156
|
+
* @default document.body
|
|
157
|
+
*/
|
|
158
|
+
portalContainer?: Element;
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
/**
|
|
162
|
+
* A container for overlays like modals and popovers. Renders the overlay
|
|
163
|
+
* into a Portal which is placed at the end of the document body.
|
|
164
|
+
* Also ensures that the overlay is hidden from screen readers if a
|
|
165
|
+
* nested modal is opened. Only the top-most modal or overlay should
|
|
166
|
+
* be accessible at once.
|
|
167
|
+
*/
|
|
168
|
+
export const OverlayContainer: ParentComponent<OverlayContainerProps> = (props) => {
|
|
169
|
+
// Don't render portal on server
|
|
170
|
+
if (isServer) {
|
|
171
|
+
return null;
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
const portalContext = useUNSAFE_PortalContext();
|
|
175
|
+
const portalContainer = () => props.portalContainer ?? portalContext.getContainer?.() ?? document.body;
|
|
176
|
+
|
|
177
|
+
createEffect(() => {
|
|
178
|
+
const container = portalContainer();
|
|
179
|
+
if (container?.closest('[data-overlay-container]')) {
|
|
180
|
+
throw new Error('An OverlayContainer must not be inside another container. Please change the portalContainer prop.');
|
|
181
|
+
}
|
|
182
|
+
});
|
|
183
|
+
|
|
184
|
+
return (
|
|
185
|
+
<Portal mount={portalContainer()}>
|
|
186
|
+
<OverlayProvider>{props.children}</OverlayProvider>
|
|
187
|
+
</Portal>
|
|
188
|
+
);
|
|
189
|
+
};
|
|
190
|
+
|
|
191
|
+
export interface AriaModalOptions {
|
|
192
|
+
/** Whether the modal is disabled. */
|
|
193
|
+
isDisabled?: boolean;
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
export interface ModalAria {
|
|
197
|
+
/** Props for the modal content element. */
|
|
198
|
+
modalProps: {
|
|
199
|
+
'data-ismodal': boolean;
|
|
200
|
+
};
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
/**
|
|
204
|
+
* Hides content outside the current `<OverlayContainer>` from screen readers
|
|
205
|
+
* on mount and restores it on unmount. Typically used by modal dialogs and
|
|
206
|
+
* other types of overlays to ensure that only the top-most modal is
|
|
207
|
+
* accessible at once.
|
|
208
|
+
*/
|
|
209
|
+
export function createModal(options?: AriaModalOptions): ModalAria {
|
|
210
|
+
// Add aria-hidden to all parent providers on mount, and restore on unmount.
|
|
211
|
+
const context = useContext(ModalContext);
|
|
212
|
+
|
|
213
|
+
if (!context) {
|
|
214
|
+
throw new Error('Modal is not contained within a provider');
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
createEffect(() => {
|
|
218
|
+
if (options?.isDisabled || !context.parent) {
|
|
219
|
+
return;
|
|
220
|
+
}
|
|
221
|
+
|
|
222
|
+
// The immediate context is from the provider containing this modal, so we only
|
|
223
|
+
// want to trigger aria-hidden on its parents not on the modal provider itself.
|
|
224
|
+
context.parent.addModal();
|
|
225
|
+
|
|
226
|
+
onCleanup(() => {
|
|
227
|
+
if (context.parent) {
|
|
228
|
+
context.parent.removeModal();
|
|
229
|
+
}
|
|
230
|
+
});
|
|
231
|
+
});
|
|
232
|
+
|
|
233
|
+
return {
|
|
234
|
+
modalProps: {
|
|
235
|
+
'data-ismodal': !options?.isDisabled,
|
|
236
|
+
},
|
|
237
|
+
};
|
|
238
|
+
}
|