@salt-ds/lab 1.0.0-alpha.54 → 1.0.0-alpha.55

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 (1216) hide show
  1. package/CHANGELOG.md +1895 -0
  2. package/css/salt-lab.css +211 -51
  3. package/dist-cjs/app-header/AppHeader.js +9 -8
  4. package/dist-cjs/app-header/AppHeader.js.map +1 -1
  5. package/dist-cjs/breadcrumbs/Breadcrumb.js +43 -43
  6. package/dist-cjs/breadcrumbs/Breadcrumb.js.map +1 -1
  7. package/dist-cjs/breadcrumbs/Breadcrumbs.js +28 -33
  8. package/dist-cjs/breadcrumbs/Breadcrumbs.js.map +1 -1
  9. package/dist-cjs/breadcrumbs/internal/BreadcrumbsCollapsed.js +19 -16
  10. package/dist-cjs/breadcrumbs/internal/BreadcrumbsCollapsed.js.map +1 -1
  11. package/dist-cjs/breadcrumbs/internal/BreadcrumbsContext.js +0 -2
  12. package/dist-cjs/breadcrumbs/internal/BreadcrumbsContext.js.map +1 -1
  13. package/dist-cjs/breadcrumbs/internal/BreadcrumbsSeparator.js +1 -5
  14. package/dist-cjs/breadcrumbs/internal/BreadcrumbsSeparator.js.map +1 -1
  15. package/dist-cjs/breadcrumbs/internal/useFocusMenuRemount.js +0 -2
  16. package/dist-cjs/breadcrumbs/internal/useFocusMenuRemount.js.map +1 -1
  17. package/dist-cjs/button-bar/ButtonBar.js +20 -27
  18. package/dist-cjs/button-bar/ButtonBar.js.map +1 -1
  19. package/dist-cjs/button-bar/OrderedButton.js +16 -15
  20. package/dist-cjs/button-bar/OrderedButton.js.map +1 -1
  21. package/dist-cjs/button-bar/internal/ButtonBarContext.js +0 -2
  22. package/dist-cjs/button-bar/internal/ButtonBarContext.js.map +1 -1
  23. package/dist-cjs/button-bar/internal/DescendantContext.js +1 -6
  24. package/dist-cjs/button-bar/internal/DescendantContext.js.map +1 -1
  25. package/dist-cjs/button-bar/internal/useDescendant.js +0 -2
  26. package/dist-cjs/button-bar/internal/useDescendant.js.map +1 -1
  27. package/dist-cjs/button-bar/internal/useDescendants.js +0 -2
  28. package/dist-cjs/button-bar/internal/useDescendants.js.map +1 -1
  29. package/dist-cjs/calendar/Calendar.js +20 -16
  30. package/dist-cjs/calendar/Calendar.js.map +1 -1
  31. package/dist-cjs/calendar/CalendarDateGrid.js +34 -29
  32. package/dist-cjs/calendar/CalendarDateGrid.js.map +1 -1
  33. package/dist-cjs/calendar/CalendarNavigation.js +103 -96
  34. package/dist-cjs/calendar/CalendarNavigation.js.map +1 -1
  35. package/dist-cjs/calendar/CalendarWeekHeader.js +18 -13
  36. package/dist-cjs/calendar/CalendarWeekHeader.js.map +1 -1
  37. package/dist-cjs/calendar/formatDate.js +3 -8
  38. package/dist-cjs/calendar/formatDate.js.map +1 -1
  39. package/dist-cjs/calendar/internal/CalendarContext.js +0 -2
  40. package/dist-cjs/calendar/internal/CalendarContext.js.map +1 -1
  41. package/dist-cjs/calendar/internal/CalendarDay.js +48 -41
  42. package/dist-cjs/calendar/internal/CalendarDay.js.map +1 -1
  43. package/dist-cjs/calendar/internal/CalendarMonth.js +28 -20
  44. package/dist-cjs/calendar/internal/CalendarMonth.js.map +1 -1
  45. package/dist-cjs/calendar/internal/useFocusManagement.js +0 -2
  46. package/dist-cjs/calendar/internal/useFocusManagement.js.map +1 -1
  47. package/dist-cjs/calendar/internal/utils.js +0 -2
  48. package/dist-cjs/calendar/internal/utils.js.map +1 -1
  49. package/dist-cjs/calendar/useCalendar.js +3 -4
  50. package/dist-cjs/calendar/useCalendar.js.map +1 -1
  51. package/dist-cjs/calendar/useCalendarDay.js +0 -2
  52. package/dist-cjs/calendar/useCalendarDay.js.map +1 -1
  53. package/dist-cjs/calendar/useCalendarSelection.js +2 -2
  54. package/dist-cjs/calendar/useCalendarSelection.js.map +1 -1
  55. package/dist-cjs/carousel/Carousel.js +59 -56
  56. package/dist-cjs/carousel/Carousel.js.map +1 -1
  57. package/dist-cjs/carousel/CarouselSlide.js +35 -38
  58. package/dist-cjs/carousel/CarouselSlide.js.map +1 -1
  59. package/dist-cjs/cascading-menu/CascadingMenu.js +15 -15
  60. package/dist-cjs/cascading-menu/CascadingMenu.js.map +1 -1
  61. package/dist-cjs/cascading-menu/CascadingMenuItem.js +72 -61
  62. package/dist-cjs/cascading-menu/CascadingMenuItem.js.map +1 -1
  63. package/dist-cjs/cascading-menu/CascadingMenuList.js +50 -43
  64. package/dist-cjs/cascading-menu/CascadingMenuList.js.map +1 -1
  65. package/dist-cjs/cascading-menu/internal/CascadingMenuAction.js +0 -2
  66. package/dist-cjs/cascading-menu/internal/CascadingMenuAction.js.map +1 -1
  67. package/dist-cjs/cascading-menu/internal/keydownHandlers.js +0 -2
  68. package/dist-cjs/cascading-menu/internal/keydownHandlers.js.map +1 -1
  69. package/dist-cjs/cascading-menu/internal/menuPositioning.js +0 -2
  70. package/dist-cjs/cascading-menu/internal/menuPositioning.js.map +1 -1
  71. package/dist-cjs/cascading-menu/internal/stateUtils.js +1 -2
  72. package/dist-cjs/cascading-menu/internal/stateUtils.js.map +1 -1
  73. package/dist-cjs/cascading-menu/internal/useClickAway.js +4 -3
  74. package/dist-cjs/cascading-menu/internal/useClickAway.js.map +1 -1
  75. package/dist-cjs/cascading-menu/internal/useMenuTriggerHandlers.js +0 -2
  76. package/dist-cjs/cascading-menu/internal/useMenuTriggerHandlers.js.map +1 -1
  77. package/dist-cjs/cascading-menu/internal/useMountedRef.js +0 -2
  78. package/dist-cjs/cascading-menu/internal/useMountedRef.js.map +1 -1
  79. package/dist-cjs/cascading-menu/internal/useMouseHandlers.js +2 -5
  80. package/dist-cjs/cascading-menu/internal/useMouseHandlers.js.map +1 -1
  81. package/dist-cjs/cascading-menu/internal/useRefsManager.js +0 -2
  82. package/dist-cjs/cascading-menu/internal/useRefsManager.js.map +1 -1
  83. package/dist-cjs/cascading-menu/internal/useStateReducer.js +0 -2
  84. package/dist-cjs/cascading-menu/internal/useStateReducer.js.map +1 -1
  85. package/dist-cjs/cascading-menu/stateChangeTypes.js +0 -2
  86. package/dist-cjs/cascading-menu/stateChangeTypes.js.map +1 -1
  87. package/dist-cjs/color-chooser/AlphaInputField.js +17 -15
  88. package/dist-cjs/color-chooser/AlphaInputField.js.map +1 -1
  89. package/dist-cjs/color-chooser/Color.js +4 -9
  90. package/dist-cjs/color-chooser/Color.js.map +1 -1
  91. package/dist-cjs/color-chooser/ColorChooser.js +58 -60
  92. package/dist-cjs/color-chooser/ColorChooser.js.map +1 -1
  93. package/dist-cjs/color-chooser/ColorHelpers.js +5 -11
  94. package/dist-cjs/color-chooser/ColorHelpers.js.map +1 -1
  95. package/dist-cjs/color-chooser/ColorPicker.js +33 -49
  96. package/dist-cjs/color-chooser/ColorPicker.js.map +1 -1
  97. package/dist-cjs/color-chooser/DictTabs.js +24 -23
  98. package/dist-cjs/color-chooser/DictTabs.js.map +1 -1
  99. package/dist-cjs/color-chooser/GetColorPalettes.js +1 -3
  100. package/dist-cjs/color-chooser/GetColorPalettes.js.map +1 -1
  101. package/dist-cjs/color-chooser/HexInput.js +9 -15
  102. package/dist-cjs/color-chooser/HexInput.js.map +1 -1
  103. package/dist-cjs/color-chooser/RGBAInput.js +24 -39
  104. package/dist-cjs/color-chooser/RGBAInput.js.map +1 -1
  105. package/dist-cjs/color-chooser/RGBAInputField.js +14 -12
  106. package/dist-cjs/color-chooser/RGBAInputField.js.map +1 -1
  107. package/dist-cjs/color-chooser/Swatch.js +19 -18
  108. package/dist-cjs/color-chooser/Swatch.js.map +1 -1
  109. package/dist-cjs/color-chooser/Swatches.js +27 -43
  110. package/dist-cjs/color-chooser/Swatches.js.map +1 -1
  111. package/dist-cjs/color-chooser/SwatchesPicker.js +26 -20
  112. package/dist-cjs/color-chooser/SwatchesPicker.js.map +1 -1
  113. package/dist-cjs/color-chooser/color-utils.js +0 -2
  114. package/dist-cjs/color-chooser/color-utils.js.map +1 -1
  115. package/dist-cjs/color-chooser/colorMap.js +1 -2
  116. package/dist-cjs/color-chooser/colorMap.js.map +1 -1
  117. package/dist-cjs/color-chooser/createTabsMapping.js +0 -2
  118. package/dist-cjs/color-chooser/createTabsMapping.js.map +1 -1
  119. package/dist-cjs/combo-box/ComboBox.js +29 -25
  120. package/dist-cjs/combo-box/ComboBox.js.map +1 -1
  121. package/dist-cjs/combo-box/useCombobox.js +16 -15
  122. package/dist-cjs/combo-box/useCombobox.js.map +1 -1
  123. package/dist-cjs/combo-box-deprecated/ComboBoxDeprecated.js +37 -33
  124. package/dist-cjs/combo-box-deprecated/ComboBoxDeprecated.js.map +1 -1
  125. package/dist-cjs/combo-box-deprecated/filterHelpers.js +0 -2
  126. package/dist-cjs/combo-box-deprecated/filterHelpers.js.map +1 -1
  127. package/dist-cjs/combo-box-deprecated/internal/DefaultComboBox.js +37 -37
  128. package/dist-cjs/combo-box-deprecated/internal/DefaultComboBox.js.map +1 -1
  129. package/dist-cjs/combo-box-deprecated/internal/MultiSelectComboBox.js +37 -37
  130. package/dist-cjs/combo-box-deprecated/internal/MultiSelectComboBox.js.map +1 -1
  131. package/dist-cjs/combo-box-deprecated/internal/getAnnouncement.js +1 -3
  132. package/dist-cjs/combo-box-deprecated/internal/getAnnouncement.js.map +1 -1
  133. package/dist-cjs/combo-box-deprecated/internal/useComboBox.js +0 -2
  134. package/dist-cjs/combo-box-deprecated/internal/useComboBox.js.map +1 -1
  135. package/dist-cjs/combo-box-deprecated/internal/useMultiSelectComboBox.js +0 -2
  136. package/dist-cjs/combo-box-deprecated/internal/useMultiSelectComboBox.js.map +1 -1
  137. package/dist-cjs/combo-box-deprecated/internal/usePopperStatus.js +0 -2
  138. package/dist-cjs/combo-box-deprecated/internal/usePopperStatus.js.map +1 -1
  139. package/dist-cjs/common-hooks/calcPreferredHeight.js +2 -3
  140. package/dist-cjs/common-hooks/calcPreferredHeight.js.map +1 -1
  141. package/dist-cjs/common-hooks/collectionProvider.js +1 -6
  142. package/dist-cjs/common-hooks/collectionProvider.js.map +1 -1
  143. package/dist-cjs/common-hooks/itemToString.js +0 -2
  144. package/dist-cjs/common-hooks/itemToString.js.map +1 -1
  145. package/dist-cjs/common-hooks/keyUtils.js +0 -2
  146. package/dist-cjs/common-hooks/keyUtils.js.map +1 -1
  147. package/dist-cjs/common-hooks/list-dom-utils.js +0 -2
  148. package/dist-cjs/common-hooks/list-dom-utils.js.map +1 -1
  149. package/dist-cjs/common-hooks/selectionTypes.js +0 -2
  150. package/dist-cjs/common-hooks/selectionTypes.js.map +1 -1
  151. package/dist-cjs/common-hooks/useAutoSizer.js +0 -2
  152. package/dist-cjs/common-hooks/useAutoSizer.js.map +1 -1
  153. package/dist-cjs/common-hooks/useCollapsibleGroups.js +0 -2
  154. package/dist-cjs/common-hooks/useCollapsibleGroups.js.map +1 -1
  155. package/dist-cjs/common-hooks/useCollectionItems.js +21 -12
  156. package/dist-cjs/common-hooks/useCollectionItems.js.map +1 -1
  157. package/dist-cjs/common-hooks/useImperativeScrollingAPI.js +0 -2
  158. package/dist-cjs/common-hooks/useImperativeScrollingAPI.js.map +1 -1
  159. package/dist-cjs/common-hooks/useKeyboardNavigation.js +2 -3
  160. package/dist-cjs/common-hooks/useKeyboardNavigation.js.map +1 -1
  161. package/dist-cjs/common-hooks/useKeyboardNavigationPanel.js +3 -2
  162. package/dist-cjs/common-hooks/useKeyboardNavigationPanel.js.map +1 -1
  163. package/dist-cjs/common-hooks/useSelection.js +3 -7
  164. package/dist-cjs/common-hooks/useSelection.js.map +1 -1
  165. package/dist-cjs/common-hooks/useTypeahead.js +0 -2
  166. package/dist-cjs/common-hooks/useTypeahead.js.map +1 -1
  167. package/dist-cjs/common-hooks/useViewportTracking.js +0 -2
  168. package/dist-cjs/common-hooks/useViewportTracking.js.map +1 -1
  169. package/dist-cjs/common-hooks/utils/collection-item-utils.js +2 -4
  170. package/dist-cjs/common-hooks/utils/collection-item-utils.js.map +1 -1
  171. package/dist-cjs/common-hooks/utils/filter-utils.js +0 -2
  172. package/dist-cjs/common-hooks/utils/filter-utils.js.map +1 -1
  173. package/dist-cjs/common-hooks/utils/isSelected.js +0 -2
  174. package/dist-cjs/common-hooks/utils/isSelected.js.map +1 -1
  175. package/dist-cjs/contact-details/ContactAction.js +9 -13
  176. package/dist-cjs/contact-details/ContactAction.js.map +1 -1
  177. package/dist-cjs/contact-details/ContactActions.js +1 -8
  178. package/dist-cjs/contact-details/ContactActions.js.map +1 -1
  179. package/dist-cjs/contact-details/ContactAvatar.js +17 -16
  180. package/dist-cjs/contact-details/ContactAvatar.js.map +1 -1
  181. package/dist-cjs/contact-details/ContactDetails.js +6 -10
  182. package/dist-cjs/contact-details/ContactDetails.js.map +1 -1
  183. package/dist-cjs/contact-details/ContactFavoriteToggle.js +13 -12
  184. package/dist-cjs/contact-details/ContactFavoriteToggle.js.map +1 -1
  185. package/dist-cjs/contact-details/ContactMetadata.js +13 -13
  186. package/dist-cjs/contact-details/ContactMetadata.js.map +1 -1
  187. package/dist-cjs/contact-details/ContactMetadataItem.js +5 -23
  188. package/dist-cjs/contact-details/ContactMetadataItem.js.map +1 -1
  189. package/dist-cjs/contact-details/ContactPrimaryInfo.js +16 -15
  190. package/dist-cjs/contact-details/ContactPrimaryInfo.js.map +1 -1
  191. package/dist-cjs/contact-details/ContactSecondaryInfo.js +16 -17
  192. package/dist-cjs/contact-details/ContactSecondaryInfo.js.map +1 -1
  193. package/dist-cjs/contact-details/ContactTertiaryInfo.js +16 -17
  194. package/dist-cjs/contact-details/ContactTertiaryInfo.js.map +1 -1
  195. package/dist-cjs/contact-details/MailLinkComponent.js +1 -12
  196. package/dist-cjs/contact-details/MailLinkComponent.js.map +1 -1
  197. package/dist-cjs/contact-details/internal/ContactDetailsContext.js +0 -2
  198. package/dist-cjs/contact-details/internal/ContactDetailsContext.js.map +1 -1
  199. package/dist-cjs/contact-details/internal/FavoriteToggle.js +18 -17
  200. package/dist-cjs/contact-details/internal/FavoriteToggle.js.map +1 -1
  201. package/dist-cjs/contact-details/internal/FavoriteToggleWithTooltip.js +1 -11
  202. package/dist-cjs/contact-details/internal/FavoriteToggleWithTooltip.js.map +1 -1
  203. package/dist-cjs/contact-details/internal/StarIcon.js +10 -14
  204. package/dist-cjs/contact-details/internal/StarIcon.js.map +1 -1
  205. package/dist-cjs/contact-details/internal/StarIconContainer.js +28 -24
  206. package/dist-cjs/contact-details/internal/StarIconContainer.js.map +1 -1
  207. package/dist-cjs/contact-details/internal/useComponentSize.js +0 -2
  208. package/dist-cjs/contact-details/internal/useComponentSize.js.map +1 -1
  209. package/dist-cjs/content-status/ContentStatus.js +16 -31
  210. package/dist-cjs/content-status/ContentStatus.js.map +1 -1
  211. package/dist-cjs/content-status/internal/StatusIndicator.js +30 -23
  212. package/dist-cjs/content-status/internal/StatusIndicator.js.map +1 -1
  213. package/dist-cjs/date-input/DateInputRange.js +91 -96
  214. package/dist-cjs/date-input/DateInputRange.js.map +1 -1
  215. package/dist-cjs/date-input/DateInputSingle.js +55 -58
  216. package/dist-cjs/date-input/DateInputSingle.js.map +1 -1
  217. package/dist-cjs/date-input/utils.js +0 -2
  218. package/dist-cjs/date-input/utils.js.map +1 -1
  219. package/dist-cjs/date-picker/DatePicker.js +3 -26
  220. package/dist-cjs/date-picker/DatePicker.js.map +1 -1
  221. package/dist-cjs/date-picker/DatePickerActions.js +13 -23
  222. package/dist-cjs/date-picker/DatePickerActions.js.map +1 -1
  223. package/dist-cjs/date-picker/DatePickerContext.js +0 -2
  224. package/dist-cjs/date-picker/DatePickerContext.js.map +1 -1
  225. package/dist-cjs/date-picker/DatePickerOverlay.js +18 -17
  226. package/dist-cjs/date-picker/DatePickerOverlay.js.map +1 -1
  227. package/dist-cjs/date-picker/DatePickerOverlayProvider.js +3 -8
  228. package/dist-cjs/date-picker/DatePickerOverlayProvider.js.map +1 -1
  229. package/dist-cjs/date-picker/DatePickerRangeInput.js +29 -25
  230. package/dist-cjs/date-picker/DatePickerRangeInput.js.map +1 -1
  231. package/dist-cjs/date-picker/DatePickerRangePanel.js +25 -59
  232. package/dist-cjs/date-picker/DatePickerRangePanel.js.map +1 -1
  233. package/dist-cjs/date-picker/DatePickerSingleInput.js +32 -28
  234. package/dist-cjs/date-picker/DatePickerSingleInput.js.map +1 -1
  235. package/dist-cjs/date-picker/DatePickerSinglePanel.js +19 -49
  236. package/dist-cjs/date-picker/DatePickerSinglePanel.js.map +1 -1
  237. package/dist-cjs/date-picker/useDatePicker.js +2 -4
  238. package/dist-cjs/date-picker/useDatePicker.js.map +1 -1
  239. package/dist-cjs/deck-item/DeckItem.js +21 -18
  240. package/dist-cjs/deck-item/DeckItem.js.map +1 -1
  241. package/dist-cjs/deck-layout/DeckLayout.js +34 -27
  242. package/dist-cjs/deck-layout/DeckLayout.js.map +1 -1
  243. package/dist-cjs/dialog/DialogHeader.css.js +6 -0
  244. package/dist-cjs/dialog/DialogHeader.css.js.map +1 -0
  245. package/dist-cjs/dialog/DialogHeader.js +63 -0
  246. package/dist-cjs/dialog/DialogHeader.js.map +1 -0
  247. package/dist-cjs/dropdown/Dropdown.js +28 -24
  248. package/dist-cjs/dropdown/Dropdown.js.map +1 -1
  249. package/dist-cjs/dropdown/DropdownBase.js +29 -29
  250. package/dist-cjs/dropdown/DropdownBase.js.map +1 -1
  251. package/dist-cjs/dropdown/DropdownButton.js +40 -36
  252. package/dist-cjs/dropdown/DropdownButton.js.map +1 -1
  253. package/dist-cjs/dropdown/useClickAway.js +0 -2
  254. package/dist-cjs/dropdown/useClickAway.js.map +1 -1
  255. package/dist-cjs/dropdown/useDropdown.js +2 -4
  256. package/dist-cjs/dropdown/useDropdown.js.map +1 -1
  257. package/dist-cjs/dropdown/useDropdownBase.js +3 -5
  258. package/dist-cjs/dropdown/useDropdownBase.js.map +1 -1
  259. package/dist-cjs/editable-label/EditableLabel.js +23 -19
  260. package/dist-cjs/editable-label/EditableLabel.js.map +1 -1
  261. package/dist-cjs/form-field-context-legacy/FormFieldLegacyContext.js +0 -2
  262. package/dist-cjs/form-field-context-legacy/FormFieldLegacyContext.js.map +1 -1
  263. package/dist-cjs/form-field-context-legacy/useFormFieldLegacyProps.js +0 -2
  264. package/dist-cjs/form-field-context-legacy/useFormFieldLegacyProps.js.map +1 -1
  265. package/dist-cjs/form-field-legacy/FormActivationIndicator.js +29 -38
  266. package/dist-cjs/form-field-legacy/FormActivationIndicator.js.map +1 -1
  267. package/dist-cjs/form-field-legacy/FormFieldLegacy.js +53 -44
  268. package/dist-cjs/form-field-legacy/FormFieldLegacy.js.map +1 -1
  269. package/dist-cjs/form-field-legacy/FormHelperText.js +1 -7
  270. package/dist-cjs/form-field-legacy/FormHelperText.js.map +1 -1
  271. package/dist-cjs/form-field-legacy/FormLabel.js +34 -24
  272. package/dist-cjs/form-field-legacy/FormLabel.js.map +1 -1
  273. package/dist-cjs/form-field-legacy/NecessityIndicator.js +9 -8
  274. package/dist-cjs/form-field-legacy/NecessityIndicator.js.map +1 -1
  275. package/dist-cjs/form-field-legacy/StatusIndicator.js +22 -18
  276. package/dist-cjs/form-field-legacy/StatusIndicator.js.map +1 -1
  277. package/dist-cjs/form-field-legacy/constant.js +0 -2
  278. package/dist-cjs/form-field-legacy/constant.js.map +1 -1
  279. package/dist-cjs/form-group/FormGroup.js +8 -7
  280. package/dist-cjs/form-group/FormGroup.js.map +1 -1
  281. package/dist-cjs/formatted-input/FormattedInput.js +13 -12
  282. package/dist-cjs/formatted-input/FormattedInput.js.map +1 -1
  283. package/dist-cjs/formatted-input/internal/InputWithMask.js +13 -14
  284. package/dist-cjs/formatted-input/internal/InputWithMask.js.map +1 -1
  285. package/dist-cjs/index.js +14 -4
  286. package/dist-cjs/index.js.map +1 -1
  287. package/dist-cjs/input-legacy/InputLegacy.js +48 -47
  288. package/dist-cjs/input-legacy/InputLegacy.js.map +1 -1
  289. package/dist-cjs/input-legacy/StaticInputAdornment.js +1 -8
  290. package/dist-cjs/input-legacy/StaticInputAdornment.js.map +1 -1
  291. package/dist-cjs/input-legacy/useCursorOnFocus.js +0 -2
  292. package/dist-cjs/input-legacy/useCursorOnFocus.js.map +1 -1
  293. package/dist-cjs/layer-layout/LayerLayout.js +34 -30
  294. package/dist-cjs/layer-layout/LayerLayout.js.map +1 -1
  295. package/dist-cjs/list/Highlighter.js +9 -11
  296. package/dist-cjs/list/Highlighter.js.map +1 -1
  297. package/dist-cjs/list/List.js +61 -63
  298. package/dist-cjs/list/List.js.map +1 -1
  299. package/dist-cjs/list/ListItem.js +29 -28
  300. package/dist-cjs/list/ListItem.js.map +1 -1
  301. package/dist-cjs/list/ListItemGroup.js +0 -2
  302. package/dist-cjs/list/ListItemGroup.js.map +1 -1
  303. package/dist-cjs/list/ListItemHeader.js +0 -2
  304. package/dist-cjs/list/ListItemHeader.js.map +1 -1
  305. package/dist-cjs/list/VirtualizedList.js +52 -48
  306. package/dist-cjs/list/VirtualizedList.js.map +1 -1
  307. package/dist-cjs/list/keyset.js +0 -2
  308. package/dist-cjs/list/keyset.js.map +1 -1
  309. package/dist-cjs/list/useList.js +3 -2
  310. package/dist-cjs/list/useList.js.map +1 -1
  311. package/dist-cjs/list/useListHeight.js +4 -4
  312. package/dist-cjs/list/useListHeight.js.map +1 -1
  313. package/dist-cjs/list/useVirtualization.js +0 -2
  314. package/dist-cjs/list/useVirtualization.js.map +1 -1
  315. package/dist-cjs/list-deprecated/List.js +6 -14
  316. package/dist-cjs/list-deprecated/List.js.map +1 -1
  317. package/dist-cjs/list-deprecated/ListBase.js +99 -87
  318. package/dist-cjs/list-deprecated/ListBase.js.map +1 -1
  319. package/dist-cjs/list-deprecated/ListItem.js +1 -8
  320. package/dist-cjs/list-deprecated/ListItem.js.map +1 -1
  321. package/dist-cjs/list-deprecated/ListItemBase.js +10 -14
  322. package/dist-cjs/list-deprecated/ListItemBase.js.map +1 -1
  323. package/dist-cjs/list-deprecated/ListItemContext.js +0 -2
  324. package/dist-cjs/list-deprecated/ListItemContext.js.map +1 -1
  325. package/dist-cjs/list-deprecated/ListStateContext.js +0 -2
  326. package/dist-cjs/list-deprecated/ListStateContext.js.map +1 -1
  327. package/dist-cjs/list-deprecated/internal/DescendantContext.js +1 -6
  328. package/dist-cjs/list-deprecated/internal/DescendantContext.js.map +1 -1
  329. package/dist-cjs/list-deprecated/internal/Highlighter.js +4 -11
  330. package/dist-cjs/list-deprecated/internal/Highlighter.js.map +1 -1
  331. package/dist-cjs/list-deprecated/internal/calcPreferredListHeight.js +2 -3
  332. package/dist-cjs/list-deprecated/internal/calcPreferredListHeight.js.map +1 -1
  333. package/dist-cjs/list-deprecated/internal/helpers.js +0 -2
  334. package/dist-cjs/list-deprecated/internal/helpers.js.map +1 -1
  335. package/dist-cjs/list-deprecated/internal/scrollIntoView.js +0 -2
  336. package/dist-cjs/list-deprecated/internal/scrollIntoView.js.map +1 -1
  337. package/dist-cjs/list-deprecated/internal/useListAutoSizer.js +0 -2
  338. package/dist-cjs/list-deprecated/internal/useListAutoSizer.js.map +1 -1
  339. package/dist-cjs/list-deprecated/internal/useWidth.js +0 -2
  340. package/dist-cjs/list-deprecated/internal/useWidth.js.map +1 -1
  341. package/dist-cjs/list-deprecated/itemToString.js +0 -2
  342. package/dist-cjs/list-deprecated/itemToString.js.map +1 -1
  343. package/dist-cjs/list-deprecated/useList.js +7 -9
  344. package/dist-cjs/list-deprecated/useList.js.map +1 -1
  345. package/dist-cjs/list-deprecated/useListItem.js +5 -2
  346. package/dist-cjs/list-deprecated/useListItem.js.map +1 -1
  347. package/dist-cjs/list-deprecated/useTypeSelect.js +2 -2
  348. package/dist-cjs/list-deprecated/useTypeSelect.js.map +1 -1
  349. package/dist-cjs/list-next/ListItemNext.js +25 -25
  350. package/dist-cjs/list-next/ListItemNext.js.map +1 -1
  351. package/dist-cjs/list-next/ListNext.js +5 -7
  352. package/dist-cjs/list-next/ListNext.js.map +1 -1
  353. package/dist-cjs/list-next/ListNextContext.js +0 -2
  354. package/dist-cjs/list-next/ListNextContext.js.map +1 -1
  355. package/dist-cjs/list-next/useList.js +3 -6
  356. package/dist-cjs/list-next/useList.js.map +1 -1
  357. package/dist-cjs/logo/Logo.js +1 -7
  358. package/dist-cjs/logo/Logo.js.map +1 -1
  359. package/dist-cjs/logo/LogoImage.js +9 -8
  360. package/dist-cjs/logo/LogoImage.js.map +1 -1
  361. package/dist-cjs/logo/LogoSeparator.js +1 -7
  362. package/dist-cjs/logo/LogoSeparator.js.map +1 -1
  363. package/dist-cjs/menu-button/MenuButton.js +21 -17
  364. package/dist-cjs/menu-button/MenuButton.js.map +1 -1
  365. package/dist-cjs/menu-button/MenuButtonTrigger.js +21 -17
  366. package/dist-cjs/menu-button/MenuButtonTrigger.js.map +1 -1
  367. package/dist-cjs/metric/Metric.js +5 -7
  368. package/dist-cjs/metric/Metric.js.map +1 -1
  369. package/dist-cjs/metric/MetricContent.js +32 -30
  370. package/dist-cjs/metric/MetricContent.js.map +1 -1
  371. package/dist-cjs/metric/MetricHeader.js +20 -26
  372. package/dist-cjs/metric/MetricHeader.js.map +1 -1
  373. package/dist-cjs/metric/internal/MetricContext.js +0 -2
  374. package/dist-cjs/metric/internal/MetricContext.js.map +1 -1
  375. package/dist-cjs/portal/Portal.js +3 -10
  376. package/dist-cjs/portal/Portal.js.map +1 -1
  377. package/dist-cjs/query-input/QueryInput.js +21 -19
  378. package/dist-cjs/query-input/QueryInput.js.map +1 -1
  379. package/dist-cjs/query-input/internal/CategoryList.js +8 -17
  380. package/dist-cjs/query-input/internal/CategoryList.js.map +1 -1
  381. package/dist-cjs/query-input/internal/CategoryListContext.js +0 -2
  382. package/dist-cjs/query-input/internal/CategoryListContext.js.map +1 -1
  383. package/dist-cjs/query-input/internal/CategoryListItem.js +9 -32
  384. package/dist-cjs/query-input/internal/CategoryListItem.js.map +1 -1
  385. package/dist-cjs/query-input/internal/QueryInputBody.js +16 -24
  386. package/dist-cjs/query-input/internal/QueryInputBody.js.map +1 -1
  387. package/dist-cjs/query-input/internal/SearchList.js +21 -28
  388. package/dist-cjs/query-input/internal/SearchList.js.map +1 -1
  389. package/dist-cjs/query-input/internal/ValueList.js +18 -25
  390. package/dist-cjs/query-input/internal/ValueList.js.map +1 -1
  391. package/dist-cjs/query-input/internal/ValueSelector.js +42 -37
  392. package/dist-cjs/query-input/internal/ValueSelector.js.map +1 -1
  393. package/dist-cjs/query-input/internal/usePopperStatus.js +0 -2
  394. package/dist-cjs/query-input/internal/usePopperStatus.js.map +1 -1
  395. package/dist-cjs/query-input/useQueryInput.js +0 -2
  396. package/dist-cjs/query-input/useQueryInput.js.map +1 -1
  397. package/dist-cjs/responsive/OverflowReducer.js +7 -9
  398. package/dist-cjs/responsive/OverflowReducer.js.map +1 -1
  399. package/dist-cjs/responsive/overflowUtils.js +0 -2
  400. package/dist-cjs/responsive/overflowUtils.js.map +1 -1
  401. package/dist-cjs/responsive/useDynamicCollapse.js +0 -2
  402. package/dist-cjs/responsive/useDynamicCollapse.js.map +1 -1
  403. package/dist-cjs/responsive/useInstantCollapse.js +1 -4
  404. package/dist-cjs/responsive/useInstantCollapse.js.map +1 -1
  405. package/dist-cjs/responsive/useOverflow.js +0 -2
  406. package/dist-cjs/responsive/useOverflow.js.map +1 -1
  407. package/dist-cjs/responsive/useOverflowCollectionItems.js +1 -4
  408. package/dist-cjs/responsive/useOverflowCollectionItems.js.map +1 -1
  409. package/dist-cjs/responsive/useOverflowLayout.js +4 -7
  410. package/dist-cjs/responsive/useOverflowLayout.js.map +1 -1
  411. package/dist-cjs/responsive/useReclaimSpace.js +1 -4
  412. package/dist-cjs/responsive/useReclaimSpace.js.map +1 -1
  413. package/dist-cjs/responsive/useResizeObserver.js +0 -2
  414. package/dist-cjs/responsive/useResizeObserver.js.map +1 -1
  415. package/dist-cjs/responsive/useWidth.js +0 -2
  416. package/dist-cjs/responsive/useWidth.js.map +1 -1
  417. package/dist-cjs/responsive/utils.js +2 -10
  418. package/dist-cjs/responsive/utils.js.map +1 -1
  419. package/dist-cjs/search-input/SearchInput.js +27 -24
  420. package/dist-cjs/search-input/SearchInput.js.map +1 -1
  421. package/dist-cjs/skip-link/SkipLink.js +5 -6
  422. package/dist-cjs/skip-link/SkipLink.js.map +1 -1
  423. package/dist-cjs/skip-link/SkipLinks.js +1 -8
  424. package/dist-cjs/skip-link/SkipLinks.js.map +1 -1
  425. package/dist-cjs/skip-link/internal/useManageFocusOnTarget.js +0 -2
  426. package/dist-cjs/skip-link/internal/useManageFocusOnTarget.js.map +1 -1
  427. package/dist-cjs/slider/Slider.js +47 -41
  428. package/dist-cjs/slider/Slider.js.map +1 -1
  429. package/dist-cjs/slider/internal/SliderContext.js +0 -2
  430. package/dist-cjs/slider/internal/SliderContext.js.map +1 -1
  431. package/dist-cjs/slider/internal/SliderMarks.js +8 -10
  432. package/dist-cjs/slider/internal/SliderMarks.js.map +1 -1
  433. package/dist-cjs/slider/internal/SliderSelection.js +13 -12
  434. package/dist-cjs/slider/internal/SliderSelection.js.map +1 -1
  435. package/dist-cjs/slider/internal/SliderThumb.js +49 -45
  436. package/dist-cjs/slider/internal/SliderThumb.js.map +1 -1
  437. package/dist-cjs/slider/internal/SliderTrack.js +26 -24
  438. package/dist-cjs/slider/internal/SliderTrack.js.map +1 -1
  439. package/dist-cjs/slider/internal/useKeyDownThumb.js +1 -4
  440. package/dist-cjs/slider/internal/useKeyDownThumb.js.map +1 -1
  441. package/dist-cjs/slider/internal/utils.js +5 -12
  442. package/dist-cjs/slider/internal/utils.js.map +1 -1
  443. package/dist-cjs/static-list/StaticList.js +1 -8
  444. package/dist-cjs/static-list/StaticList.js.map +1 -1
  445. package/dist-cjs/static-list/StaticListItem.js +1 -8
  446. package/dist-cjs/static-list/StaticListItem.js.map +1 -1
  447. package/dist-cjs/static-list/StaticListItemContent.js +1 -8
  448. package/dist-cjs/static-list/StaticListItemContent.js.map +1 -1
  449. package/dist-cjs/stepped-tracker/StepLabel/StepLabel.js +1 -10
  450. package/dist-cjs/stepped-tracker/StepLabel/StepLabel.js.map +1 -1
  451. package/dist-cjs/stepped-tracker/SteppedTracker.js +6 -12
  452. package/dist-cjs/stepped-tracker/SteppedTracker.js.map +1 -1
  453. package/dist-cjs/stepped-tracker/SteppedTrackerContext.js +2 -10
  454. package/dist-cjs/stepped-tracker/SteppedTrackerContext.js.map +1 -1
  455. package/dist-cjs/stepped-tracker/TrackerConnector/TrackerConnector.js +1 -5
  456. package/dist-cjs/stepped-tracker/TrackerConnector/TrackerConnector.js.map +1 -1
  457. package/dist-cjs/stepped-tracker/TrackerStep/TrackerStep.js +24 -31
  458. package/dist-cjs/stepped-tracker/TrackerStep/TrackerStep.js.map +1 -1
  459. package/dist-cjs/stepper-input/StepperInput.js +84 -89
  460. package/dist-cjs/stepper-input/StepperInput.js.map +1 -1
  461. package/dist-cjs/stepper-input/internal/useActivateWhileMouseDown.js +2 -6
  462. package/dist-cjs/stepper-input/internal/useActivateWhileMouseDown.js.map +1 -1
  463. package/dist-cjs/stepper-input/internal/useInterval.js +0 -2
  464. package/dist-cjs/stepper-input/internal/useInterval.js.map +1 -1
  465. package/dist-cjs/stepper-input/internal/utils.js +5 -12
  466. package/dist-cjs/stepper-input/internal/utils.js.map +1 -1
  467. package/dist-cjs/stepper-input/useStepperInput.js +6 -14
  468. package/dist-cjs/stepper-input/useStepperInput.js.map +1 -1
  469. package/dist-cjs/system-status/SystemStatus.js +13 -15
  470. package/dist-cjs/system-status/SystemStatus.js.map +1 -1
  471. package/dist-cjs/system-status/SystemStatusActions.js +1 -7
  472. package/dist-cjs/system-status/SystemStatusActions.js.map +1 -1
  473. package/dist-cjs/system-status/SystemStatusContent.js +1 -7
  474. package/dist-cjs/system-status/SystemStatusContent.js.map +1 -1
  475. package/dist-cjs/tabs/Tab.js +74 -57
  476. package/dist-cjs/tabs/Tab.js.map +1 -1
  477. package/dist-cjs/tabs/TabActivationIndicator.js +1 -10
  478. package/dist-cjs/tabs/TabActivationIndicator.js.map +1 -1
  479. package/dist-cjs/tabs/TabPanel.js +11 -10
  480. package/dist-cjs/tabs/TabPanel.js.map +1 -1
  481. package/dist-cjs/tabs/Tabs.js +21 -17
  482. package/dist-cjs/tabs/Tabs.js.map +1 -1
  483. package/dist-cjs/tabs/Tabstrip.js +86 -72
  484. package/dist-cjs/tabs/Tabstrip.js.map +1 -1
  485. package/dist-cjs/tabs/drag-drop/Draggable.js +5 -6
  486. package/dist-cjs/tabs/drag-drop/Draggable.js.map +1 -1
  487. package/dist-cjs/tabs/drag-drop/drag-utils.js +1 -4
  488. package/dist-cjs/tabs/drag-drop/drag-utils.js.map +1 -1
  489. package/dist-cjs/tabs/drag-drop/dragDropTypes.js +0 -2
  490. package/dist-cjs/tabs/drag-drop/dragDropTypes.js.map +1 -1
  491. package/dist-cjs/tabs/drag-drop/useDragDrop.js +0 -2
  492. package/dist-cjs/tabs/drag-drop/useDragDrop.js.map +1 -1
  493. package/dist-cjs/tabs/drag-drop/useDragDropNaturalMovement.js +9 -8
  494. package/dist-cjs/tabs/drag-drop/useDragDropNaturalMovement.js.map +1 -1
  495. package/dist-cjs/tabs/drag-drop/useDragSpacers.js +1 -2
  496. package/dist-cjs/tabs/drag-drop/useDragSpacers.js.map +1 -1
  497. package/dist-cjs/tabs/useActivationIndicator.js +0 -2
  498. package/dist-cjs/tabs/useActivationIndicator.js.map +1 -1
  499. package/dist-cjs/tabs/useEditableItem.js +0 -2
  500. package/dist-cjs/tabs/useEditableItem.js.map +1 -1
  501. package/dist-cjs/tabs/useItemsWithIds.js +1 -7
  502. package/dist-cjs/tabs/useItemsWithIds.js.map +1 -1
  503. package/dist-cjs/tabs/useKeyboardNavigation.js +0 -2
  504. package/dist-cjs/tabs/useKeyboardNavigation.js.map +1 -1
  505. package/dist-cjs/tabs/useSelection.js +1 -3
  506. package/dist-cjs/tabs/useSelection.js.map +1 -1
  507. package/dist-cjs/tabs/useTabs.js +3 -5
  508. package/dist-cjs/tabs/useTabs.js.map +1 -1
  509. package/dist-cjs/tabs/useTabstrip.js +3 -3
  510. package/dist-cjs/tabs/useTabstrip.js.map +1 -1
  511. package/dist-cjs/tabs-next/TabBar.css.js +6 -0
  512. package/dist-cjs/tabs-next/TabBar.css.js.map +1 -0
  513. package/dist-cjs/tabs-next/TabBar.js +41 -0
  514. package/dist-cjs/tabs-next/TabBar.js.map +1 -0
  515. package/dist-cjs/tabs-next/TabListNext.css.js +6 -0
  516. package/dist-cjs/tabs-next/TabListNext.css.js.map +1 -0
  517. package/dist-cjs/tabs-next/TabListNext.js +127 -0
  518. package/dist-cjs/tabs-next/TabListNext.js.map +1 -0
  519. package/dist-cjs/tabs-next/TabNext.css.js +1 -1
  520. package/dist-cjs/tabs-next/TabNext.js +74 -58
  521. package/dist-cjs/tabs-next/TabNext.js.map +1 -1
  522. package/dist-cjs/tabs-next/TabNextAction.js +35 -0
  523. package/dist-cjs/tabs-next/TabNextAction.js.map +1 -0
  524. package/dist-cjs/tabs-next/TabNextContext.js +15 -17
  525. package/dist-cjs/tabs-next/TabNextContext.js.map +1 -1
  526. package/dist-cjs/tabs-next/TabNextPanel.css.js +6 -0
  527. package/dist-cjs/tabs-next/TabNextPanel.css.js.map +1 -0
  528. package/dist-cjs/tabs-next/TabNextPanel.js +77 -0
  529. package/dist-cjs/tabs-next/TabNextPanel.js.map +1 -0
  530. package/dist-cjs/tabs-next/TabNextTrigger.css.js +6 -0
  531. package/dist-cjs/tabs-next/TabNextTrigger.css.js.map +1 -0
  532. package/dist-cjs/tabs-next/TabNextTrigger.js +77 -0
  533. package/dist-cjs/tabs-next/TabNextTrigger.js.map +1 -0
  534. package/dist-cjs/tabs-next/TabOverflowList.css.js +6 -0
  535. package/dist-cjs/tabs-next/TabOverflowList.css.js.map +1 -0
  536. package/dist-cjs/tabs-next/TabOverflowList.js +132 -0
  537. package/dist-cjs/tabs-next/TabOverflowList.js.map +1 -0
  538. package/dist-cjs/tabs-next/TabsNext.js +176 -0
  539. package/dist-cjs/tabs-next/TabsNext.js.map +1 -0
  540. package/dist-cjs/tabs-next/TabsNextContext.js +33 -0
  541. package/dist-cjs/tabs-next/TabsNextContext.js.map +1 -0
  542. package/dist-cjs/tabs-next/hooks/useCollection.js +91 -0
  543. package/dist-cjs/tabs-next/hooks/useCollection.js.map +1 -0
  544. package/dist-cjs/tabs-next/hooks/useFocusOutside.js +25 -0
  545. package/dist-cjs/tabs-next/hooks/useFocusOutside.js.map +1 -0
  546. package/dist-cjs/tabs-next/hooks/useOverflow.js +141 -0
  547. package/dist-cjs/tabs-next/hooks/useOverflow.js.map +1 -0
  548. package/dist-cjs/toast-group/ToastGroup.js +8 -7
  549. package/dist-cjs/toast-group/ToastGroup.js.map +1 -1
  550. package/dist-cjs/tokenized-input/TokenizedInput.js +9 -8
  551. package/dist-cjs/tokenized-input/TokenizedInput.js.map +1 -1
  552. package/dist-cjs/tokenized-input/TokenizedInputBase.js +105 -96
  553. package/dist-cjs/tokenized-input/TokenizedInputBase.js.map +1 -1
  554. package/dist-cjs/tokenized-input/internal/InputPill.js +24 -26
  555. package/dist-cjs/tokenized-input/internal/InputPill.js.map +1 -1
  556. package/dist-cjs/tokenized-input/internal/InputRuler.js +1 -7
  557. package/dist-cjs/tokenized-input/internal/InputRuler.js.map +1 -1
  558. package/dist-cjs/tokenized-input/internal/calcFirstHiddenIndex.js +0 -2
  559. package/dist-cjs/tokenized-input/internal/calcFirstHiddenIndex.js.map +1 -1
  560. package/dist-cjs/tokenized-input/internal/defaultItemToString.js +0 -2
  561. package/dist-cjs/tokenized-input/internal/defaultItemToString.js.map +1 -1
  562. package/dist-cjs/tokenized-input/internal/getCursorPosition.js +0 -2
  563. package/dist-cjs/tokenized-input/internal/getCursorPosition.js.map +1 -1
  564. package/dist-cjs/tokenized-input/internal/isPlainObject.js +0 -2
  565. package/dist-cjs/tokenized-input/internal/isPlainObject.js.map +1 -1
  566. package/dist-cjs/tokenized-input/internal/useResizeObserver.js +0 -2
  567. package/dist-cjs/tokenized-input/internal/useResizeObserver.js.map +1 -1
  568. package/dist-cjs/tokenized-input/internal/useWidth.js +0 -2
  569. package/dist-cjs/tokenized-input/internal/useWidth.js.map +1 -1
  570. package/dist-cjs/tokenized-input/useTokenizedInput.js +11 -7
  571. package/dist-cjs/tokenized-input/useTokenizedInput.js.map +1 -1
  572. package/dist-cjs/tokenized-input-next/TokenizedInputNext.js +68 -58
  573. package/dist-cjs/tokenized-input-next/TokenizedInputNext.js.map +1 -1
  574. package/dist-cjs/tokenized-input-next/internal/InputPill.js +6 -12
  575. package/dist-cjs/tokenized-input-next/internal/InputPill.js.map +1 -1
  576. package/dist-cjs/tokenized-input-next/internal/calcFirstHiddenIndex.js +0 -2
  577. package/dist-cjs/tokenized-input-next/internal/calcFirstHiddenIndex.js.map +1 -1
  578. package/dist-cjs/tokenized-input-next/internal/useResizeObserver.js +0 -2
  579. package/dist-cjs/tokenized-input-next/internal/useResizeObserver.js.map +1 -1
  580. package/dist-cjs/tokenized-input-next/internal/useWidth.js +1 -3
  581. package/dist-cjs/tokenized-input-next/internal/useWidth.js.map +1 -1
  582. package/dist-cjs/tokenized-input-next/useTokenizedInputNext.js +9 -10
  583. package/dist-cjs/tokenized-input-next/useTokenizedInputNext.js.map +1 -1
  584. package/dist-cjs/toolbar/Toolbar.js +43 -35
  585. package/dist-cjs/toolbar/Toolbar.js.map +1 -1
  586. package/dist-cjs/toolbar/ToolbarButton.js +10 -9
  587. package/dist-cjs/toolbar/ToolbarButton.js.map +1 -1
  588. package/dist-cjs/toolbar/Tooltray.js +23 -29
  589. package/dist-cjs/toolbar/Tooltray.js.map +1 -1
  590. package/dist-cjs/toolbar/internal/renderToolbarItems.js +7 -12
  591. package/dist-cjs/toolbar/internal/renderToolbarItems.js.map +1 -1
  592. package/dist-cjs/toolbar/internal/renderTrayTools.js +23 -18
  593. package/dist-cjs/toolbar/internal/renderTrayTools.js.map +1 -1
  594. package/dist-cjs/toolbar/overflow-panel/OverflowPanel.js +40 -43
  595. package/dist-cjs/toolbar/overflow-panel/OverflowPanel.js.map +1 -1
  596. package/dist-cjs/toolbar/overflow-panel/OverflowSeparator.js +1 -6
  597. package/dist-cjs/toolbar/overflow-panel/OverflowSeparator.js.map +1 -1
  598. package/dist-cjs/toolbar/toolbar-field/ToolbarField.js +1 -6
  599. package/dist-cjs/toolbar/toolbar-field/ToolbarField.js.map +1 -1
  600. package/dist-cjs/toolbar/toolbar-field/useToolbarField.js +2 -4
  601. package/dist-cjs/toolbar/toolbar-field/useToolbarField.js.map +1 -1
  602. package/dist-cjs/tree/Tree.js +57 -48
  603. package/dist-cjs/tree/Tree.js.map +1 -1
  604. package/dist-cjs/tree/TreeNode.js +11 -25
  605. package/dist-cjs/tree/TreeNode.js.map +1 -1
  606. package/dist-cjs/tree/use-tree-keyboard-navigation.js +0 -2
  607. package/dist-cjs/tree/use-tree-keyboard-navigation.js.map +1 -1
  608. package/dist-cjs/tree/useTree.js +11 -6
  609. package/dist-cjs/tree/useTree.js.map +1 -1
  610. package/dist-cjs/utils/escapeRegExp.js +0 -2
  611. package/dist-cjs/utils/escapeRegExp.js.map +1 -1
  612. package/dist-cjs/utils/forwardCallbackProps.js +0 -2
  613. package/dist-cjs/utils/forwardCallbackProps.js.map +1 -1
  614. package/dist-cjs/utils/isEmail.js +0 -2
  615. package/dist-cjs/utils/isEmail.js.map +1 -1
  616. package/dist-cjs/utils/isPlainObject.js +0 -2
  617. package/dist-cjs/utils/isPlainObject.js.map +1 -1
  618. package/dist-cjs/utils/partition.js +0 -2
  619. package/dist-cjs/utils/partition.js.map +1 -1
  620. package/dist-cjs/utils/useClickOutside.js +1 -3
  621. package/dist-cjs/utils/useClickOutside.js.map +1 -1
  622. package/dist-cjs/utils/useEventCallback.js +4 -3
  623. package/dist-cjs/utils/useEventCallback.js.map +1 -1
  624. package/dist-cjs/utils/useIsViewportLargerThanBreakpoint.js +0 -2
  625. package/dist-cjs/utils/useIsViewportLargerThanBreakpoint.js.map +1 -1
  626. package/dist-cjs/utils/useLayoutEffectOnce.js +0 -2
  627. package/dist-cjs/utils/useLayoutEffectOnce.js.map +1 -1
  628. package/dist-cjs/utils/useLayoutEffectSkipFirst.js +0 -2
  629. package/dist-cjs/utils/useLayoutEffectSkipFirst.js.map +1 -1
  630. package/dist-cjs/utils/useOverflowDetection.js +0 -2
  631. package/dist-cjs/utils/useOverflowDetection.js.map +1 -1
  632. package/dist-cjs/utils/useSlideSelection.js +0 -2
  633. package/dist-cjs/utils/useSlideSelection.js.map +1 -1
  634. package/dist-cjs/window/ElectronWindow.js +7 -21
  635. package/dist-cjs/window/ElectronWindow.js.map +1 -1
  636. package/dist-cjs/window/WindowContext.js +1 -7
  637. package/dist-cjs/window/WindowContext.js.map +1 -1
  638. package/dist-cjs/window/desktop-utils.js +0 -2
  639. package/dist-cjs/window/desktop-utils.js.map +1 -1
  640. package/dist-es/app-header/AppHeader.js +9 -6
  641. package/dist-es/app-header/AppHeader.js.map +1 -1
  642. package/dist-es/breadcrumbs/Breadcrumb.js +43 -41
  643. package/dist-es/breadcrumbs/Breadcrumb.js.map +1 -1
  644. package/dist-es/breadcrumbs/Breadcrumbs.js +28 -31
  645. package/dist-es/breadcrumbs/Breadcrumbs.js.map +1 -1
  646. package/dist-es/breadcrumbs/internal/BreadcrumbsCollapsed.js +19 -14
  647. package/dist-es/breadcrumbs/internal/BreadcrumbsCollapsed.js.map +1 -1
  648. package/dist-es/breadcrumbs/internal/BreadcrumbsContext.js.map +1 -1
  649. package/dist-es/breadcrumbs/internal/BreadcrumbsSeparator.js +1 -3
  650. package/dist-es/breadcrumbs/internal/BreadcrumbsSeparator.js.map +1 -1
  651. package/dist-es/breadcrumbs/internal/useFocusMenuRemount.js.map +1 -1
  652. package/dist-es/button-bar/ButtonBar.js +20 -25
  653. package/dist-es/button-bar/ButtonBar.js.map +1 -1
  654. package/dist-es/button-bar/OrderedButton.js +16 -13
  655. package/dist-es/button-bar/OrderedButton.js.map +1 -1
  656. package/dist-es/button-bar/internal/ButtonBarContext.js.map +1 -1
  657. package/dist-es/button-bar/internal/DescendantContext.js +1 -4
  658. package/dist-es/button-bar/internal/DescendantContext.js.map +1 -1
  659. package/dist-es/button-bar/internal/useDescendant.js.map +1 -1
  660. package/dist-es/button-bar/internal/useDescendants.js.map +1 -1
  661. package/dist-es/calendar/Calendar.js +20 -14
  662. package/dist-es/calendar/Calendar.js.map +1 -1
  663. package/dist-es/calendar/CalendarDateGrid.js +34 -27
  664. package/dist-es/calendar/CalendarDateGrid.js.map +1 -1
  665. package/dist-es/calendar/CalendarNavigation.js +103 -94
  666. package/dist-es/calendar/CalendarNavigation.js.map +1 -1
  667. package/dist-es/calendar/CalendarWeekHeader.js +18 -11
  668. package/dist-es/calendar/CalendarWeekHeader.js.map +1 -1
  669. package/dist-es/calendar/formatDate.js +3 -6
  670. package/dist-es/calendar/formatDate.js.map +1 -1
  671. package/dist-es/calendar/internal/CalendarContext.js.map +1 -1
  672. package/dist-es/calendar/internal/CalendarDay.js +48 -39
  673. package/dist-es/calendar/internal/CalendarDay.js.map +1 -1
  674. package/dist-es/calendar/internal/CalendarMonth.js +28 -18
  675. package/dist-es/calendar/internal/CalendarMonth.js.map +1 -1
  676. package/dist-es/calendar/internal/useFocusManagement.js.map +1 -1
  677. package/dist-es/calendar/internal/utils.js.map +1 -1
  678. package/dist-es/calendar/useCalendar.js +3 -2
  679. package/dist-es/calendar/useCalendar.js.map +1 -1
  680. package/dist-es/calendar/useCalendarDay.js.map +1 -1
  681. package/dist-es/calendar/useCalendarSelection.js +2 -0
  682. package/dist-es/calendar/useCalendarSelection.js.map +1 -1
  683. package/dist-es/carousel/Carousel.js +59 -54
  684. package/dist-es/carousel/Carousel.js.map +1 -1
  685. package/dist-es/carousel/CarouselSlide.js +35 -36
  686. package/dist-es/carousel/CarouselSlide.js.map +1 -1
  687. package/dist-es/cascading-menu/CascadingMenu.js +15 -13
  688. package/dist-es/cascading-menu/CascadingMenu.js.map +1 -1
  689. package/dist-es/cascading-menu/CascadingMenuItem.js +72 -59
  690. package/dist-es/cascading-menu/CascadingMenuItem.js.map +1 -1
  691. package/dist-es/cascading-menu/CascadingMenuList.js +50 -41
  692. package/dist-es/cascading-menu/CascadingMenuList.js.map +1 -1
  693. package/dist-es/cascading-menu/internal/CascadingMenuAction.js.map +1 -1
  694. package/dist-es/cascading-menu/internal/keydownHandlers.js.map +1 -1
  695. package/dist-es/cascading-menu/internal/menuPositioning.js.map +1 -1
  696. package/dist-es/cascading-menu/internal/stateUtils.js +1 -0
  697. package/dist-es/cascading-menu/internal/stateUtils.js.map +1 -1
  698. package/dist-es/cascading-menu/internal/useClickAway.js +4 -1
  699. package/dist-es/cascading-menu/internal/useClickAway.js.map +1 -1
  700. package/dist-es/cascading-menu/internal/useMenuTriggerHandlers.js.map +1 -1
  701. package/dist-es/cascading-menu/internal/useMountedRef.js.map +1 -1
  702. package/dist-es/cascading-menu/internal/useMouseHandlers.js +2 -3
  703. package/dist-es/cascading-menu/internal/useMouseHandlers.js.map +1 -1
  704. package/dist-es/cascading-menu/internal/useRefsManager.js.map +1 -1
  705. package/dist-es/cascading-menu/internal/useStateReducer.js.map +1 -1
  706. package/dist-es/cascading-menu/stateChangeTypes.js.map +1 -1
  707. package/dist-es/color-chooser/AlphaInputField.js +17 -13
  708. package/dist-es/color-chooser/AlphaInputField.js.map +1 -1
  709. package/dist-es/color-chooser/Color.js +1 -0
  710. package/dist-es/color-chooser/Color.js.map +1 -1
  711. package/dist-es/color-chooser/ColorChooser.js +58 -58
  712. package/dist-es/color-chooser/ColorChooser.js.map +1 -1
  713. package/dist-es/color-chooser/ColorHelpers.js +5 -9
  714. package/dist-es/color-chooser/ColorHelpers.js.map +1 -1
  715. package/dist-es/color-chooser/ColorPicker.js +33 -47
  716. package/dist-es/color-chooser/ColorPicker.js.map +1 -1
  717. package/dist-es/color-chooser/DictTabs.js +24 -21
  718. package/dist-es/color-chooser/DictTabs.js.map +1 -1
  719. package/dist-es/color-chooser/GetColorPalettes.js +1 -1
  720. package/dist-es/color-chooser/GetColorPalettes.js.map +1 -1
  721. package/dist-es/color-chooser/HexInput.js +9 -13
  722. package/dist-es/color-chooser/HexInput.js.map +1 -1
  723. package/dist-es/color-chooser/RGBAInput.js +24 -37
  724. package/dist-es/color-chooser/RGBAInput.js.map +1 -1
  725. package/dist-es/color-chooser/RGBAInputField.js +14 -10
  726. package/dist-es/color-chooser/RGBAInputField.js.map +1 -1
  727. package/dist-es/color-chooser/Swatch.js +19 -16
  728. package/dist-es/color-chooser/Swatch.js.map +1 -1
  729. package/dist-es/color-chooser/Swatches.js +27 -41
  730. package/dist-es/color-chooser/Swatches.js.map +1 -1
  731. package/dist-es/color-chooser/SwatchesPicker.js +26 -18
  732. package/dist-es/color-chooser/SwatchesPicker.js.map +1 -1
  733. package/dist-es/color-chooser/color-utils.js.map +1 -1
  734. package/dist-es/color-chooser/colorMap.js +1 -0
  735. package/dist-es/color-chooser/colorMap.js.map +1 -1
  736. package/dist-es/color-chooser/createTabsMapping.js.map +1 -1
  737. package/dist-es/combo-box/ComboBox.js +29 -23
  738. package/dist-es/combo-box/ComboBox.js.map +1 -1
  739. package/dist-es/combo-box/useCombobox.js +16 -13
  740. package/dist-es/combo-box/useCombobox.js.map +1 -1
  741. package/dist-es/combo-box-deprecated/ComboBoxDeprecated.js +37 -31
  742. package/dist-es/combo-box-deprecated/ComboBoxDeprecated.js.map +1 -1
  743. package/dist-es/combo-box-deprecated/filterHelpers.js.map +1 -1
  744. package/dist-es/combo-box-deprecated/internal/DefaultComboBox.js +37 -35
  745. package/dist-es/combo-box-deprecated/internal/DefaultComboBox.js.map +1 -1
  746. package/dist-es/combo-box-deprecated/internal/MultiSelectComboBox.js +37 -35
  747. package/dist-es/combo-box-deprecated/internal/MultiSelectComboBox.js.map +1 -1
  748. package/dist-es/combo-box-deprecated/internal/getAnnouncement.js +1 -1
  749. package/dist-es/combo-box-deprecated/internal/getAnnouncement.js.map +1 -1
  750. package/dist-es/combo-box-deprecated/internal/useComboBox.js.map +1 -1
  751. package/dist-es/combo-box-deprecated/internal/useMultiSelectComboBox.js.map +1 -1
  752. package/dist-es/combo-box-deprecated/internal/usePopperStatus.js.map +1 -1
  753. package/dist-es/common-hooks/calcPreferredHeight.js +2 -1
  754. package/dist-es/common-hooks/calcPreferredHeight.js.map +1 -1
  755. package/dist-es/common-hooks/collectionProvider.js +1 -4
  756. package/dist-es/common-hooks/collectionProvider.js.map +1 -1
  757. package/dist-es/common-hooks/itemToString.js.map +1 -1
  758. package/dist-es/common-hooks/keyUtils.js.map +1 -1
  759. package/dist-es/common-hooks/list-dom-utils.js.map +1 -1
  760. package/dist-es/common-hooks/selectionTypes.js.map +1 -1
  761. package/dist-es/common-hooks/useAutoSizer.js.map +1 -1
  762. package/dist-es/common-hooks/useCollapsibleGroups.js.map +1 -1
  763. package/dist-es/common-hooks/useCollectionItems.js +21 -10
  764. package/dist-es/common-hooks/useCollectionItems.js.map +1 -1
  765. package/dist-es/common-hooks/useImperativeScrollingAPI.js.map +1 -1
  766. package/dist-es/common-hooks/useKeyboardNavigation.js +2 -1
  767. package/dist-es/common-hooks/useKeyboardNavigation.js.map +1 -1
  768. package/dist-es/common-hooks/useKeyboardNavigationPanel.js +3 -0
  769. package/dist-es/common-hooks/useKeyboardNavigationPanel.js.map +1 -1
  770. package/dist-es/common-hooks/useSelection.js +3 -5
  771. package/dist-es/common-hooks/useSelection.js.map +1 -1
  772. package/dist-es/common-hooks/useTypeahead.js.map +1 -1
  773. package/dist-es/common-hooks/useViewportTracking.js.map +1 -1
  774. package/dist-es/common-hooks/utils/collection-item-utils.js +2 -2
  775. package/dist-es/common-hooks/utils/collection-item-utils.js.map +1 -1
  776. package/dist-es/common-hooks/utils/filter-utils.js.map +1 -1
  777. package/dist-es/common-hooks/utils/isSelected.js.map +1 -1
  778. package/dist-es/contact-details/ContactAction.js +9 -11
  779. package/dist-es/contact-details/ContactAction.js.map +1 -1
  780. package/dist-es/contact-details/ContactActions.js +1 -6
  781. package/dist-es/contact-details/ContactActions.js.map +1 -1
  782. package/dist-es/contact-details/ContactAvatar.js +17 -14
  783. package/dist-es/contact-details/ContactAvatar.js.map +1 -1
  784. package/dist-es/contact-details/ContactDetails.js +6 -8
  785. package/dist-es/contact-details/ContactDetails.js.map +1 -1
  786. package/dist-es/contact-details/ContactFavoriteToggle.js +13 -10
  787. package/dist-es/contact-details/ContactFavoriteToggle.js.map +1 -1
  788. package/dist-es/contact-details/ContactMetadata.js +13 -11
  789. package/dist-es/contact-details/ContactMetadata.js.map +1 -1
  790. package/dist-es/contact-details/ContactMetadataItem.js +5 -21
  791. package/dist-es/contact-details/ContactMetadataItem.js.map +1 -1
  792. package/dist-es/contact-details/ContactPrimaryInfo.js +16 -13
  793. package/dist-es/contact-details/ContactPrimaryInfo.js.map +1 -1
  794. package/dist-es/contact-details/ContactSecondaryInfo.js +16 -15
  795. package/dist-es/contact-details/ContactSecondaryInfo.js.map +1 -1
  796. package/dist-es/contact-details/ContactTertiaryInfo.js +16 -15
  797. package/dist-es/contact-details/ContactTertiaryInfo.js.map +1 -1
  798. package/dist-es/contact-details/MailLinkComponent.js +1 -10
  799. package/dist-es/contact-details/MailLinkComponent.js.map +1 -1
  800. package/dist-es/contact-details/internal/ContactDetailsContext.js.map +1 -1
  801. package/dist-es/contact-details/internal/FavoriteToggle.js +18 -15
  802. package/dist-es/contact-details/internal/FavoriteToggle.js.map +1 -1
  803. package/dist-es/contact-details/internal/FavoriteToggleWithTooltip.js +1 -9
  804. package/dist-es/contact-details/internal/FavoriteToggleWithTooltip.js.map +1 -1
  805. package/dist-es/contact-details/internal/StarIcon.js +10 -12
  806. package/dist-es/contact-details/internal/StarIcon.js.map +1 -1
  807. package/dist-es/contact-details/internal/StarIconContainer.js +28 -22
  808. package/dist-es/contact-details/internal/StarIconContainer.js.map +1 -1
  809. package/dist-es/contact-details/internal/useComponentSize.js.map +1 -1
  810. package/dist-es/content-status/ContentStatus.js +16 -29
  811. package/dist-es/content-status/ContentStatus.js.map +1 -1
  812. package/dist-es/content-status/internal/StatusIndicator.js +30 -21
  813. package/dist-es/content-status/internal/StatusIndicator.js.map +1 -1
  814. package/dist-es/date-input/DateInputRange.js +91 -94
  815. package/dist-es/date-input/DateInputRange.js.map +1 -1
  816. package/dist-es/date-input/DateInputSingle.js +55 -56
  817. package/dist-es/date-input/DateInputSingle.js.map +1 -1
  818. package/dist-es/date-input/utils.js.map +1 -1
  819. package/dist-es/date-picker/DatePicker.js +3 -24
  820. package/dist-es/date-picker/DatePicker.js.map +1 -1
  821. package/dist-es/date-picker/DatePickerActions.js +13 -21
  822. package/dist-es/date-picker/DatePickerActions.js.map +1 -1
  823. package/dist-es/date-picker/DatePickerContext.js.map +1 -1
  824. package/dist-es/date-picker/DatePickerOverlay.js +18 -15
  825. package/dist-es/date-picker/DatePickerOverlay.js.map +1 -1
  826. package/dist-es/date-picker/DatePickerOverlayProvider.js +3 -6
  827. package/dist-es/date-picker/DatePickerOverlayProvider.js.map +1 -1
  828. package/dist-es/date-picker/DatePickerRangeInput.js +29 -23
  829. package/dist-es/date-picker/DatePickerRangeInput.js.map +1 -1
  830. package/dist-es/date-picker/DatePickerRangePanel.js +25 -53
  831. package/dist-es/date-picker/DatePickerRangePanel.js.map +1 -1
  832. package/dist-es/date-picker/DatePickerSingleInput.js +32 -26
  833. package/dist-es/date-picker/DatePickerSingleInput.js.map +1 -1
  834. package/dist-es/date-picker/DatePickerSinglePanel.js +19 -43
  835. package/dist-es/date-picker/DatePickerSinglePanel.js.map +1 -1
  836. package/dist-es/date-picker/useDatePicker.js +2 -2
  837. package/dist-es/date-picker/useDatePicker.js.map +1 -1
  838. package/dist-es/deck-item/DeckItem.js +21 -16
  839. package/dist-es/deck-item/DeckItem.js.map +1 -1
  840. package/dist-es/deck-layout/DeckLayout.js +34 -25
  841. package/dist-es/deck-layout/DeckLayout.js.map +1 -1
  842. package/dist-es/dialog/DialogHeader.css.js +4 -0
  843. package/dist-es/dialog/DialogHeader.css.js.map +1 -0
  844. package/dist-es/dialog/DialogHeader.js +61 -0
  845. package/dist-es/dialog/DialogHeader.js.map +1 -0
  846. package/dist-es/dropdown/Dropdown.js +28 -22
  847. package/dist-es/dropdown/Dropdown.js.map +1 -1
  848. package/dist-es/dropdown/DropdownBase.js +29 -27
  849. package/dist-es/dropdown/DropdownBase.js.map +1 -1
  850. package/dist-es/dropdown/DropdownButton.js +40 -34
  851. package/dist-es/dropdown/DropdownButton.js.map +1 -1
  852. package/dist-es/dropdown/useClickAway.js.map +1 -1
  853. package/dist-es/dropdown/useDropdown.js +2 -2
  854. package/dist-es/dropdown/useDropdown.js.map +1 -1
  855. package/dist-es/dropdown/useDropdownBase.js +3 -3
  856. package/dist-es/dropdown/useDropdownBase.js.map +1 -1
  857. package/dist-es/editable-label/EditableLabel.js +23 -17
  858. package/dist-es/editable-label/EditableLabel.js.map +1 -1
  859. package/dist-es/form-field-context-legacy/FormFieldLegacyContext.js.map +1 -1
  860. package/dist-es/form-field-context-legacy/useFormFieldLegacyProps.js.map +1 -1
  861. package/dist-es/form-field-legacy/FormActivationIndicator.js +29 -36
  862. package/dist-es/form-field-legacy/FormActivationIndicator.js.map +1 -1
  863. package/dist-es/form-field-legacy/FormFieldLegacy.js +53 -42
  864. package/dist-es/form-field-legacy/FormFieldLegacy.js.map +1 -1
  865. package/dist-es/form-field-legacy/FormHelperText.js +1 -5
  866. package/dist-es/form-field-legacy/FormHelperText.js.map +1 -1
  867. package/dist-es/form-field-legacy/FormLabel.js +34 -22
  868. package/dist-es/form-field-legacy/FormLabel.js.map +1 -1
  869. package/dist-es/form-field-legacy/NecessityIndicator.js +9 -6
  870. package/dist-es/form-field-legacy/NecessityIndicator.js.map +1 -1
  871. package/dist-es/form-field-legacy/StatusIndicator.js +22 -16
  872. package/dist-es/form-field-legacy/StatusIndicator.js.map +1 -1
  873. package/dist-es/form-group/FormGroup.js +8 -5
  874. package/dist-es/form-group/FormGroup.js.map +1 -1
  875. package/dist-es/formatted-input/FormattedInput.js +13 -10
  876. package/dist-es/formatted-input/FormattedInput.js.map +1 -1
  877. package/dist-es/formatted-input/internal/InputWithMask.js +13 -12
  878. package/dist-es/formatted-input/internal/InputWithMask.js.map +1 -1
  879. package/dist-es/index.js +7 -1
  880. package/dist-es/index.js.map +1 -1
  881. package/dist-es/input-legacy/InputLegacy.js +48 -45
  882. package/dist-es/input-legacy/InputLegacy.js.map +1 -1
  883. package/dist-es/input-legacy/StaticInputAdornment.js +1 -6
  884. package/dist-es/input-legacy/StaticInputAdornment.js.map +1 -1
  885. package/dist-es/input-legacy/useCursorOnFocus.js.map +1 -1
  886. package/dist-es/layer-layout/LayerLayout.js +34 -28
  887. package/dist-es/layer-layout/LayerLayout.js.map +1 -1
  888. package/dist-es/list/Highlighter.js +9 -9
  889. package/dist-es/list/Highlighter.js.map +1 -1
  890. package/dist-es/list/List.js +61 -61
  891. package/dist-es/list/List.js.map +1 -1
  892. package/dist-es/list/ListItem.js +29 -26
  893. package/dist-es/list/ListItem.js.map +1 -1
  894. package/dist-es/list/VirtualizedList.js +52 -46
  895. package/dist-es/list/VirtualizedList.js.map +1 -1
  896. package/dist-es/list/keyset.js.map +1 -1
  897. package/dist-es/list/useList.js +3 -0
  898. package/dist-es/list/useList.js.map +1 -1
  899. package/dist-es/list/useListHeight.js +4 -2
  900. package/dist-es/list/useListHeight.js.map +1 -1
  901. package/dist-es/list/useVirtualization.js.map +1 -1
  902. package/dist-es/list-deprecated/List.js +6 -12
  903. package/dist-es/list-deprecated/List.js.map +1 -1
  904. package/dist-es/list-deprecated/ListBase.js +99 -85
  905. package/dist-es/list-deprecated/ListBase.js.map +1 -1
  906. package/dist-es/list-deprecated/ListItem.js +1 -6
  907. package/dist-es/list-deprecated/ListItem.js.map +1 -1
  908. package/dist-es/list-deprecated/ListItemBase.js +10 -12
  909. package/dist-es/list-deprecated/ListItemBase.js.map +1 -1
  910. package/dist-es/list-deprecated/ListItemContext.js.map +1 -1
  911. package/dist-es/list-deprecated/ListStateContext.js.map +1 -1
  912. package/dist-es/list-deprecated/internal/DescendantContext.js +1 -4
  913. package/dist-es/list-deprecated/internal/DescendantContext.js.map +1 -1
  914. package/dist-es/list-deprecated/internal/Highlighter.js +4 -9
  915. package/dist-es/list-deprecated/internal/Highlighter.js.map +1 -1
  916. package/dist-es/list-deprecated/internal/calcPreferredListHeight.js +2 -1
  917. package/dist-es/list-deprecated/internal/calcPreferredListHeight.js.map +1 -1
  918. package/dist-es/list-deprecated/internal/scrollIntoView.js.map +1 -1
  919. package/dist-es/list-deprecated/internal/useListAutoSizer.js.map +1 -1
  920. package/dist-es/list-deprecated/internal/useWidth.js.map +1 -1
  921. package/dist-es/list-deprecated/itemToString.js.map +1 -1
  922. package/dist-es/list-deprecated/useList.js +7 -7
  923. package/dist-es/list-deprecated/useList.js.map +1 -1
  924. package/dist-es/list-deprecated/useListItem.js +5 -0
  925. package/dist-es/list-deprecated/useListItem.js.map +1 -1
  926. package/dist-es/list-deprecated/useTypeSelect.js +2 -0
  927. package/dist-es/list-deprecated/useTypeSelect.js.map +1 -1
  928. package/dist-es/list-next/ListItemNext.js +25 -23
  929. package/dist-es/list-next/ListItemNext.js.map +1 -1
  930. package/dist-es/list-next/ListNext.js +5 -5
  931. package/dist-es/list-next/ListNext.js.map +1 -1
  932. package/dist-es/list-next/ListNextContext.js.map +1 -1
  933. package/dist-es/list-next/useList.js +3 -4
  934. package/dist-es/list-next/useList.js.map +1 -1
  935. package/dist-es/logo/Logo.js +1 -5
  936. package/dist-es/logo/Logo.js.map +1 -1
  937. package/dist-es/logo/LogoImage.js +9 -6
  938. package/dist-es/logo/LogoImage.js.map +1 -1
  939. package/dist-es/logo/LogoSeparator.js +1 -5
  940. package/dist-es/logo/LogoSeparator.js.map +1 -1
  941. package/dist-es/menu-button/MenuButton.js +21 -15
  942. package/dist-es/menu-button/MenuButton.js.map +1 -1
  943. package/dist-es/menu-button/MenuButtonTrigger.js +21 -15
  944. package/dist-es/menu-button/MenuButtonTrigger.js.map +1 -1
  945. package/dist-es/metric/Metric.js +5 -5
  946. package/dist-es/metric/Metric.js.map +1 -1
  947. package/dist-es/metric/MetricContent.js +32 -28
  948. package/dist-es/metric/MetricContent.js.map +1 -1
  949. package/dist-es/metric/MetricHeader.js +20 -24
  950. package/dist-es/metric/MetricHeader.js.map +1 -1
  951. package/dist-es/metric/internal/MetricContext.js.map +1 -1
  952. package/dist-es/portal/Portal.js +3 -8
  953. package/dist-es/portal/Portal.js.map +1 -1
  954. package/dist-es/query-input/QueryInput.js +21 -17
  955. package/dist-es/query-input/QueryInput.js.map +1 -1
  956. package/dist-es/query-input/internal/CategoryList.js +8 -15
  957. package/dist-es/query-input/internal/CategoryList.js.map +1 -1
  958. package/dist-es/query-input/internal/CategoryListContext.js.map +1 -1
  959. package/dist-es/query-input/internal/CategoryListItem.js +9 -30
  960. package/dist-es/query-input/internal/CategoryListItem.js.map +1 -1
  961. package/dist-es/query-input/internal/QueryInputBody.js +16 -22
  962. package/dist-es/query-input/internal/QueryInputBody.js.map +1 -1
  963. package/dist-es/query-input/internal/SearchList.js +21 -26
  964. package/dist-es/query-input/internal/SearchList.js.map +1 -1
  965. package/dist-es/query-input/internal/ValueList.js +18 -23
  966. package/dist-es/query-input/internal/ValueList.js.map +1 -1
  967. package/dist-es/query-input/internal/ValueSelector.js +42 -35
  968. package/dist-es/query-input/internal/ValueSelector.js.map +1 -1
  969. package/dist-es/query-input/internal/usePopperStatus.js.map +1 -1
  970. package/dist-es/query-input/useQueryInput.js.map +1 -1
  971. package/dist-es/responsive/OverflowReducer.js +7 -7
  972. package/dist-es/responsive/OverflowReducer.js.map +1 -1
  973. package/dist-es/responsive/overflowUtils.js.map +1 -1
  974. package/dist-es/responsive/useDynamicCollapse.js.map +1 -1
  975. package/dist-es/responsive/useInstantCollapse.js +1 -2
  976. package/dist-es/responsive/useInstantCollapse.js.map +1 -1
  977. package/dist-es/responsive/useOverflow.js.map +1 -1
  978. package/dist-es/responsive/useOverflowCollectionItems.js +1 -2
  979. package/dist-es/responsive/useOverflowCollectionItems.js.map +1 -1
  980. package/dist-es/responsive/useOverflowLayout.js +4 -5
  981. package/dist-es/responsive/useOverflowLayout.js.map +1 -1
  982. package/dist-es/responsive/useReclaimSpace.js +1 -2
  983. package/dist-es/responsive/useReclaimSpace.js.map +1 -1
  984. package/dist-es/responsive/useResizeObserver.js.map +1 -1
  985. package/dist-es/responsive/useWidth.js.map +1 -1
  986. package/dist-es/responsive/utils.js +2 -8
  987. package/dist-es/responsive/utils.js.map +1 -1
  988. package/dist-es/search-input/SearchInput.js +27 -22
  989. package/dist-es/search-input/SearchInput.js.map +1 -1
  990. package/dist-es/skip-link/SkipLink.js +5 -4
  991. package/dist-es/skip-link/SkipLink.js.map +1 -1
  992. package/dist-es/skip-link/SkipLinks.js +1 -6
  993. package/dist-es/skip-link/SkipLinks.js.map +1 -1
  994. package/dist-es/skip-link/internal/useManageFocusOnTarget.js.map +1 -1
  995. package/dist-es/slider/Slider.js +47 -39
  996. package/dist-es/slider/Slider.js.map +1 -1
  997. package/dist-es/slider/internal/SliderContext.js.map +1 -1
  998. package/dist-es/slider/internal/SliderMarks.js +8 -8
  999. package/dist-es/slider/internal/SliderMarks.js.map +1 -1
  1000. package/dist-es/slider/internal/SliderSelection.js +13 -10
  1001. package/dist-es/slider/internal/SliderSelection.js.map +1 -1
  1002. package/dist-es/slider/internal/SliderThumb.js +49 -43
  1003. package/dist-es/slider/internal/SliderThumb.js.map +1 -1
  1004. package/dist-es/slider/internal/SliderTrack.js +26 -22
  1005. package/dist-es/slider/internal/SliderTrack.js.map +1 -1
  1006. package/dist-es/slider/internal/useKeyDownThumb.js +1 -2
  1007. package/dist-es/slider/internal/useKeyDownThumb.js.map +1 -1
  1008. package/dist-es/slider/internal/utils.js +5 -10
  1009. package/dist-es/slider/internal/utils.js.map +1 -1
  1010. package/dist-es/static-list/StaticList.js +1 -6
  1011. package/dist-es/static-list/StaticList.js.map +1 -1
  1012. package/dist-es/static-list/StaticListItem.js +1 -6
  1013. package/dist-es/static-list/StaticListItem.js.map +1 -1
  1014. package/dist-es/static-list/StaticListItemContent.js +1 -6
  1015. package/dist-es/static-list/StaticListItemContent.js.map +1 -1
  1016. package/dist-es/stepped-tracker/StepLabel/StepLabel.js +1 -8
  1017. package/dist-es/stepped-tracker/StepLabel/StepLabel.js.map +1 -1
  1018. package/dist-es/stepped-tracker/SteppedTracker.js +6 -10
  1019. package/dist-es/stepped-tracker/SteppedTracker.js.map +1 -1
  1020. package/dist-es/stepped-tracker/SteppedTrackerContext.js +2 -8
  1021. package/dist-es/stepped-tracker/SteppedTrackerContext.js.map +1 -1
  1022. package/dist-es/stepped-tracker/TrackerConnector/TrackerConnector.js +1 -3
  1023. package/dist-es/stepped-tracker/TrackerConnector/TrackerConnector.js.map +1 -1
  1024. package/dist-es/stepped-tracker/TrackerStep/TrackerStep.js +24 -29
  1025. package/dist-es/stepped-tracker/TrackerStep/TrackerStep.js.map +1 -1
  1026. package/dist-es/stepper-input/StepperInput.js +84 -87
  1027. package/dist-es/stepper-input/StepperInput.js.map +1 -1
  1028. package/dist-es/stepper-input/internal/useActivateWhileMouseDown.js +2 -4
  1029. package/dist-es/stepper-input/internal/useActivateWhileMouseDown.js.map +1 -1
  1030. package/dist-es/stepper-input/internal/useInterval.js.map +1 -1
  1031. package/dist-es/stepper-input/internal/utils.js +5 -10
  1032. package/dist-es/stepper-input/internal/utils.js.map +1 -1
  1033. package/dist-es/stepper-input/useStepperInput.js +6 -12
  1034. package/dist-es/stepper-input/useStepperInput.js.map +1 -1
  1035. package/dist-es/system-status/SystemStatus.js +13 -13
  1036. package/dist-es/system-status/SystemStatus.js.map +1 -1
  1037. package/dist-es/system-status/SystemStatusActions.js +1 -5
  1038. package/dist-es/system-status/SystemStatusActions.js.map +1 -1
  1039. package/dist-es/system-status/SystemStatusContent.js +1 -5
  1040. package/dist-es/system-status/SystemStatusContent.js.map +1 -1
  1041. package/dist-es/tabs/Tab.js +74 -55
  1042. package/dist-es/tabs/Tab.js.map +1 -1
  1043. package/dist-es/tabs/TabActivationIndicator.js +1 -8
  1044. package/dist-es/tabs/TabActivationIndicator.js.map +1 -1
  1045. package/dist-es/tabs/TabPanel.js +11 -8
  1046. package/dist-es/tabs/TabPanel.js.map +1 -1
  1047. package/dist-es/tabs/Tabs.js +21 -15
  1048. package/dist-es/tabs/Tabs.js.map +1 -1
  1049. package/dist-es/tabs/Tabstrip.js +86 -70
  1050. package/dist-es/tabs/Tabstrip.js.map +1 -1
  1051. package/dist-es/tabs/drag-drop/Draggable.js +5 -4
  1052. package/dist-es/tabs/drag-drop/Draggable.js.map +1 -1
  1053. package/dist-es/tabs/drag-drop/drag-utils.js +1 -2
  1054. package/dist-es/tabs/drag-drop/drag-utils.js.map +1 -1
  1055. package/dist-es/tabs/drag-drop/useDragDrop.js.map +1 -1
  1056. package/dist-es/tabs/drag-drop/useDragDropNaturalMovement.js +9 -6
  1057. package/dist-es/tabs/drag-drop/useDragDropNaturalMovement.js.map +1 -1
  1058. package/dist-es/tabs/drag-drop/useDragSpacers.js +1 -0
  1059. package/dist-es/tabs/drag-drop/useDragSpacers.js.map +1 -1
  1060. package/dist-es/tabs/useActivationIndicator.js.map +1 -1
  1061. package/dist-es/tabs/useEditableItem.js.map +1 -1
  1062. package/dist-es/tabs/useItemsWithIds.js +1 -5
  1063. package/dist-es/tabs/useItemsWithIds.js.map +1 -1
  1064. package/dist-es/tabs/useKeyboardNavigation.js.map +1 -1
  1065. package/dist-es/tabs/useSelection.js +1 -1
  1066. package/dist-es/tabs/useSelection.js.map +1 -1
  1067. package/dist-es/tabs/useTabs.js +3 -3
  1068. package/dist-es/tabs/useTabs.js.map +1 -1
  1069. package/dist-es/tabs/useTabstrip.js +3 -1
  1070. package/dist-es/tabs/useTabstrip.js.map +1 -1
  1071. package/dist-es/tabs-next/TabBar.css.js +4 -0
  1072. package/dist-es/tabs-next/TabBar.css.js.map +1 -0
  1073. package/dist-es/tabs-next/TabBar.js +39 -0
  1074. package/dist-es/tabs-next/TabBar.js.map +1 -0
  1075. package/dist-es/tabs-next/TabListNext.css.js +4 -0
  1076. package/dist-es/tabs-next/TabListNext.css.js.map +1 -0
  1077. package/dist-es/tabs-next/TabListNext.js +125 -0
  1078. package/dist-es/tabs-next/TabListNext.js.map +1 -0
  1079. package/dist-es/tabs-next/TabNext.css.js +1 -1
  1080. package/dist-es/tabs-next/TabNext.js +77 -55
  1081. package/dist-es/tabs-next/TabNext.js.map +1 -1
  1082. package/dist-es/tabs-next/TabNextAction.js +33 -0
  1083. package/dist-es/tabs-next/TabNextAction.js.map +1 -0
  1084. package/dist-es/tabs-next/TabNextContext.js +14 -14
  1085. package/dist-es/tabs-next/TabNextContext.js.map +1 -1
  1086. package/dist-es/tabs-next/TabNextPanel.css.js +4 -0
  1087. package/dist-es/tabs-next/TabNextPanel.css.js.map +1 -0
  1088. package/dist-es/tabs-next/TabNextPanel.js +75 -0
  1089. package/dist-es/tabs-next/TabNextPanel.js.map +1 -0
  1090. package/dist-es/tabs-next/TabNextTrigger.css.js +4 -0
  1091. package/dist-es/tabs-next/TabNextTrigger.css.js.map +1 -0
  1092. package/dist-es/tabs-next/TabNextTrigger.js +75 -0
  1093. package/dist-es/tabs-next/TabNextTrigger.js.map +1 -0
  1094. package/dist-es/tabs-next/TabOverflowList.css.js +4 -0
  1095. package/dist-es/tabs-next/TabOverflowList.css.js.map +1 -0
  1096. package/dist-es/tabs-next/TabOverflowList.js +130 -0
  1097. package/dist-es/tabs-next/TabOverflowList.js.map +1 -0
  1098. package/dist-es/tabs-next/TabsNext.js +174 -0
  1099. package/dist-es/tabs-next/TabsNext.js.map +1 -0
  1100. package/dist-es/tabs-next/TabsNextContext.js +30 -0
  1101. package/dist-es/tabs-next/TabsNextContext.js.map +1 -0
  1102. package/dist-es/tabs-next/hooks/useCollection.js +89 -0
  1103. package/dist-es/tabs-next/hooks/useCollection.js.map +1 -0
  1104. package/dist-es/tabs-next/hooks/useFocusOutside.js +23 -0
  1105. package/dist-es/tabs-next/hooks/useFocusOutside.js.map +1 -0
  1106. package/dist-es/tabs-next/hooks/useOverflow.js +139 -0
  1107. package/dist-es/tabs-next/hooks/useOverflow.js.map +1 -0
  1108. package/dist-es/toast-group/ToastGroup.js +8 -5
  1109. package/dist-es/toast-group/ToastGroup.js.map +1 -1
  1110. package/dist-es/tokenized-input/TokenizedInput.js +9 -6
  1111. package/dist-es/tokenized-input/TokenizedInput.js.map +1 -1
  1112. package/dist-es/tokenized-input/TokenizedInputBase.js +104 -89
  1113. package/dist-es/tokenized-input/TokenizedInputBase.js.map +1 -1
  1114. package/dist-es/tokenized-input/internal/InputPill.js +24 -24
  1115. package/dist-es/tokenized-input/internal/InputPill.js.map +1 -1
  1116. package/dist-es/tokenized-input/internal/InputRuler.js +1 -5
  1117. package/dist-es/tokenized-input/internal/InputRuler.js.map +1 -1
  1118. package/dist-es/tokenized-input/internal/calcFirstHiddenIndex.js.map +1 -1
  1119. package/dist-es/tokenized-input/internal/defaultItemToString.js.map +1 -1
  1120. package/dist-es/tokenized-input/internal/getCursorPosition.js.map +1 -1
  1121. package/dist-es/tokenized-input/internal/useResizeObserver.js.map +1 -1
  1122. package/dist-es/tokenized-input/internal/useWidth.js.map +1 -1
  1123. package/dist-es/tokenized-input/useTokenizedInput.js +10 -0
  1124. package/dist-es/tokenized-input/useTokenizedInput.js.map +1 -1
  1125. package/dist-es/tokenized-input-next/TokenizedInputNext.js +68 -56
  1126. package/dist-es/tokenized-input-next/TokenizedInputNext.js.map +1 -1
  1127. package/dist-es/tokenized-input-next/internal/InputPill.js +6 -10
  1128. package/dist-es/tokenized-input-next/internal/InputPill.js.map +1 -1
  1129. package/dist-es/tokenized-input-next/internal/calcFirstHiddenIndex.js.map +1 -1
  1130. package/dist-es/tokenized-input-next/internal/useResizeObserver.js.map +1 -1
  1131. package/dist-es/tokenized-input-next/internal/useWidth.js +1 -1
  1132. package/dist-es/tokenized-input-next/internal/useWidth.js.map +1 -1
  1133. package/dist-es/tokenized-input-next/useTokenizedInputNext.js +8 -3
  1134. package/dist-es/tokenized-input-next/useTokenizedInputNext.js.map +1 -1
  1135. package/dist-es/toolbar/Toolbar.js +43 -33
  1136. package/dist-es/toolbar/Toolbar.js.map +1 -1
  1137. package/dist-es/toolbar/ToolbarButton.js +10 -7
  1138. package/dist-es/toolbar/ToolbarButton.js.map +1 -1
  1139. package/dist-es/toolbar/Tooltray.js +23 -27
  1140. package/dist-es/toolbar/Tooltray.js.map +1 -1
  1141. package/dist-es/toolbar/internal/renderToolbarItems.js +7 -10
  1142. package/dist-es/toolbar/internal/renderToolbarItems.js.map +1 -1
  1143. package/dist-es/toolbar/internal/renderTrayTools.js +23 -16
  1144. package/dist-es/toolbar/internal/renderTrayTools.js.map +1 -1
  1145. package/dist-es/toolbar/overflow-panel/OverflowPanel.js +40 -41
  1146. package/dist-es/toolbar/overflow-panel/OverflowPanel.js.map +1 -1
  1147. package/dist-es/toolbar/overflow-panel/OverflowSeparator.js +1 -4
  1148. package/dist-es/toolbar/overflow-panel/OverflowSeparator.js.map +1 -1
  1149. package/dist-es/toolbar/toolbar-field/ToolbarField.js +1 -4
  1150. package/dist-es/toolbar/toolbar-field/ToolbarField.js.map +1 -1
  1151. package/dist-es/toolbar/toolbar-field/useToolbarField.js +2 -2
  1152. package/dist-es/toolbar/toolbar-field/useToolbarField.js.map +1 -1
  1153. package/dist-es/tree/Tree.js +57 -46
  1154. package/dist-es/tree/Tree.js.map +1 -1
  1155. package/dist-es/tree/TreeNode.js +11 -23
  1156. package/dist-es/tree/TreeNode.js.map +1 -1
  1157. package/dist-es/tree/use-tree-keyboard-navigation.js.map +1 -1
  1158. package/dist-es/tree/useTree.js +11 -4
  1159. package/dist-es/tree/useTree.js.map +1 -1
  1160. package/dist-es/utils/escapeRegExp.js.map +1 -1
  1161. package/dist-es/utils/forwardCallbackProps.js.map +1 -1
  1162. package/dist-es/utils/isEmail.js.map +1 -1
  1163. package/dist-es/utils/partition.js.map +1 -1
  1164. package/dist-es/utils/useClickOutside.js +1 -1
  1165. package/dist-es/utils/useClickOutside.js.map +1 -1
  1166. package/dist-es/utils/useEventCallback.js +4 -1
  1167. package/dist-es/utils/useEventCallback.js.map +1 -1
  1168. package/dist-es/utils/useIsViewportLargerThanBreakpoint.js.map +1 -1
  1169. package/dist-es/utils/useLayoutEffectOnce.js.map +1 -1
  1170. package/dist-es/utils/useLayoutEffectSkipFirst.js.map +1 -1
  1171. package/dist-es/utils/useOverflowDetection.js.map +1 -1
  1172. package/dist-es/utils/useSlideSelection.js.map +1 -1
  1173. package/dist-es/window/ElectronWindow.js +6 -14
  1174. package/dist-es/window/ElectronWindow.js.map +1 -1
  1175. package/dist-es/window/WindowContext.js +1 -5
  1176. package/dist-es/window/WindowContext.js.map +1 -1
  1177. package/dist-es/window/desktop-utils.js.map +1 -1
  1178. package/dist-types/contact-details/internal/StarIcon.d.ts +1 -2
  1179. package/dist-types/contact-details/internal/StarIconContainer.d.ts +2 -2
  1180. package/dist-types/date-picker/DatePickerActions.d.ts +3 -3
  1181. package/dist-types/dialog/DialogHeader.d.ts +28 -0
  1182. package/dist-types/dialog/index.d.ts +1 -0
  1183. package/dist-types/editable-label/EditableLabel.d.ts +1 -2
  1184. package/dist-types/index.d.ts +1 -0
  1185. package/dist-types/list-deprecated/internal/DescendantContext.d.ts +1 -2
  1186. package/dist-types/responsive/overflowUtils.d.ts +1 -1
  1187. package/dist-types/tabs/drag-drop/drag-utils.d.ts +6 -6
  1188. package/dist-types/tabs-next/TabBar.d.ts +12 -0
  1189. package/dist-types/tabs-next/TabListNext.d.ts +12 -0
  1190. package/dist-types/tabs-next/TabNext.d.ts +9 -2
  1191. package/dist-types/tabs-next/TabNextAction.d.ts +4 -0
  1192. package/dist-types/tabs-next/TabNextContext.d.ts +9 -16
  1193. package/dist-types/tabs-next/TabNextPanel.d.ts +8 -0
  1194. package/dist-types/tabs-next/TabNextTrigger.d.ts +4 -0
  1195. package/dist-types/tabs-next/TabOverflowList.d.ts +11 -0
  1196. package/dist-types/tabs-next/TabsNext.d.ts +17 -0
  1197. package/dist-types/tabs-next/TabsNextContext.d.ts +21 -0
  1198. package/dist-types/tabs-next/hooks/useCollection.d.ts +18 -0
  1199. package/dist-types/tabs-next/hooks/useFocusOutside.d.ts +2 -0
  1200. package/dist-types/tabs-next/hooks/useOverflow.d.ts +11 -0
  1201. package/dist-types/tabs-next/index.d.ts +6 -1
  1202. package/package.json +9 -8
  1203. package/dist-cjs/tabs-next/OverflowMenu.js +0 -48
  1204. package/dist-cjs/tabs-next/OverflowMenu.js.map +0 -1
  1205. package/dist-cjs/tabs-next/TabstripNext.css.js +0 -6
  1206. package/dist-cjs/tabs-next/TabstripNext.css.js.map +0 -1
  1207. package/dist-cjs/tabs-next/TabstripNext.js +0 -193
  1208. package/dist-cjs/tabs-next/TabstripNext.js.map +0 -1
  1209. package/dist-es/tabs-next/OverflowMenu.js +0 -44
  1210. package/dist-es/tabs-next/OverflowMenu.js.map +0 -1
  1211. package/dist-es/tabs-next/TabstripNext.css.js +0 -4
  1212. package/dist-es/tabs-next/TabstripNext.css.js.map +0 -1
  1213. package/dist-es/tabs-next/TabstripNext.js +0 -185
  1214. package/dist-es/tabs-next/TabstripNext.js.map +0 -1
  1215. package/dist-types/tabs-next/OverflowMenu.d.ts +0 -11
  1216. package/dist-types/tabs-next/TabstripNext.d.ts +0 -12
