@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,79 +1,79 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* createTooltip hook for Solidaria
|
|
3
|
-
*
|
|
4
|
-
* Provides the accessibility implementation for a Tooltip component.
|
|
5
|
-
*
|
|
6
|
-
* Port of @react-aria/tooltip useTooltip.
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
import { type JSX } from 'solid-js';
|
|
10
|
-
import { type TooltipTriggerState } from '@proyecto-viviana/solid-stately';
|
|
11
|
-
import { createHover } from '../interactions/createHover';
|
|
12
|
-
import { filterDOMProps, mergeProps } from '../utils';
|
|
13
|
-
|
|
14
|
-
// ============================================
|
|
15
|
-
// TYPES
|
|
16
|
-
// ============================================
|
|
17
|
-
|
|
18
|
-
export interface TooltipProps {
|
|
19
|
-
/** Whether the tooltip is disabled. */
|
|
20
|
-
isDisabled?: boolean;
|
|
21
|
-
/** Custom aria-label for the tooltip. */
|
|
22
|
-
'aria-label'?: string;
|
|
23
|
-
/** ID of an element that labels the tooltip. */
|
|
24
|
-
'aria-labelledby'?: string;
|
|
25
|
-
/** ID of an element that describes the tooltip. */
|
|
26
|
-
'aria-describedby'?: string;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
export interface TooltipAria {
|
|
30
|
-
/** Props to spread on the tooltip element. */
|
|
31
|
-
tooltipProps: JSX.HTMLAttributes<HTMLElement>;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
// ============================================
|
|
35
|
-
// IMPLEMENTATION
|
|
36
|
-
// ============================================
|
|
37
|
-
|
|
38
|
-
/**
|
|
39
|
-
* Provides the accessibility implementation for a Tooltip component.
|
|
40
|
-
*
|
|
41
|
-
* When hovering over the tooltip itself, it stays open. When the mouse leaves
|
|
42
|
-
* the tooltip, it closes.
|
|
43
|
-
*
|
|
44
|
-
* @example
|
|
45
|
-
* ```tsx
|
|
46
|
-
* import { createTooltip } from 'solidaria';
|
|
47
|
-
* import { createTooltipTriggerState } from 'solid-stately';
|
|
48
|
-
*
|
|
49
|
-
* function Tooltip(props) {
|
|
50
|
-
* const state = props.state;
|
|
51
|
-
* const { tooltipProps } = createTooltip(props, state);
|
|
52
|
-
*
|
|
53
|
-
* return (
|
|
54
|
-
* <div {...tooltipProps} role="tooltip">
|
|
55
|
-
* {props.children}
|
|
56
|
-
* </div>
|
|
57
|
-
* );
|
|
58
|
-
* }
|
|
59
|
-
* ```
|
|
60
|
-
*/
|
|
61
|
-
export function createTooltip(
|
|
62
|
-
props: TooltipProps = {},
|
|
63
|
-
state?: TooltipTriggerState
|
|
64
|
-
): TooltipAria {
|
|
65
|
-
const domProps = filterDOMProps(props, { labelable: true });
|
|
66
|
-
|
|
67
|
-
const { hoverProps } = createHover({
|
|
68
|
-
onHoverStart: () => state?.open(true),
|
|
69
|
-
onHoverEnd: () => state?.close(),
|
|
70
|
-
});
|
|
71
|
-
|
|
72
|
-
return {
|
|
73
|
-
tooltipProps: mergeProps<JSX.HTMLAttributes<HTMLElement>>(
|
|
74
|
-
domProps,
|
|
75
|
-
hoverProps,
|
|
76
|
-
{ role: 'tooltip' }
|
|
77
|
-
),
|
|
78
|
-
};
|
|
79
|
-
}
|
|
1
|
+
/**
|
|
2
|
+
* createTooltip hook for Solidaria
|
|
3
|
+
*
|
|
4
|
+
* Provides the accessibility implementation for a Tooltip component.
|
|
5
|
+
*
|
|
6
|
+
* Port of @react-aria/tooltip useTooltip.
|
|
7
|
+
*/
|
|
8
|
+
|
|
9
|
+
import { type JSX } from 'solid-js';
|
|
10
|
+
import { type TooltipTriggerState } from '@proyecto-viviana/solid-stately';
|
|
11
|
+
import { createHover } from '../interactions/createHover';
|
|
12
|
+
import { filterDOMProps, mergeProps } from '../utils';
|
|
13
|
+
|
|
14
|
+
// ============================================
|
|
15
|
+
// TYPES
|
|
16
|
+
// ============================================
|
|
17
|
+
|
|
18
|
+
export interface TooltipProps {
|
|
19
|
+
/** Whether the tooltip is disabled. */
|
|
20
|
+
isDisabled?: boolean;
|
|
21
|
+
/** Custom aria-label for the tooltip. */
|
|
22
|
+
'aria-label'?: string;
|
|
23
|
+
/** ID of an element that labels the tooltip. */
|
|
24
|
+
'aria-labelledby'?: string;
|
|
25
|
+
/** ID of an element that describes the tooltip. */
|
|
26
|
+
'aria-describedby'?: string;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export interface TooltipAria {
|
|
30
|
+
/** Props to spread on the tooltip element. */
|
|
31
|
+
tooltipProps: JSX.HTMLAttributes<HTMLElement>;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
// ============================================
|
|
35
|
+
// IMPLEMENTATION
|
|
36
|
+
// ============================================
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* Provides the accessibility implementation for a Tooltip component.
|
|
40
|
+
*
|
|
41
|
+
* When hovering over the tooltip itself, it stays open. When the mouse leaves
|
|
42
|
+
* the tooltip, it closes.
|
|
43
|
+
*
|
|
44
|
+
* @example
|
|
45
|
+
* ```tsx
|
|
46
|
+
* import { createTooltip } from 'solidaria';
|
|
47
|
+
* import { createTooltipTriggerState } from 'solid-stately';
|
|
48
|
+
*
|
|
49
|
+
* function Tooltip(props) {
|
|
50
|
+
* const state = props.state;
|
|
51
|
+
* const { tooltipProps } = createTooltip(props, state);
|
|
52
|
+
*
|
|
53
|
+
* return (
|
|
54
|
+
* <div {...tooltipProps} role="tooltip">
|
|
55
|
+
* {props.children}
|
|
56
|
+
* </div>
|
|
57
|
+
* );
|
|
58
|
+
* }
|
|
59
|
+
* ```
|
|
60
|
+
*/
|
|
61
|
+
export function createTooltip(
|
|
62
|
+
props: TooltipProps = {},
|
|
63
|
+
state?: TooltipTriggerState
|
|
64
|
+
): TooltipAria {
|
|
65
|
+
const domProps = filterDOMProps(props, { labelable: true });
|
|
66
|
+
|
|
67
|
+
const { hoverProps } = createHover({
|
|
68
|
+
onHoverStart: () => state?.open(true),
|
|
69
|
+
onHoverEnd: () => state?.close(),
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
return {
|
|
73
|
+
tooltipProps: mergeProps<JSX.HTMLAttributes<HTMLElement>>(
|
|
74
|
+
domProps,
|
|
75
|
+
hoverProps,
|
|
76
|
+
{ role: 'tooltip' }
|
|
77
|
+
),
|
|
78
|
+
};
|
|
79
|
+
}
|
|
@@ -1,222 +1,226 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* createTooltipTrigger hook for Solidaria
|
|
3
|
-
*
|
|
4
|
-
* Provides the behavior and accessibility implementation for a tooltip trigger,
|
|
5
|
-
* e.g. a button that shows a description when focused or hovered.
|
|
6
|
-
*
|
|
7
|
-
* Port of @react-aria/tooltip useTooltipTrigger.
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
import { type JSX, createEffect, onCleanup } from 'solid-js';
|
|
11
|
-
import { type TooltipTriggerState } from '@proyecto-viviana/solid-stately';
|
|
12
|
-
import { createHover } from '../interactions/createHover';
|
|
13
|
-
import { createFocusable } from '../interactions/createFocusable';
|
|
14
|
-
import {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
//
|
|
18
|
-
//
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
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
|
-
* import {
|
|
77
|
-
*
|
|
78
|
-
*
|
|
79
|
-
*
|
|
80
|
-
*
|
|
81
|
-
* const
|
|
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
|
-
const
|
|
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
|
-
|
|
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
|
-
}
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
1
|
+
/**
|
|
2
|
+
* createTooltipTrigger hook for Solidaria
|
|
3
|
+
*
|
|
4
|
+
* Provides the behavior and accessibility implementation for a tooltip trigger,
|
|
5
|
+
* e.g. a button that shows a description when focused or hovered.
|
|
6
|
+
*
|
|
7
|
+
* Port of @react-aria/tooltip useTooltipTrigger.
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
import { type JSX, createEffect, onCleanup } from 'solid-js';
|
|
11
|
+
import { type TooltipTriggerState } from '@proyecto-viviana/solid-stately';
|
|
12
|
+
import { createHover } from '../interactions/createHover';
|
|
13
|
+
import { createFocusable } from '../interactions/createFocusable';
|
|
14
|
+
import { createId } from '../ssr';
|
|
15
|
+
|
|
16
|
+
// ============================================
|
|
17
|
+
// TYPES
|
|
18
|
+
// ============================================
|
|
19
|
+
|
|
20
|
+
export interface TooltipTriggerProps {
|
|
21
|
+
/** Whether the tooltip should be disabled. */
|
|
22
|
+
isDisabled?: boolean;
|
|
23
|
+
/**
|
|
24
|
+
* The trigger mechanism for the tooltip.
|
|
25
|
+
* @default 'focus'
|
|
26
|
+
*/
|
|
27
|
+
trigger?: 'focus';
|
|
28
|
+
/**
|
|
29
|
+
* Whether the tooltip should close when the trigger is pressed.
|
|
30
|
+
* @default true
|
|
31
|
+
*/
|
|
32
|
+
shouldCloseOnPress?: boolean;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
export interface TooltipTriggerAria {
|
|
36
|
+
/** Props to spread on the trigger element. */
|
|
37
|
+
triggerProps: JSX.HTMLAttributes<HTMLElement>;
|
|
38
|
+
/** Props to spread on the tooltip element (id for accessibility). */
|
|
39
|
+
tooltipProps: { id: string };
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
// ============================================
|
|
43
|
+
// GLOBAL STATE
|
|
44
|
+
// ============================================
|
|
45
|
+
|
|
46
|
+
type Modality = 'keyboard' | 'pointer' | 'virtual';
|
|
47
|
+
let currentModality: Modality | null = null;
|
|
48
|
+
|
|
49
|
+
// Track interaction modality (pointer vs keyboard)
|
|
50
|
+
if (typeof document !== 'undefined') {
|
|
51
|
+
document.addEventListener('keydown', () => {
|
|
52
|
+
currentModality = 'keyboard';
|
|
53
|
+
}, true);
|
|
54
|
+
document.addEventListener('pointerdown', () => {
|
|
55
|
+
currentModality = 'pointer';
|
|
56
|
+
}, true);
|
|
57
|
+
document.addEventListener('pointermove', () => {
|
|
58
|
+
currentModality = 'pointer';
|
|
59
|
+
}, true);
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
function isFocusVisible(): boolean {
|
|
63
|
+
return currentModality === 'keyboard';
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
// ============================================
|
|
67
|
+
// IMPLEMENTATION
|
|
68
|
+
// ============================================
|
|
69
|
+
|
|
70
|
+
/**
|
|
71
|
+
* Provides the behavior and accessibility implementation for a tooltip trigger.
|
|
72
|
+
*
|
|
73
|
+
* @example
|
|
74
|
+
* ```tsx
|
|
75
|
+
* import { createTooltipTrigger } from 'solidaria';
|
|
76
|
+
* import { createTooltipTriggerState } from 'solid-stately';
|
|
77
|
+
*
|
|
78
|
+
* function TooltipButton(props) {
|
|
79
|
+
* let ref;
|
|
80
|
+
* const state = createTooltipTriggerState({ delay: 500 });
|
|
81
|
+
* const { triggerProps, tooltipProps } = createTooltipTrigger(
|
|
82
|
+
* { isDisabled: props.isDisabled },
|
|
83
|
+
* state,
|
|
84
|
+
* () => ref
|
|
85
|
+
* );
|
|
86
|
+
*
|
|
87
|
+
* return (
|
|
88
|
+
* <>
|
|
89
|
+
* <button ref={ref} {...triggerProps}>
|
|
90
|
+
* Hover me
|
|
91
|
+
* </button>
|
|
92
|
+
* <Show when={state.isOpen()}>
|
|
93
|
+
* <div {...tooltipProps}>Tooltip content</div>
|
|
94
|
+
* </Show>
|
|
95
|
+
* </>
|
|
96
|
+
* );
|
|
97
|
+
* }
|
|
98
|
+
* ```
|
|
99
|
+
*/
|
|
100
|
+
export function createTooltipTrigger(
|
|
101
|
+
props: TooltipTriggerProps,
|
|
102
|
+
state: TooltipTriggerState,
|
|
103
|
+
ref: () => HTMLElement | null | undefined
|
|
104
|
+
): TooltipTriggerAria {
|
|
105
|
+
const isDisabled = () => props.isDisabled ?? false;
|
|
106
|
+
const trigger = () => props.trigger;
|
|
107
|
+
const shouldCloseOnPress = () => props.shouldCloseOnPress ?? true;
|
|
108
|
+
|
|
109
|
+
const tooltipId = createId();
|
|
110
|
+
|
|
111
|
+
// Track hover and focus state
|
|
112
|
+
let isHovered = false;
|
|
113
|
+
let isFocused = false;
|
|
114
|
+
|
|
115
|
+
const handleShow = () => {
|
|
116
|
+
if (isHovered || isFocused) {
|
|
117
|
+
state.open(isFocused);
|
|
118
|
+
}
|
|
119
|
+
};
|
|
120
|
+
|
|
121
|
+
const handleHide = (immediate?: boolean) => {
|
|
122
|
+
if (!isHovered && !isFocused) {
|
|
123
|
+
state.close(immediate);
|
|
124
|
+
}
|
|
125
|
+
};
|
|
126
|
+
|
|
127
|
+
// Handle Escape key to dismiss tooltip
|
|
128
|
+
createEffect(() => {
|
|
129
|
+
if (!state.isOpen()) return;
|
|
130
|
+
|
|
131
|
+
const onKeyDown = (e: KeyboardEvent) => {
|
|
132
|
+
const element = ref();
|
|
133
|
+
if (element) {
|
|
134
|
+
if (e.key === 'Escape') {
|
|
135
|
+
e.stopPropagation();
|
|
136
|
+
state.close(true);
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
};
|
|
140
|
+
|
|
141
|
+
document.addEventListener('keydown', onKeyDown, true);
|
|
142
|
+
onCleanup(() => {
|
|
143
|
+
document.removeEventListener('keydown', onKeyDown, true);
|
|
144
|
+
});
|
|
145
|
+
});
|
|
146
|
+
|
|
147
|
+
const onHoverStart = () => {
|
|
148
|
+
if (trigger() === 'focus') {
|
|
149
|
+
return;
|
|
150
|
+
}
|
|
151
|
+
// Hover events (onPointerEnter) only fire from pointer interactions,
|
|
152
|
+
// so we can always set isHovered to true here
|
|
153
|
+
isHovered = true;
|
|
154
|
+
handleShow();
|
|
155
|
+
};
|
|
156
|
+
|
|
157
|
+
const onHoverEnd = () => {
|
|
158
|
+
if (trigger() === 'focus') {
|
|
159
|
+
return;
|
|
160
|
+
}
|
|
161
|
+
isFocused = false;
|
|
162
|
+
isHovered = false;
|
|
163
|
+
handleHide();
|
|
164
|
+
};
|
|
165
|
+
|
|
166
|
+
const closeOnPress = () => {
|
|
167
|
+
if (!shouldCloseOnPress()) {
|
|
168
|
+
return;
|
|
169
|
+
}
|
|
170
|
+
isFocused = false;
|
|
171
|
+
isHovered = false;
|
|
172
|
+
handleHide(true);
|
|
173
|
+
};
|
|
174
|
+
|
|
175
|
+
const onKeyDownPress = (event: KeyboardEvent) => {
|
|
176
|
+
if (event.key !== 'Enter' && event.key !== ' ' && event.key !== 'Spacebar') {
|
|
177
|
+
return;
|
|
178
|
+
}
|
|
179
|
+
closeOnPress();
|
|
180
|
+
};
|
|
181
|
+
|
|
182
|
+
const onFocus = () => {
|
|
183
|
+
const visible = isFocusVisible();
|
|
184
|
+
if (visible) {
|
|
185
|
+
isFocused = true;
|
|
186
|
+
handleShow();
|
|
187
|
+
}
|
|
188
|
+
};
|
|
189
|
+
|
|
190
|
+
const onBlur = () => {
|
|
191
|
+
isFocused = false;
|
|
192
|
+
isHovered = false;
|
|
193
|
+
handleHide(true);
|
|
194
|
+
};
|
|
195
|
+
|
|
196
|
+
const { hoverProps } = createHover({
|
|
197
|
+
isDisabled: isDisabled(),
|
|
198
|
+
onHoverStart,
|
|
199
|
+
onHoverEnd,
|
|
200
|
+
});
|
|
201
|
+
|
|
202
|
+
const { focusableProps } = createFocusable({
|
|
203
|
+
isDisabled: isDisabled(),
|
|
204
|
+
onFocus,
|
|
205
|
+
onBlur,
|
|
206
|
+
});
|
|
207
|
+
|
|
208
|
+
const triggerProps = {
|
|
209
|
+
...focusableProps,
|
|
210
|
+
...hoverProps,
|
|
211
|
+
get 'aria-describedby'() {
|
|
212
|
+
return state.isOpen() ? tooltipId : undefined;
|
|
213
|
+
},
|
|
214
|
+
onPointerDown: closeOnPress,
|
|
215
|
+
onKeyDown: onKeyDownPress,
|
|
216
|
+
// Remove tabIndex set by focusableProps to avoid overriding
|
|
217
|
+
tabIndex: undefined,
|
|
218
|
+
};
|
|
219
|
+
|
|
220
|
+
return {
|
|
221
|
+
triggerProps: triggerProps as JSX.HTMLAttributes<HTMLElement>,
|
|
222
|
+
tooltipProps: {
|
|
223
|
+
id: tooltipId,
|
|
224
|
+
},
|
|
225
|
+
};
|
|
226
|
+
}
|
package/src/tooltip/index.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
export { createTooltip, type TooltipProps, type TooltipAria } from './createTooltip';
|
|
2
|
-
export {
|
|
3
|
-
createTooltipTrigger,
|
|
4
|
-
type TooltipTriggerProps,
|
|
5
|
-
type TooltipTriggerAria,
|
|
6
|
-
} from './createTooltipTrigger';
|
|
1
|
+
export { createTooltip, type TooltipProps, type TooltipAria } from './createTooltip';
|
|
2
|
+
export {
|
|
3
|
+
createTooltipTrigger,
|
|
4
|
+
type TooltipTriggerProps,
|
|
5
|
+
type TooltipTriggerAria,
|
|
6
|
+
} from './createTooltipTrigger';
|