@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
@@ -0,0 +1,352 @@
1
+ /**
2
+ * createTimeSegment hook for Solidaria
3
+ *
4
+ * Provides the behavior and accessibility implementation for a time segment.
5
+ * Based on @react-aria/datepicker useDateSegment semantics (time-field scope).
6
+ */
7
+
8
+ import { createMemo, createSignal } from "solid-js";
9
+ import { useLocale } from "../i18n";
10
+ import { access, type MaybeAccessor } from "../utils/reactivity";
11
+ import type { TimeFieldState, TimeSegment, TimeSegmentType } from "@proyecto-viviana/solid-stately";
12
+
13
+ export interface AriaTimeSegmentProps {
14
+ /** The segment data. */
15
+ segment: TimeSegment;
16
+ }
17
+
18
+ export interface TimeSegmentAria {
19
+ /** Props for the segment element. */
20
+ segmentProps: Record<string, unknown>;
21
+ /** Whether the segment is focused. */
22
+ isFocused: boolean;
23
+ /** Whether the segment is editable. */
24
+ isEditable: boolean;
25
+ /** Whether the segment is a placeholder. */
26
+ isPlaceholder: boolean;
27
+ /** The text to display. */
28
+ text: string;
29
+ }
30
+
31
+ /**
32
+ * Provides the behavior and accessibility implementation for a time segment.
33
+ */
34
+ export function createTimeSegment<T extends TimeFieldState>(
35
+ props: MaybeAccessor<AriaTimeSegmentProps>,
36
+ state: T,
37
+ ref?: () => HTMLElement | null,
38
+ ): TimeSegmentAria {
39
+ const getProps = () => access(props);
40
+ const [isFocused, setIsFocused] = createSignal(false);
41
+ const [enteredKeys, setEnteredKeys] = createSignal("");
42
+ const [isComposing, setIsComposing] = createSignal(false);
43
+ const locale = useLocale();
44
+
45
+ const segment = createMemo(() => getProps().segment);
46
+
47
+ const isEditable = createMemo(() => {
48
+ const seg = segment();
49
+ return seg.isEditable && !state.isDisabled() && !state.isReadOnly();
50
+ });
51
+
52
+ const focusSegment = (target: "first" | "last" | "prev" | "next") => {
53
+ const el = ref?.();
54
+ if (!el) return;
55
+
56
+ const container = el.parentElement;
57
+ if (!container) return;
58
+
59
+ const segments = Array.from(container.querySelectorAll<HTMLElement>('[role="spinbutton"]'));
60
+
61
+ if (segments.length === 0) return;
62
+
63
+ if (target === "first") {
64
+ segments[0]?.focus();
65
+ return;
66
+ }
67
+
68
+ if (target === "last") {
69
+ segments[segments.length - 1]?.focus();
70
+ return;
71
+ }
72
+
73
+ const currentIndex = segments.indexOf(el);
74
+ if (currentIndex < 0) return;
75
+
76
+ const nextIndex = target === "next" ? currentIndex + 1 : currentIndex - 1;
77
+ if (nextIndex >= 0 && nextIndex < segments.length) {
78
+ segments[nextIndex]?.focus();
79
+ }
80
+ };
81
+
82
+ const clearCurrentSegment = (type: TimeSegmentType) => {
83
+ state.clearSegment(type);
84
+ setEnteredKeys("");
85
+ };
86
+
87
+ const handleNumericInput = (key: string, type: TimeSegmentType, seg: TimeSegment) => {
88
+ const newKeys = enteredKeys() + key;
89
+ const numValue = parseInt(newKeys, 10);
90
+ const maxValue = seg.maxValue ?? 99;
91
+ const minValue = seg.minValue ?? 0;
92
+ const maxDigits = String(maxValue).length;
93
+
94
+ if (numValue <= maxValue) {
95
+ state.setSegment(type, numValue);
96
+
97
+ const potentialNextValue = parseInt(newKeys + "0", 10);
98
+ if (potentialNextValue > maxValue || newKeys.length >= maxDigits) {
99
+ setEnteredKeys("");
100
+ focusSegment("next");
101
+ } else {
102
+ setEnteredKeys(newKeys);
103
+ }
104
+ } else {
105
+ const singleValue = parseInt(key, 10);
106
+ if (singleValue >= minValue && singleValue <= maxValue) {
107
+ state.setSegment(type, singleValue);
108
+ const potentialNextValue = parseInt(key + "0", 10);
109
+ if (potentialNextValue > maxValue || key.length >= maxDigits) {
110
+ setEnteredKeys("");
111
+ focusSegment("next");
112
+ } else {
113
+ setEnteredKeys(key);
114
+ }
115
+ } else {
116
+ setEnteredKeys("");
117
+ }
118
+ }
119
+ };
120
+
121
+ const handleKeyDown = (e: KeyboardEvent) => {
122
+ if (!isEditable()) return;
123
+ if (isComposing()) return;
124
+
125
+ const seg = segment();
126
+ const type = seg.type;
127
+
128
+ if (type === "literal") return;
129
+
130
+ switch (e.key) {
131
+ case "ArrowRight":
132
+ e.preventDefault();
133
+ focusSegment(locale().direction === "rtl" ? "prev" : "next");
134
+ break;
135
+ case "ArrowLeft":
136
+ e.preventDefault();
137
+ focusSegment(locale().direction === "rtl" ? "next" : "prev");
138
+ break;
139
+ case "ArrowUp":
140
+ e.preventDefault();
141
+ state.incrementSegment(type);
142
+ break;
143
+ case "ArrowDown":
144
+ e.preventDefault();
145
+ state.decrementSegment(type);
146
+ break;
147
+ case "Home":
148
+ e.preventDefault();
149
+ focusSegment("first");
150
+ break;
151
+ case "End":
152
+ e.preventDefault();
153
+ focusSegment("last");
154
+ break;
155
+ case "Backspace":
156
+ e.preventDefault();
157
+ if (seg.isPlaceholder) {
158
+ focusSegment("prev");
159
+ } else {
160
+ clearCurrentSegment(type);
161
+ }
162
+ break;
163
+ case "Delete":
164
+ e.preventDefault();
165
+ clearCurrentSegment(type);
166
+ break;
167
+ default:
168
+ const normalizedDigit = normalizeDigit(e.key);
169
+ if (normalizedDigit) {
170
+ e.preventDefault();
171
+ handleNumericInput(normalizedDigit, type, seg);
172
+ }
173
+ break;
174
+ }
175
+ };
176
+
177
+ const handleBeforeInput = (e: InputEvent) => {
178
+ if (!isEditable()) return;
179
+ if (isComposing()) return;
180
+
181
+ const seg = segment();
182
+ if (seg.type === "literal") return;
183
+
184
+ if (e.inputType === "deleteContentBackward" || e.inputType === "deleteContentForward") {
185
+ e.preventDefault();
186
+ clearCurrentSegment(seg.type);
187
+ return;
188
+ }
189
+
190
+ if (e.inputType === "insertText" && e.data) {
191
+ const normalizedDigit = normalizeDigit(e.data);
192
+ if (!normalizedDigit) return;
193
+ e.preventDefault();
194
+ handleNumericInput(normalizedDigit, seg.type, seg);
195
+ }
196
+ };
197
+
198
+ const handleCompositionStart = () => {
199
+ if (!isEditable()) return;
200
+ setIsComposing(true);
201
+ setEnteredKeys("");
202
+ };
203
+
204
+ const handleCompositionEnd = (e: CompositionEvent) => {
205
+ if (!isEditable()) return;
206
+ setIsComposing(false);
207
+
208
+ const seg = segment();
209
+ if (seg.type === "literal") return;
210
+
211
+ const digits = extractNormalizedDigits(e.data ?? "");
212
+ if (digits.length === 0) return;
213
+
214
+ for (const digit of digits) {
215
+ handleNumericInput(digit, seg.type, seg);
216
+ }
217
+ };
218
+
219
+ const handleFocus = () => {
220
+ setIsFocused(true);
221
+ setEnteredKeys("");
222
+ };
223
+
224
+ const handleBlur = () => {
225
+ setIsFocused(false);
226
+ setEnteredKeys("");
227
+
228
+ const maybeState = state as unknown as { confirmPlaceholder?: () => void };
229
+ maybeState.confirmPlaceholder?.();
230
+ };
231
+
232
+ const segmentProps = createMemo(() => {
233
+ const seg = segment();
234
+ const type = seg.type;
235
+
236
+ if (type === "literal") {
237
+ return {
238
+ "aria-hidden": true,
239
+ };
240
+ }
241
+
242
+ return {
243
+ role: "spinbutton",
244
+ tabIndex: isEditable() ? 0 : -1,
245
+ "aria-label": getSegmentLabel(type, locale().locale),
246
+ "aria-valuenow": seg.value,
247
+ "aria-valuemin": seg.minValue,
248
+ "aria-valuemax": seg.maxValue,
249
+ "aria-valuetext": seg.isPlaceholder ? seg.placeholder : seg.text,
250
+ "aria-readonly": state.isReadOnly() || undefined,
251
+ "aria-disabled": state.isDisabled() || undefined,
252
+ "aria-invalid": state.isInvalid() || undefined,
253
+ contentEditable: isEditable(),
254
+ suppressContentEditableWarning: true,
255
+ inputMode: "numeric" as const,
256
+ autoCorrect: "off",
257
+ enterKeyHint: "next" as const,
258
+ spellCheck: false,
259
+ onKeyDown: handleKeyDown,
260
+ onFocus: handleFocus,
261
+ onBlur: handleBlur,
262
+ onBeforeInput: handleBeforeInput,
263
+ onCompositionStart: handleCompositionStart,
264
+ onCompositionEnd: handleCompositionEnd,
265
+ onMouseDown: (e: MouseEvent) => {
266
+ e.preventDefault();
267
+ },
268
+ };
269
+ });
270
+
271
+ const text = createMemo(() => {
272
+ const seg = segment();
273
+ return seg.isPlaceholder ? seg.placeholder : seg.text;
274
+ });
275
+
276
+ return {
277
+ get segmentProps() {
278
+ return segmentProps();
279
+ },
280
+ get isFocused() {
281
+ return isFocused();
282
+ },
283
+ get isEditable() {
284
+ return isEditable();
285
+ },
286
+ get isPlaceholder() {
287
+ return segment().isPlaceholder;
288
+ },
289
+ get text() {
290
+ return text();
291
+ },
292
+ };
293
+ }
294
+
295
+ type EditableTimeSegmentType = Exclude<TimeSegmentType, "literal">;
296
+
297
+ const SEGMENT_LABELS: Record<string, Record<EditableTimeSegmentType, string>> = {
298
+ en: {
299
+ hour: "Hour",
300
+ minute: "Minute",
301
+ second: "Second",
302
+ dayPeriod: "AM/PM",
303
+ },
304
+ es: {
305
+ hour: "Hora",
306
+ minute: "Minuto",
307
+ second: "Segundo",
308
+ dayPeriod: "AM/PM",
309
+ },
310
+ };
311
+
312
+ function getSegmentLabel(type: TimeSegmentType, locale: string): string {
313
+ if (type === "literal") return "";
314
+
315
+ const language = locale.toLowerCase().split("-")[0] ?? "en";
316
+ const labels = SEGMENT_LABELS[language] ?? SEGMENT_LABELS.en;
317
+ return labels[type];
318
+ }
319
+
320
+ function normalizeDigit(input: string): string | null {
321
+ if (/^[0-9]$/.test(input)) {
322
+ return input;
323
+ }
324
+
325
+ const code = input.codePointAt(0);
326
+ if (code === undefined) return null;
327
+
328
+ if (code >= 0x0660 && code <= 0x0669) {
329
+ return String(code - 0x0660);
330
+ }
331
+
332
+ if (code >= 0x06f0 && code <= 0x06f9) {
333
+ return String(code - 0x06f0);
334
+ }
335
+
336
+ if (code >= 0xff10 && code <= 0xff19) {
337
+ return String(code - 0xff10);
338
+ }
339
+
340
+ return null;
341
+ }
342
+
343
+ function extractNormalizedDigits(input: string): string[] {
344
+ const digits: string[] = [];
345
+ for (const char of input) {
346
+ const normalized = normalizeDigit(char);
347
+ if (normalized) {
348
+ digits.push(normalized);
349
+ }
350
+ }
351
+ return digits;
352
+ }
@@ -1,23 +1,22 @@
1
1
  // Date Field