@@ -0,0 +1,125 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { makePrefixer, useForkRef, useIsomorphicLayoutEffect, capitalize } from '@salt-ds/core';
3
+ import { useComponentCssInjection } from '@salt-ds/styles';
4
+ import { useWindow } from '@salt-ds/window';
5
+ import { clsx } from 'clsx';
6
+ import { forwardRef, useRef } from 'react';
7
+ import css_248z from './TabListNext.css.js';
8
+ import { TabOverflowList } from './TabOverflowList.js';
9
+ import { useTabsNext } from './TabsNextContext.js';
10
+ import { useOverflow } from './hooks/useOverflow.js';
11
+
12
+ const withBaseName = makePrefixer("saltTabListNext");
13
+ const TabListNext = forwardRef(
14
+ function TabstripNext(props, ref) {
15
+ const {
16
+ appearance = "bordered",
17
+ activeColor = "primary",
18
+ children,
19
+ className,
20
+ onKeyDown,
21
+ ...rest
22
+ } = props;
23
+ const targetWindow = useWindow();
24
+ useComponentCssInjection({
25
+ testId: "salt-tablist-next",
26
+ css: css_248z,
27
+ window: targetWindow
28
+ });
29
+ const {
30
+ selected,
31
+ getNext,
32
+ getPrevious,
33
+ getFirst,
34
+ getLast,
35
+ items,
36
+ activeTab,
37
+ menuOpen,
38
+ setMenuOpen,
39
+ returnFocus
40
+ } = useTabsNext();
41
+ const tabstripRef = useRef(null);
42
+ const handleRef = useForkRef(tabstripRef, ref);
43
+ const overflowButtonRef = useRef(null);
44
+ const [visible, hidden, isMeasuring] = useOverflow({
45
+ container: tabstripRef,
46
+ tabs: items,
47
+ children,
48
+ selected,
49
+ overflowButton: overflowButtonRef
50
+ });
51
+ const handleKeyDown = (event) => {
52
+ var _a, _b, _c;
53
+ onKeyDown == null ? void 0 : onKeyDown(event);
54
+ const actionMap = {
55
+ ArrowRight: getNext,
56
+ ArrowLeft: getPrevious,
57
+ Home: getFirst,
58
+ End: getLast,
59
+ ArrowUp: menuOpen ? getPrevious : void 0,
60
+ ArrowDown: menuOpen ? getNext : void 0
61
+ };
62
+ const action = actionMap[event.key];
63
+ if (action) {
64
+ event.preventDefault();
65
+ const activeTabId = (_a = activeTab.current) == null ? void 0 : _a.id;
66
+ if (!activeTabId) return;
67
+ const nextItem = action(activeTabId);
68
+ if (nextItem) {
69
+ (_b = nextItem.element) == null ? void 0 : _b.scrollIntoView({
70
+ block: "nearest",
71
+ inline: "nearest"
72
+ });
73
+ (_c = nextItem.element) == null ? void 0 : _c.focus({ preventScroll: true });
74
+ }
75
+ }
76
+ };
77
+ useIsomorphicLayoutEffect(() => {
78
+ var _a;
79
+ if (!returnFocus.current || visible.length < 1 || selected === void 0)
80
+ return;
81
+ const itemToFocus = items.find((i) => i.value === returnFocus.current);
82
+ (_a = itemToFocus == null ? void 0 : itemToFocus.element) == null ? void 0 : _a.focus({ preventScroll: true });
83
+ requestAnimationFrame(() => {
84
+ var _a2;
85
+ if (((_a2 = targetWindow == null ? void 0 : targetWindow.document) == null ? void 0 : _a2.activeElement) === (itemToFocus == null ? void 0 : itemToFocus.element)) {
86
+ returnFocus.current = void 0;
87
+ }
88
+ });
89
+ }, [visible, returnFocus, targetWindow, items, selected]);
90
+ return /* @__PURE__ */ jsxs(
91
+ "div",
92
+ {
93
+ role: "tablist",
94
+ className: clsx(
95
+ withBaseName(),
96
+ withBaseName(appearance),
97
+ withBaseName("horizontal"),
98
+ withBaseName(`activeColor${capitalize(activeColor)}`),
99
+ className
100
+ ),
101
+ "data-ismeasuring": isMeasuring ? true : void 0,
102
+ ref: handleRef,
103
+ onKeyDown: handleKeyDown,
104
+ ...rest,
105
+ children: [
106
+ visible,
107
+ /* @__PURE__ */ jsx(
108
+ TabOverflowList,
109
+ {
110
+ isMeasuring,
111
+ buttonRef: overflowButtonRef,
112
+ tabstripRef,
113
+ open: menuOpen,
114
+ setOpen: setMenuOpen,
115
+ children: hidden
116
+ }
117
+ )
118
+ ]
119
+ }
120
+ );
121
+ }
122
+ );
123
+
124
+ export { TabListNext };
125
+ //# sourceMappingURL=TabListNext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TabListNext.js","sources":["../src/tabs-next/TabListNext.tsx"],"sourcesContent":["import {\n capitalize,\n makePrefixer,\n useForkRef,\n useIsomorphicLayoutEffect,\n} from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport {\n type ComponentPropsWithoutRef,\n type KeyboardEvent,\n forwardRef,\n useRef,\n} from \"react\";\n\nimport tablistNextCss from \"./TabListNext.css\";\nimport { TabOverflowList } from \"./TabOverflowList\";\nimport { useTabsNext } from \"./TabsNextContext\";\nimport { useOverflow } from \"./hooks/useOverflow\";\n\nconst withBaseName = makePrefixer(\"saltTabListNext\");\n\nexport interface TabListNextProps\n extends Omit<ComponentPropsWithoutRef<\"div\">, \"onChange\"> {\n /**\n * Styling active color variant. Defaults to \"primary\".\n */\n activeColor?: \"primary\" | \"secondary\" | \"tertiary\";\n /**\n * The appearance of the tabs. Defaults to \"bordered\".\n */\n appearance?: \"bordered\" | \"transparent\";\n}\n\nexport const TabListNext = forwardRef<HTMLDivElement, TabListNextProps>(\n function TabstripNext(props, ref) {\n const {\n appearance = \"bordered\",\n activeColor = \"primary\",\n children,\n className,\n onKeyDown,\n ...rest\n } = props;\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-tablist-next\",\n css: tablistNextCss,\n window: targetWindow,\n });\n\n const {\n selected,\n getNext,\n getPrevious,\n getFirst,\n getLast,\n items,\n activeTab,\n menuOpen,\n setMenuOpen,\n returnFocus,\n } = useTabsNext();\n\n const tabstripRef = useRef<HTMLDivElement>(null);\n const handleRef = useForkRef(tabstripRef, ref);\n const overflowButtonRef = useRef<HTMLButtonElement>(null);\n\n const [visible, hidden, isMeasuring] = useOverflow({\n container: tabstripRef,\n tabs: items,\n children,\n selected,\n overflowButton: overflowButtonRef,\n });\n\n const handleKeyDown = (event: KeyboardEvent<HTMLDivElement>) => {\n onKeyDown?.(event);\n\n const actionMap = {\n ArrowRight: getNext,\n ArrowLeft: getPrevious,\n Home: getFirst,\n End: getLast,\n ArrowUp: menuOpen ? getPrevious : undefined,\n ArrowDown: menuOpen ? getNext : undefined,\n };\n\n const action = actionMap[event.key as keyof typeof actionMap];\n\n if (action) {\n event.preventDefault();\n const activeTabId = activeTab.current?.id;\n if (!activeTabId) return;\n const nextItem = action(activeTabId);\n if (nextItem) {\n nextItem.element?.scrollIntoView({\n block: \"nearest\",\n inline: \"nearest\",\n });\n nextItem.element?.focus({ preventScroll: true });\n }\n }\n };\n\n useIsomorphicLayoutEffect(() => {\n if (!returnFocus.current || visible.length < 1 || selected === undefined)\n return;\n\n const itemToFocus = items.find((i) => i.value === returnFocus.current);\n itemToFocus?.element?.focus({ preventScroll: true });\n\n requestAnimationFrame(() => {\n if (targetWindow?.document?.activeElement === itemToFocus?.element) {\n returnFocus.current = undefined;\n }\n });\n }, [visible, returnFocus, targetWindow, items, selected]);\n\n return (\n <div\n role=\"tablist\"\n className={clsx(\n withBaseName(),\n withBaseName(appearance),\n withBaseName(\"horizontal\"),\n withBaseName(`activeColor${capitalize(activeColor)}`),\n className,\n )}\n data-ismeasuring={isMeasuring ? true : undefined}\n ref={handleRef}\n onKeyDown={handleKeyDown}\n {...rest}\n >\n {visible}\n <TabOverflowList\n isMeasuring={isMeasuring}\n buttonRef={overflowButtonRef}\n tabstripRef={tabstripRef}\n open={menuOpen}\n setOpen={setMenuOpen}\n >\n {hidden}\n </TabOverflowList>\n </div>\n );\n },\n);\n"],"names":["tablistNextCss","_a"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- var css_248z = "/* Class applied to root Tab element */\n.saltTabNext {\n align-items: center;\n justify-content: center;\n appearance: none;\n -webkit-appearance: none;\n display: inline-flex;\n background: var(--salt-navigable-primary-background);\n gap: var(--salt-spacing-100);\n border: none;\n border-left: var(--salt-size-border) var(--salt-container-borderStyle) transparent;\n border-right: var(--salt-size-border) var(--salt-container-borderStyle) transparent;\n border-radius: 0;\n white-space: pre;\n min-height: calc(var(--salt-size-base) + var(--salt-spacing-100));\n min-width: 4em;\n padding: var(--salt-spacing-50) var(--salt-spacing-100);\n position: relative;\n flex-shrink: 0;\n box-sizing: border-box;\n\n cursor: var(--salt-navigable-cursor-hover);\n color: var(--salt-content-primary-foreground);\n font-weight: var(--salt-navigable-fontWeight);\n font-family: var(--salt-text-fontFamily);\n text-align: var(--salt-text-textAlign);\n letter-spacing: var(--salt-text-letterSpacing);\n line-height: var(--salt-text-lineHeight);\n font-size: var(--salt-text-fontSize);\n}\n\n.saltTabNext-primary {\n --tabNext-background-active: var(--salt-container-primary-background);\n}\n\n.saltTabNext-secondary {\n --tabNext-background-active: var(--salt-container-secondary-background);\n}\n\n.saltTabNext::after {\n content: \"\";\n position: absolute;\n left: calc(var(--salt-size-border) * -1);\n right: calc(var(--salt-size-border) * -1);\n height: var(--salt-size-indicator);\n}\n\n.saltTabNext-main::after {\n top: 0;\n}\n\n.saltTabNext-inline::after {\n bottom: 0;\n}\n\n.saltTabNext:hover::after,\n.saltTabNext:focus-visible::after {\n background: var(--salt-navigable-indicator-hover);\n}\n\n.saltTabNext:disabled:hover::after,\n.saltTabNext:disabled:focus-visible::after {\n background: none;\n}\n\n.saltTabNext:focus-visible {\n outline: var(--salt-focused-outline);\n}\n\n.saltTabNext-main[aria-selected=\"true\"] {\n background: var(--tabNext-background-active);\n border-left: var(--salt-size-border) var(--salt-separable-borderStyle) var(--salt-separable-secondary-borderColor);\n border-right: var(--salt-size-border) var(--salt-separable-borderStyle) var(--salt-separable-secondary-borderColor);\n}\n\n.saltTabNext[aria-selected=\"true\"]::after {\n background: var(--salt-navigable-indicator-active);\n}\n\n.saltTabNext:disabled {\n cursor: var(--salt-navigable-cursor-disabled);\n color: var(--salt-content-primary-foreground-disabled);\n}\n";
1
+ var css_248z = "/* Class applied to root Tab element */\n.saltTabNext {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n appearance: none;\n -webkit-appearance: none;\n gap: var(--salt-spacing-100);\n border: none;\n border-left: var(--salt-size-border) var(--salt-container-borderStyle) transparent;\n border-right: var(--salt-size-border) var(--salt-container-borderStyle) transparent;\n white-space: pre;\n min-height: calc(var(--salt-size-base) + var(--salt-spacing-100));\n min-width: 4em;\n padding: var(--salt-spacing-50) var(--salt-spacing-100);\n position: relative;\n flex-shrink: 0;\n box-sizing: border-box;\n --tabNext-radius: var(--salt-palette-corner-weak, 0);\n border-radius: var(--tab-radius) var(--tab-radius) 0 0;\n overflow: hidden;\n\n cursor: var(--salt-navigable-cursor-hover);\n color: var(--salt-content-primary-foreground);\n font-weight: var(--salt-navigable-fontWeight);\n font-family: var(--salt-text-fontFamily);\n text-align: var(--salt-text-textAlign);\n letter-spacing: var(--salt-text-letterSpacing);\n line-height: var(--salt-text-lineHeight);\n font-size: var(--salt-text-fontSize);\n}\n\n.saltTabNext::after {\n content: \"\";\n position: absolute;\n left: calc(var(--salt-size-border) * -1);\n right: calc(var(--salt-size-border) * -1);\n height: var(--salt-size-indicator);\n}\n\n.saltTabListNext-bordered .saltTabNext::after {\n top: 0;\n}\n\n.saltTabListNext-transparent .saltTabNext::after {\n bottom: 0;\n}\n\n.saltTabNext:hover::after,\n.saltTabNext-focusVisible::after {\n background: var(--salt-navigable-indicator-hover);\n}\n\n.saltTabNext-disabled:hover::after,\n.saltTabNext-disabled.saltTabNext-focusVisible::after {\n background: none;\n}\n\n.saltTabNext-focusVisible {\n outline: var(--salt-focused-outline);\n}\n\n.saltTabListNext-bordered .saltTabNext.saltTabNext-selected {\n background: var(--saltTabListNext-activeColor);\n border-left: var(--salt-size-border) var(--salt-separable-borderStyle) var(--salt-separable-secondary-borderColor);\n border-right: var(--salt-size-border) var(--salt-separable-borderStyle) var(--salt-separable-secondary-borderColor);\n}\n\n.saltTabNext.saltTabNext-selected::after {\n background: var(--salt-navigable-indicator-active);\n}\n\n.saltTabNext.saltTabNext-disabled {\n cursor: var(--salt-navigable-cursor-disabled);\n color: var(--salt-content-primary-foreground-disabled);\n}\n";
2
2
 
