@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,149 +1,149 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Provides the behavior and accessibility implementation for a menu item.
|
|
3
|
-
* Based on @react-aria/menu useMenuItem.
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
import { type JSX, type Accessor } from 'solid-js';
|
|
7
|
-
import { createPress } from '../interactions/createPress';
|
|
8
|
-
import { createHover } from '../interactions/createHover';
|
|
9
|
-
import { createFocusRing } from '../interactions/createFocusRing';
|
|
10
|
-
import { mergeProps } from '../utils/mergeProps';
|
|
11
|
-
import { access, type MaybeAccessor } from '../utils/reactivity';
|
|
12
|
-
import { getMenuData } from './createMenu';
|
|
13
|
-
import type { MenuState, Key } from '@proyecto-viviana/solid-stately';
|
|
14
|
-
|
|
15
|
-
export interface AriaMenuItemProps {
|
|
16
|
-
/** The unique key for the menu item. */
|
|
17
|
-
key: Key;
|
|
18
|
-
/** Whether the menu item is disabled. */
|
|
19
|
-
isDisabled?: boolean;
|
|
20
|
-
/** An accessible label for the menu item. */
|
|
21
|
-
'aria-label'?: string;
|
|
22
|
-
/** Handler called when the menu item is selected. */
|
|
23
|
-
onAction?: () => void;
|
|
24
|
-
/** Whether to close the menu when this item is selected. */
|
|
25
|
-
closeOnSelect?: boolean;
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
export interface MenuItemAria {
|
|
29
|
-
/** Props for the menu item element. */
|
|
30
|
-
menuItemProps: JSX.HTMLAttributes<HTMLElement>;
|
|
31
|
-
/** Props for the label text inside the menu item. */
|
|
32
|
-
labelProps: JSX.HTMLAttributes<HTMLElement>;
|
|
33
|
-
/** Props for the description text inside the menu item. */
|
|
34
|
-
descriptionProps: JSX.HTMLAttributes<HTMLElement>;
|
|
35
|
-
/** Props for the keyboard shortcut inside the menu item. */
|
|
36
|
-
keyboardShortcutProps: JSX.HTMLAttributes<HTMLElement>;
|
|
37
|
-
/** Whether the menu item is currently focused. */
|
|
38
|
-
isFocused: Accessor<boolean>;
|
|
39
|
-
/** Whether the menu item is keyboard focused. */
|
|
40
|
-
isFocusVisible: Accessor<boolean>;
|
|
41
|
-
/** Whether the menu item is currently pressed. */
|
|
42
|
-
isPressed: Accessor<boolean>;
|
|
43
|
-
/** Whether the menu item is disabled. */
|
|
44
|
-
isDisabled: Accessor<boolean>;
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
/**
|
|
48
|
-
* Provides the behavior and accessibility implementation for a menu item.
|
|
49
|
-
*/
|
|
50
|
-
export function createMenuItem<T>(
|
|
51
|
-
props: MaybeAccessor<AriaMenuItemProps>,
|
|
52
|
-
state: MenuState<T>,
|
|
53
|
-
_ref?: () => HTMLElement | null
|
|
54
|
-
): MenuItemAria {
|
|
55
|
-
const getProps = () => access(props);
|
|
56
|
-
|
|
57
|
-
// Get shared data from menu
|
|
58
|
-
const getData = () => getMenuData(state);
|
|
59
|
-
|
|
60
|
-
// Computed states
|
|
61
|
-
const isDisabled: Accessor<boolean> = () => {
|
|
62
|
-
return getProps().isDisabled
|
|
63
|
-
};
|
|
64
|
-
|
|
65
|
-
const isFocused: Accessor<boolean> = () => {
|
|
66
|
-
return state.focusedKey() === getProps().key;
|
|
67
|
-
};
|
|
68
|
-
|
|
69
|
-
// Handle press
|
|
70
|
-
const { pressProps, isPressed } = createPress({
|
|
71
|
-
get isDisabled() {
|
|
72
|
-
return isDisabled();
|
|
73
|
-
},
|
|
74
|
-
onPress() {
|
|
75
|
-
const p = getProps();
|
|
76
|
-
const key = p.key;
|
|
77
|
-
const data = getData();
|
|
78
|
-
|
|
79
|
-
// Call item-specific onAction
|
|
80
|
-
p.onAction?.();
|
|
81
|
-
|
|
82
|
-
// Call menu-level onAction
|
|
83
|
-
data?.onAction?.(key);
|
|
84
|
-
|
|
85
|
-
// Close menu if closeOnSelect is not explicitly false
|
|
86
|
-
if (p.closeOnSelect !== false) {
|
|
87
|
-
data?.onClose?.();
|
|
88
|
-
}
|
|
89
|
-
},
|
|
90
|
-
});
|
|
91
|
-
|
|
92
|
-
// Handle hover
|
|
93
|
-
const { hoverProps } = createHover({
|
|
94
|
-
get isDisabled() {
|
|
95
|
-
return isDisabled();
|
|
96
|
-
},
|
|
97
|
-
onHoverStart() {
|
|
98
|
-
state.setFocusedKey(getProps().key);
|
|
99
|
-
},
|
|
100
|
-
});
|
|
101
|
-
|
|
102
|
-
// Handle focus ring
|
|
103
|
-
const { isFocusVisible, focusProps } = createFocusRing();
|
|
104
|
-
|
|
105
|
-
// Generate unique IDs for label and description
|
|
106
|
-
const labelId = `${getProps().key}-label`;
|
|
107
|
-
const descriptionId = `${getProps().key}-desc`;
|
|
108
|
-
const keyboardId = `${getProps().key}-kbd`;
|
|
109
|
-
|
|
110
|
-
return {
|
|
111
|
-
get menuItemProps() {
|
|
112
|
-
const key = getProps().key;
|
|
113
|
-
const ariaLabel = getProps()['aria-label'];
|
|
114
|
-
|
|
115
|
-
return mergeProps(
|
|
116
|
-
pressProps as Record<string, unknown>,
|
|
117
|
-
hoverProps as Record<string, unknown>,
|
|
118
|
-
focusProps as Record<string, unknown>,
|
|
119
|
-
{
|
|
120
|
-
role: 'menuitem',
|
|
121
|
-
id: String(key),
|
|
122
|
-
'aria-disabled': isDisabled() || undefined,
|
|
123
|
-
'aria-label': ariaLabel,
|
|
124
|
-
'aria-labelledby': !ariaLabel ? labelId : undefined,
|
|
125
|
-
'aria-describedby': descriptionId,
|
|
126
|
-
tabIndex: isFocused() ? 0 : -1,
|
|
127
|
-
'data-focused': isFocused() || undefined,
|
|
128
|
-
'data-focus-visible': isFocusVisible() || undefined,
|
|
129
|
-
'data-pressed': isPressed() || undefined,
|
|
130
|
-
'data-disabled': isDisabled() || undefined,
|
|
131
|
-
} as Record<string, unknown>
|
|
132
|
-
) as JSX.HTMLAttributes<HTMLElement>;
|
|
133
|
-
},
|
|
134
|
-
labelProps: {
|
|
135
|
-
id: labelId,
|
|
136
|
-
},
|
|
137
|
-
descriptionProps: {
|
|
138
|
-
id: descriptionId,
|
|
139
|
-
},
|
|
140
|
-
keyboardShortcutProps: {
|
|
141
|
-
id: keyboardId,
|
|
142
|
-
'aria-hidden': true,
|
|
143
|
-
},
|
|
144
|
-
isFocused,
|
|
145
|
-
isFocusVisible: () => isFocused() && isFocusVisible(),
|
|
146
|
-
isPressed,
|
|
147
|
-
isDisabled,
|
|
148
|
-
};
|
|
149
|
-
}
|
|
1
|
+
/**
|
|
2
|
+
* Provides the behavior and accessibility implementation for a menu item.
|
|
3
|
+
* Based on @react-aria/menu useMenuItem.
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import { type JSX, type Accessor } from 'solid-js';
|
|
7
|
+
import { createPress } from '../interactions/createPress';
|
|
8
|
+
import { createHover } from '../interactions/createHover';
|
|
9
|
+
import { createFocusRing } from '../interactions/createFocusRing';
|
|
10
|
+
import { mergeProps } from '../utils/mergeProps';
|
|
11
|
+
import { access, type MaybeAccessor } from '../utils/reactivity';
|
|
12
|
+
import { getMenuData } from './createMenu';
|
|
13
|
+
import type { MenuState, Key } from '@proyecto-viviana/solid-stately';
|
|
14
|
+
|
|
15
|
+
export interface AriaMenuItemProps {
|
|
16
|
+
/** The unique key for the menu item. */
|
|
17
|
+
key: Key;
|
|
18
|
+
/** Whether the menu item is disabled. */
|
|
19
|
+
isDisabled?: boolean;
|
|
20
|
+
/** An accessible label for the menu item. */
|
|
21
|
+
'aria-label'?: string;
|
|
22
|
+
/** Handler called when the menu item is selected. */
|
|
23
|
+
onAction?: () => void;
|
|
24
|
+
/** Whether to close the menu when this item is selected. */
|
|
25
|
+
closeOnSelect?: boolean;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
export interface MenuItemAria {
|
|
29
|
+
/** Props for the menu item element. */
|
|
30
|
+
menuItemProps: JSX.HTMLAttributes<HTMLElement>;
|
|
31
|
+
/** Props for the label text inside the menu item. */
|
|
32
|
+
labelProps: JSX.HTMLAttributes<HTMLElement>;
|
|
33
|
+
/** Props for the description text inside the menu item. */
|
|
34
|
+
descriptionProps: JSX.HTMLAttributes<HTMLElement>;
|
|
35
|
+
/** Props for the keyboard shortcut inside the menu item. */
|
|
36
|
+
keyboardShortcutProps: JSX.HTMLAttributes<HTMLElement>;
|
|
37
|
+
/** Whether the menu item is currently focused. */
|
|
38
|
+
isFocused: Accessor<boolean>;
|
|
39
|
+
/** Whether the menu item is keyboard focused. */
|
|
40
|
+
isFocusVisible: Accessor<boolean>;
|
|
41
|
+
/** Whether the menu item is currently pressed. */
|
|
42
|
+
isPressed: Accessor<boolean>;
|
|
43
|
+
/** Whether the menu item is disabled. */
|
|
44
|
+
isDisabled: Accessor<boolean>;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
/**
|
|
48
|
+
* Provides the behavior and accessibility implementation for a menu item.
|
|
49
|
+
*/
|
|
50
|
+
export function createMenuItem<T>(
|
|
51
|
+
props: MaybeAccessor<AriaMenuItemProps>,
|
|
52
|
+
state: MenuState<T>,
|
|
53
|
+
_ref?: () => HTMLElement | null
|
|
54
|
+
): MenuItemAria {
|
|
55
|
+
const getProps = () => access(props);
|
|
56
|
+
|
|
57
|
+
// Get shared data from menu
|
|
58
|
+
const getData = () => getMenuData(state);
|
|
59
|
+
|
|
60
|
+
// Computed states
|
|
61
|
+
const isDisabled: Accessor<boolean> = () => {
|
|
62
|
+
return Boolean(getData()?.isDisabled || getProps().isDisabled || state.isDisabled(getProps().key));
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
const isFocused: Accessor<boolean> = () => {
|
|
66
|
+
return state.focusedKey() === getProps().key;
|
|
67
|
+
};
|
|
68
|
+
|
|
69
|
+
// Handle press
|
|
70
|
+
const { pressProps, isPressed } = createPress({
|
|
71
|
+
get isDisabled() {
|
|
72
|
+
return isDisabled();
|
|
73
|
+
},
|
|
74
|
+
onPress() {
|
|
75
|
+
const p = getProps();
|
|
76
|
+
const key = p.key;
|
|
77
|
+
const data = getData();
|
|
78
|
+
|
|
79
|
+
// Call item-specific onAction
|
|
80
|
+
p.onAction?.();
|
|
81
|
+
|
|
82
|
+
// Call menu-level onAction
|
|
83
|
+
data?.onAction?.(key);
|
|
84
|
+
|
|
85
|
+
// Close menu if closeOnSelect is not explicitly false
|
|
86
|
+
if (p.closeOnSelect !== false) {
|
|
87
|
+
data?.onClose?.();
|
|
88
|
+
}
|
|
89
|
+
},
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
// Handle hover
|
|
93
|
+
const { hoverProps } = createHover({
|
|
94
|
+
get isDisabled() {
|
|
95
|
+
return isDisabled();
|
|
96
|
+
},
|
|
97
|
+
onHoverStart() {
|
|
98
|
+
state.setFocusedKey(getProps().key);
|
|
99
|
+
},
|
|
100
|
+
});
|
|
101
|
+
|
|
102
|
+
// Handle focus ring
|
|
103
|
+
const { isFocusVisible, focusProps } = createFocusRing();
|
|
104
|
+
|
|
105
|
+
// Generate unique IDs for label and description
|
|
106
|
+
const labelId = `${getProps().key}-label`;
|
|
107
|
+
const descriptionId = `${getProps().key}-desc`;
|
|
108
|
+
const keyboardId = `${getProps().key}-kbd`;
|
|
109
|
+
|
|
110
|
+
return {
|
|
111
|
+
get menuItemProps() {
|
|
112
|
+
const key = getProps().key;
|
|
113
|
+
const ariaLabel = getProps()['aria-label'];
|
|
114
|
+
|
|
115
|
+
return mergeProps(
|
|
116
|
+
pressProps as Record<string, unknown>,
|
|
117
|
+
hoverProps as Record<string, unknown>,
|
|
118
|
+
focusProps as Record<string, unknown>,
|
|
119
|
+
{
|
|
120
|
+
role: 'menuitem',
|
|
121
|
+
id: String(key),
|
|
122
|
+
'aria-disabled': isDisabled() || undefined,
|
|
123
|
+
'aria-label': ariaLabel,
|
|
124
|
+
'aria-labelledby': !ariaLabel ? labelId : undefined,
|
|
125
|
+
'aria-describedby': descriptionId,
|
|
126
|
+
tabIndex: isFocused() ? 0 : -1,
|
|
127
|
+
'data-focused': isFocused() || undefined,
|
|
128
|
+
'data-focus-visible': isFocusVisible() || undefined,
|
|
129
|
+
'data-pressed': isPressed() || undefined,
|
|
130
|
+
'data-disabled': isDisabled() || undefined,
|
|
131
|
+
} as Record<string, unknown>
|
|
132
|
+
) as JSX.HTMLAttributes<HTMLElement>;
|
|
133
|
+
},
|
|
134
|
+
labelProps: {
|
|
135
|
+
id: labelId,
|
|
136
|
+
},
|
|
137
|
+
descriptionProps: {
|
|
138
|
+
id: descriptionId,
|
|
139
|
+
},
|
|
140
|
+
keyboardShortcutProps: {
|
|
141
|
+
id: keyboardId,
|
|
142
|
+
'aria-hidden': true,
|
|
143
|
+
},
|
|
144
|
+
isFocused,
|
|
145
|
+
isFocusVisible: () => isFocused() && isFocusVisible(),
|
|
146
|
+
isPressed,
|
|
147
|
+
isDisabled,
|
|
148
|
+
};
|
|
149
|
+
}
|
|
@@ -1,88 +1,88 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Provides the behavior and accessibility implementation for a menu trigger.
|
|
3
|
-
* Based on @react-aria/menu useMenuTrigger.
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
import { type JSX } from 'solid-js';
|
|
7
|
-
import { createId } from '../ssr';
|
|
8
|
-
import { access, type MaybeAccessor } from '../utils/reactivity';
|
|
9
|
-
import type { OverlayTriggerState } from '@proyecto-viviana/solid-stately';
|
|
10
|
-
|
|
11
|
-
export interface AriaMenuTriggerProps {
|
|
12
|
-
/** The type of menu that the menu trigger opens. */
|
|
13
|
-
type?: 'menu' | 'listbox';
|
|
14
|
-
/** Whether the menu trigger is disabled. */
|
|
15
|
-
isDisabled?: boolean;
|
|
16
|
-
/** An ID for the menu. */
|
|
17
|
-
id?: string;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
export interface MenuTriggerAria {
|
|
21
|
-
/** Props for the menu trigger button. */
|
|
22
|
-
menuTriggerProps: JSX.HTMLAttributes<HTMLElement> & {
|
|
23
|
-
onPress: () => void;
|
|
24
|
-
onKeyDown: (e: KeyboardEvent) => void;
|
|
25
|
-
};
|
|
26
|
-
/** Props for the menu element. */
|
|
27
|
-
menuProps: JSX.HTMLAttributes<HTMLElement>;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
/**
|
|
31
|
-
* Provides the behavior and accessibility implementation for a menu trigger.
|
|
32
|
-
*/
|
|
33
|
-
export function createMenuTrigger(
|
|
34
|
-
props: MaybeAccessor<AriaMenuTriggerProps>,
|
|
35
|
-
state: OverlayTriggerState
|
|
36
|
-
): MenuTriggerAria {
|
|
37
|
-
const getProps = () => access(props);
|
|
38
|
-
const menuId = createId(getProps().id);
|
|
39
|
-
|
|
40
|
-
const onPress = () => {
|
|
41
|
-
if (!getProps().isDisabled) {
|
|
42
|
-
state.toggle();
|
|
43
|
-
}
|
|
44
|
-
};
|
|
45
|
-
|
|
46
|
-
const onKeyDown = (e: KeyboardEvent) => {
|
|
47
|
-
if (getProps().isDisabled) return;
|
|
48
|
-
|
|
49
|
-
switch (e.key) {
|
|
50
|
-
case 'Enter':
|
|
51
|
-
case ' ':
|
|
52
|
-
case 'ArrowDown': {
|
|
53
|
-
e.preventDefault();
|
|
54
|
-
if (!state.isOpen()) {
|
|
55
|
-
state.open();
|
|
56
|
-
}
|
|
57
|
-
break;
|
|
58
|
-
}
|
|
59
|
-
case 'ArrowUp': {
|
|
60
|
-
e.preventDefault();
|
|
61
|
-
if (!state.isOpen()) {
|
|
62
|
-
state.open();
|
|
63
|
-
}
|
|
64
|
-
break;
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
};
|
|
68
|
-
|
|
69
|
-
return {
|
|
70
|
-
get menuTriggerProps() {
|
|
71
|
-
const p = getProps();
|
|
72
|
-
const type = p.type ?? 'menu';
|
|
73
|
-
const isOpen = state.isOpen();
|
|
74
|
-
|
|
75
|
-
return {
|
|
76
|
-
'aria-haspopup': type,
|
|
77
|
-
'aria-expanded': isOpen,
|
|
78
|
-
'aria-controls': isOpen ? menuId : undefined,
|
|
79
|
-
'aria-disabled': p.isDisabled || undefined,
|
|
80
|
-
onPress,
|
|
81
|
-
onKeyDown,
|
|
82
|
-
};
|
|
83
|
-
},
|
|
84
|
-
menuProps: {
|
|
85
|
-
id: menuId,
|
|
86
|
-
},
|
|
87
|
-
};
|
|
88
|
-
}
|
|
1
|
+
/**
|
|
2
|
+
* Provides the behavior and accessibility implementation for a menu trigger.
|
|
3
|
+
* Based on @react-aria/menu useMenuTrigger.
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import { type JSX } from 'solid-js';
|
|
7
|
+
import { createId } from '../ssr';
|
|
8
|
+
import { access, type MaybeAccessor } from '../utils/reactivity';
|
|
9
|
+
import type { OverlayTriggerState } from '@proyecto-viviana/solid-stately';
|
|
10
|
+
|
|
11
|
+
export interface AriaMenuTriggerProps {
|
|
12
|
+
/** The type of menu that the menu trigger opens. */
|
|
13
|
+
type?: 'menu' | 'listbox';
|
|
14
|
+
/** Whether the menu trigger is disabled. */
|
|
15
|
+
isDisabled?: boolean;
|
|
16
|
+
/** An ID for the menu. */
|
|
17
|
+
id?: string;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export interface MenuTriggerAria {
|
|
21
|
+
/** Props for the menu trigger button. */
|
|
22
|
+
menuTriggerProps: JSX.HTMLAttributes<HTMLElement> & {
|
|
23
|
+
onPress: () => void;
|
|
24
|
+
onKeyDown: (e: KeyboardEvent) => void;
|
|
25
|
+
};
|
|
26
|
+
/** Props for the menu element. */
|
|
27
|
+
menuProps: JSX.HTMLAttributes<HTMLElement>;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* Provides the behavior and accessibility implementation for a menu trigger.
|
|
32
|
+
*/
|
|
33
|
+
export function createMenuTrigger(
|
|
34
|
+
props: MaybeAccessor<AriaMenuTriggerProps>,
|
|
35
|
+
state: OverlayTriggerState
|
|
36
|
+
): MenuTriggerAria {
|
|
37
|
+
const getProps = () => access(props);
|
|
38
|
+
const menuId = createId(getProps().id);
|
|
39
|
+
|
|
40
|
+
const onPress = () => {
|
|
41
|
+
if (!getProps().isDisabled) {
|
|
42
|
+
state.toggle();
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
const onKeyDown = (e: KeyboardEvent) => {
|
|
47
|
+
if (getProps().isDisabled) return;
|
|
48
|
+
|
|
49
|
+
switch (e.key) {
|
|
50
|
+
case 'Enter':
|
|
51
|
+
case ' ':
|
|
52
|
+
case 'ArrowDown': {
|
|
53
|
+
e.preventDefault();
|
|
54
|
+
if (!state.isOpen()) {
|
|
55
|
+
state.open();
|
|
56
|
+
}
|
|
57
|
+
break;
|
|
58
|
+
}
|
|
59
|
+
case 'ArrowUp': {
|
|
60
|
+
e.preventDefault();
|
|
61
|
+
if (!state.isOpen()) {
|
|
62
|
+
state.open();
|
|
63
|
+
}
|
|
64
|
+
break;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
};
|
|
68
|
+
|
|
69
|
+
return {
|
|
70
|
+
get menuTriggerProps() {
|
|
71
|
+
const p = getProps();
|
|
72
|
+
const type = p.type ?? 'menu';
|
|
73
|
+
const isOpen = state.isOpen();
|
|
74
|
+
|
|
75
|
+
return {
|
|
76
|
+
'aria-haspopup': type,
|
|
77
|
+
'aria-expanded': isOpen,
|
|
78
|
+
'aria-controls': isOpen ? menuId : undefined,
|
|
79
|
+
'aria-disabled': p.isDisabled || undefined,
|
|
80
|
+
onPress,
|
|
81
|
+
onKeyDown,
|
|
82
|
+
};
|
|
83
|
+
},
|
|
84
|
+
menuProps: {
|
|
85
|
+
id: menuId,
|
|
86
|
+
},
|
|
87
|
+
};
|
|
88
|
+
}
|
package/src/menu/index.ts
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
export {
|
|
2
|
-
createMenu,
|
|
3
|
-
getMenuData,
|
|
4
|
-
type AriaMenuProps,
|
|
5
|
-
type MenuAria,
|
|
6
|
-
} from './createMenu';
|
|
7
|
-
|
|
8
|
-
export {
|
|
9
|
-
createMenuItem,
|
|
10
|
-
type AriaMenuItemProps,
|
|
11
|
-
type MenuItemAria,
|
|
12
|
-
} from './createMenuItem';
|
|
13
|
-
|
|
14
|
-
export {
|
|
15
|
-
createMenuTrigger,
|
|
16
|
-
type AriaMenuTriggerProps,
|
|
17
|
-
type MenuTriggerAria,
|
|
18
|
-
} from './createMenuTrigger';
|
|
1
|
+
export {
|
|
2
|
+
createMenu,
|
|
3
|
+
getMenuData,
|
|
4
|
+
type AriaMenuProps,
|
|
5
|
+
type MenuAria,
|
|
6
|
+
} from './createMenu';
|
|
7
|
+
|
|
8
|
+
export {
|
|
9
|
+
createMenuItem,
|
|
10
|
+
type AriaMenuItemProps,
|
|
11
|
+
type MenuItemAria,
|
|
12
|
+
} from './createMenuItem';
|
|
13
|
+
|
|
14
|
+
export {
|
|
15
|
+
createMenuTrigger,
|
|
16
|
+
type AriaMenuTriggerProps,
|
|
17
|
+
type MenuTriggerAria,
|
|
18
|
+
} from './createMenuTrigger';
|
package/src/meter/createMeter.ts
CHANGED
|
@@ -60,12 +60,7 @@ export function createMeter(props: AriaMeterProps = {}): MeterAria {
|
|
|
60
60
|
get meterProps() {
|
|
61
61
|
return {
|
|
62
62
|
...progressBarProps,
|
|
63
|
-
|
|
64
|
-
// Chrome currently falls back from meter automatically, and Firefox
|
|
65
|
-
// does not support meter at all. Safari 13+ seems to support meter properly.
|
|
66
|
-
// https://bugs.chromium.org/p/chromium/issues/detail?id=944542
|
|
67
|
-
// https://bugzilla.mozilla.org/show_bug.cgi?id=1460378
|
|
68
|
-
role: 'meter progressbar',
|
|
63
|
+
role: 'meter',
|
|
69
64
|
};
|
|
70
65
|
},
|
|
71
66
|
get labelProps() {
|