@proyecto-viviana/solidaria 0.2.5 → 0.3.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 (555) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +31 -236
  3. package/dist/actiongroup/createActionGroup.d.ts +29 -0
  4. package/dist/actiongroup/createActionGroup.d.ts.map +1 -0
  5. package/dist/actiongroup/index.d.ts +2 -0
  6. package/dist/actiongroup/index.d.ts.map +1 -0
  7. package/dist/autocomplete/createAutocomplete.d.ts +16 -12
  8. package/dist/autocomplete/createAutocomplete.d.ts.map +1 -1
  9. package/dist/autocomplete/index.d.ts +1 -1
  10. package/dist/autocomplete/index.d.ts.map +1 -1
  11. package/dist/breadcrumbs/createBreadcrumbs.d.ts +11 -7
  12. package/dist/breadcrumbs/createBreadcrumbs.d.ts.map +1 -1
  13. package/dist/breadcrumbs/index.d.ts +1 -1
  14. package/dist/button/createButton.d.ts +1 -1
  15. package/dist/button/createButton.d.ts.map +1 -1
  16. package/dist/button/createToggleButton.d.ts +3 -3
  17. package/dist/button/createToggleButtonGroup.d.ts +32 -0
  18. package/dist/button/createToggleButtonGroup.d.ts.map +1 -0
  19. package/dist/button/index.d.ts +6 -4
  20. package/dist/button/index.d.ts.map +1 -1
  21. package/dist/button/types.d.ts +18 -12
  22. package/dist/button/types.d.ts.map +1 -1
  23. package/dist/calendar/createCalendar.d.ts +15 -5
  24. package/dist/calendar/createCalendar.d.ts.map +1 -1
  25. package/dist/calendar/createCalendarCell.d.ts +8 -2
  26. package/dist/calendar/createCalendarCell.d.ts.map +1 -1
  27. package/dist/calendar/createCalendarGrid.d.ts +4 -4
  28. package/dist/calendar/createCalendarGrid.d.ts.map +1 -1
  29. package/dist/calendar/createRangeCalendar.d.ts +15 -5
  30. package/dist/calendar/createRangeCalendar.d.ts.map +1 -1
  31. package/dist/calendar/createRangeCalendarCell.d.ts +7 -3
  32. package/dist/calendar/createRangeCalendarCell.d.ts.map +1 -1
  33. package/dist/calendar/index.d.ts +5 -5
  34. package/dist/calendar/index.d.ts.map +1 -1
  35. package/dist/calendar/intl/index.d.ts +12 -0
  36. package/dist/calendar/intl/index.d.ts.map +1 -0
  37. package/dist/calendar/utils.d.ts +12 -0
  38. package/dist/calendar/utils.d.ts.map +1 -0
  39. package/dist/checkbox/createCheckbox.d.ts +6 -6
  40. package/dist/checkbox/createCheckbox.d.ts.map +1 -1
  41. package/dist/checkbox/createCheckboxGroup.d.ts +11 -7
  42. package/dist/checkbox/createCheckboxGroup.d.ts.map +1 -1
  43. package/dist/checkbox/createCheckboxGroupItem.d.ts +4 -4
  44. package/dist/checkbox/createCheckboxGroupItem.d.ts.map +1 -1
  45. package/dist/checkbox/createCheckboxGroupState.d.ts +2 -2
  46. package/dist/checkbox/createCheckboxGroupState.d.ts.map +1 -1
  47. package/dist/checkbox/index.d.ts +8 -8
  48. package/dist/checkbox/index.d.ts.map +1 -1
  49. package/dist/collections/index.d.ts +56 -0
  50. package/dist/collections/index.d.ts.map +1 -0
  51. package/dist/color/createColorArea.d.ts +3 -3
  52. package/dist/color/createColorArea.d.ts.map +1 -1
  53. package/dist/color/createColorField.d.ts +4 -4
  54. package/dist/color/createColorField.d.ts.map +1 -1
  55. package/dist/color/createColorSlider.d.ts +4 -4
  56. package/dist/color/createColorSlider.d.ts.map +1 -1
  57. package/dist/color/createColorSwatch.d.ts +2 -2
  58. package/dist/color/createColorSwatch.d.ts.map +1 -1
  59. package/dist/color/createColorWheel.d.ts +3 -3
  60. package/dist/color/createColorWheel.d.ts.map +1 -1
  61. package/dist/color/index.d.ts +6 -6
  62. package/dist/color/types.d.ts +98 -16
  63. package/dist/color/types.d.ts.map +1 -1
  64. package/dist/combobox/createComboBox.d.ts +16 -7
  65. package/dist/combobox/createComboBox.d.ts.map +1 -1
  66. package/dist/combobox/index.d.ts +1 -1
  67. package/dist/combobox/intl/index.d.ts +1 -1
  68. package/dist/datepicker/createDateField.d.ts +18 -6
  69. package/dist/datepicker/createDateField.d.ts.map +1 -1
  70. package/dist/datepicker/createDatePicker.d.ts +57 -5
  71. package/dist/datepicker/createDatePicker.d.ts.map +1 -1
  72. package/dist/datepicker/createDatePickerGroup.d.ts +19 -0
  73. package/dist/datepicker/createDatePickerGroup.d.ts.map +1 -0
  74. package/dist/datepicker/createDateRangePicker.d.ts +42 -0
  75. package/dist/datepicker/createDateRangePicker.d.ts.map +1 -0
  76. package/dist/datepicker/createDateSegment.d.ts +11 -3
  77. package/dist/datepicker/createDateSegment.d.ts.map +1 -1
  78. package/dist/datepicker/createTimeField.d.ts +11 -5
  79. package/dist/datepicker/createTimeField.d.ts.map +1 -1
  80. package/dist/datepicker/createTimeSegment.d.ts +29 -0
  81. package/dist/datepicker/createTimeSegment.d.ts.map +1 -0
  82. package/dist/datepicker/index.d.ts +7 -4
  83. package/dist/datepicker/index.d.ts.map +1 -1
  84. package/dist/dialog/createDialog.d.ts +5 -5
  85. package/dist/dialog/createDialog.d.ts.map +1 -1
  86. package/dist/dialog/index.d.ts +2 -2
  87. package/dist/dialog/index.d.ts.map +1 -1
  88. package/dist/dialog/types.d.ts +4 -4
  89. package/dist/disclosure/createDisclosure.d.ts +5 -2
  90. package/dist/disclosure/createDisclosure.d.ts.map +1 -1
  91. package/dist/disclosure/createDisclosureGroup.d.ts +4 -3
  92. package/dist/disclosure/createDisclosureGroup.d.ts.map +1 -1
  93. package/dist/disclosure/index.d.ts +2 -2
  94. package/dist/dnd/createDrag.d.ts +2 -2
  95. package/dist/dnd/createDrag.d.ts.map +1 -1
  96. package/dist/dnd/createDraggableCollection.d.ts +6 -2
  97. package/dist/dnd/createDraggableCollection.d.ts.map +1 -1
  98. package/dist/dnd/createDraggableItem.d.ts +3 -3
  99. package/dist/dnd/createDraggableItem.d.ts.map +1 -1
  100. package/dist/dnd/createDrop.d.ts +2 -2
  101. package/dist/dnd/createDrop.d.ts.map +1 -1
  102. package/dist/dnd/createDroppableCollection.d.ts +55 -4
  103. package/dist/dnd/createDroppableCollection.d.ts.map +1 -1
  104. package/dist/dnd/createDroppableItem.d.ts +3 -3
  105. package/dist/dnd/createDroppableItem.d.ts.map +1 -1
  106. package/dist/dnd/index.d.ts +12 -12
  107. package/dist/dnd/index.d.ts.map +1 -1
  108. package/dist/dnd/types.d.ts +2 -2
  109. package/dist/dnd/types.d.ts.map +1 -1
  110. package/dist/dnd/utils.d.ts +1 -1
  111. package/dist/dnd/utils.d.ts.map +1 -1
  112. package/dist/focus/FocusScope.d.ts +1 -1
  113. package/dist/focus/FocusScope.d.ts.map +1 -1
  114. package/dist/focus/createAutoFocus.d.ts.map +1 -1
  115. package/dist/focus/createFocusRestore.d.ts.map +1 -1
  116. package/dist/focus/createVirtualFocus.d.ts +4 -4
  117. package/dist/focus/createVirtualFocus.d.ts.map +1 -1
  118. package/dist/focus/index.d.ts +4 -4
  119. package/dist/focus/index.d.ts.map +1 -1
  120. package/dist/form/createFormReset.d.ts +1 -1
  121. package/dist/form/createFormValidation.d.ts +3 -3
  122. package/dist/form/createFormValidation.d.ts.map +1 -1
  123. package/dist/form/index.d.ts +2 -2
  124. package/dist/form/index.d.ts.map +1 -1
  125. package/dist/grid/GridKeyboardDelegate.d.ts +5 -5
  126. package/dist/grid/createGrid.d.ts +3 -3
  127. package/dist/grid/createGrid.d.ts.map +1 -1
  128. package/dist/grid/createGridCell.d.ts +3 -3
  129. package/dist/grid/createGridRow.d.ts +3 -3
  130. package/dist/grid/index.d.ts +5 -5
  131. package/dist/grid/types.d.ts +8 -8
  132. package/dist/gridlist/createGridList.d.ts +6 -4
  133. package/dist/gridlist/createGridList.d.ts.map +1 -1
  134. package/dist/gridlist/createGridListItem.d.ts +4 -4
  135. package/dist/gridlist/createGridListItem.d.ts.map +1 -1
  136. package/dist/gridlist/createGridListSelectionCheckbox.d.ts +3 -3
  137. package/dist/gridlist/createGridListSelectionCheckbox.d.ts.map +1 -1
  138. package/dist/gridlist/index.d.ts +4 -4
  139. package/dist/gridlist/types.d.ts +11 -7
  140. package/dist/gridlist/types.d.ts.map +1 -1
  141. package/dist/i18n/createCollator.d.ts.map +1 -1
  142. package/dist/i18n/createDateFormatter.d.ts.map +1 -1
  143. package/dist/i18n/createFilter.d.ts.map +1 -1
  144. package/dist/i18n/createNumberFormatter.d.ts +1 -1
  145. package/dist/i18n/createNumberFormatter.d.ts.map +1 -1
  146. package/dist/i18n/createStringFormatter.d.ts +2 -2
  147. package/dist/i18n/createStringFormatter.d.ts.map +1 -1
  148. package/dist/i18n/index.d.ts +8 -8
  149. package/dist/i18n/index.d.ts.map +1 -1
  150. package/dist/i18n/locale.d.ts +2 -2
  151. package/dist/i18n/locale.d.ts.map +1 -1
  152. package/dist/i18n/utils.d.ts.map +1 -1
  153. package/dist/index.d.ts +52 -49
  154. package/dist/index.d.ts.map +1 -1
  155. package/dist/index.js +18089 -15690
  156. package/dist/index.js.map +1 -7
  157. package/dist/index.jsx +18242 -0
  158. package/dist/index.jsx.map +1 -0
  159. package/dist/interactions/FocusableProvider.d.ts +2 -2
  160. package/dist/interactions/FocusableProvider.d.ts.map +1 -1
  161. package/dist/interactions/PressEvent.d.ts +2 -2
  162. package/dist/interactions/createFocus.d.ts +1 -1
  163. package/dist/interactions/createFocus.d.ts.map +1 -1
  164. package/dist/interactions/createFocusRing.d.ts +1 -1
  165. package/dist/interactions/createFocusRing.d.ts.map +1 -1
  166. package/dist/interactions/createFocusWithin.d.ts +1 -1
  167. package/dist/interactions/createFocusWithin.d.ts.map +1 -1
  168. package/dist/interactions/createFocusable.d.ts +3 -3
  169. package/dist/interactions/createFocusable.d.ts.map +1 -1
  170. package/dist/interactions/createHover.d.ts +5 -5
  171. package/dist/interactions/createHover.d.ts.map +1 -1
  172. package/dist/interactions/createInteractionModality.d.ts +3 -3
  173. package/dist/interactions/createInteractionModality.d.ts.map +1 -1
  174. package/dist/interactions/createKeyboard.d.ts +1 -1
  175. package/dist/interactions/createLongPress.d.ts +5 -5
  176. package/dist/interactions/createMove.d.ts +5 -5
  177. package/dist/interactions/createMove.d.ts.map +1 -1
  178. package/dist/interactions/createPress.d.ts +4 -4
  179. package/dist/interactions/createPress.d.ts.map +1 -1
  180. package/dist/interactions/index.d.ts +12 -12
  181. package/dist/interactions/index.d.ts.map +1 -1
  182. package/dist/label/createField.d.ts +4 -4
  183. package/dist/label/createField.d.ts.map +1 -1
  184. package/dist/label/createLabel.d.ts +7 -7
  185. package/dist/label/createLabel.d.ts.map +1 -1
  186. package/dist/label/createLabels.d.ts +1 -1
  187. package/dist/label/createLabels.d.ts.map +1 -1
  188. package/dist/label/index.d.ts +5 -5
  189. package/dist/landmark/createLandmark.d.ts +5 -5
  190. package/dist/landmark/createLandmark.d.ts.map +1 -1
  191. package/dist/landmark/index.d.ts +1 -1
  192. package/dist/link/createLink.d.ts +23 -7
  193. package/dist/link/createLink.d.ts.map +1 -1
  194. package/dist/link/index.d.ts +1 -1
  195. package/dist/listbox/createListBox.d.ts +12 -6
  196. package/dist/listbox/createListBox.d.ts.map +1 -1
  197. package/dist/listbox/createOption.d.ts +21 -4
  198. package/dist/listbox/createOption.d.ts.map +1 -1
  199. package/dist/listbox/index.d.ts +2 -2
  200. package/dist/listbox/index.d.ts.map +1 -1
  201. package/dist/live-announcer/announce.d.ts +2 -2
  202. package/dist/live-announcer/announce.d.ts.map +1 -1
  203. package/dist/live-announcer/index.d.ts +1 -1
  204. package/dist/menu/createMenu.d.ts +8 -7
  205. package/dist/menu/createMenu.d.ts.map +1 -1
  206. package/dist/menu/createMenuItem.d.ts +16 -4
  207. package/dist/menu/createMenuItem.d.ts.map +1 -1
  208. package/dist/menu/createMenuTrigger.d.ts +4 -4
  209. package/dist/menu/index.d.ts +3 -3
  210. package/dist/menu/index.d.ts.map +1 -1
  211. package/dist/meter/createMeter.d.ts +6 -6
  212. package/dist/meter/createMeter.d.ts.map +1 -1
  213. package/dist/meter/index.d.ts +1 -1
  214. package/dist/numberfield/createNumberField.d.ts +27 -8
  215. package/dist/numberfield/createNumberField.d.ts.map +1 -1
  216. package/dist/numberfield/index.d.ts +1 -1
  217. package/dist/overlays/ariaHideOutside.d.ts.map +1 -1
  218. package/dist/overlays/createModal.d.ts +19 -3
  219. package/dist/overlays/createModal.d.ts.map +1 -1
  220. package/dist/overlays/createOverlay.d.ts +1 -1
  221. package/dist/overlays/createOverlay.d.ts.map +1 -1
  222. package/dist/overlays/createOverlayTrigger.d.ts +6 -6
  223. package/dist/overlays/index.d.ts +6 -6
  224. package/dist/overlays/index.d.ts.map +1 -1
  225. package/dist/popover/calculatePosition.d.ts +4 -4
  226. package/dist/popover/calculatePosition.d.ts.map +1 -1
  227. package/dist/popover/createOverlayPosition.d.ts +3 -3
  228. package/dist/popover/createOverlayPosition.d.ts.map +1 -1
  229. package/dist/popover/createPopover.d.ts +4 -4
  230. package/dist/popover/createPopover.d.ts.map +1 -1
  231. package/dist/popover/index.d.ts +3 -3
  232. package/dist/progress/createProgressBar.d.ts +7 -5
  233. package/dist/progress/createProgressBar.d.ts.map +1 -1
  234. package/dist/progress/index.d.ts +1 -1
  235. package/dist/radio/createRadio.d.ts +7 -7
  236. package/dist/radio/createRadio.d.ts.map +1 -1
  237. package/dist/radio/createRadioGroup.d.ts +11 -11
  238. package/dist/radio/createRadioGroup.d.ts.map +1 -1
  239. package/dist/radio/createRadioGroupState.d.ts +3 -3
  240. package/dist/radio/createRadioGroupState.d.ts.map +1 -1
  241. package/dist/radio/index.d.ts +3 -3
  242. package/dist/radio/index.d.ts.map +1 -1
  243. package/dist/searchfield/createSearchField.d.ts +7 -7
  244. package/dist/searchfield/createSearchField.d.ts.map +1 -1
  245. package/dist/searchfield/index.d.ts +2 -2
  246. package/dist/select/createHiddenSelect.d.ts +4 -4
  247. package/dist/select/createHiddenSelect.d.ts.map +1 -1
  248. package/dist/select/createSelect.d.ts +14 -6
  249. package/dist/select/createSelect.d.ts.map +1 -1
  250. package/dist/select/index.d.ts +2 -2
  251. package/dist/select/index.d.ts.map +1 -1
  252. package/dist/selection/createTypeSelect.d.ts +2 -2
  253. package/dist/selection/index.d.ts +1 -1
  254. package/dist/separator/createSeparator.d.ts +9 -5
  255. package/dist/separator/createSeparator.d.ts.map +1 -1
  256. package/dist/separator/index.d.ts +1 -1
  257. package/dist/slider/createSlider.d.ts +11 -7
  258. package/dist/slider/createSlider.d.ts.map +1 -1
  259. package/dist/slider/index.d.ts +2 -2
  260. package/dist/ssr/index.d.ts +1 -1
  261. package/dist/ssr/index.d.ts.map +1 -1
  262. package/dist/steplist/createStepList.d.ts +36 -0
  263. package/dist/steplist/createStepList.d.ts.map +1 -0
  264. package/dist/steplist/index.d.ts +2 -0
  265. package/dist/steplist/index.d.ts.map +1 -0
  266. package/dist/switch/createSwitch.d.ts +6 -4
  267. package/dist/switch/createSwitch.d.ts.map +1 -1
  268. package/dist/switch/index.d.ts +1 -1
  269. package/dist/table/createTable.d.ts +3 -3
  270. package/dist/table/createTable.d.ts.map +1 -1
  271. package/dist/table/createTableCell.d.ts +3 -3
  272. package/dist/table/createTableCell.d.ts.map +1 -1
  273. package/dist/table/createTableColumnHeader.d.ts +3 -3
  274. package/dist/table/createTableColumnHeader.d.ts.map +1 -1
  275. package/dist/table/createTableColumnResize.d.ts +41 -0
  276. package/dist/table/createTableColumnResize.d.ts.map +1 -0
  277. package/dist/table/createTableHeaderRow.d.ts +3 -3
  278. package/dist/table/createTableRow.d.ts +3 -3
  279. package/dist/table/createTableRow.d.ts.map +1 -1
  280. package/dist/table/createTableRowGroup.d.ts +2 -2
  281. package/dist/table/createTableRowGroup.d.ts.map +1 -1
  282. package/dist/table/createTableSelectAllCheckbox.d.ts +3 -3
  283. package/dist/table/createTableSelectAllCheckbox.d.ts.map +1 -1
  284. package/dist/table/createTableSelectionCheckbox.d.ts +3 -3
  285. package/dist/table/index.d.ts +11 -9
  286. package/dist/table/index.d.ts.map +1 -1
  287. package/dist/table/types.d.ts +15 -7
  288. package/dist/table/types.d.ts.map +1 -1
  289. package/dist/tabs/createTabs.d.ts +28 -25
  290. package/dist/tabs/createTabs.d.ts.map +1 -1
  291. package/dist/tabs/index.d.ts +1 -1
  292. package/dist/tag/createTag.d.ts +2 -2
  293. package/dist/tag/createTag.d.ts.map +1 -1
  294. package/dist/tag/createTagGroup.d.ts +5 -5
  295. package/dist/tag/createTagGroup.d.ts.map +1 -1
  296. package/dist/tag/index.d.ts +2 -2
  297. package/dist/tag/index.d.ts.map +1 -1
  298. package/dist/textfield/createTextField.d.ts +17 -11
  299. package/dist/textfield/createTextField.d.ts.map +1 -1
  300. package/dist/textfield/index.d.ts +1 -1
  301. package/dist/textfield/index.d.ts.map +1 -1
  302. package/dist/toast/createToast.d.ts +6 -2
  303. package/dist/toast/createToast.d.ts.map +1 -1
  304. package/dist/toast/createToastRegion.d.ts +5 -3
  305. package/dist/toast/createToastRegion.d.ts.map +1 -1
  306. package/dist/toast/index.d.ts +2 -2
  307. package/dist/toast/index.d.ts.map +1 -1
  308. package/dist/toggle/createToggle.d.ts +9 -9
  309. package/dist/toggle/createToggle.d.ts.map +1 -1
  310. package/dist/toggle/createToggleState.d.ts +2 -2
  311. package/dist/toggle/createToggleState.d.ts.map +1 -1
  312. package/dist/toggle/index.d.ts +4 -4
  313. package/dist/toggle/index.d.ts.map +1 -1
  314. package/dist/toolbar/createToolbar.d.ts +9 -9
  315. package/dist/toolbar/createToolbar.d.ts.map +1 -1
  316. package/dist/toolbar/index.d.ts +1 -1
  317. package/dist/toolbar/index.d.ts.map +1 -1
  318. package/dist/tooltip/createTooltip.d.ts +5 -5
  319. package/dist/tooltip/createTooltip.d.ts.map +1 -1
  320. package/dist/tooltip/createTooltipTrigger.d.ts +10 -5
  321. package/dist/tooltip/createTooltipTrigger.d.ts.map +1 -1
  322. package/dist/tooltip/index.d.ts +2 -2
  323. package/dist/tree/createTree.d.ts +3 -3
  324. package/dist/tree/createTree.d.ts.map +1 -1
  325. package/dist/tree/createTreeItem.d.ts +4 -4
  326. package/dist/tree/createTreeItem.d.ts.map +1 -1
  327. package/dist/tree/createTreeSelectionCheckbox.d.ts +3 -3
  328. package/dist/tree/createTreeSelectionCheckbox.d.ts.map +1 -1
  329. package/dist/tree/index.d.ts +4 -4
  330. package/dist/tree/types.d.ts +13 -5
  331. package/dist/tree/types.d.ts.map +1 -1
  332. package/dist/utils/createDescription.d.ts +2 -2
  333. package/dist/utils/createDescription.d.ts.map +1 -1
  334. package/dist/utils/dom.d.ts.map +1 -1
  335. package/dist/utils/env.d.ts +1 -1
  336. package/dist/utils/env.d.ts.map +1 -1
  337. package/dist/utils/focus.d.ts +1 -1
  338. package/dist/utils/focus.d.ts.map +1 -1
  339. package/dist/utils/geometry.d.ts.map +1 -1
  340. package/dist/utils/index.d.ts +12 -12
  341. package/dist/utils/index.d.ts.map +1 -1
  342. package/dist/utils/mergeProps.d.ts.map +1 -1
  343. package/dist/utils/platform.d.ts.map +1 -1
  344. package/dist/utils/reactivity.d.ts +1 -1
  345. package/dist/visually-hidden/createVisuallyHidden.d.ts +2 -2
  346. package/dist/visually-hidden/createVisuallyHidden.d.ts.map +1 -1
  347. package/dist/visually-hidden/index.d.ts +1 -1
  348. package/package.json +34 -32
  349. package/src/actiongroup/createActionGroup.ts +334 -0
  350. package/src/actiongroup/index.ts +8 -0
  351. package/src/autocomplete/createAutocomplete.ts +137 -131
  352. package/src/autocomplete/index.ts +1 -1
  353. package/src/breadcrumbs/createBreadcrumbs.ts +37 -51
  354. package/src/breadcrumbs/index.ts +1 -1
  355. package/src/button/createButton.ts +102 -73
  356. package/src/button/createToggleButton.ts +10 -10
  357. package/src/button/createToggleButtonGroup.ts +121 -0
  358. package/src/button/index.ts +10 -4
  359. package/src/button/types.ts +18 -12
  360. package/src/calendar/createCalendar.ts +62 -29
  361. package/src/calendar/createCalendarCell.ts +102 -48
  362. package/src/calendar/createCalendarGrid.ts +78 -47
  363. package/src/calendar/createRangeCalendar.ts +66 -31
  364. package/src/calendar/createRangeCalendarCell.ts +115 -37
  365. package/src/calendar/index.ts +5 -9
  366. package/src/calendar/intl/index.ts +210 -0
  367. package/src/calendar/utils.ts +227 -0
  368. package/src/checkbox/createCheckbox.ts +13 -21
  369. package/src/checkbox/createCheckboxGroup.ts +86 -45
  370. package/src/checkbox/createCheckboxGroupItem.ts +16 -27
  371. package/src/checkbox/createCheckboxGroupState.ts +3 -22
  372. package/src/checkbox/index.ts +8 -10
  373. package/src/collections/index.ts +246 -0
  374. package/src/color/createColorArea.ts +458 -314
  375. package/src/color/createColorField.ts +186 -137
  376. package/src/color/createColorSlider.ts +444 -197
  377. package/src/color/createColorSwatch.ts +65 -40
  378. package/src/color/createColorWheel.ts +343 -208
  379. package/src/color/index.ts +24 -24
  380. package/src/color/types.ts +198 -116
  381. package/src/combobox/createComboBox.ts +727 -647
  382. package/src/combobox/index.ts +6 -6
  383. package/src/combobox/intl/index.ts +5 -5
  384. package/src/datepicker/createDateField.ts +192 -39
  385. package/src/datepicker/createDatePicker.ts +294 -63
  386. package/src/datepicker/createDatePickerGroup.ts +149 -0
  387. package/src/datepicker/createDateRangePicker.ts +294 -0
  388. package/src/datepicker/createDateSegment.ts +316 -75
  389. package/src/datepicker/createTimeField.ts +38 -34
  390. package/src/datepicker/createTimeSegment.ts +352 -0
  391. package/src/datepicker/index.ts +24 -11
  392. package/src/dialog/createDialog.ts +127 -120
  393. package/src/dialog/index.ts +2 -2
  394. package/src/dialog/types.ts +19 -19
  395. package/src/disclosure/createDisclosure.ts +138 -33
  396. package/src/disclosure/createDisclosureGroup.ts +8 -18
  397. package/src/disclosure/index.ts +2 -2
  398. package/src/dnd/createDrag.ts +218 -209
  399. package/src/dnd/createDraggableCollection.ts +96 -63
  400. package/src/dnd/createDraggableItem.ts +260 -243
  401. package/src/dnd/createDrop.ts +313 -321
  402. package/src/dnd/createDroppableCollection.ts +799 -293
  403. package/src/dnd/createDroppableItem.ts +215 -213
  404. package/src/dnd/index.ts +66 -47
  405. package/src/dnd/types.ts +86 -89
  406. package/src/dnd/utils.ts +281 -294
  407. package/src/focus/FocusScope.tsx +155 -164
  408. package/src/focus/createAutoFocus.ts +305 -321
  409. package/src/focus/createFocusRestore.ts +300 -313
  410. package/src/focus/createVirtualFocus.ts +380 -396
  411. package/src/focus/index.ts +4 -8
  412. package/src/form/createFormReset.ts +4 -4
  413. package/src/form/createFormValidation.ts +201 -224
  414. package/src/form/index.ts +8 -11
  415. package/src/grid/GridKeyboardDelegate.ts +30 -30
  416. package/src/grid/createGrid.ts +38 -36
  417. package/src/grid/createGridCell.ts +18 -18
  418. package/src/grid/createGridRow.ts +14 -14
  419. package/src/grid/index.ts +5 -5
  420. package/src/grid/types.ts +8 -8
  421. package/src/gridlist/createGridList.ts +45 -24
  422. package/src/gridlist/createGridListItem.ts +68 -23
  423. package/src/gridlist/createGridListSelectionCheckbox.ts +12 -9
  424. package/src/gridlist/index.ts +4 -4
  425. package/src/gridlist/types.ts +11 -7
  426. package/src/i18n/createCollator.ts +66 -79
  427. package/src/i18n/createDateFormatter.ts +75 -83
  428. package/src/i18n/createFilter.ts +118 -131
  429. package/src/i18n/createNumberFormatter.ts +50 -52
  430. package/src/i18n/createStringFormatter.ts +19 -15
  431. package/src/i18n/index.ts +37 -40
  432. package/src/i18n/locale.tsx +163 -188
  433. package/src/i18n/utils.ts +95 -99
  434. package/src/index.ts +114 -164
  435. package/src/interactions/FocusableProvider.tsx +3 -7
  436. package/src/interactions/PressEvent.ts +4 -4
  437. package/src/interactions/createFocus.ts +16 -11
  438. package/src/interactions/createFocusRing.ts +21 -19
  439. package/src/interactions/createFocusWithin.ts +24 -16
  440. package/src/interactions/createFocusable.ts +15 -16
  441. package/src/interactions/createHover.ts +70 -55
  442. package/src/interactions/createInteractionModality.ts +75 -82
  443. package/src/interactions/createKeyboard.ts +2 -2
  444. package/src/interactions/createLongPress.ts +174 -174
  445. package/src/interactions/createMove.ts +299 -289
  446. package/src/interactions/createPress.ts +168 -91
  447. package/src/interactions/index.ts +24 -16
  448. package/src/label/createField.ts +18 -19
  449. package/src/label/createLabel.ts +18 -30
  450. package/src/label/createLabels.ts +8 -12
  451. package/src/label/index.ts +5 -5
  452. package/src/landmark/createLandmark.ts +356 -377
  453. package/src/landmark/index.ts +8 -8
  454. package/src/link/createLink.ts +96 -54
  455. package/src/link/index.ts +1 -1
  456. package/src/listbox/createListBox.ts +319 -269
  457. package/src/listbox/createOption.ts +208 -151
  458. package/src/listbox/index.ts +8 -12
  459. package/src/live-announcer/announce.ts +295 -322
  460. package/src/live-announcer/index.ts +9 -9
  461. package/src/menu/createMenu.ts +434 -396
  462. package/src/menu/createMenuItem.ts +201 -149
  463. package/src/menu/createMenuTrigger.ts +88 -88
  464. package/src/menu/index.ts +9 -18
  465. package/src/meter/createMeter.ts +7 -20
  466. package/src/meter/index.ts +1 -1
  467. package/src/numberfield/createNumberField.ts +368 -268
  468. package/src/numberfield/index.ts +5 -5
  469. package/src/overlays/ariaHideOutside.ts +223 -219
  470. package/src/overlays/createInteractOutside.ts +152 -149
  471. package/src/overlays/createModal.tsx +238 -202
  472. package/src/overlays/createOverlay.ts +195 -155
  473. package/src/overlays/createOverlayTrigger.ts +85 -85
  474. package/src/overlays/createPreventScroll.ts +288 -266
  475. package/src/overlays/index.ts +37 -44
  476. package/src/popover/calculatePosition.ts +117 -119
  477. package/src/popover/createOverlayPosition.ts +52 -43
  478. package/src/popover/createPopover.ts +63 -24
  479. package/src/popover/index.ts +3 -3
  480. package/src/progress/createProgressBar.ts +36 -32
  481. package/src/progress/index.ts +1 -1
  482. package/src/radio/createRadio.ts +95 -73
  483. package/src/radio/createRadioGroup.ts +142 -62
  484. package/src/radio/createRadioGroupState.ts +7 -31
  485. package/src/radio/index.ts +3 -8
  486. package/src/searchfield/createSearchField.ts +269 -186
  487. package/src/searchfield/index.ts +2 -2
  488. package/src/select/createHiddenSelect.tsx +276 -236
  489. package/src/select/createSelect.ts +430 -395
  490. package/src/select/index.ts +9 -14
  491. package/src/selection/createTypeSelect.ts +11 -11
  492. package/src/selection/index.ts +1 -1
  493. package/src/separator/createSeparator.ts +20 -25
  494. package/src/separator/index.ts +1 -1
  495. package/src/slider/createSlider.ts +333 -349
  496. package/src/slider/index.ts +2 -2
  497. package/src/ssr/index.tsx +331 -370
  498. package/src/steplist/createStepList.ts +106 -0
  499. package/src/steplist/index.ts +8 -0
  500. package/src/switch/createSwitch.ts +9 -14
  501. package/src/switch/index.ts +1 -1
  502. package/src/table/createTable.ts +155 -86
  503. package/src/table/createTableCell.ts +17 -16
  504. package/src/table/createTableColumnHeader.ts +67 -20
  505. package/src/table/createTableColumnResize.ts +256 -0
  506. package/src/table/createTableHeaderRow.ts +7 -7
  507. package/src/table/createTableRow.ts +149 -29
  508. package/src/table/createTableRowGroup.ts +5 -7
  509. package/src/table/createTableSelectAllCheckbox.ts +12 -11
  510. package/src/table/createTableSelectionCheckbox.ts +8 -8
  511. package/src/table/index.ts +14 -9
  512. package/src/table/types.ts +15 -7
  513. package/src/tabs/createTabs.ts +138 -127
  514. package/src/tabs/index.ts +1 -1
  515. package/src/tag/createTag.ts +171 -40
  516. package/src/tag/createTagGroup.ts +50 -39
  517. package/src/tag/index.ts +2 -6
  518. package/src/textfield/createTextField.ts +67 -35
  519. package/src/textfield/index.ts +1 -5
  520. package/src/toast/createToast.ts +34 -26
  521. package/src/toast/createToastRegion.ts +169 -27
  522. package/src/toast/index.ts +2 -6
  523. package/src/toggle/createToggle.ts +95 -53
  524. package/src/toggle/createToggleState.ts +2 -10
  525. package/src/toggle/index.ts +4 -5
  526. package/src/toolbar/createToolbar.ts +226 -169
  527. package/src/toolbar/index.ts +1 -1
  528. package/src/tooltip/createTooltip.ts +66 -79
  529. package/src/tooltip/createTooltipTrigger.ts +238 -222
  530. package/src/tooltip/index.ts +6 -6
  531. package/src/tree/createTree.ts +259 -246
  532. package/src/tree/createTreeItem.ts +282 -233
  533. package/src/tree/createTreeSelectionCheckbox.ts +71 -68
  534. package/src/tree/index.ts +16 -16
  535. package/src/tree/types.ts +95 -87
  536. package/src/utils/createDescription.ts +6 -23
  537. package/src/utils/dom.ts +61 -54
  538. package/src/utils/env.ts +53 -54
  539. package/src/utils/events.ts +7 -7
  540. package/src/utils/filterDOMProps.ts +49 -49
  541. package/src/utils/focus.ts +60 -68
  542. package/src/utils/geometry.ts +1 -4
  543. package/src/utils/globalListeners.ts +9 -9
  544. package/src/utils/index.ts +12 -22
  545. package/src/utils/mergeProps.ts +42 -15
  546. package/src/utils/platform.ts +16 -6
  547. package/src/utils/reactivity.ts +3 -3
  548. package/src/utils/textSelection.ts +16 -16
  549. package/src/visually-hidden/createVisuallyHidden.ts +127 -124
  550. package/src/visually-hidden/index.ts +6 -6
  551. package/dist/i18n/NumberFormatter.d.ts +0 -43
  552. package/dist/i18n/NumberFormatter.d.ts.map +0 -1
  553. package/dist/index.ssr.js +0 -15875
  554. package/dist/index.ssr.js.map +0 -7
  555. package/src/i18n/NumberFormatter.ts +0 -266