3
3
  export { css_248z as default };
4
4
  //# sourceMappingURL=TabNext.css.js.map
@@ -1,23 +1,27 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
- import { makePrefixer } from '@salt-ds/core';
2
+ import { makePrefixer, useId } from '@salt-ds/core';
3
3
  import { useComponentCssInjection } from '@salt-ds/styles';
4
4
  import { useWindow } from '@salt-ds/window';
5
- import { forwardRef, useEffect } from 'react';
6
- import { OverflowItem } from '@fluentui/react-overflow';
7
- import clsx from 'clsx';
5
+ import { clsx } from 'clsx';
6
+ import { forwardRef, useRef, useState, useCallback, useMemo } from 'react';
8
7
  import css_248z from './TabNext.css.js';
9
- import { useTabs } from './TabNextContext.js';
8
+ import { TabNextContext } from './TabNextContext.js';
9
+ import { useTabsNext } from './TabsNextContext.js';
10
10
 
11
11
  const withBaseName = makePrefixer("saltTabNext");
12
12
  const TabNext = forwardRef(
13
13
  function Tab(props, ref) {
14
14
  const {
15
+ "aria-labelledby": ariaLabelledBy,
15
16
  children,
16
17
  className,
17
18
  disabled: disabledProp,
18
- onClick,
19
+ onBlur,
20
+ onMouseDown,
19
21
  onFocus,
22
+ onFocusCapture,
20
23
  value,
24
+ id: idProp,
21
25
  ...rest
22
26
  } = props;
23
27
  const targetWindow = useWindow();
@@ -26,59 +30,77 @@ const TabNext = forwardRef(
26
30
  css: css_248z,
27
31
  window: targetWindow
28
32
  });
29
- const {
30
- activeColor,
31
- isActive,
32
- activate,
33
- isFocusable,
34
- setFocusable,
35
- disabled: tabstripDisabled,
36
- unregisterTab,
37
- registerTab,
38
- variant
39
- } = useTabs();
40
- const active = isActive(value);
41
- const focusable = isFocusable(value);
42
- const disabled = tabstripDisabled || disabledProp;
43
- const handleClick = (event) => {
44
- activate(event);
45
- onClick == null ? void 0 : onClick(event);
33
+ const { selected, activeTab } = useTabsNext();
34
+ const disabled = !!disabledProp;
35
+ const id = useId(idProp);
36
+ const wasMouseDown = useRef(false);
37
+ const [focusVisible, setFocusVisible] = useState(false);
38
+ const [focused, setFocused] = useState(false);
39
+ const handleFocusCapture = (event) => {
40
+ onFocusCapture == null ? void 0 : onFocusCapture(event);
41
+ if (value && id) {
42
+ activeTab.current = { value, id };
43
+ }
46
44
  };
47
45
  const handleFocus = (event) => {
48
- setFocusable(value);
49
46
  onFocus == null ? void 0 : onFocus(event);
47
+ setFocused(true);
48
+ if (!wasMouseDown.current && event.target.getAttribute("role") === "tab") {
49
+ setFocusVisible(true);
50
+ }
51
+ wasMouseDown.current = false;
50
52
  };
51
- useEffect(() => {
52
- registerTab({ value, label: children });
53
- return () => unregisterTab(value);
54
- }, [children, registerTab, unregisterTab, value]);
55
- return /* @__PURE__ */ jsx(OverflowItem, {
56
- id: value,
57
- priority: active ? 2 : 1,
58
- children: /* @__PURE__ */ jsx("div", {
59
- className: withBaseName("wrapper"),
60
- children: /* @__PURE__ */ jsx("button", {
61
- className: clsx(
62
- withBaseName(),
63
- withBaseName(variant),
64
- withBaseName(activeColor),
65
- className
66
- ),
67
- "data-value": value,
68
- "aria-selected": active,
69
- disabled,
70
- value,
71
- ref,
72
- role: "tab",
73
- onClick: handleClick,
74
- onFocus: handleFocus,
75
- tabIndex: focusable && !disabled ? 0 : -1,
76
- type: "button",
77
- ...rest,
78
- children
79
- })
80
- })
81
- });
53
+ const handleBlur = (event) => {
54
+ onBlur == null ? void 0 : onBlur(event);
55
+ setFocused(false);
56
+ setFocusVisible(false);
57
+ };
58
+ const handleMouseDown = (event) => {
59
+ onMouseDown == null ? void 0 : onMouseDown(event);
60
+ wasMouseDown.current = true;
61
+ };
62
+ const [actions, setActions] = useState([]);
63
+ const registerAction = useCallback((id2) => {
64
+ setActions((old) => old.concat(id2));
65
+ return () => {
66
+ setActions((old) => old.filter((action) => action !== id2));
67
+ };
68
+ }, []);
69
+ const context = useMemo(
70
+ () => ({
71
+ tabId: id,
72
+ selected: selected === value,
73
+ focused,
74
+ value,
75
+ disabled,
76
+ actions,
77
+ registerAction
78
+ }),
79
+ [id, selected, value, focused, disabled, actions, registerAction]
80
+ );
81
+ return /* @__PURE__ */ jsx(TabNextContext.Provider, { value: context, children: /* @__PURE__ */ jsx(
82
+ "div",
83
+ {
84
+ className: clsx(
85
+ withBaseName(),
86
+ {
87
+ [withBaseName("selected")]: selected === value,
88
+ [withBaseName("disabled")]: disabled,
89
+ [withBaseName("focusVisible")]: focusVisible
90
+ },
91
+ className
92
+ ),
93
+ "data-overflowitem": "true",
94
+ ref,
95
+ onMouseDown: handleMouseDown,
96
+ onFocusCapture: handleFocusCapture,
97
+ onFocus: handleFocus,
98
+ onBlur: handleBlur,
99
+ role: "presentation",
100
+ ...rest,
101
+ children
102
+ }
103
+ ) });
82
104
  }
83
105
  );