2
- export {
3
- createDateField,
4
- type AriaDateFieldProps,
5
- type DateFieldAria,
6
- } from './createDateField';
2
+ export { createDateField, type AriaDateFieldProps, type DateFieldAria } from "./createDateField";
7
3
 
8
4
  // Date Segment
9
5
  export {
10
6
  createDateSegment,
11
7
  type AriaDateSegmentProps,
12
8
  type DateSegmentAria,
13
- } from './createDateSegment';
9
+ } from "./createDateSegment";
14
10
 
15
11
  // Time Field
12
+ export { createTimeField, type AriaTimeFieldProps, type TimeFieldAria } from "./createTimeField";
13
+
14
+ // Time Segment
16
15
  export {
17
- createTimeField,
18
- type AriaTimeFieldProps,
19
- type TimeFieldAria,
20
- } from './createTimeField';
16
+ createTimeSegment,
17
+ type AriaTimeSegmentProps,
18
+ type TimeSegmentAria,
19
+ } from "./createTimeSegment";
21
20
 
22
21
  // Date Picker
23
22
  export {
@@ -25,4 +24,18 @@ export {
25
24
  type AriaDatePickerProps,
26
25
  type DatePickerAria,
27
26
  type DatePickerState,
28
- } from './createDatePicker';
27
+ } from "./createDatePicker";
28
+
29
+ // Date Picker Group
30
+ export {
31
+ createDatePickerGroup,
32
+ type AriaDatePickerGroupProps,
33
+ type DatePickerGroupAria,
34
+ } from "./createDatePickerGroup";
35
+
36
+ // Date Range Picker
37
+ export {
38
+ createDateRangePicker,
39
+ type AriaDateRangePickerProps,
40
+ type DateRangePickerAria,
41
+ } from "./createDateRangePicker";
@@ -1,120 +1,127 @@
1
- /*
2
- * Copyright 2020 Adobe. All rights reserved.
3
- * This file is licensed to you under the Apache License, Version 2.0 (the "License");
4
- * you may not use this file except in compliance with the License. You may obtain a copy
5
- * of the License at http://www.apache.org/licenses/LICENSE-2.0
6
- *
7
- * Unless required by applicable law or agreed to in writing, software distributed under
8
- * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
9
- * OF ANY KIND, either express or implied. See the License for the specific language
10
- * governing permissions and limitations under the License.
11
- */
12
-
13
- /**
14
- * Ported from React Aria:
15
- * https://github.com/adobe/react-spectrum/blob/main/packages/@react-aria/dialog/src/useDialog.ts
16
- */
17
-
18
- import { Accessor, createEffect, createMemo, createSignal, createUniqueId, onCleanup } from 'solid-js'
19
- import { filterDOMProps, focusSafely } from '../utils'
20
- import type { AriaLabelingProps, DOMProps } from './types'
21
-
22
- export interface AriaDialogProps extends DOMProps, AriaLabelingProps {
23
- /**
24
- * The role of the dialog element.
25
- * @default 'dialog'
26
- */
27
- role?: 'dialog' | 'alertdialog'
28
- }
29
-
30
- export interface DialogAria {
31
- /** Props for the dialog container element. */
32
- dialogProps: Accessor<Record<string, any>>
33
-
34
- /** Props for the dialog title element. */
35
- titleProps: Accessor<Record<string, any>>
36
- }
37
-
38
- /**
39
- * Provides the behavior and accessibility implementation for a dialog component.
40
- * A dialog is an overlay shown above other content in an application.
41
- */
42
- export function createDialog(
43
- props: AriaDialogProps | Accessor<AriaDialogProps>,
44
- ref: Accessor<HTMLElement | undefined>
45
- ): DialogAria {
46
- // Support both direct props and accessor pattern
47
- const getProps = typeof props === 'function' ? props : () => props
48
-
49
- const role = () => getProps().role ?? 'dialog'
50
- const generatedTitleId = createUniqueId()
51
- const [isRefocusing, setIsRefocusing] = createSignal(false)
52
-
53
- const titleId = createMemo(() => {
54
- const p = getProps()
55
- // Use provided aria-labelledby, or generated ID if no aria-label
56
- if (p['aria-labelledby']) return undefined
57
- return p['aria-label'] ? undefined : generatedTitleId
58
- })
59
-
60
- // Focus the dialog itself on mount, unless a child element is already focused.
61
- // Only run on the client (SSR-safe)
62
- createEffect(() => {
63
- // Guard against SSR - document is not available on the server
64
- if (typeof document === 'undefined') return
65
-
66
- const dialogEl = ref()
67
- if (dialogEl && !dialogEl.contains(document.activeElement)) {
68
- focusSafely(dialogEl)
69
-
70
- // Safari on iOS does not move the VoiceOver cursor to the dialog
71
- // or announce that it has opened until it has rendered. A workaround
72
- // is to wait for half a second, then blur and re-focus the dialog.
73
- const timeout = setTimeout(() => {
74
- // Check that the dialog is still focused, or focused was lost to the body.
75
- if (document.activeElement === dialogEl || document.activeElement === document.body) {
76
- setIsRefocusing(true)
77
- dialogEl.blur()
78
- focusSafely(dialogEl)
79
- setIsRefocusing(false)
80
- }
81
- }, 500)
82
-
83
- onCleanup(() => {
84
- clearTimeout(timeout)
85
- })
86
- }
87
- })
88
-
89
- // Note: Focus containment is typically handled by createModal at a higher level
90
- // For standalone dialogs, focus containment should be managed by the overlay system
91
-
92
- const dialogProps = createMemo(() => {
93
- const p = getProps()
94
- return {
95
- ...filterDOMProps(p),
96
- role: role(),
97
- tabIndex: -1,
98
- 'aria-label': p['aria-label'],
99
- 'aria-labelledby': p['aria-labelledby'] || titleId(),
100
- 'aria-describedby': p['aria-describedby'],
101
- // Prevent blur events from reaching createOverlay, which may cause
102
- // popovers to close. Since focus is contained within the dialog,
103
- // we don't want this to occur due to the above createEffect.
104
- onBlur: (e: FocusEvent) => {
105
- if (isRefocusing()) {
106
- e.stopPropagation()
107
- }
108
- }
109
- }
110
- })
111
-
112
- const titlePropsValue = createMemo(() => ({
113
- id: titleId()
114
- }))
115
-
116
- return {
117
- dialogProps,
118
- titleProps: titlePropsValue
119
- }
120
- }
1
+ /*
2
+ * Copyright 2020 Adobe. All rights reserved.
3
+ * This file is licensed to you under the Apache License, Version 2.0 (the "License");
4
+ * you may not use this file except in compliance with the License. You may obtain a copy
5
+ * of the License at http://www.apache.org/licenses/LICENSE-2.0
6
+ *
7
+ * Unless required by applicable law or agreed to in writing, software distributed under
8
+ * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
9
+ * OF ANY KIND, either express or implied. See the License for the specific language
10
+ * governing permissions and limitations under the License.
11
+ */
12
+
13
+ /**
14
+ * Ported from React Aria:
15
+ * https://github.com/adobe/react-spectrum/blob/main/packages/@react-aria/dialog/src/useDialog.ts
16
+ */
17
+
18
+ import {
19
+ Accessor,
20
+ createEffect,
21
+ createMemo,
22
+ createSignal,
23
+ createUniqueId,
24
+ onCleanup,
25
+ } from "solid-js";
26
+ import { filterDOMProps, focusSafely } from "../utils";
27
+ import type { AriaLabelingProps, DOMProps } from "./types";
28
+
29
+ export interface AriaDialogProps extends DOMProps, AriaLabelingProps {
30
+ /**
31
+ * The role of the dialog element.
32
+ * @default 'dialog'
33
+ */
34
+ role?: "dialog" | "alertdialog";
35
+ }
36
+
37
+ export interface DialogAria {
38
+ /** Props for the dialog container element. */
39
+ dialogProps: Accessor<Record<string, unknown>>;
40
+
41
+ /** Props for the dialog title element. */
42
+ titleProps: Accessor<Record<string, unknown>>;
43
+ }
44
+
45
+ /**
46
+ * Provides the behavior and accessibility implementation for a dialog component.
47
+ * A dialog is an overlay shown above other content in an application.
48
+ */
49
+ export function createDialog(
50
+ props: AriaDialogProps | Accessor<AriaDialogProps>,
51
+ ref: Accessor<HTMLElement | undefined>,
52
+ ): DialogAria {
53
+ // Support both direct props and accessor pattern
54
+ const getProps = typeof props === "function" ? props : () => props;
55
+
56
+ const role = () => getProps().role ?? "dialog";
57
+ const generatedTitleId = createUniqueId();
58
+ const [isRefocusing, setIsRefocusing] = createSignal(false);
59
+
60
+ const titleId = createMemo(() => {
61
+ const p = getProps();
62
+ // Use provided aria-labelledby, or generated ID if no aria-label
63
+ if (p["aria-labelledby"]) return undefined;
64
+ return p["aria-label"] ? undefined : generatedTitleId;
65
+ });
66
+
67
+ // Focus the dialog itself on mount, unless a child element is already focused.
68
+ // Only run on the client (SSR-safe)
69
+ createEffect(() => {
70
+ // Guard against SSR - document is not available on the server
71
+ if (typeof document === "undefined") return;
72
+
73
+ const dialogEl = ref();
74
+ if (dialogEl && !dialogEl.contains(document.activeElement)) {
75
+ focusSafely(dialogEl);
76
+
77
+ // Safari on iOS does not move the VoiceOver cursor to the dialog
78
+ // or announce that it has opened until it has rendered. A workaround
79
+ // is to wait for half a second, then blur and re-focus the dialog.
80
+ const timeout = setTimeout(() => {
81
+ // Check that the dialog is still focused, or focused was lost to the body.
82
+ if (document.activeElement === dialogEl || document.activeElement === document.body) {
83
+ setIsRefocusing(true);
84
+ dialogEl.blur();
85
+ focusSafely(dialogEl);
86
+ setIsRefocusing(false);
87
+ }
88
+ }, 500);
89
+
90
+ onCleanup(() => {
91
+ clearTimeout(timeout);
92
+ });
93
+ }
94
+ });
95
+
96
+ // Note: Focus containment is typically handled by createModal at a higher level
97
+ // For standalone dialogs, focus containment should be managed by the overlay system
98
+
99
+ const dialogProps = createMemo(() => {
100
+ const p = getProps();
101
+ return {
102
+ ...filterDOMProps(p),
103
+ role: role(),
104
+ tabIndex: -1,
105
+ "aria-label": p["aria-label"],
106
+ "aria-labelledby": p["aria-labelledby"] || titleId(),
107
+ "aria-describedby": p["aria-describedby"],
108
+ // Prevent blur events from reaching createOverlay, which may cause
109
+ // popovers to close. Since focus is contained within the dialog,
110
+ // we don't want this to occur due to the above createEffect.
111
+ onBlur: (e: FocusEvent) => {
112
+ if (isRefocusing()) {
113
+ e.stopPropagation();
114
+ }
115
+ },
116
+ };
117
+ });
118
+
119
+ const titlePropsValue = createMemo(() => ({
120
+ id: titleId(),
121
+ }));
122
+
123
+ return {
124
+ dialogProps,
125
+ titleProps: titlePropsValue,
126
+ };
127
+ }
@@ -1,2 +1,2 @@
1
- export { createDialog } from './createDialog'
2
- export type { AriaDialogProps, DialogAria } from './createDialog'
1
+ export { createDialog } from "./createDialog";
2
+ export type { AriaDialogProps, DialogAria } from "./createDialog";