@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.
Files changed (580) hide show
  1. package/dist/index.d.ts +6135 -50
  2. package/dist/index.js +485 -1120
  3. package/dist/{index.ssr.js → index.jsx} +89 -143
  4. package/package.json +7 -9
  5. package/dist/autocomplete/createAutocomplete.d.ts +0 -109
  6. package/dist/autocomplete/createAutocomplete.d.ts.map +0 -1
  7. package/dist/autocomplete/index.d.ts +0 -2
  8. package/dist/autocomplete/index.d.ts.map +0 -1
  9. package/dist/breadcrumbs/createBreadcrumbs.d.ts +0 -43
  10. package/dist/breadcrumbs/createBreadcrumbs.d.ts.map +0 -1
  11. package/dist/breadcrumbs/index.d.ts +0 -2
  12. package/dist/breadcrumbs/index.d.ts.map +0 -1
  13. package/dist/button/createButton.d.ts +0 -29
  14. package/dist/button/createButton.d.ts.map +0 -1
  15. package/dist/button/createToggleButton.d.ts +0 -41
  16. package/dist/button/createToggleButton.d.ts.map +0 -1
  17. package/dist/button/index.d.ts +0 -5
  18. package/dist/button/index.d.ts.map +0 -1
  19. package/dist/button/types.d.ts +0 -77
  20. package/dist/button/types.d.ts.map +0 -1
  21. package/dist/calendar/createCalendar.d.ts +0 -41
  22. package/dist/calendar/createCalendar.d.ts.map +0 -1
  23. package/dist/calendar/createCalendarCell.d.ts +0 -41
  24. package/dist/calendar/createCalendarCell.d.ts.map +0 -1
  25. package/dist/calendar/createCalendarGrid.d.ts +0 -29
  26. package/dist/calendar/createCalendarGrid.d.ts.map +0 -1
  27. package/dist/calendar/createRangeCalendar.d.ts +0 -39
  28. package/dist/calendar/createRangeCalendar.d.ts.map +0 -1
  29. package/dist/calendar/createRangeCalendarCell.d.ts +0 -45
  30. package/dist/calendar/createRangeCalendarCell.d.ts.map +0 -1
  31. package/dist/calendar/index.d.ts +0 -6
  32. package/dist/calendar/index.d.ts.map +0 -1
  33. package/dist/checkbox/createCheckbox.d.ts +0 -56
  34. package/dist/checkbox/createCheckbox.d.ts.map +0 -1
  35. package/dist/checkbox/createCheckboxGroup.d.ts +0 -53
  36. package/dist/checkbox/createCheckboxGroup.d.ts.map +0 -1
  37. package/dist/checkbox/createCheckboxGroupItem.d.ts +0 -25
  38. package/dist/checkbox/createCheckboxGroupItem.d.ts.map +0 -1
  39. package/dist/checkbox/createCheckboxGroupState.d.ts +0 -71
  40. package/dist/checkbox/createCheckboxGroupState.d.ts.map +0 -1
  41. package/dist/checkbox/index.d.ts +0 -9
  42. package/dist/checkbox/index.d.ts.map +0 -1
  43. package/dist/color/createColorArea.d.ts +0 -13
  44. package/dist/color/createColorArea.d.ts.map +0 -1
  45. package/dist/color/createColorField.d.ts +0 -13
  46. package/dist/color/createColorField.d.ts.map +0 -1
  47. package/dist/color/createColorSlider.d.ts +0 -13
  48. package/dist/color/createColorSlider.d.ts.map +0 -1
  49. package/dist/color/createColorSwatch.d.ts +0 -12
  50. package/dist/color/createColorSwatch.d.ts.map +0 -1
  51. package/dist/color/createColorWheel.d.ts +0 -13
  52. package/dist/color/createColorWheel.d.ts.map +0 -1
  53. package/dist/color/index.d.ts +0 -10
  54. package/dist/color/index.d.ts.map +0 -1
  55. package/dist/color/types.d.ts +0 -106
  56. package/dist/color/types.d.ts.map +0 -1
  57. package/dist/combobox/createComboBox.d.ts +0 -77
  58. package/dist/combobox/createComboBox.d.ts.map +0 -1
  59. package/dist/combobox/index.d.ts +0 -2
  60. package/dist/combobox/index.d.ts.map +0 -1
  61. package/dist/combobox/intl/index.d.ts +0 -14
  62. package/dist/combobox/intl/index.d.ts.map +0 -1
  63. package/dist/datepicker/createDateField.d.ts +0 -51
  64. package/dist/datepicker/createDateField.d.ts.map +0 -1
  65. package/dist/datepicker/createDatePicker.d.ts +0 -65
  66. package/dist/datepicker/createDatePicker.d.ts.map +0 -1
  67. package/dist/datepicker/createDateSegment.d.ts +0 -29
  68. package/dist/datepicker/createDateSegment.d.ts.map +0 -1
  69. package/dist/datepicker/createTimeField.d.ts +0 -51
  70. package/dist/datepicker/createTimeField.d.ts.map +0 -1
  71. package/dist/datepicker/index.d.ts +0 -5
  72. package/dist/datepicker/index.d.ts.map +0 -1
  73. package/dist/dialog/createDialog.d.ts +0 -25
  74. package/dist/dialog/createDialog.d.ts.map +0 -1
  75. package/dist/dialog/index.d.ts +0 -3
  76. package/dist/dialog/index.d.ts.map +0 -1
  77. package/dist/dialog/types.d.ts +0 -18
  78. package/dist/dialog/types.d.ts.map +0 -1
  79. package/dist/disclosure/createDisclosure.d.ts +0 -52
  80. package/dist/disclosure/createDisclosure.d.ts.map +0 -1
  81. package/dist/disclosure/createDisclosureGroup.d.ts +0 -39
  82. package/dist/disclosure/createDisclosureGroup.d.ts.map +0 -1
  83. package/dist/disclosure/index.d.ts +0 -3
  84. package/dist/disclosure/index.d.ts.map +0 -1
  85. package/dist/dnd/createDrag.d.ts +0 -16
  86. package/dist/dnd/createDrag.d.ts.map +0 -1
  87. package/dist/dnd/createDraggableCollection.d.ts +0 -27
  88. package/dist/dnd/createDraggableCollection.d.ts.map +0 -1
  89. package/dist/dnd/createDraggableItem.d.ts +0 -37
  90. package/dist/dnd/createDraggableItem.d.ts.map +0 -1
  91. package/dist/dnd/createDrop.d.ts +0 -16
  92. package/dist/dnd/createDrop.d.ts.map +0 -1
  93. package/dist/dnd/createDroppableCollection.d.ts +0 -76
  94. package/dist/dnd/createDroppableCollection.d.ts.map +0 -1
  95. package/dist/dnd/createDroppableItem.d.ts +0 -31
  96. package/dist/dnd/createDroppableItem.d.ts.map +0 -1
  97. package/dist/dnd/index.d.ts +0 -18
  98. package/dist/dnd/index.d.ts.map +0 -1
  99. package/dist/dnd/types.d.ts +0 -66
  100. package/dist/dnd/types.d.ts.map +0 -1
  101. package/dist/dnd/utils.d.ts +0 -57
  102. package/dist/dnd/utils.d.ts.map +0 -1
  103. package/dist/focus/FocusScope.d.ts +0 -57
  104. package/dist/focus/FocusScope.d.ts.map +0 -1
  105. package/dist/focus/createAutoFocus.d.ts +0 -120
  106. package/dist/focus/createAutoFocus.d.ts.map +0 -1
  107. package/dist/focus/createFocusRestore.d.ts +0 -116
  108. package/dist/focus/createFocusRestore.d.ts.map +0 -1
  109. package/dist/focus/createVirtualFocus.d.ts +0 -170
  110. package/dist/focus/createVirtualFocus.d.ts.map +0 -1
  111. package/dist/focus/index.d.ts +0 -5
  112. package/dist/focus/index.d.ts.map +0 -1
  113. package/dist/form/createFormReset.d.ts +0 -27
  114. package/dist/form/createFormReset.d.ts.map +0 -1
  115. package/dist/form/createFormValidation.d.ts +0 -56
  116. package/dist/form/createFormValidation.d.ts.map +0 -1
  117. package/dist/form/index.d.ts +0 -3
  118. package/dist/form/index.d.ts.map +0 -1
  119. package/dist/grid/GridKeyboardDelegate.d.ts +0 -79
  120. package/dist/grid/GridKeyboardDelegate.d.ts.map +0 -1
  121. package/dist/grid/createGrid.d.ts +0 -24
  122. package/dist/grid/createGrid.d.ts.map +0 -1
  123. package/dist/grid/createGridCell.d.ts +0 -12
  124. package/dist/grid/createGridCell.d.ts.map +0 -1
  125. package/dist/grid/createGridRow.d.ts +0 -12
  126. package/dist/grid/createGridRow.d.ts.map +0 -1
  127. package/dist/grid/index.d.ts +0 -10
  128. package/dist/grid/index.d.ts.map +0 -1
  129. package/dist/grid/types.d.ts +0 -126
  130. package/dist/grid/types.d.ts.map +0 -1
  131. package/dist/gridlist/createGridList.d.ts +0 -28
  132. package/dist/gridlist/createGridList.d.ts.map +0 -1
  133. package/dist/gridlist/createGridListItem.d.ts +0 -12
  134. package/dist/gridlist/createGridListItem.d.ts.map +0 -1
  135. package/dist/gridlist/createGridListSelectionCheckbox.d.ts +0 -12
  136. package/dist/gridlist/createGridListSelectionCheckbox.d.ts.map +0 -1
  137. package/dist/gridlist/index.d.ts +0 -8
  138. package/dist/gridlist/index.d.ts.map +0 -1
  139. package/dist/gridlist/types.d.ts +0 -75
  140. package/dist/gridlist/types.d.ts.map +0 -1
  141. package/dist/i18n/NumberFormatter.d.ts +0 -43
  142. package/dist/i18n/NumberFormatter.d.ts.map +0 -1
  143. package/dist/i18n/createCollator.d.ts +0 -41
  144. package/dist/i18n/createCollator.d.ts.map +0 -1
  145. package/dist/i18n/createDateFormatter.d.ts +0 -45
  146. package/dist/i18n/createDateFormatter.d.ts.map +0 -1
  147. package/dist/i18n/createFilter.d.ts +0 -57
  148. package/dist/i18n/createFilter.d.ts.map +0 -1
  149. package/dist/i18n/createNumberFormatter.d.ts +0 -43
  150. package/dist/i18n/createNumberFormatter.d.ts.map +0 -1
  151. package/dist/i18n/createStringFormatter.d.ts +0 -42
  152. package/dist/i18n/createStringFormatter.d.ts.map +0 -1
  153. package/dist/i18n/index.d.ts +0 -9
  154. package/dist/i18n/index.d.ts.map +0 -1
  155. package/dist/i18n/locale.d.ts +0 -66
  156. package/dist/i18n/locale.d.ts.map +0 -1
  157. package/dist/i18n/utils.d.ts +0 -17
  158. package/dist/i18n/utils.d.ts.map +0 -1
  159. package/dist/index.d.ts.map +0 -1
  160. package/dist/index.js.map +0 -7
  161. package/dist/index.ssr.js.map +0 -7
  162. package/dist/interactions/FocusableProvider.d.ts +0 -26
  163. package/dist/interactions/FocusableProvider.d.ts.map +0 -1
  164. package/dist/interactions/PressEvent.d.ts +0 -73
  165. package/dist/interactions/PressEvent.d.ts.map +0 -1
  166. package/dist/interactions/createFocus.d.ts +0 -31
  167. package/dist/interactions/createFocus.d.ts.map +0 -1
  168. package/dist/interactions/createFocusRing.d.ts +0 -37
  169. package/dist/interactions/createFocusRing.d.ts.map +0 -1
  170. package/dist/interactions/createFocusWithin.d.ts +0 -27
  171. package/dist/interactions/createFocusWithin.d.ts.map +0 -1
  172. package/dist/interactions/createFocusable.d.ts +0 -65
  173. package/dist/interactions/createFocusable.d.ts.map +0 -1
  174. package/dist/interactions/createHover.d.ts +0 -43
  175. package/dist/interactions/createHover.d.ts.map +0 -1
  176. package/dist/interactions/createInteractionModality.d.ts +0 -73
  177. package/dist/interactions/createInteractionModality.d.ts.map +0 -1
  178. package/dist/interactions/createKeyboard.d.ts +0 -35
  179. package/dist/interactions/createKeyboard.d.ts.map +0 -1
  180. package/dist/interactions/createLongPress.d.ts +0 -63
  181. package/dist/interactions/createLongPress.d.ts.map +0 -1
  182. package/dist/interactions/createMove.d.ts +0 -40
  183. package/dist/interactions/createMove.d.ts.map +0 -1
  184. package/dist/interactions/createPress.d.ts +0 -55
  185. package/dist/interactions/createPress.d.ts.map +0 -1
  186. package/dist/interactions/index.d.ts +0 -13
  187. package/dist/interactions/index.d.ts.map +0 -1
  188. package/dist/label/createField.d.ts +0 -51
  189. package/dist/label/createField.d.ts.map +0 -1
  190. package/dist/label/createLabel.d.ts +0 -49
  191. package/dist/label/createLabel.d.ts.map +0 -1
  192. package/dist/label/createLabels.d.ts +0 -16
  193. package/dist/label/createLabels.d.ts.map +0 -1
  194. package/dist/label/index.d.ts +0 -6
  195. package/dist/label/index.d.ts.map +0 -1
  196. package/dist/landmark/createLandmark.d.ts +0 -79
  197. package/dist/landmark/createLandmark.d.ts.map +0 -1
  198. package/dist/landmark/index.d.ts +0 -2
  199. package/dist/landmark/index.d.ts.map +0 -1
  200. package/dist/link/createLink.d.ts +0 -65
  201. package/dist/link/createLink.d.ts.map +0 -1
  202. package/dist/link/index.d.ts +0 -2
  203. package/dist/link/index.d.ts.map +0 -1
  204. package/dist/listbox/createListBox.d.ts +0 -58
  205. package/dist/listbox/createListBox.d.ts.map +0 -1
  206. package/dist/listbox/createOption.d.ts +0 -42
  207. package/dist/listbox/createOption.d.ts.map +0 -1
  208. package/dist/listbox/index.d.ts +0 -3
  209. package/dist/listbox/index.d.ts.map +0 -1
  210. package/dist/live-announcer/announce.d.ts +0 -113
  211. package/dist/live-announcer/announce.d.ts.map +0 -1
  212. package/dist/live-announcer/index.d.ts +0 -2
  213. package/dist/live-announcer/index.d.ts.map +0 -1
  214. package/dist/menu/createMenu.d.ts +0 -57
  215. package/dist/menu/createMenu.d.ts.map +0 -1
  216. package/dist/menu/createMenuItem.d.ts +0 -42
  217. package/dist/menu/createMenuItem.d.ts.map +0 -1
  218. package/dist/menu/createMenuTrigger.d.ts +0 -29
  219. package/dist/menu/createMenuTrigger.d.ts.map +0 -1
  220. package/dist/menu/index.d.ts +0 -4
  221. package/dist/menu/index.d.ts.map +0 -1
  222. package/dist/meter/createMeter.d.ts +0 -44
  223. package/dist/meter/createMeter.d.ts.map +0 -1
  224. package/dist/meter/index.d.ts +0 -2
  225. package/dist/meter/index.d.ts.map +0 -1
  226. package/dist/numberfield/createNumberField.d.ts +0 -56
  227. package/dist/numberfield/createNumberField.d.ts.map +0 -1
  228. package/dist/numberfield/index.d.ts +0 -2
  229. package/dist/numberfield/index.d.ts.map +0 -1
  230. package/dist/overlays/ariaHideOutside.d.ts +0 -25
  231. package/dist/overlays/ariaHideOutside.d.ts.map +0 -1
  232. package/dist/overlays/createInteractOutside.d.ts +0 -20
  233. package/dist/overlays/createInteractOutside.d.ts.map +0 -1
  234. package/dist/overlays/createModal.d.ts +0 -70
  235. package/dist/overlays/createModal.d.ts.map +0 -1
  236. package/dist/overlays/createOverlay.d.ts +0 -43
  237. package/dist/overlays/createOverlay.d.ts.map +0 -1
  238. package/dist/overlays/createOverlayTrigger.d.ts +0 -30
  239. package/dist/overlays/createOverlayTrigger.d.ts.map +0 -1
  240. package/dist/overlays/createPreventScroll.d.ts +0 -15
  241. package/dist/overlays/createPreventScroll.d.ts.map +0 -1
  242. package/dist/overlays/index.d.ts +0 -7
  243. package/dist/overlays/index.d.ts.map +0 -1
  244. package/dist/popover/calculatePosition.d.ts +0 -67
  245. package/dist/popover/calculatePosition.d.ts.map +0 -1
  246. package/dist/popover/createOverlayPosition.d.ts +0 -109
  247. package/dist/popover/createOverlayPosition.d.ts.map +0 -1
  248. package/dist/popover/createPopover.d.ts +0 -88
  249. package/dist/popover/createPopover.d.ts.map +0 -1
  250. package/dist/popover/index.d.ts +0 -4
  251. package/dist/popover/index.d.ts.map +0 -1
  252. package/dist/progress/createProgressBar.d.ts +0 -47
  253. package/dist/progress/createProgressBar.d.ts.map +0 -1
  254. package/dist/progress/index.d.ts +0 -2
  255. package/dist/progress/index.d.ts.map +0 -1
  256. package/dist/radio/createRadio.d.ts +0 -68
  257. package/dist/radio/createRadio.d.ts.map +0 -1
  258. package/dist/radio/createRadioGroup.d.ts +0 -85
  259. package/dist/radio/createRadioGroup.d.ts.map +0 -1
  260. package/dist/radio/createRadioGroupState.d.ts +0 -77
  261. package/dist/radio/createRadioGroupState.d.ts.map +0 -1
  262. package/dist/radio/index.d.ts +0 -4
  263. package/dist/radio/index.d.ts.map +0 -1
  264. package/dist/searchfield/createSearchField.d.ts +0 -32
  265. package/dist/searchfield/createSearchField.d.ts.map +0 -1
  266. package/dist/searchfield/index.d.ts +0 -3
  267. package/dist/searchfield/index.d.ts.map +0 -1
  268. package/dist/select/createHiddenSelect.d.ts +0 -69
  269. package/dist/select/createHiddenSelect.d.ts.map +0 -1
  270. package/dist/select/createSelect.d.ts +0 -70
  271. package/dist/select/createSelect.d.ts.map +0 -1
  272. package/dist/select/index.d.ts +0 -3
  273. package/dist/select/index.d.ts.map +0 -1
  274. package/dist/selection/createTypeSelect.d.ts +0 -43
  275. package/dist/selection/createTypeSelect.d.ts.map +0 -1
  276. package/dist/selection/index.d.ts +0 -6
  277. package/dist/selection/index.d.ts.map +0 -1
  278. package/dist/separator/createSeparator.d.ts +0 -38
  279. package/dist/separator/createSeparator.d.ts.map +0 -1
  280. package/dist/separator/index.d.ts +0 -2
  281. package/dist/separator/index.d.ts.map +0 -1
  282. package/dist/slider/createSlider.d.ts +0 -43
  283. package/dist/slider/createSlider.d.ts.map +0 -1
  284. package/dist/slider/index.d.ts +0 -3
  285. package/dist/slider/index.d.ts.map +0 -1
  286. package/dist/ssr/index.d.ts +0 -221
  287. package/dist/ssr/index.d.ts.map +0 -1
  288. package/dist/switch/createSwitch.d.ts +0 -34
  289. package/dist/switch/createSwitch.d.ts.map +0 -1
  290. package/dist/switch/index.d.ts +0 -2
  291. package/dist/switch/index.d.ts.map +0 -1
  292. package/dist/table/createTable.d.ts +0 -24
  293. package/dist/table/createTable.d.ts.map +0 -1
  294. package/dist/table/createTableCell.d.ts +0 -12
  295. package/dist/table/createTableCell.d.ts.map +0 -1
  296. package/dist/table/createTableColumnHeader.d.ts +0 -12
  297. package/dist/table/createTableColumnHeader.d.ts.map +0 -1
  298. package/dist/table/createTableHeaderRow.d.ts +0 -12
  299. package/dist/table/createTableHeaderRow.d.ts.map +0 -1
  300. package/dist/table/createTableRow.d.ts +0 -12
  301. package/dist/table/createTableRow.d.ts.map +0 -1
  302. package/dist/table/createTableRowGroup.d.ts +0 -11
  303. package/dist/table/createTableRowGroup.d.ts.map +0 -1
  304. package/dist/table/createTableSelectAllCheckbox.d.ts +0 -12
  305. package/dist/table/createTableSelectAllCheckbox.d.ts.map +0 -1
  306. package/dist/table/createTableSelectionCheckbox.d.ts +0 -12
  307. package/dist/table/createTableSelectionCheckbox.d.ts.map +0 -1
  308. package/dist/table/index.d.ts +0 -14
  309. package/dist/table/index.d.ts.map +0 -1
  310. package/dist/table/types.d.ts +0 -150
  311. package/dist/table/types.d.ts.map +0 -1
  312. package/dist/tabs/createTabs.d.ts +0 -123
  313. package/dist/tabs/createTabs.d.ts.map +0 -1
  314. package/dist/tabs/index.d.ts +0 -2
  315. package/dist/tabs/index.d.ts.map +0 -1
  316. package/dist/tag/createTag.d.ts +0 -42
  317. package/dist/tag/createTag.d.ts.map +0 -1
  318. package/dist/tag/createTagGroup.d.ts +0 -54
  319. package/dist/tag/createTagGroup.d.ts.map +0 -1
  320. package/dist/tag/index.d.ts +0 -3
  321. package/dist/tag/index.d.ts.map +0 -1
  322. package/dist/textfield/createTextField.d.ts +0 -73
  323. package/dist/textfield/createTextField.d.ts.map +0 -1
  324. package/dist/textfield/index.d.ts +0 -2
  325. package/dist/textfield/index.d.ts.map +0 -1
  326. package/dist/toast/createToast.d.ts +0 -58
  327. package/dist/toast/createToast.d.ts.map +0 -1
  328. package/dist/toast/createToastRegion.d.ts +0 -49
  329. package/dist/toast/createToastRegion.d.ts.map +0 -1
  330. package/dist/toast/index.d.ts +0 -3
  331. package/dist/toast/index.d.ts.map +0 -1
  332. package/dist/toggle/createToggle.d.ts +0 -94
  333. package/dist/toggle/createToggle.d.ts.map +0 -1
  334. package/dist/toggle/createToggleState.d.ts +0 -34
  335. package/dist/toggle/createToggleState.d.ts.map +0 -1
  336. package/dist/toggle/index.d.ts +0 -5
  337. package/dist/toggle/index.d.ts.map +0 -1
  338. package/dist/toolbar/createToolbar.d.ts +0 -49
  339. package/dist/toolbar/createToolbar.d.ts.map +0 -1
  340. package/dist/toolbar/index.d.ts +0 -2
  341. package/dist/toolbar/index.d.ts.map +0 -1
  342. package/dist/tooltip/createTooltip.d.ts +0 -48
  343. package/dist/tooltip/createTooltip.d.ts.map +0 -1
  344. package/dist/tooltip/createTooltipTrigger.d.ts +0 -64
  345. package/dist/tooltip/createTooltipTrigger.d.ts.map +0 -1
  346. package/dist/tooltip/index.d.ts +0 -3
  347. package/dist/tooltip/index.d.ts.map +0 -1
  348. package/dist/tree/createTree.d.ts +0 -28
  349. package/dist/tree/createTree.d.ts.map +0 -1
  350. package/dist/tree/createTreeItem.d.ts +0 -12
  351. package/dist/tree/createTreeItem.d.ts.map +0 -1
  352. package/dist/tree/createTreeSelectionCheckbox.d.ts +0 -12
  353. package/dist/tree/createTreeSelectionCheckbox.d.ts.map +0 -1
  354. package/dist/tree/index.d.ts +0 -8
  355. package/dist/tree/index.d.ts.map +0 -1
  356. package/dist/tree/types.d.ts +0 -81
  357. package/dist/tree/types.d.ts.map +0 -1
  358. package/dist/utils/createDescription.d.ts +0 -56
  359. package/dist/utils/createDescription.d.ts.map +0 -1
  360. package/dist/utils/dom.d.ts +0 -68
  361. package/dist/utils/dom.d.ts.map +0 -1
  362. package/dist/utils/env.d.ts +0 -18
  363. package/dist/utils/env.d.ts.map +0 -1
  364. package/dist/utils/events.d.ts +0 -29
  365. package/dist/utils/events.d.ts.map +0 -1
  366. package/dist/utils/filterDOMProps.d.ts +0 -29
  367. package/dist/utils/filterDOMProps.d.ts.map +0 -1
  368. package/dist/utils/focus.d.ts +0 -20
  369. package/dist/utils/focus.d.ts.map +0 -1
  370. package/dist/utils/geometry.d.ts +0 -40
  371. package/dist/utils/geometry.d.ts.map +0 -1
  372. package/dist/utils/globalListeners.d.ts +0 -36
  373. package/dist/utils/globalListeners.d.ts.map +0 -1
  374. package/dist/utils/index.d.ts +0 -13
  375. package/dist/utils/index.d.ts.map +0 -1
  376. package/dist/utils/mergeProps.d.ts +0 -11
  377. package/dist/utils/mergeProps.d.ts.map +0 -1
  378. package/dist/utils/platform.d.ts +0 -14
  379. package/dist/utils/platform.d.ts.map +0 -1
  380. package/dist/utils/reactivity.d.ts +0 -28
  381. package/dist/utils/reactivity.d.ts.map +0 -1
  382. package/dist/utils/textSelection.d.ts +0 -19
  383. package/dist/utils/textSelection.d.ts.map +0 -1
  384. package/dist/visually-hidden/createVisuallyHidden.d.ts +0 -60
  385. package/dist/visually-hidden/createVisuallyHidden.d.ts.map +0 -1
  386. package/dist/visually-hidden/index.d.ts +0 -2
  387. package/dist/visually-hidden/index.d.ts.map +0 -1
  388. package/src/autocomplete/createAutocomplete.ts +0 -341
  389. package/src/autocomplete/index.ts +0 -9
  390. package/src/breadcrumbs/createBreadcrumbs.ts +0 -196
  391. package/src/breadcrumbs/index.ts +0 -8
  392. package/src/button/createButton.ts +0 -142
  393. package/src/button/createToggleButton.ts +0 -101
  394. package/src/button/index.ts +0 -4
  395. package/src/button/types.ts +0 -78
  396. package/src/calendar/createCalendar.ts +0 -138
  397. package/src/calendar/createCalendarCell.ts +0 -187
  398. package/src/calendar/createCalendarGrid.ts +0 -140
  399. package/src/calendar/createRangeCalendar.ts +0 -136
  400. package/src/calendar/createRangeCalendarCell.ts +0 -186
  401. package/src/calendar/index.ts +0 -34
  402. package/src/checkbox/createCheckbox.ts +0 -135
  403. package/src/checkbox/createCheckboxGroup.ts +0 -137
  404. package/src/checkbox/createCheckboxGroupItem.ts +0 -117
  405. package/src/checkbox/createCheckboxGroupState.ts +0 -193
  406. package/src/checkbox/index.ts +0 -13
  407. package/src/color/createColorArea.ts +0 -314
  408. package/src/color/createColorField.ts +0 -137
  409. package/src/color/createColorSlider.ts +0 -197
  410. package/src/color/createColorSwatch.ts +0 -40
  411. package/src/color/createColorWheel.ts +0 -208
  412. package/src/color/index.ts +0 -24
  413. package/src/color/types.ts +0 -116
  414. package/src/combobox/createComboBox.ts +0 -647
  415. package/src/combobox/index.ts +0 -6
  416. package/src/combobox/intl/en-US.json +0 -7
  417. package/src/combobox/intl/es-ES.json +0 -7
  418. package/src/combobox/intl/index.ts +0 -23
  419. package/src/datepicker/createDateField.ts +0 -154
  420. package/src/datepicker/createDatePicker.ts +0 -206
  421. package/src/datepicker/createDateSegment.ts +0 -229
  422. package/src/datepicker/createTimeField.ts +0 -154
  423. package/src/datepicker/index.ts +0 -28
  424. package/src/dialog/createDialog.ts +0 -120
  425. package/src/dialog/index.ts +0 -2
  426. package/src/dialog/types.ts +0 -19
  427. package/src/disclosure/createDisclosure.ts +0 -131
  428. package/src/disclosure/createDisclosureGroup.ts +0 -62
  429. package/src/disclosure/index.ts +0 -11
  430. package/src/dnd/createDrag.ts +0 -209
  431. package/src/dnd/createDraggableCollection.ts +0 -63
  432. package/src/dnd/createDraggableItem.ts +0 -243
  433. package/src/dnd/createDrop.ts +0 -321
  434. package/src/dnd/createDroppableCollection.ts +0 -293
  435. package/src/dnd/createDroppableItem.ts +0 -213
  436. package/src/dnd/index.ts +0 -47
  437. package/src/dnd/types.ts +0 -89
  438. package/src/dnd/utils.ts +0 -294
  439. package/src/focus/FocusScope.tsx +0 -408
  440. package/src/focus/createAutoFocus.ts +0 -321
  441. package/src/focus/createFocusRestore.ts +0 -313
  442. package/src/focus/createVirtualFocus.ts +0 -396
  443. package/src/focus/index.ts +0 -35
  444. package/src/form/createFormReset.ts +0 -51
  445. package/src/form/createFormValidation.ts +0 -224
  446. package/src/form/index.ts +0 -11
  447. package/src/grid/GridKeyboardDelegate.ts +0 -429
  448. package/src/grid/createGrid.ts +0 -261
  449. package/src/grid/createGridCell.ts +0 -182
  450. package/src/grid/createGridRow.ts +0 -153
  451. package/src/grid/index.ts +0 -18
  452. package/src/grid/types.ts +0 -133
  453. package/src/gridlist/createGridList.ts +0 -185
  454. package/src/gridlist/createGridListItem.ts +0 -180
  455. package/src/gridlist/createGridListSelectionCheckbox.ts +0 -59
  456. package/src/gridlist/index.ts +0 -16
  457. package/src/gridlist/types.ts +0 -81
  458. package/src/i18n/NumberFormatter.ts +0 -266
  459. package/src/i18n/createCollator.ts +0 -79
  460. package/src/i18n/createDateFormatter.ts +0 -83
  461. package/src/i18n/createFilter.ts +0 -131
  462. package/src/i18n/createNumberFormatter.ts +0 -52
  463. package/src/i18n/createStringFormatter.ts +0 -87
  464. package/src/i18n/index.ts +0 -40
  465. package/src/i18n/locale.tsx +0 -188
  466. package/src/i18n/utils.ts +0 -99
  467. package/src/index.ts +0 -670
  468. package/src/interactions/FocusableProvider.tsx +0 -44
  469. package/src/interactions/PressEvent.ts +0 -124
  470. package/src/interactions/createFocus.ts +0 -163
  471. package/src/interactions/createFocusRing.ts +0 -89
  472. package/src/interactions/createFocusWithin.ts +0 -206
  473. package/src/interactions/createFocusable.ts +0 -168
  474. package/src/interactions/createHover.ts +0 -254
  475. package/src/interactions/createInteractionModality.ts +0 -424
  476. package/src/interactions/createKeyboard.ts +0 -82
  477. package/src/interactions/createLongPress.ts +0 -174
  478. package/src/interactions/createMove.ts +0 -289
  479. package/src/interactions/createPress.ts +0 -834
  480. package/src/interactions/index.ts +0 -78
  481. package/src/label/createField.ts +0 -145
  482. package/src/label/createLabel.ts +0 -117
  483. package/src/label/createLabels.ts +0 -50
  484. package/src/label/index.ts +0 -19
  485. package/src/landmark/createLandmark.ts +0 -377
  486. package/src/landmark/index.ts +0 -8
  487. package/src/link/createLink.ts +0 -182
  488. package/src/link/index.ts +0 -1
  489. package/src/listbox/createListBox.ts +0 -269
  490. package/src/listbox/createOption.ts +0 -151
  491. package/src/listbox/index.ts +0 -12
  492. package/src/live-announcer/announce.ts +0 -322
  493. package/src/live-announcer/index.ts +0 -9
  494. package/src/menu/createMenu.ts +0 -396
  495. package/src/menu/createMenuItem.ts +0 -149
  496. package/src/menu/createMenuTrigger.ts +0 -88
  497. package/src/menu/index.ts +0 -18
  498. package/src/meter/createMeter.ts +0 -75
  499. package/src/meter/index.ts +0 -1
  500. package/src/numberfield/createNumberField.ts +0 -268
  501. package/src/numberfield/index.ts +0 -5
  502. package/src/overlays/ariaHideOutside.ts +0 -219
  503. package/src/overlays/createInteractOutside.ts +0 -149
  504. package/src/overlays/createModal.tsx +0 -202
  505. package/src/overlays/createOverlay.ts +0 -155
  506. package/src/overlays/createOverlayTrigger.ts +0 -85
  507. package/src/overlays/createPreventScroll.ts +0 -266
  508. package/src/overlays/index.ts +0 -44
  509. package/src/popover/calculatePosition.ts +0 -766
  510. package/src/popover/createOverlayPosition.ts +0 -356
  511. package/src/popover/createPopover.ts +0 -170
  512. package/src/popover/index.ts +0 -24
  513. package/src/progress/createProgressBar.ts +0 -128
  514. package/src/progress/index.ts +0 -5
  515. package/src/radio/createRadio.ts +0 -287
  516. package/src/radio/createRadioGroup.ts +0 -189
  517. package/src/radio/createRadioGroupState.ts +0 -201
  518. package/src/radio/index.ts +0 -23
  519. package/src/searchfield/createSearchField.ts +0 -186
  520. package/src/searchfield/index.ts +0 -2
  521. package/src/select/createHiddenSelect.tsx +0 -236
  522. package/src/select/createSelect.ts +0 -395
  523. package/src/select/index.ts +0 -14
  524. package/src/selection/createTypeSelect.ts +0 -201
  525. package/src/selection/index.ts +0 -6
  526. package/src/separator/createSeparator.ts +0 -82
  527. package/src/separator/index.ts +0 -6
  528. package/src/slider/createSlider.ts +0 -349
  529. package/src/slider/index.ts +0 -2
  530. package/src/ssr/index.tsx +0 -370
  531. package/src/switch/createSwitch.ts +0 -70
  532. package/src/switch/index.ts +0 -1
  533. package/src/table/createTable.ts +0 -526
  534. package/src/table/createTableCell.ts +0 -147
  535. package/src/table/createTableColumnHeader.ts +0 -115
  536. package/src/table/createTableHeaderRow.ts +0 -40
  537. package/src/table/createTableRow.ts +0 -155
  538. package/src/table/createTableRowGroup.ts +0 -32
  539. package/src/table/createTableSelectAllCheckbox.ts +0 -73
  540. package/src/table/createTableSelectionCheckbox.ts +0 -59
  541. package/src/table/index.ts +0 -30
  542. package/src/table/types.ts +0 -165
  543. package/src/tabs/createTabs.ts +0 -472
  544. package/src/tabs/index.ts +0 -14
  545. package/src/tag/createTag.ts +0 -194
  546. package/src/tag/createTagGroup.ts +0 -154
  547. package/src/tag/index.ts +0 -12
  548. package/src/textfield/createTextField.ts +0 -198
  549. package/src/textfield/index.ts +0 -5
  550. package/src/toast/createToast.ts +0 -118
  551. package/src/toast/createToastRegion.ts +0 -100
  552. package/src/toast/index.ts +0 -11
  553. package/src/toggle/createToggle.ts +0 -223
  554. package/src/toggle/createToggleState.ts +0 -94
  555. package/src/toggle/index.ts +0 -7
  556. package/src/toolbar/createToolbar.ts +0 -368
  557. package/src/toolbar/index.ts +0 -6
  558. package/src/tooltip/createTooltip.ts +0 -79
  559. package/src/tooltip/createTooltipTrigger.ts +0 -222
  560. package/src/tooltip/index.ts +0 -6
  561. package/src/tree/createTree.ts +0 -246
  562. package/src/tree/createTreeItem.ts +0 -233
  563. package/src/tree/createTreeSelectionCheckbox.ts +0 -68
  564. package/src/tree/index.ts +0 -16
  565. package/src/tree/types.ts +0 -87
  566. package/src/utils/createDescription.ts +0 -137
  567. package/src/utils/dom.ts +0 -327
  568. package/src/utils/env.ts +0 -54
  569. package/src/utils/events.ts +0 -106
  570. package/src/utils/filterDOMProps.ts +0 -116
  571. package/src/utils/focus.ts +0 -151
  572. package/src/utils/geometry.ts +0 -115
  573. package/src/utils/globalListeners.ts +0 -142
  574. package/src/utils/index.ts +0 -80
  575. package/src/utils/mergeProps.ts +0 -52
  576. package/src/utils/platform.ts +0 -52
  577. package/src/utils/reactivity.ts +0 -36
  578. package/src/utils/textSelection.ts +0 -114
  579. package/src/visually-hidden/createVisuallyHidden.ts +0 -124
  580. package/src/visually-hidden/index.ts +0 -6