84
106
 
@@ -1 +1 @@
1
- {"version":3,"file":"TabNext.js","sources":["../src/tabs-next/TabNext.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport {\n type ComponentPropsWithoutRef,\n type FocusEvent,\n type MouseEvent,\n type ReactElement,\n forwardRef,\n useEffect,\n} from \"react\";\n\nimport { OverflowItem } from \"@fluentui/react-overflow\";\nimport clsx from \"clsx\";\nimport tabCss from \"./TabNext.css\";\nimport { useTabs } from \"./TabNextContext\";\n\nconst withBaseName = makePrefixer(\"saltTabNext\");\n\nexport interface TabNextProps extends ComponentPropsWithoutRef<\"button\"> {\n /* Value prop is mandatory and must be unique in order for overflow to work. */\n value: string;\n}\n\nexport const TabNext = forwardRef<HTMLButtonElement, TabNextProps>(\n function Tab(props, ref): ReactElement<TabNextProps> {\n const {\n children,\n className,\n disabled: disabledProp,\n onClick,\n onFocus,\n value,\n ...rest\n } = props;\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-tab-next\",\n css: tabCss,\n window: targetWindow,\n });\n const {\n activeColor,\n isActive,\n activate,\n isFocusable,\n setFocusable,\n disabled: tabstripDisabled,\n unregisterTab,\n registerTab,\n variant,\n } = useTabs();\n const active = isActive(value);\n const focusable = isFocusable(value);\n const disabled = tabstripDisabled || disabledProp;\n\n const handleClick = (event: MouseEvent<HTMLButtonElement>) => {\n activate(event);\n onClick?.(event);\n };\n\n const handleFocus = (event: FocusEvent<HTMLButtonElement>) => {\n setFocusable(value);\n onFocus?.(event);\n };\n\n useEffect(() => {\n registerTab({ value, label: children });\n return () => unregisterTab(value);\n }, [children, registerTab, unregisterTab, value]);\n\n return (\n <OverflowItem id={value} priority={active ? 2 : 1}>\n <div className={withBaseName(\"wrapper\")}>\n <button\n className={clsx(\n withBaseName(),\n withBaseName(variant),\n withBaseName(activeColor),\n className,\n )}\n data-value={value}\n aria-selected={active}\n disabled={disabled}\n value={value}\n ref={ref}\n role=\"tab\"\n onClick={handleClick}\n onFocus={handleFocus}\n tabIndex={focusable && !disabled ? 0 : -1}\n type=\"button\"\n {...rest}\n >\n {children}\n </button>\n </div>\n </OverflowItem>\n );\n },\n);\n"],"names":["tabCss"],"mappings":";;;;;;;;;;AAiBA,MAAM,YAAA,GAAe,aAAa,aAAa,CAAA,CAAA;AAOxC,MAAM,OAAU,GAAA,UAAA;AAAA,EACrB,SAAS,GAAI,CAAA,KAAA,EAAO,GAAiC,EAAA;AACnD,IAAM,MAAA;AAAA,MACJ,QAAA;AAAA,MACA,SAAA;AAAA,MACA,QAAU,EAAA,YAAA;AAAA,MACV,OAAA;AAAA,MACA,OAAA;AAAA,MACA,KAAA;AAAA,MACG,GAAA,IAAA;AAAA,KACD,GAAA,KAAA,CAAA;AACJ,IAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,IAAyB,wBAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,eAAA;AAAA,MACR,GAAK,EAAAA,QAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AACD,IAAM,MAAA;AAAA,MACJ,WAAA;AAAA,MACA,QAAA;AAAA,MACA,QAAA;AAAA,MACA,WAAA;AAAA,MACA,YAAA;AAAA,MACA,QAAU,EAAA,gBAAA;AAAA,MACV,aAAA;AAAA,MACA,WAAA;AAAA,MACA,OAAA;AAAA,QACE,OAAQ,EAAA,CAAA;AACZ,IAAM,MAAA,MAAA,GAAS,SAAS,KAAK,CAAA,CAAA;AAC7B,IAAM,MAAA,SAAA,GAAY,YAAY,KAAK,CAAA,CAAA;AACnC,IAAA,MAAM,WAAW,gBAAoB,IAAA,YAAA,CAAA;AAErC,IAAM,MAAA,WAAA,GAAc,CAAC,KAAyC,KAAA;AAC5D,MAAA,QAAA,CAAS,KAAK,CAAA,CAAA;AACd,MAAU,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,CAAA,KAAA,CAAA,CAAA;AAAA,KACZ,CAAA;AAEA,IAAM,MAAA,WAAA,GAAc,CAAC,KAAyC,KAAA;AAC5D,MAAA,YAAA,CAAa,KAAK,CAAA,CAAA;AAClB,MAAU,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,CAAA,KAAA,CAAA,CAAA;AAAA,KACZ,CAAA;AAEA,IAAA,SAAA,CAAU,MAAM;AACd,MAAA,WAAA,CAAY,EAAE,KAAA,EAAO,KAAO,EAAA,QAAA,EAAU,CAAA,CAAA;AACtC,MAAO,OAAA,MAAM,cAAc,KAAK,CAAA,CAAA;AAAA,OAC/B,CAAC,QAAA,EAAU,WAAa,EAAA,aAAA,EAAe,KAAK,CAAC,CAAA,CAAA;AAEhD,IAAA,uBACG,GAAA,CAAA,YAAA,EAAA;AAAA,MAAa,EAAI,EAAA,KAAA;AAAA,MAAO,QAAA,EAAU,SAAS,CAAI,GAAA,CAAA;AAAA,MAC9C,QAAC,kBAAA,GAAA,CAAA,KAAA,EAAA;AAAA,QAAI,SAAA,EAAW,aAAa,SAAS,CAAA;AAAA,QACpC,QAAC,kBAAA,GAAA,CAAA,QAAA,EAAA;AAAA,UACC,SAAW,EAAA,IAAA;AAAA,YACT,YAAa,EAAA;AAAA,YACb,aAAa,OAAO,CAAA;AAAA,YACpB,aAAa,WAAW,CAAA;AAAA,YACxB,SAAA;AAAA,WACF;AAAA,UACA,YAAY,EAAA,KAAA;AAAA,UACZ,eAAe,EAAA,MAAA;AAAA,UACf,QAAA;AAAA,UACA,KAAA;AAAA,UACA,GAAA;AAAA,UACA,IAAK,EAAA,KAAA;AAAA,UACL,OAAS,EAAA,WAAA;AAAA,UACT,OAAS,EAAA,WAAA;AAAA,UACT,QAAU,EAAA,SAAA,IAAa,CAAC,QAAA,GAAW,CAAI,GAAA,CAAA,CAAA;AAAA,UACvC,IAAK,EAAA,QAAA;AAAA,UACJ,GAAG,IAAA;AAAA,UAEH,QAAA;AAAA,SACH,CAAA;AAAA,OACF,CAAA;AAAA,KACF,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
1
+ {"version":3,"file":"TabNext.js","sources":["../src/tabs-next/TabNext.tsx"],"sourcesContent":["import { makePrefixer, useId } from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport {\n type ComponentPropsWithoutRef,\n type FocusEvent,\n type MouseEvent,\n type ReactElement,\n forwardRef,\n useCallback,\n useMemo,\n useRef,\n useState,\n} from \"react\";\n\nimport tabCss from \"./TabNext.css\";\nimport { TabNextContext } from \"./TabNextContext\";\nimport { useTabsNext } from \"./TabsNextContext\";\n\nconst withBaseName = makePrefixer(\"saltTabNext\");\n\nexport interface TabNextProps extends ComponentPropsWithoutRef<\"div\"> {\n /**\n * If `true`, the tab will be disabled.\n */\n disabled?: boolean;\n /**\n * The value of the tab.\n */\n value: string;\n}\n\nexport const TabNext = forwardRef<HTMLDivElement, TabNextProps>(\n function Tab(props, ref): ReactElement<TabNextProps> {\n const {\n \"aria-labelledby\": ariaLabelledBy,\n children,\n className,\n disabled: disabledProp,\n onBlur,\n onMouseDown,\n onFocus,\n onFocusCapture,\n value,\n id: idProp,\n ...rest\n } = props;\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-tab-next\",\n css: tabCss,\n window: targetWindow,\n });\n\n const { selected, activeTab } = useTabsNext();\n\n const disabled = !!disabledProp;\n\n const id = useId(idProp);\n\n const wasMouseDown = useRef(false);\n const [focusVisible, setFocusVisible] = useState(false);\n const [focused, setFocused] = useState(false);\n\n const handleFocusCapture = (event: FocusEvent<HTMLDivElement>) => {\n onFocusCapture?.(event);\n if (value && id) {\n activeTab.current = { value, id };\n }\n };\n\n const handleFocus = (event: FocusEvent<HTMLDivElement>) => {\n onFocus?.(event);\n\n setFocused(true);\n\n if (\n !wasMouseDown.current &&\n event.target.getAttribute(\"role\") === \"tab\"\n ) {\n setFocusVisible(true);\n }\n\n wasMouseDown.current = false;\n };\n\n const handleBlur = (event: FocusEvent<HTMLDivElement>) => {\n onBlur?.(event);\n setFocused(false);\n setFocusVisible(false);\n };\n\n const handleMouseDown = (event: MouseEvent<HTMLDivElement>) => {\n onMouseDown?.(event);\n wasMouseDown.current = true;\n };\n\n const [actions, setActions] = useState<string[]>([]);\n\n const registerAction = useCallback((id: string) => {\n setActions((old) => old.concat(id));\n\n return () => {\n setActions((old) => old.filter((action) => action !== id));\n };\n }, []);\n\n const context = useMemo(\n () => ({\n tabId: id,\n selected: selected === value,\n focused,\n value,\n disabled,\n actions,\n registerAction,\n }),\n [id, selected, value, focused, disabled, actions, registerAction],\n );\n\n return (\n <TabNextContext.Provider value={context}>\n <div\n className={clsx(\n withBaseName(),\n {\n [withBaseName(\"selected\")]: selected === value,\n [withBaseName(\"disabled\")]: disabled,\n [withBaseName(\"focusVisible\")]: focusVisible,\n },\n className,\n )}\n data-overflowitem=\"true\"\n ref={ref}\n onMouseDown={handleMouseDown}\n onFocusCapture={handleFocusCapture}\n onFocus={handleFocus}\n onBlur={handleBlur}\n role=\"presentation\"\n {...rest}\n >\n {children}\n </div>\n </TabNextContext.Provider>\n );\n },\n);\n"],"names":["tabCss","id"],"mappings":"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"}
@@ -0,0 +1,33 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { useId, useIsomorphicLayoutEffect, Button } from '@salt-ds/core';
3
+ import { clsx } from 'clsx';
4
+ import { forwardRef } from 'react';
5
+ import { useTabNext } from './TabNextContext.js';
6
+
7
+ const TabNextAction = forwardRef(
8
+ function TabNextAction2(props, ref) {
9
+ const { "aria-labelledby": ariaLabelledBy, id: idProp, ...rest } = props;
10
+ const id = useId(idProp);
11
+ const { focused, selected, tabId, registerAction } = useTabNext();
12
+ useIsomorphicLayoutEffect(() => {
13
+ if (id) {
14
+ return registerAction(id);
15
+ }
16
+ }, [registerAction, id]);
17
+ return /* @__PURE__ */ jsx(
18
+ Button,
19
+ {
20
+ id,
21
+ "aria-labelledby": clsx(ariaLabelledBy, tabId, id),
22
+ tabIndex: focused || selected ? void 0 : -1,
23
+ appearance: "transparent",
24
+ sentiment: "neutral",
25
+ ref,
26
+ ...rest
27
+ }
28
+ );
29
+ }
30
+ );
31
+
32
+ export { TabNextAction };
33
+ //# sourceMappingURL=TabNextAction.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TabNextAction.js","sources":["../src/tabs-next/TabNextAction.tsx"],"sourcesContent":["import {\n Button,\n type ButtonProps,\n useId,\n useIsomorphicLayoutEffect,\n} from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { forwardRef } from \"react\";\nimport { useTabNext } from \"./TabNextContext\";\n\nexport interface TabNextActionProps extends ButtonProps {}\n\nexport const TabNextAction = forwardRef<HTMLButtonElement, TabNextActionProps>(\n function TabNextAction(props, ref) {\n const { \"aria-labelledby\": ariaLabelledBy, id: idProp, ...rest } = props;\n\n const id = useId(idProp);\n const { focused, selected, tabId, registerAction } = useTabNext();\n\n useIsomorphicLayoutEffect(() => {\n if (id) {\n return registerAction(id);\n }\n }, [registerAction, id]);\n\n return (\n <Button\n id={id}\n aria-labelledby={clsx(ariaLabelledBy, tabId, id)}\n tabIndex={focused || selected ? undefined : -1}\n appearance=\"transparent\"\n sentiment=\"neutral\"\n ref={ref}\n {...rest}\n />\n );\n },\n);\n"],"names":["TabNextAction"],"mappings":";;;;;;AAYO,MAAM,aAAgB,GAAA,UAAA;AAAA,EAC3B,SAASA,cAAc,CAAA,KAAA,EAAO,GAAK,EAAA;AACjC,IAAA,MAAM,EAAE,iBAAmB,EAAA,cAAA,EAAgB,IAAI,MAAQ,EAAA,GAAG,MAAS,GAAA,KAAA;AAEnE,IAAM,MAAA,EAAA,GAAK,MAAM,MAAM,CAAA;AACvB,IAAA,MAAM,EAAE,OAAS,EAAA,QAAA,EAAU,KAAO,EAAA,cAAA,KAAmB,UAAW,EAAA;AAEhE,IAAA,yBAAA,CAA0B,MAAM;AAC9B,MAAA,IAAI,EAAI,EAAA;AACN,QAAA,OAAO,eAAe,EAAE,CAAA;AAAA;AAC1B,KACC,EAAA,CAAC,cAAgB,EAAA,EAAE,CAAC,CAAA;AAEvB,IACE,uBAAA,GAAA;AAAA,MAAC,MAAA;AAAA,MAAA;AAAA,QACC,EAAA;AAAA,QACA,iBAAiB,EAAA,IAAA,CAAK,cAAgB,EAAA,KAAA,EAAO,EAAE,CAAA;AAAA,QAC/C,QAAA,EAAU,OAAW,IAAA,QAAA,GAAW,KAAY,CAAA,GAAA,CAAA,CAAA;AAAA,QAC5C,UAAW,EAAA,aAAA;AAAA,QACX,SAAU,EAAA,SAAA;AAAA,QACV,GAAA;AAAA,QACC,GAAG;AAAA;AAAA,KACN;AAAA;AAGN;;;;"}
@@ -1,20 +1,20 @@
1
1
  import { createContext } from '@salt-ds/core';
2
2
  import { useContext } from 'react';
3
3
 
4
- const TabsContext = createContext("TabsContext", {
5
- activeColor: "primary",
6
- disabled: false,
7
- activate: () => void 0,
8
- isActive: () => false,
9
- setFocusable: () => void 0,
10
- isFocusable: () => false,
11
- registerTab: () => void 0,
12
- unregisterTab: () => void 0,
13
- variant: "main"
14
- });
15
- function useTabs() {
16
- return useContext(TabsContext);
4
+ const TabNextContext = createContext(
5
+ "TabNextContext",
6
+ {
7
+ focused: false,
8
+ selected: false,
9
+ disabled: false,
10
+ value: "",
11
+ actions: [],
12
+ registerAction: () => () => void 0
13
+ }
14
+ );
15
+ function useTabNext() {
16
+ return useContext(TabNextContext);
17
17
  }
18
18
 
19
- export { TabsContext, useTabs };
19
+ export { TabNextContext, useTabNext };
20
20
  //# sourceMappingURL=TabNextContext.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TabNextContext.js","sources":["../src/tabs-next/TabNextContext.tsx"],"sourcesContent":["import { createContext } from \"@salt-ds/core\";\nimport { type ReactNode, type SyntheticEvent, useContext } from \"react\";\n\ninterface TabValue {\n value: string;\n label: ReactNode;\n}\n\nexport interface TabsContextValue {\n activeColor: \"primary\" | \"secondary\";\n disabled?: boolean;\n activate: (event: SyntheticEvent<HTMLButtonElement>) => void;\n isActive: (id: string) => boolean;\n setFocusable: (id: string) => void;\n isFocusable: (id: string) => boolean;\n registerTab: (tab: TabValue) => void;\n unregisterTab: (id: string) => void;\n variant: \"main\" | \"inline\";\n}\n\nexport const TabsContext = createContext<TabsContextValue>(\"TabsContext\", {\n activeColor: \"primary\",\n disabled: false,\n activate: () => undefined,\n isActive: () => false,\n setFocusable: () => undefined,\n isFocusable: () => false,\n registerTab: () => undefined,\n unregisterTab: () => undefined,\n variant: \"main\",\n});\n\nexport function useTabs() {\n return useContext(TabsContext);\n}\n"],"names":[],"mappings":";;;AAoBa,MAAA,WAAA,GAAc,cAAgC,aAAe,EAAA;AAAA,EACxE,WAAa,EAAA,SAAA;AAAA,EACb,QAAU,EAAA,KAAA;AAAA,EACV,UAAU,MAAM,KAAA,CAAA;AAAA,EAChB,UAAU,MAAM,KAAA;AAAA,EAChB,cAAc,MAAM,KAAA,CAAA;AAAA,EACpB,aAAa,MAAM,KAAA;AAAA,EACnB,aAAa,MAAM,KAAA,CAAA;AAAA,EACnB,eAAe,MAAM,KAAA,CAAA;AAAA,EACrB,OAAS,EAAA,MAAA;AACX,CAAC,EAAA;AAEM,SAAS,OAAU,GAAA;AACxB,EAAA,OAAO,WAAW,WAAW,CAAA,CAAA;AAC/B;;;;"}
1
+ {"version":3,"file":"TabNextContext.js","sources":["../src/tabs-next/TabNextContext.tsx"],"sourcesContent":["import { createContext } from \"@salt-ds/core\";\nimport { useContext } from \"react\";\n\ninterface TabNextContextValue {\n tabId?: string;\n focused: boolean;\n selected: boolean;\n value: string;\n disabled: boolean;\n actions: string[];\n registerAction: (id: string) => () => void;\n}\n\nexport const TabNextContext = createContext<TabNextContextValue>(\n \"TabNextContext\",\n {\n focused: false,\n selected: false,\n disabled: false,\n value: \"\",\n actions: [],\n registerAction: () => () => undefined,\n },\n);\n\nexport function useTabNext() {\n return useContext(TabNextContext);\n}\n"],"names":[],"mappings":";;;AAaO,MAAM,cAAiB,GAAA,aAAA;AAAA,EAC5B,gBAAA;AAAA,EACA;AAAA,IACE,OAAS,EAAA,KAAA;AAAA,IACT,QAAU,EAAA,KAAA;AAAA,IACV,QAAU,EAAA,KAAA;AAAA,IACV,KAAO,EAAA,EAAA;AAAA,IACP,SAAS,EAAC;AAAA,IACV,cAAA,EAAgB,MAAM,MAAM,KAAA;AAAA;AAEhC;AAEO,SAAS,UAAa,GAAA;AAC3B,EAAA,OAAO,WAAW,cAAc,CAAA;AAClC;;;;"}
@@ -0,0 +1,4 @@
1
+ var css_248z = ".saltTabNextPanel {\n height: 100%;\n width: 100%;\n}\n\n.saltTabNextPanel[hidden] {\n display: none;\n}\n\n.saltTabNextPanel:focus-visible {\n outline: var(--salt-focused-outline);\n}\n";
2
+
3
+ export { css_248z as default };
4
+ //# sourceMappingURL=TabNextPanel.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TabNextPanel.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
@@ -0,0 +1,75 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { makePrefixer, useId, useForkRef, useIsomorphicLayoutEffect } from '@salt-ds/core';
3
+ import { useComponentCssInjection } from '@salt-ds/styles';
4
+ import { useWindow } from '@salt-ds/window';
5
+ import { clsx } from 'clsx';
6
+ import { forwardRef, useRef, useState, useEffect } from 'react';
7
+ import { tabbable } from 'tabbable';
8
+ import css_248z from './TabNextPanel.css.js';
9
+ import { useTabsNext } from './TabsNextContext.js';
10
+
11
+ const withBaseName = makePrefixer("saltTabNextPanel");
12
+ const TabNextPanel = forwardRef(
13
+ function TabNextPanel2(props, ref) {
14
+ const { className, children, id: idProp, value, ...rest } = props;
15
+ const targetWindow = useWindow();
16
+ useComponentCssInjection({
17
+ testId: "salt-tab-next-panel",
18
+ css: css_248z,
19
+ window: targetWindow
20
+ });
21
+ const id = useId(idProp);
22
+ const { registerPanel, getTabId, selected } = useTabsNext();
23
+ const panelRef = useRef(null);
24
+ const handleRef = useForkRef(panelRef, ref);
25
+ useIsomorphicLayoutEffect(() => {
26
+ if (value && id) {
27
+ return registerPanel(id, value);
28
+ }
29
+ }, [value, id, registerPanel]);
30
+ const [hasFocusableChildren, setHasFocusableChildren] = useState(false);
31
+ useEffect(() => {
32
+ if (!panelRef.current) return;
33
+ const detectFocusableChildren = () => {
34
+ requestAnimationFrame(() => {
35
+ if (!panelRef.current) return;
36
+ const elements = tabbable(panelRef.current);
37
+ setHasFocusableChildren(elements.length > 0);
38
+ });
39
+ };
40
+ const observer = new MutationObserver(() => {
41
+ detectFocusableChildren();
42
+ });
43
+ requestAnimationFrame(() => {
44
+ detectFocusableChildren();
45
+ });
46
+ observer.observe(panelRef.current, {
47
+ childList: true,
48
+ subtree: true,
49
+ attributes: true
50
+ });
51
+ return () => {
52
+ observer.disconnect();
53
+ };
54
+ }, []);
55
+ const hidden = selected !== value;
56
+ const tabId = getTabId(value);
57
+ return /* @__PURE__ */ jsx(
58
+ "div",
59
+ {
60
+ id,
61
+ ref: handleRef,
62
+ role: "tabpanel",
63
+ "aria-labelledby": tabId,
64
+ className: clsx(withBaseName(), className),
65
+ hidden: hidden || void 0,
66
+ tabIndex: hidden || hasFocusableChildren ? void 0 : 0,
67
+ ...rest,
68
+ children
69
+ }
70
+ );
71
+ }
72
+ );
73
+
74
+ export { TabNextPanel };
75
+ //# sourceMappingURL=TabNextPanel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TabNextPanel.js","sources":["../src/tabs-next/TabNextPanel.tsx"],"sourcesContent":["import {\n makePrefixer,\n useForkRef,\n useId,\n useIsomorphicLayoutEffect,\n} from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport {\n type ComponentPropsWithoutRef,\n forwardRef,\n useEffect,\n useRef,\n useState,\n} from \"react\";\nimport { tabbable } from \"tabbable\";\nimport tabPanelCss from \"./TabNextPanel.css\";\nimport { useTabsNext } from \"./TabsNextContext\";\n\nexport interface TabNextPanelProps extends ComponentPropsWithoutRef<\"div\"> {\n /**\n * The value of the panel, this should map to the corresponding tab.\n */\n value: string;\n}\n\nconst withBaseName = makePrefixer(\"saltTabNextPanel\");\n\nexport const TabNextPanel = forwardRef<HTMLDivElement, TabNextPanelProps>(\n function TabNextPanel(props, ref) {\n const { className, children, id: idProp, value, ...rest } = props;\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-tab-next-panel\",\n css: tabPanelCss,\n window: targetWindow,\n });\n const id = useId(idProp);\n const { registerPanel, getTabId, selected } = useTabsNext();\n\n const panelRef = useRef<HTMLDivElement>(null);\n const handleRef = useForkRef(panelRef, ref);\n\n useIsomorphicLayoutEffect(() => {\n if (value && id) {\n return registerPanel(id, value);\n }\n }, [value, id, registerPanel]);\n\n const [hasFocusableChildren, setHasFocusableChildren] = useState(false);\n useEffect(() => {\n if (!panelRef.current) return;\n\n const detectFocusableChildren = () => {\n requestAnimationFrame(() => {\n if (!panelRef.current) return;\n const elements = tabbable(panelRef.current);\n setHasFocusableChildren(elements.length > 0);\n });\n };\n\n const observer = new MutationObserver(() => {\n detectFocusableChildren();\n });\n\n requestAnimationFrame(() => {\n detectFocusableChildren();\n });\n\n observer.observe(panelRef.current, {\n childList: true,\n subtree: true,\n attributes: true,\n });\n\n return () => {\n observer.disconnect();\n };\n }, []);\n\n const hidden = selected !== value;\n const tabId = getTabId(value);\n\n return (\n <div\n id={id}\n ref={handleRef}\n role=\"tabpanel\"\n aria-labelledby={tabId}\n className={clsx(withBaseName(), className)}\n hidden={hidden || undefined}\n tabIndex={hidden || hasFocusableChildren ? undefined : 0}\n {...rest}\n >\n {children}\n </div>\n );\n },\n);\n"],"names":["TabNextPanel","tabPanelCss"],"mappings":";;;;;;;;;;AA2BA,MAAM,YAAA,GAAe,aAAa,kBAAkB,CAAA;AAE7C,MAAM,YAAe,GAAA,UAAA;AAAA,EAC1B,SAASA,aAAa,CAAA,KAAA,EAAO,GAAK,EAAA;AAChC,IAAM,MAAA,EAAE,WAAW,QAAU,EAAA,EAAA,EAAI,QAAQ,KAAO,EAAA,GAAG,MAAS,GAAA,KAAA;AAC5D,IAAA,MAAM,eAAe,SAAU,EAAA;AAC/B,IAAyB,wBAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,qBAAA;AAAA,MACR,GAAK,EAAAC,QAAA;AAAA,MACL,MAAQ,EAAA;AAAA,KACT,CAAA;AACD,IAAM,MAAA,EAAA,GAAK,MAAM,MAAM,CAAA;AACvB,IAAA,MAAM,EAAE,aAAA,EAAe,QAAU,EAAA,QAAA,KAAa,WAAY,EAAA;AAE1D,IAAM,MAAA,QAAA,GAAW,OAAuB,IAAI,CAAA;AAC5C,IAAM,MAAA,SAAA,GAAY,UAAW,CAAA,QAAA,EAAU,GAAG,CAAA;AAE1C,IAAA,yBAAA,CAA0B,MAAM;AAC9B,MAAA,IAAI,SAAS,EAAI,EAAA;AACf,QAAO,OAAA,aAAA,CAAc,IAAI,KAAK,CAAA;AAAA;AAChC,KACC,EAAA,CAAC,KAAO,EAAA,EAAA,EAAI,aAAa,CAAC,CAAA;AAE7B,IAAA,MAAM,CAAC,oBAAA,EAAsB,uBAAuB,CAAA,GAAI,SAAS,KAAK,CAAA;AACtE,IAAA,SAAA,CAAU,MAAM;AACd,MAAI,IAAA,CAAC,SAAS,OAAS,EAAA;AAEvB,MAAA,MAAM,0BAA0B,MAAM;AACpC,QAAA,qBAAA,CAAsB,MAAM;AAC1B,UAAI,IAAA,CAAC,SAAS,OAAS,EAAA;AACvB,UAAM,MAAA,QAAA,GAAW,QAAS,CAAA,QAAA,CAAS,OAAO,CAAA;AAC1C,UAAwB,uBAAA,CAAA,QAAA,CAAS,SAAS,CAAC,CAAA;AAAA,SAC5C,CAAA;AAAA,OACH;AAEA,MAAM,MAAA,QAAA,GAAW,IAAI,gBAAA,CAAiB,MAAM;AAC1C,QAAwB,uBAAA,EAAA;AAAA,OACzB,CAAA;AAED,MAAA,qBAAA,CAAsB,MAAM;AAC1B,QAAwB,uBAAA,EAAA;AAAA,OACzB,CAAA;AAED,MAAS,QAAA,CAAA,OAAA,CAAQ,SAAS,OAAS,EAAA;AAAA,QACjC,SAAW,EAAA,IAAA;AAAA,QACX,OAAS,EAAA,IAAA;AAAA,QACT,UAAY,EAAA;AAAA,OACb,CAAA;AAED,MAAA,OAAO,MAAM;AACX,QAAA,QAAA,CAAS,UAAW,EAAA;AAAA,OACtB;AAAA,KACF,EAAG,EAAE,CAAA;AAEL,IAAA,MAAM,SAAS,QAAa,KAAA,KAAA;AAC5B,IAAM,MAAA,KAAA,GAAQ,SAAS,KAAK,CAAA;AAE5B,IACE,uBAAA,GAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACC,EAAA;AAAA,QACA,GAAK,EAAA,SAAA;AAAA,QACL,IAAK,EAAA,UAAA;AAAA,QACL,iBAAiB,EAAA,KAAA;AAAA,QACjB,SAAW,EAAA,IAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,QACzC,QAAQ,MAAU,IAAA,KAAA,CAAA;AAAA,QAClB,QAAA,EAAU,MAAU,IAAA,oBAAA,GAAuB,KAAY,CAAA,GAAA,CAAA;AAAA,QACtD,GAAG,IAAA;AAAA,QAEH;AAAA;AAAA,KACH;AAAA;AAGN;;;;"}
@@ -0,0 +1,4 @@
1
+ var css_248z = ".saltTabNextTrigger {\n all: unset;\n display: flex;\n gap: var(--salt-spacing-100);\n align-items: center;\n justify-content: center;\n flex: 1;\n}\n\n/* The action should be triggered by clicking anywhere on the tab. */\n.saltTabNextTrigger::before {\n content: \"\";\n position: absolute;\n width: 100%;\n height: 100%;\n left: 0;\n top: 0;\n}\n";
2
+
3
+ export { css_248z as default };
4
+ //# sourceMappingURL=TabNextTrigger.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TabNextTrigger.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
@@ -0,0 +1,75 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { makePrefixer, useIsomorphicLayoutEffect, useForkRef } from '@salt-ds/core';
3
+ import { useComponentCssInjection } from '@salt-ds/styles';
4
+ import { useWindow } from '@salt-ds/window';
5
+ import { clsx } from 'clsx';
6
+ import { forwardRef, useRef } from 'react';
7
+ import { useTabNext } from './TabNextContext.js';
8
+ import css_248z from './TabNextTrigger.css.js';
9
+ import { useTabsNext } from './TabsNextContext.js';
10
+
11
+ const withBaseName = makePrefixer("saltTabNextTrigger");
12
+ function getAriaDescription(count) {
13
+ if (count < 1) {
14
+ return void 0;
15
+ }
16
+ if (count === 1) {
17
+ return "1 action available";
18
+ }
19
+ return `${count} actions available`;
20
+ }
21
+ const TabNextTrigger = forwardRef(function TabNextTrigger2(props, ref) {
22
+ const { children, id: idProp, onClick, onKeyDown, ...rest } = props;
23
+ const targetWindow = useWindow();
24
+ useComponentCssInjection({
25
+ testId: "salt-tab-next-trigger",
26
+ css: css_248z,
27
+ window: targetWindow
28
+ });
29
+ const { setSelected, registerTab, getPanelId } = useTabsNext();
30
+ const { selected, value, focused, disabled, tabId, actions } = useTabNext();
31
+ const tabRef = useRef(null);
32
+ const id = tabId;
33
+ useIsomorphicLayoutEffect(() => {
34
+ if (value && id && tabRef.current) {
35
+ return registerTab({ id, value, element: tabRef.current });
36
+ }
37
+ }, [value, id, registerTab]);
38
+ const handleClick = (event) => {
39
+ setSelected(event, value);
40
+ };
41
+ const handleKeyDown = (event) => {
42
+ onKeyDown == null ? void 0 : onKeyDown(event);
43
+ if (event.key === "Enter" || event.key === " ") {
44
+ setSelected(event, value);
45
+ }
46
+ };
47
+ const handleRef = useForkRef(tabRef, ref);
48
+ const panelId = getPanelId(value);
49
+ return (
50
+ // biome-ignore lint/a11y/useValidAriaProps: aria-actions is a draft spec https://pr-preview.s3.amazonaws.com/w3c/aria/pull/1805.html#aria-actions
51
+ /* @__PURE__ */ jsx(
52
+ "button",
53
+ {
54
+ "aria-selected": selected,
55
+ "aria-disabled": disabled,
56
+ "aria-controls": panelId,
57
+ "aria-actions": clsx(actions) || void 0,
58
+ "aria-description": getAriaDescription(actions.length),
59
+ tabIndex: focused || selected ? void 0 : -1,
60
+ role: "tab",
61
+ type: "button",
62
+ onClick: !disabled ? handleClick : void 0,
63
+ onKeyDown: !disabled ? handleKeyDown : void 0,
64
+ className: withBaseName(),
65
+ id,
66
+ ref: handleRef,
67
+ ...rest,
68
+ children
69
+ }
70
+ )
71
+ );
72
+ });
73
+
74
+ export { TabNextTrigger };
75
+ //# sourceMappingURL=TabNextTrigger.js.map