@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,141 @@
1
+ 'use strict';
2
+
3
+ var core = require('@salt-ds/core');
4
+ var window = require('@salt-ds/window');
5
+ var react = require('react');
6
+
7
+ function getTabWidth(element) {
8
+ const { width } = element.getBoundingClientRect();
9
+ return Math.ceil(width);
10
+ }
11
+ function useOverflow({
12
+ tabs,
13
+ container,
14
+ overflowButton,
15
+ children,
16
+ selected
17
+ }) {
18
+ const [{ visibleCount, isMeasuring }, setVisibleItems] = core.useValueEffect({
19
+ visibleCount: tabs.length,
20
+ isMeasuring: false
21
+ });
22
+ const targetWindow = window.useWindow();
23
+ const updateOverflow = core.useEventCallback(() => {
24
+ const computeVisible = (visibleCount2) => {
25
+ var _a;
26
+ if (container.current && targetWindow) {
27
+ const items = Array.from(
28
+ container.current.querySelectorAll(
29
+ "[data-overflowitem]"
30
+ )
31
+ );
32
+ const selectedTab = (_a = container.current.querySelector(
33
+ "[role=tab][aria-selected=true]"
34
+ )) == null ? void 0 : _a.parentElement;
35
+ let maxWidth = container.current.clientWidth ?? 0;
36
+ const containerStyles = targetWindow.getComputedStyle(
37
+ container.current
38
+ );
39
+ const gap = Number.parseInt(containerStyles.gap || "0");
40
+ let currentWidth = 0;
41
+ let newVisibleCount = 0;
42
+ const visible2 = [];
43
+ while (newVisibleCount < items.length) {
44
+ const element = items[newVisibleCount];
45
+ if (element) {
46
+ if (currentWidth + getTabWidth(element) + gap > maxWidth) {
47
+ break;
48
+ }
49
+ currentWidth += getTabWidth(element) + gap;
50
+ visible2.push(element);
51
+ }
52
+ newVisibleCount++;
53
+ }
54
+ if (newVisibleCount >= items.length) {
55
+ return newVisibleCount;
56
+ }
57
+ const overflowButtonWidth = overflowButton.current ? overflowButton.current.offsetWidth + gap : 0;
58
+ maxWidth -= overflowButtonWidth;
59
+ while (currentWidth > maxWidth) {
60
+ const removed = visible2.pop();
61
+ if (!removed) break;
62
+ currentWidth -= getTabWidth(removed) + gap;
63
+ newVisibleCount--;
64
+ }
65
+ if (selectedTab && !visible2.includes(selectedTab)) {
66
+ const selectedTabWidth = getTabWidth(selectedTab) + gap;
67
+ while (currentWidth + selectedTabWidth > maxWidth) {
68
+ const removed = visible2.pop();
69
+ if (!removed) break;
70
+ currentWidth -= getTabWidth(selectedTab) + gap;
71
+ newVisibleCount--;
72
+ }
73
+ }
74
+ return Math.max(1, newVisibleCount);
75
+ }
76
+ return visibleCount2;
77
+ };
78
+ setVisibleItems(function* () {
79
+ yield {
80
+ visibleCount: tabs.length,
81
+ isMeasuring: true
82
+ };
83
+ const newVisibleCount = computeVisible(tabs.length);
84
+ const isMeasuring2 = newVisibleCount < tabs.length && newVisibleCount > 0;
85
+ yield {
86
+ visibleCount: newVisibleCount,
87
+ isMeasuring: isMeasuring2
88
+ };
89
+ if (isMeasuring2) {
90
+ yield {
91
+ visibleCount: computeVisible(newVisibleCount),
92
+ isMeasuring: false
93
+ };
94
+ }
95
+ });
96
+ });
97
+ core.useIsomorphicLayoutEffect(() => {
98
+ updateOverflow();
99
+ }, [selected]);
100
+ react.useEffect(() => {
101
+ const element = container == null ? void 0 : container.current;
102
+ if (!element) return;
103
+ const win = core.ownerWindow(element);
104
+ const resizeObserver = new win.ResizeObserver((entries) => {
105
+ requestAnimationFrame(() => {
106
+ if (entries.length === 0) return;
107
+ updateOverflow();
108
+ });
109
+ });
110
+ resizeObserver.observe(element);
111
+ if (element.parentElement) {
112
+ resizeObserver.observe(element.parentElement);
113
+ }
114
+ return () => {
115
+ if (element) {
116
+ resizeObserver.unobserve(element);
117
+ }
118
+ };
119
+ }, [container, updateOverflow]);
120
+ const childArray = react.useMemo(() => react.Children.toArray(children), [children]);
121
+ const visible = childArray.slice(0, visibleCount || 1);
122
+ const hidden = childArray.slice(visibleCount || 1);
123
+ const hiddenSelectedIndex = hidden.findIndex(
124
+ // @ts-ignore
125
+ (child) => {
126
+ var _a;
127
+ return ((_a = child == null ? void 0 : child.props) == null ? void 0 : _a.value) === selected;
128
+ }
129
+ );
130
+ if (selected && hiddenSelectedIndex !== -1) {
131
+ const removed = hidden.splice(hiddenSelectedIndex, 1);
132
+ visible.push(removed[0]);
133
+ }
134
+ if (isMeasuring) {
135
+ return [childArray, [], isMeasuring];
136
+ }
137
+ return [visible, hidden, isMeasuring];
138
+ }
139
+
140
+ exports.useOverflow = useOverflow;
141
+ //# sourceMappingURL=useOverflow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useOverflow.js","sources":["../src/tabs-next/hooks/useOverflow.ts"],"sourcesContent":["import {\n ownerWindow,\n useEventCallback,\n useIsomorphicLayoutEffect,\n useValueEffect,\n} from \"@salt-ds/core\";\nimport { useWindow } from \"@salt-ds/window\";\nimport {\n Children,\n type ReactNode,\n type RefObject,\n useEffect,\n useMemo,\n} from \"react\";\nimport type { Item } from \"./useCollection\";\n\ninterface UseOverflowProps {\n container: RefObject<HTMLElement>;\n selected?: string;\n children: ReactNode;\n tabs: Item[];\n overflowButton: RefObject<HTMLButtonElement>;\n}\n\nfunction getTabWidth(element: HTMLElement) {\n const { width } = element.getBoundingClientRect();\n return Math.ceil(width);\n}\n\nexport function useOverflow({\n tabs,\n container,\n overflowButton,\n children,\n selected,\n}: UseOverflowProps) {\n const [{ visibleCount, isMeasuring }, setVisibleItems] = useValueEffect({\n visibleCount: tabs.length,\n isMeasuring: false,\n });\n const targetWindow = useWindow();\n\n const updateOverflow = useEventCallback(() => {\n const computeVisible = (visibleCount: number) => {\n if (container.current && targetWindow) {\n const items = Array.from(\n container.current.querySelectorAll<HTMLElement>(\n \"[data-overflowitem]\",\n ),\n );\n const selectedTab = container.current.querySelector<HTMLElement>(\n \"[role=tab][aria-selected=true]\",\n )?.parentElement;\n\n let maxWidth = container.current.clientWidth ?? 0;\n\n const containerStyles = targetWindow.getComputedStyle(\n container.current,\n );\n const gap = Number.parseInt(containerStyles.gap || \"0\");\n\n let currentWidth = 0;\n let newVisibleCount = 0;\n\n const visible = [];\n\n while (newVisibleCount < items.length) {\n const element = items[newVisibleCount];\n if (element) {\n if (currentWidth + getTabWidth(element) + gap > maxWidth) {\n break;\n }\n currentWidth += getTabWidth(element) + gap;\n visible.push(element);\n }\n newVisibleCount++;\n }\n\n if (newVisibleCount >= items.length) {\n return newVisibleCount;\n }\n\n const overflowButtonWidth = overflowButton.current\n ? overflowButton.current.offsetWidth + gap\n : 0;\n maxWidth -= overflowButtonWidth;\n\n while (currentWidth > maxWidth) {\n const removed = visible.pop();\n if (!removed) break;\n currentWidth -= getTabWidth(removed) + gap;\n newVisibleCount--;\n }\n\n if (selectedTab && !visible.includes(selectedTab)) {\n const selectedTabWidth = getTabWidth(selectedTab) + gap;\n while (currentWidth + selectedTabWidth > maxWidth) {\n const removed = visible.pop();\n if (!removed) break;\n currentWidth -= getTabWidth(selectedTab) + gap;\n newVisibleCount--;\n }\n }\n\n return Math.max(1, newVisibleCount);\n }\n return visibleCount;\n };\n\n setVisibleItems(function* () {\n // Show all\n yield {\n visibleCount: tabs.length,\n isMeasuring: true,\n };\n\n // Measure the visible count\n const newVisibleCount = computeVisible(tabs.length);\n const isMeasuring = newVisibleCount < tabs.length && newVisibleCount > 0;\n yield {\n visibleCount: newVisibleCount,\n isMeasuring,\n };\n\n // ensure the visible count is correct\n if (isMeasuring) {\n yield {\n visibleCount: computeVisible(newVisibleCount),\n isMeasuring: false,\n };\n }\n });\n });\n\n // biome-ignore lint/correctness/useExhaustiveDependencies: we want to update when selected changes.\n useIsomorphicLayoutEffect(() => {\n updateOverflow();\n }, [selected]);\n\n useEffect(() => {\n const element = container?.current;\n if (!element) return;\n\n const win = ownerWindow(element);\n\n const resizeObserver = new win.ResizeObserver((entries) => {\n requestAnimationFrame(() => {\n if (entries.length === 0) return;\n\n updateOverflow();\n });\n });\n resizeObserver.observe(element);\n if (element.parentElement) {\n resizeObserver.observe(element.parentElement);\n }\n\n return () => {\n if (element) {\n resizeObserver.unobserve(element);\n }\n };\n }, [container, updateOverflow]);\n\n const childArray = useMemo(() => Children.toArray(children), [children]);\n const visible = childArray.slice(0, visibleCount || 1);\n const hidden = childArray.slice(visibleCount || 1);\n\n const hiddenSelectedIndex = hidden.findIndex(\n // @ts-ignore\n (child) => child?.props?.value === selected,\n );\n\n if (selected && hiddenSelectedIndex !== -1) {\n const removed = hidden.splice(hiddenSelectedIndex, 1);\n visible.push(removed[0]);\n }\n\n if (isMeasuring) {\n return [childArray, [], isMeasuring] as const;\n }\n\n return [visible, hidden, isMeasuring] as const;\n}\n"],"names":["useValueEffect","useWindow","useEventCallback","visibleCount","visible","isMeasuring","useIsomorphicLayoutEffect","useEffect","ownerWindow","useMemo","Children"],"mappings":"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"}
@@ -1,7 +1,5 @@
1
1
  'use strict';
