@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,186 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Provides the behavior and accessibility implementation for a search field.
|
|
3
|
-
* A search field allows a user to enter and clear a search query.
|
|
4
|
-
* Based on @react-aria/searchfield useSearchField.
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import { type JSX } from 'solid-js';
|
|
8
|
-
import { createTextField, type AriaTextFieldProps, type TextFieldAria } from '../textfield';
|
|
9
|
-
import { mergeProps } from '../utils';
|
|
10
|
-
import { type MaybeAccessor, access } from '../utils/reactivity';
|
|
11
|
-
import type { SearchFieldState } from '@proyecto-viviana/solid-stately';
|
|
12
|
-
|
|
13
|
-
export interface AriaSearchFieldProps extends Omit<AriaTextFieldProps, 'type'> {
|
|
14
|
-
/** Handler that is called when the user submits the search (pressing Enter). */
|
|
15
|
-
onSubmit?: (value: string) => void;
|
|
16
|
-
/** Handler that is called when the clear button is pressed or Escape clears the field. */
|
|
17
|
-
onClear?: () => void;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
export interface SearchFieldAria extends Omit<TextFieldAria, 'inputProps'> {
|
|
21
|
-
/** Props for the input element. */
|
|
22
|
-
inputProps: JSX.InputHTMLAttributes<HTMLInputElement>;
|
|
23
|
-
/** Props for the clear button. */
|
|
24
|
-
clearButtonProps: {
|
|
25
|
-
'aria-label': string;
|
|
26
|
-
tabIndex: number;
|
|
27
|
-
disabled?: boolean;
|
|
28
|
-
onMouseDown: (e: MouseEvent) => void;
|
|
29
|
-
onClick: () => void;
|
|
30
|
-
};
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
/**
|
|
34
|
-
* Provides the behavior and accessibility implementation for a search field.
|
|
35
|
-
*/
|
|
36
|
-
export function createSearchField(
|
|
37
|
-
props: MaybeAccessor<AriaSearchFieldProps>,
|
|
38
|
-
state: SearchFieldState,
|
|
39
|
-
inputRef?: () => HTMLInputElement | null
|
|
40
|
-
): SearchFieldAria {
|
|
41
|
-
const getProps = () => access(props);
|
|
42
|
-
|
|
43
|
-
// Use createTextField for the base implementation
|
|
44
|
-
const textFieldAria = createTextField({
|
|
45
|
-
get value() {
|
|
46
|
-
return state.value();
|
|
47
|
-
},
|
|
48
|
-
get isDisabled() {
|
|
49
|
-
return getProps().isDisabled;
|
|
50
|
-
},
|
|
51
|
-
get isReadOnly() {
|
|
52
|
-
return getProps().isReadOnly;
|
|
53
|
-
},
|
|
54
|
-
get isRequired() {
|
|
55
|
-
return getProps().isRequired;
|
|
56
|
-
},
|
|
57
|
-
get isInvalid() {
|
|
58
|
-
return getProps().isInvalid;
|
|
59
|
-
},
|
|
60
|
-
get label() {
|
|
61
|
-
return getProps().label;
|
|
62
|
-
},
|
|
63
|
-
get 'aria-label'() {
|
|
64
|
-
return getProps()['aria-label'];
|
|
65
|
-
},
|
|
66
|
-
get 'aria-labelledby'() {
|
|
67
|
-
return getProps()['aria-labelledby'];
|
|
68
|
-
},
|
|
69
|
-
get 'aria-describedby'() {
|
|
70
|
-
return getProps()['aria-describedby'];
|
|
71
|
-
},
|
|
72
|
-
get description() {
|
|
73
|
-
return getProps().description;
|
|
74
|
-
},
|
|
75
|
-
get errorMessage() {
|
|
76
|
-
return getProps().errorMessage;
|
|
77
|
-
},
|
|
78
|
-
get placeholder() {
|
|
79
|
-
return getProps().placeholder;
|
|
80
|
-
},
|
|
81
|
-
get name() {
|
|
82
|
-
return getProps().name;
|
|
83
|
-
},
|
|
84
|
-
get autoFocus() {
|
|
85
|
-
return getProps().autoFocus;
|
|
86
|
-
},
|
|
87
|
-
get autoComplete() {
|
|
88
|
-
return getProps().autoComplete;
|
|
89
|
-
},
|
|
90
|
-
get maxLength() {
|
|
91
|
-
return getProps().maxLength;
|
|
92
|
-
},
|
|
93
|
-
get minLength() {
|
|
94
|
-
return getProps().minLength;
|
|
95
|
-
},
|
|
96
|
-
get pattern() {
|
|
97
|
-
return getProps().pattern;
|
|
98
|
-
},
|
|
99
|
-
type: 'search',
|
|
100
|
-
onChange: (value: string) => {
|
|
101
|
-
state.setValue(value);
|
|
102
|
-
getProps().onChange?.(value);
|
|
103
|
-
},
|
|
104
|
-
});
|
|
105
|
-
|
|
106
|
-
// Handle keyboard events for search field
|
|
107
|
-
const onKeyDown: JSX.EventHandler<HTMLInputElement, KeyboardEvent> = (e) => {
|
|
108
|
-
const p = getProps();
|
|
109
|
-
|
|
110
|
-
if (p.isDisabled || p.isReadOnly) {
|
|
111
|
-
if (e.key === 'Enter') {
|
|
112
|
-
e.preventDefault();
|
|
113
|
-
}
|
|
114
|
-
return;
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
if (e.key === 'Enter' && p.onSubmit) {
|
|
118
|
-
e.preventDefault();
|
|
119
|
-
p.onSubmit(state.value());
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
if (e.key === 'Escape') {
|
|
123
|
-
const currentValue = state.value();
|
|
124
|
-
const inputValue = inputRef?.()?.value ?? '';
|
|
125
|
-
|
|
126
|
-
// Only clear if there's a value
|
|
127
|
-
if (currentValue !== '' || inputValue !== '') {
|
|
128
|
-
e.preventDefault();
|
|
129
|
-
e.stopPropagation();
|
|
130
|
-
state.setValue('');
|
|
131
|
-
p.onClear?.();
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
};
|
|
135
|
-
|
|
136
|
-
// Handle clear button click
|
|
137
|
-
const onClearButtonClick = () => {
|
|
138
|
-
const p = getProps();
|
|
139
|
-
state.setValue('');
|
|
140
|
-
p.onClear?.();
|
|
141
|
-
// Focus the input after clearing
|
|
142
|
-
inputRef?.()?.focus();
|
|
143
|
-
};
|
|
144
|
-
|
|
145
|
-
// Prevent focus from leaving input on mobile when clicking clear button
|
|
146
|
-
const onClearButtonMouseDown = (e: MouseEvent) => {
|
|
147
|
-
e.preventDefault();
|
|
148
|
-
};
|
|
149
|
-
|
|
150
|
-
return {
|
|
151
|
-
get labelProps() {
|
|
152
|
-
return textFieldAria.labelProps;
|
|
153
|
-
},
|
|
154
|
-
get inputProps() {
|
|
155
|
-
return mergeProps(
|
|
156
|
-
textFieldAria.inputProps as Record<string, unknown>,
|
|
157
|
-
{
|
|
158
|
-
onKeyDown,
|
|
159
|
-
// Clear defaultValue since it's handled by state
|
|
160
|
-
defaultValue: undefined,
|
|
161
|
-
} as Record<string, unknown>
|
|
162
|
-
) as JSX.InputHTMLAttributes<HTMLInputElement>;
|
|
163
|
-
},
|
|
164
|
-
get clearButtonProps() {
|
|
165
|
-
const p = getProps();
|
|
166
|
-
const isDisabled = p.isDisabled || p.isReadOnly;
|
|
167
|
-
|
|
168
|
-
return {
|
|
169
|
-
'aria-label': 'Clear search',
|
|
170
|
-
tabIndex: -1, // Exclude from tab order
|
|
171
|
-
disabled: isDisabled,
|
|
172
|
-
onMouseDown: onClearButtonMouseDown,
|
|
173
|
-
onClick: onClearButtonClick,
|
|
174
|
-
};
|
|
175
|
-
},
|
|
176
|
-
get descriptionProps() {
|
|
177
|
-
return textFieldAria.descriptionProps;
|
|
178
|
-
},
|
|
179
|
-
get errorMessageProps() {
|
|
180
|
-
return textFieldAria.errorMessageProps;
|
|
181
|
-
},
|
|
182
|
-
get isInvalid() {
|
|
183
|
-
return textFieldAria.isInvalid;
|
|
184
|
-
},
|
|
185
|
-
};
|
|
186
|
-
}
|
package/src/searchfield/index.ts
DELETED
|
@@ -1,236 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Provides a hidden native select element for form integration.
|
|
3
|
-
* Based on @react-aria/select useHiddenSelect.
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
import { type JSX, type Accessor, For, createEffect, onCleanup } from 'solid-js';
|
|
7
|
-
import { access, type MaybeAccessor } from '../utils/reactivity';
|
|
8
|
-
import { createFormReset } from '../form/createFormReset';
|
|
9
|
-
import { createFormValidation } from '../form/createFormValidation';
|
|
10
|
-
import type { SelectState, Key, FormValidationState } from '@proyecto-viviana/solid-stately';
|
|
11
|
-
|
|
12
|
-
export type ValidationBehavior = 'aria' | 'native';
|
|
13
|
-
|
|
14
|
-
export interface AriaHiddenSelectProps<T> {
|
|
15
|
-
/** The state object for the select. */
|
|
16
|
-
state: SelectState<T>;
|
|
17
|
-
/** The name attribute for the hidden select. */
|
|
18
|
-
name?: string;
|
|
19
|
-
/** Whether the select is disabled. */
|
|
20
|
-
isDisabled?: boolean;
|
|
21
|
-
/** Whether the select is required. */
|
|
22
|
-
isRequired?: boolean;
|
|
23
|
-
/** Describes the type of autocomplete functionality the select should provide. */
|
|
24
|
-
autoComplete?: string;
|
|
25
|
-
/** The `form` attribute to associate the select with a form by ID. */
|
|
26
|
-
form?: string;
|
|
27
|
-
/** Validation behavior: 'aria' for realtime, 'native' for on submit. */
|
|
28
|
-
validationBehavior?: ValidationBehavior;
|
|
29
|
-
/** A ref to the trigger element for focus on validation error. */
|
|
30
|
-
triggerRef?: Accessor<HTMLElement | null>;
|
|
31
|
-
/** Form validation state (optional, for native validation). */
|
|
32
|
-
validationState?: FormValidationState;
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
export interface HiddenSelectAria {
|
|
36
|
-
/** Props for the container element. */
|
|
37
|
-
containerProps: JSX.HTMLAttributes<HTMLDivElement>;
|
|
38
|
-
/** Props for the hidden select element. */
|
|
39
|
-
selectProps: JSX.SelectHTMLAttributes<HTMLSelectElement>;
|
|
40
|
-
/** Props for the hidden input element (for form submission). */
|
|
41
|
-
inputProps: JSX.InputHTMLAttributes<HTMLInputElement>;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
/**
|
|
45
|
-
* Provides the accessibility implementation for a hidden select.
|
|
46
|
-
* This is used for native form submission and accessibility on mobile devices.
|
|
47
|
-
*/
|
|
48
|
-
export function createHiddenSelect<T>(
|
|
49
|
-
props: MaybeAccessor<AriaHiddenSelectProps<T>>
|
|
50
|
-
): HiddenSelectAria {
|
|
51
|
-
const getProps = () => access(props);
|
|
52
|
-
|
|
53
|
-
// Track the select element for form reset/validation
|
|
54
|
-
let selectRef: HTMLSelectElement | undefined;
|
|
55
|
-
|
|
56
|
-
// Set up form reset handler
|
|
57
|
-
createEffect(() => {
|
|
58
|
-
const p = getProps();
|
|
59
|
-
if (!selectRef) return;
|
|
60
|
-
|
|
61
|
-
const form = selectRef.form;
|
|
62
|
-
if (!form) return;
|
|
63
|
-
|
|
64
|
-
const handleReset = () => {
|
|
65
|
-
// Reset to default selected key (first key or null)
|
|
66
|
-
const defaultKey = p.state.collection().getFirstKey();
|
|
67
|
-
p.state.setSelectedKey(defaultKey);
|
|
68
|
-
};
|
|
69
|
-
|
|
70
|
-
form.addEventListener('reset', handleReset);
|
|
71
|
-
|
|
72
|
-
onCleanup(() => {
|
|
73
|
-
form.removeEventListener('reset', handleReset);
|
|
74
|
-
});
|
|
75
|
-
});
|
|
76
|
-
|
|
77
|
-
// Set up form validation handler for native validation
|
|
78
|
-
createEffect(() => {
|
|
79
|
-
const p = getProps();
|
|
80
|
-
if (!selectRef || p.validationBehavior !== 'native' || !p.validationState) return;
|
|
81
|
-
|
|
82
|
-
createFormValidation(
|
|
83
|
-
{
|
|
84
|
-
validationBehavior: p.validationBehavior,
|
|
85
|
-
focus: () => p.triggerRef?.()?.focus(),
|
|
86
|
-
},
|
|
87
|
-
p.validationState,
|
|
88
|
-
() => selectRef
|
|
89
|
-
);
|
|
90
|
-
});
|
|
91
|
-
|
|
92
|
-
return {
|
|
93
|
-
get containerProps() {
|
|
94
|
-
return {
|
|
95
|
-
'aria-hidden': true,
|
|
96
|
-
'data-a11y-ignore': 'aria-hidden-focus',
|
|
97
|
-
} as JSX.HTMLAttributes<HTMLDivElement>;
|
|
98
|
-
},
|
|
99
|
-
get selectProps() {
|
|
100
|
-
const p = getProps();
|
|
101
|
-
const state = p.state;
|
|
102
|
-
const selectedKey = state.selectedKey();
|
|
103
|
-
const validationBehavior = p.validationBehavior ?? 'aria';
|
|
104
|
-
|
|
105
|
-
return {
|
|
106
|
-
ref: (el: HTMLSelectElement) => { selectRef = el; },
|
|
107
|
-
tabIndex: -1,
|
|
108
|
-
autoComplete: p.autoComplete,
|
|
109
|
-
disabled: p.isDisabled ?? state.isDisabled,
|
|
110
|
-
name: p.name,
|
|
111
|
-
form: p.form,
|
|
112
|
-
// Add required attribute for native form validation
|
|
113
|
-
required: validationBehavior === 'native' && p.isRequired,
|
|
114
|
-
value: selectedKey != null ? String(selectedKey) : '',
|
|
115
|
-
onChange: (e: Event) => {
|
|
116
|
-
const target = e.target as HTMLSelectElement;
|
|
117
|
-
state.setSelectedKey(target.value as Key);
|
|
118
|
-
},
|
|
119
|
-
style: {
|
|
120
|
-
position: 'absolute',
|
|
121
|
-
top: 0,
|
|
122
|
-
left: 0,
|
|
123
|
-
width: '100%',
|
|
124
|
-
height: '100%',
|
|
125
|
-
opacity: 0,
|
|
126
|
-
'font-size': '16px', // Prevents zoom on iOS
|
|
127
|
-
border: 'none',
|
|
128
|
-
cursor: 'default',
|
|
129
|
-
margin: 0,
|
|
130
|
-
padding: 0,
|
|
131
|
-
'pointer-events': 'none',
|
|
132
|
-
},
|
|
133
|
-
} as JSX.SelectHTMLAttributes<HTMLSelectElement>;
|
|
134
|
-
},
|
|
135
|
-
get inputProps() {
|
|
136
|
-
const p = getProps();
|
|
137
|
-
const state = p.state;
|
|
138
|
-
const selectedKey = state.selectedKey();
|
|
139
|
-
const validationBehavior = p.validationBehavior ?? 'aria';
|
|
140
|
-
|
|
141
|
-
// For native validation with required, use type="text" with display:none
|
|
142
|
-
// so the browser will validate it on form submit
|
|
143
|
-
const useTextInput = validationBehavior === 'native' && p.isRequired;
|
|
144
|
-
|
|
145
|
-
return {
|
|
146
|
-
type: useTextInput ? 'text' : 'hidden',
|
|
147
|
-
name: p.name,
|
|
148
|
-
form: p.form,
|
|
149
|
-
value: selectedKey != null ? String(selectedKey) : '',
|
|
150
|
-
disabled: p.isDisabled ?? state.isDisabled,
|
|
151
|
-
required: useTextInput ? p.isRequired : undefined,
|
|
152
|
-
style: useTextInput ? { display: 'none' } : undefined,
|
|
153
|
-
} as JSX.InputHTMLAttributes<HTMLInputElement>;
|
|
154
|
-
},
|
|
155
|
-
};
|
|
156
|
-
}
|
|
157
|
-
|
|
158
|
-
export interface HiddenSelectProps<T> {
|
|
159
|
-
/** The state object for the select. */
|
|
160
|
-
state: SelectState<T>;
|
|
161
|
-
/** The name attribute for the hidden select. */
|
|
162
|
-
name?: string;
|
|
163
|
-
/** Whether the select is disabled. */
|
|
164
|
-
isDisabled?: boolean;
|
|
165
|
-
/** Whether the select is required. */
|
|
166
|
-
isRequired?: boolean;
|
|
167
|
-
/** A ref to the trigger element. */
|
|
168
|
-
triggerRef?: () => HTMLElement | null;
|
|
169
|
-
/** Label for the select. */
|
|
170
|
-
label?: string;
|
|
171
|
-
/** Describes the type of autocomplete functionality the select should provide. */
|
|
172
|
-
autoComplete?: string;
|
|
173
|
-
/** The `form` attribute to associate the select with a form by ID. */
|
|
174
|
-
form?: string;
|
|
175
|
-
/** Validation behavior: 'aria' for realtime, 'native' for on submit. */
|
|
176
|
-
validationBehavior?: ValidationBehavior;
|
|
177
|
-
/** Form validation state (optional, for native validation). */
|
|
178
|
-
validationState?: FormValidationState;
|
|
179
|
-
}
|
|
180
|
-
|
|
181
|
-
/**
|
|
182
|
-
* A component that renders a hidden native select for form submission.
|
|
183
|
-
* This is useful on mobile devices where native select behavior is preferred.
|
|
184
|
-
*/
|
|
185
|
-
export function HiddenSelect<T>(props: HiddenSelectProps<T>): JSX.Element {
|
|
186
|
-
const { containerProps, selectProps } = createHiddenSelect({
|
|
187
|
-
get state() {
|
|
188
|
-
return props.state;
|
|
189
|
-
},
|
|
190
|
-
get name() {
|
|
191
|
-
return props.name;
|
|
192
|
-
},
|
|
193
|
-
get isDisabled() {
|
|
194
|
-
return props.isDisabled;
|
|
195
|
-
},
|
|
196
|
-
get isRequired() {
|
|
197
|
-
return props.isRequired;
|
|
198
|
-
},
|
|
199
|
-
get autoComplete() {
|
|
200
|
-
return props.autoComplete;
|
|
201
|
-
},
|
|
202
|
-
get form() {
|
|
203
|
-
return props.form;
|
|
204
|
-
},
|
|
205
|
-
get validationBehavior() {
|
|
206
|
-
return props.validationBehavior;
|
|
207
|
-
},
|
|
208
|
-
get triggerRef() {
|
|
209
|
-
return props.triggerRef;
|
|
210
|
-
},
|
|
211
|
-
get validationState() {
|
|
212
|
-
return props.validationState;
|
|
213
|
-
},
|
|
214
|
-
});
|
|
215
|
-
|
|
216
|
-
const collection = () => props.state.collection();
|
|
217
|
-
const selectedKey = () => props.state.selectedKey();
|
|
218
|
-
|
|
219
|
-
return (
|
|
220
|
-
<div {...containerProps}>
|
|
221
|
-
<label>
|
|
222
|
-
{props.label}
|
|
223
|
-
<select {...selectProps}>
|
|
224
|
-
<option />
|
|
225
|
-
<For each={Array.from(collection())}>
|
|
226
|
-
{(item) => (
|
|
227
|
-
<option value={String(item.key)} selected={item.key === selectedKey()}>
|
|
228
|
-
{item.textValue}
|
|
229
|
-
</option>
|
|
230
|
-
)}
|
|
231
|
-
</For>
|
|
232
|
-
</select>
|
|
233
|
-
</label>
|
|
234
|
-
</div>
|
|
235
|
-
);
|
|
236
|
-
}
|