@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
|
@@ -1,154 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* createDateField hook for Solidaria
|
|
3
|
-
*
|
|
4
|
-
* Provides the behavior and accessibility implementation for a date field component.
|
|
5
|
-
* Based on @react-aria/datepicker useDateField
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import { createMemo } from 'solid-js';
|
|
9
|
-
import { createId } from '../ssr';
|
|
10
|
-
import { createLabel } from '../label/createLabel';
|
|
11
|
-
import { access, type MaybeAccessor } from '../utils/reactivity';
|
|
12
|
-
import { mergeProps } from '../utils/mergeProps';
|
|
13
|
-
import type { DateFieldState, DateSegment } from '@proyecto-viviana/solid-stately';
|
|
14
|
-
|
|
15
|
-
// ============================================
|
|
16
|
-
// TYPES
|
|
17
|
-
// ============================================
|
|
18
|
-
|
|
19
|
-
export interface AriaDateFieldProps {
|
|
20
|
-
/** An ID for the date field. */
|
|
21
|
-
id?: string;
|
|
22
|
-
/** A visible label for the date field. */
|
|
23
|
-
label?: string;
|
|
24
|
-
/** An accessible label for the date field. */
|
|
25
|
-
'aria-label'?: string;
|
|
26
|
-
/** The ID of an element that labels the date field. */
|
|
27
|
-
'aria-labelledby'?: string;
|
|
28
|
-
/** The ID of an element that describes the date field. */
|
|
29
|
-
'aria-describedby'?: string;
|
|
30
|
-
/** Whether the date field is disabled. */
|
|
31
|
-
isDisabled?: boolean;
|
|
32
|
-
/** Whether the date field is read-only. */
|
|
33
|
-
isReadOnly?: boolean;
|
|
34
|
-
/** Whether the date field is required. */
|
|
35
|
-
isRequired?: boolean;
|
|
36
|
-
/** Whether the date field is invalid. */
|
|
37
|
-
isInvalid?: boolean;
|
|
38
|
-
/** Description text. */
|
|
39
|
-
description?: string;
|
|
40
|
-
/** Error message. */
|
|
41
|
-
errorMessage?: string;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
export interface DateFieldAria {
|
|
45
|
-
/** Props for the label element. */
|
|
46
|
-
labelProps: Record<string, unknown>;
|
|
47
|
-
/** Props for the field container element. */
|
|
48
|
-
fieldProps: Record<string, unknown>;
|
|
49
|
-
/** Props for the input container (holds segments). */
|
|
50
|
-
inputProps: Record<string, unknown>;
|
|
51
|
-
/** Props for the description element. */
|
|
52
|
-
descriptionProps: Record<string, unknown>;
|
|
53
|
-
/** Props for the error message element. */
|
|
54
|
-
errorMessageProps: Record<string, unknown>;
|
|
55
|
-
/** The segments to render. */
|
|
56
|
-
segments: DateSegment[];
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
// ============================================
|
|
60
|
-
// IMPLEMENTATION
|
|
61
|
-
// ============================================
|
|
62
|
-
|
|
63
|
-
/**
|
|
64
|
-
* Provides the behavior and accessibility implementation for a date field component.
|
|
65
|
-
*/
|
|
66
|
-
export function createDateField<T extends DateFieldState>(
|
|
67
|
-
props: MaybeAccessor<AriaDateFieldProps>,
|
|
68
|
-
state: T,
|
|
69
|
-
_ref?: () => HTMLElement | null
|
|
70
|
-
): DateFieldAria {
|
|
71
|
-
const getProps = () => access(props);
|
|
72
|
-
const id = createId(getProps().id);
|
|
73
|
-
const descriptionId = createId();
|
|
74
|
-
const errorMessageId = createId();
|
|
75
|
-
|
|
76
|
-
// Create label handling
|
|
77
|
-
const { labelProps, fieldProps: labelFieldProps } = createLabel({
|
|
78
|
-
get label() { return getProps().label; },
|
|
79
|
-
get 'aria-label'() { return getProps()['aria-label']; },
|
|
80
|
-
get 'aria-labelledby'() { return getProps()['aria-labelledby']; },
|
|
81
|
-
labelElementType: 'span',
|
|
82
|
-
});
|
|
83
|
-
|
|
84
|
-
// Build aria-describedby
|
|
85
|
-
const getAriaDescribedBy = () => {
|
|
86
|
-
const p = getProps();
|
|
87
|
-
const ids: string[] = [];
|
|
88
|
-
if (p['aria-describedby']) {
|
|
89
|
-
ids.push(p['aria-describedby']);
|
|
90
|
-
}
|
|
91
|
-
if (p.description) {
|
|
92
|
-
ids.push(descriptionId);
|
|
93
|
-
}
|
|
94
|
-
if (p.isInvalid && p.errorMessage) {
|
|
95
|
-
ids.push(errorMessageId);
|
|
96
|
-
}
|
|
97
|
-
return ids.length > 0 ? ids.join(' ') : undefined;
|
|
98
|
-
};
|
|
99
|
-
|
|
100
|
-
// Segments from state
|
|
101
|
-
const segments = createMemo(() => state.segments());
|
|
102
|
-
|
|
103
|
-
// Field container props
|
|
104
|
-
const fieldProps = createMemo(() => {
|
|
105
|
-
const p = getProps();
|
|
106
|
-
|
|
107
|
-
return mergeProps(labelFieldProps as Record<string, unknown>, {
|
|
108
|
-
id,
|
|
109
|
-
role: 'group',
|
|
110
|
-
'aria-disabled': p.isDisabled || state.isDisabled() || undefined,
|
|
111
|
-
'aria-readonly': p.isReadOnly || state.isReadOnly() || undefined,
|
|
112
|
-
'aria-required': p.isRequired || state.isRequired() || undefined,
|
|
113
|
-
'aria-invalid': p.isInvalid || state.isInvalid() || undefined,
|
|
114
|
-
'aria-describedby': getAriaDescribedBy(),
|
|
115
|
-
});
|
|
116
|
-
});
|
|
117
|
-
|
|
118
|
-
// Input container props
|
|
119
|
-
const inputProps = createMemo(() => ({
|
|
120
|
-
role: 'presentation',
|
|
121
|
-
}));
|
|
122
|
-
|
|
123
|
-
// Description props
|
|
124
|
-
const descriptionProps = createMemo(() => ({
|
|
125
|
-
id: descriptionId,
|
|
126
|
-
}));
|
|
127
|
-
|
|
128
|
-
// Error message props
|
|
129
|
-
const errorMessageProps = createMemo(() => ({
|
|
130
|
-
id: errorMessageId,
|
|
131
|
-
role: 'alert',
|
|
132
|
-
}));
|
|
133
|
-
|
|
134
|
-
return {
|
|
135
|
-
get labelProps() {
|
|
136
|
-
return labelProps as Record<string, unknown>;
|
|
137
|
-
},
|
|
138
|
-
get fieldProps() {
|
|
139
|
-
return fieldProps();
|
|
140
|
-
},
|
|
141
|
-
get inputProps() {
|
|
142
|
-
return inputProps();
|
|
143
|
-
},
|
|
144
|
-
get descriptionProps() {
|
|
145
|
-
return descriptionProps();
|
|
146
|
-
},
|
|
147
|
-
get errorMessageProps() {
|
|
148
|
-
return errorMessageProps();
|
|
149
|
-
},
|
|
150
|
-
get segments() {
|
|
151
|
-
return segments();
|
|
152
|
-
},
|
|
153
|
-
};
|
|
154
|
-
}
|
|
@@ -1,206 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* createDatePicker hook for Solidaria
|
|
3
|
-
*
|
|
4
|
-
* Provides the behavior and accessibility implementation for a date picker component.
|
|
5
|
-
* Based on @react-aria/datepicker useDatePicker
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import { createMemo } from 'solid-js';
|
|
9
|
-
import { createId } from '../ssr';
|
|
10
|
-
import { createLabel } from '../label/createLabel';
|
|
11
|
-
import { access, type MaybeAccessor } from '../utils/reactivity';
|
|
12
|
-
import { mergeProps } from '../utils/mergeProps';
|
|
13
|
-
import type { DateFieldState, CalendarState } from '@proyecto-viviana/solid-stately';
|
|
14
|
-
|
|
15
|
-
// ============================================
|
|
16
|
-
// TYPES
|
|
17
|
-
// ============================================
|
|
18
|
-
|
|
19
|
-
export interface AriaDatePickerProps {
|
|
20
|
-
/** An ID for the date picker. */
|
|
21
|
-
id?: string;
|
|
22
|
-
/** A visible label for the date picker. */
|
|
23
|
-
label?: string;
|
|
24
|
-
/** An accessible label for the date picker. */
|
|
25
|
-
'aria-label'?: string;
|
|
26
|
-
/** The ID of an element that labels the date picker. */
|
|
27
|
-
'aria-labelledby'?: string;
|
|
28
|
-
/** The ID of an element that describes the date picker. */
|
|
29
|
-
'aria-describedby'?: string;
|
|
30
|
-
/** Whether the date picker is disabled. */
|
|
31
|
-
isDisabled?: boolean;
|
|
32
|
-
/** Whether the date picker is read-only. */
|
|
33
|
-
isReadOnly?: boolean;
|
|
34
|
-
/** Whether the date picker is required. */
|
|
35
|
-
isRequired?: boolean;
|
|
36
|
-
/** Whether the date picker is invalid. */
|
|
37
|
-
isInvalid?: boolean;
|
|
38
|
-
/** Description text. */
|
|
39
|
-
description?: string;
|
|
40
|
-
/** Error message. */
|
|
41
|
-
errorMessage?: string;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
export interface DatePickerState {
|
|
45
|
-
/** Whether the calendar is open. */
|
|
46
|
-
isOpen: boolean;
|
|
47
|
-
/** Open the calendar. */
|
|
48
|
-
open: () => void;
|
|
49
|
-
/** Close the calendar. */
|
|
50
|
-
close: () => void;
|
|
51
|
-
/** Toggle the calendar. */
|
|
52
|
-
toggle: () => void;
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
export interface DatePickerAria {
|
|
56
|
-
/** Props for the group container. */
|
|
57
|
-
groupProps: Record<string, unknown>;
|
|
58
|
-
/** Props for the label element. */
|
|
59
|
-
labelProps: Record<string, unknown>;
|
|
60
|
-
/** Props for the date field container. */
|
|
61
|
-
fieldProps: Record<string, unknown>;
|
|
62
|
-
/** Props for the button that opens the calendar. */
|
|
63
|
-
buttonProps: Record<string, unknown>;
|
|
64
|
-
/** Props for the calendar dialog. */
|
|
65
|
-
dialogProps: Record<string, unknown>;
|
|
66
|
-
/** Props for the calendar. */
|
|
67
|
-
calendarProps: Record<string, unknown>;
|
|
68
|
-
/** Props for the description element. */
|
|
69
|
-
descriptionProps: Record<string, unknown>;
|
|
70
|
-
/** Props for the error message element. */
|
|
71
|
-
errorMessageProps: Record<string, unknown>;
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
// ============================================
|
|
75
|
-
// IMPLEMENTATION
|
|
76
|
-
// ============================================
|
|
77
|
-
|
|
78
|
-
/**
|
|
79
|
-
* Provides the behavior and accessibility implementation for a date picker component.
|
|
80
|
-
*/
|
|
81
|
-
export function createDatePicker<T extends DateFieldState, C extends CalendarState>(
|
|
82
|
-
props: MaybeAccessor<AriaDatePickerProps>,
|
|
83
|
-
state: T,
|
|
84
|
-
overlayState: DatePickerState,
|
|
85
|
-
_calendarState?: C
|
|
86
|
-
): DatePickerAria {
|
|
87
|
-
const getProps = () => access(props);
|
|
88
|
-
const id = createId(getProps().id);
|
|
89
|
-
const descriptionId = createId();
|
|
90
|
-
const errorMessageId = createId();
|
|
91
|
-
const dialogId = createId();
|
|
92
|
-
|
|
93
|
-
// Create label handling
|
|
94
|
-
const { labelProps, fieldProps: labelFieldProps } = createLabel({
|
|
95
|
-
get label() { return getProps().label; },
|
|
96
|
-
get 'aria-label'() { return getProps()['aria-label']; },
|
|
97
|
-
get 'aria-labelledby'() { return getProps()['aria-labelledby']; },
|
|
98
|
-
labelElementType: 'span',
|
|
99
|
-
});
|
|
100
|
-
|
|
101
|
-
// Build aria-describedby
|
|
102
|
-
const getAriaDescribedBy = () => {
|
|
103
|
-
const p = getProps();
|
|
104
|
-
const ids: string[] = [];
|
|
105
|
-
if (p['aria-describedby']) {
|
|
106
|
-
ids.push(p['aria-describedby']);
|
|
107
|
-
}
|
|
108
|
-
if (p.description) {
|
|
109
|
-
ids.push(descriptionId);
|
|
110
|
-
}
|
|
111
|
-
if (p.isInvalid && p.errorMessage) {
|
|
112
|
-
ids.push(errorMessageId);
|
|
113
|
-
}
|
|
114
|
-
return ids.length > 0 ? ids.join(' ') : undefined;
|
|
115
|
-
};
|
|
116
|
-
|
|
117
|
-
// Group props
|
|
118
|
-
const groupProps = createMemo(() => {
|
|
119
|
-
const p = getProps();
|
|
120
|
-
|
|
121
|
-
return mergeProps(labelFieldProps as Record<string, unknown>, {
|
|
122
|
-
id,
|
|
123
|
-
role: 'group',
|
|
124
|
-
'aria-disabled': p.isDisabled || state.isDisabled() || undefined,
|
|
125
|
-
'aria-describedby': getAriaDescribedBy(),
|
|
126
|
-
});
|
|
127
|
-
});
|
|
128
|
-
|
|
129
|
-
// Field props
|
|
130
|
-
const fieldProps = createMemo(() => ({
|
|
131
|
-
'aria-haspopup': 'dialog' as const,
|
|
132
|
-
'aria-expanded': overlayState.isOpen,
|
|
133
|
-
'aria-controls': overlayState.isOpen ? dialogId : undefined,
|
|
134
|
-
}));
|
|
135
|
-
|
|
136
|
-
// Button props
|
|
137
|
-
const buttonProps = createMemo(() => {
|
|
138
|
-
const p = getProps();
|
|
139
|
-
const isDisabled = p.isDisabled || state.isDisabled();
|
|
140
|
-
|
|
141
|
-
return {
|
|
142
|
-
'aria-label': 'Open calendar',
|
|
143
|
-
'aria-haspopup': 'dialog' as const,
|
|
144
|
-
'aria-expanded': overlayState.isOpen,
|
|
145
|
-
'aria-controls': overlayState.isOpen ? dialogId : undefined,
|
|
146
|
-
disabled: isDisabled,
|
|
147
|
-
tabIndex: -1,
|
|
148
|
-
onClick: () => {
|
|
149
|
-
if (!isDisabled) {
|
|
150
|
-
overlayState.toggle();
|
|
151
|
-
}
|
|
152
|
-
},
|
|
153
|
-
};
|
|
154
|
-
});
|
|
155
|
-
|
|
156
|
-
// Dialog props
|
|
157
|
-
const dialogProps = createMemo(() => ({
|
|
158
|
-
id: dialogId,
|
|
159
|
-
role: 'dialog',
|
|
160
|
-
'aria-modal': true,
|
|
161
|
-
'aria-label': 'Calendar',
|
|
162
|
-
}));
|
|
163
|
-
|
|
164
|
-
// Calendar props
|
|
165
|
-
const calendarProps = createMemo(() => ({
|
|
166
|
-
'aria-label': 'Calendar',
|
|
167
|
-
}));
|
|
168
|
-
|
|
169
|
-
// Description props
|
|
170
|
-
const descriptionProps = createMemo(() => ({
|
|
171
|
-
id: descriptionId,
|
|
172
|
-
}));
|
|
173
|
-
|
|
174
|
-
// Error message props
|
|
175
|
-
const errorMessageProps = createMemo(() => ({
|
|
176
|
-
id: errorMessageId,
|
|
177
|
-
role: 'alert',
|
|
178
|
-
}));
|
|
179
|
-
|
|
180
|
-
return {
|
|
181
|
-
get groupProps() {
|
|
182
|
-
return groupProps();
|
|
183
|
-
},
|
|
184
|
-
get labelProps() {
|
|
185
|
-
return labelProps as Record<string, unknown>;
|
|
186
|
-
},
|
|
187
|
-
get fieldProps() {
|
|
188
|
-
return fieldProps();
|
|
189
|
-
},
|
|
190
|
-
get buttonProps() {
|
|
191
|
-
return buttonProps();
|
|
192
|
-
},
|
|
193
|
-
get dialogProps() {
|
|
194
|
-
return dialogProps();
|
|
195
|
-
},
|
|
196
|
-
get calendarProps() {
|
|
197
|
-
return calendarProps();
|
|
198
|
-
},
|
|
199
|
-
get descriptionProps() {
|
|
200
|
-
return descriptionProps();
|
|
201
|
-
},
|
|
202
|
-
get errorMessageProps() {
|
|
203
|
-
return errorMessageProps();
|
|
204
|
-
},
|
|
205
|
-
};
|
|
206
|
-
}
|
|
@@ -1,229 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* createDateSegment hook for Solidaria
|
|
3
|
-
*
|
|
4
|
-
* Provides the behavior and accessibility implementation for a date segment.
|
|
5
|
-
* Based on @react-aria/datepicker useDateSegment
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import { createSignal, createMemo } from 'solid-js';
|
|
9
|
-
import { access, type MaybeAccessor } from '../utils/reactivity';
|
|
10
|
-
import type { DateFieldState, DateSegment, DateSegmentType } from '@proyecto-viviana/solid-stately';
|
|
11
|
-
|
|
12
|
-
// ============================================
|
|
13
|
-
// TYPES
|
|
14
|
-
// ============================================
|
|
15
|
-
|
|
16
|
-
export interface AriaDateSegmentProps {
|
|
17
|
-
/** The segment data. */
|
|
18
|
-
segment: DateSegment;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
export interface DateSegmentAria {
|
|
22
|
-
/** Props for the segment element. */
|
|
23
|
-
segmentProps: Record<string, unknown>;
|
|
24
|
-
/** Whether the segment is focused. */
|
|
25
|
-
isFocused: boolean;
|
|
26
|
-
/** Whether the segment is editable. */
|
|
27
|
-
isEditable: boolean;
|
|
28
|
-
/** Whether the segment is a placeholder. */
|
|
29
|
-
isPlaceholder: boolean;
|
|
30
|
-
/** The text to display. */
|
|
31
|
-
text: string;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
// ============================================
|
|
35
|
-
// IMPLEMENTATION
|
|
36
|
-
// ============================================
|
|
37
|
-
|
|
38
|
-
/**
|
|
39
|
-
* Provides the behavior and accessibility implementation for a date segment.
|
|
40
|
-
*/
|
|
41
|
-
export function createDateSegment<T extends DateFieldState>(
|
|
42
|
-
props: MaybeAccessor<AriaDateSegmentProps>,
|
|
43
|
-
state: T,
|
|
44
|
-
_ref?: () => HTMLElement | null
|
|
45
|
-
): DateSegmentAria {
|
|
46
|
-
const getProps = () => access(props);
|
|
47
|
-
const [isFocused, setIsFocused] = createSignal(false);
|
|
48
|
-
const [enteredKeys, setEnteredKeys] = createSignal('');
|
|
49
|
-
|
|
50
|
-
// Get the segment from props
|
|
51
|
-
const segment = createMemo(() => getProps().segment);
|
|
52
|
-
|
|
53
|
-
// Check if editable
|
|
54
|
-
const isEditable = createMemo(() => {
|
|
55
|
-
const seg = segment();
|
|
56
|
-
return seg.isEditable && !state.isDisabled() && !state.isReadOnly();
|
|
57
|
-
});
|
|
58
|
-
|
|
59
|
-
// Handle keyboard input
|
|
60
|
-
const handleKeyDown = (e: KeyboardEvent) => {
|
|
61
|
-
if (!isEditable()) return;
|
|
62
|
-
|
|
63
|
-
const seg = segment();
|
|
64
|
-
const type = seg.type;
|
|
65
|
-
|
|
66
|
-
if (type === 'literal') return;
|
|
67
|
-
|
|
68
|
-
switch (e.key) {
|
|
69
|
-
case 'ArrowUp':
|
|
70
|
-
e.preventDefault();
|
|
71
|
-
state.incrementSegment(type);
|
|
72
|
-
break;
|
|
73
|
-
case 'ArrowDown':
|
|
74
|
-
e.preventDefault();
|
|
75
|
-
state.decrementSegment(type);
|
|
76
|
-
break;
|
|
77
|
-
case 'Backspace':
|
|
78
|
-
case 'Delete':
|
|
79
|
-
e.preventDefault();
|
|
80
|
-
state.clearSegment(type);
|
|
81
|
-
setEnteredKeys('');
|
|
82
|
-
break;
|
|
83
|
-
default:
|
|
84
|
-
// Handle numeric input
|
|
85
|
-
if (/^\d$/.test(e.key)) {
|
|
86
|
-
e.preventDefault();
|
|
87
|
-
handleNumericInput(e.key, type, seg);
|
|
88
|
-
}
|
|
89
|
-
break;
|
|
90
|
-
}
|
|
91
|
-
};
|
|
92
|
-
|
|
93
|
-
// Handle numeric input
|
|
94
|
-
const handleNumericInput = (
|
|
95
|
-
key: string,
|
|
96
|
-
type: DateSegmentType,
|
|
97
|
-
seg: DateSegment
|
|
98
|
-
) => {
|
|
99
|
-
const newKeys = enteredKeys() + key;
|
|
100
|
-
const numValue = parseInt(newKeys, 10);
|
|
101
|
-
const maxValue = seg.maxValue ?? 99;
|
|
102
|
-
const minValue = seg.minValue ?? 0;
|
|
103
|
-
|
|
104
|
-
// Check if we should accept more digits
|
|
105
|
-
if (numValue <= maxValue) {
|
|
106
|
-
state.setSegment(type, numValue);
|
|
107
|
-
|
|
108
|
-
// If entering more digits wouldn't make sense, clear entered keys
|
|
109
|
-
const potentialNextValue = parseInt(newKeys + '0', 10);
|
|
110
|
-
if (potentialNextValue > maxValue || newKeys.length >= String(maxValue).length) {
|
|
111
|
-
setEnteredKeys('');
|
|
112
|
-
// Move to next segment (would need focus management)
|
|
113
|
-
} else {
|
|
114
|
-
setEnteredKeys(newKeys);
|
|
115
|
-
}
|
|
116
|
-
} else {
|
|
117
|
-
// Start fresh with just this key
|
|
118
|
-
const singleValue = parseInt(key, 10);
|
|
119
|
-
if (singleValue >= minValue && singleValue <= maxValue) {
|
|
120
|
-
state.setSegment(type, singleValue);
|
|
121
|
-
}
|
|
122
|
-
setEnteredKeys(key);
|
|
123
|
-
}
|
|
124
|
-
};
|
|
125
|
-
|
|
126
|
-
// Handle focus
|
|
127
|
-
const handleFocus = () => {
|
|
128
|
-
setIsFocused(true);
|
|
129
|
-
setEnteredKeys('');
|
|
130
|
-
};
|
|
131
|
-
|
|
132
|
-
const handleBlur = () => {
|
|
133
|
-
setIsFocused(false);
|
|
134
|
-
setEnteredKeys('');
|
|
135
|
-
state.confirmPlaceholder();
|
|
136
|
-
};
|
|
137
|
-
|
|
138
|
-
// Segment props
|
|
139
|
-
const segmentProps = createMemo(() => {
|
|
140
|
-
const seg = segment();
|
|
141
|
-
const type = seg.type;
|
|
142
|
-
|
|
143
|
-
// Literal segments don't need interaction props
|
|
144
|
-
if (type === 'literal') {
|
|
145
|
-
return {
|
|
146
|
-
'aria-hidden': true,
|
|
147
|
-
};
|
|
148
|
-
}
|
|
149
|
-
|
|
150
|
-
return {
|
|
151
|
-
role: 'spinbutton',
|
|
152
|
-
tabIndex: isEditable() ? 0 : -1,
|
|
153
|
-
'aria-label': getSegmentLabel(type),
|
|
154
|
-
'aria-valuenow': seg.value,
|
|
155
|
-
'aria-valuemin': seg.minValue,
|
|
156
|
-
'aria-valuemax': seg.maxValue,
|
|
157
|
-
'aria-valuetext': seg.isPlaceholder ? seg.placeholder : seg.text,
|
|
158
|
-
'aria-readonly': state.isReadOnly() || undefined,
|
|
159
|
-
'aria-disabled': state.isDisabled() || undefined,
|
|
160
|
-
'aria-invalid': state.isInvalid() || undefined,
|
|
161
|
-
contentEditable: isEditable(),
|
|
162
|
-
suppressContentEditableWarning: true,
|
|
163
|
-
inputMode: 'numeric' as const,
|
|
164
|
-
autoCorrect: 'off',
|
|
165
|
-
enterKeyHint: 'next' as const,
|
|
166
|
-
spellCheck: false,
|
|
167
|
-
onKeyDown: handleKeyDown,
|
|
168
|
-
onFocus: handleFocus,
|
|
169
|
-
onBlur: handleBlur,
|
|
170
|
-
onMouseDown: (e: MouseEvent) => {
|
|
171
|
-
// Prevent cursor positioning in the middle of the segment
|
|
172
|
-
e.preventDefault();
|
|
173
|
-
},
|
|
174
|
-
};
|
|
175
|
-
});
|
|
176
|
-
|
|
177
|
-
// Text to display
|
|
178
|
-
const text = createMemo(() => {
|
|
179
|
-
const seg = segment();
|
|
180
|
-
return seg.isPlaceholder ? seg.placeholder : seg.text;
|
|
181
|
-
});
|
|
182
|
-
|
|
183
|
-
return {
|
|
184
|
-
get segmentProps() {
|
|
185
|
-
return segmentProps();
|
|
186
|
-
},
|
|
187
|
-
get isFocused() {
|
|
188
|
-
return isFocused();
|
|
189
|
-
},
|
|
190
|
-
get isEditable() {
|
|
191
|
-
return isEditable();
|
|
192
|
-
},
|
|
193
|
-
get isPlaceholder() {
|
|
194
|
-
return segment().isPlaceholder;
|
|
195
|
-
},
|
|
196
|
-
get text() {
|
|
197
|
-
return text();
|
|
198
|
-
},
|
|
199
|
-
};
|
|
200
|
-
}
|
|
201
|
-
|
|
202
|
-
// ============================================
|
|
203
|
-
// HELPER FUNCTIONS
|
|
204
|
-
// ============================================
|
|
205
|
-
|
|
206
|
-
function getSegmentLabel(type: DateSegmentType): string {
|
|
207
|
-
switch (type) {
|
|
208
|
-
case 'year':
|
|
209
|
-
return 'Year';
|
|
210
|
-
case 'month':
|
|
211
|
-
return 'Month';
|
|
212
|
-
case 'day':
|
|
213
|
-
return 'Day';
|
|
214
|
-
case 'hour':
|
|
215
|
-
return 'Hour';
|
|
216
|
-
case 'minute':
|
|
217
|
-
return 'Minute';
|
|
218
|
-
case 'second':
|
|
219
|
-
return 'Second';
|
|
220
|
-
case 'dayPeriod':
|
|
221
|
-
return 'AM/PM';
|
|
222
|
-
case 'era':
|
|
223
|
-
return 'Era';
|
|
224
|
-
case 'timeZoneName':
|
|
225
|
-
return 'Time zone';
|
|
226
|
-
default:
|
|
227
|
-
return '';
|
|
228
|
-
}
|
|
229
|
-
}
|