2
2
 
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
3
  var jsxRuntime = require('react/jsx-runtime');
6
4
  var core = require('@salt-ds/core');
7
5
  var styles = require('@salt-ds/styles');
@@ -20,11 +18,14 @@ const ToastGroup = react.forwardRef(
20
18
  css: ToastGroup$1,
21
19
  window: targetWindow
22
20
  });
23
- return /* @__PURE__ */ jsxRuntime.jsx("div", {
24
- className: clsx.clsx(withBaseName(), withBaseName(placement), className),
25
- ...rest,
26
- children
27
- });
21
+ return /* @__PURE__ */ jsxRuntime.jsx(
22
+ "div",
23
+ {
24
+ className: clsx.clsx(withBaseName(), withBaseName(placement), className),
25
+ ...rest,
26
+ children
27
+ }
28
+ );
28
29
  }
29
30
  );
30
31
 
@@ -1 +1 @@
1
- {"version":3,"file":"ToastGroup.js","sources":["../src/toast-group/ToastGroup.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport { type ComponentPropsWithoutRef, forwardRef } from \"react\";\n\nimport toastGroupCss from \"./ToastGroup.css\";\n\nconst withBaseName = makePrefixer(\"saltToastGroup\");\n\nexport interface ToastGroupProps extends ComponentPropsWithoutRef<\"div\"> {\n placement?: \"top-right\" | \"bottom-right\";\n}\n\nexport const ToastGroup = forwardRef<HTMLDivElement, ToastGroupProps>(\n function ToastGroup(props, ref) {\n const { children, className, placement = \"bottom-right\", ...rest } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-toast\",\n css: toastGroupCss,\n window: targetWindow,\n });\n\n return (\n <div\n className={clsx(withBaseName(), withBaseName(placement), className)}\n {...rest}\n >\n {children}\n </div>\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","ToastGroup","useWindow","useComponentCssInjection","toastGroupCss","jsx","clsx"],"mappings":";;;;;;;;;;;;AAQA,MAAM,YAAA,GAAeA,kBAAa,gBAAgB,CAAA,CAAA;AAM3C,MAAM,UAAa,GAAAC,gBAAA;AAAA,EACxB,SAASC,WAAW,CAAA,KAAA,EAAO,GAAK,EAAA;AAC9B,IAAA,MAAM,EAAE,QAAU,EAAA,SAAA,EAAW,SAAY,GAAA,cAAA,EAAA,GAAmB,MAAS,GAAA,KAAA,CAAA;AAErE,IAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,YAAA;AAAA,MACR,GAAK,EAAAC,YAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAA,uBACGC,cAAA,CAAA,KAAA,EAAA;AAAA,MACC,WAAWC,SAAK,CAAA,YAAA,IAAgB,YAAa,CAAA,SAAS,GAAG,SAAS,CAAA;AAAA,MACjE,GAAG,IAAA;AAAA,MAEH,QAAA;AAAA,KACH,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
1
+ {"version":3,"file":"ToastGroup.js","sources":["../src/toast-group/ToastGroup.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport { type ComponentPropsWithoutRef, forwardRef } from \"react\";\n\nimport toastGroupCss from \"./ToastGroup.css\";\n\nconst withBaseName = makePrefixer(\"saltToastGroup\");\n\nexport interface ToastGroupProps extends ComponentPropsWithoutRef<\"div\"> {\n placement?: \"top-right\" | \"bottom-right\";\n}\n\nexport const ToastGroup = forwardRef<HTMLDivElement, ToastGroupProps>(\n function ToastGroup(props, ref) {\n const { children, className, placement = \"bottom-right\", ...rest } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-toast\",\n css: toastGroupCss,\n window: targetWindow,\n });\n\n return (\n <div\n className={clsx(withBaseName(), withBaseName(placement), className)}\n {...rest}\n >\n {children}\n </div>\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","ToastGroup","useWindow","useComponentCssInjection","toastGroupCss","jsx","clsx"],"mappings":";;;;;;;;;;AAQA,MAAM,YAAA,GAAeA,kBAAa,gBAAgB,CAAA;AAM3C,MAAM,UAAa,GAAAC,gBAAA;AAAA,EACxB,SAASC,WAAW,CAAA,KAAA,EAAO,GAAK,EAAA;AAC9B,IAAA,MAAM,EAAE,QAAU,EAAA,SAAA,EAAW,YAAY,cAAgB,EAAA,GAAG,MAAS,GAAA,KAAA;AAErE,IAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,YAAA;AAAA,MACR,GAAK,EAAAC,YAAA;AAAA,MACL,MAAQ,EAAA;AAAA,KACT,CAAA;AAED,IACE,uBAAAC,cAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACC,WAAWC,SAAK,CAAA,YAAA,IAAgB,YAAa,CAAA,SAAS,GAAG,SAAS,CAAA;AAAA,QACjE,GAAG,IAAA;AAAA,QAEH;AAAA;AAAA,KACH;AAAA;AAGN;;;;"}
@@ -1,7 +1,5 @@
1
1
  'use strict';
2
2
 
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
3
  var jsxRuntime = require('react/jsx-runtime');
6
4
  var core = require('@salt-ds/core');
7
5
  var react = require('react');
@@ -11,12 +9,15 @@ var useTokenizedInput = require('./useTokenizedInput.js');
11
9
  const TokenizedInput = react.forwardRef(function TokenizedInput2(props, ref) {
12
10
  const { inputRef: inputRefProp, ...restProps } = props;
13
11
  const { inputRef, helpers, inputProps } = useTokenizedInput.useTokenizedInput(restProps);
14
- return /* @__PURE__ */ jsxRuntime.jsx(TokenizedInputBase.TokenizedInputBase, {
15
- helpers,
16
- inputRef: core.useForkRef(inputRef, inputRefProp),
17
- ref,
18
- ...inputProps
19
- });
12
+ return /* @__PURE__ */ jsxRuntime.jsx(
13
+ TokenizedInputBase.TokenizedInputBase,
14
+ {
15
+ helpers,
16
+ inputRef: core.useForkRef(inputRef, inputRefProp),
17
+ ref,
18
+ ...inputProps
19
+ }
20
+ );
20
21
  });
21
22
 
22
23
  exports.TokenizedInput = TokenizedInput;
@@ -1 +1 @@
1
- {"version":3,"file":"TokenizedInput.js","sources":["../src/tokenized-input/TokenizedInput.tsx"],"sourcesContent":["import { type UseTooltipProps, useForkRef } from \"@salt-ds/core\";\nimport { type ComponentType, type ForwardedRef, forwardRef } from \"react\";\nimport {\n TokenizedInputBase,\n type TokenizedInputBaseProps,\n} from \"./TokenizedInputBase\";\nimport { useTokenizedInput } from \"./useTokenizedInput\";\n\nexport type StringToItem<Item> = (\n selectedItems: Array<Item>,\n value: string,\n) => Item | null | undefined;\n\nexport type ChangeHandler<Item> = (selectedItems: Item[] | undefined) => void;\n\nexport interface TokenizedInputProps<Item>\n extends Omit<\n TokenizedInputBaseProps<Item>,\n | \"activeIndices\"\n | \"focused\"\n | \"highlightedIndex\"\n | \"helpers\"\n | \"onRemoveItem\"\n > {\n Tooltip?: ComponentType;\n delimiter?: string | Array<string>;\n disableAddOnBlur?: boolean;\n initialSelectedItems?: Array<Item>;\n onChange?: ChangeHandler<Item>;\n onCollapse?: () => void;\n onExpand?: () => void;\n stringToItem?: StringToItem<Item>;\n tooltipEnterDelay?: UseTooltipProps[\"enterDelay\"];\n tooltipLeaveDelay?: UseTooltipProps[\"leaveDelay\"];\n tooltipPlacement?: UseTooltipProps[\"placement\"];\n}\n\nexport const TokenizedInput = forwardRef(function TokenizedInput<Item>(\n props: TokenizedInputProps<Item>,\n ref: ForwardedRef<HTMLDivElement>,\n) {\n const { inputRef: inputRefProp, ...restProps } = props;\n\n const { inputRef, helpers, inputProps } = useTokenizedInput(restProps);\n\n return (\n <TokenizedInputBase\n helpers={helpers}\n inputRef={useForkRef(inputRef, inputRefProp)}\n ref={ref}\n {...inputProps}\n />\n );\n});\n"],"names":["forwardRef","TokenizedInput","useTokenizedInput","jsx","TokenizedInputBase","useForkRef"],"mappings":";;;;;;;;;;AAqCO,MAAM,cAAiB,GAAAA,gBAAA,CAAW,SAASC,eAAAA,CAChD,OACA,GACA,EAAA;AACA,EAAA,MAAM,EAAE,QAAA,EAAU,YAAiB,EAAA,GAAA,SAAA,EAAc,GAAA,KAAA,CAAA;AAEjD,EAAA,MAAM,EAAE,QAAU,EAAA,OAAA,EAAS,UAAW,EAAA,GAAIC,oCAAkB,SAAS,CAAA,CAAA;AAErE,EAAA,uBACGC,cAAA,CAAAC,qCAAA,EAAA;AAAA,IACC,OAAA;AAAA,IACA,QAAA,EAAUC,eAAW,CAAA,QAAA,EAAU,YAAY,CAAA;AAAA,IAC3C,GAAA;AAAA,IACC,GAAG,UAAA;AAAA,GACN,CAAA,CAAA;AAEJ,CAAC;;;;"}
1
+ {"version":3,"file":"TokenizedInput.js","sources":["../src/tokenized-input/TokenizedInput.tsx"],"sourcesContent":["import { type UseTooltipProps, useForkRef } from \"@salt-ds/core\";\nimport { type ComponentType, type ForwardedRef, forwardRef } from \"react\";\nimport {\n TokenizedInputBase,\n type TokenizedInputBaseProps,\n} from \"./TokenizedInputBase\";\nimport { useTokenizedInput } from \"./useTokenizedInput\";\n\nexport type StringToItem<Item> = (\n selectedItems: Array<Item>,\n value: string,\n) => Item | null | undefined;\n\nexport type ChangeHandler<Item> = (selectedItems: Item[] | undefined) => void;\n\nexport interface TokenizedInputProps<Item>\n extends Omit<\n TokenizedInputBaseProps<Item>,\n | \"activeIndices\"\n | \"focused\"\n | \"highlightedIndex\"\n | \"helpers\"\n | \"onRemoveItem\"\n > {\n Tooltip?: ComponentType;\n delimiter?: string | Array<string>;\n disableAddOnBlur?: boolean;\n initialSelectedItems?: Array<Item>;\n onChange?: ChangeHandler<Item>;\n onCollapse?: () => void;\n onExpand?: () => void;\n stringToItem?: StringToItem<Item>;\n tooltipEnterDelay?: UseTooltipProps[\"enterDelay\"];\n tooltipLeaveDelay?: UseTooltipProps[\"leaveDelay\"];\n tooltipPlacement?: UseTooltipProps[\"placement\"];\n}\n\nexport const TokenizedInput = forwardRef(function TokenizedInput<Item>(\n props: TokenizedInputProps<Item>,\n ref: ForwardedRef<HTMLDivElement>,\n) {\n const { inputRef: inputRefProp, ...restProps } = props;\n\n const { inputRef, helpers, inputProps } = useTokenizedInput(restProps);\n\n return (\n <TokenizedInputBase\n helpers={helpers}\n inputRef={useForkRef(inputRef, inputRefProp)}\n ref={ref}\n {...inputProps}\n />\n );\n});\n"],"names":["forwardRef","TokenizedInput","useTokenizedInput","jsx","TokenizedInputBase","useForkRef"],"mappings":";;;;;;;;AAqCO,MAAM,cAAiB,GAAAA,gBAAA,CAAW,SAASC,eAAAA,CAChD,OACA,GACA,EAAA;AACA,EAAA,MAAM,EAAE,QAAA,EAAU,YAAc,EAAA,GAAG,WAAc,GAAA,KAAA;AAEjD,EAAA,MAAM,EAAE,QAAU,EAAA,OAAA,EAAS,UAAW,EAAA,GAAIC,oCAAkB,SAAS,CAAA;AAErE,EACE,uBAAAC,cAAA;AAAA,IAACC,qCAAA;AAAA,IAAA;AAAA,MACC,OAAA;AAAA,MACA,QAAA,EAAUC,eAAW,CAAA,QAAA,EAAU,YAAY,CAAA;AAAA,MAC3C,GAAA;AAAA,MACC,GAAG;AAAA;AAAA,GACN;AAEJ,CAAC;;;;"}
@@ -1,7 +1,5 @@
1
1
  'use strict';
2
2
 
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
3
  var jsxRuntime = require('react/jsx-runtime');
6
4
  var core = require('@salt-ds/core');
7
5
  var styles = require('@salt-ds/styles');
@@ -19,10 +17,6 @@ var useResizeObserver = require('./internal/useResizeObserver.js');
19
17
  var useWidth = require('./internal/useWidth.js');
20
18
  var TokenizedInput = require('./TokenizedInput.css.js');
21
19
 
22
- function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
23
-
24
- var deepmerge__default = /*#__PURE__*/_interopDefaultLegacy(deepmerge);
25
-
26
20
  const INITIAL_INPUT_WIDTH = 5;
27
21
  const withBaseName = core.makePrefixer("saltTokenizedInput");
28
22
  const getItemsAriaLabel = (itemCount) => itemCount === 0 ? "no item selected" : `${itemCount} ${itemCount > 1 ? "items" : "item"}`;
@@ -120,6 +114,7 @@ const TokenizedInputBase = react.forwardRef(function TokenizedInputBase2(props,
120
114
  );
121
115
  }
122
116
  },
