@proyecto-viviana/solidaria 0.1.3 → 0.2.0
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/dist/index.d.ts +6135 -50
- package/dist/index.js +485 -1120
- package/dist/{index.ssr.js → index.jsx} +89 -143
- package/package.json +7 -9
- package/dist/autocomplete/createAutocomplete.d.ts +0 -109
- package/dist/autocomplete/createAutocomplete.d.ts.map +0 -1
- package/dist/autocomplete/index.d.ts +0 -2
- package/dist/autocomplete/index.d.ts.map +0 -1
- package/dist/breadcrumbs/createBreadcrumbs.d.ts +0 -43
- package/dist/breadcrumbs/createBreadcrumbs.d.ts.map +0 -1
- package/dist/breadcrumbs/index.d.ts +0 -2
- package/dist/breadcrumbs/index.d.ts.map +0 -1
- package/dist/button/createButton.d.ts +0 -29
- package/dist/button/createButton.d.ts.map +0 -1
- package/dist/button/createToggleButton.d.ts +0 -41
- package/dist/button/createToggleButton.d.ts.map +0 -1
- package/dist/button/index.d.ts +0 -5
- package/dist/button/index.d.ts.map +0 -1
- package/dist/button/types.d.ts +0 -77
- package/dist/button/types.d.ts.map +0 -1
- package/dist/calendar/createCalendar.d.ts +0 -41
- package/dist/calendar/createCalendar.d.ts.map +0 -1
- package/dist/calendar/createCalendarCell.d.ts +0 -41
- package/dist/calendar/createCalendarCell.d.ts.map +0 -1
- package/dist/calendar/createCalendarGrid.d.ts +0 -29
- package/dist/calendar/createCalendarGrid.d.ts.map +0 -1
- package/dist/calendar/createRangeCalendar.d.ts +0 -39
- package/dist/calendar/createRangeCalendar.d.ts.map +0 -1
- package/dist/calendar/createRangeCalendarCell.d.ts +0 -45
- package/dist/calendar/createRangeCalendarCell.d.ts.map +0 -1
- package/dist/calendar/index.d.ts +0 -6
- package/dist/calendar/index.d.ts.map +0 -1
- package/dist/checkbox/createCheckbox.d.ts +0 -56
- package/dist/checkbox/createCheckbox.d.ts.map +0 -1
- package/dist/checkbox/createCheckboxGroup.d.ts +0 -53
- package/dist/checkbox/createCheckboxGroup.d.ts.map +0 -1
- package/dist/checkbox/createCheckboxGroupItem.d.ts +0 -25
- package/dist/checkbox/createCheckboxGroupItem.d.ts.map +0 -1
- package/dist/checkbox/createCheckboxGroupState.d.ts +0 -71
- package/dist/checkbox/createCheckboxGroupState.d.ts.map +0 -1
- package/dist/checkbox/index.d.ts +0 -9
- package/dist/checkbox/index.d.ts.map +0 -1
- package/dist/color/createColorArea.d.ts +0 -13
- package/dist/color/createColorArea.d.ts.map +0 -1
- package/dist/color/createColorField.d.ts +0 -13
- package/dist/color/createColorField.d.ts.map +0 -1
- package/dist/color/createColorSlider.d.ts +0 -13
- package/dist/color/createColorSlider.d.ts.map +0 -1
- package/dist/color/createColorSwatch.d.ts +0 -12
- package/dist/color/createColorSwatch.d.ts.map +0 -1
- package/dist/color/createColorWheel.d.ts +0 -13
- package/dist/color/createColorWheel.d.ts.map +0 -1
- package/dist/color/index.d.ts +0 -10
- package/dist/color/index.d.ts.map +0 -1
- package/dist/color/types.d.ts +0 -106
- package/dist/color/types.d.ts.map +0 -1
- package/dist/combobox/createComboBox.d.ts +0 -77
- package/dist/combobox/createComboBox.d.ts.map +0 -1
- package/dist/combobox/index.d.ts +0 -2
- package/dist/combobox/index.d.ts.map +0 -1
- package/dist/combobox/intl/index.d.ts +0 -14
- package/dist/combobox/intl/index.d.ts.map +0 -1
- package/dist/datepicker/createDateField.d.ts +0 -51
- package/dist/datepicker/createDateField.d.ts.map +0 -1
- package/dist/datepicker/createDatePicker.d.ts +0 -65
- package/dist/datepicker/createDatePicker.d.ts.map +0 -1
- package/dist/datepicker/createDateSegment.d.ts +0 -29
- package/dist/datepicker/createDateSegment.d.ts.map +0 -1
- package/dist/datepicker/createTimeField.d.ts +0 -51
- package/dist/datepicker/createTimeField.d.ts.map +0 -1
- package/dist/datepicker/index.d.ts +0 -5
- package/dist/datepicker/index.d.ts.map +0 -1
- package/dist/dialog/createDialog.d.ts +0 -25
- package/dist/dialog/createDialog.d.ts.map +0 -1
- package/dist/dialog/index.d.ts +0 -3
- package/dist/dialog/index.d.ts.map +0 -1
- package/dist/dialog/types.d.ts +0 -18
- package/dist/dialog/types.d.ts.map +0 -1
- package/dist/disclosure/createDisclosure.d.ts +0 -52
- package/dist/disclosure/createDisclosure.d.ts.map +0 -1
- package/dist/disclosure/createDisclosureGroup.d.ts +0 -39
- package/dist/disclosure/createDisclosureGroup.d.ts.map +0 -1
- package/dist/disclosure/index.d.ts +0 -3
- package/dist/disclosure/index.d.ts.map +0 -1
- package/dist/dnd/createDrag.d.ts +0 -16
- package/dist/dnd/createDrag.d.ts.map +0 -1
- package/dist/dnd/createDraggableCollection.d.ts +0 -27
- package/dist/dnd/createDraggableCollection.d.ts.map +0 -1
- package/dist/dnd/createDraggableItem.d.ts +0 -37
- package/dist/dnd/createDraggableItem.d.ts.map +0 -1
- package/dist/dnd/createDrop.d.ts +0 -16
- package/dist/dnd/createDrop.d.ts.map +0 -1
- package/dist/dnd/createDroppableCollection.d.ts +0 -76
- package/dist/dnd/createDroppableCollection.d.ts.map +0 -1
- package/dist/dnd/createDroppableItem.d.ts +0 -31
- package/dist/dnd/createDroppableItem.d.ts.map +0 -1
- package/dist/dnd/index.d.ts +0 -18
- package/dist/dnd/index.d.ts.map +0 -1
- package/dist/dnd/types.d.ts +0 -66
- package/dist/dnd/types.d.ts.map +0 -1
- package/dist/dnd/utils.d.ts +0 -57
- package/dist/dnd/utils.d.ts.map +0 -1
- package/dist/focus/FocusScope.d.ts +0 -57
- package/dist/focus/FocusScope.d.ts.map +0 -1
- package/dist/focus/createAutoFocus.d.ts +0 -120
- package/dist/focus/createAutoFocus.d.ts.map +0 -1
- package/dist/focus/createFocusRestore.d.ts +0 -116
- package/dist/focus/createFocusRestore.d.ts.map +0 -1
- package/dist/focus/createVirtualFocus.d.ts +0 -170
- package/dist/focus/createVirtualFocus.d.ts.map +0 -1
- package/dist/focus/index.d.ts +0 -5
- package/dist/focus/index.d.ts.map +0 -1
- package/dist/form/createFormReset.d.ts +0 -27
- package/dist/form/createFormReset.d.ts.map +0 -1
- package/dist/form/createFormValidation.d.ts +0 -56
- package/dist/form/createFormValidation.d.ts.map +0 -1
- package/dist/form/index.d.ts +0 -3
- package/dist/form/index.d.ts.map +0 -1
- package/dist/grid/GridKeyboardDelegate.d.ts +0 -79
- package/dist/grid/GridKeyboardDelegate.d.ts.map +0 -1
- package/dist/grid/createGrid.d.ts +0 -24
- package/dist/grid/createGrid.d.ts.map +0 -1
- package/dist/grid/createGridCell.d.ts +0 -12
- package/dist/grid/createGridCell.d.ts.map +0 -1
- package/dist/grid/createGridRow.d.ts +0 -12
- package/dist/grid/createGridRow.d.ts.map +0 -1
- package/dist/grid/index.d.ts +0 -10
- package/dist/grid/index.d.ts.map +0 -1
- package/dist/grid/types.d.ts +0 -126
- package/dist/grid/types.d.ts.map +0 -1
- package/dist/gridlist/createGridList.d.ts +0 -28
- package/dist/gridlist/createGridList.d.ts.map +0 -1
- package/dist/gridlist/createGridListItem.d.ts +0 -12
- package/dist/gridlist/createGridListItem.d.ts.map +0 -1
- package/dist/gridlist/createGridListSelectionCheckbox.d.ts +0 -12
- package/dist/gridlist/createGridListSelectionCheckbox.d.ts.map +0 -1
- package/dist/gridlist/index.d.ts +0 -8
- package/dist/gridlist/index.d.ts.map +0 -1
- package/dist/gridlist/types.d.ts +0 -75
- package/dist/gridlist/types.d.ts.map +0 -1
- package/dist/i18n/NumberFormatter.d.ts +0 -43
- package/dist/i18n/NumberFormatter.d.ts.map +0 -1
- package/dist/i18n/createCollator.d.ts +0 -41
- package/dist/i18n/createCollator.d.ts.map +0 -1
- package/dist/i18n/createDateFormatter.d.ts +0 -45
- package/dist/i18n/createDateFormatter.d.ts.map +0 -1
- package/dist/i18n/createFilter.d.ts +0 -57
- package/dist/i18n/createFilter.d.ts.map +0 -1
- package/dist/i18n/createNumberFormatter.d.ts +0 -43
- package/dist/i18n/createNumberFormatter.d.ts.map +0 -1
- package/dist/i18n/createStringFormatter.d.ts +0 -42
- package/dist/i18n/createStringFormatter.d.ts.map +0 -1
- package/dist/i18n/index.d.ts +0 -9
- package/dist/i18n/index.d.ts.map +0 -1
- package/dist/i18n/locale.d.ts +0 -66
- package/dist/i18n/locale.d.ts.map +0 -1
- package/dist/i18n/utils.d.ts +0 -17
- package/dist/i18n/utils.d.ts.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -7
- package/dist/index.ssr.js.map +0 -7
- package/dist/interactions/FocusableProvider.d.ts +0 -26
- package/dist/interactions/FocusableProvider.d.ts.map +0 -1
- package/dist/interactions/PressEvent.d.ts +0 -73
- package/dist/interactions/PressEvent.d.ts.map +0 -1
- package/dist/interactions/createFocus.d.ts +0 -31
- package/dist/interactions/createFocus.d.ts.map +0 -1
- package/dist/interactions/createFocusRing.d.ts +0 -37
- package/dist/interactions/createFocusRing.d.ts.map +0 -1
- package/dist/interactions/createFocusWithin.d.ts +0 -27
- package/dist/interactions/createFocusWithin.d.ts.map +0 -1
- package/dist/interactions/createFocusable.d.ts +0 -65
- package/dist/interactions/createFocusable.d.ts.map +0 -1
- package/dist/interactions/createHover.d.ts +0 -43
- package/dist/interactions/createHover.d.ts.map +0 -1
- package/dist/interactions/createInteractionModality.d.ts +0 -73
- package/dist/interactions/createInteractionModality.d.ts.map +0 -1
- package/dist/interactions/createKeyboard.d.ts +0 -35
- package/dist/interactions/createKeyboard.d.ts.map +0 -1
- package/dist/interactions/createLongPress.d.ts +0 -63
- package/dist/interactions/createLongPress.d.ts.map +0 -1
- package/dist/interactions/createMove.d.ts +0 -40
- package/dist/interactions/createMove.d.ts.map +0 -1
- package/dist/interactions/createPress.d.ts +0 -55
- package/dist/interactions/createPress.d.ts.map +0 -1
- package/dist/interactions/index.d.ts +0 -13
- package/dist/interactions/index.d.ts.map +0 -1
- package/dist/label/createField.d.ts +0 -51
- package/dist/label/createField.d.ts.map +0 -1
- package/dist/label/createLabel.d.ts +0 -49
- package/dist/label/createLabel.d.ts.map +0 -1
- package/dist/label/createLabels.d.ts +0 -16
- package/dist/label/createLabels.d.ts.map +0 -1
- package/dist/label/index.d.ts +0 -6
- package/dist/label/index.d.ts.map +0 -1
- package/dist/landmark/createLandmark.d.ts +0 -79
- package/dist/landmark/createLandmark.d.ts.map +0 -1
- package/dist/landmark/index.d.ts +0 -2
- package/dist/landmark/index.d.ts.map +0 -1
- package/dist/link/createLink.d.ts +0 -65
- package/dist/link/createLink.d.ts.map +0 -1
- package/dist/link/index.d.ts +0 -2
- package/dist/link/index.d.ts.map +0 -1
- package/dist/listbox/createListBox.d.ts +0 -58
- package/dist/listbox/createListBox.d.ts.map +0 -1
- package/dist/listbox/createOption.d.ts +0 -42
- package/dist/listbox/createOption.d.ts.map +0 -1
- package/dist/listbox/index.d.ts +0 -3
- package/dist/listbox/index.d.ts.map +0 -1
- package/dist/live-announcer/announce.d.ts +0 -113
- package/dist/live-announcer/announce.d.ts.map +0 -1
- package/dist/live-announcer/index.d.ts +0 -2
- package/dist/live-announcer/index.d.ts.map +0 -1
- package/dist/menu/createMenu.d.ts +0 -57
- package/dist/menu/createMenu.d.ts.map +0 -1
- package/dist/menu/createMenuItem.d.ts +0 -42
- package/dist/menu/createMenuItem.d.ts.map +0 -1
- package/dist/menu/createMenuTrigger.d.ts +0 -29
- package/dist/menu/createMenuTrigger.d.ts.map +0 -1
- package/dist/menu/index.d.ts +0 -4
- package/dist/menu/index.d.ts.map +0 -1
- package/dist/meter/createMeter.d.ts +0 -44
- package/dist/meter/createMeter.d.ts.map +0 -1
- package/dist/meter/index.d.ts +0 -2
- package/dist/meter/index.d.ts.map +0 -1
- package/dist/numberfield/createNumberField.d.ts +0 -56
- package/dist/numberfield/createNumberField.d.ts.map +0 -1
- package/dist/numberfield/index.d.ts +0 -2
- package/dist/numberfield/index.d.ts.map +0 -1
- package/dist/overlays/ariaHideOutside.d.ts +0 -25
- package/dist/overlays/ariaHideOutside.d.ts.map +0 -1
- package/dist/overlays/createInteractOutside.d.ts +0 -20
- package/dist/overlays/createInteractOutside.d.ts.map +0 -1
- package/dist/overlays/createModal.d.ts +0 -70
- package/dist/overlays/createModal.d.ts.map +0 -1
- package/dist/overlays/createOverlay.d.ts +0 -43
- package/dist/overlays/createOverlay.d.ts.map +0 -1
- package/dist/overlays/createOverlayTrigger.d.ts +0 -30
- package/dist/overlays/createOverlayTrigger.d.ts.map +0 -1
- package/dist/overlays/createPreventScroll.d.ts +0 -15
- package/dist/overlays/createPreventScroll.d.ts.map +0 -1
- package/dist/overlays/index.d.ts +0 -7
- package/dist/overlays/index.d.ts.map +0 -1
- package/dist/popover/calculatePosition.d.ts +0 -67
- package/dist/popover/calculatePosition.d.ts.map +0 -1
- package/dist/popover/createOverlayPosition.d.ts +0 -109
- package/dist/popover/createOverlayPosition.d.ts.map +0 -1
- package/dist/popover/createPopover.d.ts +0 -88
- package/dist/popover/createPopover.d.ts.map +0 -1
- package/dist/popover/index.d.ts +0 -4
- package/dist/popover/index.d.ts.map +0 -1
- package/dist/progress/createProgressBar.d.ts +0 -47
- package/dist/progress/createProgressBar.d.ts.map +0 -1
- package/dist/progress/index.d.ts +0 -2
- package/dist/progress/index.d.ts.map +0 -1
- package/dist/radio/createRadio.d.ts +0 -68
- package/dist/radio/createRadio.d.ts.map +0 -1
- package/dist/radio/createRadioGroup.d.ts +0 -85
- package/dist/radio/createRadioGroup.d.ts.map +0 -1
- package/dist/radio/createRadioGroupState.d.ts +0 -77
- package/dist/radio/createRadioGroupState.d.ts.map +0 -1
- package/dist/radio/index.d.ts +0 -4
- package/dist/radio/index.d.ts.map +0 -1
- package/dist/searchfield/createSearchField.d.ts +0 -32
- package/dist/searchfield/createSearchField.d.ts.map +0 -1
- package/dist/searchfield/index.d.ts +0 -3
- package/dist/searchfield/index.d.ts.map +0 -1
- package/dist/select/createHiddenSelect.d.ts +0 -69
- package/dist/select/createHiddenSelect.d.ts.map +0 -1
- package/dist/select/createSelect.d.ts +0 -70
- package/dist/select/createSelect.d.ts.map +0 -1
- package/dist/select/index.d.ts +0 -3
- package/dist/select/index.d.ts.map +0 -1
- package/dist/selection/createTypeSelect.d.ts +0 -43
- package/dist/selection/createTypeSelect.d.ts.map +0 -1
- package/dist/selection/index.d.ts +0 -6
- package/dist/selection/index.d.ts.map +0 -1
- package/dist/separator/createSeparator.d.ts +0 -38
- package/dist/separator/createSeparator.d.ts.map +0 -1
- package/dist/separator/index.d.ts +0 -2
- package/dist/separator/index.d.ts.map +0 -1
- package/dist/slider/createSlider.d.ts +0 -43
- package/dist/slider/createSlider.d.ts.map +0 -1
- package/dist/slider/index.d.ts +0 -3
- package/dist/slider/index.d.ts.map +0 -1
- package/dist/ssr/index.d.ts +0 -221
- package/dist/ssr/index.d.ts.map +0 -1
- package/dist/switch/createSwitch.d.ts +0 -34
- package/dist/switch/createSwitch.d.ts.map +0 -1
- package/dist/switch/index.d.ts +0 -2
- package/dist/switch/index.d.ts.map +0 -1
- package/dist/table/createTable.d.ts +0 -24
- package/dist/table/createTable.d.ts.map +0 -1
- package/dist/table/createTableCell.d.ts +0 -12
- package/dist/table/createTableCell.d.ts.map +0 -1
- package/dist/table/createTableColumnHeader.d.ts +0 -12
- package/dist/table/createTableColumnHeader.d.ts.map +0 -1
- package/dist/table/createTableHeaderRow.d.ts +0 -12
- package/dist/table/createTableHeaderRow.d.ts.map +0 -1
- package/dist/table/createTableRow.d.ts +0 -12
- package/dist/table/createTableRow.d.ts.map +0 -1
- package/dist/table/createTableRowGroup.d.ts +0 -11
- package/dist/table/createTableRowGroup.d.ts.map +0 -1
- package/dist/table/createTableSelectAllCheckbox.d.ts +0 -12
- package/dist/table/createTableSelectAllCheckbox.d.ts.map +0 -1
- package/dist/table/createTableSelectionCheckbox.d.ts +0 -12
- package/dist/table/createTableSelectionCheckbox.d.ts.map +0 -1
- package/dist/table/index.d.ts +0 -14
- package/dist/table/index.d.ts.map +0 -1
- package/dist/table/types.d.ts +0 -150
- package/dist/table/types.d.ts.map +0 -1
- package/dist/tabs/createTabs.d.ts +0 -123
- package/dist/tabs/createTabs.d.ts.map +0 -1
- package/dist/tabs/index.d.ts +0 -2
- package/dist/tabs/index.d.ts.map +0 -1
- package/dist/tag/createTag.d.ts +0 -42
- package/dist/tag/createTag.d.ts.map +0 -1
- package/dist/tag/createTagGroup.d.ts +0 -54
- package/dist/tag/createTagGroup.d.ts.map +0 -1
- package/dist/tag/index.d.ts +0 -3
- package/dist/tag/index.d.ts.map +0 -1
- package/dist/textfield/createTextField.d.ts +0 -73
- package/dist/textfield/createTextField.d.ts.map +0 -1
- package/dist/textfield/index.d.ts +0 -2
- package/dist/textfield/index.d.ts.map +0 -1
- package/dist/toast/createToast.d.ts +0 -58
- package/dist/toast/createToast.d.ts.map +0 -1
- package/dist/toast/createToastRegion.d.ts +0 -49
- package/dist/toast/createToastRegion.d.ts.map +0 -1
- package/dist/toast/index.d.ts +0 -3
- package/dist/toast/index.d.ts.map +0 -1
- package/dist/toggle/createToggle.d.ts +0 -94
- package/dist/toggle/createToggle.d.ts.map +0 -1
- package/dist/toggle/createToggleState.d.ts +0 -34
- package/dist/toggle/createToggleState.d.ts.map +0 -1
- package/dist/toggle/index.d.ts +0 -5
- package/dist/toggle/index.d.ts.map +0 -1
- package/dist/toolbar/createToolbar.d.ts +0 -49
- package/dist/toolbar/createToolbar.d.ts.map +0 -1
- package/dist/toolbar/index.d.ts +0 -2
- package/dist/toolbar/index.d.ts.map +0 -1
- package/dist/tooltip/createTooltip.d.ts +0 -48
- package/dist/tooltip/createTooltip.d.ts.map +0 -1
- package/dist/tooltip/createTooltipTrigger.d.ts +0 -64
- package/dist/tooltip/createTooltipTrigger.d.ts.map +0 -1
- package/dist/tooltip/index.d.ts +0 -3
- package/dist/tooltip/index.d.ts.map +0 -1
- package/dist/tree/createTree.d.ts +0 -28
- package/dist/tree/createTree.d.ts.map +0 -1
- package/dist/tree/createTreeItem.d.ts +0 -12
- package/dist/tree/createTreeItem.d.ts.map +0 -1
- package/dist/tree/createTreeSelectionCheckbox.d.ts +0 -12
- package/dist/tree/createTreeSelectionCheckbox.d.ts.map +0 -1
- package/dist/tree/index.d.ts +0 -8
- package/dist/tree/index.d.ts.map +0 -1
- package/dist/tree/types.d.ts +0 -81
- package/dist/tree/types.d.ts.map +0 -1
- package/dist/utils/createDescription.d.ts +0 -56
- package/dist/utils/createDescription.d.ts.map +0 -1
- package/dist/utils/dom.d.ts +0 -68
- package/dist/utils/dom.d.ts.map +0 -1
- package/dist/utils/env.d.ts +0 -18
- package/dist/utils/env.d.ts.map +0 -1
- package/dist/utils/events.d.ts +0 -29
- package/dist/utils/events.d.ts.map +0 -1
- package/dist/utils/filterDOMProps.d.ts +0 -29
- package/dist/utils/filterDOMProps.d.ts.map +0 -1
- package/dist/utils/focus.d.ts +0 -20
- package/dist/utils/focus.d.ts.map +0 -1
- package/dist/utils/geometry.d.ts +0 -40
- package/dist/utils/geometry.d.ts.map +0 -1
- package/dist/utils/globalListeners.d.ts +0 -36
- package/dist/utils/globalListeners.d.ts.map +0 -1
- package/dist/utils/index.d.ts +0 -13
- package/dist/utils/index.d.ts.map +0 -1
- package/dist/utils/mergeProps.d.ts +0 -11
- package/dist/utils/mergeProps.d.ts.map +0 -1
- package/dist/utils/platform.d.ts +0 -14
- package/dist/utils/platform.d.ts.map +0 -1
- package/dist/utils/reactivity.d.ts +0 -28
- package/dist/utils/reactivity.d.ts.map +0 -1
- package/dist/utils/textSelection.d.ts +0 -19
- package/dist/utils/textSelection.d.ts.map +0 -1
- package/dist/visually-hidden/createVisuallyHidden.d.ts +0 -60
- package/dist/visually-hidden/createVisuallyHidden.d.ts.map +0 -1
- package/dist/visually-hidden/index.d.ts +0 -2
- package/dist/visually-hidden/index.d.ts.map +0 -1
- package/src/autocomplete/createAutocomplete.ts +0 -341
- package/src/autocomplete/index.ts +0 -9
- package/src/breadcrumbs/createBreadcrumbs.ts +0 -196
- package/src/breadcrumbs/index.ts +0 -8
- package/src/button/createButton.ts +0 -142
- package/src/button/createToggleButton.ts +0 -101
- package/src/button/index.ts +0 -4
- package/src/button/types.ts +0 -78
- package/src/calendar/createCalendar.ts +0 -138
- package/src/calendar/createCalendarCell.ts +0 -187
- package/src/calendar/createCalendarGrid.ts +0 -140
- package/src/calendar/createRangeCalendar.ts +0 -136
- package/src/calendar/createRangeCalendarCell.ts +0 -186
- package/src/calendar/index.ts +0 -34
- package/src/checkbox/createCheckbox.ts +0 -135
- package/src/checkbox/createCheckboxGroup.ts +0 -137
- package/src/checkbox/createCheckboxGroupItem.ts +0 -117
- package/src/checkbox/createCheckboxGroupState.ts +0 -193
- package/src/checkbox/index.ts +0 -13
- package/src/color/createColorArea.ts +0 -314
- package/src/color/createColorField.ts +0 -137
- package/src/color/createColorSlider.ts +0 -197
- package/src/color/createColorSwatch.ts +0 -40
- package/src/color/createColorWheel.ts +0 -208
- package/src/color/index.ts +0 -24
- package/src/color/types.ts +0 -116
- package/src/combobox/createComboBox.ts +0 -647
- package/src/combobox/index.ts +0 -6
- package/src/combobox/intl/en-US.json +0 -7
- package/src/combobox/intl/es-ES.json +0 -7
- package/src/combobox/intl/index.ts +0 -23
- package/src/datepicker/createDateField.ts +0 -154
- package/src/datepicker/createDatePicker.ts +0 -206
- package/src/datepicker/createDateSegment.ts +0 -229
- package/src/datepicker/createTimeField.ts +0 -154
- package/src/datepicker/index.ts +0 -28
- package/src/dialog/createDialog.ts +0 -120
- package/src/dialog/index.ts +0 -2
- package/src/dialog/types.ts +0 -19
- package/src/disclosure/createDisclosure.ts +0 -131
- package/src/disclosure/createDisclosureGroup.ts +0 -62
- package/src/disclosure/index.ts +0 -11
- package/src/dnd/createDrag.ts +0 -209
- package/src/dnd/createDraggableCollection.ts +0 -63
- package/src/dnd/createDraggableItem.ts +0 -243
- package/src/dnd/createDrop.ts +0 -321
- package/src/dnd/createDroppableCollection.ts +0 -293
- package/src/dnd/createDroppableItem.ts +0 -213
- package/src/dnd/index.ts +0 -47
- package/src/dnd/types.ts +0 -89
- package/src/dnd/utils.ts +0 -294
- package/src/focus/FocusScope.tsx +0 -408
- package/src/focus/createAutoFocus.ts +0 -321
- package/src/focus/createFocusRestore.ts +0 -313
- package/src/focus/createVirtualFocus.ts +0 -396
- package/src/focus/index.ts +0 -35
- package/src/form/createFormReset.ts +0 -51
- package/src/form/createFormValidation.ts +0 -224
- package/src/form/index.ts +0 -11
- package/src/grid/GridKeyboardDelegate.ts +0 -429
- package/src/grid/createGrid.ts +0 -261
- package/src/grid/createGridCell.ts +0 -182
- package/src/grid/createGridRow.ts +0 -153
- package/src/grid/index.ts +0 -18
- package/src/grid/types.ts +0 -133
- package/src/gridlist/createGridList.ts +0 -185
- package/src/gridlist/createGridListItem.ts +0 -180
- package/src/gridlist/createGridListSelectionCheckbox.ts +0 -59
- package/src/gridlist/index.ts +0 -16
- package/src/gridlist/types.ts +0 -81
- package/src/i18n/NumberFormatter.ts +0 -266
- package/src/i18n/createCollator.ts +0 -79
- package/src/i18n/createDateFormatter.ts +0 -83
- package/src/i18n/createFilter.ts +0 -131
- package/src/i18n/createNumberFormatter.ts +0 -52
- package/src/i18n/createStringFormatter.ts +0 -87
- package/src/i18n/index.ts +0 -40
- package/src/i18n/locale.tsx +0 -188
- package/src/i18n/utils.ts +0 -99
- package/src/index.ts +0 -670
- package/src/interactions/FocusableProvider.tsx +0 -44
- package/src/interactions/PressEvent.ts +0 -124
- package/src/interactions/createFocus.ts +0 -163
- package/src/interactions/createFocusRing.ts +0 -89
- package/src/interactions/createFocusWithin.ts +0 -206
- package/src/interactions/createFocusable.ts +0 -168
- package/src/interactions/createHover.ts +0 -254
- package/src/interactions/createInteractionModality.ts +0 -424
- package/src/interactions/createKeyboard.ts +0 -82
- package/src/interactions/createLongPress.ts +0 -174
- package/src/interactions/createMove.ts +0 -289
- package/src/interactions/createPress.ts +0 -834
- package/src/interactions/index.ts +0 -78
- package/src/label/createField.ts +0 -145
- package/src/label/createLabel.ts +0 -117
- package/src/label/createLabels.ts +0 -50
- package/src/label/index.ts +0 -19
- package/src/landmark/createLandmark.ts +0 -377
- package/src/landmark/index.ts +0 -8
- package/src/link/createLink.ts +0 -182
- package/src/link/index.ts +0 -1
- package/src/listbox/createListBox.ts +0 -269
- package/src/listbox/createOption.ts +0 -151
- package/src/listbox/index.ts +0 -12
- package/src/live-announcer/announce.ts +0 -322
- package/src/live-announcer/index.ts +0 -9
- package/src/menu/createMenu.ts +0 -396
- package/src/menu/createMenuItem.ts +0 -149
- package/src/menu/createMenuTrigger.ts +0 -88
- package/src/menu/index.ts +0 -18
- package/src/meter/createMeter.ts +0 -75
- package/src/meter/index.ts +0 -1
- package/src/numberfield/createNumberField.ts +0 -268
- package/src/numberfield/index.ts +0 -5
- package/src/overlays/ariaHideOutside.ts +0 -219
- package/src/overlays/createInteractOutside.ts +0 -149
- package/src/overlays/createModal.tsx +0 -202
- package/src/overlays/createOverlay.ts +0 -155
- package/src/overlays/createOverlayTrigger.ts +0 -85
- package/src/overlays/createPreventScroll.ts +0 -266
- package/src/overlays/index.ts +0 -44
- package/src/popover/calculatePosition.ts +0 -766
- package/src/popover/createOverlayPosition.ts +0 -356
- package/src/popover/createPopover.ts +0 -170
- package/src/popover/index.ts +0 -24
- package/src/progress/createProgressBar.ts +0 -128
- package/src/progress/index.ts +0 -5
- package/src/radio/createRadio.ts +0 -287
- package/src/radio/createRadioGroup.ts +0 -189
- package/src/radio/createRadioGroupState.ts +0 -201
- package/src/radio/index.ts +0 -23
- package/src/searchfield/createSearchField.ts +0 -186
- package/src/searchfield/index.ts +0 -2
- package/src/select/createHiddenSelect.tsx +0 -236
- package/src/select/createSelect.ts +0 -395
- package/src/select/index.ts +0 -14
- package/src/selection/createTypeSelect.ts +0 -201
- package/src/selection/index.ts +0 -6
- package/src/separator/createSeparator.ts +0 -82
- package/src/separator/index.ts +0 -6
- package/src/slider/createSlider.ts +0 -349
- package/src/slider/index.ts +0 -2
- package/src/ssr/index.tsx +0 -370
- package/src/switch/createSwitch.ts +0 -70
- package/src/switch/index.ts +0 -1
- package/src/table/createTable.ts +0 -526
- package/src/table/createTableCell.ts +0 -147
- package/src/table/createTableColumnHeader.ts +0 -115
- package/src/table/createTableHeaderRow.ts +0 -40
- package/src/table/createTableRow.ts +0 -155
- package/src/table/createTableRowGroup.ts +0 -32
- package/src/table/createTableSelectAllCheckbox.ts +0 -73
- package/src/table/createTableSelectionCheckbox.ts +0 -59
- package/src/table/index.ts +0 -30
- package/src/table/types.ts +0 -165
- package/src/tabs/createTabs.ts +0 -472
- package/src/tabs/index.ts +0 -14
- package/src/tag/createTag.ts +0 -194
- package/src/tag/createTagGroup.ts +0 -154
- package/src/tag/index.ts +0 -12
- package/src/textfield/createTextField.ts +0 -198
- package/src/textfield/index.ts +0 -5
- package/src/toast/createToast.ts +0 -118
- package/src/toast/createToastRegion.ts +0 -100
- package/src/toast/index.ts +0 -11
- package/src/toggle/createToggle.ts +0 -223
- package/src/toggle/createToggleState.ts +0 -94
- package/src/toggle/index.ts +0 -7
- package/src/toolbar/createToolbar.ts +0 -368
- package/src/toolbar/index.ts +0 -6
- package/src/tooltip/createTooltip.ts +0 -79
- package/src/tooltip/createTooltipTrigger.ts +0 -222
- package/src/tooltip/index.ts +0 -6
- package/src/tree/createTree.ts +0 -246
- package/src/tree/createTreeItem.ts +0 -233
- package/src/tree/createTreeSelectionCheckbox.ts +0 -68
- package/src/tree/index.ts +0 -16
- package/src/tree/types.ts +0 -87
- package/src/utils/createDescription.ts +0 -137
- package/src/utils/dom.ts +0 -327
- package/src/utils/env.ts +0 -54
- package/src/utils/events.ts +0 -106
- package/src/utils/filterDOMProps.ts +0 -116
- package/src/utils/focus.ts +0 -151
- package/src/utils/geometry.ts +0 -115
- package/src/utils/globalListeners.ts +0 -142
- package/src/utils/index.ts +0 -80
- package/src/utils/mergeProps.ts +0 -52
- package/src/utils/platform.ts +0 -52
- package/src/utils/reactivity.ts +0 -36
- package/src/utils/textSelection.ts +0 -114
- package/src/visually-hidden/createVisuallyHidden.ts +0 -124
- package/src/visually-hidden/index.ts +0 -6
package/src/meter/createMeter.ts
DELETED
|
@@ -1,75 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Meter hook for Solidaria
|
|
3
|
-
*
|
|
4
|
-
* Provides the accessibility implementation for a meter component.
|
|
5
|
-
* Meters represent a quantity within a known range, or a fractional value.
|
|
6
|
-
* Unlike progress bars, meters represent a current value rather than progress toward a goal.
|
|
7
|
-
*
|
|
8
|
-
* This is a port of @react-aria/meter's useMeter hook.
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
import { createProgressBar, type AriaProgressBarProps } from '../progress/createProgressBar';
|
|
12
|
-
|
|
13
|
-
// ============================================
|
|
14
|
-
// TYPES
|
|
15
|
-
// ============================================
|
|
16
|
-
|
|
17
|
-
export interface AriaMeterProps extends Omit<AriaProgressBarProps, 'isIndeterminate'> {
|
|
18
|
-
/** The current value (controlled). */
|
|
19
|
-
value?: number;
|
|
20
|
-
/** The smallest value allowed for the input. @default 0 */
|
|
21
|
-
minValue?: number;
|
|
22
|
-
/** The largest value allowed for the input. @default 100 */
|
|
23
|
-
maxValue?: number;
|
|
24
|
-
/** The content to display as the value's label (e.g. 1 of 4). */
|
|
25
|
-
valueLabel?: string;
|
|
26
|
-
/** The display format of the value label. */
|
|
27
|
-
formatOptions?: Intl.NumberFormatOptions;
|
|
28
|
-
/** The content to display as the label. */
|
|
29
|
-
label?: string;
|
|
30
|
-
/** An accessibility label for this item. */
|
|
31
|
-
'aria-label'?: string;
|
|
32
|
-
/** Identifies the element (or elements) that labels the current element. */
|
|
33
|
-
'aria-labelledby'?: string;
|
|
34
|
-
/** Identifies the element (or elements) that describes the object. */
|
|
35
|
-
'aria-describedby'?: string;
|
|
36
|
-
/** Identifies the element (or elements) that provide a detailed, extended description for the object. */
|
|
37
|
-
'aria-details'?: string;
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
export interface MeterAria {
|
|
41
|
-
/** Props for the meter container element. */
|
|
42
|
-
meterProps: Record<string, unknown>;
|
|
43
|
-
/** Props for the meter's visual label element (if any). */
|
|
44
|
-
labelProps: Record<string, unknown>;
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
// ============================================
|
|
48
|
-
// IMPLEMENTATION
|
|
49
|
-
// ============================================
|
|
50
|
-
|
|
51
|
-
/**
|
|
52
|
-
* Provides the accessibility implementation for a meter component.
|
|
53
|
-
* Meters represent a quantity within a known range, or a fractional value.
|
|
54
|
-
*/
|
|
55
|
-
export function createMeter(props: AriaMeterProps = {}): MeterAria {
|
|
56
|
-
// Reuse progress bar implementation
|
|
57
|
-
const { progressBarProps, labelProps } = createProgressBar(props);
|
|
58
|
-
|
|
59
|
-
return {
|
|
60
|
-
get meterProps() {
|
|
61
|
-
return {
|
|
62
|
-
...progressBarProps,
|
|
63
|
-
// Use the meter role if available, but fall back to progressbar if not
|
|
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',
|
|
69
|
-
};
|
|
70
|
-
},
|
|
71
|
-
get labelProps() {
|
|
72
|
-
return labelProps;
|
|
73
|
-
},
|
|
74
|
-
};
|
|
75
|
-
}
|
package/src/meter/index.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { createMeter, type AriaMeterProps, type MeterAria } from './createMeter';
|
|
@@ -1,268 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Provides the behavior and accessibility implementation for a number field.
|
|
3
|
-
* Based on @react-aria/numberfield useNumberField.
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
import { type JSX, createMemo } from 'solid-js';
|
|
7
|
-
import { createLabel } from '../label/createLabel';
|
|
8
|
-
import { filterDOMProps } from '../utils/filterDOMProps';
|
|
9
|
-
import { mergeProps } from '../utils/mergeProps';
|
|
10
|
-
import { createId } from '../ssr';
|
|
11
|
-
import { access, type MaybeAccessor } from '../utils/reactivity';
|
|
12
|
-
import type { NumberFieldState } from '@proyecto-viviana/solid-stately';
|
|
13
|
-
|
|
14
|
-
export interface AriaNumberFieldProps {
|
|
15
|
-
/** A label for the number field. */
|
|
16
|
-
label?: JSX.Element;
|
|
17
|
-
/** An accessible label for the number field. */
|
|
18
|
-
'aria-label'?: string;
|
|
19
|
-
/** The element ID that labels the number field. */
|
|
20
|
-
'aria-labelledby'?: string;
|
|
21
|
-
/** The element ID that describes the number field. */
|
|
22
|
-
'aria-describedby'?: string;
|
|
23
|
-
/** Whether the number field is disabled. */
|
|
24
|
-
isDisabled?: boolean;
|
|
25
|
-
/** Whether the number field is read-only. */
|
|
26
|
-
isReadOnly?: boolean;
|
|
27
|
-
/** Whether the number field is required. */
|
|
28
|
-
isRequired?: boolean;
|
|
29
|
-
/** Whether the number field is invalid. */
|
|
30
|
-
isInvalid?: boolean;
|
|
31
|
-
/** A description for the number field. */
|
|
32
|
-
description?: JSX.Element;
|
|
33
|
-
/** An error message for the number field. */
|
|
34
|
-
errorMessage?: JSX.Element;
|
|
35
|
-
/** The ID of the number field. */
|
|
36
|
-
id?: string;
|
|
37
|
-
/** Whether to auto-focus the input. */
|
|
38
|
-
autoFocus?: boolean;
|
|
39
|
-
/** The name for the form input. */
|
|
40
|
-
name?: string;
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
export interface NumberFieldAria {
|
|
44
|
-
/** Props for the label element. */
|
|
45
|
-
labelProps: JSX.HTMLAttributes<HTMLElement>;
|
|
46
|
-
/** Props for the input element group. */
|
|
47
|
-
groupProps: JSX.HTMLAttributes<HTMLElement>;
|
|
48
|
-
/** Props for the input element. */
|
|
49
|
-
inputProps: JSX.InputHTMLAttributes<HTMLInputElement>;
|
|
50
|
-
/** Props for the increment button. */
|
|
51
|
-
incrementButtonProps: JSX.ButtonHTMLAttributes<HTMLButtonElement>;
|
|
52
|
-
/** Props for the decrement button. */
|
|
53
|
-
decrementButtonProps: JSX.ButtonHTMLAttributes<HTMLButtonElement>;
|
|
54
|
-
/** Props for the description element. */
|
|
55
|
-
descriptionProps: JSX.HTMLAttributes<HTMLElement>;
|
|
56
|
-
/** Props for the error message element. */
|
|
57
|
-
errorMessageProps: JSX.HTMLAttributes<HTMLElement>;
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
/**
|
|
61
|
-
* Provides the behavior and accessibility implementation for a number field.
|
|
62
|
-
*/
|
|
63
|
-
export function createNumberField(
|
|
64
|
-
props: MaybeAccessor<AriaNumberFieldProps>,
|
|
65
|
-
state: NumberFieldState,
|
|
66
|
-
inputRef?: () => HTMLInputElement | null
|
|
67
|
-
): NumberFieldAria {
|
|
68
|
-
const getProps = () => access(props);
|
|
69
|
-
const id = createId(getProps().id);
|
|
70
|
-
|
|
71
|
-
// Generate IDs for associated elements
|
|
72
|
-
const inputId = `${id}-input`;
|
|
73
|
-
const incrementId = `${id}-increment`;
|
|
74
|
-
const decrementId = `${id}-decrement`;
|
|
75
|
-
const descriptionId = `${id}-description`;
|
|
76
|
-
const errorMessageId = `${id}-error`;
|
|
77
|
-
|
|
78
|
-
// Label handling
|
|
79
|
-
const { labelProps, fieldProps } = createLabel({
|
|
80
|
-
get id() {
|
|
81
|
-
return inputId;
|
|
82
|
-
},
|
|
83
|
-
get label() {
|
|
84
|
-
return getProps().label;
|
|
85
|
-
},
|
|
86
|
-
get 'aria-label'() {
|
|
87
|
-
return getProps()['aria-label'];
|
|
88
|
-
},
|
|
89
|
-
get 'aria-labelledby'() {
|
|
90
|
-
return getProps()['aria-labelledby'];
|
|
91
|
-
},
|
|
92
|
-
labelElementType: 'span',
|
|
93
|
-
});
|
|
94
|
-
|
|
95
|
-
// Get the label text for button aria-labels
|
|
96
|
-
const getLabelText = (): string => {
|
|
97
|
-
const p = getProps();
|
|
98
|
-
if (p['aria-label']) return p['aria-label'];
|
|
99
|
-
if (typeof p.label === 'string') return p.label;
|
|
100
|
-
return 'value';
|
|
101
|
-
};
|
|
102
|
-
|
|
103
|
-
// Filter DOM props
|
|
104
|
-
const domProps = createMemo(() =>
|
|
105
|
-
filterDOMProps(getProps() as unknown as Record<string, unknown>, { labelable: true })
|
|
106
|
-
);
|
|
107
|
-
|
|
108
|
-
// Handle input change
|
|
109
|
-
const onInputChange: JSX.EventHandler<HTMLInputElement, Event> = (e) => {
|
|
110
|
-
const value = e.currentTarget.value;
|
|
111
|
-
if (state.validate(value)) {
|
|
112
|
-
state.setInputValue(value);
|
|
113
|
-
}
|
|
114
|
-
};
|
|
115
|
-
|
|
116
|
-
// Handle input blur - commit value
|
|
117
|
-
const onInputBlur: JSX.EventHandler<HTMLInputElement, FocusEvent> = () => {
|
|
118
|
-
state.commit();
|
|
119
|
-
};
|
|
120
|
-
|
|
121
|
-
// Handle keyboard events
|
|
122
|
-
const onKeyDown: JSX.EventHandler<HTMLInputElement, KeyboardEvent> = (e) => {
|
|
123
|
-
const p = getProps();
|
|
124
|
-
if (p.isDisabled || p.isReadOnly) return;
|
|
125
|
-
|
|
126
|
-
switch (e.key) {
|
|
127
|
-
case 'ArrowUp':
|
|
128
|
-
e.preventDefault();
|
|
129
|
-
state.increment();
|
|
130
|
-
break;
|
|
131
|
-
case 'ArrowDown':
|
|
132
|
-
e.preventDefault();
|
|
133
|
-
state.decrement();
|
|
134
|
-
break;
|
|
135
|
-
case 'PageUp':
|
|
136
|
-
e.preventDefault();
|
|
137
|
-
state.incrementToMax();
|
|
138
|
-
break;
|
|
139
|
-
case 'PageDown':
|
|
140
|
-
e.preventDefault();
|
|
141
|
-
state.decrementToMin();
|
|
142
|
-
break;
|
|
143
|
-
case 'Home':
|
|
144
|
-
e.preventDefault();
|
|
145
|
-
state.decrementToMin();
|
|
146
|
-
break;
|
|
147
|
-
case 'End':
|
|
148
|
-
e.preventDefault();
|
|
149
|
-
state.incrementToMax();
|
|
150
|
-
break;
|
|
151
|
-
case 'Enter':
|
|
152
|
-
state.commit();
|
|
153
|
-
break;
|
|
154
|
-
}
|
|
155
|
-
};
|
|
156
|
-
|
|
157
|
-
// Handle increment button
|
|
158
|
-
const onIncrementPress = () => {
|
|
159
|
-
state.increment();
|
|
160
|
-
// Return focus to input
|
|
161
|
-
inputRef?.()?.focus();
|
|
162
|
-
};
|
|
163
|
-
|
|
164
|
-
// Handle decrement button
|
|
165
|
-
const onDecrementPress = () => {
|
|
166
|
-
state.decrement();
|
|
167
|
-
// Return focus to input
|
|
168
|
-
inputRef?.()?.focus();
|
|
169
|
-
};
|
|
170
|
-
|
|
171
|
-
// Build aria-describedby
|
|
172
|
-
const getAriaDescribedBy = () => {
|
|
173
|
-
const p = getProps();
|
|
174
|
-
const parts: string[] = [];
|
|
175
|
-
if (p['aria-describedby']) parts.push(p['aria-describedby']);
|
|
176
|
-
if (p.description) parts.push(descriptionId);
|
|
177
|
-
if (p.isInvalid && p.errorMessage) parts.push(errorMessageId);
|
|
178
|
-
return parts.length > 0 ? parts.join(' ') : undefined;
|
|
179
|
-
};
|
|
180
|
-
|
|
181
|
-
return {
|
|
182
|
-
get labelProps() {
|
|
183
|
-
return labelProps as JSX.HTMLAttributes<HTMLElement>;
|
|
184
|
-
},
|
|
185
|
-
get groupProps() {
|
|
186
|
-
return {
|
|
187
|
-
role: 'group',
|
|
188
|
-
'aria-disabled': getProps().isDisabled || undefined,
|
|
189
|
-
} as JSX.HTMLAttributes<HTMLElement>;
|
|
190
|
-
},
|
|
191
|
-
get inputProps() {
|
|
192
|
-
const p = getProps();
|
|
193
|
-
const isDisabled = p.isDisabled ?? state.isDisabled();
|
|
194
|
-
const isReadOnly = p.isReadOnly ?? state.isReadOnly();
|
|
195
|
-
|
|
196
|
-
return mergeProps(
|
|
197
|
-
domProps(),
|
|
198
|
-
fieldProps as Record<string, unknown>,
|
|
199
|
-
{
|
|
200
|
-
id: inputId,
|
|
201
|
-
type: 'text',
|
|
202
|
-
inputMode: 'decimal' as const,
|
|
203
|
-
autoComplete: 'off',
|
|
204
|
-
autoCorrect: 'off',
|
|
205
|
-
spellcheck: false,
|
|
206
|
-
role: 'spinbutton',
|
|
207
|
-
'aria-valuenow': isNaN(state.numberValue()) ? undefined : state.numberValue(),
|
|
208
|
-
'aria-valuemin': state.minValue(),
|
|
209
|
-
'aria-valuemax': state.maxValue(),
|
|
210
|
-
'aria-valuetext': isNaN(state.numberValue()) ? undefined : state.inputValue(),
|
|
211
|
-
'aria-invalid': p.isInvalid || undefined,
|
|
212
|
-
'aria-required': p.isRequired || undefined,
|
|
213
|
-
'aria-describedby': getAriaDescribedBy(),
|
|
214
|
-
disabled: isDisabled || undefined,
|
|
215
|
-
readOnly: isReadOnly || undefined,
|
|
216
|
-
value: state.inputValue(),
|
|
217
|
-
onChange: onInputChange,
|
|
218
|
-
onBlur: onInputBlur,
|
|
219
|
-
onKeyDown,
|
|
220
|
-
name: p.name,
|
|
221
|
-
autoFocus: p.autoFocus,
|
|
222
|
-
} as Record<string, unknown>
|
|
223
|
-
) as JSX.InputHTMLAttributes<HTMLInputElement>;
|
|
224
|
-
},
|
|
225
|
-
get incrementButtonProps() {
|
|
226
|
-
const p = getProps();
|
|
227
|
-
const isDisabled = p.isDisabled ?? state.isDisabled();
|
|
228
|
-
const canIncrement = state.canIncrement();
|
|
229
|
-
|
|
230
|
-
return {
|
|
231
|
-
id: incrementId,
|
|
232
|
-
type: 'button' as const,
|
|
233
|
-
tabIndex: -1, // Exclude from tab order
|
|
234
|
-
'aria-label': `Increase ${getLabelText()}`,
|
|
235
|
-
'aria-controls': inputId,
|
|
236
|
-
disabled: isDisabled || !canIncrement,
|
|
237
|
-
onClick: onIncrementPress,
|
|
238
|
-
onMouseDown: (e: MouseEvent) => e.preventDefault(), // Prevent focus
|
|
239
|
-
} as JSX.ButtonHTMLAttributes<HTMLButtonElement>;
|
|
240
|
-
},
|
|
241
|
-
get decrementButtonProps() {
|
|
242
|
-
const p = getProps();
|
|
243
|
-
const isDisabled = p.isDisabled ?? state.isDisabled();
|
|
244
|
-
const canDecrement = state.canDecrement();
|
|
245
|
-
|
|
246
|
-
return {
|
|
247
|
-
id: decrementId,
|
|
248
|
-
type: 'button' as const,
|
|
249
|
-
tabIndex: -1, // Exclude from tab order
|
|
250
|
-
'aria-label': `Decrease ${getLabelText()}`,
|
|
251
|
-
'aria-controls': inputId,
|
|
252
|
-
disabled: isDisabled || !canDecrement,
|
|
253
|
-
onClick: onDecrementPress,
|
|
254
|
-
onMouseDown: (e: MouseEvent) => e.preventDefault(), // Prevent focus
|
|
255
|
-
} as JSX.ButtonHTMLAttributes<HTMLButtonElement>;
|
|
256
|
-
},
|
|
257
|
-
get descriptionProps() {
|
|
258
|
-
return {
|
|
259
|
-
id: descriptionId,
|
|
260
|
-
} as JSX.HTMLAttributes<HTMLElement>;
|
|
261
|
-
},
|
|
262
|
-
get errorMessageProps() {
|
|
263
|
-
return {
|
|
264
|
-
id: errorMessageId,
|
|
265
|
-
} as JSX.HTMLAttributes<HTMLElement>;
|
|
266
|
-
},
|
|
267
|
-
};
|
|
268
|
-
}
|
package/src/numberfield/index.ts
DELETED
|
@@ -1,219 +0,0 @@
|
|
|
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
|
-
}
|