@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,313 +0,0 @@
1
- /**
2
- * Focus restoration utilities for solidaria
3
- *
4
- * Provides enhanced focus restoration with retry logic, cross-scope tracking,
5
- * and safe restoration patterns.
6
- */
7
-
8
- import { createEffect, onCleanup, onMount } from 'solid-js';
9
- import { isServer } from 'solid-js/web';
10
- import { getOwnerDocument } from '../utils';
11
- import { focusSafely } from '../utils/focus';
12
-
13
- // ============================================
14
- // TYPES
15
- // ============================================
16
-
17
- export interface FocusRestoreOptions {
18
- /**
19
- * Whether to restore focus when the component unmounts.
20
- * @default true
21
- */
22
- restoreOnUnmount?: boolean;
23
- /**
24
- * Maximum number of retries if the element is not in the DOM.
25
- * @default 3
26
- */
27
- maxRetries?: number;
28
- /**
29
- * Delay between retries in milliseconds.
30
- * @default 50
31
- */
32
- retryDelay?: number;
33
- /**
34
- * Callback when focus is successfully restored.
35
- */
36
- onRestore?: (element: HTMLElement) => void;
37
- /**
38
- * Callback when focus restoration fails.
39
- */
40
- onRestoreFailed?: () => void;
41
- /**
42
- * Whether to prevent scrolling when restoring focus.
43
- * @default true
44
- */
45
- preventScroll?: boolean;
46
- }
47
-
48
- export interface FocusRestoreResult {
49
- /**
50
- * Manually restore focus to the saved element.
51
- */
52
- restore: () => boolean;
53
- /**
54
- * Get the saved element (if any).
55
- */
56
- getSavedElement: () => HTMLElement | null;
57
- /**
58
- * Save the currently focused element.
59
- */
60
- saveCurrentFocus: () => void;
61
- /**
62
- * Clear the saved element without restoring.
63
- */
64
- clear: () => void;
65
- }
66
-
67
- // ============================================
68
- // GLOBAL FOCUS STACK
69
- // ============================================
70
-
71
- // Stack to track focus history across scopes
72
- const focusStack: HTMLElement[] = [];
73
-
74
- /**
75
- * Push an element onto the focus stack.
76
- */
77
- export function pushFocusStack(element: HTMLElement): void {
78
- focusStack.push(element);
79
- }
80
-
81
- /**
82
- * Pop the last element from the focus stack.
83
- */
84
- export function popFocusStack(): HTMLElement | undefined {
85
- return focusStack.pop();
86
- }
87
-
88
- /**
89
- * Get the current focus stack length.
90
- */
91
- export function getFocusStackLength(): number {
92
- return focusStack.length;
93
- }
94
-
95
- /**
96
- * Clear the entire focus stack.
97
- */
98
- export function clearFocusStack(): void {
99
- focusStack.length = 0;
100
- }
101
-
102
- // ============================================
103
- // UTILITIES
104
- // ============================================
105
-
106
- /**
107
- * Gets the active element, accounting for shadow DOM.
108
- */
109
- function getActiveElement(doc: Document): HTMLElement | null {
110
- let activeElement = doc.activeElement as HTMLElement | null;
111
- while (activeElement?.shadowRoot?.activeElement) {
112
- activeElement = activeElement.shadowRoot.activeElement as HTMLElement;
113
- }
114
- return activeElement;
115
- }
116
-
117
- /**
118
- * Checks if an element is still valid for focus restoration.
119
- */
120
- function isValidForRestore(element: HTMLElement | null): boolean {
121
- if (!element) return false;
122
- if (!document.body.contains(element)) return false;
123
- if (element.hasAttribute('disabled')) return false;
124
- if (element.getAttribute('aria-disabled') === 'true') return false;
125
- if (element.getAttribute('aria-hidden') === 'true') return false;
126
- return true;
127
- }
128
-
129
- /**
130
- * Attempts to restore focus with retries.
131
- */
132
- function tryRestoreFocus(
133
- element: HTMLElement | null,
134
- options: Required<Pick<FocusRestoreOptions, 'maxRetries' | 'retryDelay' | 'preventScroll' | 'onRestore' | 'onRestoreFailed'>>
135
- ): void {
136
- const { maxRetries, retryDelay, preventScroll, onRestore, onRestoreFailed } = options;
137
- let attempts = 0;
138
-
139
- const attempt = () => {
140
- if (!element) {
141
- onRestoreFailed?.();
142
- return;
143
- }
144
-
145
- if (isValidForRestore(element)) {
146
- if (preventScroll) {
147
- focusSafely(element);
148
- } else {
149
- element.focus();
150
- }
151
- onRestore?.(element);
152
- return;
153
- }
154
-
155
- attempts++;
156
- if (attempts < maxRetries) {
157
- setTimeout(attempt, retryDelay);
158
- } else {
159
- onRestoreFailed?.();
160
- }
161
- };
162
-
163
- // Use requestAnimationFrame for the first attempt to ensure DOM is ready
164
- requestAnimationFrame(attempt);
165
- }
166
-
167
- // ============================================
168
- // HOOK
169
- // ============================================
170
-
171
- /**
172
- * Creates a focus restoration manager.
173
- *
174
- * This hook saves the currently focused element when mounted and provides
175
- * methods to restore focus later, with retry logic for reliability.
176
- *
177
- * @example
178
- * ```tsx
179
- * function Modal(props) {
180
- * const focusRestore = createFocusRestore({
181
- * restoreOnUnmount: true,
182
- * onRestore: () => console.log('Focus restored'),
183
- * });
184
- *
185
- * return (
186
- * <div role="dialog">
187
- * {props.children}
188
- * <button onClick={() => focusRestore.restore()}>
189
- * Close
190
- * </button>
191
- * </div>
192
- * );
193
- * }
194
- * ```
195
- *
196
- * @example
197
- * ```tsx
198
- * // Manual focus management
199
- * function Dropdown() {
200
- * const focusRestore = createFocusRestore({ restoreOnUnmount: false });
201
- *
202
- * const onOpen = () => {
203
- * focusRestore.saveCurrentFocus();
204
- * // Focus dropdown content
205
- * };
206
- *
207
- * const onClose = () => {
208
- * focusRestore.restore();
209
- * };
210
- *
211
- * return <div>...</div>;
212
- * }
213
- * ```
214
- */
215
- export function createFocusRestore(
216
- options: FocusRestoreOptions = {}
217
- ): FocusRestoreResult {
218
- const {
219
- restoreOnUnmount = true,
220
- maxRetries = 3,
221
- retryDelay = 50,
222
- onRestore,
223
- onRestoreFailed,
224
- preventScroll = true,
225
- } = options;
226
-
227
- // During SSR, return no-op functions
228
- if (isServer) {
229
- return {
230
- restore: () => false,
231
- getSavedElement: () => null,
232
- saveCurrentFocus: () => {},
233
- clear: () => {},
234
- };
235
- }
236
-
237
- let savedElement: HTMLElement | null = null;
238
-
239
- // Save focus on mount
240
- onMount(() => {
241
- saveCurrentFocus();
242
- });
243
-
244
- // Restore focus on cleanup
245
- onCleanup(() => {
246
- if (restoreOnUnmount && savedElement) {
247
- tryRestoreFocus(savedElement, {
248
- maxRetries,
249
- retryDelay,
250
- preventScroll,
251
- onRestore: onRestore ?? (() => {}),
252
- onRestoreFailed: onRestoreFailed ?? (() => {}),
253
- });
254
- }
255
- });
256
-
257
- function saveCurrentFocus(): void {
258
- const doc = typeof document !== 'undefined' ? document : null;
259
- if (!doc) return;
260
-
261
- const active = getActiveElement(doc);
262
- if (active && active !== doc.body) {
263
- savedElement = active;
264
- pushFocusStack(active);
265
- }
266
- }
267
-
268
- function restore(): boolean {
269
- if (!savedElement) return false;
270
-
271
- if (isValidForRestore(savedElement)) {
272
- if (preventScroll) {
273
- focusSafely(savedElement);
274
- } else {
275
- savedElement.focus();
276
- }
277
- onRestore?.(savedElement);
278
- return true;
279
- }
280
-
281
- // Try the focus stack
282
- while (focusStack.length > 0) {
283
- const stackElement = popFocusStack();
284
- if (stackElement && isValidForRestore(stackElement)) {
285
- if (preventScroll) {
286
- focusSafely(stackElement);
287
- } else {
288
- stackElement.focus();
289
- }
290
- onRestore?.(stackElement);
291
- return true;
292
- }
293
- }
294
-
295
- onRestoreFailed?.();
296
- return false;
297
- }
298
-
299
- function getSavedElement(): HTMLElement | null {
300
- return savedElement;
301
- }
302
-
303
- function clear(): void {
304
- savedElement = null;
305
- }
306
-
307
- return {
308
- restore,
309
- getSavedElement,
310
- saveCurrentFocus,
311
- clear,
312
- };
313
- }
@@ -1,396 +0,0 @@
1
- /**
2
- * Virtual focus management for solidaria
3
- *
4
- * Provides virtual focus for large collections where tracking DOM focus
5
- * on every item is impractical. Instead, a single element receives real
6
- * focus while aria-activedescendant indicates the virtually focused item.
7
- *
8
- * This is commonly used in:
9
- * - Virtualized lists (where not all items are in the DOM)
10
- * - Large trees
11
- * - Autocomplete/combobox suggestions
12
- * - Grid/table navigation
13
- */
14
-
15
- import { type Accessor, createSignal, createEffect, onCleanup } from 'solid-js';
16
- import { isServer } from 'solid-js/web';
17
-
18
- // ============================================
19
- // TYPES
20
- // ============================================
21
-
22
- export interface VirtualFocusOptions<T> {
23
- /**
24
- * The items in the collection.
25
- */
26
- items: Accessor<T[]>;
27
- /**
28
- * Function to get a unique key for each item.
29
- */
30
- getKey: (item: T) => string;
31
- /**
32
- * Function to check if an item is disabled.
33
- */
34
- isDisabled?: (item: T) => boolean;
35
- /**
36
- * Initial focused key.
37
- */
38
- defaultFocusedKey?: string;
39
- /**
40
- * Controlled focused key.
41
- */
42
- focusedKey?: Accessor<string | null>;
43
- /**
44
- * Callback when focused key changes.
45
- */
46
- onFocusChange?: (key: string | null) => void;
47
- /**
48
- * Whether to wrap focus at the edges.
49
- * @default true
50
- */
51
- wrap?: boolean;
52
- /**
53
- * Whether to loop through disabled items.
54
- * @default false
55
- */
56
- skipDisabled?: boolean;
57
- /**
58
- * Orientation for keyboard navigation.
59
- * @default 'vertical'
60
- */
61
- orientation?: 'horizontal' | 'vertical' | 'both';
62
- }
63
-
64
- export interface VirtualFocusResult<T> {
65
- /**
66
- * The currently focused key.
67
- */
68
- focusedKey: Accessor<string | null>;
69
- /**
70
- * The currently focused item (if any).
71
- */
72
- focusedItem: Accessor<T | null>;
73
- /**
74
- * Set the focused key.
75
- */
76
- setFocusedKey: (key: string | null) => void;
77
- /**
78
- * Move focus to the next item.
79
- */
80
- focusNext: () => void;
81
- /**
82
- * Move focus to the previous item.
83
- */
84
- focusPrevious: () => void;
85
- /**
86
- * Move focus to the first item.
87
- */
88
- focusFirst: () => void;
89
- /**
90
- * Move focus to the last item.
91
- */
92
- focusLast: () => void;
93
- /**
94
- * Move focus by a page (for large lists).
95
- */
96
- focusPageDown: (pageSize?: number) => void;
97
- /**
98
- * Move focus up by a page (for large lists).
99
- */
100
- focusPageUp: (pageSize?: number) => void;
101
- /**
102
- * Check if a key is the currently focused key.
103
- */
104
- isFocused: (key: string) => boolean;
105
- /**
106
- * Props to spread on the container element.
107
- */
108
- containerProps: {
109
- 'aria-activedescendant': Accessor<string | undefined>;
110
- onKeyDown: (e: KeyboardEvent) => void;
111
- };
112
- /**
113
- * Get props for an item element.
114
- */
115
- getItemProps: (key: string) => {
116
- id: string;
117
- 'aria-selected'?: boolean;
118
- };
119
- }
120
-
121
- // ============================================
122
- // CONSTANTS
123
- // ============================================
124
-
125
- const DEFAULT_PAGE_SIZE = 10;
126
-
127
- // ============================================
128
- // HOOK
129
- // ============================================
130
-
131
- /**
132
- * Creates virtual focus management for a collection.
133
- *
134
- * Virtual focus uses aria-activedescendant to indicate which item is
135
- * "focused" while keeping real DOM focus on a container element. This
136
- * is more performant for large collections and required for virtualized
137
- * lists where items may not be in the DOM.
138
- *
139
- * @example
140
- * ```tsx
141
- * function Listbox(props) {
142
- * const virtualFocus = createVirtualFocus({
143
- * items: () => props.items,
144
- * getKey: (item) => item.id,
145
- * isDisabled: (item) => item.disabled,
146
- * });
147
- *
148
- * return (
149
- * <ul
150
- * role="listbox"
151
- * tabIndex={0}
152
- * aria-activedescendant={virtualFocus.containerProps['aria-activedescendant']()}
153
- * onKeyDown={virtualFocus.containerProps.onKeyDown}
154
- * >
155
- * <For each={props.items}>
156
- * {(item) => (
157
- * <li
158
- * {...virtualFocus.getItemProps(item.id)}
159
- * role="option"
160
- * aria-selected={virtualFocus.isFocused(item.id)}
161
- * >
162
- * {item.name}
163
- * </li>
164
- * )}
165
- * </For>
166
- * </ul>
167
- * );
168
- * }
169
- * ```
170
- *
171
- * @example
172
- * ```tsx
173
- * // With controlled focus
174
- * function ControlledListbox() {
175
- * const [focusedKey, setFocusedKey] = createSignal<string | null>(null);
176
- *
177
- * const virtualFocus = createVirtualFocus({
178
- * items: () => items,
179
- * getKey: (item) => item.id,
180
- * focusedKey: focusedKey,
181
- * onFocusChange: setFocusedKey,
182
- * });
183
- *
184
- * return <ul>...</ul>;
185
- * }
186
- * ```
187
- */
188
- export function createVirtualFocus<T>(
189
- options: VirtualFocusOptions<T>
190
- ): VirtualFocusResult<T> {
191
- const {
192
- items,
193
- getKey,
194
- isDisabled = () => false,
195
- defaultFocusedKey,
196
- focusedKey: controlledFocusedKey,
197
- onFocusChange,
198
- wrap = true,
199
- skipDisabled = true,
200
- orientation = 'vertical',
201
- } = options;
202
-
203
- // During SSR, return minimal implementation
204
- if (isServer) {
205
- const emptyAccessor = () => null;
206
- return {
207
- focusedKey: emptyAccessor,
208
- focusedItem: emptyAccessor,
209
- setFocusedKey: () => {},
210
- focusNext: () => {},
211
- focusPrevious: () => {},
212
- focusFirst: () => {},
213
- focusLast: () => {},
214
- focusPageDown: () => {},
215
- focusPageUp: () => {},
216
- isFocused: () => false,
217
- containerProps: {
218
- 'aria-activedescendant': () => undefined,
219
- onKeyDown: () => {},
220
- },
221
- getItemProps: (key: string) => ({ id: `item-${key}` }),
222
- };
223
- }
224
-
225
- // Internal state for uncontrolled mode
226
- const [internalKey, setInternalKey] = createSignal<string | null>(
227
- defaultFocusedKey ?? null
228
- );
229
-
230
- // Use controlled or uncontrolled value
231
- const focusedKey = controlledFocusedKey ?? internalKey;
232
-
233
- const setFocusedKey = (key: string | null) => {
234
- if (controlledFocusedKey) {
235
- onFocusChange?.(key);
236
- } else {
237
- setInternalKey(key);
238
- onFocusChange?.(key);
239
- }
240
- };
241
-
242
- // Get focused item
243
- const focusedItem = (): T | null => {
244
- const key = focusedKey();
245
- if (!key) return null;
246
- return items().find((item) => getKey(item) === key) ?? null;
247
- };
248
-
249
- // Get valid items (not disabled if skipDisabled is true)
250
- const getValidItems = (): T[] => {
251
- if (!skipDisabled) return items();
252
- return items().filter((item) => !isDisabled(item));
253
- };
254
-
255
- // Get index of key in valid items
256
- const getKeyIndex = (key: string | null): number => {
257
- if (!key) return -1;
258
- const validItems = getValidItems();
259
- return validItems.findIndex((item) => getKey(item) === key);
260
- };
261
-
262
- // Focus by index
263
- const focusByIndex = (index: number): void => {
264
- const validItems = getValidItems();
265
- if (validItems.length === 0) return;
266
-
267
- let targetIndex = index;
268
-
269
- if (wrap) {
270
- targetIndex = ((index % validItems.length) + validItems.length) % validItems.length;
271
- } else {
272
- targetIndex = Math.max(0, Math.min(index, validItems.length - 1));
273
- }
274
-
275
- const item = validItems[targetIndex];
276
- if (item) {
277
- setFocusedKey(getKey(item));
278
- }
279
- };
280
-
281
- const focusNext = (): void => {
282
- const currentIndex = getKeyIndex(focusedKey());
283
- focusByIndex(currentIndex + 1);
284
- };
285
-
286
- const focusPrevious = (): void => {
287
- const currentIndex = getKeyIndex(focusedKey());
288
- if (currentIndex === -1) {
289
- focusByIndex(getValidItems().length - 1);
290
- } else {
291
- focusByIndex(currentIndex - 1);
292
- }
293
- };
294
-
295
- const focusFirst = (): void => {
296
- focusByIndex(0);
297
- };
298
-
299
- const focusLast = (): void => {
300
- focusByIndex(getValidItems().length - 1);
301
- };
302
-
303
- const focusPageDown = (pageSize: number = DEFAULT_PAGE_SIZE): void => {
304
- const currentIndex = getKeyIndex(focusedKey());
305
- focusByIndex(currentIndex + pageSize);
306
- };
307
-
308
- const focusPageUp = (pageSize: number = DEFAULT_PAGE_SIZE): void => {
309
- const currentIndex = getKeyIndex(focusedKey());
310
- if (currentIndex === -1) {
311
- focusByIndex(getValidItems().length - 1);
312
- } else {
313
- focusByIndex(currentIndex - pageSize);
314
- }
315
- };
316
-
317
- const isFocused = (key: string): boolean => {
318
- return focusedKey() === key;
319
- };
320
-
321
- // Keyboard handler
322
- const onKeyDown = (e: KeyboardEvent): void => {
323
- const isVertical = orientation === 'vertical' || orientation === 'both';
324
- const isHorizontal = orientation === 'horizontal' || orientation === 'both';
325
-
326
- switch (e.key) {
327
- case 'ArrowDown':
328
- if (isVertical) {
329
- e.preventDefault();
330
- focusNext();
331
- }
332
- break;
333
- case 'ArrowUp':
334
- if (isVertical) {
335
- e.preventDefault();
336
- focusPrevious();
337
- }
338
- break;
339
- case 'ArrowRight':
340
- if (isHorizontal) {
341
- e.preventDefault();
342
- focusNext();
343
- }
344
- break;
345
- case 'ArrowLeft':
346
- if (isHorizontal) {
347
- e.preventDefault();
348
- focusPrevious();
349
- }
350
- break;
351
- case 'Home':
352
- e.preventDefault();
353
- focusFirst();
354
- break;
355
- case 'End':
356
- e.preventDefault();
357
- focusLast();
358
- break;
359
- case 'PageDown':
360
- e.preventDefault();
361
- focusPageDown();
362
- break;
363
- case 'PageUp':
364
- e.preventDefault();
365
- focusPageUp();
366
- break;
367
- }
368
- };
369
-
370
- const containerProps = {
371
- 'aria-activedescendant': () => {
372
- const key = focusedKey();
373
- return key ? `item-${key}` : undefined;
374
- },
375
- onKeyDown,
376
- };
377
-
378
- const getItemProps = (key: string) => ({
379
- id: `item-${key}`,
380
- });
381
-
382
- return {
383
- focusedKey,
384
- focusedItem,
385
- setFocusedKey,
386
- focusNext,
387
- focusPrevious,
388
- focusFirst,
389
- focusLast,
390
- focusPageDown,
391
- focusPageUp,
392
- isFocused,
393
- containerProps,
394
- getItemProps,
395
- };
396
- }