117
+ // Additional dependency on selectedItems is for the controlled version
123
118
  [expanded, pillGroupWidth, selectedItems]
124
119
  );
125
120
  core.useIsomorphicLayoutEffect(() => {
@@ -176,7 +171,7 @@ const TokenizedInputBase = react.forwardRef(function TokenizedInputBase2(props,
176
171
  (_, index) => `${id}-pill-${index}`
177
172
  );
178
173
  const inputAriaLabelledBy = disabled ? [ariaLabelledBy, inputId, ...selectedItemIds] : [ariaLabelledBy, inputId];
179
- const mergedInputProps = deepmerge__default["default"](
174
+ const mergedInputProps = deepmerge(
180
175
  {
181
176
  inputProps: {
182
177
  style: {
@@ -194,102 +189,116 @@ const TokenizedInputBase = react.forwardRef(function TokenizedInputBase2(props,
194
189
  accessibleText: expandButtonAccessibleText,
195
190
  ...restExpandButtonProps
196
191
  } = ExpandButtonProps;
197
- return /* @__PURE__ */ jsxRuntime.jsxs("div", {
198
- ...restProps,
199
- className: clsx.clsx(
200
- withBaseName(),
201
- {
202
- [withBaseName("focused")]: focused,
203
- [withBaseName("expanded")]: expanded,
204
- [withBaseName("disabled")]: disabled
205
- },
206
- className
207
- ),
208
- id,
209
- onClick,
210
- ref: core.useForkRef(ref, containerRef),
211
- children: [
212
- /* @__PURE__ */ jsxRuntime.jsx("span", {
213
- "aria-owns": selectedItemIds.join(" "),
214
- className: withBaseName("hidden"),
215
- role: "listbox"
216
- }),
217
- /* @__PURE__ */ jsxRuntime.jsxs("div", {
218
- className: withBaseName("pillGroup"),
219
- children: [
192
+ return /* @__PURE__ */ jsxRuntime.jsxs(
193
+ "div",
194
+ {
195
+ ...restProps,
196
+ className: clsx.clsx(
197
+ withBaseName(),
198
+ {
199
+ [withBaseName("focused")]: focused,
200
+ [withBaseName("expanded")]: expanded,
201
+ [withBaseName("disabled")]: disabled
202
+ },
203
+ className
204
+ ),
205
+ id,
206
+ onClick,
207
+ ref: core.useForkRef(ref, containerRef),
208
+ children: [
209
+ /* @__PURE__ */ jsxRuntime.jsx(
210
+ "span",
211
+ {
212
+ "aria-owns": selectedItemIds.join(" "),
213
+ className: withBaseName("hidden"),
214
+ role: "listbox"
215
+ }
216
+ ),
217
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: withBaseName("pillGroup"), children: [
220
218
  selectedItems.map((item, index) => {
221
219
  const label = itemToString(item);
222
- return /* @__PURE__ */ jsxRuntime.jsx(InputPill.InputPill, {
223
- active: activeIndices.indexOf(index) !== -1,
224
- disabled,
225
- hidden: showExpandButton && index >= firstHiddenIndex,
226
- highlighted: index === highlightedIndex,
227
- id: `${id}-pill-${index}`,
228
- index,
229
- label,
230
- lastVisible: !showExpandButton && index === selectedItems.length - 1,
231
- onDelete: expanded ? onRemoveItem : void 0,
232
- pillsRef
233
- }, `${index}-${label}`);
220
+ return /* @__PURE__ */ jsxRuntime.jsx(
221
+ InputPill.InputPill,
222
+ {
223
+ active: activeIndices.indexOf(index) !== -1,
224
+ disabled,
225
+ hidden: showExpandButton && index >= firstHiddenIndex,
226
+ highlighted: index === highlightedIndex,
227
+ id: `${id}-pill-${index}`,
228
+ index,
229
+ label,
230
+ lastVisible: !showExpandButton && index === selectedItems.length - 1,
231
+ onDelete: expanded ? onRemoveItem : void 0,
232
+ pillsRef
233
+ },
234
+ `${index}-${label}`
235
+ );
234
236
  }),
235
- /* @__PURE__ */ jsxRuntime.jsx(core.Button, {
236
- "aria-labelledby": [ariaLabelledBy, inputId, expandButtonId].filter(Boolean).join(" "),
237
- className: clsx.clsx(withBaseName("expandButton"), {
238
- [withBaseName("hidden")]: !showExpandButton
237
+ /* @__PURE__ */ jsxRuntime.jsx(
238
+ core.Button,
239
+ {
240
+ "aria-labelledby": [ariaLabelledBy, inputId, expandButtonId].filter(Boolean).join(" "),
241
+ className: clsx.clsx(withBaseName("expandButton"), {
242
+ [withBaseName("hidden")]: !showExpandButton
243
+ }),
244
+ disabled,
245
+ id: expandButtonId,
246
+ onBlur,
247
+ onClick: handleExpand,
248
+ onFocus,
249
+ onKeyDown: handleExpandButtonKeyDown,
250
+ ref: core.useForkRef(expandButtonRef, expandButtonRefProp),
251
+ variant: "secondary",
252
+ ...restExpandButtonProps,
253
+ children: /* @__PURE__ */ jsxRuntime.jsx(
254
+ OverflowIcon,
255
+ {
256
+ "aria-label": expandButtonAccessibleText === void 0 ? "expand edit" : expandButtonAccessibleText
257
+ }
258
+ )
259
+ }
260
+ ),
261
+ /* @__PURE__ */ jsxRuntime.jsx(
262
+ InputLegacy.InputLegacy,
263
+ {
264
+ ...mergedInputProps,
265
+ className: clsx.clsx(withBaseName("input"), withBaseName("inputField"), {
266
+ [withBaseName("hidden")]: showExpandButton
267
+ }),
268
+ disabled,
269
+ id: inputId,
270
+ onBlur: onInputBlur,
271
+ onChange: onInputChange,
272
+ onFocus: onInputFocus,
273
+ onKeyDown,
274
+ onKeyUp: handleInputKeyUp,
275
+ onSelect: onInputSelect,
276
+ renderSuffix: () => /* @__PURE__ */ jsxRuntime.jsx(InputRuler.InputRuler, { ref: inputRulerRef, value }),
277
+ value,
278
+ ref: inputRef
279
+ }
280
+ )
281
+ ] }),
282
+ /* @__PURE__ */ jsxRuntime.jsx(
283
+ core.Button,
284
+ {
285
+ className: clsx.clsx(withBaseName("clearButton"), {
286
+ [withBaseName("hidden")]: !expanded || selectedItems.length === 0
239
287
  }),
240
288
  disabled,
241
- id: expandButtonId,
289
+ id: clearButtonId,
242
290
  onBlur,
243
- onClick: handleExpand,
244
- onFocus,
245
- onKeyDown: handleExpandButtonKeyDown,
246
- ref: core.useForkRef(expandButtonRef, expandButtonRefProp),
291
+ onClick: onClear,
292
+ onFocus: handleClearButtonFocus,
293
+ ref: clearButtonRef,
247
294
  variant: "secondary",
248
- ...restExpandButtonProps,
249
- children: /* @__PURE__ */ jsxRuntime.jsx(OverflowIcon, {
250
- "aria-label": expandButtonAccessibleText === void 0 ? "expand edit" : expandButtonAccessibleText
251
- })
252
- }),
253
- /* @__PURE__ */ jsxRuntime.jsx(InputLegacy.InputLegacy, {
254
- ...mergedInputProps,
255
- className: clsx.clsx(withBaseName("input"), withBaseName("inputField"), {
256
- [withBaseName("hidden")]: showExpandButton
257
- }),
258
- disabled,
259
- id: inputId,
260
- onBlur: onInputBlur,
261
- onChange: onInputChange,
262
- onFocus: onInputFocus,
263
- onKeyDown,
264
- onKeyUp: handleInputKeyUp,
265
- onSelect: onInputSelect,
266
- renderSuffix: () => /* @__PURE__ */ jsxRuntime.jsx(InputRuler.InputRuler, {
267
- ref: inputRulerRef,
268
- value
269
- }),
270
- value,
271
- ref: inputRef
272
- })
273
- ]
274
- }),
275
- /* @__PURE__ */ jsxRuntime.jsx(core.Button, {
276
- className: clsx.clsx(withBaseName("clearButton"), {
277
- [withBaseName("hidden")]: !expanded || selectedItems.length === 0
278
- }),
279
- disabled,
280
- id: clearButtonId,
281
- onBlur,
282
- onClick: onClear,
283
- onFocus: handleClearButtonFocus,
284
- ref: clearButtonRef,
285
- variant: "secondary",
286
- "data-testid": "clear-button",
287
- children: /* @__PURE__ */ jsxRuntime.jsx(CloseIcon, {
288
- "aria-label": "clear input"
289
- })
290
- })
291
- ]
292
- });
295
+ "data-testid": "clear-button",
296
+ children: /* @__PURE__ */ jsxRuntime.jsx(CloseIcon, { "aria-label": "clear input" })
297
+ }
298
+ )
299
+ ]
300
+ }
301
+ );
293
302
  });
294
303
 
295
304
  exports.TokenizedInputBase = TokenizedInputBase;
@@ -1 +1 @@
1
- {"version":3,"file":"TokenizedInputBase.js","sources":["../src/tokenized-input/TokenizedInputBase.tsx"],"sourcesContent":["import {\n Button,\n type ButtonProps,\n makePrefixer,\n useDensity,\n useForkRef,\n useIcon,\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 deepmerge from \"deepmerge\";\nimport {\n type ChangeEventHandler,\n type FocusEvent,\n type FocusEventHandler,\n type ForwardedRef,\n type HTMLAttributes,\n type KeyboardEvent,\n type KeyboardEventHandler,\n type ReactElement,\n type ReactEventHandler,\n type Ref,\n type SyntheticEvent,\n forwardRef,\n useCallback,\n useRef,\n useState,\n} from \"react\";\nimport {\n InputLegacy as Input,\n type InputLegacyProps as InputProps,\n} from \"../input-legacy\";\nimport { InputPill } from \"./internal/InputPill\";\nimport { InputRuler } from \"./internal/InputRuler\";\nimport { calcFirstHiddenIndex } from \"./internal/calcFirstHiddenIndex\";\nimport { defaultItemToString } from \"./internal/defaultItemToString\";\nimport { useResizeObserver } from \"./internal/useResizeObserver\";\nimport { useWidth } from \"./internal/useWidth\";\nimport type {\n TokenizedInputHelpers,\n TokenizedInputState,\n} from \"./useTokenizedInput\";\n\nimport tokenizedInputCss from \"./TokenizedInput.css\";\n\nexport type RemoveItemHandler = (itemIndex: number) => void;\nexport type ItemToString<Item> = (item: Item) => string;\nexport type ExpandButtonProps = Pick<\n ButtonProps,\n \"role\" | \"aria-roledescription\" | \"aria-describedby\"\n> & { accessibleText?: string };\n\nexport interface TokenizedInputBaseProps<Item>\n extends Partial<TokenizedInputState<Item>>,\n Omit<\n HTMLAttributes<HTMLDivElement>,\n \"onFocus\" | \"onBlur\" | \"onChange\" | \"onKeyUp\" | \"onKeyDown\"\n > {\n ExpandButtonProps?: ExpandButtonProps;\n InputProps?: Pick<InputProps, \"aria-describedby\" | \"inputProps\">;\n disabled?: boolean;\n expandButtonRef?: Ref<HTMLButtonElement>;\n helpers: TokenizedInputHelpers<Item>;\n inputRef?: Ref<HTMLInputElement>;\n itemToString?: ItemToString<Item>;\n onFocus?: FocusEventHandler<HTMLInputElement | HTMLButtonElement>;\n onBlur?: FocusEventHandler<HTMLInputElement | HTMLButtonElement>;\n onKeyUp?: KeyboardEventHandler<HTMLInputElement>;\n // Can key down on either input or expand button\n onKeyDown?: KeyboardEventHandler<HTMLInputElement | HTMLButtonElement>;\n onRemoveItem?: RemoveItemHandler;\n onInputBlur?: FocusEventHandler<HTMLInputElement>;\n onInputFocus?: FocusEventHandler<HTMLInputElement>;\n onInputChange?: ChangeEventHandler<HTMLInputElement>;\n onInputSelect?: ReactEventHandler<HTMLInputElement>;\n onClick?: (event: SyntheticEvent<HTMLElement>) => void;\n onClear?: ReactEventHandler;\n}\n\nconst INITIAL_INPUT_WIDTH = 5;\nconst withBaseName = makePrefixer(\"saltTokenizedInput\");\n\nconst getItemsAriaLabel = (itemCount: number) =>\n itemCount === 0\n ? \"no item selected\"\n : `${itemCount} ${itemCount > 1 ? \"items\" : \"item\"}`;\n\nfunction hasHelpers<Item>(helpers: TokenizedInputHelpers<Item>) {\n if (process.env.NODE_ENV !== \"production\") {\n if (helpers == null) {\n console.warn(\n 'TokenizedInputBase is used without helpers. You should pass in \"helpers\" from \"useTokenizedInput\".',\n );\n }\n }\n return helpers != null;\n}\n\nexport const TokenizedInputBase = forwardRef(function TokenizedInputBase<Item>(\n props: TokenizedInputBaseProps<Item>,\n ref: ForwardedRef<HTMLDivElement>,\n) {\n const {\n InputProps = {},\n ExpandButtonProps = {},\n className,\n activeIndices = [],\n selectedItems = [],\n highlightedIndex,\n value,\n focused,\n expanded,\n disabled,\n helpers,\n onFocus,\n onBlur,\n onKeyUp,\n onKeyDown,\n onRemoveItem,\n onInputChange,\n onInputFocus,\n onInputBlur,\n onInputSelect,\n onClear,\n onClick,\n inputRef,\n itemToString = defaultItemToString,\n id: idProp,\n expandButtonRef: expandButtonRefProp,\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabelledBy,\n ...restProps\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-tokenized-input\",\n css: tokenizedInputCss,\n window: targetWindow,\n });\n\n const density = useDensity();\n const { OverflowIcon, CloseIcon } = useIcon();\n const id = useId(idProp);\n const inputId = `${id}-input`;\n const expandButtonId = `${id}-expand-button`;\n const clearButtonId = `${id}-clear-button`;\n\n // TODO: Use proper machanism to get variable values from theme in React. Something like below\n // getComputedStyle(document.documentElement)\n // .getPropertyValue('--my-variable-name'); // #999999\n const pillGroupPadding = 16;\n const lastVisiblePillMargin = 4;\n\n const pillsRef = useRef<{ [index: number]: number | undefined }>({});\n const inputRulerRef = useRef<HTMLSpanElement | null>(null);\n const keydownExpandButton = useRef(false);\n\n const [expandButtonRef, expandButtonWidth] = useWidth(density);\n const [clearButtonRef, clearButtonWidth] = useWidth(density);\n const [inputWidth, setInputWidth] = useState(INITIAL_INPUT_WIDTH);\n const [pillGroupWidth, setPillGroupWidth] = useState<number | null>(null);\n const [firstHiddenIndex, setFirstHiddenIndex] = useState<number | null>(null);\n\n const showExpandButton = !expanded && firstHiddenIndex != null;\n\n const widthOffset =\n pillGroupPadding +\n INITIAL_INPUT_WIDTH +\n (expanded ? clearButtonWidth : expandButtonWidth);\n\n const containerRef = useResizeObserver<HTMLDivElement>(\n useCallback(\n ([{ contentRect }]) => {\n setPillGroupWidth(contentRect.width - widthOffset);\n },\n [widthOffset],\n ),\n );\n\n useIsomorphicLayoutEffect(\n () => () => {\n // When density changes, set hidden index to null so that pills are in their\n // readonly state before they are measured.\n setFirstHiddenIndex(null);\n },\n [density],\n );\n\n // useLayoutEffect because of potential layout change\n // We want to do that before paint to avoid layout jumps\n useIsomorphicLayoutEffect(\n () => {\n if (expanded) {\n setFirstHiddenIndex(null);\n } else if (pillGroupWidth != null) {\n setFirstHiddenIndex(\n calcFirstHiddenIndex({\n containerWidth: pillGroupWidth,\n pillWidths: Object.values(pillsRef.current).filter(\n Boolean,\n ) as number[],\n }),\n );\n }\n },\n // Additional dependency on selectedItems is for the controlled version\n [expanded, pillGroupWidth, selectedItems],\n );\n\n useIsomorphicLayoutEffect(() => {\n if (expanded && inputRulerRef.current) {\n const newInputWidth = inputRulerRef.current.scrollWidth;\n setInputWidth(Math.min(newInputWidth, pillGroupWidth || 0));\n }\n }, [expanded, pillGroupWidth, value]);\n\n const handleExpandButtonKeyDown = (\n event: KeyboardEvent<HTMLButtonElement>,\n ) => {\n const singleChar = event.key.length === 1;\n const triggerExpand =\n [\n \"CONTROL\",\n \"META\",\n \"ENTER\",\n \"BACKSPACE\",\n \"ARROWDOWN\",\n \"ARROWLEFT\",\n \"ARROWRIGHT\",\n ].indexOf(event.key.toUpperCase()) !== -1;\n\n if ((singleChar || triggerExpand) && hasHelpers(helpers)) {\n if (event.key === \"Enter\" || event.key === \" \") {\n event.preventDefault();\n event.stopPropagation();\n }\n helpers.updateExpanded(true);\n keydownExpandButton.current = true;\n }\n };\n\n const handleInputKeyUp = (event: KeyboardEvent<HTMLInputElement>) => {\n // Call keydown again if the initail event has been used to expand the input\n if (keydownExpandButton.current && \"Enter\" !== event.key) {\n keydownExpandButton.current = false;\n\n if (onKeyDown) {\n onKeyDown(event);\n }\n }\n\n if (onKeyUp) {\n onKeyUp(event);\n }\n };\n\n const handleExpand = (event: SyntheticEvent<HTMLButtonElement>) => {\n event.stopPropagation();\n\n if (hasHelpers(helpers)) {\n helpers.updateExpanded(true);\n }\n };\n\n const handleClearButtonFocus = (event: FocusEvent<HTMLButtonElement>) => {\n event.stopPropagation();\n\n if (hasHelpers(helpers)) {\n helpers.setFocused(false);\n helpers.cancelBlur();\n }\n };\n\n const selectedItemIds = selectedItems.map(\n (_, index) => `${id}-pill-${index}`,\n );\n\n const inputAriaLabelledBy = disabled\n ? [ariaLabelledBy, inputId, ...selectedItemIds]\n : [ariaLabelledBy, inputId];\n\n const mergedInputProps = deepmerge(\n {\n inputProps: {\n style: {\n width: inputWidth,\n minWidth: inputWidth,\n },\n \"aria-label\": [ariaLabel, getItemsAriaLabel(selectedItems.length)]\n .filter(Boolean)\n .join(\" \"),\n \"aria-labelledby\": inputAriaLabelledBy.filter(Boolean).join(\" \"),\n \"aria-activedescendant\":\n highlightedIndex && highlightedIndex >= 0\n ? `${id}-pill-${highlightedIndex}`\n : undefined,\n },\n },\n InputProps,\n );\n\n const {\n accessibleText: expandButtonAccessibleText,\n ...restExpandButtonProps\n } = ExpandButtonProps;\n\n return (\n <div\n {...restProps}\n className={clsx(\n withBaseName(),\n {\n [withBaseName(\"focused\")]: focused,\n [withBaseName(\"expanded\")]: expanded,\n [withBaseName(\"disabled\")]: disabled,\n },\n className,\n )}\n id={id}\n onClick={onClick}\n ref={useForkRef(ref, containerRef)}\n >\n <span\n aria-owns={selectedItemIds.join(\" \")}\n className={withBaseName(\"hidden\")}\n role=\"listbox\"\n />\n <div className={withBaseName(\"pillGroup\")}>\n {selectedItems.map((item, index) => {\n const label = itemToString(item);\n\n return (\n <InputPill\n active={activeIndices.indexOf(index) !== -1}\n disabled={disabled}\n hidden={showExpandButton && index >= firstHiddenIndex}\n highlighted={index === highlightedIndex}\n id={`${id}-pill-${index}`}\n index={index}\n key={`${index}-${label}`}\n label={label}\n lastVisible={\n !showExpandButton && index === selectedItems.length - 1\n }\n onDelete={expanded ? onRemoveItem : undefined}\n pillsRef={pillsRef}\n />\n );\n })}\n <Button\n aria-labelledby={[ariaLabelledBy, inputId, expandButtonId]\n .filter(Boolean)\n .join(\" \")}\n className={clsx(withBaseName(\"expandButton\"), {\n [withBaseName(\"hidden\")]: !showExpandButton,\n })}\n disabled={disabled}\n id={expandButtonId}\n onBlur={onBlur}\n onClick={handleExpand}\n onFocus={onFocus}\n onKeyDown={handleExpandButtonKeyDown}\n ref={useForkRef(expandButtonRef, expandButtonRefProp)}\n variant=\"secondary\"\n {...restExpandButtonProps}\n >\n <OverflowIcon\n aria-label={\n expandButtonAccessibleText === undefined\n ? \"expand edit\"\n : expandButtonAccessibleText\n }\n />\n </Button>\n <Input\n {...mergedInputProps}\n className={clsx(withBaseName(\"input\"), withBaseName(\"inputField\"), {\n [withBaseName(\"hidden\")]: showExpandButton,\n })}\n disabled={disabled}\n id={inputId}\n // TODO: Use multi line input when available\n // multiline\n onBlur={onInputBlur}\n onChange={onInputChange}\n onFocus={onInputFocus}\n onKeyDown={onKeyDown}\n onKeyUp={handleInputKeyUp}\n onSelect={onInputSelect}\n renderSuffix={() => <InputRuler ref={inputRulerRef} value={value} />}\n value={value}\n ref={inputRef}\n />\n </div>\n <Button\n className={clsx(withBaseName(\"clearButton\"), {\n [withBaseName(\"hidden\")]: !expanded || selectedItems.length === 0,\n })}\n disabled={disabled}\n id={clearButtonId}\n onBlur={onBlur}\n onClick={onClear}\n onFocus={handleClearButtonFocus}\n ref={clearButtonRef}\n variant=\"secondary\"\n data-testid=\"clear-button\"\n >\n <CloseIcon aria-label=\"clear input\" />\n </Button>\n </div>\n );\n}) as <Item>(\n p: TokenizedInputBaseProps<Item> & { ref?: ForwardedRef<HTMLDivElement> },\n) => ReactElement<TokenizedInputBaseProps<Item>>;\n"],"names":["makePrefixer","forwardRef","TokenizedInputBase","defaultItemToString","useWindow","useComponentCssInjection","tokenizedInputCss","useDensity","useIcon","useId","useRef","useWidth","useState","useResizeObserver","useCallback","useIsomorphicLayoutEffect","calcFirstHiddenIndex","deepmerge","jsxs","clsx","useForkRef","jsx","InputPill","Button","Input","InputRuler"],"mappings":"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"}
1
+ {"version":3,"file":"TokenizedInputBase.js","sources":["../src/tokenized-input/TokenizedInputBase.tsx"],"sourcesContent":["import {\n Button,\n type ButtonProps,\n makePrefixer,\n useDensity,\n useForkRef,\n useIcon,\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 deepmerge from \"deepmerge\";\nimport {\n type ChangeEventHandler,\n type FocusEvent,\n type FocusEventHandler,\n type ForwardedRef,\n type HTMLAttributes,\n type KeyboardEvent,\n type KeyboardEventHandler,\n type ReactElement,\n type ReactEventHandler,\n type Ref,\n type SyntheticEvent,\n forwardRef,\n useCallback,\n useRef,\n useState,\n} from \"react\";\nimport {\n InputLegacy as Input,\n type InputLegacyProps as InputProps,\n} from \"../input-legacy\";\nimport { InputPill } from \"./internal/InputPill\";\nimport { InputRuler } from \"./internal/InputRuler\";\nimport { calcFirstHiddenIndex } from \"./internal/calcFirstHiddenIndex\";\nimport { defaultItemToString } from \"./internal/defaultItemToString\";\nimport { useResizeObserver } from \"./internal/useResizeObserver\";\nimport { useWidth } from \"./internal/useWidth\";\nimport type {\n TokenizedInputHelpers,\n TokenizedInputState,\n} from \"./useTokenizedInput\";\n\nimport tokenizedInputCss from \"./TokenizedInput.css\";\n\nexport type RemoveItemHandler = (itemIndex: number) => void;\nexport type ItemToString<Item> = (item: Item) => string;\nexport type ExpandButtonProps = Pick<\n ButtonProps,\n \"role\" | \"aria-roledescription\" | \"aria-describedby\"\n> & { accessibleText?: string };\n\nexport interface TokenizedInputBaseProps<Item>\n extends Partial<TokenizedInputState<Item>>,\n Omit<\n HTMLAttributes<HTMLDivElement>,\n \"onFocus\" | \"onBlur\" | \"onChange\" | \"onKeyUp\" | \"onKeyDown\"\n > {\n ExpandButtonProps?: ExpandButtonProps;\n InputProps?: Pick<InputProps, \"aria-describedby\" | \"inputProps\">;\n disabled?: boolean;\n expandButtonRef?: Ref<HTMLButtonElement>;\n helpers: TokenizedInputHelpers<Item>;\n inputRef?: Ref<HTMLInputElement>;\n itemToString?: ItemToString<Item>;\n onFocus?: FocusEventHandler<HTMLInputElement | HTMLButtonElement>;\n onBlur?: FocusEventHandler<HTMLInputElement | HTMLButtonElement>;\n onKeyUp?: KeyboardEventHandler<HTMLInputElement>;\n // Can key down on either input or expand button\n onKeyDown?: KeyboardEventHandler<HTMLInputElement | HTMLButtonElement>;\n onRemoveItem?: RemoveItemHandler;\n onInputBlur?: FocusEventHandler<HTMLInputElement>;\n onInputFocus?: FocusEventHandler<HTMLInputElement>;\n onInputChange?: ChangeEventHandler<HTMLInputElement>;\n onInputSelect?: ReactEventHandler<HTMLInputElement>;\n onClick?: (event: SyntheticEvent<HTMLElement>) => void;\n onClear?: ReactEventHandler;\n}\n\nconst INITIAL_INPUT_WIDTH = 5;\nconst withBaseName = makePrefixer(\"saltTokenizedInput\");\n\nconst getItemsAriaLabel = (itemCount: number) =>\n itemCount === 0\n ? \"no item selected\"\n : `${itemCount} ${itemCount > 1 ? \"items\" : \"item\"}`;\n\nfunction hasHelpers<Item>(helpers: TokenizedInputHelpers<Item>) {\n if (process.env.NODE_ENV !== \"production\") {\n if (helpers == null) {\n console.warn(\n 'TokenizedInputBase is used without helpers. You should pass in \"helpers\" from \"useTokenizedInput\".',\n );\n }\n }\n return helpers != null;\n}\n\nexport const TokenizedInputBase = forwardRef(function TokenizedInputBase<Item>(\n props: TokenizedInputBaseProps<Item>,\n ref: ForwardedRef<HTMLDivElement>,\n) {\n const {\n InputProps = {},\n ExpandButtonProps = {},\n className,\n activeIndices = [],\n selectedItems = [],\n highlightedIndex,\n value,\n focused,\n expanded,\n disabled,\n helpers,\n onFocus,\n onBlur,\n onKeyUp,\n onKeyDown,\n onRemoveItem,\n onInputChange,\n onInputFocus,\n onInputBlur,\n onInputSelect,\n onClear,\n onClick,\n inputRef,\n itemToString = defaultItemToString,\n id: idProp,\n expandButtonRef: expandButtonRefProp,\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabelledBy,\n ...restProps\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-tokenized-input\",\n css: tokenizedInputCss,\n window: targetWindow,\n });\n\n const density = useDensity();\n const { OverflowIcon, CloseIcon } = useIcon();\n const id = useId(idProp);\n const inputId = `${id}-input`;\n const expandButtonId = `${id}-expand-button`;\n const clearButtonId = `${id}-clear-button`;\n\n // TODO: Use proper machanism to get variable values from theme in React. Something like below\n // getComputedStyle(document.documentElement)\n // .getPropertyValue('--my-variable-name'); // #999999\n const pillGroupPadding = 16;\n const lastVisiblePillMargin = 4;\n\n const pillsRef = useRef<{ [index: number]: number | undefined }>({});\n const inputRulerRef = useRef<HTMLSpanElement | null>(null);\n const keydownExpandButton = useRef(false);\n\n const [expandButtonRef, expandButtonWidth] = useWidth(density);\n const [clearButtonRef, clearButtonWidth] = useWidth(density);\n const [inputWidth, setInputWidth] = useState(INITIAL_INPUT_WIDTH);\n const [pillGroupWidth, setPillGroupWidth] = useState<number | null>(null);\n const [firstHiddenIndex, setFirstHiddenIndex] = useState<number | null>(null);\n\n const showExpandButton = !expanded && firstHiddenIndex != null;\n\n const widthOffset =\n pillGroupPadding +\n INITIAL_INPUT_WIDTH +\n (expanded ? clearButtonWidth : expandButtonWidth);\n\n const containerRef = useResizeObserver<HTMLDivElement>(\n useCallback(\n ([{ contentRect }]) => {\n setPillGroupWidth(contentRect.width - widthOffset);\n },\n [widthOffset],\n ),\n );\n\n useIsomorphicLayoutEffect(\n () => () => {\n // When density changes, set hidden index to null so that pills are in their\n // readonly state before they are measured.\n setFirstHiddenIndex(null);\n },\n [density],\n );\n\n // useLayoutEffect because of potential layout change\n // We want to do that before paint to avoid layout jumps\n useIsomorphicLayoutEffect(\n () => {\n if (expanded) {\n setFirstHiddenIndex(null);\n } else if (pillGroupWidth != null) {\n setFirstHiddenIndex(\n calcFirstHiddenIndex({\n containerWidth: pillGroupWidth,\n pillWidths: Object.values(pillsRef.current).filter(\n Boolean,\n ) as number[],\n }),\n );\n }\n },\n // Additional dependency on selectedItems is for the controlled version\n [expanded, pillGroupWidth, selectedItems],\n );\n\n useIsomorphicLayoutEffect(() => {\n if (expanded && inputRulerRef.current) {\n const newInputWidth = inputRulerRef.current.scrollWidth;\n setInputWidth(Math.min(newInputWidth, pillGroupWidth || 0));\n }\n }, [expanded, pillGroupWidth, value]);\n\n const handleExpandButtonKeyDown = (\n event: KeyboardEvent<HTMLButtonElement>,\n ) => {\n const singleChar = event.key.length === 1;\n const triggerExpand =\n [\n \"CONTROL\",\n \"META\",\n \"ENTER\",\n \"BACKSPACE\",\n \"ARROWDOWN\",\n \"ARROWLEFT\",\n \"ARROWRIGHT\",\n ].indexOf(event.key.toUpperCase()) !== -1;\n\n if ((singleChar || triggerExpand) && hasHelpers(helpers)) {\n if (event.key === \"Enter\" || event.key === \" \") {\n event.preventDefault();\n event.stopPropagation();\n }\n helpers.updateExpanded(true);\n keydownExpandButton.current = true;\n }\n };\n\n const handleInputKeyUp = (event: KeyboardEvent<HTMLInputElement>) => {\n // Call keydown again if the initail event has been used to expand the input\n if (keydownExpandButton.current && \"Enter\" !== event.key) {\n keydownExpandButton.current = false;\n\n if (onKeyDown) {\n onKeyDown(event);\n }\n }\n\n if (onKeyUp) {\n onKeyUp(event);\n }\n };\n\n const handleExpand = (event: SyntheticEvent<HTMLButtonElement>) => {\n event.stopPropagation();\n\n if (hasHelpers(helpers)) {\n helpers.updateExpanded(true);\n }\n };\n\n const handleClearButtonFocus = (event: FocusEvent<HTMLButtonElement>) => {\n event.stopPropagation();\n\n if (hasHelpers(helpers)) {\n helpers.setFocused(false);\n helpers.cancelBlur();\n }\n };\n\n const selectedItemIds = selectedItems.map(\n (_, index) => `${id}-pill-${index}`,\n );\n\n const inputAriaLabelledBy = disabled\n ? [ariaLabelledBy, inputId, ...selectedItemIds]\n : [ariaLabelledBy, inputId];\n\n const mergedInputProps = deepmerge(\n {\n inputProps: {\n style: {\n width: inputWidth,\n minWidth: inputWidth,\n },\n \"aria-label\": [ariaLabel, getItemsAriaLabel(selectedItems.length)]\n .filter(Boolean)\n .join(\" \"),\n \"aria-labelledby\": inputAriaLabelledBy.filter(Boolean).join(\" \"),\n \"aria-activedescendant\":\n highlightedIndex && highlightedIndex >= 0\n ? `${id}-pill-${highlightedIndex}`\n : undefined,\n },\n },\n InputProps,\n );\n\n const {\n accessibleText: expandButtonAccessibleText,\n ...restExpandButtonProps\n } = ExpandButtonProps;\n\n return (\n <div\n {...restProps}\n className={clsx(\n withBaseName(),\n {\n [withBaseName(\"focused\")]: focused,\n [withBaseName(\"expanded\")]: expanded,\n [withBaseName(\"disabled\")]: disabled,\n },\n className,\n )}\n id={id}\n onClick={onClick}\n ref={useForkRef(ref, containerRef)}\n >\n <span\n aria-owns={selectedItemIds.join(\" \")}\n className={withBaseName(\"hidden\")}\n role=\"listbox\"\n />\n <div className={withBaseName(\"pillGroup\")}>\n {selectedItems.map((item, index) => {\n const label = itemToString(item);\n\n return (\n <InputPill\n active={activeIndices.indexOf(index) !== -1}\n disabled={disabled}\n hidden={showExpandButton && index >= firstHiddenIndex}\n highlighted={index === highlightedIndex}\n id={`${id}-pill-${index}`}\n index={index}\n key={`${index}-${label}`}\n label={label}\n lastVisible={\n !showExpandButton && index === selectedItems.length - 1\n }\n onDelete={expanded ? onRemoveItem : undefined}\n pillsRef={pillsRef}\n />\n );\n })}\n <Button\n aria-labelledby={[ariaLabelledBy, inputId, expandButtonId]\n .filter(Boolean)\n .join(\" \")}\n className={clsx(withBaseName(\"expandButton\"), {\n [withBaseName(\"hidden\")]: !showExpandButton,\n })}\n disabled={disabled}\n id={expandButtonId}\n onBlur={onBlur}\n onClick={handleExpand}\n onFocus={onFocus}\n onKeyDown={handleExpandButtonKeyDown}\n ref={useForkRef(expandButtonRef, expandButtonRefProp)}\n variant=\"secondary\"\n {...restExpandButtonProps}\n >\n <OverflowIcon\n aria-label={\n expandButtonAccessibleText === undefined\n ? \"expand edit\"\n : expandButtonAccessibleText\n }\n />\n </Button>\n <Input\n {...mergedInputProps}\n className={clsx(withBaseName(\"input\"), withBaseName(\"inputField\"), {\n [withBaseName(\"hidden\")]: showExpandButton,\n })}\n disabled={disabled}\n id={inputId}\n // TODO: Use multi line input when available\n // multiline\n onBlur={onInputBlur}\n onChange={onInputChange}\n onFocus={onInputFocus}\n onKeyDown={onKeyDown}\n onKeyUp={handleInputKeyUp}\n onSelect={onInputSelect}\n renderSuffix={() => <InputRuler ref={inputRulerRef} value={value} />}\n value={value}\n ref={inputRef}\n />\n </div>\n <Button\n className={clsx(withBaseName(\"clearButton\"), {\n [withBaseName(\"hidden\")]: !expanded || selectedItems.length === 0,\n })}\n disabled={disabled}\n id={clearButtonId}\n onBlur={onBlur}\n onClick={onClear}\n onFocus={handleClearButtonFocus}\n ref={clearButtonRef}\n variant=\"secondary\"\n data-testid=\"clear-button\"\n >\n <CloseIcon aria-label=\"clear input\" />\n </Button>\n </div>\n );\n}) as <Item>(\n p: TokenizedInputBaseProps<Item> & { ref?: ForwardedRef<HTMLDivElement> },\n) => ReactElement<TokenizedInputBaseProps<Item>>;\n"],"names":["makePrefixer","forwardRef","TokenizedInputBase","defaultItemToString","useWindow","useComponentCssInjection","tokenizedInputCss","useDensity","useIcon","useId","useRef","useWidth","useState","useResizeObserver","useCallback","useIsomorphicLayoutEffect","calcFirstHiddenIndex","jsxs","clsx","useForkRef","jsx","InputPill","Button","Input","InputRuler"],"mappings":"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"}