react-aria 3.48.0 → 3.50.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 (1248) hide show
  1. package/dist/exports/CollectionBuilder.cjs.map +1 -1
  2. package/dist/exports/CollectionBuilder.js.map +1 -1
  3. package/dist/exports/CollectionBuilder.mjs.map +1 -1
  4. package/dist/exports/index.cjs +12 -0
  5. package/dist/exports/index.cjs.map +1 -1
  6. package/dist/exports/index.js +9 -1
  7. package/dist/exports/index.js.map +1 -1
  8. package/dist/exports/index.mjs +9 -1
  9. package/dist/exports/index.mjs.map +1 -1
  10. package/dist/exports/private/actiongroup/useActionGroup.cjs.map +1 -1
  11. package/dist/exports/private/actiongroup/useActionGroup.js.map +1 -1
  12. package/dist/exports/private/actiongroup/useActionGroup.mjs.map +1 -1
  13. package/dist/exports/private/actiongroup/useActionGroupItem.cjs.map +1 -1
  14. package/dist/exports/private/actiongroup/useActionGroupItem.js.map +1 -1
  15. package/dist/exports/private/actiongroup/useActionGroupItem.mjs.map +1 -1
  16. package/dist/exports/private/autocomplete/useSearchAutocomplete.cjs.map +1 -1
  17. package/dist/exports/private/autocomplete/useSearchAutocomplete.js.map +1 -1
  18. package/dist/exports/private/autocomplete/useSearchAutocomplete.mjs.map +1 -1
  19. package/dist/exports/private/collections/BaseCollection.cjs.map +1 -1
  20. package/dist/exports/private/collections/BaseCollection.js.map +1 -1
  21. package/dist/exports/private/collections/BaseCollection.mjs.map +1 -1
  22. package/dist/exports/private/collections/useCachedChildren.cjs.map +1 -1
  23. package/dist/exports/private/collections/useCachedChildren.js.map +1 -1
  24. package/dist/exports/private/collections/useCachedChildren.mjs.map +1 -1
  25. package/dist/exports/private/focus/FocusScope.cjs.map +1 -1
  26. package/dist/exports/private/focus/FocusScope.js.map +1 -1
  27. package/dist/exports/private/focus/FocusScope.mjs.map +1 -1
  28. package/dist/exports/private/focus/virtualFocus.cjs.map +1 -1
  29. package/dist/exports/private/focus/virtualFocus.js.map +1 -1
  30. package/dist/exports/private/focus/virtualFocus.mjs.map +1 -1
  31. package/dist/exports/private/grid/GridKeyboardDelegate.cjs.map +1 -1
  32. package/dist/exports/private/grid/GridKeyboardDelegate.js.map +1 -1
  33. package/dist/exports/private/grid/GridKeyboardDelegate.mjs.map +1 -1
  34. package/dist/exports/private/grid/useGridSelectionAnnouncement.cjs.map +1 -1
  35. package/dist/exports/private/grid/useGridSelectionAnnouncement.js.map +1 -1
  36. package/dist/exports/private/grid/useGridSelectionAnnouncement.mjs.map +1 -1
  37. package/dist/exports/private/grid/useGridSelectionCheckbox.cjs.map +1 -1
  38. package/dist/exports/private/grid/useGridSelectionCheckbox.js.map +1 -1
  39. package/dist/exports/private/grid/useGridSelectionCheckbox.mjs.map +1 -1
  40. package/dist/exports/private/grid/useHighlightSelectionDescription.cjs.map +1 -1
  41. package/dist/exports/private/grid/useHighlightSelectionDescription.js.map +1 -1
  42. package/dist/exports/private/grid/useHighlightSelectionDescription.mjs.map +1 -1
  43. package/dist/exports/private/interactions/useFocusVisible.cjs.map +1 -1
  44. package/dist/exports/private/interactions/useFocusVisible.js.map +1 -1
  45. package/dist/exports/private/interactions/useFocusVisible.mjs.map +1 -1
  46. package/dist/exports/private/interactions/useFocusable.cjs.map +1 -1
  47. package/dist/exports/private/interactions/useFocusable.js.map +1 -1
  48. package/dist/exports/private/interactions/useFocusable.mjs.map +1 -1
  49. package/dist/exports/private/landmark/useLandmark.cjs.map +1 -1
  50. package/dist/exports/private/landmark/useLandmark.js.map +1 -1
  51. package/dist/exports/private/landmark/useLandmark.mjs.map +1 -1
  52. package/dist/exports/private/live-announcer/LiveAnnouncer.cjs.map +1 -1
  53. package/dist/exports/private/live-announcer/LiveAnnouncer.js.map +1 -1
  54. package/dist/exports/private/live-announcer/LiveAnnouncer.mjs.map +1 -1
  55. package/dist/exports/private/overlays/useModal.cjs.map +1 -1
  56. package/dist/exports/private/overlays/useModal.js.map +1 -1
  57. package/dist/exports/private/overlays/useModal.mjs.map +1 -1
  58. package/dist/exports/private/selection/useSelectableCollection.cjs.map +1 -1
  59. package/dist/exports/private/selection/useSelectableCollection.js.map +1 -1
  60. package/dist/exports/private/selection/useSelectableCollection.mjs.map +1 -1
  61. package/dist/exports/private/selection/useSelectableItem.cjs.map +1 -1
  62. package/dist/exports/private/selection/useSelectableItem.js.map +1 -1
  63. package/dist/exports/private/selection/useSelectableItem.mjs.map +1 -1
  64. package/dist/exports/private/selection/useSelectableList.cjs.map +1 -1
  65. package/dist/exports/private/selection/useSelectableList.js.map +1 -1
  66. package/dist/exports/private/selection/useSelectableList.mjs.map +1 -1
  67. package/dist/exports/private/selection/useTypeSelect.cjs.map +1 -1
  68. package/dist/exports/private/selection/useTypeSelect.js.map +1 -1
  69. package/dist/exports/private/selection/useTypeSelect.mjs.map +1 -1
  70. package/dist/exports/private/spinbutton/useSpinButton.cjs.map +1 -1
  71. package/dist/exports/private/spinbutton/useSpinButton.js.map +1 -1
  72. package/dist/exports/private/spinbutton/useSpinButton.mjs.map +1 -1
  73. package/dist/exports/private/steplist/useStepList.cjs.map +1 -1
  74. package/dist/exports/private/steplist/useStepList.js.map +1 -1
  75. package/dist/exports/private/steplist/useStepList.mjs.map +1 -1
  76. package/dist/exports/private/steplist/useStepListItem.cjs.map +1 -1
  77. package/dist/exports/private/steplist/useStepListItem.js.map +1 -1
  78. package/dist/exports/private/steplist/useStepListItem.mjs.map +1 -1
  79. package/dist/exports/private/utils/openLink.cjs.map +1 -1
  80. package/dist/exports/private/utils/openLink.js.map +1 -1
  81. package/dist/exports/private/utils/openLink.mjs.map +1 -1
  82. package/dist/exports/private/utils/platform.cjs.map +1 -1
  83. package/dist/exports/private/utils/platform.js.map +1 -1
  84. package/dist/exports/private/utils/platform.mjs.map +1 -1
  85. package/dist/exports/private/utils/shadowdom/DOMFunctions.cjs.map +1 -1
  86. package/dist/exports/private/utils/shadowdom/DOMFunctions.js.map +1 -1
  87. package/dist/exports/private/utils/shadowdom/DOMFunctions.mjs.map +1 -1
  88. package/dist/exports/private/utils/shadowdom/ShadowTreeWalker.cjs.map +1 -1
  89. package/dist/exports/private/utils/shadowdom/ShadowTreeWalker.js.map +1 -1
  90. package/dist/exports/private/utils/shadowdom/ShadowTreeWalker.mjs.map +1 -1
  91. package/dist/exports/private/utils/useLoadMoreSentinel.cjs.map +1 -1
  92. package/dist/exports/private/utils/useLoadMoreSentinel.js.map +1 -1
  93. package/dist/exports/private/utils/useLoadMoreSentinel.mjs.map +1 -1
  94. package/dist/exports/private/virtualizer/useVirtualizerItem.cjs.map +1 -1
  95. package/dist/exports/private/virtualizer/useVirtualizerItem.js.map +1 -1
  96. package/dist/exports/private/virtualizer/useVirtualizerItem.mjs.map +1 -1
  97. package/dist/exports/private/virtualizer/utils.cjs.map +1 -1
  98. package/dist/exports/private/virtualizer/utils.js.map +1 -1
  99. package/dist/exports/private/virtualizer/utils.mjs.map +1 -1
  100. package/dist/exports/useAutocomplete.cjs.map +1 -1
  101. package/dist/exports/useAutocomplete.js.map +1 -1
  102. package/dist/exports/useAutocomplete.mjs.map +1 -1
  103. package/dist/exports/useBreadcrumbs.cjs.map +1 -1
  104. package/dist/exports/useBreadcrumbs.js.map +1 -1
  105. package/dist/exports/useBreadcrumbs.mjs.map +1 -1
  106. package/dist/exports/useButton.cjs.map +1 -1
  107. package/dist/exports/useButton.js.map +1 -1
  108. package/dist/exports/useButton.mjs.map +1 -1
  109. package/dist/exports/useCalendar.cjs +9 -0
  110. package/dist/exports/useCalendar.cjs.map +1 -1
  111. package/dist/exports/useCalendar.js +7 -1
  112. package/dist/exports/useCalendar.js.map +1 -1
  113. package/dist/exports/useCalendar.mjs +7 -1
  114. package/dist/exports/useCalendar.mjs.map +1 -1
  115. package/dist/exports/useClipboard.cjs.map +1 -1
  116. package/dist/exports/useClipboard.js.map +1 -1
  117. package/dist/exports/useClipboard.mjs.map +1 -1
  118. package/dist/exports/useColorArea.cjs.map +1 -1
  119. package/dist/exports/useColorArea.js.map +1 -1
  120. package/dist/exports/useColorArea.mjs.map +1 -1
  121. package/dist/exports/useColorField.cjs.map +1 -1
  122. package/dist/exports/useColorField.js.map +1 -1
  123. package/dist/exports/useColorField.mjs.map +1 -1
  124. package/dist/exports/useColorSlider.cjs.map +1 -1
  125. package/dist/exports/useColorSlider.js.map +1 -1
  126. package/dist/exports/useColorSlider.mjs.map +1 -1
  127. package/dist/exports/useColorWheel.cjs.map +1 -1
  128. package/dist/exports/useColorWheel.js.map +1 -1
  129. package/dist/exports/useColorWheel.mjs.map +1 -1
  130. package/dist/exports/useComboBox.cjs.map +1 -1
  131. package/dist/exports/useComboBox.js.map +1 -1
  132. package/dist/exports/useComboBox.mjs.map +1 -1
  133. package/dist/exports/useDateField.cjs.map +1 -1
  134. package/dist/exports/useDateField.js.map +1 -1
  135. package/dist/exports/useDateField.mjs.map +1 -1
  136. package/dist/exports/useDateRangePicker.cjs.map +1 -1
  137. package/dist/exports/useDateRangePicker.js.map +1 -1
  138. package/dist/exports/useDateRangePicker.mjs.map +1 -1
  139. package/dist/exports/useDisclosure.cjs +1 -1
  140. package/dist/exports/useDisclosure.cjs.map +1 -1
  141. package/dist/exports/useDisclosure.js +1 -1
  142. package/dist/exports/useDisclosure.js.map +1 -1
  143. package/dist/exports/useDisclosure.mjs +1 -1
  144. package/dist/exports/useDisclosure.mjs.map +1 -1
  145. package/dist/exports/useDrag.cjs.map +1 -1
  146. package/dist/exports/useDrag.js.map +1 -1
  147. package/dist/exports/useDrag.mjs.map +1 -1
  148. package/dist/exports/useDraggableCollection.cjs.map +1 -1
  149. package/dist/exports/useDraggableCollection.js.map +1 -1
  150. package/dist/exports/useDraggableCollection.mjs.map +1 -1
  151. package/dist/exports/useDrop.cjs.map +1 -1
  152. package/dist/exports/useDrop.js.map +1 -1
  153. package/dist/exports/useDrop.mjs.map +1 -1
  154. package/dist/exports/useDroppableCollection.cjs.map +1 -1
  155. package/dist/exports/useDroppableCollection.js.map +1 -1
  156. package/dist/exports/useDroppableCollection.mjs.map +1 -1
  157. package/dist/exports/useFocusable.cjs.map +1 -1
  158. package/dist/exports/useFocusable.js.map +1 -1
  159. package/dist/exports/useFocusable.mjs.map +1 -1
  160. package/dist/exports/useGridList.cjs.map +1 -1
  161. package/dist/exports/useGridList.js.map +1 -1
  162. package/dist/exports/useGridList.mjs.map +1 -1
  163. package/dist/exports/useInteractOutside.cjs.map +1 -1
  164. package/dist/exports/useInteractOutside.js.map +1 -1
  165. package/dist/exports/useInteractOutside.mjs.map +1 -1
  166. package/dist/exports/useLandmark.cjs.map +1 -1
  167. package/dist/exports/useLandmark.js.map +1 -1
  168. package/dist/exports/useLandmark.mjs.map +1 -1
  169. package/dist/exports/useListBox.cjs.map +1 -1
  170. package/dist/exports/useListBox.js.map +1 -1
  171. package/dist/exports/useListBox.mjs.map +1 -1
  172. package/dist/exports/useLocalizedStringFormatter.cjs.map +1 -1
  173. package/dist/exports/useLocalizedStringFormatter.js.map +1 -1
  174. package/dist/exports/useLocalizedStringFormatter.mjs.map +1 -1
  175. package/dist/exports/useMove.cjs.map +1 -1
  176. package/dist/exports/useMove.js.map +1 -1
  177. package/dist/exports/useMove.mjs.map +1 -1
  178. package/dist/exports/useOverlayPosition.cjs.map +1 -1
  179. package/dist/exports/useOverlayPosition.js.map +1 -1
  180. package/dist/exports/useOverlayPosition.mjs.map +1 -1
  181. package/dist/exports/useProgressBar.cjs.map +1 -1
  182. package/dist/exports/useProgressBar.js.map +1 -1
  183. package/dist/exports/useProgressBar.mjs.map +1 -1
  184. package/dist/exports/useRangeCalendar.cjs +15 -0
  185. package/dist/exports/useRangeCalendar.cjs.map +1 -1
  186. package/dist/exports/useRangeCalendar.js +11 -1
  187. package/dist/exports/useRangeCalendar.js.map +1 -1
  188. package/dist/exports/useRangeCalendar.mjs +11 -1
  189. package/dist/exports/useRangeCalendar.mjs.map +1 -1
  190. package/dist/exports/useSelect.cjs.map +1 -1
  191. package/dist/exports/useSelect.js.map +1 -1
  192. package/dist/exports/useSelect.mjs.map +1 -1
  193. package/dist/exports/useSlider.cjs.map +1 -1
  194. package/dist/exports/useSlider.js.map +1 -1
  195. package/dist/exports/useSlider.mjs.map +1 -1
  196. package/dist/exports/useTable.cjs.map +1 -1
  197. package/dist/exports/useTable.js.map +1 -1
  198. package/dist/exports/useTable.mjs.map +1 -1
  199. package/dist/exports/useTimeField.cjs.map +1 -1
  200. package/dist/exports/useTimeField.js.map +1 -1
  201. package/dist/exports/useTimeField.mjs.map +1 -1
  202. package/dist/exports/useToggleButton.cjs.map +1 -1
  203. package/dist/exports/useToggleButton.js.map +1 -1
  204. package/dist/exports/useToggleButton.mjs.map +1 -1
  205. package/dist/exports/useToggleButtonGroup.cjs.map +1 -1
  206. package/dist/exports/useToggleButtonGroup.js.map +1 -1
  207. package/dist/exports/useToggleButtonGroup.mjs.map +1 -1
  208. package/dist/exports/useTree.cjs.map +1 -1
  209. package/dist/exports/useTree.js.map +1 -1
  210. package/dist/exports/useTree.mjs.map +1 -1
  211. package/dist/private/actiongroup/useActionGroup.cjs +3 -3
  212. package/dist/private/actiongroup/useActionGroup.cjs.map +1 -1
  213. package/dist/private/actiongroup/useActionGroup.js +3 -3
  214. package/dist/private/actiongroup/useActionGroup.js.map +1 -1
  215. package/dist/private/actiongroup/useActionGroup.mjs +3 -3
  216. package/dist/private/actiongroup/useActionGroup.mjs.map +1 -1
  217. package/dist/private/actiongroup/useActionGroupItem.cjs +5 -4
  218. package/dist/private/actiongroup/useActionGroupItem.cjs.map +1 -1
  219. package/dist/private/actiongroup/useActionGroupItem.js +5 -4
  220. package/dist/private/actiongroup/useActionGroupItem.js.map +1 -1
  221. package/dist/private/actiongroup/useActionGroupItem.mjs +5 -4
  222. package/dist/private/actiongroup/useActionGroupItem.mjs.map +1 -1
  223. package/dist/private/aria-modal-polyfill/ariaModalPolyfill.cjs +7 -5
  224. package/dist/private/aria-modal-polyfill/ariaModalPolyfill.cjs.map +1 -1
  225. package/dist/private/aria-modal-polyfill/ariaModalPolyfill.js +7 -5
  226. package/dist/private/aria-modal-polyfill/ariaModalPolyfill.js.map +1 -1
  227. package/dist/private/aria-modal-polyfill/ariaModalPolyfill.mjs +7 -5
  228. package/dist/private/aria-modal-polyfill/ariaModalPolyfill.mjs.map +1 -1
  229. package/dist/private/autocomplete/useAutocomplete.cjs +16 -7
  230. package/dist/private/autocomplete/useAutocomplete.cjs.map +1 -1
  231. package/dist/private/autocomplete/useAutocomplete.js +16 -7
  232. package/dist/private/autocomplete/useAutocomplete.js.map +1 -1
  233. package/dist/private/autocomplete/useAutocomplete.mjs +16 -7
  234. package/dist/private/autocomplete/useAutocomplete.mjs.map +1 -1
  235. package/dist/private/autocomplete/useSearchAutocomplete.cjs.map +1 -1
  236. package/dist/private/autocomplete/useSearchAutocomplete.js.map +1 -1
  237. package/dist/private/autocomplete/useSearchAutocomplete.mjs.map +1 -1
  238. package/dist/private/breadcrumbs/useBreadcrumbItem.cjs.map +1 -1
  239. package/dist/private/breadcrumbs/useBreadcrumbItem.js.map +1 -1
  240. package/dist/private/breadcrumbs/useBreadcrumbItem.mjs.map +1 -1
  241. package/dist/private/breadcrumbs/useBreadcrumbs.cjs.map +1 -1
  242. package/dist/private/breadcrumbs/useBreadcrumbs.js.map +1 -1
  243. package/dist/private/breadcrumbs/useBreadcrumbs.mjs.map +1 -1
  244. package/dist/private/button/useButton.cjs.map +1 -1
  245. package/dist/private/button/useButton.js.map +1 -1
  246. package/dist/private/button/useButton.mjs.map +1 -1
  247. package/dist/private/button/useToggleButton.cjs.map +1 -1
  248. package/dist/private/button/useToggleButton.js.map +1 -1
  249. package/dist/private/button/useToggleButton.mjs.map +1 -1
  250. package/dist/private/button/useToggleButtonGroup.cjs.map +1 -1
  251. package/dist/private/button/useToggleButtonGroup.js.map +1 -1
  252. package/dist/private/button/useToggleButtonGroup.mjs.map +1 -1
  253. package/dist/private/calendar/useCalendar.cjs.map +1 -1
  254. package/dist/private/calendar/useCalendar.js.map +1 -1
  255. package/dist/private/calendar/useCalendar.mjs.map +1 -1
  256. package/dist/private/calendar/useCalendarBase.cjs.map +1 -1
  257. package/dist/private/calendar/useCalendarBase.js.map +1 -1
  258. package/dist/private/calendar/useCalendarBase.mjs.map +1 -1
  259. package/dist/private/calendar/useCalendarCell.cjs +10 -14
  260. package/dist/private/calendar/useCalendarCell.cjs.map +1 -1
  261. package/dist/private/calendar/useCalendarCell.js +10 -14
  262. package/dist/private/calendar/useCalendarCell.js.map +1 -1
  263. package/dist/private/calendar/useCalendarCell.mjs +10 -14
  264. package/dist/private/calendar/useCalendarCell.mjs.map +1 -1
  265. package/dist/private/calendar/useCalendarGrid.cjs +9 -5
  266. package/dist/private/calendar/useCalendarGrid.cjs.map +1 -1
  267. package/dist/private/calendar/useCalendarGrid.js +10 -6
  268. package/dist/private/calendar/useCalendarGrid.js.map +1 -1
  269. package/dist/private/calendar/useCalendarGrid.mjs +10 -6
  270. package/dist/private/calendar/useCalendarGrid.mjs.map +1 -1
  271. package/dist/private/calendar/useCalendarHeading.cjs +56 -0
  272. package/dist/private/calendar/useCalendarHeading.cjs.map +1 -0
  273. package/dist/private/calendar/useCalendarHeading.js +52 -0
  274. package/dist/private/calendar/useCalendarHeading.js.map +1 -0
  275. package/dist/private/calendar/useCalendarHeading.mjs +51 -0
  276. package/dist/private/calendar/useCalendarHeading.mjs.map +1 -0
  277. package/dist/private/calendar/useCalendarMonthPicker.cjs +66 -0
  278. package/dist/private/calendar/useCalendarMonthPicker.cjs.map +1 -0
  279. package/dist/private/calendar/useCalendarMonthPicker.js +61 -0
  280. package/dist/private/calendar/useCalendarMonthPicker.js.map +1 -0
  281. package/dist/private/calendar/useCalendarMonthPicker.mjs +61 -0
  282. package/dist/private/calendar/useCalendarMonthPicker.mjs.map +1 -0
  283. package/dist/private/calendar/useCalendarYearPicker.cjs +90 -0
  284. package/dist/private/calendar/useCalendarYearPicker.cjs.map +1 -0
  285. package/dist/private/calendar/useCalendarYearPicker.js +86 -0
  286. package/dist/private/calendar/useCalendarYearPicker.js.map +1 -0
  287. package/dist/private/calendar/useCalendarYearPicker.mjs +85 -0
  288. package/dist/private/calendar/useCalendarYearPicker.mjs.map +1 -0
  289. package/dist/private/calendar/useRangeCalendar.cjs +1 -1
  290. package/dist/private/calendar/useRangeCalendar.cjs.map +1 -1
  291. package/dist/private/calendar/useRangeCalendar.js +1 -1
  292. package/dist/private/calendar/useRangeCalendar.js.map +1 -1
  293. package/dist/private/calendar/useRangeCalendar.mjs +1 -1
  294. package/dist/private/calendar/useRangeCalendar.mjs.map +1 -1
  295. package/dist/private/calendar/utils.cjs +20 -4
  296. package/dist/private/calendar/utils.cjs.map +1 -1
  297. package/dist/private/calendar/utils.js +22 -5
  298. package/dist/private/calendar/utils.js.map +1 -1
  299. package/dist/private/calendar/utils.mjs +20 -4
  300. package/dist/private/calendar/utils.mjs.map +1 -1
  301. package/dist/private/checkbox/useCheckbox.cjs +6 -35
  302. package/dist/private/checkbox/useCheckbox.cjs.map +1 -1
  303. package/dist/private/checkbox/useCheckbox.js +6 -35
  304. package/dist/private/checkbox/useCheckbox.js.map +1 -1
  305. package/dist/private/checkbox/useCheckbox.mjs +6 -35
  306. package/dist/private/checkbox/useCheckbox.mjs.map +1 -1
  307. package/dist/private/checkbox/useCheckboxGroup.cjs.map +1 -1
  308. package/dist/private/checkbox/useCheckboxGroup.js.map +1 -1
  309. package/dist/private/checkbox/useCheckboxGroup.mjs.map +1 -1
  310. package/dist/private/checkbox/useCheckboxGroupItem.cjs +1 -1
  311. package/dist/private/checkbox/useCheckboxGroupItem.cjs.map +1 -1
  312. package/dist/private/checkbox/useCheckboxGroupItem.js +1 -1
  313. package/dist/private/checkbox/useCheckboxGroupItem.js.map +1 -1
  314. package/dist/private/checkbox/useCheckboxGroupItem.mjs +1 -1
  315. package/dist/private/checkbox/useCheckboxGroupItem.mjs.map +1 -1
  316. package/dist/private/checkbox/utils.cjs.map +1 -1
  317. package/dist/private/checkbox/utils.js.map +1 -1
  318. package/dist/private/checkbox/utils.mjs.map +1 -1
  319. package/dist/private/collections/BaseCollection.cjs +4 -4
  320. package/dist/private/collections/BaseCollection.cjs.map +1 -1
  321. package/dist/private/collections/BaseCollection.js +4 -4
  322. package/dist/private/collections/BaseCollection.js.map +1 -1
  323. package/dist/private/collections/BaseCollection.mjs +4 -4
  324. package/dist/private/collections/BaseCollection.mjs.map +1 -1
  325. package/dist/private/collections/CollectionBuilder.cjs +5 -3
  326. package/dist/private/collections/CollectionBuilder.cjs.map +1 -1
  327. package/dist/private/collections/CollectionBuilder.js +5 -3
  328. package/dist/private/collections/CollectionBuilder.js.map +1 -1
  329. package/dist/private/collections/CollectionBuilder.mjs +5 -3
  330. package/dist/private/collections/CollectionBuilder.mjs.map +1 -1
  331. package/dist/private/collections/Document.cjs.map +1 -1
  332. package/dist/private/collections/Document.js.map +1 -1
  333. package/dist/private/collections/Document.mjs.map +1 -1
  334. package/dist/private/collections/Hidden.cjs.map +1 -1
  335. package/dist/private/collections/Hidden.js.map +1 -1
  336. package/dist/private/collections/Hidden.mjs.map +1 -1
  337. package/dist/private/collections/useCachedChildren.cjs +29 -8
  338. package/dist/private/collections/useCachedChildren.cjs.map +1 -1
  339. package/dist/private/collections/useCachedChildren.js +29 -8
  340. package/dist/private/collections/useCachedChildren.js.map +1 -1
  341. package/dist/private/collections/useCachedChildren.mjs +29 -8
  342. package/dist/private/collections/useCachedChildren.mjs.map +1 -1
  343. package/dist/private/color/useColorArea.cjs.map +1 -1
  344. package/dist/private/color/useColorArea.js.map +1 -1
  345. package/dist/private/color/useColorArea.mjs.map +1 -1
  346. package/dist/private/color/useColorAreaGradient.cjs +1 -1
  347. package/dist/private/color/useColorAreaGradient.cjs.map +1 -1
  348. package/dist/private/color/useColorAreaGradient.js +1 -1
  349. package/dist/private/color/useColorAreaGradient.js.map +1 -1
  350. package/dist/private/color/useColorAreaGradient.mjs +1 -1
  351. package/dist/private/color/useColorAreaGradient.mjs.map +1 -1
  352. package/dist/private/color/useColorChannelField.cjs.map +1 -1
  353. package/dist/private/color/useColorChannelField.js.map +1 -1
  354. package/dist/private/color/useColorChannelField.mjs.map +1 -1
  355. package/dist/private/color/useColorField.cjs +1 -1
  356. package/dist/private/color/useColorField.cjs.map +1 -1
  357. package/dist/private/color/useColorField.js +1 -1
  358. package/dist/private/color/useColorField.js.map +1 -1
  359. package/dist/private/color/useColorField.mjs +1 -1
  360. package/dist/private/color/useColorField.mjs.map +1 -1
  361. package/dist/private/color/useColorSlider.cjs +2 -2
  362. package/dist/private/color/useColorSlider.cjs.map +1 -1
  363. package/dist/private/color/useColorSlider.js +2 -2
  364. package/dist/private/color/useColorSlider.js.map +1 -1
  365. package/dist/private/color/useColorSlider.mjs +2 -2
  366. package/dist/private/color/useColorSlider.mjs.map +1 -1
  367. package/dist/private/color/useColorSwatch.cjs.map +1 -1
  368. package/dist/private/color/useColorSwatch.js.map +1 -1
  369. package/dist/private/color/useColorSwatch.mjs.map +1 -1
  370. package/dist/private/color/useColorWheel.cjs.map +1 -1
  371. package/dist/private/color/useColorWheel.js.map +1 -1
  372. package/dist/private/color/useColorWheel.mjs.map +1 -1
  373. package/dist/private/combobox/useComboBox.cjs +5 -3
  374. package/dist/private/combobox/useComboBox.cjs.map +1 -1
  375. package/dist/private/combobox/useComboBox.js +5 -3
  376. package/dist/private/combobox/useComboBox.js.map +1 -1
  377. package/dist/private/combobox/useComboBox.mjs +5 -3
  378. package/dist/private/combobox/useComboBox.mjs.map +1 -1
  379. package/dist/private/datepicker/useDateField.cjs.map +1 -1
  380. package/dist/private/datepicker/useDateField.js.map +1 -1
  381. package/dist/private/datepicker/useDateField.mjs.map +1 -1
  382. package/dist/private/datepicker/useDatePicker.cjs.map +1 -1
  383. package/dist/private/datepicker/useDatePicker.js.map +1 -1
  384. package/dist/private/datepicker/useDatePicker.mjs.map +1 -1
  385. package/dist/private/datepicker/useDatePickerGroup.cjs.map +1 -1
  386. package/dist/private/datepicker/useDatePickerGroup.js.map +1 -1
  387. package/dist/private/datepicker/useDatePickerGroup.mjs.map +1 -1
  388. package/dist/private/datepicker/useDateRangePicker.cjs.map +1 -1
  389. package/dist/private/datepicker/useDateRangePicker.js.map +1 -1
  390. package/dist/private/datepicker/useDateRangePicker.mjs.map +1 -1
  391. package/dist/private/datepicker/useDateSegment.cjs +2 -2
  392. package/dist/private/datepicker/useDateSegment.cjs.map +1 -1
  393. package/dist/private/datepicker/useDateSegment.js +2 -2
  394. package/dist/private/datepicker/useDateSegment.js.map +1 -1
  395. package/dist/private/datepicker/useDateSegment.mjs +2 -2
  396. package/dist/private/datepicker/useDateSegment.mjs.map +1 -1
  397. package/dist/private/datepicker/useDisplayNames.cjs +1 -2
  398. package/dist/private/datepicker/useDisplayNames.cjs.map +1 -1
  399. package/dist/private/datepicker/useDisplayNames.js +1 -2
  400. package/dist/private/datepicker/useDisplayNames.js.map +1 -1
  401. package/dist/private/datepicker/useDisplayNames.mjs +1 -2
  402. package/dist/private/datepicker/useDisplayNames.mjs.map +1 -1
  403. package/dist/private/dialog/useDialog.cjs.map +1 -1
  404. package/dist/private/dialog/useDialog.js.map +1 -1
  405. package/dist/private/dialog/useDialog.mjs.map +1 -1
  406. package/dist/private/disclosure/useDisclosure.cjs.map +1 -1
  407. package/dist/private/disclosure/useDisclosure.js.map +1 -1
  408. package/dist/private/disclosure/useDisclosure.mjs.map +1 -1
  409. package/dist/private/dnd/DragManager.cjs +4 -1
  410. package/dist/private/dnd/DragManager.cjs.map +1 -1
  411. package/dist/private/dnd/DragManager.js +4 -1
  412. package/dist/private/dnd/DragManager.js.map +1 -1
  413. package/dist/private/dnd/DragManager.mjs +4 -1
  414. package/dist/private/dnd/DragManager.mjs.map +1 -1
  415. package/dist/private/dnd/DragPreview.cjs.map +1 -1
  416. package/dist/private/dnd/DragPreview.js.map +1 -1
  417. package/dist/private/dnd/DragPreview.mjs.map +1 -1
  418. package/dist/private/dnd/DropTargetKeyboardNavigation.cjs +16 -4
  419. package/dist/private/dnd/DropTargetKeyboardNavigation.cjs.map +1 -1
  420. package/dist/private/dnd/DropTargetKeyboardNavigation.js +16 -4
  421. package/dist/private/dnd/DropTargetKeyboardNavigation.js.map +1 -1
  422. package/dist/private/dnd/DropTargetKeyboardNavigation.mjs +16 -4
  423. package/dist/private/dnd/DropTargetKeyboardNavigation.mjs.map +1 -1
  424. package/dist/private/dnd/ListDropTargetDelegate.cjs.map +1 -1
  425. package/dist/private/dnd/ListDropTargetDelegate.js.map +1 -1
  426. package/dist/private/dnd/ListDropTargetDelegate.mjs.map +1 -1
  427. package/dist/private/dnd/constants.cjs.map +1 -1
  428. package/dist/private/dnd/constants.js.map +1 -1
  429. package/dist/private/dnd/constants.mjs.map +1 -1
  430. package/dist/private/dnd/useAutoScroll.cjs.map +1 -1
  431. package/dist/private/dnd/useAutoScroll.js.map +1 -1
  432. package/dist/private/dnd/useAutoScroll.mjs.map +1 -1
  433. package/dist/private/dnd/useClipboard.cjs.map +1 -1
  434. package/dist/private/dnd/useClipboard.js.map +1 -1
  435. package/dist/private/dnd/useClipboard.mjs.map +1 -1
  436. package/dist/private/dnd/useDrag.cjs.map +1 -1
  437. package/dist/private/dnd/useDrag.js.map +1 -1
  438. package/dist/private/dnd/useDrag.mjs.map +1 -1
  439. package/dist/private/dnd/useDraggableCollection.cjs.map +1 -1
  440. package/dist/private/dnd/useDraggableCollection.js.map +1 -1
  441. package/dist/private/dnd/useDraggableCollection.mjs.map +1 -1
  442. package/dist/private/dnd/useDraggableItem.cjs.map +1 -1
  443. package/dist/private/dnd/useDraggableItem.js.map +1 -1
  444. package/dist/private/dnd/useDraggableItem.mjs.map +1 -1
  445. package/dist/private/dnd/useDrop.cjs.map +1 -1
  446. package/dist/private/dnd/useDrop.js.map +1 -1
  447. package/dist/private/dnd/useDrop.mjs.map +1 -1
  448. package/dist/private/dnd/useDropIndicator.cjs.map +1 -1
  449. package/dist/private/dnd/useDropIndicator.js.map +1 -1
  450. package/dist/private/dnd/useDropIndicator.mjs.map +1 -1
  451. package/dist/private/dnd/useDroppableCollection.cjs.map +1 -1
  452. package/dist/private/dnd/useDroppableCollection.js.map +1 -1
  453. package/dist/private/dnd/useDroppableCollection.mjs.map +1 -1
  454. package/dist/private/dnd/useDroppableItem.cjs.map +1 -1
  455. package/dist/private/dnd/useDroppableItem.js.map +1 -1
  456. package/dist/private/dnd/useDroppableItem.mjs.map +1 -1
  457. package/dist/private/dnd/useVirtualDrop.cjs.map +1 -1
  458. package/dist/private/dnd/useVirtualDrop.js.map +1 -1
  459. package/dist/private/dnd/useVirtualDrop.mjs.map +1 -1
  460. package/dist/private/dnd/utils.cjs +14 -4
  461. package/dist/private/dnd/utils.cjs.map +1 -1
  462. package/dist/private/dnd/utils.js +14 -4
  463. package/dist/private/dnd/utils.js.map +1 -1
  464. package/dist/private/dnd/utils.mjs +14 -4
  465. package/dist/private/dnd/utils.mjs.map +1 -1
  466. package/dist/private/focus/FocusRing.cjs.map +1 -1
  467. package/dist/private/focus/FocusRing.js.map +1 -1
  468. package/dist/private/focus/FocusRing.mjs.map +1 -1
  469. package/dist/private/focus/FocusScope.cjs +4 -1
  470. package/dist/private/focus/FocusScope.cjs.map +1 -1
  471. package/dist/private/focus/FocusScope.js +4 -1
  472. package/dist/private/focus/FocusScope.js.map +1 -1
  473. package/dist/private/focus/FocusScope.mjs +4 -1
  474. package/dist/private/focus/FocusScope.mjs.map +1 -1
  475. package/dist/private/focus/useFocusRing.cjs.map +1 -1
  476. package/dist/private/focus/useFocusRing.js.map +1 -1
  477. package/dist/private/focus/useFocusRing.mjs.map +1 -1
  478. package/dist/private/focus/useHasTabbableChild.cjs.map +1 -1
  479. package/dist/private/focus/useHasTabbableChild.js.map +1 -1
  480. package/dist/private/focus/useHasTabbableChild.mjs.map +1 -1
  481. package/dist/private/form/useFormValidation.cjs +1 -1
  482. package/dist/private/form/useFormValidation.cjs.map +1 -1
  483. package/dist/private/form/useFormValidation.js +1 -1
  484. package/dist/private/form/useFormValidation.js.map +1 -1
  485. package/dist/private/form/useFormValidation.mjs +1 -1
  486. package/dist/private/form/useFormValidation.mjs.map +1 -1
  487. package/dist/private/grid/GridKeyboardDelegate.cjs +9 -9
  488. package/dist/private/grid/GridKeyboardDelegate.cjs.map +1 -1
  489. package/dist/private/grid/GridKeyboardDelegate.js +10 -10
  490. package/dist/private/grid/GridKeyboardDelegate.js.map +1 -1
  491. package/dist/private/grid/GridKeyboardDelegate.mjs +9 -9
  492. package/dist/private/grid/GridKeyboardDelegate.mjs.map +1 -1
  493. package/dist/private/grid/useGrid.cjs.map +1 -1
  494. package/dist/private/grid/useGrid.js.map +1 -1
  495. package/dist/private/grid/useGrid.mjs.map +1 -1
  496. package/dist/private/grid/useGridCell.cjs.map +1 -1
  497. package/dist/private/grid/useGridCell.js.map +1 -1
  498. package/dist/private/grid/useGridCell.mjs.map +1 -1
  499. package/dist/private/grid/useGridRow.cjs.map +1 -1
  500. package/dist/private/grid/useGridRow.js.map +1 -1
  501. package/dist/private/grid/useGridRow.mjs.map +1 -1
  502. package/dist/private/grid/useGridRowGroup.cjs.map +1 -1
  503. package/dist/private/grid/useGridRowGroup.js.map +1 -1
  504. package/dist/private/grid/useGridRowGroup.mjs.map +1 -1
  505. package/dist/private/grid/useGridSelectionAnnouncement.cjs.map +1 -1
  506. package/dist/private/grid/useGridSelectionAnnouncement.js.map +1 -1
  507. package/dist/private/grid/useGridSelectionAnnouncement.mjs.map +1 -1
  508. package/dist/private/grid/useGridSelectionCheckbox.cjs.map +1 -1
  509. package/dist/private/grid/useGridSelectionCheckbox.js.map +1 -1
  510. package/dist/private/grid/useGridSelectionCheckbox.mjs.map +1 -1
  511. package/dist/private/grid/useHighlightSelectionDescription.cjs.map +1 -1
  512. package/dist/private/grid/useHighlightSelectionDescription.js.map +1 -1
  513. package/dist/private/grid/useHighlightSelectionDescription.mjs.map +1 -1
  514. package/dist/private/grid/utils.cjs.map +1 -1
  515. package/dist/private/grid/utils.js.map +1 -1
  516. package/dist/private/grid/utils.mjs.map +1 -1
  517. package/dist/private/gridlist/useGridList.cjs +2 -1
  518. package/dist/private/gridlist/useGridList.cjs.map +1 -1
  519. package/dist/private/gridlist/useGridList.js +2 -1
  520. package/dist/private/gridlist/useGridList.js.map +1 -1
  521. package/dist/private/gridlist/useGridList.mjs +2 -1
  522. package/dist/private/gridlist/useGridList.mjs.map +1 -1
  523. package/dist/private/gridlist/useGridListItem.cjs +66 -23
  524. package/dist/private/gridlist/useGridListItem.cjs.map +1 -1
  525. package/dist/private/gridlist/useGridListItem.js +67 -23
  526. package/dist/private/gridlist/useGridListItem.js.map +1 -1
  527. package/dist/private/gridlist/useGridListItem.mjs +66 -23
  528. package/dist/private/gridlist/useGridListItem.mjs.map +1 -1
  529. package/dist/private/gridlist/useGridListSection.cjs +3 -1
  530. package/dist/private/gridlist/useGridListSection.cjs.map +1 -1
  531. package/dist/private/gridlist/useGridListSection.js +3 -1
  532. package/dist/private/gridlist/useGridListSection.js.map +1 -1
  533. package/dist/private/gridlist/useGridListSection.mjs +3 -1
  534. package/dist/private/gridlist/useGridListSection.mjs.map +1 -1
  535. package/dist/private/gridlist/useGridListSelectionCheckbox.cjs.map +1 -1
  536. package/dist/private/gridlist/useGridListSelectionCheckbox.js.map +1 -1
  537. package/dist/private/gridlist/useGridListSelectionCheckbox.mjs.map +1 -1
  538. package/dist/private/gridlist/utils.cjs.map +1 -1
  539. package/dist/private/gridlist/utils.js.map +1 -1
  540. package/dist/private/gridlist/utils.mjs.map +1 -1
  541. package/dist/private/i18n/I18nProvider.cjs.map +1 -1
  542. package/dist/private/i18n/I18nProvider.js.map +1 -1
  543. package/dist/private/i18n/I18nProvider.mjs.map +1 -1
  544. package/dist/private/i18n/server.cjs.map +1 -1
  545. package/dist/private/i18n/server.js.map +1 -1
  546. package/dist/private/i18n/server.mjs.map +1 -1
  547. package/dist/private/i18n/useCollator.cjs.map +1 -1
  548. package/dist/private/i18n/useCollator.js.map +1 -1
  549. package/dist/private/i18n/useCollator.mjs.map +1 -1
  550. package/dist/private/i18n/useDateFormatter.cjs.map +1 -1
  551. package/dist/private/i18n/useDateFormatter.js.map +1 -1
  552. package/dist/private/i18n/useDateFormatter.mjs.map +1 -1
  553. package/dist/private/i18n/useDefaultLocale.cjs +2 -1
  554. package/dist/private/i18n/useDefaultLocale.cjs.map +1 -1
  555. package/dist/private/i18n/useDefaultLocale.js +2 -1
  556. package/dist/private/i18n/useDefaultLocale.js.map +1 -1
  557. package/dist/private/i18n/useDefaultLocale.mjs +2 -1
  558. package/dist/private/i18n/useDefaultLocale.mjs.map +1 -1
  559. package/dist/private/i18n/useFilter.cjs.map +1 -1
  560. package/dist/private/i18n/useFilter.js.map +1 -1
  561. package/dist/private/i18n/useFilter.mjs.map +1 -1
  562. package/dist/private/i18n/useListFormatter.cjs.map +1 -1
  563. package/dist/private/i18n/useListFormatter.js.map +1 -1
  564. package/dist/private/i18n/useListFormatter.mjs.map +1 -1
  565. package/dist/private/i18n/useLocalizedStringFormatter.cjs.map +1 -1
  566. package/dist/private/i18n/useLocalizedStringFormatter.js.map +1 -1
  567. package/dist/private/i18n/useLocalizedStringFormatter.mjs.map +1 -1
  568. package/dist/private/i18n/useNumberFormatter.cjs.map +1 -1
  569. package/dist/private/i18n/useNumberFormatter.js.map +1 -1
  570. package/dist/private/i18n/useNumberFormatter.mjs.map +1 -1
  571. package/dist/private/i18n/utils.cjs +2 -2
  572. package/dist/private/i18n/utils.cjs.map +1 -1
  573. package/dist/private/i18n/utils.js +2 -2
  574. package/dist/private/i18n/utils.js.map +1 -1
  575. package/dist/private/i18n/utils.mjs +2 -2
  576. package/dist/private/i18n/utils.mjs.map +1 -1
  577. package/dist/private/interactions/PressResponder.cjs.map +1 -1
  578. package/dist/private/interactions/PressResponder.js.map +1 -1
  579. package/dist/private/interactions/PressResponder.mjs.map +1 -1
  580. package/dist/private/interactions/Pressable.cjs.map +1 -1
  581. package/dist/private/interactions/Pressable.js.map +1 -1
  582. package/dist/private/interactions/Pressable.mjs.map +1 -1
  583. package/dist/private/interactions/context.cjs.map +1 -1
  584. package/dist/private/interactions/context.js.map +1 -1
  585. package/dist/private/interactions/context.mjs.map +1 -1
  586. package/dist/private/interactions/createEventHandler.cjs +3 -0
  587. package/dist/private/interactions/createEventHandler.cjs.map +1 -1
  588. package/dist/private/interactions/createEventHandler.js +3 -0
  589. package/dist/private/interactions/createEventHandler.js.map +1 -1
  590. package/dist/private/interactions/createEventHandler.mjs +3 -0
  591. package/dist/private/interactions/createEventHandler.mjs.map +1 -1
  592. package/dist/private/interactions/focusSafely.cjs.map +1 -1
  593. package/dist/private/interactions/focusSafely.js.map +1 -1
  594. package/dist/private/interactions/focusSafely.mjs.map +1 -1
  595. package/dist/private/interactions/textSelection.cjs.map +1 -1
  596. package/dist/private/interactions/textSelection.js.map +1 -1
  597. package/dist/private/interactions/textSelection.mjs.map +1 -1
  598. package/dist/private/interactions/useFocus.cjs.map +1 -1
  599. package/dist/private/interactions/useFocus.js.map +1 -1
  600. package/dist/private/interactions/useFocus.mjs.map +1 -1
  601. package/dist/private/interactions/useFocusVisible.cjs +20 -8
  602. package/dist/private/interactions/useFocusVisible.cjs.map +1 -1
  603. package/dist/private/interactions/useFocusVisible.js +20 -8
  604. package/dist/private/interactions/useFocusVisible.js.map +1 -1
  605. package/dist/private/interactions/useFocusVisible.mjs +20 -8
  606. package/dist/private/interactions/useFocusVisible.mjs.map +1 -1
  607. package/dist/private/interactions/useFocusWithin.cjs.map +1 -1
  608. package/dist/private/interactions/useFocusWithin.js.map +1 -1
  609. package/dist/private/interactions/useFocusWithin.mjs.map +1 -1
  610. package/dist/private/interactions/useFocusable.cjs.map +1 -1
  611. package/dist/private/interactions/useFocusable.js.map +1 -1
  612. package/dist/private/interactions/useFocusable.mjs.map +1 -1
  613. package/dist/private/interactions/useHover.cjs.map +1 -1
  614. package/dist/private/interactions/useHover.js.map +1 -1
  615. package/dist/private/interactions/useHover.mjs.map +1 -1
  616. package/dist/private/interactions/useInteractOutside.cjs.map +1 -1
  617. package/dist/private/interactions/useInteractOutside.js.map +1 -1
  618. package/dist/private/interactions/useInteractOutside.mjs.map +1 -1
  619. package/dist/private/interactions/useKeyboard.cjs.map +1 -1
  620. package/dist/private/interactions/useKeyboard.js.map +1 -1
  621. package/dist/private/interactions/useKeyboard.mjs.map +1 -1
  622. package/dist/private/interactions/useLongPress.cjs.map +1 -1
  623. package/dist/private/interactions/useLongPress.js.map +1 -1
  624. package/dist/private/interactions/useLongPress.mjs.map +1 -1
  625. package/dist/private/interactions/useMove.cjs.map +1 -1
  626. package/dist/private/interactions/useMove.js.map +1 -1
  627. package/dist/private/interactions/useMove.mjs.map +1 -1
  628. package/dist/private/interactions/usePress.cjs +11 -0
  629. package/dist/private/interactions/usePress.cjs.map +1 -1
  630. package/dist/private/interactions/usePress.js +12 -1
  631. package/dist/private/interactions/usePress.js.map +1 -1
  632. package/dist/private/interactions/usePress.mjs +12 -1
  633. package/dist/private/interactions/usePress.mjs.map +1 -1
  634. package/dist/private/interactions/useScrollWheel.cjs.map +1 -1
  635. package/dist/private/interactions/useScrollWheel.js.map +1 -1
  636. package/dist/private/interactions/useScrollWheel.mjs.map +1 -1
  637. package/dist/private/interactions/utils.cjs.map +1 -1
  638. package/dist/private/interactions/utils.js.map +1 -1
  639. package/dist/private/interactions/utils.mjs.map +1 -1
  640. package/dist/private/intl/tag/en-US.cjs.map +1 -1
  641. package/dist/private/intl/tag/en-US.js.map +1 -1
  642. package/dist/private/intl/tag/en-US.mjs.map +1 -1
  643. package/dist/private/label/useField.cjs.map +1 -1
  644. package/dist/private/label/useField.js.map +1 -1
  645. package/dist/private/label/useField.mjs.map +1 -1
  646. package/dist/private/label/useLabel.cjs.map +1 -1
  647. package/dist/private/label/useLabel.js.map +1 -1
  648. package/dist/private/label/useLabel.mjs.map +1 -1
  649. package/dist/private/landmark/useLandmark.cjs +2 -1
  650. package/dist/private/landmark/useLandmark.cjs.map +1 -1
  651. package/dist/private/landmark/useLandmark.js +2 -1
  652. package/dist/private/landmark/useLandmark.js.map +1 -1
  653. package/dist/private/landmark/useLandmark.mjs +2 -1
  654. package/dist/private/landmark/useLandmark.mjs.map +1 -1
  655. package/dist/private/link/useLink.cjs.map +1 -1
  656. package/dist/private/link/useLink.js.map +1 -1
  657. package/dist/private/link/useLink.mjs.map +1 -1
  658. package/dist/private/listbox/useListBox.cjs.map +1 -1
  659. package/dist/private/listbox/useListBox.js.map +1 -1
  660. package/dist/private/listbox/useListBox.mjs.map +1 -1
  661. package/dist/private/listbox/useListBoxSection.cjs.map +1 -1
  662. package/dist/private/listbox/useListBoxSection.js.map +1 -1
  663. package/dist/private/listbox/useListBoxSection.mjs.map +1 -1
  664. package/dist/private/listbox/useOption.cjs.map +1 -1
  665. package/dist/private/listbox/useOption.js.map +1 -1
  666. package/dist/private/listbox/useOption.mjs.map +1 -1
  667. package/dist/private/listbox/utils.cjs.map +1 -1
  668. package/dist/private/listbox/utils.js.map +1 -1
  669. package/dist/private/listbox/utils.mjs.map +1 -1
  670. package/dist/private/live-announcer/LiveAnnouncer.cjs +2 -2
  671. package/dist/private/live-announcer/LiveAnnouncer.cjs.map +1 -1
  672. package/dist/private/live-announcer/LiveAnnouncer.js +2 -2
  673. package/dist/private/live-announcer/LiveAnnouncer.js.map +1 -1
  674. package/dist/private/live-announcer/LiveAnnouncer.mjs +2 -2
  675. package/dist/private/live-announcer/LiveAnnouncer.mjs.map +1 -1
  676. package/dist/private/menu/useMenu.cjs.map +1 -1
  677. package/dist/private/menu/useMenu.js.map +1 -1
  678. package/dist/private/menu/useMenu.mjs.map +1 -1
  679. package/dist/private/menu/useMenuItem.cjs +1 -1
  680. package/dist/private/menu/useMenuItem.cjs.map +1 -1
  681. package/dist/private/menu/useMenuItem.js +1 -1
  682. package/dist/private/menu/useMenuItem.js.map +1 -1
  683. package/dist/private/menu/useMenuItem.mjs +1 -1
  684. package/dist/private/menu/useMenuItem.mjs.map +1 -1
  685. package/dist/private/menu/useMenuSection.cjs.map +1 -1
  686. package/dist/private/menu/useMenuSection.js.map +1 -1
  687. package/dist/private/menu/useMenuSection.mjs.map +1 -1
  688. package/dist/private/menu/useMenuTrigger.cjs.map +1 -1
  689. package/dist/private/menu/useMenuTrigger.js.map +1 -1
  690. package/dist/private/menu/useMenuTrigger.mjs.map +1 -1
  691. package/dist/private/menu/useSafelyMouseToSubmenu.cjs.map +1 -1
  692. package/dist/private/menu/useSafelyMouseToSubmenu.js.map +1 -1
  693. package/dist/private/menu/useSafelyMouseToSubmenu.mjs.map +1 -1
  694. package/dist/private/menu/useSubmenuTrigger.cjs.map +1 -1
  695. package/dist/private/menu/useSubmenuTrigger.js.map +1 -1
  696. package/dist/private/menu/useSubmenuTrigger.mjs.map +1 -1
  697. package/dist/private/menu/utils.cjs.map +1 -1
  698. package/dist/private/menu/utils.js.map +1 -1
  699. package/dist/private/menu/utils.mjs.map +1 -1
  700. package/dist/private/meter/useMeter.cjs.map +1 -1
  701. package/dist/private/meter/useMeter.js.map +1 -1
  702. package/dist/private/meter/useMeter.mjs.map +1 -1
  703. package/dist/private/numberfield/useNumberField.cjs.map +1 -1
  704. package/dist/private/numberfield/useNumberField.js.map +1 -1
  705. package/dist/private/numberfield/useNumberField.mjs.map +1 -1
  706. package/dist/private/overlays/DismissButton.cjs.map +1 -1
  707. package/dist/private/overlays/DismissButton.js.map +1 -1
  708. package/dist/private/overlays/DismissButton.mjs.map +1 -1
  709. package/dist/private/overlays/Overlay.cjs.map +1 -1
  710. package/dist/private/overlays/Overlay.js.map +1 -1
  711. package/dist/private/overlays/Overlay.mjs.map +1 -1
  712. package/dist/private/overlays/PortalProvider.cjs.map +1 -1
  713. package/dist/private/overlays/PortalProvider.js.map +1 -1
  714. package/dist/private/overlays/PortalProvider.mjs.map +1 -1
  715. package/dist/private/overlays/ariaHideOutside.cjs.map +1 -1
  716. package/dist/private/overlays/ariaHideOutside.js.map +1 -1
  717. package/dist/private/overlays/ariaHideOutside.mjs.map +1 -1
  718. package/dist/private/overlays/calculatePosition.cjs +19 -20
  719. package/dist/private/overlays/calculatePosition.cjs.map +1 -1
  720. package/dist/private/overlays/calculatePosition.js +20 -21
  721. package/dist/private/overlays/calculatePosition.js.map +1 -1
  722. package/dist/private/overlays/calculatePosition.mjs +19 -20
  723. package/dist/private/overlays/calculatePosition.mjs.map +1 -1
  724. package/dist/private/overlays/useCloseOnScroll.cjs.map +1 -1
  725. package/dist/private/overlays/useCloseOnScroll.js.map +1 -1
  726. package/dist/private/overlays/useCloseOnScroll.mjs.map +1 -1
  727. package/dist/private/overlays/useModal.cjs.map +1 -1
  728. package/dist/private/overlays/useModal.js.map +1 -1
  729. package/dist/private/overlays/useModal.mjs.map +1 -1
  730. package/dist/private/overlays/useModalOverlay.cjs.map +1 -1
  731. package/dist/private/overlays/useModalOverlay.js.map +1 -1
  732. package/dist/private/overlays/useModalOverlay.mjs.map +1 -1
  733. package/dist/private/overlays/useOverlay.cjs.map +1 -1
  734. package/dist/private/overlays/useOverlay.js.map +1 -1
  735. package/dist/private/overlays/useOverlay.mjs.map +1 -1
  736. package/dist/private/overlays/useOverlayPosition.cjs +3 -2
  737. package/dist/private/overlays/useOverlayPosition.cjs.map +1 -1
  738. package/dist/private/overlays/useOverlayPosition.js +3 -2
  739. package/dist/private/overlays/useOverlayPosition.js.map +1 -1
  740. package/dist/private/overlays/useOverlayPosition.mjs +3 -2
  741. package/dist/private/overlays/useOverlayPosition.mjs.map +1 -1
  742. package/dist/private/overlays/useOverlayTrigger.cjs.map +1 -1
  743. package/dist/private/overlays/useOverlayTrigger.js.map +1 -1
  744. package/dist/private/overlays/useOverlayTrigger.mjs.map +1 -1
  745. package/dist/private/overlays/usePopover.cjs.map +1 -1
  746. package/dist/private/overlays/usePopover.js.map +1 -1
  747. package/dist/private/overlays/usePopover.mjs.map +1 -1
  748. package/dist/private/overlays/usePreventScroll.cjs.map +1 -1
  749. package/dist/private/overlays/usePreventScroll.js.map +1 -1
  750. package/dist/private/overlays/usePreventScroll.mjs.map +1 -1
  751. package/dist/private/progress/useProgressBar.cjs.map +1 -1
  752. package/dist/private/progress/useProgressBar.js.map +1 -1
  753. package/dist/private/progress/useProgressBar.mjs.map +1 -1
  754. package/dist/private/radio/useRadio.cjs +5 -0
  755. package/dist/private/radio/useRadio.cjs.map +1 -1
  756. package/dist/private/radio/useRadio.js +5 -0
  757. package/dist/private/radio/useRadio.js.map +1 -1
  758. package/dist/private/radio/useRadio.mjs +5 -0
  759. package/dist/private/radio/useRadio.mjs.map +1 -1
  760. package/dist/private/radio/useRadioGroup.cjs.map +1 -1
  761. package/dist/private/radio/useRadioGroup.js.map +1 -1
  762. package/dist/private/radio/useRadioGroup.mjs.map +1 -1
  763. package/dist/private/radio/utils.cjs.map +1 -1
  764. package/dist/private/radio/utils.js.map +1 -1
  765. package/dist/private/radio/utils.mjs.map +1 -1
  766. package/dist/private/searchfield/useSearchField.cjs.map +1 -1
  767. package/dist/private/searchfield/useSearchField.js.map +1 -1
  768. package/dist/private/searchfield/useSearchField.mjs.map +1 -1
  769. package/dist/private/select/HiddenSelect.cjs +2 -1
  770. package/dist/private/select/HiddenSelect.cjs.map +1 -1
  771. package/dist/private/select/HiddenSelect.js +2 -1
  772. package/dist/private/select/HiddenSelect.js.map +1 -1
  773. package/dist/private/select/HiddenSelect.mjs +2 -1
  774. package/dist/private/select/HiddenSelect.mjs.map +1 -1
  775. package/dist/private/select/useSelect.cjs +3 -4
  776. package/dist/private/select/useSelect.cjs.map +1 -1
  777. package/dist/private/select/useSelect.js +3 -4
  778. package/dist/private/select/useSelect.js.map +1 -1
  779. package/dist/private/select/useSelect.mjs +3 -4
  780. package/dist/private/select/useSelect.mjs.map +1 -1
  781. package/dist/private/selection/ListKeyboardDelegate.cjs +56 -28
  782. package/dist/private/selection/ListKeyboardDelegate.cjs.map +1 -1
  783. package/dist/private/selection/ListKeyboardDelegate.js +57 -29
  784. package/dist/private/selection/ListKeyboardDelegate.js.map +1 -1
  785. package/dist/private/selection/ListKeyboardDelegate.mjs +56 -28
  786. package/dist/private/selection/ListKeyboardDelegate.mjs.map +1 -1
  787. package/dist/private/selection/useSelectableCollection.cjs +21 -14
  788. package/dist/private/selection/useSelectableCollection.cjs.map +1 -1
  789. package/dist/private/selection/useSelectableCollection.js +27 -19
  790. package/dist/private/selection/useSelectableCollection.js.map +1 -1
  791. package/dist/private/selection/useSelectableCollection.mjs +21 -14
  792. package/dist/private/selection/useSelectableCollection.mjs.map +1 -1
  793. package/dist/private/selection/useSelectableItem.cjs.map +1 -1
  794. package/dist/private/selection/useSelectableItem.js.map +1 -1
  795. package/dist/private/selection/useSelectableItem.mjs.map +1 -1
  796. package/dist/private/selection/useSelectableList.cjs.map +1 -1
  797. package/dist/private/selection/useSelectableList.js.map +1 -1
  798. package/dist/private/selection/useSelectableList.mjs.map +1 -1
  799. package/dist/private/selection/useTypeSelect.cjs +50 -18
  800. package/dist/private/selection/useTypeSelect.cjs.map +1 -1
  801. package/dist/private/selection/useTypeSelect.js +51 -19
  802. package/dist/private/selection/useTypeSelect.js.map +1 -1
  803. package/dist/private/selection/useTypeSelect.mjs +51 -19
  804. package/dist/private/selection/useTypeSelect.mjs.map +1 -1
  805. package/dist/private/selection/utils.cjs.map +1 -1
  806. package/dist/private/selection/utils.js.map +1 -1
  807. package/dist/private/selection/utils.mjs.map +1 -1
  808. package/dist/private/separator/useSeparator.cjs.map +1 -1
  809. package/dist/private/separator/useSeparator.js.map +1 -1
  810. package/dist/private/separator/useSeparator.mjs.map +1 -1
  811. package/dist/private/slider/useSlider.cjs +4 -2
  812. package/dist/private/slider/useSlider.cjs.map +1 -1
  813. package/dist/private/slider/useSlider.js +4 -2
  814. package/dist/private/slider/useSlider.js.map +1 -1
  815. package/dist/private/slider/useSlider.mjs +4 -2
  816. package/dist/private/slider/useSlider.mjs.map +1 -1
  817. package/dist/private/slider/useSliderThumb.cjs.map +1 -1
  818. package/dist/private/slider/useSliderThumb.js.map +1 -1
  819. package/dist/private/slider/useSliderThumb.mjs.map +1 -1
  820. package/dist/private/slider/utils.cjs.map +1 -1
  821. package/dist/private/slider/utils.js.map +1 -1
  822. package/dist/private/slider/utils.mjs.map +1 -1
  823. package/dist/private/spinbutton/useSpinButton.cjs +2 -0
  824. package/dist/private/spinbutton/useSpinButton.cjs.map +1 -1
  825. package/dist/private/spinbutton/useSpinButton.js +2 -0
  826. package/dist/private/spinbutton/useSpinButton.js.map +1 -1
  827. package/dist/private/spinbutton/useSpinButton.mjs +2 -0
  828. package/dist/private/spinbutton/useSpinButton.mjs.map +1 -1
  829. package/dist/private/ssr/SSRProvider.cjs +6 -6
  830. package/dist/private/ssr/SSRProvider.cjs.map +1 -1
  831. package/dist/private/ssr/SSRProvider.js +6 -6
  832. package/dist/private/ssr/SSRProvider.js.map +1 -1
  833. package/dist/private/ssr/SSRProvider.mjs +6 -6
  834. package/dist/private/ssr/SSRProvider.mjs.map +1 -1
  835. package/dist/private/steplist/useStepList.cjs.map +1 -1
  836. package/dist/private/steplist/useStepList.js.map +1 -1
  837. package/dist/private/steplist/useStepList.mjs.map +1 -1
  838. package/dist/private/steplist/useStepListItem.cjs.map +1 -1
  839. package/dist/private/steplist/useStepListItem.js.map +1 -1
  840. package/dist/private/steplist/useStepListItem.mjs.map +1 -1
  841. package/dist/private/switch/useSwitch.cjs +2 -4
  842. package/dist/private/switch/useSwitch.cjs.map +1 -1
  843. package/dist/private/switch/useSwitch.js +2 -4
  844. package/dist/private/switch/useSwitch.js.map +1 -1
  845. package/dist/private/switch/useSwitch.mjs +2 -4
  846. package/dist/private/switch/useSwitch.mjs.map +1 -1
  847. package/dist/private/table/TableKeyboardDelegate.cjs +4 -4
  848. package/dist/private/table/TableKeyboardDelegate.cjs.map +1 -1
  849. package/dist/private/table/TableKeyboardDelegate.js +4 -4
  850. package/dist/private/table/TableKeyboardDelegate.js.map +1 -1
  851. package/dist/private/table/TableKeyboardDelegate.mjs +4 -4
  852. package/dist/private/table/TableKeyboardDelegate.mjs.map +1 -1
  853. package/dist/private/table/useTable.cjs.map +1 -1
  854. package/dist/private/table/useTable.js.map +1 -1
  855. package/dist/private/table/useTable.mjs.map +1 -1
  856. package/dist/private/table/useTableCell.cjs.map +1 -1
  857. package/dist/private/table/useTableCell.js.map +1 -1
  858. package/dist/private/table/useTableCell.mjs.map +1 -1
  859. package/dist/private/table/useTableColumnHeader.cjs.map +1 -1
  860. package/dist/private/table/useTableColumnHeader.js.map +1 -1
  861. package/dist/private/table/useTableColumnHeader.mjs.map +1 -1
  862. package/dist/private/table/useTableColumnResize.cjs +1 -1
  863. package/dist/private/table/useTableColumnResize.cjs.map +1 -1
  864. package/dist/private/table/useTableColumnResize.js +1 -1
  865. package/dist/private/table/useTableColumnResize.js.map +1 -1
  866. package/dist/private/table/useTableColumnResize.mjs +1 -1
  867. package/dist/private/table/useTableColumnResize.mjs.map +1 -1
  868. package/dist/private/table/useTableHeaderRow.cjs +2 -1
  869. package/dist/private/table/useTableHeaderRow.cjs.map +1 -1
  870. package/dist/private/table/useTableHeaderRow.js +2 -1
  871. package/dist/private/table/useTableHeaderRow.js.map +1 -1
  872. package/dist/private/table/useTableHeaderRow.mjs +2 -1
  873. package/dist/private/table/useTableHeaderRow.mjs.map +1 -1
  874. package/dist/private/table/useTableRow.cjs +2 -2
  875. package/dist/private/table/useTableRow.cjs.map +1 -1
  876. package/dist/private/table/useTableRow.js +2 -2
  877. package/dist/private/table/useTableRow.js.map +1 -1
  878. package/dist/private/table/useTableRow.mjs +2 -2
  879. package/dist/private/table/useTableRow.mjs.map +1 -1
  880. package/dist/private/table/useTableSelectionCheckbox.cjs.map +1 -1
  881. package/dist/private/table/useTableSelectionCheckbox.js.map +1 -1
  882. package/dist/private/table/useTableSelectionCheckbox.mjs.map +1 -1
  883. package/dist/private/table/utils.cjs.map +1 -1
  884. package/dist/private/table/utils.js.map +1 -1
  885. package/dist/private/table/utils.mjs.map +1 -1
  886. package/dist/private/tabs/TabsKeyboardDelegate.cjs +2 -2
  887. package/dist/private/tabs/TabsKeyboardDelegate.cjs.map +1 -1
  888. package/dist/private/tabs/TabsKeyboardDelegate.js +2 -2
  889. package/dist/private/tabs/TabsKeyboardDelegate.js.map +1 -1
  890. package/dist/private/tabs/TabsKeyboardDelegate.mjs +2 -2
  891. package/dist/private/tabs/TabsKeyboardDelegate.mjs.map +1 -1
  892. package/dist/private/tabs/useTab.cjs.map +1 -1
  893. package/dist/private/tabs/useTab.js.map +1 -1
  894. package/dist/private/tabs/useTab.mjs.map +1 -1
  895. package/dist/private/tabs/useTabList.cjs +10 -10
  896. package/dist/private/tabs/useTabList.cjs.map +1 -1
  897. package/dist/private/tabs/useTabList.js +10 -10
  898. package/dist/private/tabs/useTabList.js.map +1 -1
  899. package/dist/private/tabs/useTabList.mjs +10 -10
  900. package/dist/private/tabs/useTabList.mjs.map +1 -1
  901. package/dist/private/tabs/useTabPanel.cjs.map +1 -1
  902. package/dist/private/tabs/useTabPanel.js.map +1 -1
  903. package/dist/private/tabs/useTabPanel.mjs.map +1 -1
  904. package/dist/private/tabs/utils.cjs.map +1 -1
  905. package/dist/private/tabs/utils.js.map +1 -1
  906. package/dist/private/tabs/utils.mjs.map +1 -1
  907. package/dist/private/tag/useTag.cjs.map +1 -1
  908. package/dist/private/tag/useTag.js.map +1 -1
  909. package/dist/private/tag/useTag.mjs.map +1 -1
  910. package/dist/private/tag/useTagGroup.cjs.map +1 -1
  911. package/dist/private/tag/useTagGroup.js.map +1 -1
  912. package/dist/private/tag/useTagGroup.mjs.map +1 -1
  913. package/dist/private/textfield/useFormattedTextField.cjs.map +1 -1
  914. package/dist/private/textfield/useFormattedTextField.js.map +1 -1
  915. package/dist/private/textfield/useFormattedTextField.mjs.map +1 -1
  916. package/dist/private/textfield/useTextField.cjs.map +1 -1
  917. package/dist/private/textfield/useTextField.js.map +1 -1
  918. package/dist/private/textfield/useTextField.mjs.map +1 -1
  919. package/dist/private/toast/useToast.cjs +2 -1
  920. package/dist/private/toast/useToast.cjs.map +1 -1
  921. package/dist/private/toast/useToast.js +2 -1
  922. package/dist/private/toast/useToast.js.map +1 -1
  923. package/dist/private/toast/useToast.mjs +2 -1
  924. package/dist/private/toast/useToast.mjs.map +1 -1
  925. package/dist/private/toast/useToastRegion.cjs.map +1 -1
  926. package/dist/private/toast/useToastRegion.js.map +1 -1
  927. package/dist/private/toast/useToastRegion.mjs.map +1 -1
  928. package/dist/private/toggle/useToggle.cjs +70 -8
  929. package/dist/private/toggle/useToggle.cjs.map +1 -1
  930. package/dist/private/toggle/useToggle.js +70 -8
  931. package/dist/private/toggle/useToggle.js.map +1 -1
  932. package/dist/private/toggle/useToggle.mjs +70 -8
  933. package/dist/private/toggle/useToggle.mjs.map +1 -1
  934. package/dist/private/toolbar/useToolbar.cjs +0 -1
  935. package/dist/private/toolbar/useToolbar.cjs.map +1 -1
  936. package/dist/private/toolbar/useToolbar.js +0 -1
  937. package/dist/private/toolbar/useToolbar.js.map +1 -1
  938. package/dist/private/toolbar/useToolbar.mjs +0 -1
  939. package/dist/private/toolbar/useToolbar.mjs.map +1 -1
  940. package/dist/private/tooltip/useTooltip.cjs.map +1 -1
  941. package/dist/private/tooltip/useTooltip.js.map +1 -1
  942. package/dist/private/tooltip/useTooltip.mjs.map +1 -1
  943. package/dist/private/tooltip/useTooltipTrigger.cjs.map +1 -1
  944. package/dist/private/tooltip/useTooltipTrigger.js.map +1 -1
  945. package/dist/private/tooltip/useTooltipTrigger.mjs.map +1 -1
  946. package/dist/private/tree/useTree.cjs.map +1 -1
  947. package/dist/private/tree/useTree.js.map +1 -1
  948. package/dist/private/tree/useTree.mjs.map +1 -1
  949. package/dist/private/tree/useTreeItem.cjs.map +1 -1
  950. package/dist/private/tree/useTreeItem.js.map +1 -1
  951. package/dist/private/tree/useTreeItem.mjs.map +1 -1
  952. package/dist/private/utils/animation.cjs.map +1 -1
  953. package/dist/private/utils/animation.js.map +1 -1
  954. package/dist/private/utils/animation.mjs.map +1 -1
  955. package/dist/private/utils/domHelpers.cjs +2 -1
  956. package/dist/private/utils/domHelpers.cjs.map +1 -1
  957. package/dist/private/utils/domHelpers.js +2 -1
  958. package/dist/private/utils/domHelpers.js.map +1 -1
  959. package/dist/private/utils/domHelpers.mjs +2 -1
  960. package/dist/private/utils/domHelpers.mjs.map +1 -1
  961. package/dist/private/utils/filterDOMProps.cjs.map +1 -1
  962. package/dist/private/utils/filterDOMProps.js.map +1 -1
  963. package/dist/private/utils/filterDOMProps.mjs.map +1 -1
  964. package/dist/private/utils/focusWithoutScrolling.cjs.map +1 -1
  965. package/dist/private/utils/focusWithoutScrolling.js.map +1 -1
  966. package/dist/private/utils/focusWithoutScrolling.mjs.map +1 -1
  967. package/dist/private/utils/getNonce.cjs.map +1 -1
  968. package/dist/private/utils/getNonce.js.map +1 -1
  969. package/dist/private/utils/getNonce.mjs.map +1 -1
  970. package/dist/private/utils/getOffset.cjs.map +1 -1
  971. package/dist/private/utils/getOffset.js.map +1 -1
  972. package/dist/private/utils/getOffset.mjs.map +1 -1
  973. package/dist/private/utils/getScrollParent.cjs.map +1 -1
  974. package/dist/private/utils/getScrollParent.js.map +1 -1
  975. package/dist/private/utils/getScrollParent.mjs.map +1 -1
  976. package/dist/private/utils/getScrollParents.cjs +3 -2
  977. package/dist/private/utils/getScrollParents.cjs.map +1 -1
  978. package/dist/private/utils/getScrollParents.js +3 -2
  979. package/dist/private/utils/getScrollParents.js.map +1 -1
  980. package/dist/private/utils/getScrollParents.mjs +3 -2
  981. package/dist/private/utils/getScrollParents.mjs.map +1 -1
  982. package/dist/private/utils/isElementVisible.cjs +1 -1
  983. package/dist/private/utils/isElementVisible.cjs.map +1 -1
  984. package/dist/private/utils/isElementVisible.js +1 -1
  985. package/dist/private/utils/isElementVisible.js.map +1 -1
  986. package/dist/private/utils/isElementVisible.mjs +1 -1
  987. package/dist/private/utils/isElementVisible.mjs.map +1 -1
  988. package/dist/private/utils/isFocusable.cjs +3 -1
  989. package/dist/private/utils/isFocusable.cjs.map +1 -1
  990. package/dist/private/utils/isFocusable.js +3 -1
  991. package/dist/private/utils/isFocusable.js.map +1 -1
  992. package/dist/private/utils/isFocusable.mjs +3 -1
  993. package/dist/private/utils/isFocusable.mjs.map +1 -1
  994. package/dist/private/utils/isVirtualEvent.cjs.map +1 -1
  995. package/dist/private/utils/isVirtualEvent.js.map +1 -1
  996. package/dist/private/utils/isVirtualEvent.mjs.map +1 -1
  997. package/dist/private/utils/keyboard.cjs.map +1 -1
  998. package/dist/private/utils/keyboard.js.map +1 -1
  999. package/dist/private/utils/keyboard.mjs.map +1 -1
  1000. package/dist/private/utils/mergeProps.cjs.map +1 -1
  1001. package/dist/private/utils/mergeProps.js.map +1 -1
  1002. package/dist/private/utils/mergeProps.mjs.map +1 -1
  1003. package/dist/private/utils/mergeRefs.cjs.map +1 -1
  1004. package/dist/private/utils/mergeRefs.js.map +1 -1
  1005. package/dist/private/utils/mergeRefs.mjs.map +1 -1
  1006. package/dist/private/utils/openLink.cjs +12 -8
  1007. package/dist/private/utils/openLink.cjs.map +1 -1
  1008. package/dist/private/utils/openLink.js +12 -8
  1009. package/dist/private/utils/openLink.js.map +1 -1
  1010. package/dist/private/utils/openLink.mjs +12 -8
  1011. package/dist/private/utils/openLink.mjs.map +1 -1
  1012. package/dist/private/utils/platform.cjs.map +1 -1
  1013. package/dist/private/utils/platform.js.map +1 -1
  1014. package/dist/private/utils/platform.mjs.map +1 -1
  1015. package/dist/private/utils/scrollIntoView.cjs +21 -18
  1016. package/dist/private/utils/scrollIntoView.cjs.map +1 -1
  1017. package/dist/private/utils/scrollIntoView.js +21 -18
  1018. package/dist/private/utils/scrollIntoView.js.map +1 -1
  1019. package/dist/private/utils/scrollIntoView.mjs +21 -18
  1020. package/dist/private/utils/scrollIntoView.mjs.map +1 -1
  1021. package/dist/private/utils/shadowdom/DOMFunctions.cjs.map +1 -1
  1022. package/dist/private/utils/shadowdom/DOMFunctions.js.map +1 -1
  1023. package/dist/private/utils/shadowdom/DOMFunctions.mjs.map +1 -1
  1024. package/dist/private/utils/shadowdom/ShadowTreeWalker.cjs +6 -6
  1025. package/dist/private/utils/shadowdom/ShadowTreeWalker.cjs.map +1 -1
  1026. package/dist/private/utils/shadowdom/ShadowTreeWalker.js +6 -6
  1027. package/dist/private/utils/shadowdom/ShadowTreeWalker.js.map +1 -1
  1028. package/dist/private/utils/shadowdom/ShadowTreeWalker.mjs +6 -6
  1029. package/dist/private/utils/shadowdom/ShadowTreeWalker.mjs.map +1 -1
  1030. package/dist/private/utils/useDeepMemo.cjs +1 -1
  1031. package/dist/private/utils/useDeepMemo.cjs.map +1 -1
  1032. package/dist/private/utils/useDeepMemo.js +1 -1
  1033. package/dist/private/utils/useDeepMemo.js.map +1 -1
  1034. package/dist/private/utils/useDeepMemo.mjs +1 -1
  1035. package/dist/private/utils/useDeepMemo.mjs.map +1 -1
  1036. package/dist/private/utils/useDescription.cjs.map +1 -1
  1037. package/dist/private/utils/useDescription.js.map +1 -1
  1038. package/dist/private/utils/useDescription.mjs.map +1 -1
  1039. package/dist/private/utils/useDrag1D.cjs +1 -1
  1040. package/dist/private/utils/useDrag1D.cjs.map +1 -1
  1041. package/dist/private/utils/useDrag1D.js +1 -1
  1042. package/dist/private/utils/useDrag1D.js.map +1 -1
  1043. package/dist/private/utils/useDrag1D.mjs +1 -1
  1044. package/dist/private/utils/useDrag1D.mjs.map +1 -1
  1045. package/dist/private/utils/useFormReset.cjs.map +1 -1
  1046. package/dist/private/utils/useFormReset.js.map +1 -1
  1047. package/dist/private/utils/useFormReset.mjs.map +1 -1
  1048. package/dist/private/utils/useGlobalListeners.cjs.map +1 -1
  1049. package/dist/private/utils/useGlobalListeners.js.map +1 -1
  1050. package/dist/private/utils/useGlobalListeners.mjs.map +1 -1
  1051. package/dist/private/utils/useId.cjs.map +1 -1
  1052. package/dist/private/utils/useId.js.map +1 -1
  1053. package/dist/private/utils/useId.mjs.map +1 -1
  1054. package/dist/private/utils/useLabels.cjs.map +1 -1
  1055. package/dist/private/utils/useLabels.js.map +1 -1
  1056. package/dist/private/utils/useLabels.mjs.map +1 -1
  1057. package/dist/private/utils/useLayoutEffect.cjs.map +1 -1
  1058. package/dist/private/utils/useLayoutEffect.js.map +1 -1
  1059. package/dist/private/utils/useLayoutEffect.mjs.map +1 -1
  1060. package/dist/private/utils/useLoadMore.cjs.map +1 -1
  1061. package/dist/private/utils/useLoadMore.js.map +1 -1
  1062. package/dist/private/utils/useLoadMore.mjs.map +1 -1
  1063. package/dist/private/utils/useLoadMoreSentinel.cjs.map +1 -1
  1064. package/dist/private/utils/useLoadMoreSentinel.js.map +1 -1
  1065. package/dist/private/utils/useLoadMoreSentinel.mjs.map +1 -1
  1066. package/dist/private/utils/useObjectRef.cjs.map +1 -1
  1067. package/dist/private/utils/useObjectRef.js.map +1 -1
  1068. package/dist/private/utils/useObjectRef.mjs.map +1 -1
  1069. package/dist/private/utils/useResizeObserver.cjs.map +1 -1
  1070. package/dist/private/utils/useResizeObserver.js.map +1 -1
  1071. package/dist/private/utils/useResizeObserver.mjs.map +1 -1
  1072. package/dist/private/utils/useSlot.cjs +54 -0
  1073. package/dist/private/utils/useSlot.cjs.map +1 -0
  1074. package/dist/private/utils/useSlot.js +49 -0
  1075. package/dist/private/utils/useSlot.js.map +1 -0
  1076. package/dist/private/utils/useSlot.mjs +49 -0
  1077. package/dist/private/utils/useSlot.mjs.map +1 -0
  1078. package/dist/private/utils/useSyncRef.cjs +2 -1
  1079. package/dist/private/utils/useSyncRef.cjs.map +1 -1
  1080. package/dist/private/utils/useSyncRef.js +2 -1
  1081. package/dist/private/utils/useSyncRef.js.map +1 -1
  1082. package/dist/private/utils/useSyncRef.mjs +2 -1
  1083. package/dist/private/utils/useSyncRef.mjs.map +1 -1
  1084. package/dist/private/utils/useUpdateEffect.cjs.map +1 -1
  1085. package/dist/private/utils/useUpdateEffect.js.map +1 -1
  1086. package/dist/private/utils/useUpdateEffect.mjs.map +1 -1
  1087. package/dist/private/utils/useValueEffect.cjs.map +1 -1
  1088. package/dist/private/utils/useValueEffect.js.map +1 -1
  1089. package/dist/private/utils/useValueEffect.mjs.map +1 -1
  1090. package/dist/private/utils/useViewportSize.cjs +3 -1
  1091. package/dist/private/utils/useViewportSize.cjs.map +1 -1
  1092. package/dist/private/utils/useViewportSize.js +3 -1
  1093. package/dist/private/utils/useViewportSize.js.map +1 -1
  1094. package/dist/private/utils/useViewportSize.mjs +3 -1
  1095. package/dist/private/utils/useViewportSize.mjs.map +1 -1
  1096. package/dist/private/virtualizer/ScrollView.cjs +2 -2
  1097. package/dist/private/virtualizer/ScrollView.cjs.map +1 -1
  1098. package/dist/private/virtualizer/ScrollView.js +2 -2
  1099. package/dist/private/virtualizer/ScrollView.js.map +1 -1
  1100. package/dist/private/virtualizer/ScrollView.mjs +2 -2
  1101. package/dist/private/virtualizer/ScrollView.mjs.map +1 -1
  1102. package/dist/private/virtualizer/Virtualizer.cjs.map +1 -1
  1103. package/dist/private/virtualizer/Virtualizer.js.map +1 -1
  1104. package/dist/private/virtualizer/Virtualizer.mjs.map +1 -1
  1105. package/dist/private/virtualizer/VirtualizerItem.cjs.map +1 -1
  1106. package/dist/private/virtualizer/VirtualizerItem.js.map +1 -1
  1107. package/dist/private/virtualizer/VirtualizerItem.mjs.map +1 -1
  1108. package/dist/private/virtualizer/useVirtualizerItem.cjs.map +1 -1
  1109. package/dist/private/virtualizer/useVirtualizerItem.js.map +1 -1
  1110. package/dist/private/virtualizer/useVirtualizerItem.mjs.map +1 -1
  1111. package/dist/private/virtualizer/utils.cjs.map +1 -1
  1112. package/dist/private/virtualizer/utils.js.map +1 -1
  1113. package/dist/private/virtualizer/utils.mjs.map +1 -1
  1114. package/dist/private/visually-hidden/VisuallyHidden.cjs.map +1 -1
  1115. package/dist/private/visually-hidden/VisuallyHidden.js.map +1 -1
  1116. package/dist/private/visually-hidden/VisuallyHidden.mjs.map +1 -1
  1117. package/dist/types/exports/index.d.ts +7 -0
  1118. package/dist/types/exports/useCalendar.d.ts +6 -0
  1119. package/dist/types/exports/useRangeCalendar.d.ts +11 -0
  1120. package/dist/types/src/actiongroup/useActionGroup.d.ts +5 -1
  1121. package/dist/types/src/aria-modal-polyfill/ariaModalPolyfill.d.ts +2 -1
  1122. package/dist/types/src/autocomplete/useAutocomplete.d.ts +21 -9
  1123. package/dist/types/src/autocomplete/useSearchAutocomplete.d.ts +15 -8
  1124. package/dist/types/src/breadcrumbs/useBreadcrumbItem.d.ts +2 -0
  1125. package/dist/types/src/button/useButton.d.ts +25 -7
  1126. package/dist/types/src/button/useToggleButtonGroup.d.ts +1 -0
  1127. package/dist/types/src/calendar/useCalendar.d.ts +3 -3
  1128. package/dist/types/src/calendar/useCalendarBase.d.ts +2 -2
  1129. package/dist/types/src/calendar/useCalendarCell.d.ts +9 -8
  1130. package/dist/types/src/calendar/useCalendarGrid.d.ts +8 -4
  1131. package/dist/types/src/calendar/useCalendarHeading.d.ts +22 -0
  1132. package/dist/types/src/calendar/useCalendarMonthPicker.d.ts +22 -0
  1133. package/dist/types/src/calendar/useCalendarYearPicker.d.ts +32 -0
  1134. package/dist/types/src/calendar/useRangeCalendar.d.ts +5 -5
  1135. package/dist/types/src/calendar/utils.d.ts +3 -3
  1136. package/dist/types/src/checkbox/useCheckbox.d.ts +6 -1
  1137. package/dist/types/src/checkbox/useCheckboxGroup.d.ts +1 -0
  1138. package/dist/types/src/checkbox/useCheckboxGroupItem.d.ts +3 -2
  1139. package/dist/types/src/collections/CollectionBuilder.d.ts +8 -7
  1140. package/dist/types/src/collections/useCachedChildren.d.ts +1 -1
  1141. package/dist/types/src/color/useColorArea.d.ts +7 -4
  1142. package/dist/types/src/color/useColorChannelField.d.ts +2 -2
  1143. package/dist/types/src/combobox/useComboBox.d.ts +5 -3
  1144. package/dist/types/src/datepicker/useDateField.d.ts +2 -1
  1145. package/dist/types/src/datepicker/useDatePicker.d.ts +5 -3
  1146. package/dist/types/src/dialog/useDialog.d.ts +1 -0
  1147. package/dist/types/src/disclosure/useDisclosure.d.ts +1 -0
  1148. package/dist/types/src/dnd/ListDropTargetDelegate.d.ts +3 -0
  1149. package/dist/types/src/dnd/useDrag.d.ts +11 -4
  1150. package/dist/types/src/dnd/useDraggableCollection.d.ts +2 -2
  1151. package/dist/types/src/dnd/useDraggableItem.d.ts +7 -6
  1152. package/dist/types/src/dnd/useDrop.d.ts +5 -4
  1153. package/dist/types/src/dnd/useDroppableCollection.d.ts +2 -2
  1154. package/dist/types/src/dnd/utils.d.ts +3 -3
  1155. package/dist/types/src/focus/FocusRing.d.ts +1 -0
  1156. package/dist/types/src/focus/useFocusRing.d.ts +1 -0
  1157. package/dist/types/src/focus/useHasTabbableChild.d.ts +1 -0
  1158. package/dist/types/src/grid/GridKeyboardDelegate.d.ts +8 -4
  1159. package/dist/types/src/grid/useGrid.d.ts +12 -4
  1160. package/dist/types/src/grid/useGridCell.d.ts +11 -3
  1161. package/dist/types/src/grid/useGridRow.d.ts +7 -2
  1162. package/dist/types/src/grid/useGridSelectionAnnouncement.d.ts +3 -1
  1163. package/dist/types/src/grid/useGridSelectionCheckbox.d.ts +1 -0
  1164. package/dist/types/src/grid/useHighlightSelectionDescription.d.ts +1 -0
  1165. package/dist/types/src/gridlist/useGridList.d.ts +20 -5
  1166. package/dist/types/src/gridlist/useGridListItem.d.ts +5 -1
  1167. package/dist/types/src/gridlist/useGridListSection.d.ts +1 -0
  1168. package/dist/types/src/gridlist/useGridListSelectionCheckbox.d.ts +1 -0
  1169. package/dist/types/src/i18n/useCollator.d.ts +3 -2
  1170. package/dist/types/src/i18n/useDateFormatter.d.ts +3 -2
  1171. package/dist/types/src/i18n/useFilter.d.ts +3 -2
  1172. package/dist/types/src/i18n/useListFormatter.d.ts +3 -2
  1173. package/dist/types/src/i18n/useLocalizedStringFormatter.d.ts +3 -1
  1174. package/dist/types/src/i18n/useNumberFormatter.d.ts +3 -2
  1175. package/dist/types/src/i18n/utils.d.ts +2 -1
  1176. package/dist/types/src/interactions/createEventHandler.d.ts +2 -1
  1177. package/dist/types/src/interactions/useFocusVisible.d.ts +11 -9
  1178. package/dist/types/src/interactions/useLongPress.d.ts +3 -2
  1179. package/dist/types/src/interactions/utils.d.ts +4 -3
  1180. package/dist/types/src/label/useField.d.ts +3 -2
  1181. package/dist/types/src/label/useLabel.d.ts +2 -0
  1182. package/dist/types/src/landmark/useLandmark.d.ts +4 -1
  1183. package/dist/types/src/link/useLink.d.ts +1 -0
  1184. package/dist/types/src/listbox/useListBox.d.ts +8 -3
  1185. package/dist/types/src/listbox/useListBoxSection.d.ts +1 -0
  1186. package/dist/types/src/listbox/useOption.d.ts +7 -0
  1187. package/dist/types/src/menu/useMenu.d.ts +3 -1
  1188. package/dist/types/src/menu/useMenuItem.d.ts +10 -1
  1189. package/dist/types/src/menu/useMenuSection.d.ts +1 -0
  1190. package/dist/types/src/menu/useMenuTrigger.d.ts +1 -0
  1191. package/dist/types/src/menu/useSafelyMouseToSubmenu.d.ts +3 -2
  1192. package/dist/types/src/menu/useSubmenuTrigger.d.ts +7 -2
  1193. package/dist/types/src/menu/utils.d.ts +1 -1
  1194. package/dist/types/src/numberfield/useNumberField.d.ts +11 -4
  1195. package/dist/types/src/overlays/Overlay.d.ts +1 -0
  1196. package/dist/types/src/overlays/PortalProvider.d.ts +4 -1
  1197. package/dist/types/src/overlays/ariaHideOutside.d.ts +1 -0
  1198. package/dist/types/src/overlays/calculatePosition.d.ts +3 -1
  1199. package/dist/types/src/overlays/useModal.d.ts +8 -7
  1200. package/dist/types/src/overlays/useModalOverlay.d.ts +2 -0
  1201. package/dist/types/src/overlays/useOverlay.d.ts +2 -0
  1202. package/dist/types/src/overlays/useOverlayPosition.d.ts +18 -0
  1203. package/dist/types/src/progress/useProgressBar.d.ts +5 -1
  1204. package/dist/types/src/radio/useRadio.d.ts +4 -1
  1205. package/dist/types/src/radio/useRadioGroup.d.ts +1 -0
  1206. package/dist/types/src/searchfield/useSearchField.d.ts +7 -2
  1207. package/dist/types/src/select/HiddenSelect.d.ts +2 -1
  1208. package/dist/types/src/select/useSelect.d.ts +3 -1
  1209. package/dist/types/src/selection/ListKeyboardDelegate.d.ts +19 -6
  1210. package/dist/types/src/selection/useSelectableCollection.d.ts +17 -2
  1211. package/dist/types/src/selection/useSelectableItem.d.ts +9 -7
  1212. package/dist/types/src/selection/useSelectableList.d.ts +5 -2
  1213. package/dist/types/src/separator/useSeparator.d.ts +1 -0
  1214. package/dist/types/src/slider/useSlider.d.ts +5 -4
  1215. package/dist/types/src/slider/useSliderThumb.d.ts +3 -1
  1216. package/dist/types/src/switch/useSwitch.d.ts +14 -27
  1217. package/dist/types/src/table/TableKeyboardDelegate.d.ts +6 -2
  1218. package/dist/types/src/table/useTable.d.ts +8 -4
  1219. package/dist/types/src/table/useTableCell.d.ts +7 -2
  1220. package/dist/types/src/table/useTableColumnHeader.d.ts +9 -2
  1221. package/dist/types/src/table/useTableColumnResize.d.ts +12 -6
  1222. package/dist/types/src/table/useTableHeaderRow.d.ts +1 -0
  1223. package/dist/types/src/table/useTableRow.d.ts +1 -0
  1224. package/dist/types/src/table/useTableSelectionCheckbox.d.ts +2 -0
  1225. package/dist/types/src/tabs/useTabList.d.ts +2 -0
  1226. package/dist/types/src/tabs/useTabPanel.d.ts +2 -2
  1227. package/dist/types/src/tag/useTag.d.ts +1 -0
  1228. package/dist/types/src/tag/useTagGroup.d.ts +7 -3
  1229. package/dist/types/src/textfield/useTextField.d.ts +26 -11
  1230. package/dist/types/src/toast/useToast.d.ts +2 -2
  1231. package/dist/types/src/toast/useToastRegion.d.ts +5 -3
  1232. package/dist/types/src/toggle/useToggle.d.ts +8 -3
  1233. package/dist/types/src/toolbar/useToolbar.d.ts +2 -0
  1234. package/dist/types/src/tree/useTree.d.ts +5 -3
  1235. package/dist/types/src/tree/useTreeItem.d.ts +5 -1
  1236. package/dist/types/src/utils/filterDOMProps.d.ts +1 -0
  1237. package/dist/types/src/utils/getNonce.d.ts +3 -2
  1238. package/dist/types/src/utils/isElementVisible.d.ts +1 -0
  1239. package/dist/types/src/utils/mergeProps.d.ts +3 -2
  1240. package/dist/types/src/utils/scrollIntoView.d.ts +5 -3
  1241. package/dist/types/src/utils/shadowdom/DOMFunctions.d.ts +1 -0
  1242. package/dist/types/src/utils/useId.d.ts +2 -0
  1243. package/dist/types/src/utils/useLabels.d.ts +1 -0
  1244. package/dist/types/src/utils/useLoadMore.d.ts +6 -4
  1245. package/dist/types/src/utils/useLoadMoreSentinel.d.ts +5 -3
  1246. package/dist/types/src/utils/useSlot.d.ts +8 -0
  1247. package/dist/types/src/visually-hidden/VisuallyHidden.d.ts +1 -0
  1248. package/package.json +10 -8