@@ -1,395 +0,0 @@
1
- /**
2
- * Provides the behavior and accessibility implementation for a select component.
3
- * A select displays a collapsible list of options and allows a user to select one of them.
4
- * Based on @react-aria/select useSelect.
5
- */
6
-
7
- import { type JSX, type Accessor, createEffect, onCleanup } from 'solid-js';
8
- import { createPress } from '../interactions/createPress';
9
- import { createFocusRing } from '../interactions/createFocusRing';
10
- import { createLabel } from '../label/createLabel';
11
- import { createTypeSelect } from '../selection/createTypeSelect';
12
- import { filterDOMProps } from '../utils/filterDOMProps';
13
- import { mergeProps } from '../utils/mergeProps';
14
- import { createId } from '../ssr';
15
- import { access, type MaybeAccessor } from '../utils/reactivity';
16
- import type { SelectState, CollectionNode } from '@proyecto-viviana/solid-stately';
17
-
18
- export interface AriaSelectProps {
19
- /** An ID for the select. */
20
- id?: string;
21
- /** Whether the select is disabled. */
22
- isDisabled?: boolean;
23
- /** Whether the select is required. */
24
- isRequired?: boolean;
25
- /** The label for the select. */
26
- label?: JSX.Element;
27
- /** An accessible label for the select when no visible label is provided. */
28
- 'aria-label'?: string;
29
- /** The ID of an element that labels the select. */
30
- 'aria-labelledby'?: string;
31
- /** The ID of an element that describes the select. */
32
- 'aria-describedby'?: string;
33
- /** Placeholder text when no option is selected. */
34
- placeholder?: string;
35
- /** Whether the select should be auto-focused. */
36
- autoFocus?: boolean;
37
- /** Handler called when focus moves to the select. */
38
- onFocus?: (e: FocusEvent) => void;
39
- /** Handler called when focus moves away from the select. */
40
- onBlur?: (e: FocusEvent) => void;
41
- /** Handler called when the focus state changes. */
42
- onFocusChange?: (isFocused: boolean) => void;
43
- /** The name of the select, used when submitting an HTML form. */
44
- name?: string;
45
- /** Whether type-to-select is disabled. @default false */
46
- disallowTypeAhead?: boolean;
47
- }
48
-
49
- export interface SelectAria<T> {
50
- /** Props for the label element. */
51
- labelProps: JSX.HTMLAttributes<HTMLElement>;
52
- /** Props for the trigger button element. */
53
- triggerProps: JSX.HTMLAttributes<HTMLElement>;
54
- /** Props for the value display element. */
55
- valueProps: JSX.HTMLAttributes<HTMLElement>;
56
- /** Props for the listbox/menu popup. */
57
- menuProps: JSX.HTMLAttributes<HTMLElement>;
58
- /** Props for the description element, if any. */
59
- descriptionProps: JSX.HTMLAttributes<HTMLElement>;
60
- /** Props for the error message element, if any. */
61
- errorMessageProps: JSX.HTMLAttributes<HTMLElement>;
62
- /** Whether the select is currently focused. */
63
- isFocused: Accessor<boolean>;
64
- /** Whether the select has keyboard focus. */
65
- isFocusVisible: Accessor<boolean>;
66
- /** Whether the select is currently open. */
67
- isOpen: Accessor<boolean>;
68
- /** The currently selected item. */
69
- selectedItem: Accessor<CollectionNode<T> | null>;
70
- }
71
-
72
- // Shared data between select and options
73
- const selectData = new WeakMap<object, SelectData>();
74
-
75
- interface SelectData {
76
- id: string;
77
- }
78
-
79
- export function getSelectData(state: SelectState): SelectData | undefined {
80
- return selectData.get(state);
81
- }
82
-
83
- /**
84
- * Provides the behavior and accessibility implementation for a select component.
85
- */
86
- export function createSelect<T>(
87
- props: MaybeAccessor<AriaSelectProps>,
88
- state: SelectState<T>,
89
- _ref?: () => HTMLElement | null
90
- ): SelectAria<T> {
91
- const getProps = () => access(props);
92
- const id = createId(getProps().id);
93
-
94
- // Generate IDs for associated elements
95
- const buttonId = `${id}-button`;
96
- const listBoxId = `${id}-listbox`;
97
- const valueId = `${id}-value`;
98
- const descriptionId = `${id}-description`;
99
- const errorMessageId = `${id}-error`;
100
-
101
- // Filter DOM props
102
- const domProps = () =>
103
- filterDOMProps(getProps() as unknown as Record<string, unknown>, { labelable: true });
104
-
105
- // Share data with child options
106
- createEffect(() => {
107
- selectData.set(state, { id });
108
-
109
- onCleanup(() => {
110
- selectData.delete(state);
111
- });
112
- });
113
-
114
- // Label handling
115
- const { labelProps, fieldProps } = createLabel({
116
- get id() {
117
- return buttonId;
118
- },
119
- get label() {
120
- return getProps().label;
121
- },
122
- get 'aria-label'() {
123
- return getProps()['aria-label'];
124
- },
125
- get 'aria-labelledby'() {
126
- return getProps()['aria-labelledby'];
127
- },
128
- labelElementType: 'span',
129
- });
130
-
131
- // Focus ring for keyboard focus styling
132
- const { isFocusVisible, focusProps } = createFocusRing({
133
- get autoFocus() {
134
- return getProps().autoFocus;
135
- },
136
- });
137
-
138
- // Track focus state
139
- const isFocused = state.isFocused;
140
-
141
- // Handle press on trigger
142
- const { pressProps } = createPress({
143
- get isDisabled() {
144
- return getProps().isDisabled ?? state.isDisabled;
145
- },
146
- onPress() {
147
- state.toggle();
148
- },
149
- });
150
-
151
- // Helper to find next non-disabled key
152
- const findNextKey = (fromKey: string | number | null, direction: 'forward' | 'backward'): string | number | null => {
153
- const collection = state.collection();
154
- let key = fromKey;
155
-
156
- if (key == null) {
157
- return direction === 'forward' ? collection.getFirstKey() : collection.getLastKey();
158
- }
159
-
160
- const getNext = direction === 'forward'
161
- ? (k: string | number) => collection.getKeyAfter(k)
162
- : (k: string | number) => collection.getKeyBefore(k);
163
-
164
- let next = getNext(key);
165
- while (next != null) {
166
- // Check if item is disabled via state.isKeyDisabled or item.isDisabled
167
- const isDisabled = state.isKeyDisabled?.(next) || collection.getItem(next)?.isDisabled;
168
- if (!isDisabled) {
169
- return next;
170
- }
171
- next = getNext(next);
172
- }
173
-
174
- return null;
175
- };
176
-
177
- // Helper to check if key is disabled
178
- const isKeyDisabled = (key: string | number): boolean => {
179
- const collection = state.collection();
180
- return state.isKeyDisabled?.(key) || collection.getItem(key)?.isDisabled || false;
181
- };
182
-
183
- // Type-to-select - for Select, typing directly selects items when closed
184
- const { typeSelectProps } = createTypeSelect({
185
- collection: () => state.collection(),
186
- focusedKey: () => state.selectedKey(), // Use selectedKey as the "focused" key for closed Select
187
- onFocusedKeyChange: (key) => {
188
- // When closed, type-to-select directly changes selection
189
- if (!state.isOpen()) {
190
- state.setSelectedKey(key);
191
- } else {
192
- // When open, update focused key (listbox handles selection)
193
- state.setFocusedKey(key);
194
- }
195
- },
196
- isKeyDisabled,
197
- get isDisabled() {
198
- return getProps().disallowTypeAhead ?? false;
199
- },
200
- });
201
-
202
- // Keyboard navigation
203
- const onKeyDown: JSX.EventHandler<HTMLElement, KeyboardEvent> = (e) => {
204
- if (getProps().isDisabled) return;
205
-
206
- const collection = state.collection();
207
- const currentKey = state.selectedKey();
208
-
209
- switch (e.key) {
210
- case 'Enter':
211
- case ' ':
212
- e.preventDefault();
213
- state.toggle();
214
- break;
215
-
216
- case 'ArrowDown':
217
- e.preventDefault();
218
- if (!state.isOpen()) {
219
- // ArrowDown: Open the dropdown and focus first/selected item
220
- state.open();
221
- const focusKey = currentKey ?? collection.getFirstKey();
222
- if (focusKey) {
223
- state.setFocusedKey(focusKey);
224
- }
225
- }
226
- // When open, navigation is handled by the listbox
227
- break;
228
-
229
- case 'ArrowUp':
230
- e.preventDefault();
231
- if (!state.isOpen()) {
232
- // ArrowUp: Open the dropdown and focus last/selected item
233
- state.open();
234
- const focusKey = currentKey ?? collection.getLastKey();
235
- if (focusKey) {
236
- state.setFocusedKey(focusKey);
237
- }
238
- }
239
- // When open, navigation is handled by the listbox
240
- break;
241
-
242
- case 'ArrowRight':
243
- // ArrowRight: Select next option (for horizontal keyboard navigation pattern)
244
- if (!state.isOpen()) {
245
- e.preventDefault();
246
- const nextKey = findNextKey(currentKey, 'forward');
247
- if (nextKey != null) {
248
- state.setSelectedKey(nextKey);
249
- }
250
- }
251
- break;
252
-
253
- case 'ArrowLeft':
254
- // ArrowLeft: Select previous option (for horizontal keyboard navigation pattern)
255
- if (!state.isOpen()) {
256
- e.preventDefault();
257
- const prevKey = findNextKey(currentKey, 'backward');
258
- if (prevKey != null) {
259
- state.setSelectedKey(prevKey);
260
- }
261
- }
262
- break;
263
-
264
- case 'Home':
265
- // Home: Select first option
266
- if (!state.isOpen()) {
267
- e.preventDefault();
268
- const firstKey = collection.getFirstKey();
269
- if (firstKey != null) {
270
- // Find first non-disabled key
271
- const item = collection.getItem(firstKey);
272
- if (item && !item.isDisabled) {
273
- state.setSelectedKey(firstKey);
274
- } else {
275
- const nextKey = findNextKey(firstKey, 'forward');
276
- if (nextKey != null) {
277
- state.setSelectedKey(nextKey);
278
- }
279
- }
280
- }
281
- }
282
- break;
283
-
284
- case 'End':
285
- // End: Select last option
286
- if (!state.isOpen()) {
287
- e.preventDefault();
288
- const lastKey = collection.getLastKey();
289
- if (lastKey != null) {
290
- // Find last non-disabled key
291
- const item = collection.getItem(lastKey);
292
- if (item && !item.isDisabled) {
293
- state.setSelectedKey(lastKey);
294
- } else {
295
- const prevKey = findNextKey(lastKey, 'backward');
296
- if (prevKey != null) {
297
- state.setSelectedKey(prevKey);
298
- }
299
- }
300
- }
301
- }
302
- break;
303
-
304
- case 'Escape':
305
- if (state.isOpen()) {
306
- e.preventDefault();
307
- state.close();
308
- }
309
- break;
310
- }
311
- };
312
-
313
- // Handle focus events
314
- const handleFocus = (e: FocusEvent) => {
315
- state.setFocused(true);
316
- getProps().onFocus?.(e);
317
- getProps().onFocusChange?.(true);
318
- };
319
-
320
- const handleBlur = (e: FocusEvent) => {
321
- state.setFocused(false);
322
- getProps().onBlur?.(e);
323
- getProps().onFocusChange?.(false);
324
- };
325
-
326
- return {
327
- get labelProps() {
328
- return labelProps as JSX.HTMLAttributes<HTMLElement>;
329
- },
330
- get triggerProps() {
331
- const p = getProps();
332
- const isOpen = state.isOpen();
333
- const isDisabled = p.isDisabled ?? state.isDisabled;
334
-
335
- const baseProps = mergeProps(
336
- domProps(),
337
- pressProps as Record<string, unknown>,
338
- focusProps as Record<string, unknown>,
339
- fieldProps as Record<string, unknown>,
340
- {
341
- id: buttonId,
342
- role: 'combobox',
343
- type: 'button',
344
- tabIndex: isDisabled ? undefined : 0,
345
- 'aria-haspopup': 'listbox',
346
- 'aria-expanded': isOpen,
347
- 'aria-controls': isOpen ? listBoxId : undefined,
348
- 'aria-disabled': isDisabled || undefined,
349
- 'aria-required': p.isRequired || undefined,
350
- 'aria-describedby': p['aria-describedby'] || undefined,
351
- onKeyDown,
352
- onFocus: handleFocus,
353
- onBlur: handleBlur,
354
- 'data-open': isOpen || undefined,
355
- 'data-disabled': isDisabled || undefined,
356
- 'data-focus-visible': isFocusVisible() || undefined,
357
- } as Record<string, unknown>
358
- );
359
-
360
- // Add type-select props if enabled
361
- if (!p.disallowTypeAhead) {
362
- return mergeProps(baseProps, typeSelectProps as Record<string, unknown>) as JSX.HTMLAttributes<HTMLElement>;
363
- }
364
-
365
- return baseProps as JSX.HTMLAttributes<HTMLElement>;
366
- },
367
- get valueProps() {
368
- return {
369
- id: valueId,
370
- } as JSX.HTMLAttributes<HTMLElement>;
371
- },
372
- get menuProps() {
373
- return {
374
- id: listBoxId,
375
- role: 'listbox',
376
- 'aria-labelledby': buttonId,
377
- tabIndex: -1,
378
- } as JSX.HTMLAttributes<HTMLElement>;
379
- },
380
- get descriptionProps() {
381
- return {
382
- id: descriptionId,
383
- } as JSX.HTMLAttributes<HTMLElement>;
384
- },
385
- get errorMessageProps() {
386
- return {
387
- id: errorMessageId,
388
- } as JSX.HTMLAttributes<HTMLElement>;
389
- },
390
- isFocused,
391
- isFocusVisible: () => isFocused() && isFocusVisible(),
392
- isOpen: state.isOpen,
393
- selectedItem: state.selectedItem,
394
- };
395
- }
@@ -1,14 +0,0 @@
1
- export {
2
- createSelect,
3
- getSelectData,
4
- type AriaSelectProps,
5
- type SelectAria,
6
- } from './createSelect';
7
-
8
- export {
9
- createHiddenSelect,
10
- HiddenSelect,
11
- type AriaHiddenSelectProps,
12
- type HiddenSelectAria,
13
- type HiddenSelectProps,
14
- } from './createHiddenSelect.jsx';
@@ -1,201 +0,0 @@
1
- /**
2
- * createTypeSelect - Handles typeahead interactions with collections.
3
- * Based on @react-aria/selection useTypeSelect.
4
- *
5
- * Allows users to navigate to items by typing characters that match
6
- * item text values. Supports multi-character search with debouncing.
7
- */
8
-
9
- import type { JSX, Accessor } from 'solid-js';
10
- import type { Key, Collection, CollectionNode } from '@proyecto-viviana/solid-stately';
11
-
12
- /**
13
- * Controls how long to wait before clearing the typeahead buffer.
14
- */
15
- const TYPEAHEAD_DEBOUNCE_WAIT_MS = 1000; // 1 second
16
-
17
- export interface TypeSelectOptions<T> {
18
- /** The collection to search through. */
19
- collection: Accessor<Collection<T>>;
20
- /** The currently focused key. */
21
- focusedKey: Accessor<Key | null>;
22
- /** Callback to set the focused key when a match is found. */
23
- onFocusedKeyChange: (key: Key) => void;
24
- /** Callback when an item is focused by typing. */
25
- onTypeSelect?: (key: Key) => void;
26
- /** Function to check if a key is disabled. */
27
- isKeyDisabled?: (key: Key) => boolean;
28
- /** Whether type-to-select is disabled. */
29
- isDisabled?: boolean;
30
- }
31
-
32
- export interface TypeSelectAria {
33
- /** Props to spread on the collection element. */
34
- typeSelectProps: JSX.HTMLAttributes<HTMLElement>;
35
- }
36
-
37
- // Internal state for tracking the search buffer
38
- interface TypeSelectState {
39
- search: string;
40
- timeout: ReturnType<typeof setTimeout> | undefined;
41
- }
42
-
43
- /**
44
- * Get a printable character from a key event.
45
- * Returns the character if it's a single printable character,
46
- * or empty string for non-printable keys.
47
- */
48
- function getStringForKey(key: string): string {
49
- // If the key is of length 1, it is an ASCII value.
50
- // Otherwise, if there are no ASCII characters in the key name,
51
- // it is a Unicode character.
52
- // See https://www.w3.org/TR/uievents-key/
53
- if (key.length === 1 || !/^[A-Z]/i.test(key)) {
54
- return key;
55
- }
56
- return '';
57
- }
58
-
59
- /**
60
- * Search for a key in the collection that matches the search string.
61
- * Starts searching from the key after `fromKey`, wrapping around if needed.
62
- */
63
- function getKeyForSearch<T>(
64
- collection: Collection<T>,
65
- search: string,
66
- fromKey: Key | null,
67
- isKeyDisabled?: (key: Key) => boolean
68
- ): Key | null {
69
- const searchLower = search.toLowerCase();
70
-
71
- // Collect all items in order
72
- const items: CollectionNode<T>[] = [];
73
- for (const item of collection) {
74
- if (item.type === 'item') {
75
- items.push(item);
76
- }
77
- }
78
-
79
- if (items.length === 0) return null;
80
-
81
- // Find the starting index
82
- let startIndex = 0;
83
- if (fromKey != null) {
84
- const fromIndex = items.findIndex(item => item.key === fromKey);
85
- if (fromIndex !== -1) {
86
- // Start searching from the item AFTER the current one
87
- startIndex = (fromIndex + 1) % items.length;
88
- }
89
- }
90
-
91
- // Search from startIndex, wrapping around
92
- for (let i = 0; i < items.length; i++) {
93
- const index = (startIndex + i) % items.length;
94
- const item = items[index];
95
-
96
- // Skip disabled items
97
- if (item.isDisabled || (isKeyDisabled && isKeyDisabled(item.key))) {
98
- continue;
99
- }
100
-
101
- // Check if the text value starts with the search string
102
- const textValue = item.textValue || '';
103
- if (textValue.toLowerCase().startsWith(searchLower)) {
104
- return item.key;
105
- }
106
- }
107
-
108
- return null;
109
- }
110
-
111
- /**
112
- * Creates typeahead/type-to-select functionality for a collection.
113
- *
114
- * @example
115
- * ```tsx
116
- * const { typeSelectProps } = createTypeSelect({
117
- * collection: () => state.collection(),
118
- * focusedKey: () => state.focusedKey(),
119
- * onFocusedKeyChange: (key) => state.setFocusedKey(key),
120
- * });
121
- *
122
- * return <ul {...mergeProps(listBoxProps, typeSelectProps)}>...</ul>;
123
- * ```
124
- */
125
- export function createTypeSelect<T>(options: TypeSelectOptions<T>): TypeSelectAria {
126
- // Create mutable state object to persist across keystrokes
127
- const state: TypeSelectState = {
128
- search: '',
129
- timeout: undefined,
130
- };
131
-
132
- const onKeyDownCapture: JSX.EventHandler<HTMLElement, KeyboardEvent> = (e) => {
133
- if (options.isDisabled) return;
134
-
135
- const character = getStringForKey(e.key);
136
-
137
- // Ignore non-printable characters, modifier key combos,
138
- // and events that didn't originate from within the element
139
- if (
140
- !character ||
141
- e.ctrlKey ||
142
- e.metaKey ||
143
- e.altKey ||
144
- !e.currentTarget.contains(e.target as HTMLElement)
145
- ) {
146
- return;
147
- }
148
-
149
- // Don't start search with space (common action key)
150
- if (state.search.length === 0 && character === ' ') {
151
- return;
152
- }
153
-
154
- // If there's already search text and the user types a space,
155
- // prevent it from triggering selection and include it in the search
156
- if (character === ' ' && state.search.trim().length > 0) {
157
- e.preventDefault();
158
- e.stopPropagation();
159
- }
160
-
161
- // Append to the search buffer
162
- state.search += character;
163
-
164
- // Find a matching key
165
- const collection = options.collection();
166
- const currentKey = options.focusedKey();
167
-
168
- // First, try to find a match starting after the current key
169
- let key = getKeyForSearch(collection, state.search, currentKey, options.isKeyDisabled);
170
-
171
- // If no match found, try from the beginning
172
- if (key == null && currentKey != null) {
173
- key = getKeyForSearch(collection, state.search, null, options.isKeyDisabled);
174
- }
175
-
176
- if (key != null) {
177
- options.onFocusedKeyChange(key);
178
- options.onTypeSelect?.(key);
179
- }
180
-
181
- // Reset the debounce timer
182
- if (state.timeout !== undefined) {
183
- clearTimeout(state.timeout);
184
- }
185
- state.timeout = setTimeout(() => {
186
- state.search = '';
187
- }, TYPEAHEAD_DEBOUNCE_WAIT_MS);
188
- };
189
-
190
- // Handler for bubble phase (used in test environments and as fallback)
191
- const onKeyDown: JSX.EventHandler<HTMLElement, KeyboardEvent> = onKeyDownCapture;
192
-
193
- return {
194
- typeSelectProps: {
195
- // Use capture phase to handle spacebar before other handlers in production
196
- onKeyDownCapture,
197
- // Also attach to bubble phase for test environments
198
- onKeyDown,
199
- } as JSX.HTMLAttributes<HTMLElement>,
200
- };
201
- }
@@ -1,6 +0,0 @@
1
- /**
2
- * Selection utilities for managing typeahead and keyboard navigation
3
- * in collection components.
4
- */
5
-
6
- export { createTypeSelect, type TypeSelectOptions, type TypeSelectAria } from './createTypeSelect';
@@ -1,82 +0,0 @@
1
- /**
2
- * createSeparator - SolidJS implementation of React Aria's useSeparator
3
- *
4
- * A separator is a visual divider between two groups of content,
5
- * e.g. groups of menu items or sections of a page.
6
- */
7
-
8
- import type { JSX } from 'solid-js';
9
- import { access, type MaybeAccessor } from '../utils';
10
- import { filterDOMProps } from '../utils';
11
-
12
- // ============================================
13
- // TYPES
14
- // ============================================
15
-
16
- export type Orientation = 'horizontal' | 'vertical';
17
-
18
- export interface AriaSeparatorProps {
19
- /**
20
- * The orientation of the separator.
21
- * @default 'horizontal'
22
- */
23
- orientation?: Orientation;
24
- /**
25
- * The HTML element type that will be used to render the separator.
26
- * @default 'hr'
27
- */
28
- elementType?: string;
29
- /** An accessibility label for the separator. */
30
- 'aria-label'?: string;
31
- /** Identifies the element(s) that labels the separator. */
32
- 'aria-labelledby'?: string;
33
- /** The element's unique identifier. */
34
- id?: string;
35
- }
36
-
37
- export interface SeparatorAria {
38
- /** Props for the separator element. */
39
- separatorProps: JSX.HTMLAttributes<HTMLElement>;
40
- }
41
-
42
- // ============================================
43
- // CREATE SEPARATOR
44
- // ============================================
45
-
46
- /**
47
- * Provides the accessibility implementation for a separator.
48
- * A separator is a visual divider between two groups of content,
49
- * e.g. groups of menu items or sections of a page.
50
- */
51
- export function createSeparator(
52
- props: MaybeAccessor<AriaSeparatorProps> = {}
53
- ): SeparatorAria {
54
- const getSeparatorProps = (): JSX.HTMLAttributes<HTMLElement> => {
55
- const p = access(props);
56
- const domProps = filterDOMProps(p as Record<string, unknown>, { labelable: true });
57
-
58
- // if orientation is horizontal, aria-orientation default is horizontal, so we leave it undefined
59
- // if it's vertical, we need to specify it
60
- let ariaOrientation: 'vertical' | undefined;
61
- if (p.orientation === 'vertical') {
62
- ariaOrientation = 'vertical';
63
- }
64
-
65
- // hr elements implicitly have role = separator and a horizontal orientation
66
- if (p.elementType !== 'hr') {
67
- return {
68
- ...domProps,
69
- role: 'separator',
70
- 'aria-orientation': ariaOrientation,
71
- };
72
- }
73
-
74
- return domProps;
75
- };
76
-
77
- return {
78
- get separatorProps() {
79
- return getSeparatorProps();
80
- },
81
- };
82
- }
@@ -1,6 +0,0 @@
1
- export {
2
- createSeparator,
3
- type AriaSeparatorProps,
4
- type SeparatorAria,
5
- type Orientation,
6
- } from './createSeparator';