@@ -1,396 +1,380 @@
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
- }
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
+ export interface VirtualFocusOptions<T> {
19
+ /**
20
+ * The items in the collection.
21
+ */
22
+ items: Accessor<T[]>;
23
+ /**
24
+ * Function to get a unique key for each item.
25
+ */
26
+ getKey: (item: T) => string;
27
+ /**
28
+ * Function to check if an item is disabled.
29
+ */
30
+ isDisabled?: (item: T) => boolean;
31
+ /**
32
+ * Initial focused key.
33
+ */
34
+ defaultFocusedKey?: string;
35
+ /**
36
+ * Controlled focused key.
37
+ */
38
+ focusedKey?: Accessor<string | null>;
39
+ /**
40
+ * Callback when focused key changes.
41
+ */
42
+ onFocusChange?: (key: string | null) => void;
43
+ /**
44
+ * Whether to wrap focus at the edges.
45
+ * @default true
46
+ */
47
+ wrap?: boolean;
48
+ /**
49
+ * Whether to loop through disabled items.
50
+ * @default false
51
+ */
52
+ skipDisabled?: boolean;
53
+ /**
54
+ * Orientation for keyboard navigation.
55
+ * @default 'vertical'
56
+ */
57
+ orientation?: "horizontal" | "vertical" | "both";
58
+ }
59
+
60
+ export interface VirtualFocusResult<T> {
61
+ /**
62
+ * The currently focused key.
63
+ */
64
+ focusedKey: Accessor<string | null>;
65
+ /**
66
+ * The currently focused item (if any).
67
+ */
68
+ focusedItem: Accessor<T | null>;
69
+ /**
70
+ * Set the focused key.
71
+ */
72
+ setFocusedKey: (key: string | null) => void;
73
+ /**
74
+ * Move focus to the next item.
75
+ */
76
+ focusNext: () => void;
77
+ /**
78
+ * Move focus to the previous item.
79
+ */
80
+ focusPrevious: () => void;
81
+ /**
82
+ * Move focus to the first item.
83
+ */
84
+ focusFirst: () => void;
85
+ /**
86
+ * Move focus to the last item.
87
+ */
88
+ focusLast: () => void;
89
+ /**
90
+ * Move focus by a page (for large lists).
91
+ */
92
+ focusPageDown: (pageSize?: number) => void;
93
+ /**
94
+ * Move focus up by a page (for large lists).
95
+ */
96
+ focusPageUp: (pageSize?: number) => void;
97
+ /**
98
+ * Check if a key is the currently focused key.
99
+ */
100
+ isFocused: (key: string) => boolean;
101
+ /**
102
+ * Props to spread on the container element.
103
+ */
104
+ containerProps: {
105
+ "aria-activedescendant": Accessor<string | undefined>;
106
+ onKeyDown: (e: KeyboardEvent) => void;
107
+ };
108
+ /**
109
+ * Get props for an item element.
110
+ */
111
+ getItemProps: (key: string) => {
112
+ id: string;
113
+ "aria-selected"?: boolean;
114
+ };
115
+ }
116
+
117
+ const DEFAULT_PAGE_SIZE = 10;
118
+
119
+ /**
120
+ * Creates virtual focus management for a collection.
121
+ *
122
+ * Virtual focus uses aria-activedescendant to indicate which item is
123
+ * "focused" while keeping real DOM focus on a container element. This
124
+ * is more performant for large collections and required for virtualized
125
+ * lists where items may not be in the DOM.
126
+ *
127
+ * @example
128
+ * ```tsx
129
+ * function Listbox(props) {
130
+ * const virtualFocus = createVirtualFocus({
131
+ * items: () => props.items,
132
+ * getKey: (item) => item.id,
133
+ * isDisabled: (item) => item.disabled,
134
+ * });
135
+ *
136
+ * return (
137
+ * <ul
138
+ * role="listbox"
139
+ * tabIndex={0}
140
+ * aria-activedescendant={virtualFocus.containerProps['aria-activedescendant']()}
141
+ * onKeyDown={virtualFocus.containerProps.onKeyDown}
142
+ * >
143
+ * <For each={props.items}>
144
+ * {(item) => (
145
+ * <li
146
+ * {...virtualFocus.getItemProps(item.id)}
147
+ * role="option"
148
+ * aria-selected={virtualFocus.isFocused(item.id)}
149
+ * >
150
+ * {item.name}
151
+ * </li>
152
+ * )}
153
+ * </For>
154
+ * </ul>
155
+ * );
156
+ * }
157
+ * ```
158
+ *
159
+ * @example
160
+ * ```tsx
161
+ * // With controlled focus
162
+ * function ControlledListbox() {
163
+ * const [focusedKey, setFocusedKey] = createSignal<string | null>(null);
164
+ *
165
+ * const virtualFocus = createVirtualFocus({
166
+ * items: () => items,
167
+ * getKey: (item) => item.id,
168
+ * focusedKey: focusedKey,
169
+ * onFocusChange: setFocusedKey,
170
+ * });
171
+ *
172
+ * return <ul>...</ul>;
173
+ * }
174
+ * ```
175
+ */
176
+ export function createVirtualFocus<T>(options: VirtualFocusOptions<T>): VirtualFocusResult<T> {
177
+ const {
178
+ items,
179
+ getKey,
180
+ isDisabled = () => false,
181
+ defaultFocusedKey,
182
+ focusedKey: controlledFocusedKey,
183
+ onFocusChange,
184
+ wrap = true,
185
+ skipDisabled = true,
186
+ orientation = "vertical",
187
+ } = options;
188
+
189
+ // During SSR, return minimal implementation
190
+ if (isServer) {
191
+ const emptyAccessor = () => null;
192
+ return {
193
+ focusedKey: emptyAccessor,
194
+ focusedItem: emptyAccessor,
195
+ setFocusedKey: () => {},
196
+ focusNext: () => {},
197
+ focusPrevious: () => {},
198
+ focusFirst: () => {},
199
+ focusLast: () => {},
200
+ focusPageDown: () => {},
201
+ focusPageUp: () => {},
202
+ isFocused: () => false,
203
+ containerProps: {
204
+ "aria-activedescendant": () => undefined,
205
+ onKeyDown: () => {},
206
+ },
207
+ getItemProps: (key: string) => ({ id: `item-${key}` }),
208
+ };
209
+ }
210
+
211
+ // Internal state for uncontrolled mode
212
+ const [internalKey, setInternalKey] = createSignal<string | null>(defaultFocusedKey ?? null);
213
+
214
+ // Use controlled or uncontrolled value
215
+ const focusedKey = controlledFocusedKey ?? internalKey;
216
+
217
+ const setFocusedKey = (key: string | null) => {
218
+ if (controlledFocusedKey) {
219
+ onFocusChange?.(key);
220
+ } else {
221
+ setInternalKey(key);
222
+ onFocusChange?.(key);
223
+ }
224
+ };
225
+
226
+ // Get focused item
227
+ const focusedItem = (): T | null => {
228
+ const key = focusedKey();
229
+ if (!key) return null;
230
+ return items().find((item) => getKey(item) === key) ?? null;
231
+ };
232
+
233
+ // Get valid items (not disabled if skipDisabled is true)
234
+ const getValidItems = (): T[] => {
235
+ if (!skipDisabled) return items();
236
+ return items().filter((item) => !isDisabled(item));
237
+ };
238
+
239
+ // Get index of key in valid items
240
+ const getKeyIndex = (key: string | null): number => {
241
+ if (!key) return -1;
242
+ const validItems = getValidItems();
243
+ return validItems.findIndex((item) => getKey(item) === key);
244
+ };
245
+
246
+ // Focus by index
247
+ const focusByIndex = (index: number): void => {
248
+ const validItems = getValidItems();
249
+ if (validItems.length === 0) return;
250
+
251
+ let targetIndex = index;
252
+
253
+ if (wrap) {
254
+ targetIndex = ((index % validItems.length) + validItems.length) % validItems.length;
255
+ } else {
256
+ targetIndex = Math.max(0, Math.min(index, validItems.length - 1));
257
+ }
258
+
259
+ const item = validItems[targetIndex];
260
+ if (item) {
261
+ setFocusedKey(getKey(item));
262
+ }
263
+ };
264
+
265
+ const focusNext = (): void => {
266
+ const currentIndex = getKeyIndex(focusedKey());
267
+ focusByIndex(currentIndex + 1);
268
+ };
269
+
270
+ const focusPrevious = (): void => {
271
+ const currentIndex = getKeyIndex(focusedKey());
272
+ if (currentIndex === -1) {
273
+ focusByIndex(getValidItems().length - 1);
274
+ } else {
275
+ focusByIndex(currentIndex - 1);
276
+ }
277
+ };
278
+
279
+ const focusFirst = (): void => {
280
+ focusByIndex(0);
281
+ };
282
+
283
+ const focusLast = (): void => {
284
+ focusByIndex(getValidItems().length - 1);
285
+ };
286
+
287
+ const focusPageDown = (pageSize: number = DEFAULT_PAGE_SIZE): void => {
288
+ const currentIndex = getKeyIndex(focusedKey());
289
+ focusByIndex(currentIndex + pageSize);
290
+ };
291
+
292
+ const focusPageUp = (pageSize: number = DEFAULT_PAGE_SIZE): void => {
293
+ const currentIndex = getKeyIndex(focusedKey());
294
+ if (currentIndex === -1) {
295
+ focusByIndex(getValidItems().length - 1);
296
+ } else {
297
+ focusByIndex(currentIndex - pageSize);
298
+ }
299
+ };
300
+
301
+ const isFocused = (key: string): boolean => {
302
+ return focusedKey() === key;
303
+ };
304
+
305
+ // Keyboard handler
306
+ const onKeyDown = (e: KeyboardEvent): void => {
307
+ const isVertical = orientation === "vertical" || orientation === "both";
308
+ const isHorizontal = orientation === "horizontal" || orientation === "both";
309
+
310
+ switch (e.key) {
311
+ case "ArrowDown":
312
+ if (isVertical) {
313
+ e.preventDefault();
314
+ focusNext();
315
+ }
316
+ break;
317
+ case "ArrowUp":
318
+ if (isVertical) {
319
+ e.preventDefault();
320
+ focusPrevious();
321
+ }
322
+ break;
323
+ case "ArrowRight":
324
+ if (isHorizontal) {
325
+ e.preventDefault();
326
+ focusNext();
327
+ }
328
+ break;
329
+ case "ArrowLeft":
330
+ if (isHorizontal) {
331
+ e.preventDefault();
332
+ focusPrevious();
333
+ }
334
+ break;
335
+ case "Home":
336
+ e.preventDefault();
337
+ focusFirst();
338
+ break;
339
+ case "End":
340
+ e.preventDefault();
341
+ focusLast();
342
+ break;
343
+ case "PageDown":
344
+ e.preventDefault();
345
+ focusPageDown();
346
+ break;
347
+ case "PageUp":
348
+ e.preventDefault();
349
+ focusPageUp();
350
+ break;
351
+ }
352
+ };
353
+
354
+ const containerProps = {
355
+ "aria-activedescendant": () => {
356
+ const key = focusedKey();
357
+ return key ? `item-${key}` : undefined;
358
+ },
359
+ onKeyDown,
360
+ };
361
+
362
+ const getItemProps = (key: string) => ({
363
+ id: `item-${key}`,
364
+ });
365
+
366
+ return {
367
+ focusedKey,
368
+ focusedItem,
369
+ setFocusedKey,
370
+ focusNext,
371
+ focusPrevious,
372
+ focusFirst,
373
+ focusLast,
374
+ focusPageDown,
375
+ focusPageUp,
376
+ isFocused,
377
+ containerProps,
378
+ getItemProps,
379
+ };
380
+ }