@@ -3,7 +3,11 @@ import {getEventTarget as $d8ac7ed472840322$export$e58f029f0fbfdb29} from "../ut
3
3
  import {mergeProps as $64c36edd757dfa16$export$9d1611c77c2fe928} from "../utils/mergeProps.js";
4
4
  import {useFocusable as $088f27a386bc4a8f$export$4c014de7c8940b4c} from "../interactions/useFocusable.js";
5
5
  import {useFormReset as $5dfd40f1661a7fc3$export$5add1d006293d136} from "../utils/useFormReset.js";
6
+ import {useFormValidation as $3bea40a930a50ce5$export$b8473d3665f3a75a} from "../form/useFormValidation.js";
6
7
  import {usePress as $a87f4c40785e693b$export$45712eceda6fad21} from "../interactions/usePress.js";
8
+ import {useSlotId2 as $901b0394915cd0c2$export$ed2feabec4a533f4} from "../utils/useSlot.js";
9
+ import {useState as $2yVP5$useState} from "react";
10
+ import {useFormValidationState as $2yVP5$useFormValidationState, privateValidationStateProp as $2yVP5$privateValidationStateProp} from "react-stately/private/form/useFormValidationState";
7
11
 
8
12
  /*
9
13
  * Copyright 2020 Adobe. All rights reserved.
@@ -21,8 +25,19 @@ import {usePress as $a87f4c40785e693b$export$45712eceda6fad21} from "../interact
21
25
 
22
26
 
23
27
 
28
+
29
+
30
+
31
+
24
32
  function $02953ddad5f95ac5$export$cbe85ee05b554577(props, state, ref) {
25
- let { isDisabled: isDisabled = false, isReadOnly: isReadOnly = false, value: value, name: name, form: form, children: children, 'aria-label': ariaLabel, 'aria-labelledby': ariaLabelledby, validationState: validationState = 'valid', isInvalid: isInvalid, onPressStart: onPressStart, onPressEnd: onPressEnd, onPressChange: onPressChange, onPress: onPress, onPressUp: onPressUp, onClick: onClick } = props;
33
+ let { isDisabled: isDisabled = false, isReadOnly: isReadOnly = false, value: value, name: name, form: form, children: children, isRequired: isRequired, validationBehavior: validationBehavior = 'aria', 'aria-label': ariaLabel, 'aria-labelledby': ariaLabelledby, 'aria-describedby': ariaDescribedby, onPressStart: onPressStart, onPressEnd: onPressEnd, onPressChange: onPressChange, onPress: onPress, onPressUp: onPressUp, onClick: onClick } = props;
34
+ // Create validation state here because it doesn't make sense to add to general useToggleState.
35
+ let validationState = (0, $2yVP5$useFormValidationState)({
36
+ ...props,
37
+ value: state.isSelected
38
+ });
39
+ let { isInvalid: isInvalid, validationErrors: validationErrors, validationDetails: validationDetails } = validationState.displayValidation;
40
+ (0, $3bea40a930a50ce5$export$b8473d3665f3a75a)(props, validationState, ref);
26
41
  let onChange = (e)=>{
27
42
  // since we spread props on label, onChange will end up there as well as in here.
28
43
  // so we have to stop propagation at the lowest level that we care about
@@ -43,17 +58,49 @@ function $02953ddad5f95ac5$export$cbe85ee05b554577(props, state, ref) {
43
58
  isDisabled: isDisabled
44
59
  });
45
60
  // Handle press state on the label.
46
- let { pressProps: labelProps, isPressed: isLabelPressed } = (0, $a87f4c40785e693b$export$45712eceda6fad21)({
47
- onPressStart: onPressStart,
48
- onPressEnd: onPressEnd,
49
- onPressChange: onPressChange,
50
- onPressUp: onPressUp,
61
+ let [isLabelPressed, setLabelPressed] = (0, $2yVP5$useState)(false);
62
+ let { pressProps: labelProps } = (0, $a87f4c40785e693b$export$45712eceda6fad21)({
63
+ onPressStart (e) {
64
+ // Keyboard interactions are handled directly on the input.
65
+ if (e.pointerType === 'keyboard' || e.pointerType === 'virtual') {
66
+ e.continuePropagation();
67
+ return;
68
+ }
69
+ onPressStart === null || onPressStart === void 0 ? void 0 : onPressStart(e);
70
+ onPressChange === null || onPressChange === void 0 ? void 0 : onPressChange(true);
71
+ setLabelPressed(true);
72
+ },
73
+ onPressEnd (e) {
74
+ // Keyboard interactions are handled directly on the input.
75
+ if (e.pointerType === 'keyboard' || e.pointerType === 'virtual') {
76
+ e.continuePropagation();
77
+ return;
78
+ }
79
+ onPressEnd === null || onPressEnd === void 0 ? void 0 : onPressEnd(e);
80
+ onPressChange === null || onPressChange === void 0 ? void 0 : onPressChange(false);
81
+ setLabelPressed(false);
82
+ },
83
+ onPressUp (e) {
84
+ if (e.pointerType === 'keyboard' || e.pointerType === 'virtual') {
85
+ e.continuePropagation();
86
+ return;
87
+ }
88
+ onPressUp === null || onPressUp === void 0 ? void 0 : onPressUp(e);
89
+ },
51
90
  onClick: onClick,
52
91
  onPress (e) {
53
92
  var _ref_current;
93
+ if (e.pointerType === 'keyboard' || e.pointerType === 'virtual') {
94
+ e.continuePropagation();
95
+ return;
96
+ }
54
97
  onPress === null || onPress === void 0 ? void 0 : onPress(e);
55
98
  state.toggle();
56
99
  (_ref_current = ref.current) === null || _ref_current === void 0 ? void 0 : _ref_current.focus();
100
+ // @ts-expect-error
101
+ let { [(0, $2yVP5$privateValidationStateProp)]: groupValidationState } = props;
102
+ let { commitValidation: commitValidation } = groupValidationState ? groupValidationState : validationState;
103
+ commitValidation();
57
104
  },
58
105
  isDisabled: isDisabled || isReadOnly
59
106
  });
@@ -63,15 +110,26 @@ function $02953ddad5f95ac5$export$cbe85ee05b554577(props, state, ref) {
63
110
  labelable: true
64
111
  });
65
112
  (0, $5dfd40f1661a7fc3$export$5add1d006293d136)(ref, state.defaultSelected, state.setSelected);
113
+ // Copied from useField because we don't want the label behavior that provides.
114
+ let descriptionProps = (0, $901b0394915cd0c2$export$ed2feabec4a533f4)();
115
+ let errorMessageProps = (0, $901b0394915cd0c2$export$ed2feabec4a533f4)();
66
116
  return {
67
117
  labelProps: (0, $64c36edd757dfa16$export$9d1611c77c2fe928)(labelProps, {
68
118
  onClick: (e)=>e.preventDefault()
69
119
  }),
70
120
  inputProps: (0, $64c36edd757dfa16$export$9d1611c77c2fe928)(domProps, {
71
- 'aria-invalid': isInvalid || validationState === 'invalid' || undefined,
121
+ checked: state.isSelected,
122
+ 'aria-required': isRequired && validationBehavior === 'aria' || undefined,
123
+ required: isRequired && validationBehavior === 'native',
124
+ 'aria-invalid': isInvalid || props.validationState === 'invalid' || undefined,
72
125
  'aria-errormessage': props['aria-errormessage'],
73
126
  'aria-controls': props['aria-controls'],
74
127
  'aria-readonly': isReadOnly || undefined,
128
+ 'aria-describedby': [
129
+ descriptionProps.id,
130
+ errorMessageProps.id,
131
+ ariaDescribedby
132
+ ].filter(Boolean).join(' ') || undefined,
75
133
  onChange: onChange,
76
134
  disabled: isDisabled,
77
135
  ...value == null ? {} : {
@@ -82,11 +140,15 @@ function $02953ddad5f95ac5$export$cbe85ee05b554577(props, state, ref) {
82
140
  type: 'checkbox',
83
141
  ...interactions
84
142
  }),
143
+ descriptionProps: descriptionProps,
144
+ errorMessageProps: errorMessageProps,
85
145
  isSelected: state.isSelected,
86
146
  isPressed: isPressed || isLabelPressed,
87
147
  isDisabled: isDisabled,
88
148
  isReadOnly: isReadOnly,
89
- isInvalid: isInvalid || validationState === 'invalid'
149
+ isInvalid: isInvalid || props.validationState === 'invalid',
150
+ validationErrors: validationErrors,
151
+ validationDetails: validationDetails
90
152
  };
91
153
  }
92
154
 
@@ -1 +1 @@
1
- {"mappings":";;;;;;;AAAA;;;;;;;;;;CAUC;;;;;;AAuCM,SAAS,0CAAU,KAAsB,EAAE,KAAkB,EAAE,GAAuC;IAC3G,IAAI,cACF,aAAa,mBACb,aAAa,cACb,KAAK,QACL,IAAI,QACJ,IAAI,YACJ,QAAQ,EACR,cAAc,SAAS,EACvB,mBAAmB,cAAc,mBACjC,kBAAkB,oBAClB,SAAS,gBACT,YAAY,cACZ,UAAU,iBACV,aAAa,WACb,OAAO,aACP,SAAS,WACT,OAAO,EACR,GAAG;IAEJ,IAAI,WAAiD,CAAC;QACpD,iFAAiF;QACjF,wEAAwE;QACxE,EAAE,eAAe;QACjB,MAAM,WAAW,CAAC,CAAA,GAAA,yCAAa,EAAE,GAAG,OAAO;IAC7C;IAEA,IAAI,cAAc,YAAY;IAC9B,IAAI,eAAe,aAAa,QAAQ,kBAAkB;IAC1D,IAAI,CAAC,eAAe,CAAC,gBAAgB,QAAQ,GAAG,CAAC,QAAQ,KAAK,cAC5D,QAAQ,IAAI,CAAC;IAGf,uFAAuF;IACvF,IAAI,cAAC,UAAU,aAAE,SAAS,EAAC,GAAG,CAAA,GAAA,yCAAO,EAAE;sBACrC;oBACA;uBACA;iBACA;mBACA;iBACA;oBACA;IACF;IAEA,mCAAmC;IACnC,IAAI,EAAC,YAAY,UAAU,EAAE,WAAW,cAAc,EAAC,GAAG,CAAA,GAAA,yCAAO,EAAE;sBACjE;oBACA;uBACA;mBACA;iBACA;QACA,SAAQ,CAAC;gBAGP;YAFA,oBAAA,8BAAA,QAAU;YACV,MAAM,MAAM;aACZ,eAAA,IAAI,OAAO,cAAX,mCAAA,aAAa,KAAK;QACpB;QACA,YAAY,cAAc;IAC5B;IAEA,IAAI,kBAAC,cAAc,EAAC,GAAG,CAAA,GAAA,yCAAW,EAAE,OAAO;IAC3C,IAAI,eAAe,CAAA,GAAA,yCAAS,EAAE,YAAY;IAC1C,IAAI,WAAW,CAAA,GAAA,yCAAa,EAAE,OAAO;QAAC,WAAW;IAAI;IAErD,CAAA,GAAA,yCAAW,EAAE,KAAK,MAAM,eAAe,EAAE,MAAM,WAAW;IAE1D,OAAO;QACL,YAAY,CAAA,GAAA,yCAAS,EAAE,YAAY;YAAC,SAAS,CAAA,IAAK,EAAE,cAAc;QAAE;QACpE,YAAY,CAAA,GAAA,yCAAS,EAAE,UAAU;YAC/B,gBAAgB,aAAa,oBAAoB,aAAa;YAC9D,qBAAqB,KAAK,CAAC,oBAAoB;YAC/C,iBAAiB,KAAK,CAAC,gBAAgB;YACvC,iBAAiB,cAAc;sBAC/B;YACA,UAAU;YACV,GAAI,SAAS,OAAO,CAAC,IAAI;uBAAC;YAAK,CAAC;kBAChC;kBACA;YACA,MAAM;YACN,GAAG,YAAY;QACjB;QACA,YAAY,MAAM,UAAU;QAC5B,WAAW,aAAa;oBACxB;oBACA;QACA,WAAW,aAAa,oBAAoB;IAC9C;AACF","sources":["packages/react-aria/src/toggle/useToggle.ts"],"sourcesContent":["/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaLabelingProps, AriaValidationProps, FocusableDOMProps, InputDOMProps, PressEvents, RefObject} from '@react-types/shared';\nimport {ChangeEventHandler, InputHTMLAttributes, LabelHTMLAttributes} from 'react';\nimport {filterDOMProps} from '../utils/filterDOMProps';\nimport {getEventTarget} from '../utils/shadowdom/DOMFunctions';\nimport {mergeProps} from '../utils/mergeProps';\nimport {ToggleProps, ToggleState} from 'react-stately/useToggleState';\nimport {useFocusable} from '../interactions/useFocusable';\nimport {useFormReset} from '../utils/useFormReset';\nimport {usePress} from '../interactions/usePress';\n\nexport interface AriaToggleProps extends ToggleProps, FocusableDOMProps, AriaLabelingProps, AriaValidationProps, InputDOMProps, PressEvents {\n /**\n * Identifies the element (or elements) whose contents or presence are controlled by the current element.\n */\n 'aria-controls'?: string\n}\n\nexport interface ToggleAria {\n /** Props to be spread on the label element. */\n labelProps: LabelHTMLAttributes<HTMLLabelElement>,\n /** Props to be spread on the input element. */\n inputProps: InputHTMLAttributes<HTMLInputElement>,\n /** Whether the toggle is selected. */\n isSelected: boolean,\n /** Whether the toggle is in a pressed state. */\n isPressed: boolean,\n /** Whether the toggle is disabled. */\n isDisabled: boolean,\n /** Whether the toggle is read only. */\n isReadOnly: boolean,\n /** Whether the toggle is invalid. */\n isInvalid: boolean\n}\n\n/**\n * Handles interactions for toggle elements, e.g. Checkboxes and Switches.\n */\nexport function useToggle(props: AriaToggleProps, state: ToggleState, ref: RefObject<HTMLInputElement | null>): ToggleAria {\n let {\n isDisabled = false,\n isReadOnly = false,\n value,\n name,\n form,\n children,\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledby,\n validationState = 'valid',\n isInvalid,\n onPressStart,\n onPressEnd,\n onPressChange,\n onPress,\n onPressUp,\n onClick\n } = props;\n\n let onChange: ChangeEventHandler<HTMLInputElement> = (e) => {\n // since we spread props on label, onChange will end up there as well as in here.\n // so we have to stop propagation at the lowest level that we care about\n e.stopPropagation();\n state.setSelected(getEventTarget(e).checked);\n };\n\n let hasChildren = children != null;\n let hasAriaLabel = ariaLabel != null || ariaLabelledby != null;\n if (!hasChildren && !hasAriaLabel && process.env.NODE_ENV !== 'production') {\n console.warn('If you do not provide children, you must specify an aria-label for accessibility');\n }\n\n // Handle press state for keyboard interactions and cases where labelProps is not used.\n let {pressProps, isPressed} = usePress({\n onPressStart,\n onPressEnd,\n onPressChange,\n onPress,\n onPressUp,\n onClick,\n isDisabled\n });\n\n // Handle press state on the label.\n let {pressProps: labelProps, isPressed: isLabelPressed} = usePress({\n onPressStart,\n onPressEnd,\n onPressChange,\n onPressUp,\n onClick,\n onPress(e) {\n onPress?.(e);\n state.toggle();\n ref.current?.focus();\n },\n isDisabled: isDisabled || isReadOnly\n });\n\n let {focusableProps} = useFocusable(props, ref);\n let interactions = mergeProps(pressProps, focusableProps);\n let domProps = filterDOMProps(props, {labelable: true});\n\n useFormReset(ref, state.defaultSelected, state.setSelected);\n\n return {\n labelProps: mergeProps(labelProps, {onClick: e => e.preventDefault()}),\n inputProps: mergeProps(domProps, {\n 'aria-invalid': isInvalid || validationState === 'invalid' || undefined,\n 'aria-errormessage': props['aria-errormessage'],\n 'aria-controls': props['aria-controls'],\n 'aria-readonly': isReadOnly || undefined,\n onChange,\n disabled: isDisabled,\n ...(value == null ? {} : {value}),\n name,\n form,\n type: 'checkbox',\n ...interactions\n }),\n isSelected: state.isSelected,\n isPressed: isPressed || isLabelPressed,\n isDisabled,\n isReadOnly,\n isInvalid: isInvalid || validationState === 'invalid'\n };\n}\n"],"names":[],"version":3,"file":"useToggle.js.map"}
1
+ {"mappings":";;;;;;;;;;;AAAA;;;;;;;;;;CAUC;;;;;;;;;;AAkEM,SAAS,0CACd,KAAsB,EACtB,KAAkB,EAClB,GAAuC;IAEvC,IAAI,cACF,aAAa,mBACb,aAAa,cACb,KAAK,QACL,IAAI,QACJ,IAAI,YACJ,QAAQ,cACR,UAAU,sBACV,qBAAqB,QACrB,cAAc,SAAS,EACvB,mBAAmB,cAAc,EACjC,oBAAoB,eAAe,gBACnC,YAAY,cACZ,UAAU,iBACV,aAAa,WACb,OAAO,aACP,SAAS,WACT,OAAO,EACR,GAAG;IAEJ,+FAA+F;IAC/F,IAAI,kBAAkB,CAAA,GAAA,6BAAqB,EAAE;QAAC,GAAG,KAAK;QAAE,OAAO,MAAM,UAAU;IAAA;IAC/E,IAAI,aAAC,SAAS,oBAAE,gBAAgB,qBAAE,iBAAiB,EAAC,GAAG,gBAAgB,iBAAiB;IAExF,CAAA,GAAA,yCAAgB,EAAE,OAAO,iBAAiB;IAE1C,IAAI,WAAiD,CAAA;QACnD,iFAAiF;QACjF,wEAAwE;QACxE,EAAE,eAAe;QACjB,MAAM,WAAW,CAAC,CAAA,GAAA,yCAAa,EAAE,GAAG,OAAO;IAC7C;IAEA,IAAI,cAAc,YAAY;IAC9B,IAAI,eAAe,aAAa,QAAQ,kBAAkB;IAC1D,IAAI,CAAC,eAAe,CAAC,gBAAgB,QAAQ,GAAG,CAAC,QAAQ,KAAK,cAC5D,QAAQ,IAAI,CACV;IAIJ,uFAAuF;IACvF,IAAI,cAAC,UAAU,aAAE,SAAS,EAAC,GAAG,CAAA,GAAA,yCAAO,EAAE;sBACrC;oBACA;uBACA;iBACA;mBACA;iBACA;oBACA;IACF;IAEA,mCAAmC;IACnC,IAAI,CAAC,gBAAgB,gBAAgB,GAAG,CAAA,GAAA,eAAO,EAAE;IACjD,IAAI,EAAC,YAAY,UAAU,EAAC,GAAG,CAAA,GAAA,yCAAO,EAAE;QACtC,cAAa,CAAC;YACZ,2DAA2D;YAC3D,IAAI,EAAE,WAAW,KAAK,cAAc,EAAE,WAAW,KAAK,WAAW;gBAC/D,EAAE,mBAAmB;gBACrB;YACF;YAEA,yBAAA,mCAAA,aAAe;YACf,0BAAA,oCAAA,cAAgB;YAChB,gBAAgB;QAClB;QACA,YAAW,CAAC;YACV,2DAA2D;YAC3D,IAAI,EAAE,WAAW,KAAK,cAAc,EAAE,WAAW,KAAK,WAAW;gBAC/D,EAAE,mBAAmB;gBACrB;YACF;YAEA,uBAAA,iCAAA,WAAa;YACb,0BAAA,oCAAA,cAAgB;YAChB,gBAAgB;QAClB;QACA,WAAU,CAAC;YACT,IAAI,EAAE,WAAW,KAAK,cAAc,EAAE,WAAW,KAAK,WAAW;gBAC/D,EAAE,mBAAmB;gBACrB;YACF;YAEA,sBAAA,gCAAA,UAAY;QACd;iBACA;QACA,SAAQ,CAAC;gBAQP;YAPA,IAAI,EAAE,WAAW,KAAK,cAAc,EAAE,WAAW,KAAK,WAAW;gBAC/D,EAAE,mBAAmB;gBACrB;YACF;YAEA,oBAAA,8BAAA,QAAU;YACV,MAAM,MAAM;aACZ,eAAA,IAAI,OAAO,cAAX,mCAAA,aAAa,KAAK;YAElB,mBAAmB;YACnB,IAAI,EAAC,CAAC,CAAA,GAAA,iCAAyB,EAAE,EAAE,oBAAoB,EAAC,GAAG;YAE3D,IAAI,oBAAC,gBAAgB,EAAC,GAAG,uBAAuB,uBAAuB;YAEvE;QACF;QACA,YAAY,cAAc;IAC5B;IAEA,IAAI,kBAAC,cAAc,EAAC,GAAG,CAAA,GAAA,yCAAW,EAAE,OAAO;IAC3C,IAAI,eAAe,CAAA,GAAA,yCAAS,EAAE,YAAY;IAC1C,IAAI,WAAW,CAAA,GAAA,yCAAa,EAAE,OAAO;QAAC,WAAW;IAAI;IAErD,CAAA,GAAA,yCAAW,EAAE,KAAK,MAAM,eAAe,EAAE,MAAM,WAAW;IAE1D,+EAA+E;IAC/E,IAAI,mBAAmB,CAAA,GAAA,yCAAS;IAChC,IAAI,oBAAoB,CAAA,GAAA,yCAAS;IAEjC,OAAO;QACL,YAAY,CAAA,GAAA,yCAAS,EAAE,YAAY;YAAC,SAAS,CAAA,IAAK,EAAE,cAAc;QAAE;QACpE,YAAY,CAAA,GAAA,yCAAS,EAAE,UAAU;YAC/B,SAAS,MAAM,UAAU;YACzB,iBAAiB,AAAC,cAAc,uBAAuB,UAAW;YAClE,UAAU,cAAc,uBAAuB;YAC/C,gBAAgB,aAAa,MAAM,eAAe,KAAK,aAAa;YACpE,qBAAqB,KAAK,CAAC,oBAAoB;YAC/C,iBAAiB,KAAK,CAAC,gBAAgB;YACvC,iBAAiB,cAAc;YAC/B,oBACE;gBAAC,iBAAiB,EAAE;gBAAE,kBAAkB,EAAE;gBAAE;aAAgB,CAAC,MAAM,CAAC,SAAS,IAAI,CAAC,QAClF;sBACF;YACA,UAAU;YACV,GAAI,SAAS,OAAO,CAAC,IAAI;uBAAC;YAAK,CAAC;kBAChC;kBACA;YACA,MAAM;YACN,GAAG,YAAY;QACjB;0BACA;2BACA;QACA,YAAY,MAAM,UAAU;QAC5B,WAAW,aAAa;oBACxB;oBACA;QACA,WAAW,aAAa,MAAM,eAAe,KAAK;0BAClD;2BACA;IACF;AACF","sources":["packages/react-aria/src/toggle/useToggle.ts"],"sourcesContent":["/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {\n AriaLabelingProps,\n AriaValidationProps,\n DOMAttributesWithRef,\n FocusableDOMProps,\n InputDOMProps,\n PressEvents,\n RefObject,\n ValidationResult\n} from '@react-types/shared';\nimport {ChangeEventHandler, InputHTMLAttributes, LabelHTMLAttributes, useState} from 'react';\nimport {filterDOMProps} from '../utils/filterDOMProps';\nimport {getEventTarget} from '../utils/shadowdom/DOMFunctions';\nimport {mergeProps} from '../utils/mergeProps';\nimport {\n privateValidationStateProp,\n useFormValidationState\n} from 'react-stately/private/form/useFormValidationState';\nimport {ToggleProps, ToggleState} from 'react-stately/useToggleState';\nimport {useFocusable} from '../interactions/useFocusable';\nimport {useFormReset} from '../utils/useFormReset';\nimport {useFormValidation} from '../form/useFormValidation';\nimport {usePress} from '../interactions/usePress';\nimport {useSlotId2} from '../utils/useSlot';\n\nexport interface AriaToggleProps\n extends\n ToggleProps,\n FocusableDOMProps,\n AriaLabelingProps,\n AriaValidationProps,\n InputDOMProps,\n PressEvents {\n /**\n * Identifies the element (or elements) whose contents or presence are controlled by the current\n * element.\n */\n 'aria-controls'?: string;\n}\n\nexport interface ToggleAria extends ValidationResult {\n /** Props to be spread on the label element. */\n labelProps: LabelHTMLAttributes<HTMLLabelElement>;\n /** Props to be spread on the input element. */\n inputProps: InputHTMLAttributes<HTMLInputElement>;\n /** Props for the checkbox description element, if any. */\n descriptionProps: DOMAttributesWithRef<HTMLElement>;\n /** Props for the checkbox error message element, if any. */\n errorMessageProps: DOMAttributesWithRef<HTMLElement>;\n /** Whether the toggle is selected. */\n isSelected: boolean;\n /** Whether the toggle is in a pressed state. */\n isPressed: boolean;\n /** Whether the toggle is disabled. */\n isDisabled: boolean;\n /** Whether the toggle is read only. */\n isReadOnly: boolean;\n /** Whether the toggle is invalid. */\n isInvalid: boolean;\n}\n\n/**\n * Handles interactions for toggle elements, e.g. Checkboxes and Switches.\n */\nexport function useToggle(\n props: AriaToggleProps,\n state: ToggleState,\n ref: RefObject<HTMLInputElement | null>\n): ToggleAria {\n let {\n isDisabled = false,\n isReadOnly = false,\n value,\n name,\n form,\n children,\n isRequired,\n validationBehavior = 'aria',\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledby,\n 'aria-describedby': ariaDescribedby,\n onPressStart,\n onPressEnd,\n onPressChange,\n onPress,\n onPressUp,\n onClick\n } = props;\n\n // Create validation state here because it doesn't make sense to add to general useToggleState.\n let validationState = useFormValidationState({...props, value: state.isSelected});\n let {isInvalid, validationErrors, validationDetails} = validationState.displayValidation;\n\n useFormValidation(props, validationState, ref);\n\n let onChange: ChangeEventHandler<HTMLInputElement> = e => {\n // since we spread props on label, onChange will end up there as well as in here.\n // so we have to stop propagation at the lowest level that we care about\n e.stopPropagation();\n state.setSelected(getEventTarget(e).checked);\n };\n\n let hasChildren = children != null;\n let hasAriaLabel = ariaLabel != null || ariaLabelledby != null;\n if (!hasChildren && !hasAriaLabel && process.env.NODE_ENV !== 'production') {\n console.warn(\n 'If you do not provide children, you must specify an aria-label for accessibility'\n );\n }\n\n // Handle press state for keyboard interactions and cases where labelProps is not used.\n let {pressProps, isPressed} = usePress({\n onPressStart,\n onPressEnd,\n onPressChange,\n onPress,\n onPressUp,\n onClick,\n isDisabled\n });\n\n // Handle press state on the label.\n let [isLabelPressed, setLabelPressed] = useState(false);\n let {pressProps: labelProps} = usePress({\n onPressStart(e) {\n // Keyboard interactions are handled directly on the input.\n if (e.pointerType === 'keyboard' || e.pointerType === 'virtual') {\n e.continuePropagation();\n return;\n }\n\n onPressStart?.(e);\n onPressChange?.(true);\n setLabelPressed(true);\n },\n onPressEnd(e) {\n // Keyboard interactions are handled directly on the input.\n if (e.pointerType === 'keyboard' || e.pointerType === 'virtual') {\n e.continuePropagation();\n return;\n }\n\n onPressEnd?.(e);\n onPressChange?.(false);\n setLabelPressed(false);\n },\n onPressUp(e) {\n if (e.pointerType === 'keyboard' || e.pointerType === 'virtual') {\n e.continuePropagation();\n return;\n }\n\n onPressUp?.(e);\n },\n onClick,\n onPress(e) {\n if (e.pointerType === 'keyboard' || e.pointerType === 'virtual') {\n e.continuePropagation();\n return;\n }\n\n onPress?.(e);\n state.toggle();\n ref.current?.focus();\n\n // @ts-expect-error\n let {[privateValidationStateProp]: groupValidationState} = props;\n\n let {commitValidation} = groupValidationState ? groupValidationState : validationState;\n\n commitValidation();\n },\n isDisabled: isDisabled || isReadOnly\n });\n\n let {focusableProps} = useFocusable(props, ref);\n let interactions = mergeProps(pressProps, focusableProps);\n let domProps = filterDOMProps(props, {labelable: true});\n\n useFormReset(ref, state.defaultSelected, state.setSelected);\n\n // Copied from useField because we don't want the label behavior that provides.\n let descriptionProps = useSlotId2();\n let errorMessageProps = useSlotId2();\n\n return {\n labelProps: mergeProps(labelProps, {onClick: e => e.preventDefault()}),\n inputProps: mergeProps(domProps, {\n checked: state.isSelected,\n 'aria-required': (isRequired && validationBehavior === 'aria') || undefined,\n required: isRequired && validationBehavior === 'native',\n 'aria-invalid': isInvalid || props.validationState === 'invalid' || undefined,\n 'aria-errormessage': props['aria-errormessage'],\n 'aria-controls': props['aria-controls'],\n 'aria-readonly': isReadOnly || undefined,\n 'aria-describedby':\n [descriptionProps.id, errorMessageProps.id, ariaDescribedby].filter(Boolean).join(' ') ||\n undefined,\n onChange,\n disabled: isDisabled,\n ...(value == null ? {} : {value}),\n name,\n form,\n type: 'checkbox',\n ...interactions\n }),\n descriptionProps,\n errorMessageProps,\n isSelected: state.isSelected,\n isPressed: isPressed || isLabelPressed,\n isDisabled,\n isReadOnly,\n isInvalid: isInvalid || props.validationState === 'invalid',\n validationErrors,\n validationDetails\n };\n}\n"],"names":[],"version":3,"file":"useToggle.js.map"}
@@ -3,7 +3,11 @@ import {getEventTarget as $23f2114a1b82827e$export$e58f029f0fbfdb29} from "../ut
3
3
  import {mergeProps as $bbaa08b3cd72f041$export$9d1611c77c2fe928} from "../utils/mergeProps.mjs";
4
4
  import {useFocusable as $d1116acdf220c2da$export$4c014de7c8940b4c} from "../interactions/useFocusable.mjs";
5
5
  import {useFormReset as $3274bf1495747a7b$export$5add1d006293d136} from "../utils/useFormReset.mjs";
6
+ import {useFormValidation as $860f7da480e22816$export$b8473d3665f3a75a} from "../form/useFormValidation.mjs";
6
7
  import {usePress as $d27d541f9569d26d$export$45712eceda6fad21} from "../interactions/usePress.mjs";
8
+ import {useSlotId2 as $4c14b02d5228be26$export$ed2feabec4a533f4} from "../utils/useSlot.mjs";
9
+ import {useState as $jQnU8$useState} from "react";
10
+ import {useFormValidationState as $jQnU8$useFormValidationState, privateValidationStateProp as $jQnU8$privateValidationStateProp} from "react-stately/private/form/useFormValidationState";
7
11
 
8
12
  /*
9
13
  * Copyright 2020 Adobe. All rights reserved.
@@ -21,8 +25,19 @@ import {usePress as $d27d541f9569d26d$export$45712eceda6fad21} from "../interact
21
25
 
22
26
 
23
27
 
28
+
29
+
30
+
31
+
24
32
  function $876b6f32ca5a04c3$export$cbe85ee05b554577(props, state, ref) {
25
- let { isDisabled: isDisabled = false, isReadOnly: isReadOnly = false, value: value, name: name, form: form, children: children, 'aria-label': ariaLabel, 'aria-labelledby': ariaLabelledby, validationState: validationState = 'valid', isInvalid: isInvalid, onPressStart: onPressStart, onPressEnd: onPressEnd, onPressChange: onPressChange, onPress: onPress, onPressUp: onPressUp, onClick: onClick } = props;
33
+ let { isDisabled: isDisabled = false, isReadOnly: isReadOnly = false, value: value, name: name, form: form, children: children, isRequired: isRequired, validationBehavior: validationBehavior = 'aria', 'aria-label': ariaLabel, 'aria-labelledby': ariaLabelledby, 'aria-describedby': ariaDescribedby, onPressStart: onPressStart, onPressEnd: onPressEnd, onPressChange: onPressChange, onPress: onPress, onPressUp: onPressUp, onClick: onClick } = props;
34
+ // Create validation state here because it doesn't make sense to add to general useToggleState.
35
+ let validationState = (0, $jQnU8$useFormValidationState)({
36
+ ...props,
37
+ value: state.isSelected
38
+ });
39
+ let { isInvalid: isInvalid, validationErrors: validationErrors, validationDetails: validationDetails } = validationState.displayValidation;
40
+ (0, $860f7da480e22816$export$b8473d3665f3a75a)(props, validationState, ref);
26
41
  let onChange = (e)=>{
27
42
  // since we spread props on label, onChange will end up there as well as in here.
28
43
  // so we have to stop propagation at the lowest level that we care about
@@ -43,16 +58,48 @@ function $876b6f32ca5a04c3$export$cbe85ee05b554577(props, state, ref) {
43
58
  isDisabled: isDisabled
44
59
  });
45
60
  // Handle press state on the label.
46
- let { pressProps: labelProps, isPressed: isLabelPressed } = (0, $d27d541f9569d26d$export$45712eceda6fad21)({
47
- onPressStart: onPressStart,
48
- onPressEnd: onPressEnd,
49
- onPressChange: onPressChange,
50
- onPressUp: onPressUp,
61
+ let [isLabelPressed, setLabelPressed] = (0, $jQnU8$useState)(false);
62
+ let { pressProps: labelProps } = (0, $d27d541f9569d26d$export$45712eceda6fad21)({
63
+ onPressStart (e) {
64
+ // Keyboard interactions are handled directly on the input.
65
+ if (e.pointerType === 'keyboard' || e.pointerType === 'virtual') {
66
+ e.continuePropagation();
67
+ return;
68
+ }
69
+ onPressStart?.(e);
70
+ onPressChange?.(true);
71
+ setLabelPressed(true);
72
+ },
73
+ onPressEnd (e) {
74
+ // Keyboard interactions are handled directly on the input.
75
+ if (e.pointerType === 'keyboard' || e.pointerType === 'virtual') {
76
+ e.continuePropagation();
77
+ return;
78
+ }
79
+ onPressEnd?.(e);
80
+ onPressChange?.(false);
81
+ setLabelPressed(false);
82
+ },
83
+ onPressUp (e) {
84
+ if (e.pointerType === 'keyboard' || e.pointerType === 'virtual') {
85
+ e.continuePropagation();
86
+ return;
87
+ }
88
+ onPressUp?.(e);
89
+ },
51
90
  onClick: onClick,
52
91
  onPress (e) {
92
+ if (e.pointerType === 'keyboard' || e.pointerType === 'virtual') {
93
+ e.continuePropagation();
94
+ return;
95
+ }
53
96
  onPress?.(e);
54
97
  state.toggle();
55
98
  ref.current?.focus();
99
+ // @ts-expect-error
100
+ let { [(0, $jQnU8$privateValidationStateProp)]: groupValidationState } = props;
101
+ let { commitValidation: commitValidation } = groupValidationState ? groupValidationState : validationState;
102
+ commitValidation();
56
103
  },
57
104
  isDisabled: isDisabled || isReadOnly
58
105
  });
@@ -62,15 +109,26 @@ function $876b6f32ca5a04c3$export$cbe85ee05b554577(props, state, ref) {
62
109
  labelable: true
63
110
  });
64
111
  (0, $3274bf1495747a7b$export$5add1d006293d136)(ref, state.defaultSelected, state.setSelected);
112
+ // Copied from useField because we don't want the label behavior that provides.
113
+ let descriptionProps = (0, $4c14b02d5228be26$export$ed2feabec4a533f4)();
114
+ let errorMessageProps = (0, $4c14b02d5228be26$export$ed2feabec4a533f4)();
65
115
  return {
66
116
  labelProps: (0, $bbaa08b3cd72f041$export$9d1611c77c2fe928)(labelProps, {
67
117
  onClick: (e)=>e.preventDefault()
68
118
  }),
69
119
  inputProps: (0, $bbaa08b3cd72f041$export$9d1611c77c2fe928)(domProps, {
70
- 'aria-invalid': isInvalid || validationState === 'invalid' || undefined,
120
+ checked: state.isSelected,
121
+ 'aria-required': isRequired && validationBehavior === 'aria' || undefined,
122
+ required: isRequired && validationBehavior === 'native',
123
+ 'aria-invalid': isInvalid || props.validationState === 'invalid' || undefined,
71
124
  'aria-errormessage': props['aria-errormessage'],
72
125
  'aria-controls': props['aria-controls'],
73
126
  'aria-readonly': isReadOnly || undefined,
127
+ 'aria-describedby': [
128
+ descriptionProps.id,
129
+ errorMessageProps.id,
130
+ ariaDescribedby
131
+ ].filter(Boolean).join(' ') || undefined,
74
132
  onChange: onChange,
75
133
  disabled: isDisabled,
76
134
  ...value == null ? {} : {
@@ -81,11 +139,15 @@ function $876b6f32ca5a04c3$export$cbe85ee05b554577(props, state, ref) {
81
139
  type: 'checkbox',
82
140
  ...interactions
83
141
  }),
142
+ descriptionProps: descriptionProps,
143
+ errorMessageProps: errorMessageProps,
84
144
  isSelected: state.isSelected,
85
145
  isPressed: isPressed || isLabelPressed,
86
146
  isDisabled: isDisabled,
87
147
  isReadOnly: isReadOnly,
88
- isInvalid: isInvalid || validationState === 'invalid'
148
+ isInvalid: isInvalid || props.validationState === 'invalid',
149
+ validationErrors: validationErrors,
150
+ validationDetails: validationDetails
89
151
  };
90
152
  }
91
153
 
@@ -1 +1 @@
1
- {"mappings":";;;;;;;AAAA;;;;;;;;;;CAUC;;;;;;AAuCM,SAAS,0CAAU,KAAsB,EAAE,KAAkB,EAAE,GAAuC;IAC3G,IAAI,cACF,aAAa,mBACb,aAAa,cACb,KAAK,QACL,IAAI,QACJ,IAAI,YACJ,QAAQ,EACR,cAAc,SAAS,EACvB,mBAAmB,cAAc,mBACjC,kBAAkB,oBAClB,SAAS,gBACT,YAAY,cACZ,UAAU,iBACV,aAAa,WACb,OAAO,aACP,SAAS,WACT,OAAO,EACR,GAAG;IAEJ,IAAI,WAAiD,CAAC;QACpD,iFAAiF;QACjF,wEAAwE;QACxE,EAAE,eAAe;QACjB,MAAM,WAAW,CAAC,CAAA,GAAA,yCAAa,EAAE,GAAG,OAAO;IAC7C;IAEA,IAAI,cAAc,YAAY;IAC9B,IAAI,eAAe,aAAa,QAAQ,kBAAkB;IAC1D,IAAI,CAAC,eAAe,CAAC,gBAAgB,QAAQ,GAAG,CAAC,QAAQ,KAAK,cAC5D,QAAQ,IAAI,CAAC;IAGf,uFAAuF;IACvF,IAAI,cAAC,UAAU,aAAE,SAAS,EAAC,GAAG,CAAA,GAAA,yCAAO,EAAE;sBACrC;oBACA;uBACA;iBACA;mBACA;iBACA;oBACA;IACF;IAEA,mCAAmC;IACnC,IAAI,EAAC,YAAY,UAAU,EAAE,WAAW,cAAc,EAAC,GAAG,CAAA,GAAA,yCAAO,EAAE;sBACjE;oBACA;uBACA;mBACA;iBACA;QACA,SAAQ,CAAC;YACP,UAAU;YACV,MAAM,MAAM;YACZ,IAAI,OAAO,EAAE;QACf;QACA,YAAY,cAAc;IAC5B;IAEA,IAAI,kBAAC,cAAc,EAAC,GAAG,CAAA,GAAA,yCAAW,EAAE,OAAO;IAC3C,IAAI,eAAe,CAAA,GAAA,yCAAS,EAAE,YAAY;IAC1C,IAAI,WAAW,CAAA,GAAA,yCAAa,EAAE,OAAO;QAAC,WAAW;IAAI;IAErD,CAAA,GAAA,yCAAW,EAAE,KAAK,MAAM,eAAe,EAAE,MAAM,WAAW;IAE1D,OAAO;QACL,YAAY,CAAA,GAAA,yCAAS,EAAE,YAAY;YAAC,SAAS,CAAA,IAAK,EAAE,cAAc;QAAE;QACpE,YAAY,CAAA,GAAA,yCAAS,EAAE,UAAU;YAC/B,gBAAgB,aAAa,oBAAoB,aAAa;YAC9D,qBAAqB,KAAK,CAAC,oBAAoB;YAC/C,iBAAiB,KAAK,CAAC,gBAAgB;YACvC,iBAAiB,cAAc;sBAC/B;YACA,UAAU;YACV,GAAI,SAAS,OAAO,CAAC,IAAI;uBAAC;YAAK,CAAC;kBAChC;kBACA;YACA,MAAM;YACN,GAAG,YAAY;QACjB;QACA,YAAY,MAAM,UAAU;QAC5B,WAAW,aAAa;oBACxB;oBACA;QACA,WAAW,aAAa,oBAAoB;IAC9C;AACF","sources":["packages/react-aria/src/toggle/useToggle.ts"],"sourcesContent":["/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaLabelingProps, AriaValidationProps, FocusableDOMProps, InputDOMProps, PressEvents, RefObject} from '@react-types/shared';\nimport {ChangeEventHandler, InputHTMLAttributes, LabelHTMLAttributes} from 'react';\nimport {filterDOMProps} from '../utils/filterDOMProps';\nimport {getEventTarget} from '../utils/shadowdom/DOMFunctions';\nimport {mergeProps} from '../utils/mergeProps';\nimport {ToggleProps, ToggleState} from 'react-stately/useToggleState';\nimport {useFocusable} from '../interactions/useFocusable';\nimport {useFormReset} from '../utils/useFormReset';\nimport {usePress} from '../interactions/usePress';\n\nexport interface AriaToggleProps extends ToggleProps, FocusableDOMProps, AriaLabelingProps, AriaValidationProps, InputDOMProps, PressEvents {\n /**\n * Identifies the element (or elements) whose contents or presence are controlled by the current element.\n */\n 'aria-controls'?: string\n}\n\nexport interface ToggleAria {\n /** Props to be spread on the label element. */\n labelProps: LabelHTMLAttributes<HTMLLabelElement>,\n /** Props to be spread on the input element. */\n inputProps: InputHTMLAttributes<HTMLInputElement>,\n /** Whether the toggle is selected. */\n isSelected: boolean,\n /** Whether the toggle is in a pressed state. */\n isPressed: boolean,\n /** Whether the toggle is disabled. */\n isDisabled: boolean,\n /** Whether the toggle is read only. */\n isReadOnly: boolean,\n /** Whether the toggle is invalid. */\n isInvalid: boolean\n}\n\n/**\n * Handles interactions for toggle elements, e.g. Checkboxes and Switches.\n */\nexport function useToggle(props: AriaToggleProps, state: ToggleState, ref: RefObject<HTMLInputElement | null>): ToggleAria {\n let {\n isDisabled = false,\n isReadOnly = false,\n value,\n name,\n form,\n children,\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledby,\n validationState = 'valid',\n isInvalid,\n onPressStart,\n onPressEnd,\n onPressChange,\n onPress,\n onPressUp,\n onClick\n } = props;\n\n let onChange: ChangeEventHandler<HTMLInputElement> = (e) => {\n // since we spread props on label, onChange will end up there as well as in here.\n // so we have to stop propagation at the lowest level that we care about\n e.stopPropagation();\n state.setSelected(getEventTarget(e).checked);\n };\n\n let hasChildren = children != null;\n let hasAriaLabel = ariaLabel != null || ariaLabelledby != null;\n if (!hasChildren && !hasAriaLabel && process.env.NODE_ENV !== 'production') {\n console.warn('If you do not provide children, you must specify an aria-label for accessibility');\n }\n\n // Handle press state for keyboard interactions and cases where labelProps is not used.\n let {pressProps, isPressed} = usePress({\n onPressStart,\n onPressEnd,\n onPressChange,\n onPress,\n onPressUp,\n onClick,\n isDisabled\n });\n\n // Handle press state on the label.\n let {pressProps: labelProps, isPressed: isLabelPressed} = usePress({\n onPressStart,\n onPressEnd,\n onPressChange,\n onPressUp,\n onClick,\n onPress(e) {\n onPress?.(e);\n state.toggle();\n ref.current?.focus();\n },\n isDisabled: isDisabled || isReadOnly\n });\n\n let {focusableProps} = useFocusable(props, ref);\n let interactions = mergeProps(pressProps, focusableProps);\n let domProps = filterDOMProps(props, {labelable: true});\n\n useFormReset(ref, state.defaultSelected, state.setSelected);\n\n return {\n labelProps: mergeProps(labelProps, {onClick: e => e.preventDefault()}),\n inputProps: mergeProps(domProps, {\n 'aria-invalid': isInvalid || validationState === 'invalid' || undefined,\n 'aria-errormessage': props['aria-errormessage'],\n 'aria-controls': props['aria-controls'],\n 'aria-readonly': isReadOnly || undefined,\n onChange,\n disabled: isDisabled,\n ...(value == null ? {} : {value}),\n name,\n form,\n type: 'checkbox',\n ...interactions\n }),\n isSelected: state.isSelected,\n isPressed: isPressed || isLabelPressed,\n isDisabled,\n isReadOnly,\n isInvalid: isInvalid || validationState === 'invalid'\n };\n}\n"],"names":[],"version":3,"file":"useToggle.mjs.map"}
1
+ {"mappings":";;;;;;;;;;;AAAA;;;;;;;;;;CAUC;;;;;;;;;;AAkEM,SAAS,0CACd,KAAsB,EACtB,KAAkB,EAClB,GAAuC;IAEvC,IAAI,cACF,aAAa,mBACb,aAAa,cACb,KAAK,QACL,IAAI,QACJ,IAAI,YACJ,QAAQ,cACR,UAAU,sBACV,qBAAqB,QACrB,cAAc,SAAS,EACvB,mBAAmB,cAAc,EACjC,oBAAoB,eAAe,gBACnC,YAAY,cACZ,UAAU,iBACV,aAAa,WACb,OAAO,aACP,SAAS,WACT,OAAO,EACR,GAAG;IAEJ,+FAA+F;IAC/F,IAAI,kBAAkB,CAAA,GAAA,6BAAqB,EAAE;QAAC,GAAG,KAAK;QAAE,OAAO,MAAM,UAAU;IAAA;IAC/E,IAAI,aAAC,SAAS,oBAAE,gBAAgB,qBAAE,iBAAiB,EAAC,GAAG,gBAAgB,iBAAiB;IAExF,CAAA,GAAA,yCAAgB,EAAE,OAAO,iBAAiB;IAE1C,IAAI,WAAiD,CAAA;QACnD,iFAAiF;QACjF,wEAAwE;QACxE,EAAE,eAAe;QACjB,MAAM,WAAW,CAAC,CAAA,GAAA,yCAAa,EAAE,GAAG,OAAO;IAC7C;IAEA,IAAI,cAAc,YAAY;IAC9B,IAAI,eAAe,aAAa,QAAQ,kBAAkB;IAC1D,IAAI,CAAC,eAAe,CAAC,gBAAgB,QAAQ,GAAG,CAAC,QAAQ,KAAK,cAC5D,QAAQ,IAAI,CACV;IAIJ,uFAAuF;IACvF,IAAI,cAAC,UAAU,aAAE,SAAS,EAAC,GAAG,CAAA,GAAA,yCAAO,EAAE;sBACrC;oBACA;uBACA;iBACA;mBACA;iBACA;oBACA;IACF;IAEA,mCAAmC;IACnC,IAAI,CAAC,gBAAgB,gBAAgB,GAAG,CAAA,GAAA,eAAO,EAAE;IACjD,IAAI,EAAC,YAAY,UAAU,EAAC,GAAG,CAAA,GAAA,yCAAO,EAAE;QACtC,cAAa,CAAC;YACZ,2DAA2D;YAC3D,IAAI,EAAE,WAAW,KAAK,cAAc,EAAE,WAAW,KAAK,WAAW;gBAC/D,EAAE,mBAAmB;gBACrB;YACF;YAEA,eAAe;YACf,gBAAgB;YAChB,gBAAgB;QAClB;QACA,YAAW,CAAC;YACV,2DAA2D;YAC3D,IAAI,EAAE,WAAW,KAAK,cAAc,EAAE,WAAW,KAAK,WAAW;gBAC/D,EAAE,mBAAmB;gBACrB;YACF;YAEA,aAAa;YACb,gBAAgB;YAChB,gBAAgB;QAClB;QACA,WAAU,CAAC;YACT,IAAI,EAAE,WAAW,KAAK,cAAc,EAAE,WAAW,KAAK,WAAW;gBAC/D,EAAE,mBAAmB;gBACrB;YACF;YAEA,YAAY;QACd;iBACA;QACA,SAAQ,CAAC;YACP,IAAI,EAAE,WAAW,KAAK,cAAc,EAAE,WAAW,KAAK,WAAW;gBAC/D,EAAE,mBAAmB;gBACrB;YACF;YAEA,UAAU;YACV,MAAM,MAAM;YACZ,IAAI,OAAO,EAAE;YAEb,mBAAmB;YACnB,IAAI,EAAC,CAAC,CAAA,GAAA,iCAAyB,EAAE,EAAE,oBAAoB,EAAC,GAAG;YAE3D,IAAI,oBAAC,gBAAgB,EAAC,GAAG,uBAAuB,uBAAuB;YAEvE;QACF;QACA,YAAY,cAAc;IAC5B;IAEA,IAAI,kBAAC,cAAc,EAAC,GAAG,CAAA,GAAA,yCAAW,EAAE,OAAO;IAC3C,IAAI,eAAe,CAAA,GAAA,yCAAS,EAAE,YAAY;IAC1C,IAAI,WAAW,CAAA,GAAA,yCAAa,EAAE,OAAO;QAAC,WAAW;IAAI;IAErD,CAAA,GAAA,yCAAW,EAAE,KAAK,MAAM,eAAe,EAAE,MAAM,WAAW;IAE1D,+EAA+E;IAC/E,IAAI,mBAAmB,CAAA,GAAA,yCAAS;IAChC,IAAI,oBAAoB,CAAA,GAAA,yCAAS;IAEjC,OAAO;QACL,YAAY,CAAA,GAAA,yCAAS,EAAE,YAAY;YAAC,SAAS,CAAA,IAAK,EAAE,cAAc;QAAE;QACpE,YAAY,CAAA,GAAA,yCAAS,EAAE,UAAU;YAC/B,SAAS,MAAM,UAAU;YACzB,iBAAiB,AAAC,cAAc,uBAAuB,UAAW;YAClE,UAAU,cAAc,uBAAuB;YAC/C,gBAAgB,aAAa,MAAM,eAAe,KAAK,aAAa;YACpE,qBAAqB,KAAK,CAAC,oBAAoB;YAC/C,iBAAiB,KAAK,CAAC,gBAAgB;YACvC,iBAAiB,cAAc;YAC/B,oBACE;gBAAC,iBAAiB,EAAE;gBAAE,kBAAkB,EAAE;gBAAE;aAAgB,CAAC,MAAM,CAAC,SAAS,IAAI,CAAC,QAClF;sBACF;YACA,UAAU;YACV,GAAI,SAAS,OAAO,CAAC,IAAI;uBAAC;YAAK,CAAC;kBAChC;kBACA;YACA,MAAM;YACN,GAAG,YAAY;QACjB;0BACA;2BACA;QACA,YAAY,MAAM,UAAU;QAC5B,WAAW,aAAa;oBACxB;oBACA;QACA,WAAW,aAAa,MAAM,eAAe,KAAK;0BAClD;2BACA;IACF;AACF","sources":["packages/react-aria/src/toggle/useToggle.ts"],"sourcesContent":["/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {\n AriaLabelingProps,\n AriaValidationProps,\n DOMAttributesWithRef,\n FocusableDOMProps,\n InputDOMProps,\n PressEvents,\n RefObject,\n ValidationResult\n} from '@react-types/shared';\nimport {ChangeEventHandler, InputHTMLAttributes, LabelHTMLAttributes, useState} from 'react';\nimport {filterDOMProps} from '../utils/filterDOMProps';\nimport {getEventTarget} from '../utils/shadowdom/DOMFunctions';\nimport {mergeProps} from '../utils/mergeProps';\nimport {\n privateValidationStateProp,\n useFormValidationState\n} from 'react-stately/private/form/useFormValidationState';\nimport {ToggleProps, ToggleState} from 'react-stately/useToggleState';\nimport {useFocusable} from '../interactions/useFocusable';\nimport {useFormReset} from '../utils/useFormReset';\nimport {useFormValidation} from '../form/useFormValidation';\nimport {usePress} from '../interactions/usePress';\nimport {useSlotId2} from '../utils/useSlot';\n\nexport interface AriaToggleProps\n extends\n ToggleProps,\n FocusableDOMProps,\n AriaLabelingProps,\n AriaValidationProps,\n InputDOMProps,\n PressEvents {\n /**\n * Identifies the element (or elements) whose contents or presence are controlled by the current\n * element.\n */\n 'aria-controls'?: string;\n}\n\nexport interface ToggleAria extends ValidationResult {\n /** Props to be spread on the label element. */\n labelProps: LabelHTMLAttributes<HTMLLabelElement>;\n /** Props to be spread on the input element. */\n inputProps: InputHTMLAttributes<HTMLInputElement>;\n /** Props for the checkbox description element, if any. */\n descriptionProps: DOMAttributesWithRef<HTMLElement>;\n /** Props for the checkbox error message element, if any. */\n errorMessageProps: DOMAttributesWithRef<HTMLElement>;\n /** Whether the toggle is selected. */\n isSelected: boolean;\n /** Whether the toggle is in a pressed state. */\n isPressed: boolean;\n /** Whether the toggle is disabled. */\n isDisabled: boolean;\n /** Whether the toggle is read only. */\n isReadOnly: boolean;\n /** Whether the toggle is invalid. */\n isInvalid: boolean;\n}\n\n/**\n * Handles interactions for toggle elements, e.g. Checkboxes and Switches.\n */\nexport function useToggle(\n props: AriaToggleProps,\n state: ToggleState,\n ref: RefObject<HTMLInputElement | null>\n): ToggleAria {\n let {\n isDisabled = false,\n isReadOnly = false,\n value,\n name,\n form,\n children,\n isRequired,\n validationBehavior = 'aria',\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledby,\n 'aria-describedby': ariaDescribedby,\n onPressStart,\n onPressEnd,\n onPressChange,\n onPress,\n onPressUp,\n onClick\n } = props;\n\n // Create validation state here because it doesn't make sense to add to general useToggleState.\n let validationState = useFormValidationState({...props, value: state.isSelected});\n let {isInvalid, validationErrors, validationDetails} = validationState.displayValidation;\n\n useFormValidation(props, validationState, ref);\n\n let onChange: ChangeEventHandler<HTMLInputElement> = e => {\n // since we spread props on label, onChange will end up there as well as in here.\n // so we have to stop propagation at the lowest level that we care about\n e.stopPropagation();\n state.setSelected(getEventTarget(e).checked);\n };\n\n let hasChildren = children != null;\n let hasAriaLabel = ariaLabel != null || ariaLabelledby != null;\n if (!hasChildren && !hasAriaLabel && process.env.NODE_ENV !== 'production') {\n console.warn(\n 'If you do not provide children, you must specify an aria-label for accessibility'\n );\n }\n\n // Handle press state for keyboard interactions and cases where labelProps is not used.\n let {pressProps, isPressed} = usePress({\n onPressStart,\n onPressEnd,\n onPressChange,\n onPress,\n onPressUp,\n onClick,\n isDisabled\n });\n\n // Handle press state on the label.\n let [isLabelPressed, setLabelPressed] = useState(false);\n let {pressProps: labelProps} = usePress({\n onPressStart(e) {\n // Keyboard interactions are handled directly on the input.\n if (e.pointerType === 'keyboard' || e.pointerType === 'virtual') {\n e.continuePropagation();\n return;\n }\n\n onPressStart?.(e);\n onPressChange?.(true);\n setLabelPressed(true);\n },\n onPressEnd(e) {\n // Keyboard interactions are handled directly on the input.\n if (e.pointerType === 'keyboard' || e.pointerType === 'virtual') {\n e.continuePropagation();\n return;\n }\n\n onPressEnd?.(e);\n onPressChange?.(false);\n setLabelPressed(false);\n },\n onPressUp(e) {\n if (e.pointerType === 'keyboard' || e.pointerType === 'virtual') {\n e.continuePropagation();\n return;\n }\n\n onPressUp?.(e);\n },\n onClick,\n onPress(e) {\n if (e.pointerType === 'keyboard' || e.pointerType === 'virtual') {\n e.continuePropagation();\n return;\n }\n\n onPress?.(e);\n state.toggle();\n ref.current?.focus();\n\n // @ts-expect-error\n let {[privateValidationStateProp]: groupValidationState} = props;\n\n let {commitValidation} = groupValidationState ? groupValidationState : validationState;\n\n commitValidation();\n },\n isDisabled: isDisabled || isReadOnly\n });\n\n let {focusableProps} = useFocusable(props, ref);\n let interactions = mergeProps(pressProps, focusableProps);\n let domProps = filterDOMProps(props, {labelable: true});\n\n useFormReset(ref, state.defaultSelected, state.setSelected);\n\n // Copied from useField because we don't want the label behavior that provides.\n let descriptionProps = useSlotId2();\n let errorMessageProps = useSlotId2();\n\n return {\n labelProps: mergeProps(labelProps, {onClick: e => e.preventDefault()}),\n inputProps: mergeProps(domProps, {\n checked: state.isSelected,\n 'aria-required': (isRequired && validationBehavior === 'aria') || undefined,\n required: isRequired && validationBehavior === 'native',\n 'aria-invalid': isInvalid || props.validationState === 'invalid' || undefined,\n 'aria-errormessage': props['aria-errormessage'],\n 'aria-controls': props['aria-controls'],\n 'aria-readonly': isReadOnly || undefined,\n 'aria-describedby':\n [descriptionProps.id, errorMessageProps.id, ariaDescribedby].filter(Boolean).join(' ') ||\n undefined,\n onChange,\n disabled: isDisabled,\n ...(value == null ? {} : {value}),\n name,\n form,\n type: 'checkbox',\n ...interactions\n }),\n descriptionProps,\n errorMessageProps,\n isSelected: state.isSelected,\n isPressed: isPressed || isLabelPressed,\n isDisabled,\n isReadOnly,\n isInvalid: isInvalid || props.validationState === 'invalid',\n validationErrors,\n validationDetails\n };\n}\n"],"names":[],"version":3,"file":"useToggle.mjs.map"}
@@ -53,7 +53,6 @@ function $4be8e70c23134915$export$fa142eb1681c520(props, ref) {
53
53
  // out of the entire toolbar. To do this, move focus
54
54
  // to the first or last focusable child, and let the
55
55
  // browser handle the Tab key as usual from there.
56
- e.stopPropagation();
57
56
  lastFocused.current = (0, $da02ee888921bc9e$exports.getActiveElement)();
58
57
  if (e.shiftKey) focusManager.focusFirst();
59
58
  else focusManager.focusLast();
@@ -1 +1 @@
1
- {"mappings":";;;;;;;;;;;;;AAAA;;;;;;;;;;CAUC;;;;;;AA+BM,SAAS,yCAAW,KAAuB,EAAE,GAAkC;IACpF,MAAM,EACJ,cAAc,SAAS,EACvB,mBAAmB,cAAc,eACjC,cAAc,cACf,GAAG;IACJ,IAAI,CAAC,aAAa,aAAa,GAAG,CAAA,GAAA,qBAAO,EAAE;IAC3C,4FAA4F;IAC5F,mFAAmF;IACnF,uDAAuD;IACvD,CAAA,GAAA,yCAAc,EAAE;QACd,aAAa,CAAC,CAAE,CAAA,IAAI,OAAO,IAAI,IAAI,OAAO,CAAC,aAAa,EAAE,QAAQ,mBAAkB;IACtF;IACA,MAAM,aAAC,SAAS,EAAC,GAAG,CAAA,GAAA,mCAAQ;IAC5B,MAAM,gBAAgB,cAAc,SAAS,gBAAgB;IAC7D,IAAI,eAAe,CAAA,GAAA,4CAAiB,EAAE;IAEtC,MAAM,YAAkC,CAAC;QACvC,gCAAgC;QAChC,IAAI,CAAC,CAAA,GAAA,sCAAW,EAAE,EAAE,aAAa,EAAE,CAAA,GAAA,wCAAa,EAAE,KAChD;QAEF,IACE,AAAC,gBAAgB,gBAAgB,EAAE,GAAG,KAAK,gBACvC,gBAAgB,cAAc,EAAE,GAAG,KAAK;YAC5C,IAAI,eACF,aAAa,aAAa;iBAE1B,aAAa,SAAS;eAEnB,IACL,AAAC,gBAAgB,gBAAgB,EAAE,GAAG,KAAK,eACvC,gBAAgB,cAAc,EAAE,GAAG,KAAK;YAC5C,IAAI,eACF,aAAa,SAAS;iBAEtB,aAAa,aAAa;eAEvB,IAAI,EAAE,GAAG,KAAK,OAAO;YAC1B,qDAAqD;YACrD,oDAAoD;YACpD,oDAAoD;YACpD,kDAAkD;YAClD,EAAE,eAAe;YACjB,YAAY,OAAO,GAAG,CAAA,GAAA,0CAAe;YACrC,IAAI,EAAE,QAAQ,EACZ,aAAa,UAAU;iBAEvB,aAAa,SAAS;YAExB;QACF,OACE,wEAAwE;QACxE;QAGF,iEAAiE;QACjE,EAAE,eAAe;QACjB,EAAE,cAAc;IAClB;IAEA,qEAAqE;IACrE,MAAM,cAAc,CAAA,GAAA,mBAAK,EAAsB;IAC/C,MAAM,SAAyC,CAAC;QAC9C,IAAI,CAAC,CAAA,GAAA,sCAAW,EAAE,EAAE,aAAa,EAAE,EAAE,aAAa,KAAK,CAAC,YAAY,OAAO,EACzE,YAAY,OAAO,GAAG,CAAA,GAAA,wCAAa,EAAE;IAEzC;IAEA,+EAA+E;IAC/E,oFAAoF;IACpF,8EAA8E;IAC9E,MAAM,UAA0C,CAAC;QAC/C,IAAI,YAAY,OAAO,IAAI,CAAC,CAAA,GAAA,sCAAW,EAAE,EAAE,aAAa,EAAE,EAAE,aAAa,KAAK,CAAA,GAAA,sCAAW,EAAE,IAAI,OAAO,EAAE,CAAA,GAAA,wCAAa,EAAE,KAAK;YAC1H,YAAY,OAAO,EAAE;YACrB,YAAY,OAAO,GAAG;QACxB;IACF;IAEA,OAAO;QACL,cAAc;YACZ,GAAG,CAAA,GAAA,wCAAa,EAAE,OAAO;gBAAC,WAAW;YAAI,EAAE;YAC3C,MAAM,CAAC,cAAc,YAAY;YACjC,oBAAoB;YACpB,cAAc;YACd,mBAAmB,aAAa,OAAO,iBAAiB;YACxD,kBAAkB,CAAC,cAAc,YAAY;YAC7C,gBAAgB,CAAC,cAAc,UAAU;YACzC,eAAe,CAAC,cAAc,SAAS;QACzC;IACF;AACF","sources":["packages/react-aria/src/toolbar/useToolbar.ts"],"sourcesContent":["/*\n * Copyright 2023 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaLabelingProps, Orientation, RefObject} from '@react-types/shared';\nimport {createFocusManager} from '../focus/FocusScope';\nimport {filterDOMProps} from '../utils/filterDOMProps';\nimport {FocusEventHandler, HTMLAttributes, KeyboardEventHandler, useRef, useState} from 'react';\nimport {getActiveElement, getEventTarget, nodeContains} from '../utils/shadowdom/DOMFunctions';\nimport {useLayoutEffect} from '../utils/useLayoutEffect';\nimport {useLocale} from '../i18n/I18nProvider';\n\nexport interface AriaToolbarProps extends AriaLabelingProps {\n /**\n * The orientation of the entire toolbar.\n * @default 'horizontal'\n */\n orientation?: Orientation\n}\n\nexport interface ToolbarAria {\n /**\n * Props for the toolbar container.\n */\n toolbarProps: HTMLAttributes<HTMLElement>\n}\n\n/**\n * Provides the behavior and accessibility implementation for a toolbar.\n * A toolbar is a container for a set of interactive controls with arrow key navigation.\n * @param props - Props to be applied to the toolbar.\n * @param ref - A ref to a DOM element for the toolbar.\n */\nexport function useToolbar(props: AriaToolbarProps, ref: RefObject<HTMLElement | null>): ToolbarAria {\n const {\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n orientation = 'horizontal'\n } = props;\n let [isInToolbar, setInToolbar] = useState(false);\n // should be safe because re-calling set state with the same value it already has is a no-op\n // this will allow us to react should a parent re-render and change its role though\n // eslint-disable-next-line react-hooks/exhaustive-deps\n useLayoutEffect(() => {\n setInToolbar(!!(ref.current && ref.current.parentElement?.closest('[role=\"toolbar\"]')));\n });\n const {direction} = useLocale();\n const shouldReverse = direction === 'rtl' && orientation === 'horizontal';\n let focusManager = createFocusManager(ref);\n\n const onKeyDown: KeyboardEventHandler = (e) => {\n // don't handle portalled events\n if (!nodeContains(e.currentTarget, getEventTarget(e) as HTMLElement)) {\n return;\n }\n if (\n (orientation === 'horizontal' && e.key === 'ArrowRight')\n || (orientation === 'vertical' && e.key === 'ArrowDown')) {\n if (shouldReverse) {\n focusManager.focusPrevious();\n } else {\n focusManager.focusNext();\n }\n } else if (\n (orientation === 'horizontal' && e.key === 'ArrowLeft')\n || (orientation === 'vertical' && e.key === 'ArrowUp')) {\n if (shouldReverse) {\n focusManager.focusNext();\n } else {\n focusManager.focusPrevious();\n }\n } else if (e.key === 'Tab') {\n // When the tab key is pressed, we want to move focus\n // out of the entire toolbar. To do this, move focus\n // to the first or last focusable child, and let the\n // browser handle the Tab key as usual from there.\n e.stopPropagation();\n lastFocused.current = getActiveElement() as HTMLElement;\n if (e.shiftKey) {\n focusManager.focusFirst();\n } else {\n focusManager.focusLast();\n }\n return;\n } else {\n // if we didn't handle anything, return early so we don't preventDefault\n return;\n }\n\n // Prevent arrow keys from being handled by nested action groups.\n e.stopPropagation();\n e.preventDefault();\n };\n\n // Record the last focused child when focus moves out of the toolbar.\n const lastFocused = useRef<HTMLElement | null>(null);\n const onBlur: FocusEventHandler<HTMLElement> = (e) => {\n if (!nodeContains(e.currentTarget, e.relatedTarget) && !lastFocused.current) {\n lastFocused.current = getEventTarget(e);\n }\n };\n\n // Restore focus to the last focused child when focus returns into the toolbar.\n // If the element was removed, do nothing, either the first item in the first group,\n // or the last item in the last group will be focused, depending on direction.\n const onFocus: FocusEventHandler<HTMLElement> = (e) => {\n if (lastFocused.current && !nodeContains(e.currentTarget, e.relatedTarget) && nodeContains(ref.current, getEventTarget(e))) {\n lastFocused.current?.focus();\n lastFocused.current = null;\n }\n };\n\n return {\n toolbarProps: {\n ...filterDOMProps(props, {labelable: true}),\n role: !isInToolbar ? 'toolbar' : 'group',\n 'aria-orientation': orientation,\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabel == null ? ariaLabelledBy : undefined,\n onKeyDownCapture: !isInToolbar ? onKeyDown : undefined,\n onFocusCapture: !isInToolbar ? onFocus : undefined,\n onBlurCapture: !isInToolbar ? onBlur : undefined\n }\n };\n}\n"],"names":[],"version":3,"file":"useToolbar.cjs.map"}
1
+ {"mappings":";;;;;;;;;;;;;AAAA;;;;;;;;;;CAUC;;;;;;AAiCM,SAAS,yCACd,KAAuB,EACvB,GAAkC;IAElC,MAAM,EACJ,cAAc,SAAS,EACvB,mBAAmB,cAAc,eACjC,cAAc,cACf,GAAG;IACJ,IAAI,CAAC,aAAa,aAAa,GAAG,CAAA,GAAA,qBAAO,EAAE;IAC3C,4FAA4F;IAC5F,mFAAmF;IACnF,uDAAuD;IACvD,CAAA,GAAA,yCAAc,EAAE;QACd,aAAa,CAAC,CAAE,CAAA,IAAI,OAAO,IAAI,IAAI,OAAO,CAAC,aAAa,EAAE,QAAQ,mBAAkB;IACtF;IACA,MAAM,aAAC,SAAS,EAAC,GAAG,CAAA,GAAA,mCAAQ;IAC5B,MAAM,gBAAgB,cAAc,SAAS,gBAAgB;IAC7D,IAAI,eAAe,CAAA,GAAA,4CAAiB,EAAE;IAEtC,MAAM,YAAkC,CAAA;QACtC,gCAAgC;QAChC,IAAI,CAAC,CAAA,GAAA,sCAAW,EAAE,EAAE,aAAa,EAAE,CAAA,GAAA,wCAAa,EAAE,KAChD;QAEF,IACE,AAAC,gBAAgB,gBAAgB,EAAE,GAAG,KAAK,gBAC1C,gBAAgB,cAAc,EAAE,GAAG,KAAK;YAEzC,IAAI,eACF,aAAa,aAAa;iBAE1B,aAAa,SAAS;eAEnB,IACL,AAAC,gBAAgB,gBAAgB,EAAE,GAAG,KAAK,eAC1C,gBAAgB,cAAc,EAAE,GAAG,KAAK;YAEzC,IAAI,eACF,aAAa,SAAS;iBAEtB,aAAa,aAAa;eAEvB,IAAI,EAAE,GAAG,KAAK,OAAO;YAC1B,qDAAqD;YACrD,oDAAoD;YACpD,oDAAoD;YACpD,kDAAkD;YAClD,YAAY,OAAO,GAAG,CAAA,GAAA,0CAAe;YACrC,IAAI,EAAE,QAAQ,EACZ,aAAa,UAAU;iBAEvB,aAAa,SAAS;YAExB;QACF,OACE,wEAAwE;QACxE;QAGF,iEAAiE;QACjE,EAAE,eAAe;QACjB,EAAE,cAAc;IAClB;IAEA,qEAAqE;IACrE,MAAM,cAAc,CAAA,GAAA,mBAAK,EAAsB;IAC/C,MAAM,SAAyC,CAAA;QAC7C,IAAI,CAAC,CAAA,GAAA,sCAAW,EAAE,EAAE,aAAa,EAAE,EAAE,aAAa,KAAK,CAAC,YAAY,OAAO,EACzE,YAAY,OAAO,GAAG,CAAA,GAAA,wCAAa,EAAE;IAEzC;IAEA,+EAA+E;IAC/E,oFAAoF;IACpF,8EAA8E;IAC9E,MAAM,UAA0C,CAAA;QAC9C,IACE,YAAY,OAAO,IACnB,CAAC,CAAA,GAAA,sCAAW,EAAE,EAAE,aAAa,EAAE,EAAE,aAAa,KAC9C,CAAA,GAAA,sCAAW,EAAE,IAAI,OAAO,EAAE,CAAA,GAAA,wCAAa,EAAE,KACzC;YACA,YAAY,OAAO,EAAE;YACrB,YAAY,OAAO,GAAG;QACxB;IACF;IAEA,OAAO;QACL,cAAc;YACZ,GAAG,CAAA,GAAA,wCAAa,EAAE,OAAO;gBAAC,WAAW;YAAI,EAAE;YAC3C,MAAM,CAAC,cAAc,YAAY;YACjC,oBAAoB;YACpB,cAAc;YACd,mBAAmB,aAAa,OAAO,iBAAiB;YACxD,kBAAkB,CAAC,cAAc,YAAY;YAC7C,gBAAgB,CAAC,cAAc,UAAU;YACzC,eAAe,CAAC,cAAc,SAAS;QACzC;IACF;AACF","sources":["packages/react-aria/src/toolbar/useToolbar.ts"],"sourcesContent":["/*\n * Copyright 2023 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaLabelingProps, Orientation, RefObject} from '@react-types/shared';\nimport {createFocusManager} from '../focus/FocusScope';\nimport {filterDOMProps} from '../utils/filterDOMProps';\nimport {FocusEventHandler, HTMLAttributes, KeyboardEventHandler, useRef, useState} from 'react';\nimport {getActiveElement, getEventTarget, nodeContains} from '../utils/shadowdom/DOMFunctions';\nimport {useLayoutEffect} from '../utils/useLayoutEffect';\nimport {useLocale} from '../i18n/I18nProvider';\n\nexport interface AriaToolbarProps extends AriaLabelingProps {\n /**\n * The orientation of the entire toolbar.\n *\n * @default 'horizontal'\n */\n orientation?: Orientation;\n}\n\nexport interface ToolbarAria {\n /**\n * Props for the toolbar container.\n */\n toolbarProps: HTMLAttributes<HTMLElement>;\n}\n\n/**\n * Provides the behavior and accessibility implementation for a toolbar.\n * A toolbar is a container for a set of interactive controls with arrow key navigation.\n *\n * @param props - Props to be applied to the toolbar.\n * @param ref - A ref to a DOM element for the toolbar.\n */\nexport function useToolbar(\n props: AriaToolbarProps,\n ref: RefObject<HTMLElement | null>\n): ToolbarAria {\n const {\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n orientation = 'horizontal'\n } = props;\n let [isInToolbar, setInToolbar] = useState(false);\n // should be safe because re-calling set state with the same value it already has is a no-op\n // this will allow us to react should a parent re-render and change its role though\n // eslint-disable-next-line react-hooks/exhaustive-deps\n useLayoutEffect(() => {\n setInToolbar(!!(ref.current && ref.current.parentElement?.closest('[role=\"toolbar\"]')));\n });\n const {direction} = useLocale();\n const shouldReverse = direction === 'rtl' && orientation === 'horizontal';\n let focusManager = createFocusManager(ref);\n\n const onKeyDown: KeyboardEventHandler = e => {\n // don't handle portalled events\n if (!nodeContains(e.currentTarget, getEventTarget(e) as HTMLElement)) {\n return;\n }\n if (\n (orientation === 'horizontal' && e.key === 'ArrowRight') ||\n (orientation === 'vertical' && e.key === 'ArrowDown')\n ) {\n if (shouldReverse) {\n focusManager.focusPrevious();\n } else {\n focusManager.focusNext();\n }\n } else if (\n (orientation === 'horizontal' && e.key === 'ArrowLeft') ||\n (orientation === 'vertical' && e.key === 'ArrowUp')\n ) {\n if (shouldReverse) {\n focusManager.focusNext();\n } else {\n focusManager.focusPrevious();\n }\n } else if (e.key === 'Tab') {\n // When the tab key is pressed, we want to move focus\n // out of the entire toolbar. To do this, move focus\n // to the first or last focusable child, and let the\n // browser handle the Tab key as usual from there.\n lastFocused.current = getActiveElement() as HTMLElement;\n if (e.shiftKey) {\n focusManager.focusFirst();\n } else {\n focusManager.focusLast();\n }\n return;\n } else {\n // if we didn't handle anything, return early so we don't preventDefault\n return;\n }\n\n // Prevent arrow keys from being handled by nested action groups.\n e.stopPropagation();\n e.preventDefault();\n };\n\n // Record the last focused child when focus moves out of the toolbar.\n const lastFocused = useRef<HTMLElement | null>(null);\n const onBlur: FocusEventHandler<HTMLElement> = e => {\n if (!nodeContains(e.currentTarget, e.relatedTarget) && !lastFocused.current) {\n lastFocused.current = getEventTarget(e);\n }\n };\n\n // Restore focus to the last focused child when focus returns into the toolbar.\n // If the element was removed, do nothing, either the first item in the first group,\n // or the last item in the last group will be focused, depending on direction.\n const onFocus: FocusEventHandler<HTMLElement> = e => {\n if (\n lastFocused.current &&\n !nodeContains(e.currentTarget, e.relatedTarget) &&\n nodeContains(ref.current, getEventTarget(e))\n ) {\n lastFocused.current?.focus();\n lastFocused.current = null;\n }\n };\n\n return {\n toolbarProps: {\n ...filterDOMProps(props, {labelable: true}),\n role: !isInToolbar ? 'toolbar' : 'group',\n 'aria-orientation': orientation,\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabel == null ? ariaLabelledBy : undefined,\n onKeyDownCapture: !isInToolbar ? onKeyDown : undefined,\n onFocusCapture: !isInToolbar ? onFocus : undefined,\n onBlurCapture: !isInToolbar ? onBlur : undefined\n }\n };\n}\n"],"names":[],"version":3,"file":"useToolbar.cjs.map"}
@@ -48,7 +48,6 @@ function $bfa20c3289e39703$export$fa142eb1681c520(props, ref) {
48
48
  // out of the entire toolbar. To do this, move focus
49
49
  // to the first or last focusable child, and let the
50
50
  // browser handle the Tab key as usual from there.
51
- e.stopPropagation();
52
51
  lastFocused.current = (0, $d8ac7ed472840322$export$cd4e5573fbe2b576)();
53
52
  if (e.shiftKey) focusManager.focusFirst();
54
53
  else focusManager.focusLast();
@@ -1 +1 @@
1
- {"mappings":";;;;;;;AAAA;;;;;;;;;;CAUC;;;;;;AA+BM,SAAS,yCAAW,KAAuB,EAAE,GAAkC;IACpF,MAAM,EACJ,cAAc,SAAS,EACvB,mBAAmB,cAAc,eACjC,cAAc,cACf,GAAG;IACJ,IAAI,CAAC,aAAa,aAAa,GAAG,CAAA,GAAA,eAAO,EAAE;IAC3C,4FAA4F;IAC5F,mFAAmF;IACnF,uDAAuD;IACvD,CAAA,GAAA,yCAAc,EAAE;YACiB;QAA/B,aAAa,CAAC,CAAE,CAAA,IAAI,OAAO,MAAI,6BAAA,IAAI,OAAO,CAAC,aAAa,cAAzB,iDAAA,2BAA2B,OAAO,CAAC,oBAAkB;IACtF;IACA,MAAM,aAAC,SAAS,EAAC,GAAG,CAAA,GAAA,yCAAQ;IAC5B,MAAM,gBAAgB,cAAc,SAAS,gBAAgB;IAC7D,IAAI,eAAe,CAAA,GAAA,wCAAiB,EAAE;IAEtC,MAAM,YAAkC,CAAC;QACvC,gCAAgC;QAChC,IAAI,CAAC,CAAA,GAAA,yCAAW,EAAE,EAAE,aAAa,EAAE,CAAA,GAAA,yCAAa,EAAE,KAChD;QAEF,IACE,AAAC,gBAAgB,gBAAgB,EAAE,GAAG,KAAK,gBACvC,gBAAgB,cAAc,EAAE,GAAG,KAAK;YAC5C,IAAI,eACF,aAAa,aAAa;iBAE1B,aAAa,SAAS;eAEnB,IACL,AAAC,gBAAgB,gBAAgB,EAAE,GAAG,KAAK,eACvC,gBAAgB,cAAc,EAAE,GAAG,KAAK;YAC5C,IAAI,eACF,aAAa,SAAS;iBAEtB,aAAa,aAAa;eAEvB,IAAI,EAAE,GAAG,KAAK,OAAO;YAC1B,qDAAqD;YACrD,oDAAoD;YACpD,oDAAoD;YACpD,kDAAkD;YAClD,EAAE,eAAe;YACjB,YAAY,OAAO,GAAG,CAAA,GAAA,yCAAe;YACrC,IAAI,EAAE,QAAQ,EACZ,aAAa,UAAU;iBAEvB,aAAa,SAAS;YAExB;QACF,OACE,wEAAwE;QACxE;QAGF,iEAAiE;QACjE,EAAE,eAAe;QACjB,EAAE,cAAc;IAClB;IAEA,qEAAqE;IACrE,MAAM,cAAc,CAAA,GAAA,aAAK,EAAsB;IAC/C,MAAM,SAAyC,CAAC;QAC9C,IAAI,CAAC,CAAA,GAAA,yCAAW,EAAE,EAAE,aAAa,EAAE,EAAE,aAAa,KAAK,CAAC,YAAY,OAAO,EACzE,YAAY,OAAO,GAAG,CAAA,GAAA,yCAAa,EAAE;IAEzC;IAEA,+EAA+E;IAC/E,oFAAoF;IACpF,8EAA8E;IAC9E,MAAM,UAA0C,CAAC;QAC/C,IAAI,YAAY,OAAO,IAAI,CAAC,CAAA,GAAA,yCAAW,EAAE,EAAE,aAAa,EAAE,EAAE,aAAa,KAAK,CAAA,GAAA,yCAAW,EAAE,IAAI,OAAO,EAAE,CAAA,GAAA,yCAAa,EAAE,KAAK;gBAC1H;aAAA,uBAAA,YAAY,OAAO,cAAnB,2CAAA,qBAAqB,KAAK;YAC1B,YAAY,OAAO,GAAG;QACxB;IACF;IAEA,OAAO;QACL,cAAc;YACZ,GAAG,CAAA,GAAA,yCAAa,EAAE,OAAO;gBAAC,WAAW;YAAI,EAAE;YAC3C,MAAM,CAAC,cAAc,YAAY;YACjC,oBAAoB;YACpB,cAAc;YACd,mBAAmB,aAAa,OAAO,iBAAiB;YACxD,kBAAkB,CAAC,cAAc,YAAY;YAC7C,gBAAgB,CAAC,cAAc,UAAU;YACzC,eAAe,CAAC,cAAc,SAAS;QACzC;IACF;AACF","sources":["packages/react-aria/src/toolbar/useToolbar.ts"],"sourcesContent":["/*\n * Copyright 2023 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaLabelingProps, Orientation, RefObject} from '@react-types/shared';\nimport {createFocusManager} from '../focus/FocusScope';\nimport {filterDOMProps} from '../utils/filterDOMProps';\nimport {FocusEventHandler, HTMLAttributes, KeyboardEventHandler, useRef, useState} from 'react';\nimport {getActiveElement, getEventTarget, nodeContains} from '../utils/shadowdom/DOMFunctions';\nimport {useLayoutEffect} from '../utils/useLayoutEffect';\nimport {useLocale} from '../i18n/I18nProvider';\n\nexport interface AriaToolbarProps extends AriaLabelingProps {\n /**\n * The orientation of the entire toolbar.\n * @default 'horizontal'\n */\n orientation?: Orientation\n}\n\nexport interface ToolbarAria {\n /**\n * Props for the toolbar container.\n */\n toolbarProps: HTMLAttributes<HTMLElement>\n}\n\n/**\n * Provides the behavior and accessibility implementation for a toolbar.\n * A toolbar is a container for a set of interactive controls with arrow key navigation.\n * @param props - Props to be applied to the toolbar.\n * @param ref - A ref to a DOM element for the toolbar.\n */\nexport function useToolbar(props: AriaToolbarProps, ref: RefObject<HTMLElement | null>): ToolbarAria {\n const {\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n orientation = 'horizontal'\n } = props;\n let [isInToolbar, setInToolbar] = useState(false);\n // should be safe because re-calling set state with the same value it already has is a no-op\n // this will allow us to react should a parent re-render and change its role though\n // eslint-disable-next-line react-hooks/exhaustive-deps\n useLayoutEffect(() => {\n setInToolbar(!!(ref.current && ref.current.parentElement?.closest('[role=\"toolbar\"]')));\n });\n const {direction} = useLocale();\n const shouldReverse = direction === 'rtl' && orientation === 'horizontal';\n let focusManager = createFocusManager(ref);\n\n const onKeyDown: KeyboardEventHandler = (e) => {\n // don't handle portalled events\n if (!nodeContains(e.currentTarget, getEventTarget(e) as HTMLElement)) {\n return;\n }\n if (\n (orientation === 'horizontal' && e.key === 'ArrowRight')\n || (orientation === 'vertical' && e.key === 'ArrowDown')) {\n if (shouldReverse) {\n focusManager.focusPrevious();\n } else {\n focusManager.focusNext();\n }\n } else if (\n (orientation === 'horizontal' && e.key === 'ArrowLeft')\n || (orientation === 'vertical' && e.key === 'ArrowUp')) {\n if (shouldReverse) {\n focusManager.focusNext();\n } else {\n focusManager.focusPrevious();\n }\n } else if (e.key === 'Tab') {\n // When the tab key is pressed, we want to move focus\n // out of the entire toolbar. To do this, move focus\n // to the first or last focusable child, and let the\n // browser handle the Tab key as usual from there.\n e.stopPropagation();\n lastFocused.current = getActiveElement() as HTMLElement;\n if (e.shiftKey) {\n focusManager.focusFirst();\n } else {\n focusManager.focusLast();\n }\n return;\n } else {\n // if we didn't handle anything, return early so we don't preventDefault\n return;\n }\n\n // Prevent arrow keys from being handled by nested action groups.\n e.stopPropagation();\n e.preventDefault();\n };\n\n // Record the last focused child when focus moves out of the toolbar.\n const lastFocused = useRef<HTMLElement | null>(null);\n const onBlur: FocusEventHandler<HTMLElement> = (e) => {\n if (!nodeContains(e.currentTarget, e.relatedTarget) && !lastFocused.current) {\n lastFocused.current = getEventTarget(e);\n }\n };\n\n // Restore focus to the last focused child when focus returns into the toolbar.\n // If the element was removed, do nothing, either the first item in the first group,\n // or the last item in the last group will be focused, depending on direction.\n const onFocus: FocusEventHandler<HTMLElement> = (e) => {\n if (lastFocused.current && !nodeContains(e.currentTarget, e.relatedTarget) && nodeContains(ref.current, getEventTarget(e))) {\n lastFocused.current?.focus();\n lastFocused.current = null;\n }\n };\n\n return {\n toolbarProps: {\n ...filterDOMProps(props, {labelable: true}),\n role: !isInToolbar ? 'toolbar' : 'group',\n 'aria-orientation': orientation,\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabel == null ? ariaLabelledBy : undefined,\n onKeyDownCapture: !isInToolbar ? onKeyDown : undefined,\n onFocusCapture: !isInToolbar ? onFocus : undefined,\n onBlurCapture: !isInToolbar ? onBlur : undefined\n }\n };\n}\n"],"names":[],"version":3,"file":"useToolbar.js.map"}
1
+ {"mappings":";;;;;;;AAAA;;;;;;;;;;CAUC;;;;;;AAiCM,SAAS,yCACd,KAAuB,EACvB,GAAkC;IAElC,MAAM,EACJ,cAAc,SAAS,EACvB,mBAAmB,cAAc,eACjC,cAAc,cACf,GAAG;IACJ,IAAI,CAAC,aAAa,aAAa,GAAG,CAAA,GAAA,eAAO,EAAE;IAC3C,4FAA4F;IAC5F,mFAAmF;IACnF,uDAAuD;IACvD,CAAA,GAAA,yCAAc,EAAE;YACiB;QAA/B,aAAa,CAAC,CAAE,CAAA,IAAI,OAAO,MAAI,6BAAA,IAAI,OAAO,CAAC,aAAa,cAAzB,iDAAA,2BAA2B,OAAO,CAAC,oBAAkB;IACtF;IACA,MAAM,aAAC,SAAS,EAAC,GAAG,CAAA,GAAA,yCAAQ;IAC5B,MAAM,gBAAgB,cAAc,SAAS,gBAAgB;IAC7D,IAAI,eAAe,CAAA,GAAA,wCAAiB,EAAE;IAEtC,MAAM,YAAkC,CAAA;QACtC,gCAAgC;QAChC,IAAI,CAAC,CAAA,GAAA,yCAAW,EAAE,EAAE,aAAa,EAAE,CAAA,GAAA,yCAAa,EAAE,KAChD;QAEF,IACE,AAAC,gBAAgB,gBAAgB,EAAE,GAAG,KAAK,gBAC1C,gBAAgB,cAAc,EAAE,GAAG,KAAK;YAEzC,IAAI,eACF,aAAa,aAAa;iBAE1B,aAAa,SAAS;eAEnB,IACL,AAAC,gBAAgB,gBAAgB,EAAE,GAAG,KAAK,eAC1C,gBAAgB,cAAc,EAAE,GAAG,KAAK;YAEzC,IAAI,eACF,aAAa,SAAS;iBAEtB,aAAa,aAAa;eAEvB,IAAI,EAAE,GAAG,KAAK,OAAO;YAC1B,qDAAqD;YACrD,oDAAoD;YACpD,oDAAoD;YACpD,kDAAkD;YAClD,YAAY,OAAO,GAAG,CAAA,GAAA,yCAAe;YACrC,IAAI,EAAE,QAAQ,EACZ,aAAa,UAAU;iBAEvB,aAAa,SAAS;YAExB;QACF,OACE,wEAAwE;QACxE;QAGF,iEAAiE;QACjE,EAAE,eAAe;QACjB,EAAE,cAAc;IAClB;IAEA,qEAAqE;IACrE,MAAM,cAAc,CAAA,GAAA,aAAK,EAAsB;IAC/C,MAAM,SAAyC,CAAA;QAC7C,IAAI,CAAC,CAAA,GAAA,yCAAW,EAAE,EAAE,aAAa,EAAE,EAAE,aAAa,KAAK,CAAC,YAAY,OAAO,EACzE,YAAY,OAAO,GAAG,CAAA,GAAA,yCAAa,EAAE;IAEzC;IAEA,+EAA+E;IAC/E,oFAAoF;IACpF,8EAA8E;IAC9E,MAAM,UAA0C,CAAA;QAC9C,IACE,YAAY,OAAO,IACnB,CAAC,CAAA,GAAA,yCAAW,EAAE,EAAE,aAAa,EAAE,EAAE,aAAa,KAC9C,CAAA,GAAA,yCAAW,EAAE,IAAI,OAAO,EAAE,CAAA,GAAA,yCAAa,EAAE,KACzC;gBACA;aAAA,uBAAA,YAAY,OAAO,cAAnB,2CAAA,qBAAqB,KAAK;YAC1B,YAAY,OAAO,GAAG;QACxB;IACF;IAEA,OAAO;QACL,cAAc;YACZ,GAAG,CAAA,GAAA,yCAAa,EAAE,OAAO;gBAAC,WAAW;YAAI,EAAE;YAC3C,MAAM,CAAC,cAAc,YAAY;YACjC,oBAAoB;YACpB,cAAc;YACd,mBAAmB,aAAa,OAAO,iBAAiB;YACxD,kBAAkB,CAAC,cAAc,YAAY;YAC7C,gBAAgB,CAAC,cAAc,UAAU;YACzC,eAAe,CAAC,cAAc,SAAS;QACzC;IACF;AACF","sources":["packages/react-aria/src/toolbar/useToolbar.ts"],"sourcesContent":["/*\n * Copyright 2023 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaLabelingProps, Orientation, RefObject} from '@react-types/shared';\nimport {createFocusManager} from '../focus/FocusScope';\nimport {filterDOMProps} from '../utils/filterDOMProps';\nimport {FocusEventHandler, HTMLAttributes, KeyboardEventHandler, useRef, useState} from 'react';\nimport {getActiveElement, getEventTarget, nodeContains} from '../utils/shadowdom/DOMFunctions';\nimport {useLayoutEffect} from '../utils/useLayoutEffect';\nimport {useLocale} from '../i18n/I18nProvider';\n\nexport interface AriaToolbarProps extends AriaLabelingProps {\n /**\n * The orientation of the entire toolbar.\n *\n * @default 'horizontal'\n */\n orientation?: Orientation;\n}\n\nexport interface ToolbarAria {\n /**\n * Props for the toolbar container.\n */\n toolbarProps: HTMLAttributes<HTMLElement>;\n}\n\n/**\n * Provides the behavior and accessibility implementation for a toolbar.\n * A toolbar is a container for a set of interactive controls with arrow key navigation.\n *\n * @param props - Props to be applied to the toolbar.\n * @param ref - A ref to a DOM element for the toolbar.\n */\nexport function useToolbar(\n props: AriaToolbarProps,\n ref: RefObject<HTMLElement | null>\n): ToolbarAria {\n const {\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n orientation = 'horizontal'\n } = props;\n let [isInToolbar, setInToolbar] = useState(false);\n // should be safe because re-calling set state with the same value it already has is a no-op\n // this will allow us to react should a parent re-render and change its role though\n // eslint-disable-next-line react-hooks/exhaustive-deps\n useLayoutEffect(() => {\n setInToolbar(!!(ref.current && ref.current.parentElement?.closest('[role=\"toolbar\"]')));\n });\n const {direction} = useLocale();\n const shouldReverse = direction === 'rtl' && orientation === 'horizontal';\n let focusManager = createFocusManager(ref);\n\n const onKeyDown: KeyboardEventHandler = e => {\n // don't handle portalled events\n if (!nodeContains(e.currentTarget, getEventTarget(e) as HTMLElement)) {\n return;\n }\n if (\n (orientation === 'horizontal' && e.key === 'ArrowRight') ||\n (orientation === 'vertical' && e.key === 'ArrowDown')\n ) {\n if (shouldReverse) {\n focusManager.focusPrevious();\n } else {\n focusManager.focusNext();\n }\n } else if (\n (orientation === 'horizontal' && e.key === 'ArrowLeft') ||\n (orientation === 'vertical' && e.key === 'ArrowUp')\n ) {\n if (shouldReverse) {\n focusManager.focusNext();\n } else {\n focusManager.focusPrevious();\n }\n } else if (e.key === 'Tab') {\n // When the tab key is pressed, we want to move focus\n // out of the entire toolbar. To do this, move focus\n // to the first or last focusable child, and let the\n // browser handle the Tab key as usual from there.\n lastFocused.current = getActiveElement() as HTMLElement;\n if (e.shiftKey) {\n focusManager.focusFirst();\n } else {\n focusManager.focusLast();\n }\n return;\n } else {\n // if we didn't handle anything, return early so we don't preventDefault\n return;\n }\n\n // Prevent arrow keys from being handled by nested action groups.\n e.stopPropagation();\n e.preventDefault();\n };\n\n // Record the last focused child when focus moves out of the toolbar.\n const lastFocused = useRef<HTMLElement | null>(null);\n const onBlur: FocusEventHandler<HTMLElement> = e => {\n if (!nodeContains(e.currentTarget, e.relatedTarget) && !lastFocused.current) {\n lastFocused.current = getEventTarget(e);\n }\n };\n\n // Restore focus to the last focused child when focus returns into the toolbar.\n // If the element was removed, do nothing, either the first item in the first group,\n // or the last item in the last group will be focused, depending on direction.\n const onFocus: FocusEventHandler<HTMLElement> = e => {\n if (\n lastFocused.current &&\n !nodeContains(e.currentTarget, e.relatedTarget) &&\n nodeContains(ref.current, getEventTarget(e))\n ) {\n lastFocused.current?.focus();\n lastFocused.current = null;\n }\n };\n\n return {\n toolbarProps: {\n ...filterDOMProps(props, {labelable: true}),\n role: !isInToolbar ? 'toolbar' : 'group',\n 'aria-orientation': orientation,\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabel == null ? ariaLabelledBy : undefined,\n onKeyDownCapture: !isInToolbar ? onKeyDown : undefined,\n onFocusCapture: !isInToolbar ? onFocus : undefined,\n onBlurCapture: !isInToolbar ? onBlur : undefined\n }\n };\n}\n"],"names":[],"version":3,"file":"useToolbar.js.map"}
@@ -47,7 +47,6 @@ function $afa781ff67c1cd08$export$fa142eb1681c520(props, ref) {
47
47
  // out of the entire toolbar. To do this, move focus
48
48
  // to the first or last focusable child, and let the
49
49
  // browser handle the Tab key as usual from there.
50
- e.stopPropagation();
51
50
  lastFocused.current = (0, $23f2114a1b82827e$export$cd4e5573fbe2b576)();
52
51
  if (e.shiftKey) focusManager.focusFirst();
53
52
  else focusManager.focusLast();
@@ -1 +1 @@
1
- {"mappings":";;;;;;;AAAA;;;;;;;;;;CAUC;;;;;;AA+BM,SAAS,yCAAW,KAAuB,EAAE,GAAkC;IACpF,MAAM,EACJ,cAAc,SAAS,EACvB,mBAAmB,cAAc,eACjC,cAAc,cACf,GAAG;IACJ,IAAI,CAAC,aAAa,aAAa,GAAG,CAAA,GAAA,eAAO,EAAE;IAC3C,4FAA4F;IAC5F,mFAAmF;IACnF,uDAAuD;IACvD,CAAA,GAAA,yCAAc,EAAE;QACd,aAAa,CAAC,CAAE,CAAA,IAAI,OAAO,IAAI,IAAI,OAAO,CAAC,aAAa,EAAE,QAAQ,mBAAkB;IACtF;IACA,MAAM,aAAC,SAAS,EAAC,GAAG,CAAA,GAAA,yCAAQ;IAC5B,MAAM,gBAAgB,cAAc,SAAS,gBAAgB;IAC7D,IAAI,eAAe,CAAA,GAAA,wCAAiB,EAAE;IAEtC,MAAM,YAAkC,CAAC;QACvC,gCAAgC;QAChC,IAAI,CAAC,CAAA,GAAA,yCAAW,EAAE,EAAE,aAAa,EAAE,CAAA,GAAA,yCAAa,EAAE,KAChD;QAEF,IACE,AAAC,gBAAgB,gBAAgB,EAAE,GAAG,KAAK,gBACvC,gBAAgB,cAAc,EAAE,GAAG,KAAK;YAC5C,IAAI,eACF,aAAa,aAAa;iBAE1B,aAAa,SAAS;eAEnB,IACL,AAAC,gBAAgB,gBAAgB,EAAE,GAAG,KAAK,eACvC,gBAAgB,cAAc,EAAE,GAAG,KAAK;YAC5C,IAAI,eACF,aAAa,SAAS;iBAEtB,aAAa,aAAa;eAEvB,IAAI,EAAE,GAAG,KAAK,OAAO;YAC1B,qDAAqD;YACrD,oDAAoD;YACpD,oDAAoD;YACpD,kDAAkD;YAClD,EAAE,eAAe;YACjB,YAAY,OAAO,GAAG,CAAA,GAAA,yCAAe;YACrC,IAAI,EAAE,QAAQ,EACZ,aAAa,UAAU;iBAEvB,aAAa,SAAS;YAExB;QACF,OACE,wEAAwE;QACxE;QAGF,iEAAiE;QACjE,EAAE,eAAe;QACjB,EAAE,cAAc;IAClB;IAEA,qEAAqE;IACrE,MAAM,cAAc,CAAA,GAAA,aAAK,EAAsB;IAC/C,MAAM,SAAyC,CAAC;QAC9C,IAAI,CAAC,CAAA,GAAA,yCAAW,EAAE,EAAE,aAAa,EAAE,EAAE,aAAa,KAAK,CAAC,YAAY,OAAO,EACzE,YAAY,OAAO,GAAG,CAAA,GAAA,yCAAa,EAAE;IAEzC;IAEA,+EAA+E;IAC/E,oFAAoF;IACpF,8EAA8E;IAC9E,MAAM,UAA0C,CAAC;QAC/C,IAAI,YAAY,OAAO,IAAI,CAAC,CAAA,GAAA,yCAAW,EAAE,EAAE,aAAa,EAAE,EAAE,aAAa,KAAK,CAAA,GAAA,yCAAW,EAAE,IAAI,OAAO,EAAE,CAAA,GAAA,yCAAa,EAAE,KAAK;YAC1H,YAAY,OAAO,EAAE;YACrB,YAAY,OAAO,GAAG;QACxB;IACF;IAEA,OAAO;QACL,cAAc;YACZ,GAAG,CAAA,GAAA,yCAAa,EAAE,OAAO;gBAAC,WAAW;YAAI,EAAE;YAC3C,MAAM,CAAC,cAAc,YAAY;YACjC,oBAAoB;YACpB,cAAc;YACd,mBAAmB,aAAa,OAAO,iBAAiB;YACxD,kBAAkB,CAAC,cAAc,YAAY;YAC7C,gBAAgB,CAAC,cAAc,UAAU;YACzC,eAAe,CAAC,cAAc,SAAS;QACzC;IACF;AACF","sources":["packages/react-aria/src/toolbar/useToolbar.ts"],"sourcesContent":["/*\n * Copyright 2023 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaLabelingProps, Orientation, RefObject} from '@react-types/shared';\nimport {createFocusManager} from '../focus/FocusScope';\nimport {filterDOMProps} from '../utils/filterDOMProps';\nimport {FocusEventHandler, HTMLAttributes, KeyboardEventHandler, useRef, useState} from 'react';\nimport {getActiveElement, getEventTarget, nodeContains} from '../utils/shadowdom/DOMFunctions';\nimport {useLayoutEffect} from '../utils/useLayoutEffect';\nimport {useLocale} from '../i18n/I18nProvider';\n\nexport interface AriaToolbarProps extends AriaLabelingProps {\n /**\n * The orientation of the entire toolbar.\n * @default 'horizontal'\n */\n orientation?: Orientation\n}\n\nexport interface ToolbarAria {\n /**\n * Props for the toolbar container.\n */\n toolbarProps: HTMLAttributes<HTMLElement>\n}\n\n/**\n * Provides the behavior and accessibility implementation for a toolbar.\n * A toolbar is a container for a set of interactive controls with arrow key navigation.\n * @param props - Props to be applied to the toolbar.\n * @param ref - A ref to a DOM element for the toolbar.\n */\nexport function useToolbar(props: AriaToolbarProps, ref: RefObject<HTMLElement | null>): ToolbarAria {\n const {\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n orientation = 'horizontal'\n } = props;\n let [isInToolbar, setInToolbar] = useState(false);\n // should be safe because re-calling set state with the same value it already has is a no-op\n // this will allow us to react should a parent re-render and change its role though\n // eslint-disable-next-line react-hooks/exhaustive-deps\n useLayoutEffect(() => {\n setInToolbar(!!(ref.current && ref.current.parentElement?.closest('[role=\"toolbar\"]')));\n });\n const {direction} = useLocale();\n const shouldReverse = direction === 'rtl' && orientation === 'horizontal';\n let focusManager = createFocusManager(ref);\n\n const onKeyDown: KeyboardEventHandler = (e) => {\n // don't handle portalled events\n if (!nodeContains(e.currentTarget, getEventTarget(e) as HTMLElement)) {\n return;\n }\n if (\n (orientation === 'horizontal' && e.key === 'ArrowRight')\n || (orientation === 'vertical' && e.key === 'ArrowDown')) {\n if (shouldReverse) {\n focusManager.focusPrevious();\n } else {\n focusManager.focusNext();\n }\n } else if (\n (orientation === 'horizontal' && e.key === 'ArrowLeft')\n || (orientation === 'vertical' && e.key === 'ArrowUp')) {\n if (shouldReverse) {\n focusManager.focusNext();\n } else {\n focusManager.focusPrevious();\n }\n } else if (e.key === 'Tab') {\n // When the tab key is pressed, we want to move focus\n // out of the entire toolbar. To do this, move focus\n // to the first or last focusable child, and let the\n // browser handle the Tab key as usual from there.\n e.stopPropagation();\n lastFocused.current = getActiveElement() as HTMLElement;\n if (e.shiftKey) {\n focusManager.focusFirst();\n } else {\n focusManager.focusLast();\n }\n return;\n } else {\n // if we didn't handle anything, return early so we don't preventDefault\n return;\n }\n\n // Prevent arrow keys from being handled by nested action groups.\n e.stopPropagation();\n e.preventDefault();\n };\n\n // Record the last focused child when focus moves out of the toolbar.\n const lastFocused = useRef<HTMLElement | null>(null);\n const onBlur: FocusEventHandler<HTMLElement> = (e) => {\n if (!nodeContains(e.currentTarget, e.relatedTarget) && !lastFocused.current) {\n lastFocused.current = getEventTarget(e);\n }\n };\n\n // Restore focus to the last focused child when focus returns into the toolbar.\n // If the element was removed, do nothing, either the first item in the first group,\n // or the last item in the last group will be focused, depending on direction.\n const onFocus: FocusEventHandler<HTMLElement> = (e) => {\n if (lastFocused.current && !nodeContains(e.currentTarget, e.relatedTarget) && nodeContains(ref.current, getEventTarget(e))) {\n lastFocused.current?.focus();\n lastFocused.current = null;\n }\n };\n\n return {\n toolbarProps: {\n ...filterDOMProps(props, {labelable: true}),\n role: !isInToolbar ? 'toolbar' : 'group',\n 'aria-orientation': orientation,\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabel == null ? ariaLabelledBy : undefined,\n onKeyDownCapture: !isInToolbar ? onKeyDown : undefined,\n onFocusCapture: !isInToolbar ? onFocus : undefined,\n onBlurCapture: !isInToolbar ? onBlur : undefined\n }\n };\n}\n"],"names":[],"version":3,"file":"useToolbar.mjs.map"}
1
+ {"mappings":";;;;;;;AAAA;;;;;;;;;;CAUC;;;;;;AAiCM,SAAS,yCACd,KAAuB,EACvB,GAAkC;IAElC,MAAM,EACJ,cAAc,SAAS,EACvB,mBAAmB,cAAc,eACjC,cAAc,cACf,GAAG;IACJ,IAAI,CAAC,aAAa,aAAa,GAAG,CAAA,GAAA,eAAO,EAAE;IAC3C,4FAA4F;IAC5F,mFAAmF;IACnF,uDAAuD;IACvD,CAAA,GAAA,yCAAc,EAAE;QACd,aAAa,CAAC,CAAE,CAAA,IAAI,OAAO,IAAI,IAAI,OAAO,CAAC,aAAa,EAAE,QAAQ,mBAAkB;IACtF;IACA,MAAM,aAAC,SAAS,EAAC,GAAG,CAAA,GAAA,yCAAQ;IAC5B,MAAM,gBAAgB,cAAc,SAAS,gBAAgB;IAC7D,IAAI,eAAe,CAAA,GAAA,wCAAiB,EAAE;IAEtC,MAAM,YAAkC,CAAA;QACtC,gCAAgC;QAChC,IAAI,CAAC,CAAA,GAAA,yCAAW,EAAE,EAAE,aAAa,EAAE,CAAA,GAAA,yCAAa,EAAE,KAChD;QAEF,IACE,AAAC,gBAAgB,gBAAgB,EAAE,GAAG,KAAK,gBAC1C,gBAAgB,cAAc,EAAE,GAAG,KAAK;YAEzC,IAAI,eACF,aAAa,aAAa;iBAE1B,aAAa,SAAS;eAEnB,IACL,AAAC,gBAAgB,gBAAgB,EAAE,GAAG,KAAK,eAC1C,gBAAgB,cAAc,EAAE,GAAG,KAAK;YAEzC,IAAI,eACF,aAAa,SAAS;iBAEtB,aAAa,aAAa;eAEvB,IAAI,EAAE,GAAG,KAAK,OAAO;YAC1B,qDAAqD;YACrD,oDAAoD;YACpD,oDAAoD;YACpD,kDAAkD;YAClD,YAAY,OAAO,GAAG,CAAA,GAAA,yCAAe;YACrC,IAAI,EAAE,QAAQ,EACZ,aAAa,UAAU;iBAEvB,aAAa,SAAS;YAExB;QACF,OACE,wEAAwE;QACxE;QAGF,iEAAiE;QACjE,EAAE,eAAe;QACjB,EAAE,cAAc;IAClB;IAEA,qEAAqE;IACrE,MAAM,cAAc,CAAA,GAAA,aAAK,EAAsB;IAC/C,MAAM,SAAyC,CAAA;QAC7C,IAAI,CAAC,CAAA,GAAA,yCAAW,EAAE,EAAE,aAAa,EAAE,EAAE,aAAa,KAAK,CAAC,YAAY,OAAO,EACzE,YAAY,OAAO,GAAG,CAAA,GAAA,yCAAa,EAAE;IAEzC;IAEA,+EAA+E;IAC/E,oFAAoF;IACpF,8EAA8E;IAC9E,MAAM,UAA0C,CAAA;QAC9C,IACE,YAAY,OAAO,IACnB,CAAC,CAAA,GAAA,yCAAW,EAAE,EAAE,aAAa,EAAE,EAAE,aAAa,KAC9C,CAAA,GAAA,yCAAW,EAAE,IAAI,OAAO,EAAE,CAAA,GAAA,yCAAa,EAAE,KACzC;YACA,YAAY,OAAO,EAAE;YACrB,YAAY,OAAO,GAAG;QACxB;IACF;IAEA,OAAO;QACL,cAAc;YACZ,GAAG,CAAA,GAAA,yCAAa,EAAE,OAAO;gBAAC,WAAW;YAAI,EAAE;YAC3C,MAAM,CAAC,cAAc,YAAY;YACjC,oBAAoB;YACpB,cAAc;YACd,mBAAmB,aAAa,OAAO,iBAAiB;YACxD,kBAAkB,CAAC,cAAc,YAAY;YAC7C,gBAAgB,CAAC,cAAc,UAAU;YACzC,eAAe,CAAC,cAAc,SAAS;QACzC;IACF;AACF","sources":["packages/react-aria/src/toolbar/useToolbar.ts"],"sourcesContent":["/*\n * Copyright 2023 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaLabelingProps, Orientation, RefObject} from '@react-types/shared';\nimport {createFocusManager} from '../focus/FocusScope';\nimport {filterDOMProps} from '../utils/filterDOMProps';\nimport {FocusEventHandler, HTMLAttributes, KeyboardEventHandler, useRef, useState} from 'react';\nimport {getActiveElement, getEventTarget, nodeContains} from '../utils/shadowdom/DOMFunctions';\nimport {useLayoutEffect} from '../utils/useLayoutEffect';\nimport {useLocale} from '../i18n/I18nProvider';\n\nexport interface AriaToolbarProps extends AriaLabelingProps {\n /**\n * The orientation of the entire toolbar.\n *\n * @default 'horizontal'\n */\n orientation?: Orientation;\n}\n\nexport interface ToolbarAria {\n /**\n * Props for the toolbar container.\n */\n toolbarProps: HTMLAttributes<HTMLElement>;\n}\n\n/**\n * Provides the behavior and accessibility implementation for a toolbar.\n * A toolbar is a container for a set of interactive controls with arrow key navigation.\n *\n * @param props - Props to be applied to the toolbar.\n * @param ref - A ref to a DOM element for the toolbar.\n */\nexport function useToolbar(\n props: AriaToolbarProps,\n ref: RefObject<HTMLElement | null>\n): ToolbarAria {\n const {\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n orientation = 'horizontal'\n } = props;\n let [isInToolbar, setInToolbar] = useState(false);\n // should be safe because re-calling set state with the same value it already has is a no-op\n // this will allow us to react should a parent re-render and change its role though\n // eslint-disable-next-line react-hooks/exhaustive-deps\n useLayoutEffect(() => {\n setInToolbar(!!(ref.current && ref.current.parentElement?.closest('[role=\"toolbar\"]')));\n });\n const {direction} = useLocale();\n const shouldReverse = direction === 'rtl' && orientation === 'horizontal';\n let focusManager = createFocusManager(ref);\n\n const onKeyDown: KeyboardEventHandler = e => {\n // don't handle portalled events\n if (!nodeContains(e.currentTarget, getEventTarget(e) as HTMLElement)) {\n return;\n }\n if (\n (orientation === 'horizontal' && e.key === 'ArrowRight') ||\n (orientation === 'vertical' && e.key === 'ArrowDown')\n ) {\n if (shouldReverse) {\n focusManager.focusPrevious();\n } else {\n focusManager.focusNext();\n }\n } else if (\n (orientation === 'horizontal' && e.key === 'ArrowLeft') ||\n (orientation === 'vertical' && e.key === 'ArrowUp')\n ) {\n if (shouldReverse) {\n focusManager.focusNext();\n } else {\n focusManager.focusPrevious();\n }\n } else if (e.key === 'Tab') {\n // When the tab key is pressed, we want to move focus\n // out of the entire toolbar. To do this, move focus\n // to the first or last focusable child, and let the\n // browser handle the Tab key as usual from there.\n lastFocused.current = getActiveElement() as HTMLElement;\n if (e.shiftKey) {\n focusManager.focusFirst();\n } else {\n focusManager.focusLast();\n }\n return;\n } else {\n // if we didn't handle anything, return early so we don't preventDefault\n return;\n }\n\n // Prevent arrow keys from being handled by nested action groups.\n e.stopPropagation();\n e.preventDefault();\n };\n\n // Record the last focused child when focus moves out of the toolbar.\n const lastFocused = useRef<HTMLElement | null>(null);\n const onBlur: FocusEventHandler<HTMLElement> = e => {\n if (!nodeContains(e.currentTarget, e.relatedTarget) && !lastFocused.current) {\n lastFocused.current = getEventTarget(e);\n }\n };\n\n // Restore focus to the last focused child when focus returns into the toolbar.\n // If the element was removed, do nothing, either the first item in the first group,\n // or the last item in the last group will be focused, depending on direction.\n const onFocus: FocusEventHandler<HTMLElement> = e => {\n if (\n lastFocused.current &&\n !nodeContains(e.currentTarget, e.relatedTarget) &&\n nodeContains(ref.current, getEventTarget(e))\n ) {\n lastFocused.current?.focus();\n lastFocused.current = null;\n }\n };\n\n return {\n toolbarProps: {\n ...filterDOMProps(props, {labelable: true}),\n role: !isInToolbar ? 'toolbar' : 'group',\n 'aria-orientation': orientation,\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabel == null ? ariaLabelledBy : undefined,\n onKeyDownCapture: !isInToolbar ? onKeyDown : undefined,\n onFocusCapture: !isInToolbar ? onFocus : undefined,\n onBlurCapture: !isInToolbar ? onBlur : undefined\n }\n };\n}\n"],"names":[],"version":3,"file":"useToolbar.mjs.map"}
@@ -1 +1 @@
1
- {"mappings":";;;;;;;;;;AAAA;;;;;;;;;;CAUC;;;AAwBM,SAAS,0CAAW,KAAuB,EAAE,KAA2B;IAC7E,IAAI,WAAW,CAAA,GAAA,wCAAa,EAAE,OAAO;QAAC,WAAW;IAAI;IAErD,IAAI,cAAC,UAAU,EAAC,GAAG,CAAA,GAAA,kCAAO,EAAE;QAC1B,cAAc,IAAM,OAAO,KAAK;QAChC,YAAY,IAAM,OAAO;IAC3B;IAEA,OAAO;QACL,cAAc,CAAA,GAAA,oCAAS,EAAE,UAAU,YAAY;YAC7C,MAAM;QACR;IACF;AACF","sources":["packages/react-aria/src/tooltip/useTooltip.ts"],"sourcesContent":["/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaLabelingProps, DOMAttributes, DOMProps} from '@react-types/shared';\nimport {filterDOMProps} from '../utils/filterDOMProps';\nimport {mergeProps} from '../utils/mergeProps';\nimport {TooltipTriggerState} from 'react-stately/useTooltipTriggerState';\nimport {useHover} from '../interactions/useHover';\n\nexport interface TooltipProps {\n isOpen?: boolean\n}\n\nexport interface AriaTooltipProps extends TooltipProps, DOMProps, AriaLabelingProps {}\n\nexport interface TooltipAria {\n /**\n * Props for the tooltip element.\n */\n tooltipProps: DOMAttributes\n}\n\n/**\n * Provides the accessibility implementation for a Tooltip component.\n */\nexport function useTooltip(props: AriaTooltipProps, state?: TooltipTriggerState): TooltipAria {\n let domProps = filterDOMProps(props, {labelable: true});\n\n let {hoverProps} = useHover({\n onHoverStart: () => state?.open(true),\n onHoverEnd: () => state?.close()\n });\n\n return {\n tooltipProps: mergeProps(domProps, hoverProps, {\n role: 'tooltip'\n })\n };\n}\n"],"names":[],"version":3,"file":"useTooltip.cjs.map"}
1
+ {"mappings":";;;;;;;;;;AAAA;;;;;;;;;;CAUC;;;AAwBM,SAAS,0CAAW,KAAuB,EAAE,KAA2B;IAC7E,IAAI,WAAW,CAAA,GAAA,wCAAa,EAAE,OAAO;QAAC,WAAW;IAAI;IAErD,IAAI,cAAC,UAAU,EAAC,GAAG,CAAA,GAAA,kCAAO,EAAE;QAC1B,cAAc,IAAM,OAAO,KAAK;QAChC,YAAY,IAAM,OAAO;IAC3B;IAEA,OAAO;QACL,cAAc,CAAA,GAAA,oCAAS,EAAE,UAAU,YAAY;YAC7C,MAAM;QACR;IACF;AACF","sources":["packages/react-aria/src/tooltip/useTooltip.ts"],"sourcesContent":["/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaLabelingProps, DOMAttributes, DOMProps} from '@react-types/shared';\nimport {filterDOMProps} from '../utils/filterDOMProps';\nimport {mergeProps} from '../utils/mergeProps';\nimport {TooltipTriggerState} from 'react-stately/useTooltipTriggerState';\nimport {useHover} from '../interactions/useHover';\n\nexport interface TooltipProps {\n isOpen?: boolean;\n}\n\nexport interface AriaTooltipProps extends TooltipProps, DOMProps, AriaLabelingProps {}\n\nexport interface TooltipAria {\n /**\n * Props for the tooltip element.\n */\n tooltipProps: DOMAttributes;\n}\n\n/**\n * Provides the accessibility implementation for a Tooltip component.\n */\nexport function useTooltip(props: AriaTooltipProps, state?: TooltipTriggerState): TooltipAria {\n let domProps = filterDOMProps(props, {labelable: true});\n\n let {hoverProps} = useHover({\n onHoverStart: () => state?.open(true),\n onHoverEnd: () => state?.close()\n });\n\n return {\n tooltipProps: mergeProps(domProps, hoverProps, {\n role: 'tooltip'\n })\n };\n}\n"],"names":[],"version":3,"file":"useTooltip.cjs.map"}
@@ -1 +1 @@
1
- {"mappings":";;;;AAAA;;;;;;;;;;CAUC;;;AAwBM,SAAS,0CAAW,KAAuB,EAAE,KAA2B;IAC7E,IAAI,WAAW,CAAA,GAAA,yCAAa,EAAE,OAAO;QAAC,WAAW;IAAI;IAErD,IAAI,cAAC,UAAU,EAAC,GAAG,CAAA,GAAA,yCAAO,EAAE;QAC1B,cAAc,IAAM,kBAAA,4BAAA,MAAO,IAAI,CAAC;QAChC,YAAY,IAAM,kBAAA,4BAAA,MAAO,KAAK;IAChC;IAEA,OAAO;QACL,cAAc,CAAA,GAAA,yCAAS,EAAE,UAAU,YAAY;YAC7C,MAAM;QACR;IACF;AACF","sources":["packages/react-aria/src/tooltip/useTooltip.ts"],"sourcesContent":["/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaLabelingProps, DOMAttributes, DOMProps} from '@react-types/shared';\nimport {filterDOMProps} from '../utils/filterDOMProps';\nimport {mergeProps} from '../utils/mergeProps';\nimport {TooltipTriggerState} from 'react-stately/useTooltipTriggerState';\nimport {useHover} from '../interactions/useHover';\n\nexport interface TooltipProps {\n isOpen?: boolean\n}\n\nexport interface AriaTooltipProps extends TooltipProps, DOMProps, AriaLabelingProps {}\n\nexport interface TooltipAria {\n /**\n * Props for the tooltip element.\n */\n tooltipProps: DOMAttributes\n}\n\n/**\n * Provides the accessibility implementation for a Tooltip component.\n */\nexport function useTooltip(props: AriaTooltipProps, state?: TooltipTriggerState): TooltipAria {\n let domProps = filterDOMProps(props, {labelable: true});\n\n let {hoverProps} = useHover({\n onHoverStart: () => state?.open(true),\n onHoverEnd: () => state?.close()\n });\n\n return {\n tooltipProps: mergeProps(domProps, hoverProps, {\n role: 'tooltip'\n })\n };\n}\n"],"names":[],"version":3,"file":"useTooltip.js.map"}
1
+ {"mappings":";;;;AAAA;;;;;;;;;;CAUC;;;AAwBM,SAAS,0CAAW,KAAuB,EAAE,KAA2B;IAC7E,IAAI,WAAW,CAAA,GAAA,yCAAa,EAAE,OAAO;QAAC,WAAW;IAAI;IAErD,IAAI,cAAC,UAAU,EAAC,GAAG,CAAA,GAAA,yCAAO,EAAE;QAC1B,cAAc,IAAM,kBAAA,4BAAA,MAAO,IAAI,CAAC;QAChC,YAAY,IAAM,kBAAA,4BAAA,MAAO,KAAK;IAChC;IAEA,OAAO;QACL,cAAc,CAAA,GAAA,yCAAS,EAAE,UAAU,YAAY;YAC7C,MAAM;QACR;IACF;AACF","sources":["packages/react-aria/src/tooltip/useTooltip.ts"],"sourcesContent":["/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaLabelingProps, DOMAttributes, DOMProps} from '@react-types/shared';\nimport {filterDOMProps} from '../utils/filterDOMProps';\nimport {mergeProps} from '../utils/mergeProps';\nimport {TooltipTriggerState} from 'react-stately/useTooltipTriggerState';\nimport {useHover} from '../interactions/useHover';\n\nexport interface TooltipProps {\n isOpen?: boolean;\n}\n\nexport interface AriaTooltipProps extends TooltipProps, DOMProps, AriaLabelingProps {}\n\nexport interface TooltipAria {\n /**\n * Props for the tooltip element.\n */\n tooltipProps: DOMAttributes;\n}\n\n/**\n * Provides the accessibility implementation for a Tooltip component.\n */\nexport function useTooltip(props: AriaTooltipProps, state?: TooltipTriggerState): TooltipAria {\n let domProps = filterDOMProps(props, {labelable: true});\n\n let {hoverProps} = useHover({\n onHoverStart: () => state?.open(true),\n onHoverEnd: () => state?.close()\n });\n\n return {\n tooltipProps: mergeProps(domProps, hoverProps, {\n role: 'tooltip'\n })\n };\n}\n"],"names":[],"version":3,"file":"useTooltip.js.map"}
@@ -1 +1 @@
1
- {"mappings":";;;;AAAA;;;;;;;;;;CAUC;;;AAwBM,SAAS,0CAAW,KAAuB,EAAE,KAA2B;IAC7E,IAAI,WAAW,CAAA,GAAA,yCAAa,EAAE,OAAO;QAAC,WAAW;IAAI;IAErD,IAAI,cAAC,UAAU,EAAC,GAAG,CAAA,GAAA,yCAAO,EAAE;QAC1B,cAAc,IAAM,OAAO,KAAK;QAChC,YAAY,IAAM,OAAO;IAC3B;IAEA,OAAO;QACL,cAAc,CAAA,GAAA,yCAAS,EAAE,UAAU,YAAY;YAC7C,MAAM;QACR;IACF;AACF","sources":["packages/react-aria/src/tooltip/useTooltip.ts"],"sourcesContent":["/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaLabelingProps, DOMAttributes, DOMProps} from '@react-types/shared';\nimport {filterDOMProps} from '../utils/filterDOMProps';\nimport {mergeProps} from '../utils/mergeProps';\nimport {TooltipTriggerState} from 'react-stately/useTooltipTriggerState';\nimport {useHover} from '../interactions/useHover';\n\nexport interface TooltipProps {\n isOpen?: boolean\n}\n\nexport interface AriaTooltipProps extends TooltipProps, DOMProps, AriaLabelingProps {}\n\nexport interface TooltipAria {\n /**\n * Props for the tooltip element.\n */\n tooltipProps: DOMAttributes\n}\n\n/**\n * Provides the accessibility implementation for a Tooltip component.\n */\nexport function useTooltip(props: AriaTooltipProps, state?: TooltipTriggerState): TooltipAria {\n let domProps = filterDOMProps(props, {labelable: true});\n\n let {hoverProps} = useHover({\n onHoverStart: () => state?.open(true),\n onHoverEnd: () => state?.close()\n });\n\n return {\n tooltipProps: mergeProps(domProps, hoverProps, {\n role: 'tooltip'\n })\n };\n}\n"],"names":[],"version":3,"file":"useTooltip.mjs.map"}
1
+ {"mappings":";;;;AAAA;;;;;;;;;;CAUC;;;AAwBM,SAAS,0CAAW,KAAuB,EAAE,KAA2B;IAC7E,IAAI,WAAW,CAAA,GAAA,yCAAa,EAAE,OAAO;QAAC,WAAW;IAAI;IAErD,IAAI,cAAC,UAAU,EAAC,GAAG,CAAA,GAAA,yCAAO,EAAE;QAC1B,cAAc,IAAM,OAAO,KAAK;QAChC,YAAY,IAAM,OAAO;IAC3B;IAEA,OAAO;QACL,cAAc,CAAA,GAAA,yCAAS,EAAE,UAAU,YAAY;YAC7C,MAAM;QACR;IACF;AACF","sources":["packages/react-aria/src/tooltip/useTooltip.ts"],"sourcesContent":["/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {AriaLabelingProps, DOMAttributes, DOMProps} from '@react-types/shared';\nimport {filterDOMProps} from '../utils/filterDOMProps';\nimport {mergeProps} from '../utils/mergeProps';\nimport {TooltipTriggerState} from 'react-stately/useTooltipTriggerState';\nimport {useHover} from '../interactions/useHover';\n\nexport interface TooltipProps {\n isOpen?: boolean;\n}\n\nexport interface AriaTooltipProps extends TooltipProps, DOMProps, AriaLabelingProps {}\n\nexport interface TooltipAria {\n /**\n * Props for the tooltip element.\n */\n tooltipProps: DOMAttributes;\n}\n\n/**\n * Provides the accessibility implementation for a Tooltip component.\n */\nexport function useTooltip(props: AriaTooltipProps, state?: TooltipTriggerState): TooltipAria {\n let domProps = filterDOMProps(props, {labelable: true});\n\n let {hoverProps} = useHover({\n onHoverStart: () => state?.open(true),\n onHoverEnd: () => state?.close()\n });\n\n return {\n tooltipProps: mergeProps(domProps, hoverProps, {\n role: 'tooltip'\n })\n };\n}\n"],"names":[],"version":3,"file":"useTooltip.mjs.map"}
@@ -1 +1 @@
1
- {"mappings":";;;;;;;;;;;;;AAAA;;;;;;;;;;CAUC;;;;;;AA2BM,SAAS,0CAAkB,KAA0B,EAAE,KAA0B,EAAE,GAAuC;IAC/H,IAAI,cACF,UAAU,WACV,OAAO,sBACP,qBAAqB,MACtB,GAAG;IAEJ,IAAI,YAAY,CAAA,GAAA,+BAAI;IAEpB,IAAI,YAAY,CAAA,GAAA,mBAAK,EAAE;IACvB,IAAI,YAAY,CAAA,GAAA,mBAAK,EAAE;IAEvB,IAAI,aAAa;QACf,IAAI,UAAU,OAAO,IAAI,UAAU,OAAO,EACxC,MAAM,IAAI,CAAC,UAAU,OAAO;IAEhC;IAEA,IAAI,aAAa,CAAC;QAChB,IAAI,CAAC,UAAU,OAAO,IAAI,CAAC,UAAU,OAAO,EAC1C,MAAM,KAAK,CAAC;IAEhB;IAEA,CAAA,GAAA,sBAAQ,EAAE;QACR,IAAI,YAAY,CAAC;YACf,IAAI,OAAO,IAAI,OAAO,EACpB,6DAA6D;YAC7D,mCAAmC;YACnC;gBAAA,IAAI,EAAE,GAAG,KAAK,UAAU;oBACtB,EAAE,eAAe;oBACjB,MAAM,KAAK,CAAC;gBACd;YAAA;QAEJ;QACA,IAAI,MAAM,MAAM,EAAE;YAChB,SAAS,gBAAgB,CAAC,WAAW,WAAW;YAChD,OAAO;gBACL,SAAS,mBAAmB,CAAC,WAAW,WAAW;YACrD;QACF;IACF,GAAG;QAAC;QAAK;KAAM;IAEf,IAAI,eAAe;QACjB,IAAI,YAAY,SACd;QAEF,uFAAuF;QACvF,kGAAkG;QAClG,uGAAuG;QACvG,qCAAqC;QACrC,IAAI,CAAA,GAAA,gDAAqB,QAAQ,WAC/B,UAAU,OAAO,GAAG;aAEpB,UAAU,OAAO,GAAG;QAEtB;IACF;IAEA,IAAI,aAAa;QACf,IAAI,YAAY,SACd;QAEF,iEAAiE;QACjE,UAAU,OAAO,GAAG;QACpB,UAAU,OAAO,GAAG;QACpB;IACF;IAEA,IAAI,eAAe;QACjB,kEAAkE;QAClE,IAAI,CAAC,oBACH;QAEF,oEAAoE;QACpE,UAAU,OAAO,GAAG;QACpB,UAAU,OAAO,GAAG;QACpB,WAAW;IACb;IAEA,IAAI,UAAU;QACZ,IAAI,YAAY,CAAA,GAAA,wCAAa;QAC7B,IAAI,WAAW;YACb,UAAU,OAAO,GAAG;YACpB;QACF;IACF;IAEA,IAAI,SAAS;QACX,UAAU,OAAO,GAAG;QACpB,UAAU,OAAO,GAAG;QACpB,WAAW;IACb;IAEA,IAAI,cAAC,UAAU,EAAC,GAAG,CAAA,GAAA,kCAAO,EAAE;oBAC1B;sBACA;oBACA;IACF;IAEA,IAAI,kBAAC,cAAc,EAAC,GAAG,CAAA,GAAA,sCAAW,EAAE;oBAClC;iBACA;gBACA;IACF,GAAG;IAEH,OAAO;QACL,cAAc;YACZ,oBAAoB,MAAM,MAAM,GAAG,YAAY;YAC/C,GAAG,CAAA,GAAA,oCAAS,EAAE,gBAAgB,YAAY;gBACxC,eAAe;gBACf,WAAW;YACb,EAAE;YACF,UAAU;QACZ;QACA,cAAc;YACZ,IAAI;QACN;IACF;AACF","sources":["packages/react-aria/src/tooltip/useTooltipTrigger.ts"],"sourcesContent":["/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {DOMAttributes, FocusableElement, RefObject} from '@react-types/shared';\nimport {getInteractionModality, isFocusVisible} from '../interactions/useFocusVisible';\nimport {mergeProps} from '../utils/mergeProps';\nimport {TooltipTriggerProps, TooltipTriggerState} from 'react-stately/useTooltipTriggerState';\nimport {useEffect, useRef} from 'react';\nimport {useFocusable} from '../interactions/useFocusable';\nimport {useHover} from '../interactions/useHover';\nimport {useId} from '../utils/useId';\n\nexport interface TooltipTriggerAria {\n /**\n * Props for the trigger element.\n */\n triggerProps: DOMAttributes,\n\n /**\n * Props for the overlay container element.\n */\n tooltipProps: DOMAttributes\n}\n\n/**\n * Provides the behavior and accessibility implementation for a tooltip trigger, e.g. a button\n * that shows a description when focused or hovered.\n */\nexport function useTooltipTrigger(props: TooltipTriggerProps, state: TooltipTriggerState, ref: RefObject<FocusableElement | null>) : TooltipTriggerAria {\n let {\n isDisabled,\n trigger,\n shouldCloseOnPress = true\n } = props;\n\n let tooltipId = useId();\n\n let isHovered = useRef(false);\n let isFocused = useRef(false);\n\n let handleShow = () => {\n if (isHovered.current || isFocused.current) {\n state.open(isFocused.current);\n }\n };\n\n let handleHide = (immediate?: boolean) => {\n if (!isHovered.current && !isFocused.current) {\n state.close(immediate);\n }\n };\n\n useEffect(() => {\n let onKeyDown = (e) => {\n if (ref && ref.current) {\n // Escape after clicking something can give it keyboard focus\n // dismiss tooltip on esc key press\n if (e.key === 'Escape') {\n e.stopPropagation();\n state.close(true);\n }\n }\n };\n if (state.isOpen) {\n document.addEventListener('keydown', onKeyDown, true);\n return () => {\n document.removeEventListener('keydown', onKeyDown, true);\n };\n }\n }, [ref, state]);\n\n let onHoverStart = () => {\n if (trigger === 'focus') {\n return;\n }\n // In chrome, if you hover a trigger, then another element obscures it, due to keyboard\n // interactions for example, hover will end. When hover is restored after that element disappears,\n // focus moves on for example, then the tooltip will reopen. We check the modality to know if the hover\n // is the result of moving the mouse.\n if (getInteractionModality() === 'pointer') {\n isHovered.current = true;\n } else {\n isHovered.current = false;\n }\n handleShow();\n };\n\n let onHoverEnd = () => {\n if (trigger === 'focus') {\n return;\n }\n // no matter how the trigger is left, we should close the tooltip\n isFocused.current = false;\n isHovered.current = false;\n handleHide();\n };\n\n let onPressStart = () => {\n // if shouldCloseOnPress is false, we should not close the tooltip\n if (!shouldCloseOnPress) {\n return;\n }\n // no matter how the trigger is pressed, we should close the tooltip\n isFocused.current = false;\n isHovered.current = false;\n handleHide(true);\n };\n\n let onFocus = () => {\n let isVisible = isFocusVisible();\n if (isVisible) {\n isFocused.current = true;\n handleShow();\n }\n };\n\n let onBlur = () => {\n isFocused.current = false;\n isHovered.current = false;\n handleHide(true);\n };\n\n let {hoverProps} = useHover({\n isDisabled,\n onHoverStart,\n onHoverEnd\n });\n\n let {focusableProps} = useFocusable({\n isDisabled,\n onFocus,\n onBlur\n }, ref);\n\n return {\n triggerProps: {\n 'aria-describedby': state.isOpen ? tooltipId : undefined,\n ...mergeProps(focusableProps, hoverProps, {\n onPointerDown: onPressStart,\n onKeyDown: onPressStart\n }),\n tabIndex: undefined\n },\n tooltipProps: {\n id: tooltipId\n }\n };\n}\n"],"names":[],"version":3,"file":"useTooltipTrigger.cjs.map"}
1
+ {"mappings":";;;;;;;;;;;;;AAAA;;;;;;;;;;CAUC;;;;;;AA2BM,SAAS,0CACd,KAA0B,EAC1B,KAA0B,EAC1B,GAAuC;IAEvC,IAAI,cAAC,UAAU,WAAE,OAAO,sBAAE,qBAAqB,MAAK,GAAG;IAEvD,IAAI,YAAY,CAAA,GAAA,+BAAI;IAEpB,IAAI,YAAY,CAAA,GAAA,mBAAK,EAAE;IACvB,IAAI,YAAY,CAAA,GAAA,mBAAK,EAAE;IAEvB,IAAI,aAAa;QACf,IAAI,UAAU,OAAO,IAAI,UAAU,OAAO,EACxC,MAAM,IAAI,CAAC,UAAU,OAAO;IAEhC;IAEA,IAAI,aAAa,CAAC;QAChB,IAAI,CAAC,UAAU,OAAO,IAAI,CAAC,UAAU,OAAO,EAC1C,MAAM,KAAK,CAAC;IAEhB;IAEA,CAAA,GAAA,sBAAQ,EAAE;QACR,IAAI,YAAY,CAAA;YACd,IAAI,OAAO,IAAI,OAAO,EACpB,6DAA6D;YAC7D,mCAAmC;YACnC;gBAAA,IAAI,EAAE,GAAG,KAAK,UAAU;oBACtB,EAAE,eAAe;oBACjB,MAAM,KAAK,CAAC;gBACd;YAAA;QAEJ;QACA,IAAI,MAAM,MAAM,EAAE;YAChB,SAAS,gBAAgB,CAAC,WAAW,WAAW;YAChD,OAAO;gBACL,SAAS,mBAAmB,CAAC,WAAW,WAAW;YACrD;QACF;IACF,GAAG;QAAC;QAAK;KAAM;IAEf,IAAI,eAAe;QACjB,IAAI,YAAY,SACd;QAEF,uFAAuF;QACvF,kGAAkG;QAClG,uGAAuG;QACvG,qCAAqC;QACrC,IAAI,CAAA,GAAA,gDAAqB,QAAQ,WAC/B,UAAU,OAAO,GAAG;aAEpB,UAAU,OAAO,GAAG;QAEtB;IACF;IAEA,IAAI,aAAa;QACf,IAAI,YAAY,SACd;QAEF,iEAAiE;QACjE,UAAU,OAAO,GAAG;QACpB,UAAU,OAAO,GAAG;QACpB;IACF;IAEA,IAAI,eAAe;QACjB,kEAAkE;QAClE,IAAI,CAAC,oBACH;QAEF,oEAAoE;QACpE,UAAU,OAAO,GAAG;QACpB,UAAU,OAAO,GAAG;QACpB,WAAW;IACb;IAEA,IAAI,UAAU;QACZ,IAAI,YAAY,CAAA,GAAA,wCAAa;QAC7B,IAAI,WAAW;YACb,UAAU,OAAO,GAAG;YACpB;QACF;IACF;IAEA,IAAI,SAAS;QACX,UAAU,OAAO,GAAG;QACpB,UAAU,OAAO,GAAG;QACpB,WAAW;IACb;IAEA,IAAI,cAAC,UAAU,EAAC,GAAG,CAAA,GAAA,kCAAO,EAAE;oBAC1B;sBACA;oBACA;IACF;IAEA,IAAI,kBAAC,cAAc,EAAC,GAAG,CAAA,GAAA,sCAAW,EAChC;oBACE;iBACA;gBACA;IACF,GACA;IAGF,OAAO;QACL,cAAc;YACZ,oBAAoB,MAAM,MAAM,GAAG,YAAY;YAC/C,GAAG,CAAA,GAAA,oCAAS,EAAE,gBAAgB,YAAY;gBACxC,eAAe;gBACf,WAAW;YACb,EAAE;YACF,UAAU;QACZ;QACA,cAAc;YACZ,IAAI;QACN;IACF;AACF","sources":["packages/react-aria/src/tooltip/useTooltipTrigger.ts"],"sourcesContent":["/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nimport {DOMAttributes, FocusableElement, RefObject} from '@react-types/shared';\nimport {getInteractionModality, isFocusVisible} from '../interactions/useFocusVisible';\nimport {mergeProps} from '../utils/mergeProps';\nimport {TooltipTriggerProps, TooltipTriggerState} from 'react-stately/useTooltipTriggerState';\nimport {useEffect, useRef} from 'react';\nimport {useFocusable} from '../interactions/useFocusable';\nimport {useHover} from '../interactions/useHover';\nimport {useId} from '../utils/useId';\n\nexport interface TooltipTriggerAria {\n /**\n * Props for the trigger element.\n */\n triggerProps: DOMAttributes;\n\n /**\n * Props for the overlay container element.\n */\n tooltipProps: DOMAttributes;\n}\n\n/**\n * Provides the behavior and accessibility implementation for a tooltip trigger, e.g. a button\n * that shows a description when focused or hovered.\n */\nexport function useTooltipTrigger(\n props: TooltipTriggerProps,\n state: TooltipTriggerState,\n ref: RefObject<FocusableElement | null>\n): TooltipTriggerAria {\n let {isDisabled, trigger, shouldCloseOnPress = true} = props;\n\n let tooltipId = useId();\n\n let isHovered = useRef(false);\n let isFocused = useRef(false);\n\n let handleShow = () => {\n if (isHovered.current || isFocused.current) {\n state.open(isFocused.current);\n }\n };\n\n let handleHide = (immediate?: boolean) => {\n if (!isHovered.current && !isFocused.current) {\n state.close(immediate);\n }\n };\n\n useEffect(() => {\n let onKeyDown = e => {\n if (ref && ref.current) {\n // Escape after clicking something can give it keyboard focus\n // dismiss tooltip on esc key press\n if (e.key === 'Escape') {\n e.stopPropagation();\n state.close(true);\n }\n }\n };\n if (state.isOpen) {\n document.addEventListener('keydown', onKeyDown, true);\n return () => {\n document.removeEventListener('keydown', onKeyDown, true);\n };\n }\n }, [ref, state]);\n\n let onHoverStart = () => {\n if (trigger === 'focus') {\n return;\n }\n // In chrome, if you hover a trigger, then another element obscures it, due to keyboard\n // interactions for example, hover will end. When hover is restored after that element disappears,\n // focus moves on for example, then the tooltip will reopen. We check the modality to know if the hover\n // is the result of moving the mouse.\n if (getInteractionModality() === 'pointer') {\n isHovered.current = true;\n } else {\n isHovered.current = false;\n }\n handleShow();\n };\n\n let onHoverEnd = () => {\n if (trigger === 'focus') {\n return;\n }\n // no matter how the trigger is left, we should close the tooltip\n isFocused.current = false;\n isHovered.current = false;\n handleHide();\n };\n\n let onPressStart = () => {\n // if shouldCloseOnPress is false, we should not close the tooltip\n if (!shouldCloseOnPress) {\n return;\n }\n // no matter how the trigger is pressed, we should close the tooltip\n isFocused.current = false;\n isHovered.current = false;\n handleHide(true);\n };\n\n let onFocus = () => {\n let isVisible = isFocusVisible();\n if (isVisible) {\n isFocused.current = true;\n handleShow();\n }\n };\n\n let onBlur = () => {\n isFocused.current = false;\n isHovered.current = false;\n handleHide(true);\n };\n\n let {hoverProps} = useHover({\n isDisabled,\n onHoverStart,\n onHoverEnd\n });\n\n let {focusableProps} = useFocusable(\n {\n isDisabled,\n onFocus,\n onBlur\n },\n ref\n );\n\n return {\n triggerProps: {\n 'aria-describedby': state.isOpen ? tooltipId : undefined,\n ...mergeProps(focusableProps, hoverProps, {\n onPointerDown: onPressStart,\n onKeyDown: onPressStart\n }),\n tabIndex: undefined\n },\n tooltipProps: {\n id: tooltipId\n }\n };\n}\n"],"names":[],"version":3,"file":"useTooltipTrigger.cjs.map"}