@salt-ds/lab 1.0.0-alpha.48 → 1.0.0-alpha.49

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 (1219) hide show
  1. package/css/salt-lab.css +15 -5
  2. package/dist-cjs/app-header/AppHeader.js +3 -3
  3. package/dist-cjs/app-header/AppHeader.js.map +1 -1
  4. package/dist-cjs/breadcrumbs/Breadcrumb.js +1 -1
  5. package/dist-cjs/breadcrumbs/Breadcrumb.js.map +1 -1
  6. package/dist-cjs/breadcrumbs/Breadcrumbs.js +3 -4
  7. package/dist-cjs/breadcrumbs/Breadcrumbs.js.map +1 -1
  8. package/dist-cjs/breadcrumbs/internal/BreadcrumbsCollapsed.js +4 -4
  9. package/dist-cjs/breadcrumbs/internal/BreadcrumbsCollapsed.js.map +1 -1
  10. package/dist-cjs/breadcrumbs/internal/BreadcrumbsContext.js.map +1 -1
  11. package/dist-cjs/breadcrumbs/internal/BreadcrumbsSeparator.js.map +1 -1
  12. package/dist-cjs/breadcrumbs/internal/useFocusMenuRemount.js +1 -1
  13. package/dist-cjs/breadcrumbs/internal/useFocusMenuRemount.js.map +1 -1
  14. package/dist-cjs/button-bar/ButtonBar.js +10 -12
  15. package/dist-cjs/button-bar/ButtonBar.js.map +1 -1
  16. package/dist-cjs/button-bar/OrderedButton.js +2 -2
  17. package/dist-cjs/button-bar/OrderedButton.js.map +1 -1
  18. package/dist-cjs/button-bar/internal/ButtonBarContext.js.map +1 -1
  19. package/dist-cjs/button-bar/internal/DescendantContext.js +1 -1
  20. package/dist-cjs/button-bar/internal/DescendantContext.js.map +1 -1
  21. package/dist-cjs/button-bar/internal/useDescendant.js +1 -1
  22. package/dist-cjs/button-bar/internal/useDescendant.js.map +1 -1
  23. package/dist-cjs/button-bar/internal/useDescendants.js.map +1 -1
  24. package/dist-cjs/calendar/Calendar.js +6 -6
  25. package/dist-cjs/calendar/Calendar.js.map +1 -1
  26. package/dist-cjs/calendar/internal/CalendarCarousel.js +4 -4
  27. package/dist-cjs/calendar/internal/CalendarCarousel.js.map +1 -1
  28. package/dist-cjs/calendar/internal/CalendarContext.js.map +1 -1
  29. package/dist-cjs/calendar/internal/CalendarDay.css.js +1 -1
  30. package/dist-cjs/calendar/internal/CalendarDay.js +4 -4
  31. package/dist-cjs/calendar/internal/CalendarDay.js.map +1 -1
  32. package/dist-cjs/calendar/internal/CalendarMonth.js +5 -5
  33. package/dist-cjs/calendar/internal/CalendarMonth.js.map +1 -1
  34. package/dist-cjs/calendar/internal/CalendarNavigation.js +4 -4
  35. package/dist-cjs/calendar/internal/CalendarNavigation.js.map +1 -1
  36. package/dist-cjs/calendar/internal/CalendarWeekHeader.js +5 -5
  37. package/dist-cjs/calendar/internal/CalendarWeekHeader.js.map +1 -1
  38. package/dist-cjs/calendar/internal/useFocusManagement.js +1 -1
  39. package/dist-cjs/calendar/internal/useFocusManagement.js.map +1 -1
  40. package/dist-cjs/calendar/internal/utils.js.map +1 -1
  41. package/dist-cjs/calendar/useCalendar.js.map +1 -1
  42. package/dist-cjs/calendar/useCalendarDay.js.map +1 -1
  43. package/dist-cjs/calendar/useSelection.js +16 -12
  44. package/dist-cjs/calendar/useSelection.js.map +1 -1
  45. package/dist-cjs/carousel/Carousel.js +7 -6
  46. package/dist-cjs/carousel/Carousel.js.map +1 -1
  47. package/dist-cjs/carousel/CarouselSlide.js +1 -1
  48. package/dist-cjs/carousel/CarouselSlide.js.map +1 -1
  49. package/dist-cjs/cascading-menu/CascadingMenu.js +1 -2
  50. package/dist-cjs/cascading-menu/CascadingMenu.js.map +1 -1
  51. package/dist-cjs/cascading-menu/CascadingMenuItem.js +6 -7
  52. package/dist-cjs/cascading-menu/CascadingMenuItem.js.map +1 -1
  53. package/dist-cjs/cascading-menu/CascadingMenuList.js +8 -8
  54. package/dist-cjs/cascading-menu/CascadingMenuList.js.map +1 -1
  55. package/dist-cjs/cascading-menu/internal/CascadingMenuAction.js.map +1 -1
  56. package/dist-cjs/cascading-menu/internal/keydownHandlers.js +2 -2
  57. package/dist-cjs/cascading-menu/internal/keydownHandlers.js.map +1 -1
  58. package/dist-cjs/cascading-menu/internal/menuPositioning.js.map +1 -1
  59. package/dist-cjs/cascading-menu/internal/stateUtils.js +1 -2
  60. package/dist-cjs/cascading-menu/internal/stateUtils.js.map +1 -1
  61. package/dist-cjs/cascading-menu/internal/useClickAway.js +3 -2
  62. package/dist-cjs/cascading-menu/internal/useClickAway.js.map +1 -1
  63. package/dist-cjs/cascading-menu/internal/useMenuTriggerHandlers.js.map +1 -1
  64. package/dist-cjs/cascading-menu/internal/useMouseHandlers.js +1 -1
  65. package/dist-cjs/cascading-menu/internal/useMouseHandlers.js.map +1 -1
  66. package/dist-cjs/cascading-menu/internal/useRefsManager.js.map +1 -1
  67. package/dist-cjs/cascading-menu/internal/useStateReducer.js +1 -1
  68. package/dist-cjs/cascading-menu/internal/useStateReducer.js.map +1 -1
  69. package/dist-cjs/color-chooser/AlphaInputField.js +10 -10
  70. package/dist-cjs/color-chooser/AlphaInputField.js.map +1 -1
  71. package/dist-cjs/color-chooser/Color.js +1 -2
  72. package/dist-cjs/color-chooser/Color.js.map +1 -1
  73. package/dist-cjs/color-chooser/ColorChooser.css.js +1 -1
  74. package/dist-cjs/color-chooser/ColorChooser.js +4 -4
  75. package/dist-cjs/color-chooser/ColorChooser.js.map +1 -1
  76. package/dist-cjs/color-chooser/ColorHelpers.js +1 -1
  77. package/dist-cjs/color-chooser/ColorHelpers.js.map +1 -1
  78. package/dist-cjs/color-chooser/ColorPicker.js +3 -3
  79. package/dist-cjs/color-chooser/ColorPicker.js.map +1 -1
  80. package/dist-cjs/color-chooser/DictTabs.js +1 -1
  81. package/dist-cjs/color-chooser/DictTabs.js.map +1 -1
  82. package/dist-cjs/color-chooser/GetColorPalettes.js.map +1 -1
  83. package/dist-cjs/color-chooser/HexInput.js +5 -5
  84. package/dist-cjs/color-chooser/HexInput.js.map +1 -1
  85. package/dist-cjs/color-chooser/RGBAInput.js +3 -3
  86. package/dist-cjs/color-chooser/RGBAInput.js.map +1 -1
  87. package/dist-cjs/color-chooser/RGBAInputField.js +4 -4
  88. package/dist-cjs/color-chooser/RGBAInputField.js.map +1 -1
  89. package/dist-cjs/color-chooser/Swatch.css.js +1 -1
  90. package/dist-cjs/color-chooser/Swatch.js +1 -1
  91. package/dist-cjs/color-chooser/Swatch.js.map +1 -1
  92. package/dist-cjs/color-chooser/Swatches.js +2 -2
  93. package/dist-cjs/color-chooser/Swatches.js.map +1 -1
  94. package/dist-cjs/color-chooser/SwatchesPicker.js +2 -2
  95. package/dist-cjs/color-chooser/SwatchesPicker.js.map +1 -1
  96. package/dist-cjs/color-chooser/createTabsMapping.js.map +1 -1
  97. package/dist-cjs/combo-box/ComboBox.js +10 -10
  98. package/dist-cjs/combo-box/ComboBox.js.map +1 -1
  99. package/dist-cjs/combo-box/useCombobox.js +13 -20
  100. package/dist-cjs/combo-box/useCombobox.js.map +1 -1
  101. package/dist-cjs/combo-box-deprecated/ComboBoxDeprecated.js +5 -5
  102. package/dist-cjs/combo-box-deprecated/ComboBoxDeprecated.js.map +1 -1
  103. package/dist-cjs/combo-box-deprecated/internal/DefaultComboBox.js +7 -7
  104. package/dist-cjs/combo-box-deprecated/internal/DefaultComboBox.js.map +1 -1
  105. package/dist-cjs/combo-box-deprecated/internal/MultiSelectComboBox.js +3 -3
  106. package/dist-cjs/combo-box-deprecated/internal/MultiSelectComboBox.js.map +1 -1
  107. package/dist-cjs/combo-box-deprecated/internal/getAnnouncement.js +2 -2
  108. package/dist-cjs/combo-box-deprecated/internal/getAnnouncement.js.map +1 -1
  109. package/dist-cjs/combo-box-deprecated/internal/useComboBox.js +12 -10
  110. package/dist-cjs/combo-box-deprecated/internal/useComboBox.js.map +1 -1
  111. package/dist-cjs/combo-box-deprecated/internal/useMultiSelectComboBox.js +11 -15
  112. package/dist-cjs/combo-box-deprecated/internal/useMultiSelectComboBox.js.map +1 -1
  113. package/dist-cjs/combo-box-deprecated/internal/usePopperStatus.js.map +1 -1
  114. package/dist-cjs/common-hooks/calcPreferredHeight.js +1 -1
  115. package/dist-cjs/common-hooks/calcPreferredHeight.js.map +1 -1
  116. package/dist-cjs/common-hooks/collectionProvider.js.map +1 -1
  117. package/dist-cjs/common-hooks/itemToString.js +2 -1
  118. package/dist-cjs/common-hooks/itemToString.js.map +1 -1
  119. package/dist-cjs/common-hooks/keyUtils.js +2 -2
  120. package/dist-cjs/common-hooks/keyUtils.js.map +1 -1
  121. package/dist-cjs/common-hooks/list-dom-utils.js +4 -3
  122. package/dist-cjs/common-hooks/list-dom-utils.js.map +1 -1
  123. package/dist-cjs/common-hooks/selectionTypes.js.map +1 -1
  124. package/dist-cjs/common-hooks/useAutoSizer.js +2 -2
  125. package/dist-cjs/common-hooks/useAutoSizer.js.map +1 -1
  126. package/dist-cjs/common-hooks/useCollapsibleGroups.js.map +1 -1
  127. package/dist-cjs/common-hooks/useCollectionItems.js +13 -9
  128. package/dist-cjs/common-hooks/useCollectionItems.js.map +1 -1
  129. package/dist-cjs/common-hooks/useImperativeScrollingAPI.js +11 -7
  130. package/dist-cjs/common-hooks/useImperativeScrollingAPI.js.map +1 -1
  131. package/dist-cjs/common-hooks/useKeyboardNavigation.js +78 -82
  132. package/dist-cjs/common-hooks/useKeyboardNavigation.js.map +1 -1
  133. package/dist-cjs/common-hooks/useKeyboardNavigationPanel.js +14 -13
  134. package/dist-cjs/common-hooks/useKeyboardNavigationPanel.js.map +1 -1
  135. package/dist-cjs/common-hooks/useSelection.js +0 -1
  136. package/dist-cjs/common-hooks/useSelection.js.map +1 -1
  137. package/dist-cjs/common-hooks/useTypeahead.js.map +1 -1
  138. package/dist-cjs/common-hooks/useViewportTracking.js +24 -23
  139. package/dist-cjs/common-hooks/useViewportTracking.js.map +1 -1
  140. package/dist-cjs/common-hooks/utils/collection-item-utils.js +29 -29
  141. package/dist-cjs/common-hooks/utils/collection-item-utils.js.map +1 -1
  142. package/dist-cjs/common-hooks/utils/isSelected.js.map +1 -1
  143. package/dist-cjs/contact-details/ContactAction.js +1 -1
  144. package/dist-cjs/contact-details/ContactAction.js.map +1 -1
  145. package/dist-cjs/contact-details/ContactActions.js +2 -2
  146. package/dist-cjs/contact-details/ContactActions.js.map +1 -1
  147. package/dist-cjs/contact-details/ContactAvatar.js +3 -3
  148. package/dist-cjs/contact-details/ContactAvatar.js.map +1 -1
  149. package/dist-cjs/contact-details/ContactDetails.js +1 -1
  150. package/dist-cjs/contact-details/ContactDetails.js.map +1 -1
  151. package/dist-cjs/contact-details/ContactFavoriteToggle.js.map +1 -1
  152. package/dist-cjs/contact-details/ContactMetadata.js.map +1 -1
  153. package/dist-cjs/contact-details/ContactMetadataItem.js.map +1 -1
  154. package/dist-cjs/contact-details/ContactPrimaryInfo.js.map +1 -1
  155. package/dist-cjs/contact-details/ContactSecondaryInfo.js.map +1 -1
  156. package/dist-cjs/contact-details/ContactTertiaryInfo.js.map +1 -1
  157. package/dist-cjs/contact-details/MailLinkComponent.js.map +1 -1
  158. package/dist-cjs/contact-details/internal/ContactDetailsContext.js +1 -1
  159. package/dist-cjs/contact-details/internal/ContactDetailsContext.js.map +1 -1
  160. package/dist-cjs/contact-details/internal/FavoriteToggle.js.map +1 -1
  161. package/dist-cjs/contact-details/internal/FavoriteToggleWithTooltip.js +1 -1
  162. package/dist-cjs/contact-details/internal/FavoriteToggleWithTooltip.js.map +1 -1
  163. package/dist-cjs/contact-details/internal/StarIcon.js.map +1 -1
  164. package/dist-cjs/contact-details/internal/StarIconContainer.js +2 -2
  165. package/dist-cjs/contact-details/internal/StarIconContainer.js.map +1 -1
  166. package/dist-cjs/contact-details/internal/useComponentSize.js +7 -10
  167. package/dist-cjs/contact-details/internal/useComponentSize.js.map +1 -1
  168. package/dist-cjs/content-status/ContentStatus.js +1 -1
  169. package/dist-cjs/content-status/ContentStatus.js.map +1 -1
  170. package/dist-cjs/content-status/internal/StatusIndicator.js.map +1 -1
  171. package/dist-cjs/date-input/DateInput.js +7 -7
  172. package/dist-cjs/date-input/DateInput.js.map +1 -1
  173. package/dist-cjs/date-picker/DatePicker.js +6 -6
  174. package/dist-cjs/date-picker/DatePicker.js.map +1 -1
  175. package/dist-cjs/date-picker/DatePickerContext.js.map +1 -1
  176. package/dist-cjs/date-picker/DatePickerPanel.css.js +1 -1
  177. package/dist-cjs/date-picker/DatePickerPanel.js +18 -16
  178. package/dist-cjs/date-picker/DatePickerPanel.js.map +1 -1
  179. package/dist-cjs/deck-item/DeckItem.js +2 -2
  180. package/dist-cjs/deck-item/DeckItem.js.map +1 -1
  181. package/dist-cjs/deck-layout/DeckLayout.js +6 -9
  182. package/dist-cjs/deck-layout/DeckLayout.js.map +1 -1
  183. package/dist-cjs/dropdown/Dropdown.js +12 -12
  184. package/dist-cjs/dropdown/Dropdown.js.map +1 -1
  185. package/dist-cjs/dropdown/DropdownBase.js +3 -3
  186. package/dist-cjs/dropdown/DropdownBase.js.map +1 -1
  187. package/dist-cjs/dropdown/DropdownButton.js +3 -3
  188. package/dist-cjs/dropdown/DropdownButton.js.map +1 -1
  189. package/dist-cjs/dropdown/useClickAway.js +1 -1
  190. package/dist-cjs/dropdown/useClickAway.js.map +1 -1
  191. package/dist-cjs/dropdown/useDropdown.js +13 -14
  192. package/dist-cjs/dropdown/useDropdown.js.map +1 -1
  193. package/dist-cjs/dropdown/useDropdownBase.js +10 -12
  194. package/dist-cjs/dropdown/useDropdownBase.js.map +1 -1
  195. package/dist-cjs/editable-label/EditableLabel.js +7 -7
  196. package/dist-cjs/editable-label/EditableLabel.js.map +1 -1
  197. package/dist-cjs/form-field-context-legacy/FormFieldLegacyContext.js.map +1 -1
  198. package/dist-cjs/form-field-context-legacy/useFormFieldLegacyProps.js +1 -1
  199. package/dist-cjs/form-field-context-legacy/useFormFieldLegacyProps.js.map +1 -1
  200. package/dist-cjs/form-field-legacy/FormActivationIndicator.css.js +1 -1
  201. package/dist-cjs/form-field-legacy/FormActivationIndicator.js +4 -4
  202. package/dist-cjs/form-field-legacy/FormActivationIndicator.js.map +1 -1
  203. package/dist-cjs/form-field-legacy/FormFieldLegacy.css.js +1 -1
  204. package/dist-cjs/form-field-legacy/FormFieldLegacy.js +6 -6
  205. package/dist-cjs/form-field-legacy/FormFieldLegacy.js.map +1 -1
  206. package/dist-cjs/form-field-legacy/FormHelperText.js +4 -5
  207. package/dist-cjs/form-field-legacy/FormHelperText.js.map +1 -1
  208. package/dist-cjs/form-field-legacy/FormLabel.js +4 -4
  209. package/dist-cjs/form-field-legacy/FormLabel.js.map +1 -1
  210. package/dist-cjs/form-field-legacy/NecessityIndicator.js +2 -2
  211. package/dist-cjs/form-field-legacy/NecessityIndicator.js.map +1 -1
  212. package/dist-cjs/form-field-legacy/StatusIndicator.js +6 -6
  213. package/dist-cjs/form-field-legacy/StatusIndicator.js.map +1 -1
  214. package/dist-cjs/form-group/FormGroup.js +2 -2
  215. package/dist-cjs/form-group/FormGroup.js.map +1 -1
  216. package/dist-cjs/formatted-input/FormattedInput.js +2 -2
  217. package/dist-cjs/formatted-input/FormattedInput.js.map +1 -1
  218. package/dist-cjs/formatted-input/internal/InputWithMask.js.map +1 -1
  219. package/dist-cjs/input-legacy/InputLegacy.js +5 -5
  220. package/dist-cjs/input-legacy/InputLegacy.js.map +1 -1
  221. package/dist-cjs/input-legacy/StaticInputAdornment.js +3 -3
  222. package/dist-cjs/input-legacy/StaticInputAdornment.js.map +1 -1
  223. package/dist-cjs/input-legacy/useCursorOnFocus.js +2 -2
  224. package/dist-cjs/input-legacy/useCursorOnFocus.js.map +1 -1
  225. package/dist-cjs/layer-layout/LayerLayout.js +4 -4
  226. package/dist-cjs/layer-layout/LayerLayout.js.map +1 -1
  227. package/dist-cjs/list/Highlighter.js +1 -1
  228. package/dist-cjs/list/Highlighter.js.map +1 -1
  229. package/dist-cjs/list/List.css.js +1 -1
  230. package/dist-cjs/list/List.js +4 -6
  231. package/dist-cjs/list/List.js.map +1 -1
  232. package/dist-cjs/list/ListItem.js +3 -3
  233. package/dist-cjs/list/ListItem.js.map +1 -1
  234. package/dist-cjs/list/ListItemGroup.js.map +1 -1
  235. package/dist-cjs/list/ListItemHeader.js.map +1 -1
  236. package/dist-cjs/list/VirtualizedList.js +3 -5
  237. package/dist-cjs/list/VirtualizedList.js.map +1 -1
  238. package/dist-cjs/list/keyset.js +1 -2
  239. package/dist-cjs/list/keyset.js.map +1 -1
  240. package/dist-cjs/list/useList.js.map +1 -1
  241. package/dist-cjs/list/useListHeight.js +1 -1
  242. package/dist-cjs/list/useListHeight.js.map +1 -1
  243. package/dist-cjs/list/useVirtualization.js +2 -2
  244. package/dist-cjs/list/useVirtualization.js.map +1 -1
  245. package/dist-cjs/list-deprecated/List.js.map +1 -1
  246. package/dist-cjs/list-deprecated/ListBase.js +52 -53
  247. package/dist-cjs/list-deprecated/ListBase.js.map +1 -1
  248. package/dist-cjs/list-deprecated/ListItem.js +2 -2
  249. package/dist-cjs/list-deprecated/ListItem.js.map +1 -1
  250. package/dist-cjs/list-deprecated/ListItemBase.js +1 -1
  251. package/dist-cjs/list-deprecated/ListItemBase.js.map +1 -1
  252. package/dist-cjs/list-deprecated/ListItemContext.js +1 -1
  253. package/dist-cjs/list-deprecated/ListItemContext.js.map +1 -1
  254. package/dist-cjs/list-deprecated/ListStateContext.js.map +1 -1
  255. package/dist-cjs/list-deprecated/internal/DescendantContext.js +1 -1
  256. package/dist-cjs/list-deprecated/internal/DescendantContext.js.map +1 -1
  257. package/dist-cjs/list-deprecated/internal/Highlighter.js +2 -2
  258. package/dist-cjs/list-deprecated/internal/Highlighter.js.map +1 -1
  259. package/dist-cjs/list-deprecated/internal/calcPreferredListHeight.js +1 -1
  260. package/dist-cjs/list-deprecated/internal/calcPreferredListHeight.js.map +1 -1
  261. package/dist-cjs/list-deprecated/internal/helpers.js.map +1 -1
  262. package/dist-cjs/list-deprecated/internal/useListAutoSizer.js +1 -1
  263. package/dist-cjs/list-deprecated/internal/useListAutoSizer.js.map +1 -1
  264. package/dist-cjs/list-deprecated/internal/useWidth.js.map +1 -1
  265. package/dist-cjs/list-deprecated/itemToString.js.map +1 -1
  266. package/dist-cjs/list-deprecated/useList.js +4 -22
  267. package/dist-cjs/list-deprecated/useList.js.map +1 -1
  268. package/dist-cjs/list-deprecated/useListItem.js +2 -2
  269. package/dist-cjs/list-deprecated/useListItem.js.map +1 -1
  270. package/dist-cjs/list-deprecated/useTypeSelect.js +1 -1
  271. package/dist-cjs/list-deprecated/useTypeSelect.js.map +1 -1
  272. package/dist-cjs/list-next/ListItemNext.js +3 -3
  273. package/dist-cjs/list-next/ListItemNext.js.map +1 -1
  274. package/dist-cjs/list-next/ListNext.js +4 -4
  275. package/dist-cjs/list-next/ListNext.js.map +1 -1
  276. package/dist-cjs/list-next/ListNextContext.js.map +1 -1
  277. package/dist-cjs/list-next/useList.js +6 -9
  278. package/dist-cjs/list-next/useList.js.map +1 -1
  279. package/dist-cjs/logo/Logo.js +19 -17
  280. package/dist-cjs/logo/Logo.js.map +1 -1
  281. package/dist-cjs/logo/LogoImage.js +3 -3
  282. package/dist-cjs/logo/LogoImage.js.map +1 -1
  283. package/dist-cjs/logo/LogoSeparator.js +3 -3
  284. package/dist-cjs/logo/LogoSeparator.js.map +1 -1
  285. package/dist-cjs/menu-button/MenuButton.js +6 -6
  286. package/dist-cjs/menu-button/MenuButton.js.map +1 -1
  287. package/dist-cjs/menu-button/MenuButtonTrigger.js +3 -3
  288. package/dist-cjs/menu-button/MenuButtonTrigger.js.map +1 -1
  289. package/dist-cjs/metric/Metric.js +1 -1
  290. package/dist-cjs/metric/Metric.js.map +1 -1
  291. package/dist-cjs/metric/MetricContent.js +1 -1
  292. package/dist-cjs/metric/MetricContent.js.map +1 -1
  293. package/dist-cjs/metric/MetricHeader.js +1 -1
  294. package/dist-cjs/metric/MetricHeader.js.map +1 -1
  295. package/dist-cjs/portal/Portal.js +2 -5
  296. package/dist-cjs/portal/Portal.js.map +1 -1
  297. package/dist-cjs/query-input/QueryInput.js +1 -1
  298. package/dist-cjs/query-input/QueryInput.js.map +1 -1
  299. package/dist-cjs/query-input/internal/CategoryList.js +5 -5
  300. package/dist-cjs/query-input/internal/CategoryList.js.map +1 -1
  301. package/dist-cjs/query-input/internal/CategoryListContext.js +1 -1
  302. package/dist-cjs/query-input/internal/CategoryListContext.js.map +1 -1
  303. package/dist-cjs/query-input/internal/CategoryListItem.js.map +1 -1
  304. package/dist-cjs/query-input/internal/QueryInputBody.js.map +1 -1
  305. package/dist-cjs/query-input/internal/SearchList.js +2 -2
  306. package/dist-cjs/query-input/internal/SearchList.js.map +1 -1
  307. package/dist-cjs/query-input/internal/ValueList.js.map +1 -1
  308. package/dist-cjs/query-input/internal/ValueSelector.js +3 -3
  309. package/dist-cjs/query-input/internal/ValueSelector.js.map +1 -1
  310. package/dist-cjs/query-input/internal/usePopperStatus.js.map +1 -1
  311. package/dist-cjs/query-input/useQueryInput.js +36 -22
  312. package/dist-cjs/query-input/useQueryInput.js.map +1 -1
  313. package/dist-cjs/responsive/OverflowReducer.js +16 -19
  314. package/dist-cjs/responsive/OverflowReducer.js.map +1 -1
  315. package/dist-cjs/responsive/overflowUtils.js +22 -26
  316. package/dist-cjs/responsive/overflowUtils.js.map +1 -1
  317. package/dist-cjs/responsive/useDynamicCollapse.js +5 -5
  318. package/dist-cjs/responsive/useDynamicCollapse.js.map +1 -1
  319. package/dist-cjs/responsive/useInstantCollapse.js +3 -4
  320. package/dist-cjs/responsive/useInstantCollapse.js.map +1 -1
  321. package/dist-cjs/responsive/useOverflow.js +11 -6
  322. package/dist-cjs/responsive/useOverflow.js.map +1 -1
  323. package/dist-cjs/responsive/useOverflowCollectionItems.js +3 -3
  324. package/dist-cjs/responsive/useOverflowCollectionItems.js.map +1 -1
  325. package/dist-cjs/responsive/useOverflowLayout.js +3 -3
  326. package/dist-cjs/responsive/useOverflowLayout.js.map +1 -1
  327. package/dist-cjs/responsive/useReclaimSpace.js +10 -20
  328. package/dist-cjs/responsive/useReclaimSpace.js.map +1 -1
  329. package/dist-cjs/responsive/useResizeObserver.js +1 -1
  330. package/dist-cjs/responsive/useResizeObserver.js.map +1 -1
  331. package/dist-cjs/responsive/useWidth.js +2 -2
  332. package/dist-cjs/responsive/useWidth.js.map +1 -1
  333. package/dist-cjs/responsive/utils.js +1 -2
  334. package/dist-cjs/responsive/utils.js.map +1 -1
  335. package/dist-cjs/search-input/SearchInput.js +4 -4
  336. package/dist-cjs/search-input/SearchInput.js.map +1 -1
  337. package/dist-cjs/skip-link/SkipLink.js +3 -3
  338. package/dist-cjs/skip-link/SkipLink.js.map +1 -1
  339. package/dist-cjs/skip-link/SkipLinks.js +3 -3
  340. package/dist-cjs/skip-link/SkipLinks.js.map +1 -1
  341. package/dist-cjs/skip-link/internal/useManageFocusOnTarget.js.map +1 -1
  342. package/dist-cjs/slider/Slider.js +1 -1
  343. package/dist-cjs/slider/Slider.js.map +1 -1
  344. package/dist-cjs/slider/internal/SliderHandle.js +1 -1
  345. package/dist-cjs/slider/internal/SliderHandle.js.map +1 -1
  346. package/dist-cjs/slider/internal/SliderMarkLabels.js +3 -3
  347. package/dist-cjs/slider/internal/SliderMarkLabels.js.map +1 -1
  348. package/dist-cjs/slider/internal/SliderRail.js +2 -2
  349. package/dist-cjs/slider/internal/SliderRail.js.map +1 -1
  350. package/dist-cjs/slider/internal/SliderRailMarks.js +3 -3
  351. package/dist-cjs/slider/internal/SliderRailMarks.js.map +1 -1
  352. package/dist-cjs/slider/internal/SliderSelection.js +1 -1
  353. package/dist-cjs/slider/internal/SliderSelection.js.map +1 -1
  354. package/dist-cjs/slider/internal/styles.js +2 -2
  355. package/dist-cjs/slider/internal/styles.js.map +1 -1
  356. package/dist-cjs/slider/internal/useSliderKeyDown.js.map +1 -1
  357. package/dist-cjs/slider/internal/useSliderMouseDown.js +21 -18
  358. package/dist-cjs/slider/internal/useSliderMouseDown.js.map +1 -1
  359. package/dist-cjs/slider/internal/utils.js +1 -1
  360. package/dist-cjs/slider/internal/utils.js.map +1 -1
  361. package/dist-cjs/stepped-tracker/StepLabel/StepLabel.js +2 -2
  362. package/dist-cjs/stepped-tracker/StepLabel/StepLabel.js.map +1 -1
  363. package/dist-cjs/stepped-tracker/SteppedTracker.js +3 -3
  364. package/dist-cjs/stepped-tracker/SteppedTracker.js.map +1 -1
  365. package/dist-cjs/stepped-tracker/SteppedTrackerContext.js.map +1 -1
  366. package/dist-cjs/stepped-tracker/TrackerStep/TrackerStep.js +4 -4
  367. package/dist-cjs/stepped-tracker/TrackerStep/TrackerStep.js.map +1 -1
  368. package/dist-cjs/stepper-input/StepperInput.js +3 -3
  369. package/dist-cjs/stepper-input/StepperInput.js.map +1 -1
  370. package/dist-cjs/stepper-input/internal/useInterval.js.map +1 -1
  371. package/dist-cjs/stepper-input/internal/useSpinner.js +1 -1
  372. package/dist-cjs/stepper-input/internal/useSpinner.js.map +1 -1
  373. package/dist-cjs/stepper-input/useStepperInput.js +3 -3
  374. package/dist-cjs/stepper-input/useStepperInput.js.map +1 -1
  375. package/dist-cjs/tabs/Tab.js +5 -6
  376. package/dist-cjs/tabs/Tab.js.map +1 -1
  377. package/dist-cjs/tabs/TabActivationIndicator.js +1 -1
  378. package/dist-cjs/tabs/TabActivationIndicator.js.map +1 -1
  379. package/dist-cjs/tabs/TabPanel.js +3 -3
  380. package/dist-cjs/tabs/TabPanel.js.map +1 -1
  381. package/dist-cjs/tabs/Tabs.js +4 -4
  382. package/dist-cjs/tabs/Tabs.js.map +1 -1
  383. package/dist-cjs/tabs/Tabstrip.js +11 -14
  384. package/dist-cjs/tabs/Tabstrip.js.map +1 -1
  385. package/dist-cjs/tabs/drag-drop/Draggable.js +1 -1
  386. package/dist-cjs/tabs/drag-drop/Draggable.js.map +1 -1
  387. package/dist-cjs/tabs/drag-drop/drag-utils.js +29 -26
  388. package/dist-cjs/tabs/drag-drop/drag-utils.js.map +1 -1
  389. package/dist-cjs/tabs/drag-drop/dragDropTypes.js.map +1 -1
  390. package/dist-cjs/tabs/drag-drop/useDragDrop.js.map +1 -1
  391. package/dist-cjs/tabs/drag-drop/useDragDropNaturalMovement.js +5 -4
  392. package/dist-cjs/tabs/drag-drop/useDragDropNaturalMovement.js.map +1 -1
  393. package/dist-cjs/tabs/drag-drop/useDragSpacers.js +19 -16
  394. package/dist-cjs/tabs/drag-drop/useDragSpacers.js.map +1 -1
  395. package/dist-cjs/tabs/useActivationIndicator.js +3 -2
  396. package/dist-cjs/tabs/useActivationIndicator.js.map +1 -1
  397. package/dist-cjs/tabs/useEditableItem.js +1 -1
  398. package/dist-cjs/tabs/useEditableItem.js.map +1 -1
  399. package/dist-cjs/tabs/useItemsWithIds.js +4 -8
  400. package/dist-cjs/tabs/useItemsWithIds.js.map +1 -1
  401. package/dist-cjs/tabs/useKeyboardNavigation.js +26 -32
  402. package/dist-cjs/tabs/useKeyboardNavigation.js.map +1 -1
  403. package/dist-cjs/tabs/useSelection.js +2 -2
  404. package/dist-cjs/tabs/useSelection.js.map +1 -1
  405. package/dist-cjs/tabs/useTabs.js +1 -1
  406. package/dist-cjs/tabs/useTabs.js.map +1 -1
  407. package/dist-cjs/tabs/useTabstrip.js +6 -5
  408. package/dist-cjs/tabs/useTabstrip.js.map +1 -1
  409. package/dist-cjs/tabs-next/OverflowMenu.js +2 -2
  410. package/dist-cjs/tabs-next/OverflowMenu.js.map +1 -1
  411. package/dist-cjs/tabs-next/TabNext.js +74 -72
  412. package/dist-cjs/tabs-next/TabNext.js.map +1 -1
  413. package/dist-cjs/tabs-next/TabNextContext.js.map +1 -1
  414. package/dist-cjs/tabs-next/TabstripNext.js +5 -5
  415. package/dist-cjs/tabs-next/TabstripNext.js.map +1 -1
  416. package/dist-cjs/toast-group/ToastGroup.js +3 -3
  417. package/dist-cjs/toast-group/ToastGroup.js.map +1 -1
  418. package/dist-cjs/tokenized-input/TokenizedInput.js.map +1 -1
  419. package/dist-cjs/tokenized-input/TokenizedInputBase.js +12 -12
  420. package/dist-cjs/tokenized-input/TokenizedInputBase.js.map +1 -1
  421. package/dist-cjs/tokenized-input/internal/InputPill.js +2 -2
  422. package/dist-cjs/tokenized-input/internal/InputPill.js.map +1 -1
  423. package/dist-cjs/tokenized-input/internal/InputRuler.js +3 -3
  424. package/dist-cjs/tokenized-input/internal/InputRuler.js.map +1 -1
  425. package/dist-cjs/tokenized-input/internal/defaultItemToString.js.map +1 -1
  426. package/dist-cjs/tokenized-input/internal/getCursorPosition.js.map +1 -1
  427. package/dist-cjs/tokenized-input/internal/isPlainObject.js.map +1 -1
  428. package/dist-cjs/tokenized-input/internal/useResizeObserver.js.map +1 -1
  429. package/dist-cjs/tokenized-input/internal/useWidth.js +3 -3
  430. package/dist-cjs/tokenized-input/internal/useWidth.js.map +1 -1
  431. package/dist-cjs/tokenized-input/useTokenizedInput.js +12 -9
  432. package/dist-cjs/tokenized-input/useTokenizedInput.js.map +1 -1
  433. package/dist-cjs/tokenized-input-next/TokenizedInputNext.js +5 -5
  434. package/dist-cjs/tokenized-input-next/TokenizedInputNext.js.map +1 -1
  435. package/dist-cjs/tokenized-input-next/internal/InputPill.js +5 -5
  436. package/dist-cjs/tokenized-input-next/internal/InputPill.js.map +1 -1
  437. package/dist-cjs/tokenized-input-next/internal/useResizeObserver.js.map +1 -1
  438. package/dist-cjs/tokenized-input-next/internal/useWidth.js +3 -3
  439. package/dist-cjs/tokenized-input-next/internal/useWidth.js.map +1 -1
  440. package/dist-cjs/tokenized-input-next/useTokenizedInputNext.js +12 -14
  441. package/dist-cjs/tokenized-input-next/useTokenizedInputNext.js.map +1 -1
  442. package/dist-cjs/toolbar/Toolbar.js +3 -3
  443. package/dist-cjs/toolbar/Toolbar.js.map +1 -1
  444. package/dist-cjs/toolbar/ToolbarButton.js +2 -2
  445. package/dist-cjs/toolbar/ToolbarButton.js.map +1 -1
  446. package/dist-cjs/toolbar/Tooltray.js +1 -1
  447. package/dist-cjs/toolbar/Tooltray.js.map +1 -1
  448. package/dist-cjs/toolbar/internal/renderToolbarItems.js +22 -21
  449. package/dist-cjs/toolbar/internal/renderToolbarItems.js.map +1 -1
  450. package/dist-cjs/toolbar/internal/renderTrayTools.js +21 -23
  451. package/dist-cjs/toolbar/internal/renderTrayTools.js.map +1 -1
  452. package/dist-cjs/toolbar/overflow-panel/OverflowPanel.js +19 -21
  453. package/dist-cjs/toolbar/overflow-panel/OverflowPanel.js.map +1 -1
  454. package/dist-cjs/toolbar/overflow-panel/OverflowSeparator.js +2 -2
  455. package/dist-cjs/toolbar/overflow-panel/OverflowSeparator.js.map +1 -1
  456. package/dist-cjs/toolbar/toolbar-field/ToolbarField.js.map +1 -1
  457. package/dist-cjs/toolbar/toolbar-field/useToolbarField.js +8 -8
  458. package/dist-cjs/toolbar/toolbar-field/useToolbarField.js.map +1 -1
  459. package/dist-cjs/tree/Tree.js +9 -6
  460. package/dist-cjs/tree/Tree.js.map +1 -1
  461. package/dist-cjs/tree/TreeNode.js +2 -2
  462. package/dist-cjs/tree/TreeNode.js.map +1 -1
  463. package/dist-cjs/tree/use-tree-keyboard-navigation.js +5 -4
  464. package/dist-cjs/tree/use-tree-keyboard-navigation.js.map +1 -1
  465. package/dist-cjs/tree/useTree.js +1 -3
  466. package/dist-cjs/tree/useTree.js.map +1 -1
  467. package/dist-cjs/utils/forwardCallbackProps.js.map +1 -1
  468. package/dist-cjs/utils/partition.js.map +1 -1
  469. package/dist-cjs/utils/useClickOutside.js.map +1 -1
  470. package/dist-cjs/utils/useEventCallback.js +1 -1
  471. package/dist-cjs/utils/useEventCallback.js.map +1 -1
  472. package/dist-cjs/utils/useIsViewportLargerThanBreakpoint.js.map +1 -1
  473. package/dist-cjs/utils/useLayoutEffectOnce.js +1 -1
  474. package/dist-cjs/utils/useLayoutEffectOnce.js.map +1 -1
  475. package/dist-cjs/utils/useLayoutEffectSkipFirst.js +1 -1
  476. package/dist-cjs/utils/useLayoutEffectSkipFirst.js.map +1 -1
  477. package/dist-cjs/utils/useOverflowDetection.js +3 -3
  478. package/dist-cjs/utils/useOverflowDetection.js.map +1 -1
  479. package/dist-cjs/utils/useSlideSelection.js.map +1 -1
  480. package/dist-cjs/window/ElectronWindow.js +5 -7
  481. package/dist-cjs/window/ElectronWindow.js.map +1 -1
  482. package/dist-cjs/window/WindowContext.js.map +1 -1
  483. package/dist-es/app-header/AppHeader.js +3 -3
  484. package/dist-es/app-header/AppHeader.js.map +1 -1
  485. package/dist-es/breadcrumbs/Breadcrumb.js +1 -1
  486. package/dist-es/breadcrumbs/Breadcrumb.js.map +1 -1
  487. package/dist-es/breadcrumbs/Breadcrumbs.js +3 -4
  488. package/dist-es/breadcrumbs/Breadcrumbs.js.map +1 -1
  489. package/dist-es/breadcrumbs/internal/BreadcrumbsCollapsed.js +4 -4
  490. package/dist-es/breadcrumbs/internal/BreadcrumbsCollapsed.js.map +1 -1
  491. package/dist-es/breadcrumbs/internal/BreadcrumbsContext.js.map +1 -1
  492. package/dist-es/breadcrumbs/internal/BreadcrumbsSeparator.js.map +1 -1
  493. package/dist-es/breadcrumbs/internal/useFocusMenuRemount.js +1 -1
  494. package/dist-es/breadcrumbs/internal/useFocusMenuRemount.js.map +1 -1
  495. package/dist-es/button-bar/ButtonBar.js +10 -12
  496. package/dist-es/button-bar/ButtonBar.js.map +1 -1
  497. package/dist-es/button-bar/OrderedButton.js +2 -2
  498. package/dist-es/button-bar/OrderedButton.js.map +1 -1
  499. package/dist-es/button-bar/internal/ButtonBarContext.js.map +1 -1
  500. package/dist-es/button-bar/internal/DescendantContext.js +1 -1
  501. package/dist-es/button-bar/internal/DescendantContext.js.map +1 -1
  502. package/dist-es/button-bar/internal/useDescendant.js +1 -1
  503. package/dist-es/button-bar/internal/useDescendant.js.map +1 -1
  504. package/dist-es/button-bar/internal/useDescendants.js.map +1 -1
  505. package/dist-es/calendar/Calendar.js +6 -6
  506. package/dist-es/calendar/Calendar.js.map +1 -1
  507. package/dist-es/calendar/internal/CalendarCarousel.js +4 -4
  508. package/dist-es/calendar/internal/CalendarCarousel.js.map +1 -1
  509. package/dist-es/calendar/internal/CalendarContext.js.map +1 -1
  510. package/dist-es/calendar/internal/CalendarDay.css.js +1 -1
  511. package/dist-es/calendar/internal/CalendarDay.js +4 -4
  512. package/dist-es/calendar/internal/CalendarDay.js.map +1 -1
  513. package/dist-es/calendar/internal/CalendarMonth.js +5 -5
  514. package/dist-es/calendar/internal/CalendarMonth.js.map +1 -1
  515. package/dist-es/calendar/internal/CalendarNavigation.js +4 -4
  516. package/dist-es/calendar/internal/CalendarNavigation.js.map +1 -1
  517. package/dist-es/calendar/internal/CalendarWeekHeader.js +5 -5
  518. package/dist-es/calendar/internal/CalendarWeekHeader.js.map +1 -1
  519. package/dist-es/calendar/internal/useFocusManagement.js +1 -1
  520. package/dist-es/calendar/internal/useFocusManagement.js.map +1 -1
  521. package/dist-es/calendar/internal/utils.js.map +1 -1
  522. package/dist-es/calendar/useCalendar.js.map +1 -1
  523. package/dist-es/calendar/useCalendarDay.js.map +1 -1
  524. package/dist-es/calendar/useSelection.js +16 -12
  525. package/dist-es/calendar/useSelection.js.map +1 -1
  526. package/dist-es/carousel/Carousel.js +7 -6
  527. package/dist-es/carousel/Carousel.js.map +1 -1
  528. package/dist-es/carousel/CarouselSlide.js +1 -1
  529. package/dist-es/carousel/CarouselSlide.js.map +1 -1
  530. package/dist-es/cascading-menu/CascadingMenu.js +3 -4
  531. package/dist-es/cascading-menu/CascadingMenu.js.map +1 -1
  532. package/dist-es/cascading-menu/CascadingMenuItem.js +6 -7
  533. package/dist-es/cascading-menu/CascadingMenuItem.js.map +1 -1
  534. package/dist-es/cascading-menu/CascadingMenuList.js +8 -8
  535. package/dist-es/cascading-menu/CascadingMenuList.js.map +1 -1
  536. package/dist-es/cascading-menu/internal/CascadingMenuAction.js.map +1 -1
  537. package/dist-es/cascading-menu/internal/keydownHandlers.js +2 -2
  538. package/dist-es/cascading-menu/internal/keydownHandlers.js.map +1 -1
  539. package/dist-es/cascading-menu/internal/menuPositioning.js.map +1 -1
  540. package/dist-es/cascading-menu/internal/stateUtils.js +1 -2
  541. package/dist-es/cascading-menu/internal/stateUtils.js.map +1 -1
  542. package/dist-es/cascading-menu/internal/useClickAway.js +3 -2
  543. package/dist-es/cascading-menu/internal/useClickAway.js.map +1 -1
  544. package/dist-es/cascading-menu/internal/useMenuTriggerHandlers.js.map +1 -1
  545. package/dist-es/cascading-menu/internal/useMouseHandlers.js +1 -1
  546. package/dist-es/cascading-menu/internal/useMouseHandlers.js.map +1 -1
  547. package/dist-es/cascading-menu/internal/useRefsManager.js.map +1 -1
  548. package/dist-es/cascading-menu/internal/useStateReducer.js +1 -1
  549. package/dist-es/cascading-menu/internal/useStateReducer.js.map +1 -1
  550. package/dist-es/color-chooser/AlphaInputField.js +10 -10
  551. package/dist-es/color-chooser/AlphaInputField.js.map +1 -1
  552. package/dist-es/color-chooser/Color.js +1 -2
  553. package/dist-es/color-chooser/Color.js.map +1 -1
  554. package/dist-es/color-chooser/ColorChooser.css.js +1 -1
  555. package/dist-es/color-chooser/ColorChooser.js +4 -4
  556. package/dist-es/color-chooser/ColorChooser.js.map +1 -1
  557. package/dist-es/color-chooser/ColorHelpers.js +1 -1
  558. package/dist-es/color-chooser/ColorHelpers.js.map +1 -1
  559. package/dist-es/color-chooser/ColorPicker.js +3 -3
  560. package/dist-es/color-chooser/ColorPicker.js.map +1 -1
  561. package/dist-es/color-chooser/DictTabs.js +1 -1
  562. package/dist-es/color-chooser/DictTabs.js.map +1 -1
  563. package/dist-es/color-chooser/GetColorPalettes.js.map +1 -1
  564. package/dist-es/color-chooser/HexInput.js +5 -5
  565. package/dist-es/color-chooser/HexInput.js.map +1 -1
  566. package/dist-es/color-chooser/RGBAInput.js +3 -3
  567. package/dist-es/color-chooser/RGBAInput.js.map +1 -1
  568. package/dist-es/color-chooser/RGBAInputField.js +4 -4
  569. package/dist-es/color-chooser/RGBAInputField.js.map +1 -1
  570. package/dist-es/color-chooser/Swatch.css.js +1 -1
  571. package/dist-es/color-chooser/Swatch.js +1 -1
  572. package/dist-es/color-chooser/Swatch.js.map +1 -1
  573. package/dist-es/color-chooser/Swatches.js +2 -2
  574. package/dist-es/color-chooser/Swatches.js.map +1 -1
  575. package/dist-es/color-chooser/SwatchesPicker.js +2 -2
  576. package/dist-es/color-chooser/SwatchesPicker.js.map +1 -1
  577. package/dist-es/color-chooser/createTabsMapping.js.map +1 -1
  578. package/dist-es/combo-box/ComboBox.js +10 -10
  579. package/dist-es/combo-box/ComboBox.js.map +1 -1
  580. package/dist-es/combo-box/useCombobox.js +13 -20
  581. package/dist-es/combo-box/useCombobox.js.map +1 -1
  582. package/dist-es/combo-box-deprecated/ComboBoxDeprecated.js +5 -5
  583. package/dist-es/combo-box-deprecated/ComboBoxDeprecated.js.map +1 -1
  584. package/dist-es/combo-box-deprecated/internal/DefaultComboBox.js +7 -7
  585. package/dist-es/combo-box-deprecated/internal/DefaultComboBox.js.map +1 -1
  586. package/dist-es/combo-box-deprecated/internal/MultiSelectComboBox.js +3 -3
  587. package/dist-es/combo-box-deprecated/internal/MultiSelectComboBox.js.map +1 -1
  588. package/dist-es/combo-box-deprecated/internal/getAnnouncement.js +2 -2
  589. package/dist-es/combo-box-deprecated/internal/getAnnouncement.js.map +1 -1
  590. package/dist-es/combo-box-deprecated/internal/useComboBox.js +12 -10
  591. package/dist-es/combo-box-deprecated/internal/useComboBox.js.map +1 -1
  592. package/dist-es/combo-box-deprecated/internal/useMultiSelectComboBox.js +11 -15
  593. package/dist-es/combo-box-deprecated/internal/useMultiSelectComboBox.js.map +1 -1
  594. package/dist-es/combo-box-deprecated/internal/usePopperStatus.js.map +1 -1
  595. package/dist-es/common-hooks/calcPreferredHeight.js +1 -1
  596. package/dist-es/common-hooks/calcPreferredHeight.js.map +1 -1
  597. package/dist-es/common-hooks/collectionProvider.js.map +1 -1
  598. package/dist-es/common-hooks/itemToString.js +2 -1
  599. package/dist-es/common-hooks/itemToString.js.map +1 -1
  600. package/dist-es/common-hooks/keyUtils.js +2 -2
  601. package/dist-es/common-hooks/keyUtils.js.map +1 -1
  602. package/dist-es/common-hooks/list-dom-utils.js +4 -3
  603. package/dist-es/common-hooks/list-dom-utils.js.map +1 -1
  604. package/dist-es/common-hooks/selectionTypes.js.map +1 -1
  605. package/dist-es/common-hooks/useAutoSizer.js +2 -2
  606. package/dist-es/common-hooks/useAutoSizer.js.map +1 -1
  607. package/dist-es/common-hooks/useCollapsibleGroups.js.map +1 -1
  608. package/dist-es/common-hooks/useCollectionItems.js +13 -9
  609. package/dist-es/common-hooks/useCollectionItems.js.map +1 -1
  610. package/dist-es/common-hooks/useImperativeScrollingAPI.js +11 -7
  611. package/dist-es/common-hooks/useImperativeScrollingAPI.js.map +1 -1
  612. package/dist-es/common-hooks/useKeyboardNavigation.js +78 -82
  613. package/dist-es/common-hooks/useKeyboardNavigation.js.map +1 -1
  614. package/dist-es/common-hooks/useKeyboardNavigationPanel.js +14 -13
  615. package/dist-es/common-hooks/useKeyboardNavigationPanel.js.map +1 -1
  616. package/dist-es/common-hooks/useSelection.js +0 -1
  617. package/dist-es/common-hooks/useSelection.js.map +1 -1
  618. package/dist-es/common-hooks/useTypeahead.js.map +1 -1
  619. package/dist-es/common-hooks/useViewportTracking.js +24 -23
  620. package/dist-es/common-hooks/useViewportTracking.js.map +1 -1
  621. package/dist-es/common-hooks/utils/collection-item-utils.js +29 -29
  622. package/dist-es/common-hooks/utils/collection-item-utils.js.map +1 -1
  623. package/dist-es/common-hooks/utils/isSelected.js.map +1 -1
  624. package/dist-es/contact-details/ContactAction.js +1 -1
  625. package/dist-es/contact-details/ContactAction.js.map +1 -1
  626. package/dist-es/contact-details/ContactActions.js +2 -2
  627. package/dist-es/contact-details/ContactActions.js.map +1 -1
  628. package/dist-es/contact-details/ContactAvatar.js +3 -3
  629. package/dist-es/contact-details/ContactAvatar.js.map +1 -1
  630. package/dist-es/contact-details/ContactDetails.js +1 -1
  631. package/dist-es/contact-details/ContactDetails.js.map +1 -1
  632. package/dist-es/contact-details/ContactFavoriteToggle.js.map +1 -1
  633. package/dist-es/contact-details/ContactMetadata.js.map +1 -1
  634. package/dist-es/contact-details/ContactMetadataItem.js.map +1 -1
  635. package/dist-es/contact-details/ContactPrimaryInfo.js.map +1 -1
  636. package/dist-es/contact-details/ContactSecondaryInfo.js.map +1 -1
  637. package/dist-es/contact-details/ContactTertiaryInfo.js.map +1 -1
  638. package/dist-es/contact-details/MailLinkComponent.js.map +1 -1
  639. package/dist-es/contact-details/internal/ContactDetailsContext.js +1 -1
  640. package/dist-es/contact-details/internal/ContactDetailsContext.js.map +1 -1
  641. package/dist-es/contact-details/internal/FavoriteToggle.js.map +1 -1
  642. package/dist-es/contact-details/internal/FavoriteToggleWithTooltip.js +1 -1
  643. package/dist-es/contact-details/internal/FavoriteToggleWithTooltip.js.map +1 -1
  644. package/dist-es/contact-details/internal/StarIcon.js.map +1 -1
  645. package/dist-es/contact-details/internal/StarIconContainer.js +2 -2
  646. package/dist-es/contact-details/internal/StarIconContainer.js.map +1 -1
  647. package/dist-es/contact-details/internal/useComponentSize.js +7 -10
  648. package/dist-es/contact-details/internal/useComponentSize.js.map +1 -1
  649. package/dist-es/content-status/ContentStatus.js +1 -1
  650. package/dist-es/content-status/ContentStatus.js.map +1 -1
  651. package/dist-es/content-status/internal/StatusIndicator.js.map +1 -1
  652. package/dist-es/date-input/DateInput.js +7 -7
  653. package/dist-es/date-input/DateInput.js.map +1 -1
  654. package/dist-es/date-picker/DatePicker.js +6 -6
  655. package/dist-es/date-picker/DatePicker.js.map +1 -1
  656. package/dist-es/date-picker/DatePickerContext.js.map +1 -1
  657. package/dist-es/date-picker/DatePickerPanel.css.js +1 -1
  658. package/dist-es/date-picker/DatePickerPanel.js +18 -16
  659. package/dist-es/date-picker/DatePickerPanel.js.map +1 -1
  660. package/dist-es/deck-item/DeckItem.js +2 -2
  661. package/dist-es/deck-item/DeckItem.js.map +1 -1
  662. package/dist-es/deck-layout/DeckLayout.js +6 -9
  663. package/dist-es/deck-layout/DeckLayout.js.map +1 -1
  664. package/dist-es/dropdown/Dropdown.js +12 -12
  665. package/dist-es/dropdown/Dropdown.js.map +1 -1
  666. package/dist-es/dropdown/DropdownBase.js +3 -3
  667. package/dist-es/dropdown/DropdownBase.js.map +1 -1
  668. package/dist-es/dropdown/DropdownButton.js +3 -3
  669. package/dist-es/dropdown/DropdownButton.js.map +1 -1
  670. package/dist-es/dropdown/useClickAway.js +1 -1
  671. package/dist-es/dropdown/useClickAway.js.map +1 -1
  672. package/dist-es/dropdown/useDropdown.js +13 -14
  673. package/dist-es/dropdown/useDropdown.js.map +1 -1
  674. package/dist-es/dropdown/useDropdownBase.js +10 -12
  675. package/dist-es/dropdown/useDropdownBase.js.map +1 -1
  676. package/dist-es/editable-label/EditableLabel.js +7 -7
  677. package/dist-es/editable-label/EditableLabel.js.map +1 -1
  678. package/dist-es/form-field-context-legacy/FormFieldLegacyContext.js.map +1 -1
  679. package/dist-es/form-field-context-legacy/useFormFieldLegacyProps.js +1 -1
  680. package/dist-es/form-field-context-legacy/useFormFieldLegacyProps.js.map +1 -1
  681. package/dist-es/form-field-legacy/FormActivationIndicator.css.js +1 -1
  682. package/dist-es/form-field-legacy/FormActivationIndicator.js +4 -4
  683. package/dist-es/form-field-legacy/FormActivationIndicator.js.map +1 -1
  684. package/dist-es/form-field-legacy/FormFieldLegacy.css.js +1 -1
  685. package/dist-es/form-field-legacy/FormFieldLegacy.js +6 -6
  686. package/dist-es/form-field-legacy/FormFieldLegacy.js.map +1 -1
  687. package/dist-es/form-field-legacy/FormHelperText.js +4 -5
  688. package/dist-es/form-field-legacy/FormHelperText.js.map +1 -1
  689. package/dist-es/form-field-legacy/FormLabel.js +4 -4
  690. package/dist-es/form-field-legacy/FormLabel.js.map +1 -1
  691. package/dist-es/form-field-legacy/NecessityIndicator.js +2 -2
  692. package/dist-es/form-field-legacy/NecessityIndicator.js.map +1 -1
  693. package/dist-es/form-field-legacy/StatusIndicator.js +6 -6
  694. package/dist-es/form-field-legacy/StatusIndicator.js.map +1 -1
  695. package/dist-es/form-group/FormGroup.js +2 -2
  696. package/dist-es/form-group/FormGroup.js.map +1 -1
  697. package/dist-es/formatted-input/FormattedInput.js +2 -2
  698. package/dist-es/formatted-input/FormattedInput.js.map +1 -1
  699. package/dist-es/formatted-input/internal/InputWithMask.js.map +1 -1
  700. package/dist-es/input-legacy/InputLegacy.js +5 -5
  701. package/dist-es/input-legacy/InputLegacy.js.map +1 -1
  702. package/dist-es/input-legacy/StaticInputAdornment.js +3 -3
  703. package/dist-es/input-legacy/StaticInputAdornment.js.map +1 -1
  704. package/dist-es/input-legacy/useCursorOnFocus.js +2 -2
  705. package/dist-es/input-legacy/useCursorOnFocus.js.map +1 -1
  706. package/dist-es/layer-layout/LayerLayout.js +4 -4
  707. package/dist-es/layer-layout/LayerLayout.js.map +1 -1
  708. package/dist-es/list/Highlighter.js +1 -1
  709. package/dist-es/list/Highlighter.js.map +1 -1
  710. package/dist-es/list/List.css.js +1 -1
  711. package/dist-es/list/List.js +4 -6
  712. package/dist-es/list/List.js.map +1 -1
  713. package/dist-es/list/ListItem.js +3 -3
  714. package/dist-es/list/ListItem.js.map +1 -1
  715. package/dist-es/list/ListItemGroup.js.map +1 -1
  716. package/dist-es/list/ListItemHeader.js.map +1 -1
  717. package/dist-es/list/VirtualizedList.js +3 -5
  718. package/dist-es/list/VirtualizedList.js.map +1 -1
  719. package/dist-es/list/keyset.js +1 -2
  720. package/dist-es/list/keyset.js.map +1 -1
  721. package/dist-es/list/useList.js.map +1 -1
  722. package/dist-es/list/useListHeight.js +1 -1
  723. package/dist-es/list/useListHeight.js.map +1 -1
  724. package/dist-es/list/useVirtualization.js +2 -2
  725. package/dist-es/list/useVirtualization.js.map +1 -1
  726. package/dist-es/list-deprecated/List.js.map +1 -1
  727. package/dist-es/list-deprecated/ListBase.js +52 -53
  728. package/dist-es/list-deprecated/ListBase.js.map +1 -1
  729. package/dist-es/list-deprecated/ListItem.js +2 -2
  730. package/dist-es/list-deprecated/ListItem.js.map +1 -1
  731. package/dist-es/list-deprecated/ListItemBase.js +1 -1
  732. package/dist-es/list-deprecated/ListItemBase.js.map +1 -1
  733. package/dist-es/list-deprecated/ListItemContext.js +1 -1
  734. package/dist-es/list-deprecated/ListItemContext.js.map +1 -1
  735. package/dist-es/list-deprecated/ListStateContext.js.map +1 -1
  736. package/dist-es/list-deprecated/internal/DescendantContext.js +1 -1
  737. package/dist-es/list-deprecated/internal/DescendantContext.js.map +1 -1
  738. package/dist-es/list-deprecated/internal/Highlighter.js +2 -2
  739. package/dist-es/list-deprecated/internal/Highlighter.js.map +1 -1
  740. package/dist-es/list-deprecated/internal/calcPreferredListHeight.js +1 -1
  741. package/dist-es/list-deprecated/internal/calcPreferredListHeight.js.map +1 -1
  742. package/dist-es/list-deprecated/internal/helpers.js.map +1 -1
  743. package/dist-es/list-deprecated/internal/useListAutoSizer.js +1 -1
  744. package/dist-es/list-deprecated/internal/useListAutoSizer.js.map +1 -1
  745. package/dist-es/list-deprecated/internal/useWidth.js.map +1 -1
  746. package/dist-es/list-deprecated/itemToString.js.map +1 -1
  747. package/dist-es/list-deprecated/useList.js +4 -22
  748. package/dist-es/list-deprecated/useList.js.map +1 -1
  749. package/dist-es/list-deprecated/useListItem.js +2 -2
  750. package/dist-es/list-deprecated/useListItem.js.map +1 -1
  751. package/dist-es/list-deprecated/useTypeSelect.js +1 -1
  752. package/dist-es/list-deprecated/useTypeSelect.js.map +1 -1
  753. package/dist-es/list-next/ListItemNext.js +3 -3
  754. package/dist-es/list-next/ListItemNext.js.map +1 -1
  755. package/dist-es/list-next/ListNext.js +4 -4
  756. package/dist-es/list-next/ListNext.js.map +1 -1
  757. package/dist-es/list-next/ListNextContext.js.map +1 -1
  758. package/dist-es/list-next/useList.js +6 -9
  759. package/dist-es/list-next/useList.js.map +1 -1
  760. package/dist-es/logo/Logo.js +19 -17
  761. package/dist-es/logo/Logo.js.map +1 -1
  762. package/dist-es/logo/LogoImage.js +3 -3
  763. package/dist-es/logo/LogoImage.js.map +1 -1
  764. package/dist-es/logo/LogoSeparator.js +3 -3
  765. package/dist-es/logo/LogoSeparator.js.map +1 -1
  766. package/dist-es/menu-button/MenuButton.js +6 -6
  767. package/dist-es/menu-button/MenuButton.js.map +1 -1
  768. package/dist-es/menu-button/MenuButtonTrigger.js +3 -3
  769. package/dist-es/menu-button/MenuButtonTrigger.js.map +1 -1
  770. package/dist-es/metric/Metric.js +1 -1
  771. package/dist-es/metric/Metric.js.map +1 -1
  772. package/dist-es/metric/MetricContent.js +1 -1
  773. package/dist-es/metric/MetricContent.js.map +1 -1
  774. package/dist-es/metric/MetricHeader.js +1 -1
  775. package/dist-es/metric/MetricHeader.js.map +1 -1
  776. package/dist-es/portal/Portal.js +2 -5
  777. package/dist-es/portal/Portal.js.map +1 -1
  778. package/dist-es/query-input/QueryInput.js +1 -1
  779. package/dist-es/query-input/QueryInput.js.map +1 -1
  780. package/dist-es/query-input/internal/CategoryList.js +5 -5
  781. package/dist-es/query-input/internal/CategoryList.js.map +1 -1
  782. package/dist-es/query-input/internal/CategoryListContext.js +1 -1
  783. package/dist-es/query-input/internal/CategoryListContext.js.map +1 -1
  784. package/dist-es/query-input/internal/CategoryListItem.js.map +1 -1
  785. package/dist-es/query-input/internal/QueryInputBody.js.map +1 -1
  786. package/dist-es/query-input/internal/SearchList.js +2 -2
  787. package/dist-es/query-input/internal/SearchList.js.map +1 -1
  788. package/dist-es/query-input/internal/ValueList.js.map +1 -1
  789. package/dist-es/query-input/internal/ValueSelector.js +3 -3
  790. package/dist-es/query-input/internal/ValueSelector.js.map +1 -1
  791. package/dist-es/query-input/internal/usePopperStatus.js.map +1 -1
  792. package/dist-es/query-input/useQueryInput.js +36 -22
  793. package/dist-es/query-input/useQueryInput.js.map +1 -1
  794. package/dist-es/responsive/OverflowReducer.js +16 -19
  795. package/dist-es/responsive/OverflowReducer.js.map +1 -1
  796. package/dist-es/responsive/overflowUtils.js +22 -26
  797. package/dist-es/responsive/overflowUtils.js.map +1 -1
  798. package/dist-es/responsive/useDynamicCollapse.js +5 -5
  799. package/dist-es/responsive/useDynamicCollapse.js.map +1 -1
  800. package/dist-es/responsive/useInstantCollapse.js +3 -4
  801. package/dist-es/responsive/useInstantCollapse.js.map +1 -1
  802. package/dist-es/responsive/useOverflow.js +11 -6
  803. package/dist-es/responsive/useOverflow.js.map +1 -1
  804. package/dist-es/responsive/useOverflowCollectionItems.js +3 -3
  805. package/dist-es/responsive/useOverflowCollectionItems.js.map +1 -1
  806. package/dist-es/responsive/useOverflowLayout.js +3 -3
  807. package/dist-es/responsive/useOverflowLayout.js.map +1 -1
  808. package/dist-es/responsive/useReclaimSpace.js +11 -21
  809. package/dist-es/responsive/useReclaimSpace.js.map +1 -1
  810. package/dist-es/responsive/useResizeObserver.js +1 -1
  811. package/dist-es/responsive/useResizeObserver.js.map +1 -1
  812. package/dist-es/responsive/useWidth.js +2 -2
  813. package/dist-es/responsive/useWidth.js.map +1 -1
  814. package/dist-es/responsive/utils.js +1 -2
  815. package/dist-es/responsive/utils.js.map +1 -1
  816. package/dist-es/search-input/SearchInput.js +4 -4
  817. package/dist-es/search-input/SearchInput.js.map +1 -1
  818. package/dist-es/skip-link/SkipLink.js +3 -3
  819. package/dist-es/skip-link/SkipLink.js.map +1 -1
  820. package/dist-es/skip-link/SkipLinks.js +3 -3
  821. package/dist-es/skip-link/SkipLinks.js.map +1 -1
  822. package/dist-es/skip-link/internal/useManageFocusOnTarget.js.map +1 -1
  823. package/dist-es/slider/Slider.js +1 -1
  824. package/dist-es/slider/Slider.js.map +1 -1
  825. package/dist-es/slider/internal/SliderHandle.js +1 -1
  826. package/dist-es/slider/internal/SliderHandle.js.map +1 -1
  827. package/dist-es/slider/internal/SliderMarkLabels.js +3 -3
  828. package/dist-es/slider/internal/SliderMarkLabels.js.map +1 -1
  829. package/dist-es/slider/internal/SliderRail.js +2 -2
  830. package/dist-es/slider/internal/SliderRail.js.map +1 -1
  831. package/dist-es/slider/internal/SliderRailMarks.js +4 -4
  832. package/dist-es/slider/internal/SliderRailMarks.js.map +1 -1
  833. package/dist-es/slider/internal/SliderSelection.js +1 -1
  834. package/dist-es/slider/internal/SliderSelection.js.map +1 -1
  835. package/dist-es/slider/internal/styles.js +2 -2
  836. package/dist-es/slider/internal/styles.js.map +1 -1
  837. package/dist-es/slider/internal/useSliderKeyDown.js.map +1 -1
  838. package/dist-es/slider/internal/useSliderMouseDown.js +21 -18
  839. package/dist-es/slider/internal/useSliderMouseDown.js.map +1 -1
  840. package/dist-es/slider/internal/utils.js +1 -1
  841. package/dist-es/slider/internal/utils.js.map +1 -1
  842. package/dist-es/stepped-tracker/StepLabel/StepLabel.js +2 -2
  843. package/dist-es/stepped-tracker/StepLabel/StepLabel.js.map +1 -1
  844. package/dist-es/stepped-tracker/SteppedTracker.js +3 -3
  845. package/dist-es/stepped-tracker/SteppedTracker.js.map +1 -1
  846. package/dist-es/stepped-tracker/SteppedTrackerContext.js.map +1 -1
  847. package/dist-es/stepped-tracker/TrackerStep/TrackerStep.js +4 -4
  848. package/dist-es/stepped-tracker/TrackerStep/TrackerStep.js.map +1 -1
  849. package/dist-es/stepper-input/StepperInput.js +3 -3
  850. package/dist-es/stepper-input/StepperInput.js.map +1 -1
  851. package/dist-es/stepper-input/internal/useInterval.js.map +1 -1
  852. package/dist-es/stepper-input/internal/useSpinner.js +1 -1
  853. package/dist-es/stepper-input/internal/useSpinner.js.map +1 -1
  854. package/dist-es/stepper-input/useStepperInput.js +3 -3
  855. package/dist-es/stepper-input/useStepperInput.js.map +1 -1
  856. package/dist-es/tabs/Tab.js +5 -6
  857. package/dist-es/tabs/Tab.js.map +1 -1
  858. package/dist-es/tabs/TabActivationIndicator.js +1 -1
  859. package/dist-es/tabs/TabActivationIndicator.js.map +1 -1
  860. package/dist-es/tabs/TabPanel.js +3 -3
  861. package/dist-es/tabs/TabPanel.js.map +1 -1
  862. package/dist-es/tabs/Tabs.js +4 -4
  863. package/dist-es/tabs/Tabs.js.map +1 -1
  864. package/dist-es/tabs/Tabstrip.js +11 -14
  865. package/dist-es/tabs/Tabstrip.js.map +1 -1
  866. package/dist-es/tabs/drag-drop/Draggable.js +1 -1
  867. package/dist-es/tabs/drag-drop/Draggable.js.map +1 -1
  868. package/dist-es/tabs/drag-drop/drag-utils.js +29 -26
  869. package/dist-es/tabs/drag-drop/drag-utils.js.map +1 -1
  870. package/dist-es/tabs/drag-drop/dragDropTypes.js.map +1 -1
  871. package/dist-es/tabs/drag-drop/useDragDrop.js.map +1 -1
  872. package/dist-es/tabs/drag-drop/useDragDropNaturalMovement.js +5 -4
  873. package/dist-es/tabs/drag-drop/useDragDropNaturalMovement.js.map +1 -1
  874. package/dist-es/tabs/drag-drop/useDragSpacers.js +19 -16
  875. package/dist-es/tabs/drag-drop/useDragSpacers.js.map +1 -1
  876. package/dist-es/tabs/useActivationIndicator.js +3 -2
  877. package/dist-es/tabs/useActivationIndicator.js.map +1 -1
  878. package/dist-es/tabs/useEditableItem.js +1 -1
  879. package/dist-es/tabs/useEditableItem.js.map +1 -1
  880. package/dist-es/tabs/useItemsWithIds.js +5 -9
  881. package/dist-es/tabs/useItemsWithIds.js.map +1 -1
  882. package/dist-es/tabs/useKeyboardNavigation.js +26 -32
  883. package/dist-es/tabs/useKeyboardNavigation.js.map +1 -1
  884. package/dist-es/tabs/useSelection.js +2 -2
  885. package/dist-es/tabs/useSelection.js.map +1 -1
  886. package/dist-es/tabs/useTabs.js +1 -1
  887. package/dist-es/tabs/useTabs.js.map +1 -1
  888. package/dist-es/tabs/useTabstrip.js +6 -5
  889. package/dist-es/tabs/useTabstrip.js.map +1 -1
  890. package/dist-es/tabs-next/OverflowMenu.js +2 -2
  891. package/dist-es/tabs-next/OverflowMenu.js.map +1 -1
  892. package/dist-es/tabs-next/TabNext.js +74 -72
  893. package/dist-es/tabs-next/TabNext.js.map +1 -1
  894. package/dist-es/tabs-next/TabNextContext.js.map +1 -1
  895. package/dist-es/tabs-next/TabstripNext.js +5 -5
  896. package/dist-es/tabs-next/TabstripNext.js.map +1 -1
  897. package/dist-es/toast-group/ToastGroup.js +3 -3
  898. package/dist-es/toast-group/ToastGroup.js.map +1 -1
  899. package/dist-es/tokenized-input/TokenizedInput.js.map +1 -1
  900. package/dist-es/tokenized-input/TokenizedInputBase.js +12 -12
  901. package/dist-es/tokenized-input/TokenizedInputBase.js.map +1 -1
  902. package/dist-es/tokenized-input/internal/InputPill.js +2 -2
  903. package/dist-es/tokenized-input/internal/InputPill.js.map +1 -1
  904. package/dist-es/tokenized-input/internal/InputRuler.js +3 -3
  905. package/dist-es/tokenized-input/internal/InputRuler.js.map +1 -1
  906. package/dist-es/tokenized-input/internal/defaultItemToString.js.map +1 -1
  907. package/dist-es/tokenized-input/internal/getCursorPosition.js.map +1 -1
  908. package/dist-es/tokenized-input/internal/isPlainObject.js.map +1 -1
  909. package/dist-es/tokenized-input/internal/useResizeObserver.js.map +1 -1
  910. package/dist-es/tokenized-input/internal/useWidth.js +3 -3
  911. package/dist-es/tokenized-input/internal/useWidth.js.map +1 -1
  912. package/dist-es/tokenized-input/useTokenizedInput.js +12 -9
  913. package/dist-es/tokenized-input/useTokenizedInput.js.map +1 -1
  914. package/dist-es/tokenized-input-next/TokenizedInputNext.js +5 -5
  915. package/dist-es/tokenized-input-next/TokenizedInputNext.js.map +1 -1
  916. package/dist-es/tokenized-input-next/internal/InputPill.js +5 -5
  917. package/dist-es/tokenized-input-next/internal/InputPill.js.map +1 -1
  918. package/dist-es/tokenized-input-next/internal/useResizeObserver.js.map +1 -1
  919. package/dist-es/tokenized-input-next/internal/useWidth.js +3 -3
  920. package/dist-es/tokenized-input-next/internal/useWidth.js.map +1 -1
  921. package/dist-es/tokenized-input-next/useTokenizedInputNext.js +12 -14
  922. package/dist-es/tokenized-input-next/useTokenizedInputNext.js.map +1 -1
  923. package/dist-es/toolbar/Toolbar.js +3 -3
  924. package/dist-es/toolbar/Toolbar.js.map +1 -1
  925. package/dist-es/toolbar/ToolbarButton.js +2 -2
  926. package/dist-es/toolbar/ToolbarButton.js.map +1 -1
  927. package/dist-es/toolbar/Tooltray.js +1 -1
  928. package/dist-es/toolbar/Tooltray.js.map +1 -1
  929. package/dist-es/toolbar/internal/renderToolbarItems.js +22 -21
  930. package/dist-es/toolbar/internal/renderToolbarItems.js.map +1 -1
  931. package/dist-es/toolbar/internal/renderTrayTools.js +21 -23
  932. package/dist-es/toolbar/internal/renderTrayTools.js.map +1 -1
  933. package/dist-es/toolbar/overflow-panel/OverflowPanel.js +19 -21
  934. package/dist-es/toolbar/overflow-panel/OverflowPanel.js.map +1 -1
  935. package/dist-es/toolbar/overflow-panel/OverflowSeparator.js +2 -2
  936. package/dist-es/toolbar/overflow-panel/OverflowSeparator.js.map +1 -1
  937. package/dist-es/toolbar/toolbar-field/ToolbarField.js.map +1 -1
  938. package/dist-es/toolbar/toolbar-field/useToolbarField.js +8 -8
  939. package/dist-es/toolbar/toolbar-field/useToolbarField.js.map +1 -1
  940. package/dist-es/tree/Tree.js +9 -6
  941. package/dist-es/tree/Tree.js.map +1 -1
  942. package/dist-es/tree/TreeNode.js +2 -2
  943. package/dist-es/tree/TreeNode.js.map +1 -1
  944. package/dist-es/tree/use-tree-keyboard-navigation.js +5 -4
  945. package/dist-es/tree/use-tree-keyboard-navigation.js.map +1 -1
  946. package/dist-es/tree/useTree.js +1 -3
  947. package/dist-es/tree/useTree.js.map +1 -1
  948. package/dist-es/utils/forwardCallbackProps.js.map +1 -1
  949. package/dist-es/utils/partition.js.map +1 -1
  950. package/dist-es/utils/useClickOutside.js.map +1 -1
  951. package/dist-es/utils/useEventCallback.js +1 -1
  952. package/dist-es/utils/useEventCallback.js.map +1 -1
  953. package/dist-es/utils/useIsViewportLargerThanBreakpoint.js.map +1 -1
  954. package/dist-es/utils/useLayoutEffectOnce.js +1 -1
  955. package/dist-es/utils/useLayoutEffectOnce.js.map +1 -1
  956. package/dist-es/utils/useLayoutEffectSkipFirst.js +1 -1
  957. package/dist-es/utils/useLayoutEffectSkipFirst.js.map +1 -1
  958. package/dist-es/utils/useOverflowDetection.js +3 -3
  959. package/dist-es/utils/useOverflowDetection.js.map +1 -1
  960. package/dist-es/utils/useSlideSelection.js.map +1 -1
  961. package/dist-es/window/ElectronWindow.js +5 -7
  962. package/dist-es/window/ElectronWindow.js.map +1 -1
  963. package/dist-es/window/WindowContext.js.map +1 -1
  964. package/dist-types/app-header/AppHeader.d.ts +1 -1
  965. package/dist-types/breadcrumbs/Breadcrumb.d.ts +3 -3
  966. package/dist-types/breadcrumbs/Breadcrumbs.d.ts +2 -2
  967. package/dist-types/breadcrumbs/internal/BreadcrumbsCollapsed.d.ts +4 -4
  968. package/dist-types/breadcrumbs/internal/BreadcrumbsSeparator.d.ts +2 -2
  969. package/dist-types/button-bar/ButtonBar.d.ts +2 -2
  970. package/dist-types/button-bar/OrderedButton.d.ts +1 -1
  971. package/dist-types/button-bar/internal/DescendantContext.d.ts +2 -2
  972. package/dist-types/button-bar/internal/useDescendants.d.ts +1 -1
  973. package/dist-types/calendar/Calendar.d.ts +3 -3
  974. package/dist-types/calendar/internal/CalendarCarousel.d.ts +1 -1
  975. package/dist-types/calendar/internal/CalendarContext.d.ts +1 -1
  976. package/dist-types/calendar/internal/CalendarDay.d.ts +4 -4
  977. package/dist-types/calendar/internal/CalendarMonth.d.ts +3 -3
  978. package/dist-types/calendar/internal/CalendarNavigation.d.ts +3 -3
  979. package/dist-types/calendar/internal/CalendarWeekHeader.d.ts +1 -1
  980. package/dist-types/calendar/internal/useFocusManagement.d.ts +2 -2
  981. package/dist-types/calendar/internal/utils.d.ts +1 -1
  982. package/dist-types/calendar/useCalendar.d.ts +7 -7
  983. package/dist-types/calendar/useCalendarDay.d.ts +4 -4
  984. package/dist-types/calendar/useSelection.d.ts +2 -2
  985. package/dist-types/carousel/Carousel.d.ts +2 -2
  986. package/dist-types/carousel/CarouselSlide.d.ts +1 -1
  987. package/dist-types/cascading-menu/CascadingMenu.d.ts +1 -1
  988. package/dist-types/cascading-menu/CascadingMenuItem.d.ts +3 -3
  989. package/dist-types/cascading-menu/CascadingMenuList.d.ts +6 -6
  990. package/dist-types/cascading-menu/CascadingMenuProps.d.ts +5 -5
  991. package/dist-types/cascading-menu/internal/CascadingMenuAction.d.ts +1 -1
  992. package/dist-types/cascading-menu/internal/keydownHandlers.d.ts +2 -2
  993. package/dist-types/cascading-menu/internal/stateUtils.d.ts +1 -1
  994. package/dist-types/cascading-menu/internal/useMenuTriggerHandlers.d.ts +4 -4
  995. package/dist-types/cascading-menu/internal/useMouseHandlers.d.ts +2 -2
  996. package/dist-types/cascading-menu/internal/useStateReducer.d.ts +3 -3
  997. package/dist-types/color-chooser/AlphaInputField.d.ts +2 -1
  998. package/dist-types/color-chooser/ColorChooser.d.ts +3 -3
  999. package/dist-types/color-chooser/ColorPicker.d.ts +1 -1
  1000. package/dist-types/color-chooser/DictTabs.d.ts +3 -3
  1001. package/dist-types/color-chooser/RGBAInput.d.ts +2 -2
  1002. package/dist-types/color-chooser/RGBAInputField.d.ts +1 -1
  1003. package/dist-types/color-chooser/Swatch.d.ts +1 -1
  1004. package/dist-types/color-chooser/Swatches.d.ts +1 -1
  1005. package/dist-types/color-chooser/SwatchesPicker.d.ts +1 -1
  1006. package/dist-types/color-chooser/createTabsMapping.d.ts +3 -3
  1007. package/dist-types/combo-box/ComboBox.d.ts +5 -5
  1008. package/dist-types/combo-box/useCombobox.d.ts +5 -5
  1009. package/dist-types/combo-box-deprecated/ComboBoxDeprecated.d.ts +3 -3
  1010. package/dist-types/combo-box-deprecated/internal/DefaultComboBox.d.ts +5 -5
  1011. package/dist-types/combo-box-deprecated/internal/MultiSelectComboBox.d.ts +3 -3
  1012. package/dist-types/combo-box-deprecated/internal/useComboBox.d.ts +65 -59
  1013. package/dist-types/combo-box-deprecated/internal/useMultiSelectComboBox.d.ts +189 -172
  1014. package/dist-types/combo-box-deprecated/internal/usePopperStatus.d.ts +1 -1
  1015. package/dist-types/common-hooks/collectionProvider.d.ts +3 -3
  1016. package/dist-types/common-hooks/collectionTypes.d.ts +2 -2
  1017. package/dist-types/common-hooks/keyUtils.d.ts +1 -1
  1018. package/dist-types/common-hooks/navigationTypes.d.ts +3 -3
  1019. package/dist-types/common-hooks/selectionTypes.d.ts +2 -2
  1020. package/dist-types/common-hooks/useAutoSizer.d.ts +1 -1
  1021. package/dist-types/common-hooks/useCollapsibleGroups.d.ts +2 -2
  1022. package/dist-types/common-hooks/useCollectionItems.d.ts +1 -1
  1023. package/dist-types/common-hooks/useImperativeScrollingAPI.d.ts +2 -2
  1024. package/dist-types/common-hooks/useKeyboardNavigation.d.ts +2 -2
  1025. package/dist-types/common-hooks/useKeyboardNavigationPanel.d.ts +1 -1
  1026. package/dist-types/common-hooks/useSelection.d.ts +1 -1
  1027. package/dist-types/common-hooks/useTypeahead.d.ts +1 -1
  1028. package/dist-types/common-hooks/useViewportTracking.d.ts +2 -2
  1029. package/dist-types/common-hooks/utils/collection-item-utils.d.ts +2 -2
  1030. package/dist-types/common-hooks/utils/isSelected.d.ts +1 -1
  1031. package/dist-types/contact-details/ContactAction.d.ts +3 -3
  1032. package/dist-types/contact-details/ContactActions.d.ts +1 -1
  1033. package/dist-types/contact-details/ContactAvatar.d.ts +1 -1
  1034. package/dist-types/contact-details/ContactDetails.d.ts +1 -1
  1035. package/dist-types/contact-details/ContactFavoriteToggle.d.ts +2 -2
  1036. package/dist-types/contact-details/ContactMetadata.d.ts +1 -1
  1037. package/dist-types/contact-details/ContactMetadataItem.d.ts +3 -3
  1038. package/dist-types/contact-details/ContactPrimaryInfo.d.ts +1 -1
  1039. package/dist-types/contact-details/ContactSecondaryInfo.d.ts +3 -3
  1040. package/dist-types/contact-details/ContactTertiaryInfo.d.ts +2 -2
  1041. package/dist-types/contact-details/MailLinkComponent.d.ts +2 -2
  1042. package/dist-types/contact-details/internal/ContactDetailsContext.d.ts +1 -1
  1043. package/dist-types/contact-details/internal/FavoriteToggle.d.ts +3 -2
  1044. package/dist-types/contact-details/internal/FavoriteToggleWithTooltip.d.ts +2 -2
  1045. package/dist-types/contact-details/internal/StarIconContainer.d.ts +1 -1
  1046. package/dist-types/contact-details/internal/useComponentSize.d.ts +1 -1
  1047. package/dist-types/contact-details/types.d.ts +1 -1
  1048. package/dist-types/content-status/ContentStatus.d.ts +2 -2
  1049. package/dist-types/content-status/internal/StatusIndicator.d.ts +3 -3
  1050. package/dist-types/date-input/DateInput.d.ts +3 -3
  1051. package/dist-types/date-picker/DatePicker.d.ts +4 -4
  1052. package/dist-types/date-picker/DatePickerContext.d.ts +3 -3
  1053. package/dist-types/date-picker/DatePickerPanel.d.ts +3 -3
  1054. package/dist-types/deck-item/DeckItem.d.ts +2 -2
  1055. package/dist-types/deck-layout/DeckLayout.d.ts +2 -2
  1056. package/dist-types/dropdown/Dropdown.d.ts +4 -4
  1057. package/dist-types/dropdown/DropdownBase.d.ts +1 -1
  1058. package/dist-types/dropdown/DropdownButton.d.ts +3 -3
  1059. package/dist-types/dropdown/dropdownTypes.d.ts +2 -2
  1060. package/dist-types/dropdown/useClickAway.d.ts +1 -1
  1061. package/dist-types/dropdown/useDropdown.d.ts +3 -3
  1062. package/dist-types/dropdown/useDropdownBase.d.ts +2 -2
  1063. package/dist-types/focus-manager/FocusManager.d.ts +2 -2
  1064. package/dist-types/form-field-context-legacy/FormFieldLegacyContext.d.ts +2 -2
  1065. package/dist-types/form-field-context-legacy/useFormFieldLegacyProps.d.ts +1 -1
  1066. package/dist-types/form-field-legacy/FormActivationIndicator.d.ts +2 -2
  1067. package/dist-types/form-field-legacy/FormFieldLegacy.d.ts +6 -6
  1068. package/dist-types/form-field-legacy/FormHelperText.d.ts +3 -3
  1069. package/dist-types/form-field-legacy/FormLabel.d.ts +5 -5
  1070. package/dist-types/form-field-legacy/NecessityIndicator.d.ts +2 -2
  1071. package/dist-types/form-field-legacy/StatusIndicator.d.ts +4 -4
  1072. package/dist-types/form-group/FormGroup.d.ts +1 -1
  1073. package/dist-types/formatted-input/FormattedInput.d.ts +1 -1
  1074. package/dist-types/formatted-input/internal/InputWithMask.d.ts +2 -2
  1075. package/dist-types/input-legacy/InputLegacy.d.ts +1 -1
  1076. package/dist-types/input-legacy/StaticInputAdornment.d.ts +1 -1
  1077. package/dist-types/input-legacy/useCursorOnFocus.d.ts +1 -1
  1078. package/dist-types/layer-layout/LayerLayout.d.ts +2 -2
  1079. package/dist-types/list/Highlighter.d.ts +1 -1
  1080. package/dist-types/list/List.d.ts +3 -3
  1081. package/dist-types/list/ListItem.d.ts +2 -2
  1082. package/dist-types/list/ListItemGroup.d.ts +1 -1
  1083. package/dist-types/list/ListItemHeader.d.ts +1 -1
  1084. package/dist-types/list/VirtualizedList.d.ts +3 -3
  1085. package/dist-types/list/listTypes.d.ts +3 -2
  1086. package/dist-types/list/useList.d.ts +2 -2
  1087. package/dist-types/list/useListHeight.d.ts +1 -1
  1088. package/dist-types/list/useVirtualization.d.ts +2 -2
  1089. package/dist-types/list-deprecated/List.d.ts +3 -3
  1090. package/dist-types/list-deprecated/ListBase.d.ts +2 -2
  1091. package/dist-types/list-deprecated/ListItem.d.ts +2 -2
  1092. package/dist-types/list-deprecated/ListItemBase.d.ts +1 -1
  1093. package/dist-types/list-deprecated/ListItemContext.d.ts +1 -1
  1094. package/dist-types/list-deprecated/ListProps.d.ts +1 -1
  1095. package/dist-types/list-deprecated/internal/DescendantContext.d.ts +1 -1
  1096. package/dist-types/list-deprecated/internal/Highlighter.d.ts +1 -1
  1097. package/dist-types/list-deprecated/internal/useListAutoSizer.d.ts +1 -1
  1098. package/dist-types/list-deprecated/internal/useWidth.d.ts +1 -1
  1099. package/dist-types/list-deprecated/useList.d.ts +2 -2
  1100. package/dist-types/list-deprecated/useListItem.d.ts +3 -3
  1101. package/dist-types/list-next/ListItemNext.d.ts +1 -1
  1102. package/dist-types/list-next/ListNext.d.ts +1 -1
  1103. package/dist-types/list-next/ListNextContext.d.ts +1 -1
  1104. package/dist-types/list-next/useList.d.ts +1 -1
  1105. package/dist-types/logo/Logo.d.ts +1 -1
  1106. package/dist-types/logo/LogoImage.d.ts +1 -1
  1107. package/dist-types/logo/LogoSeparator.d.ts +1 -1
  1108. package/dist-types/menu-button/MenuButton.d.ts +3 -3
  1109. package/dist-types/menu-button/MenuButtonTrigger.d.ts +2 -2
  1110. package/dist-types/metric/Metric.d.ts +2 -2
  1111. package/dist-types/metric/MetricContent.d.ts +2 -2
  1112. package/dist-types/metric/MetricHeader.d.ts +2 -2
  1113. package/dist-types/portal/Portal.d.ts +1 -1
  1114. package/dist-types/query-input/QueryInput.d.ts +3 -3
  1115. package/dist-types/query-input/internal/CategoryList.d.ts +3 -3
  1116. package/dist-types/query-input/internal/CategoryListItem.d.ts +2 -2
  1117. package/dist-types/query-input/internal/QueryInputBody.d.ts +4 -4
  1118. package/dist-types/query-input/internal/SearchList.d.ts +3 -3
  1119. package/dist-types/query-input/internal/ValueList.d.ts +3 -3
  1120. package/dist-types/query-input/internal/ValueSelector.d.ts +3 -3
  1121. package/dist-types/query-input/internal/usePopperStatus.d.ts +1 -1
  1122. package/dist-types/query-input/useQueryInput.d.ts +4 -4
  1123. package/dist-types/responsive/OverflowReducer.d.ts +2 -2
  1124. package/dist-types/responsive/overflowTypes.d.ts +2 -2
  1125. package/dist-types/responsive/overflowUtils.d.ts +2 -2
  1126. package/dist-types/responsive/useDynamicCollapse.d.ts +2 -2
  1127. package/dist-types/responsive/useInstantCollapse.d.ts +2 -2
  1128. package/dist-types/responsive/useOverflow.d.ts +1 -1
  1129. package/dist-types/responsive/useOverflowCollectionItems.d.ts +1 -1
  1130. package/dist-types/responsive/useOverflowLayout.d.ts +1 -1
  1131. package/dist-types/responsive/useReclaimSpace.d.ts +1 -1
  1132. package/dist-types/responsive/useResizeObserver.d.ts +1 -1
  1133. package/dist-types/responsive/useWidth.d.ts +1 -1
  1134. package/dist-types/search-input/SearchInput.d.ts +2 -2
  1135. package/dist-types/skip-link/SkipLink.d.ts +2 -2
  1136. package/dist-types/skip-link/SkipLinks.d.ts +1 -1
  1137. package/dist-types/skip-link/internal/useManageFocusOnTarget.d.ts +1 -1
  1138. package/dist-types/slider/Slider.d.ts +3 -3
  1139. package/dist-types/slider/internal/SliderHandle.d.ts +1 -1
  1140. package/dist-types/slider/internal/SliderMarkLabels.d.ts +2 -2
  1141. package/dist-types/slider/internal/SliderRail.d.ts +1 -3
  1142. package/dist-types/slider/internal/SliderRailMarks.d.ts +2 -2
  1143. package/dist-types/slider/internal/SliderSelection.d.ts +1 -1
  1144. package/dist-types/slider/internal/styles.d.ts +3 -3
  1145. package/dist-types/slider/internal/useSliderKeyDown.d.ts +2 -2
  1146. package/dist-types/slider/internal/useSliderMouseDown.d.ts +3 -3
  1147. package/dist-types/slider/internal/utils.d.ts +2 -2
  1148. package/dist-types/stepped-tracker/StepLabel/StepLabel.d.ts +2 -2
  1149. package/dist-types/stepped-tracker/SteppedTracker.d.ts +1 -1
  1150. package/dist-types/stepped-tracker/SteppedTrackerContext.d.ts +3 -3
  1151. package/dist-types/stepped-tracker/TrackerConnector/TrackerConnector.d.ts +1 -1
  1152. package/dist-types/stepped-tracker/TrackerStep/TrackerStep.d.ts +1 -1
  1153. package/dist-types/stepper-input/StepperInput.d.ts +2 -2
  1154. package/dist-types/stepper-input/internal/useInterval.d.ts +1 -1
  1155. package/dist-types/stepper-input/useStepperInput.d.ts +3 -3
  1156. package/dist-types/tabs/Tab.d.ts +1 -1
  1157. package/dist-types/tabs/TabActivationIndicator.d.ts +1 -1
  1158. package/dist-types/tabs/TabPanel.d.ts +1 -1
  1159. package/dist-types/tabs/Tabs.d.ts +1 -1
  1160. package/dist-types/tabs/TabsTypes.d.ts +4 -4
  1161. package/dist-types/tabs/Tabstrip.d.ts +1 -1
  1162. package/dist-types/tabs/drag-drop/Draggable.d.ts +2 -2
  1163. package/dist-types/tabs/drag-drop/DropIndicator.d.ts +1 -1
  1164. package/dist-types/tabs/drag-drop/drag-utils.d.ts +2 -2
  1165. package/dist-types/tabs/drag-drop/dragDropTypes.d.ts +2 -2
  1166. package/dist-types/tabs/drag-drop/useDragDrop.d.ts +1 -1
  1167. package/dist-types/tabs/drag-drop/useDragDropNaturalMovement.d.ts +1 -1
  1168. package/dist-types/tabs/drag-drop/useDragSpacers.d.ts +3 -3
  1169. package/dist-types/tabs/useActivationIndicator.d.ts +2 -2
  1170. package/dist-types/tabs/useEditableItem.d.ts +2 -2
  1171. package/dist-types/tabs/useItemsWithIds.d.ts +2 -2
  1172. package/dist-types/tabs/useKeyboardNavigation.d.ts +2 -2
  1173. package/dist-types/tabs/useSelection.d.ts +1 -1
  1174. package/dist-types/tabs/useTabs.d.ts +2 -2
  1175. package/dist-types/tabs/useTabstrip.d.ts +6 -6
  1176. package/dist-types/tabs-next/OverflowMenu.d.ts +2 -2
  1177. package/dist-types/tabs-next/TabNext.d.ts +1 -1
  1178. package/dist-types/tabs-next/TabNextContext.d.ts +1 -1
  1179. package/dist-types/tabs-next/TabstripNext.d.ts +1 -1
  1180. package/dist-types/toast-group/ToastGroup.d.ts +1 -1
  1181. package/dist-types/tokenized-input/TokenizedInput.d.ts +3 -3
  1182. package/dist-types/tokenized-input/TokenizedInputBase.d.ts +4 -4
  1183. package/dist-types/tokenized-input/internal/InputPill.d.ts +2 -2
  1184. package/dist-types/tokenized-input/internal/InputRuler.d.ts +1 -1
  1185. package/dist-types/tokenized-input/internal/getCursorPosition.d.ts +1 -1
  1186. package/dist-types/tokenized-input/internal/useResizeObserver.d.ts +1 -1
  1187. package/dist-types/tokenized-input/internal/useWidth.d.ts +1 -1
  1188. package/dist-types/tokenized-input/useTokenizedInput.d.ts +3 -3
  1189. package/dist-types/tokenized-input-next/TokenizedInputNext.d.ts +3 -3
  1190. package/dist-types/tokenized-input-next/internal/InputPill.d.ts +2 -2
  1191. package/dist-types/tokenized-input-next/internal/useResizeObserver.d.ts +1 -1
  1192. package/dist-types/tokenized-input-next/internal/useWidth.d.ts +1 -1
  1193. package/dist-types/tokenized-input-next/useTokenizedInputNext.d.ts +2 -2
  1194. package/dist-types/toolbar/Toolbar.d.ts +1 -1
  1195. package/dist-types/toolbar/ToolbarButton.d.ts +1 -1
  1196. package/dist-types/toolbar/ToolbarProps.d.ts +2 -2
  1197. package/dist-types/toolbar/Tooltray.d.ts +2 -2
  1198. package/dist-types/toolbar/TooltrayProps.d.ts +2 -2
  1199. package/dist-types/toolbar/internal/ToolbarButtonRefsContext.d.ts +1 -1
  1200. package/dist-types/toolbar/internal/renderToolbarItems.d.ts +2 -2
  1201. package/dist-types/toolbar/internal/renderTrayTools.d.ts +3 -3
  1202. package/dist-types/toolbar/overflow-panel/OverflowPanel.d.ts +1 -1
  1203. package/dist-types/toolbar/overflow-panel/OverflowSeparator.d.ts +1 -1
  1204. package/dist-types/toolbar/toolbar-field/ToolbarField.d.ts +1 -1
  1205. package/dist-types/toolbar/toolbar-field/toolbarFieldTypes.d.ts +1 -1
  1206. package/dist-types/toolbar/toolbar-field/useToolbarField.d.ts +2 -2
  1207. package/dist-types/tree/Tree.d.ts +2 -2
  1208. package/dist-types/tree/TreeNode.d.ts +2 -2
  1209. package/dist-types/tree/treeTypes.d.ts +4 -4
  1210. package/dist-types/tree/use-tree-keyboard-navigation.d.ts +2 -2
  1211. package/dist-types/tree/useTree.d.ts +3 -3
  1212. package/dist-types/utils/useClickOutside.d.ts +1 -1
  1213. package/dist-types/utils/useIsViewportLargerThanBreakpoint.d.ts +1 -1
  1214. package/dist-types/utils/useLayoutEffectOnce.d.ts +1 -1
  1215. package/dist-types/utils/useLayoutEffectSkipFirst.d.ts +1 -1
  1216. package/dist-types/utils/useOverflowDetection.d.ts +1 -1
  1217. package/dist-types/utils/useSlideSelection.d.ts +1 -1
  1218. package/dist-types/window/WindowContext.d.ts +1 -1
  1219. package/package.json +3 -3
@@ -1 +1 @@
1
- {"version":3,"file":"useInstantCollapse.js","sources":["../src/responsive/useInstantCollapse.ts"],"sourcesContent":["import { useIsomorphicLayoutEffect } from \"@salt-ds/core\";\nimport { useCallback, useMemo } from \"react\";\nimport {\n InstantCollapseHookResult,\n OverflowHookProps,\n OverflowItem,\n} from \"./overflowTypes\";\nimport {\n addAll,\n allExceptOverflowIndicator,\n getElementForItem,\n measureContainerOverflow,\n measureElementSize,\n} from \"./overflowUtils\";\n\ntype MinMaxSize = {\n maxSize: number | null;\n minSize: number | null;\n};\n\nconst newlyCollapsed = (overflowItems: OverflowItem[]) =>\n overflowItems.some(\n (item) =>\n item.collapsible === \"instant\" && item.collapsed && item.fullSize === null\n );\n\nconst findItemToCollapse = (items: OverflowItem[]) => {\n for (let i = items.length - 1; i >= 0; i--) {\n const item = items[i];\n if (item.collapsible === \"instant\" && !item.collapsed) {\n // We only ever collapse 1 item at a time. We don'tknow how much space\n //this has saved until it re-renders and we can re-measure\n return item;\n }\n }\n};\n\nconst uncollapseItems = (items: OverflowItem[], containerSize: number) => {\n const visibleContentSize = items.reduce(allExceptOverflowIndicator, 0);\n let diff = containerSize - visibleContentSize;\n\n const collapsed = items\n .filter((item) => item.collapsible === \"instant\" && item.collapsed)\n .sort((i1, i2) => i2.index - i1.index);\n // find the next collapsed item, see how much extra space it would\n // occupy if restored. If we have enough space, restore it.\n const result: OverflowItem[] = [];\n while (collapsed.length) {\n const item = collapsed.pop() as OverflowItem;\n const itemDiff = item.fullSize! - item.size;\n if (diff >= itemDiff) {\n result.push({\n ...item,\n collapsed: false,\n size: item.fullSize as number,\n fullSize: null,\n });\n diff = diff - itemDiff;\n } else {\n break;\n }\n }\n return result;\n};\n\nexport const useInstantCollapse = ({\n collectionHook,\n hasOverflowedItems,\n innerContainerSize = 0,\n label = \"Toolbar\",\n overflowContainerRef: ref,\n overflowItemsRef,\n orientation,\n}: OverflowHookProps): InstantCollapseHookResult => {\n const minMaxSizes = useMemo(() => new Map<number, MinMaxSize>(), []);\n const { dispatch } = collectionHook;\n\n const updateCollapse = useCallback(\n (containerSize: number, renderedSize: number | null) => {\n const { current: managedItems } = overflowItemsRef;\n if (renderedSize && containerSize < renderedSize) {\n const overflowItem = findItemToCollapse(managedItems);\n if (overflowItem) {\n dispatch({\n type: \"collapse-instant-item\",\n overflowItem,\n });\n }\n } else {\n const uncollapsedItems = uncollapseItems(managedItems, containerSize);\n if (uncollapsedItems.length) {\n dispatch({\n type: \"update-items\",\n overflowItems: uncollapsedItems,\n });\n }\n }\n },\n [dispatch, overflowItemsRef]\n );\n\n const handleResize = useCallback(\n (size: number, containerHasGrown?: boolean) => {\n const { current: managedItems } = overflowItemsRef;\n const { isOverflowing: willOverflow } = measureContainerOverflow(\n ref,\n orientation\n );\n\n const collapsedItems = managedItems.filter((item) => item.collapsed);\n\n if (willOverflow && !hasOverflowedItems) {\n const overflowItem = findItemToCollapse(managedItems);\n if (overflowItem) {\n dispatch({\n type: \"collapse-instant-item\",\n overflowItem,\n });\n }\n } else if (collapsedItems.length > 0 && containerHasGrown) {\n // Note: it must have been previously overflowing, too\n // check to see if we can reinstate one or more items\n updateCollapse(size, null);\n } else if (willOverflow && hasOverflowedItems) {\n // Note: container must have shrunk\n // still overflowing, possibly more overflowing than before\n const renderedSize = managedItems.reduce(addAll, 0);\n updateCollapse(size, renderedSize);\n }\n },\n [\n dispatch,\n hasOverflowedItems,\n orientation,\n overflowItemsRef,\n ref,\n updateCollapse,\n ]\n );\n\n const resetMeasurements = useCallback(\n (isOverflowing?: boolean) => {\n const { current: managedItems } = overflowItemsRef;\n if (isOverflowing) {\n const overflowItem = findItemToCollapse(managedItems);\n if (overflowItem) {\n dispatch({\n type: \"collapse-instant-item\",\n overflowItem,\n });\n return true;\n } else {\n return false;\n }\n }\n },\n [dispatch, overflowItemsRef]\n );\n\n const setMinSize = useCallback(\n (item: OverflowItem, size: number) => {\n const minMaxSize = minMaxSizes.get(item.index);\n if (minMaxSize) {\n minMaxSize.minSize = size;\n } else {\n minMaxSizes.set(item.index, { maxSize: null, minSize: size });\n }\n },\n [minMaxSizes]\n );\n\n const measureCollapsedItem = useCallback(() => {\n const { current: managedItems } = overflowItemsRef;\n const dimension = orientation === \"horizontal\" ? \"width\" : \"height\";\n const [collapsedItem] = managedItems.filter(\n (item) => item.collapsible === \"instant\" && item.collapsed\n );\n console.log(`measureCollapsedItem ${collapsedItem.index}`);\n if (collapsedItem.fullSize === null) {\n const target = getElementForItem(ref, collapsedItem);\n if (target) {\n const collapsedSize = measureElementSize(target, dimension);\n const managedItem = findItemToCollapse(managedItems);\n const diff = collapsedItem.size - collapsedSize;\n const renderedSize = managedItems.reduce(addAll, 0) - diff;\n const updates = [];\n if (renderedSize > innerContainerSize && managedItem) {\n console.log(`next item to collapse ${managedItem.index}`);\n updates.push(\n {\n ...collapsedItem,\n fullSize: collapsedItem.size,\n size: collapsedSize,\n },\n {\n ...managedItem,\n collapsed: true,\n }\n );\n } else {\n updates.push({\n ...collapsedItem,\n fullSize: collapsedItem.size,\n size: collapsedSize,\n });\n }\n dispatch({\n type: \"update-items\",\n overflowItems: updates,\n });\n setMinSize(collapsedItem, collapsedSize);\n }\n } else {\n return -1;\n }\n }, [\n dispatch,\n innerContainerSize,\n orientation,\n overflowItemsRef,\n ref,\n setMinSize,\n ]);\n\n useIsomorphicLayoutEffect(() => {\n const { current: managedItems } = overflowItemsRef;\n const newlyCollapsedItem = newlyCollapsed(managedItems);\n if (newlyCollapsedItem) {\n measureCollapsedItem();\n }\n });\n\n return {\n onResize: handleResize,\n resetMeasurements,\n };\n};\n"],"names":["allExceptOverflowIndicator","useMemo","useCallback","measureContainerOverflow","addAll","getElementForItem","measureElementSize","useIsomorphicLayoutEffect"],"mappings":"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"}
1
+ {"version":3,"file":"useInstantCollapse.js","sources":["../src/responsive/useInstantCollapse.ts"],"sourcesContent":["import { useIsomorphicLayoutEffect } from \"@salt-ds/core\";\nimport { useCallback, useMemo } from \"react\";\nimport type {\n InstantCollapseHookResult,\n OverflowHookProps,\n OverflowItem,\n} from \"./overflowTypes\";\nimport {\n addAll,\n allExceptOverflowIndicator,\n getElementForItem,\n measureContainerOverflow,\n measureElementSize,\n} from \"./overflowUtils\";\n\ntype MinMaxSize = {\n maxSize: number | null;\n minSize: number | null;\n};\n\nconst newlyCollapsed = (overflowItems: OverflowItem[]) =>\n overflowItems.some(\n (item) =>\n item.collapsible === \"instant\" &&\n item.collapsed &&\n item.fullSize === null,\n );\n\nconst findItemToCollapse = (items: OverflowItem[]) => {\n for (let i = items.length - 1; i >= 0; i--) {\n const item = items[i];\n if (item.collapsible === \"instant\" && !item.collapsed) {\n // We only ever collapse 1 item at a time. We don'tknow how much space\n //this has saved until it re-renders and we can re-measure\n return item;\n }\n }\n};\n\nconst uncollapseItems = (items: OverflowItem[], containerSize: number) => {\n const visibleContentSize = items.reduce(allExceptOverflowIndicator, 0);\n let diff = containerSize - visibleContentSize;\n\n const collapsed = items\n .filter((item) => item.collapsible === \"instant\" && item.collapsed)\n .sort((i1, i2) => i2.index - i1.index);\n // find the next collapsed item, see how much extra space it would\n // occupy if restored. If we have enough space, restore it.\n const result: OverflowItem[] = [];\n while (collapsed.length) {\n const item = collapsed.pop() as OverflowItem;\n const itemDiff = (item.fullSize ?? 0) - item.size;\n if (diff >= itemDiff) {\n result.push({\n ...item,\n collapsed: false,\n size: item.fullSize as number,\n fullSize: null,\n });\n diff = diff - itemDiff;\n } else {\n break;\n }\n }\n return result;\n};\n\nexport const useInstantCollapse = ({\n collectionHook,\n hasOverflowedItems,\n innerContainerSize = 0,\n overflowContainerRef: ref,\n overflowItemsRef,\n orientation,\n}: OverflowHookProps): InstantCollapseHookResult => {\n const minMaxSizes = useMemo(() => new Map<number, MinMaxSize>(), []);\n const { dispatch } = collectionHook;\n\n const updateCollapse = useCallback(\n (containerSize: number, renderedSize: number | null) => {\n const { current: managedItems } = overflowItemsRef;\n if (renderedSize && containerSize < renderedSize) {\n const overflowItem = findItemToCollapse(managedItems);\n if (overflowItem) {\n dispatch({\n type: \"collapse-instant-item\",\n overflowItem,\n });\n }\n } else {\n const uncollapsedItems = uncollapseItems(managedItems, containerSize);\n if (uncollapsedItems.length) {\n dispatch({\n type: \"update-items\",\n overflowItems: uncollapsedItems,\n });\n }\n }\n },\n [dispatch, overflowItemsRef],\n );\n\n const handleResize = useCallback(\n (size: number, containerHasGrown?: boolean) => {\n const { current: managedItems } = overflowItemsRef;\n const { isOverflowing: willOverflow } = measureContainerOverflow(\n ref,\n orientation,\n );\n\n const collapsedItems = managedItems.filter((item) => item.collapsed);\n\n if (willOverflow && !hasOverflowedItems) {\n const overflowItem = findItemToCollapse(managedItems);\n if (overflowItem) {\n dispatch({\n type: \"collapse-instant-item\",\n overflowItem,\n });\n }\n } else if (collapsedItems.length > 0 && containerHasGrown) {\n // Note: it must have been previously overflowing, too\n // check to see if we can reinstate one or more items\n updateCollapse(size, null);\n } else if (willOverflow && hasOverflowedItems) {\n // Note: container must have shrunk\n // still overflowing, possibly more overflowing than before\n const renderedSize = managedItems.reduce(addAll, 0);\n updateCollapse(size, renderedSize);\n }\n },\n [\n dispatch,\n hasOverflowedItems,\n orientation,\n overflowItemsRef,\n ref,\n updateCollapse,\n ],\n );\n\n const resetMeasurements = useCallback(\n (isOverflowing?: boolean) => {\n const { current: managedItems } = overflowItemsRef;\n if (isOverflowing) {\n const overflowItem = findItemToCollapse(managedItems);\n if (overflowItem) {\n dispatch({\n type: \"collapse-instant-item\",\n overflowItem,\n });\n return true;\n }\n return false;\n }\n },\n [dispatch, overflowItemsRef],\n );\n\n const setMinSize = useCallback(\n (item: OverflowItem, size: number) => {\n const minMaxSize = minMaxSizes.get(item.index);\n if (minMaxSize) {\n minMaxSize.minSize = size;\n } else {\n minMaxSizes.set(item.index, { maxSize: null, minSize: size });\n }\n },\n [minMaxSizes],\n );\n\n const measureCollapsedItem = useCallback(() => {\n const { current: managedItems } = overflowItemsRef;\n const dimension = orientation === \"horizontal\" ? \"width\" : \"height\";\n const [collapsedItem] = managedItems.filter(\n (item) => item.collapsible === \"instant\" && item.collapsed,\n );\n console.log(`measureCollapsedItem ${collapsedItem.index}`);\n if (collapsedItem.fullSize === null) {\n const target = getElementForItem(ref, collapsedItem);\n if (target) {\n const collapsedSize = measureElementSize(target, dimension);\n const managedItem = findItemToCollapse(managedItems);\n const diff = collapsedItem.size - collapsedSize;\n const renderedSize = managedItems.reduce(addAll, 0) - diff;\n const updates = [];\n if (renderedSize > innerContainerSize && managedItem) {\n console.log(`next item to collapse ${managedItem.index}`);\n updates.push(\n {\n ...collapsedItem,\n fullSize: collapsedItem.size,\n size: collapsedSize,\n },\n {\n ...managedItem,\n collapsed: true,\n },\n );\n } else {\n updates.push({\n ...collapsedItem,\n fullSize: collapsedItem.size,\n size: collapsedSize,\n });\n }\n dispatch({\n type: \"update-items\",\n overflowItems: updates,\n });\n setMinSize(collapsedItem, collapsedSize);\n }\n } else {\n return -1;\n }\n }, [\n dispatch,\n innerContainerSize,\n orientation,\n overflowItemsRef,\n ref,\n setMinSize,\n ]);\n\n useIsomorphicLayoutEffect(() => {\n const { current: managedItems } = overflowItemsRef;\n const newlyCollapsedItem = newlyCollapsed(managedItems);\n if (newlyCollapsedItem) {\n measureCollapsedItem();\n }\n });\n\n return {\n onResize: handleResize,\n resetMeasurements,\n };\n};\n"],"names":["allExceptOverflowIndicator","useMemo","useCallback","measureContainerOverflow","addAll","getElementForItem","measureElementSize","useIsomorphicLayoutEffect"],"mappings":";;;;;;;;AAoBA,MAAM,cAAA,GAAiB,CAAC,aAAA,KACtB,aAAc,CAAA,IAAA;AAAA,EACZ,CAAC,SACC,IAAK,CAAA,WAAA,KAAgB,aACrB,IAAK,CAAA,SAAA,IACL,KAAK,QAAa,KAAA,IAAA;AACtB,CAAA,CAAA;AAEF,MAAM,kBAAA,GAAqB,CAAC,KAA0B,KAAA;AACpD,EAAA,KAAA,IAAS,IAAI,KAAM,CAAA,MAAA,GAAS,CAAG,EAAA,CAAA,IAAK,GAAG,CAAK,EAAA,EAAA;AAC1C,IAAA,MAAM,OAAO,KAAM,CAAA,CAAA,CAAA,CAAA;AACnB,IAAA,IAAI,IAAK,CAAA,WAAA,KAAgB,SAAa,IAAA,CAAC,KAAK,SAAW,EAAA;AAGrD,MAAO,OAAA,IAAA,CAAA;AAAA,KACT;AAAA,GACF;AACF,CAAA,CAAA;AAEA,MAAM,eAAA,GAAkB,CAAC,KAAA,EAAuB,aAA0B,KAAA;AAvC1E,EAAA,IAAA,EAAA,CAAA;AAwCE,EAAA,MAAM,kBAAqB,GAAA,KAAA,CAAM,MAAO,CAAAA,wCAAA,EAA4B,CAAC,CAAA,CAAA;AACrE,EAAA,IAAI,OAAO,aAAgB,GAAA,kBAAA,CAAA;AAE3B,EAAA,MAAM,YAAY,KACf,CAAA,MAAA,CAAO,CAAC,IAAS,KAAA,IAAA,CAAK,gBAAgB,SAAa,IAAA,IAAA,CAAK,SAAS,CAAA,CACjE,KAAK,CAAC,EAAA,EAAI,OAAO,EAAG,CAAA,KAAA,GAAQ,GAAG,KAAK,CAAA,CAAA;AAGvC,EAAA,MAAM,SAAyB,EAAC,CAAA;AAChC,EAAA,OAAO,UAAU,MAAQ,EAAA;AACvB,IAAM,MAAA,IAAA,GAAO,UAAU,GAAI,EAAA,CAAA;AAC3B,IAAA,MAAM,QAAY,GAAA,CAAA,CAAA,EAAA,GAAA,IAAA,CAAK,QAAL,KAAA,IAAA,GAAA,EAAA,GAAiB,KAAK,IAAK,CAAA,IAAA,CAAA;AAC7C,IAAA,IAAI,QAAQ,QAAU,EAAA;AACpB,MAAA,MAAA,CAAO,IAAK,CAAA;AAAA,QACV,GAAG,IAAA;AAAA,QACH,SAAW,EAAA,KAAA;AAAA,QACX,MAAM,IAAK,CAAA,QAAA;AAAA,QACX,QAAU,EAAA,IAAA;AAAA,OACX,CAAA,CAAA;AACD,MAAA,IAAA,GAAO,IAAO,GAAA,QAAA,CAAA;AAAA,KACT,MAAA;AACL,MAAA,MAAA;AAAA,KACF;AAAA,GACF;AACA,EAAO,OAAA,MAAA,CAAA;AACT,CAAA,CAAA;AAEO,MAAM,qBAAqB,CAAC;AAAA,EACjC,cAAA;AAAA,EACA,kBAAA;AAAA,EACA,kBAAqB,GAAA,CAAA;AAAA,EACrB,oBAAsB,EAAA,GAAA;AAAA,EACtB,gBAAA;AAAA,EACA,WAAA;AACF,CAAoD,KAAA;AAClD,EAAA,MAAM,cAAcC,aAAQ,CAAA,0BAAU,GAAwB,EAAA,EAAG,EAAE,CAAA,CAAA;AACnE,EAAM,MAAA,EAAE,UAAa,GAAA,cAAA,CAAA;AAErB,EAAA,MAAM,cAAiB,GAAAC,iBAAA;AAAA,IACrB,CAAC,eAAuB,YAAgC,KAAA;AACtD,MAAM,MAAA,EAAE,OAAS,EAAA,YAAA,EAAiB,GAAA,gBAAA,CAAA;AAClC,MAAI,IAAA,YAAA,IAAgB,gBAAgB,YAAc,EAAA;AAChD,QAAM,MAAA,YAAA,GAAe,mBAAmB,YAAY,CAAA,CAAA;AACpD,QAAA,IAAI,YAAc,EAAA;AAChB,UAAS,QAAA,CAAA;AAAA,YACP,IAAM,EAAA,uBAAA;AAAA,YACN,YAAA;AAAA,WACD,CAAA,CAAA;AAAA,SACH;AAAA,OACK,MAAA;AACL,QAAM,MAAA,gBAAA,GAAmB,eAAgB,CAAA,YAAA,EAAc,aAAa,CAAA,CAAA;AACpE,QAAA,IAAI,iBAAiB,MAAQ,EAAA;AAC3B,UAAS,QAAA,CAAA;AAAA,YACP,IAAM,EAAA,cAAA;AAAA,YACN,aAAe,EAAA,gBAAA;AAAA,WAChB,CAAA,CAAA;AAAA,SACH;AAAA,OACF;AAAA,KACF;AAAA,IACA,CAAC,UAAU,gBAAgB,CAAA;AAAA,GAC7B,CAAA;AAEA,EAAA,MAAM,YAAe,GAAAA,iBAAA;AAAA,IACnB,CAAC,MAAc,iBAAgC,KAAA;AAC7C,MAAM,MAAA,EAAE,OAAS,EAAA,YAAA,EAAiB,GAAA,gBAAA,CAAA;AAClC,MAAM,MAAA,EAAE,aAAe,EAAA,YAAA,EAAiB,GAAAC,sCAAA;AAAA,QACtC,GAAA;AAAA,QACA,WAAA;AAAA,OACF,CAAA;AAEA,MAAA,MAAM,iBAAiB,YAAa,CAAA,MAAA,CAAO,CAAC,IAAA,KAAS,KAAK,SAAS,CAAA,CAAA;AAEnE,MAAI,IAAA,YAAA,IAAgB,CAAC,kBAAoB,EAAA;AACvC,QAAM,MAAA,YAAA,GAAe,mBAAmB,YAAY,CAAA,CAAA;AACpD,QAAA,IAAI,YAAc,EAAA;AAChB,UAAS,QAAA,CAAA;AAAA,YACP,IAAM,EAAA,uBAAA;AAAA,YACN,YAAA;AAAA,WACD,CAAA,CAAA;AAAA,SACH;AAAA,OACS,MAAA,IAAA,cAAA,CAAe,MAAS,GAAA,CAAA,IAAK,iBAAmB,EAAA;AAGzD,QAAA,cAAA,CAAe,MAAM,IAAI,CAAA,CAAA;AAAA,OAC3B,MAAA,IAAW,gBAAgB,kBAAoB,EAAA;AAG7C,QAAA,MAAM,YAAe,GAAA,YAAA,CAAa,MAAO,CAAAC,oBAAA,EAAQ,CAAC,CAAA,CAAA;AAClD,QAAA,cAAA,CAAe,MAAM,YAAY,CAAA,CAAA;AAAA,OACnC;AAAA,KACF;AAAA,IACA;AAAA,MACE,QAAA;AAAA,MACA,kBAAA;AAAA,MACA,WAAA;AAAA,MACA,gBAAA;AAAA,MACA,GAAA;AAAA,MACA,cAAA;AAAA,KACF;AAAA,GACF,CAAA;AAEA,EAAA,MAAM,iBAAoB,GAAAF,iBAAA;AAAA,IACxB,CAAC,aAA4B,KAAA;AAC3B,MAAM,MAAA,EAAE,OAAS,EAAA,YAAA,EAAiB,GAAA,gBAAA,CAAA;AAClC,MAAA,IAAI,aAAe,EAAA;AACjB,QAAM,MAAA,YAAA,GAAe,mBAAmB,YAAY,CAAA,CAAA;AACpD,QAAA,IAAI,YAAc,EAAA;AAChB,UAAS,QAAA,CAAA;AAAA,YACP,IAAM,EAAA,uBAAA;AAAA,YACN,YAAA;AAAA,WACD,CAAA,CAAA;AACD,UAAO,OAAA,IAAA,CAAA;AAAA,SACT;AACA,QAAO,OAAA,KAAA,CAAA;AAAA,OACT;AAAA,KACF;AAAA,IACA,CAAC,UAAU,gBAAgB,CAAA;AAAA,GAC7B,CAAA;AAEA,EAAA,MAAM,UAAa,GAAAA,iBAAA;AAAA,IACjB,CAAC,MAAoB,IAAiB,KAAA;AACpC,MAAA,MAAM,UAAa,GAAA,WAAA,CAAY,GAAI,CAAA,IAAA,CAAK,KAAK,CAAA,CAAA;AAC7C,MAAA,IAAI,UAAY,EAAA;AACd,QAAA,UAAA,CAAW,OAAU,GAAA,IAAA,CAAA;AAAA,OAChB,MAAA;AACL,QAAY,WAAA,CAAA,GAAA,CAAI,KAAK,KAAO,EAAA,EAAE,SAAS,IAAM,EAAA,OAAA,EAAS,MAAM,CAAA,CAAA;AAAA,OAC9D;AAAA,KACF;AAAA,IACA,CAAC,WAAW,CAAA;AAAA,GACd,CAAA;AAEA,EAAM,MAAA,oBAAA,GAAuBA,kBAAY,MAAM;AAC7C,IAAM,MAAA,EAAE,OAAS,EAAA,YAAA,EAAiB,GAAA,gBAAA,CAAA;AAClC,IAAM,MAAA,SAAA,GAAY,WAAgB,KAAA,YAAA,GAAe,OAAU,GAAA,QAAA,CAAA;AAC3D,IAAM,MAAA,CAAC,aAAa,CAAA,GAAI,YAAa,CAAA,MAAA;AAAA,MACnC,CAAC,IAAA,KAAS,IAAK,CAAA,WAAA,KAAgB,aAAa,IAAK,CAAA,SAAA;AAAA,KACnD,CAAA;AACA,IAAQ,OAAA,CAAA,GAAA,CAAI,CAAwB,qBAAA,EAAA,aAAA,CAAc,KAAO,CAAA,CAAA,CAAA,CAAA;AACzD,IAAI,IAAA,aAAA,CAAc,aAAa,IAAM,EAAA;AACnC,MAAM,MAAA,MAAA,GAASG,+BAAkB,CAAA,GAAA,EAAK,aAAa,CAAA,CAAA;AACnD,MAAA,IAAI,MAAQ,EAAA;AACV,QAAM,MAAA,aAAA,GAAgBC,gCAAmB,CAAA,MAAA,EAAQ,SAAS,CAAA,CAAA;AAC1D,QAAM,MAAA,WAAA,GAAc,mBAAmB,YAAY,CAAA,CAAA;AACnD,QAAM,MAAA,IAAA,GAAO,cAAc,IAAO,GAAA,aAAA,CAAA;AAClC,QAAA,MAAM,YAAe,GAAA,YAAA,CAAa,MAAO,CAAAF,oBAAA,EAAQ,CAAC,CAAI,GAAA,IAAA,CAAA;AACtD,QAAA,MAAM,UAAU,EAAC,CAAA;AACjB,QAAI,IAAA,YAAA,GAAe,sBAAsB,WAAa,EAAA;AACpD,UAAQ,OAAA,CAAA,GAAA,CAAI,CAAyB,sBAAA,EAAA,WAAA,CAAY,KAAO,CAAA,CAAA,CAAA,CAAA;AACxD,UAAQ,OAAA,CAAA,IAAA;AAAA,YACN;AAAA,cACE,GAAG,aAAA;AAAA,cACH,UAAU,aAAc,CAAA,IAAA;AAAA,cACxB,IAAM,EAAA,aAAA;AAAA,aACR;AAAA,YACA;AAAA,cACE,GAAG,WAAA;AAAA,cACH,SAAW,EAAA,IAAA;AAAA,aACb;AAAA,WACF,CAAA;AAAA,SACK,MAAA;AACL,UAAA,OAAA,CAAQ,IAAK,CAAA;AAAA,YACX,GAAG,aAAA;AAAA,YACH,UAAU,aAAc,CAAA,IAAA;AAAA,YACxB,IAAM,EAAA,aAAA;AAAA,WACP,CAAA,CAAA;AAAA,SACH;AACA,QAAS,QAAA,CAAA;AAAA,UACP,IAAM,EAAA,cAAA;AAAA,UACN,aAAe,EAAA,OAAA;AAAA,SAChB,CAAA,CAAA;AACD,QAAA,UAAA,CAAW,eAAe,aAAa,CAAA,CAAA;AAAA,OACzC;AAAA,KACK,MAAA;AACL,MAAO,OAAA,CAAA,CAAA,CAAA;AAAA,KACT;AAAA,GACC,EAAA;AAAA,IACD,QAAA;AAAA,IACA,kBAAA;AAAA,IACA,WAAA;AAAA,IACA,gBAAA;AAAA,IACA,GAAA;AAAA,IACA,UAAA;AAAA,GACD,CAAA,CAAA;AAED,EAAAG,8BAAA,CAA0B,MAAM;AAC9B,IAAM,MAAA,EAAE,OAAS,EAAA,YAAA,EAAiB,GAAA,gBAAA,CAAA;AAClC,IAAM,MAAA,kBAAA,GAAqB,eAAe,YAAY,CAAA,CAAA;AACtD,IAAA,IAAI,kBAAoB,EAAA;AACtB,MAAqB,oBAAA,EAAA,CAAA;AAAA,KACvB;AAAA,GACD,CAAA,CAAA;AAED,EAAO,OAAA;AAAA,IACL,QAAU,EAAA,YAAA;AAAA,IACV,iBAAA;AAAA,GACF,CAAA;AACF;;;;"}
@@ -2,10 +2,10 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
+ var core = require('@salt-ds/core');
5
6
  var React = require('react');
6
- var overflowUtils = require('./overflowUtils.js');
7
7
  var partition = require('../utils/partition.js');
8
- var core = require('@salt-ds/core');
8
+ var overflowUtils = require('./overflowUtils.js');
9
9
 
10
10
  const NO_OVERFLOW_INDICATOR = { size: 0 };
11
11
  const getPriority = (item) => item.priority;
@@ -129,7 +129,7 @@ const useOverflow = ({
129
129
  }
130
130
  return [overflowCount, reinstatedItems];
131
131
  },
132
- []
132
+ [overflowItemsRef]
133
133
  );
134
134
  const resetMeasurements = React.useCallback(
135
135
  (isOverflowing, innerContainerSize) => {
@@ -179,12 +179,17 @@ const useOverflow = ({
179
179
  });
180
180
  }
181
181
  return true;
182
- } else {
183
- return false;
184
182
  }
183
+ return false;
185
184
  }
186
185
  },
187
- [dispatch, getAllOverflowedItems, id, overflowItemsRef, setContainerMinSize]
186
+ [
187
+ dispatch,
188
+ getAllOverflowedItems,
189
+ id,
190
+ overflowItemsRef,
191
+ setContainerMinSize
192
+ ]
188
193
  );
189
194
  const updateOverflow = React.useCallback(
190
195
  (containerSize, renderedSize) => {
@@ -1 +1 @@
1
- {"version":3,"file":"useOverflow.js","sources":["../src/responsive/useOverflow.ts"],"sourcesContent":["import { useCallback, useRef } from \"react\";\nimport {\n addAll,\n allExceptOverflowIndicator,\n getOverflowIndicator,\n isOverflowed,\n measureContainerOverflow,\n notOverflowed,\n popNextItemByPriority,\n} from \"./overflowUtils\";\nimport {\n OverflowItem,\n OverflowHookProps,\n OverflowHookResult,\n} from \"./overflowTypes\";\nimport { partition } from \"../utils\";\nimport { useIdMemo } from \"@salt-ds/core\";\n\nconst NO_OVERFLOW_INDICATOR = { size: 0 };\n\nconst getPriority = (item: OverflowItem) => item.priority;\n\nconst popNextOverflowedItem = (items: OverflowItem[]) => {\n const minPriority = Math.min(...items.map(getPriority));\n for (let i = 0; i < items.length; i++) {\n if (!items[i].isOverflowIndicator && items[i].priority === minPriority) {\n return items.splice(i, 1)[0];\n }\n }\n return null;\n};\n\nexport const useOverflow = ({\n collectionHook: { dispatch },\n id: idProp,\n label = \"Toolbar\",\n overflowItemsRef,\n overflowContainerRef,\n orientation,\n}: OverflowHookProps): OverflowHookResult => {\n // We need to detect when we enter/exit the overflowed state\n const innerContainerSizeRef = useRef(0);\n const overflowIndicatorSize = useRef(0);\n const id = useIdMemo(idProp);\n\n const setContainerMinSize = useCallback(\n (size?: number) => {\n if (overflowContainerRef.current) {\n const isHorizontal = orientation === \"horizontal\";\n if (size === undefined) {\n const dimension = isHorizontal ? \"width\" : \"height\";\n ({ [dimension]: size } =\n overflowContainerRef.current.getBoundingClientRect());\n }\n if (typeof size === \"number\") {\n const styleDimension = isHorizontal ? \"minWidth\" : \"minHeight\";\n overflowContainerRef.current.style[styleDimension] = `${size}px`;\n }\n }\n },\n [orientation, overflowContainerRef]\n );\n\n const getAllOverflowedItems = useCallback(\n (renderedSize: number, availableSpace: number) => {\n const { current: allItems } = overflowItemsRef;\n const overflowedItems: OverflowItem[] = [];\n const items = allItems.slice();\n while (renderedSize > availableSpace) {\n const overflowedItem = popNextItemByPriority(items);\n if (overflowedItem === null) {\n break;\n }\n // eslint-disable-next-line no-param-reassign\n renderedSize -= overflowedItem.size;\n overflowedItems.push({\n ...overflowedItem,\n overflowed: true,\n });\n }\n return overflowedItems;\n },\n [overflowItemsRef]\n );\n\n const getOverflowedItems = useCallback(\n (visibleContentSize: number, containerSize: number) => {\n const newlyOverflowedItems = [];\n const { current: managedItems } = overflowItemsRef;\n const visibleItems = managedItems.filter(notOverflowed);\n while (visibleContentSize > containerSize) {\n const overflowedItem = popNextItemByPriority(visibleItems);\n if (overflowedItem === null) {\n // unable to overflow, all items are collapsed, this is our minimum width,\n // enforce it ...\n // TODO what if density changes\n // TODO probably not right, now we overflow even collapsed items, min width should be\n // overflow indicator width plus width of any non-overflowable items\n // setContainerMinSize(visibleContentSize);\n break;\n }\n visibleContentSize -= overflowedItem.size;\n newlyOverflowedItems.push({\n ...overflowedItem,\n overflowed: true,\n });\n }\n return newlyOverflowedItems;\n },\n [overflowItemsRef]\n );\n\n const getReinstatedItems = useCallback(\n (containerSize: number): [number, OverflowItem[]] => {\n const reinstatedItems: OverflowItem[] = [];\n const { current: managedItems } = overflowItemsRef;\n\n const [overflowedItems, visibleItems] = partition(\n managedItems,\n isOverflowed\n );\n const overflowCount = overflowedItems.length;\n // TODO calculate this without using fullWidth if we have OVERFLOW\n // Need a loop here where we first remove OVERFLOW, then potentially remove\n // COLLAPSE too\n // We want to re-introduce overflowed items before we start to restore collapsed items\n // When we are dealing with overflowed items, we just use the current width of collapsed items.\n let visibleContentSize = visibleItems.reduce(\n allExceptOverflowIndicator,\n 0\n );\n let diff = containerSize - visibleContentSize;\n const { size: overflowSize = 0 } =\n getOverflowIndicator(managedItems) || NO_OVERFLOW_INDICATOR;\n const totalOverflowedSize = overflowedItems.reduce(\n (sum, item) => sum + item.size,\n 0\n );\n // It is important to make this check first, because the overflow indicator may have larger size than\n // individual overflowed item(s).\n if (totalOverflowedSize <= diff) {\n reinstatedItems.push(\n ...overflowedItems.map((item) => ({ ...item, overflowed: false }))\n );\n } else {\n while (overflowedItems.length > 0) {\n const nextItem = popNextOverflowedItem(overflowedItems);\n if (nextItem && diff >= nextItem.size) {\n // we have enough free space to reinstate this overflowed item\n // we can only ignore the width of overflow Indicator if either there is only one remaining\n // overflow item (so overflowIndicator will be removed) or diff is big enough to accommodate\n // the overflow Ind.\n if (\n overflowedItems.length === 0 ||\n diff >= nextItem.size + overflowSize\n ) {\n visibleContentSize += nextItem.size;\n diff = diff - nextItem.size;\n reinstatedItems.push({\n ...nextItem,\n overflowed: false,\n });\n } else {\n break;\n }\n } else {\n break;\n }\n }\n }\n return [overflowCount, reinstatedItems];\n },\n []\n );\n\n const resetMeasurements = useCallback(\n (isOverflowing: boolean, innerContainerSize: number) => {\n if (isOverflowing) {\n const { current: managedItems } = overflowItemsRef;\n const renderedSize = managedItems.reduce(allExceptOverflowIndicator, 0);\n const overflowIndicator = managedItems.find(\n (i) => i.isOverflowIndicator\n );\n if (\n overflowIndicator &&\n overflowIndicator.size !== overflowIndicatorSize.current\n ) {\n overflowIndicatorSize.current = overflowIndicator.size;\n setContainerMinSize(overflowIndicator.size);\n }\n const existingOverflow = managedItems.filter(isOverflowed);\n const updates = getAllOverflowedItems(\n renderedSize,\n innerContainerSize - overflowIndicatorSize.current\n );\n\n existingOverflow.forEach((item) => {\n if (!updates.some((i) => i.index === item.index)) {\n updates.push({\n ...item,\n overflowed: false,\n });\n }\n });\n\n const overflowAdded = !existingOverflow.length && updates.length;\n\n if (updates.length > 0) {\n if (overflowAdded) {\n dispatch({\n type: \"update-items-add-overflow-indicator\",\n overflowItems: updates,\n overflowItem: {\n fullSize: null,\n id: `${id}-overflow-indicator`,\n index: managedItems.length,\n isOverflowIndicator: true,\n label: \"Overflow Menu\",\n priority: 1,\n source: {},\n } as OverflowItem<\"source\">,\n });\n } else {\n dispatch({\n type: \"update-items\",\n overflowItems: updates,\n });\n }\n return true;\n } else {\n return false;\n }\n }\n },\n [dispatch, getAllOverflowedItems, id, overflowItemsRef, setContainerMinSize]\n );\n\n const updateOverflow = useCallback(\n (containerSize: number, renderedSize: number) => {\n if (containerSize < renderedSize) {\n const overflowItems = getOverflowedItems(renderedSize, containerSize);\n if (overflowItems.length) {\n dispatch({\n type: \"update-items\",\n overflowItems,\n });\n }\n }\n },\n [dispatch, getOverflowedItems]\n );\n\n const removeOverflow = useCallback(\n (containerSize: number) => {\n const [overflowCount, reinstated] = getReinstatedItems(containerSize);\n if (reinstated.length) {\n if (overflowCount === reinstated.length) {\n dispatch({\n type: \"update-items-remove-overflow-indicator\",\n overflowItems: reinstated,\n });\n } else {\n dispatch({\n type: \"update-items\",\n overflowItems: reinstated,\n });\n }\n }\n },\n [dispatch, getReinstatedItems]\n );\n\n const handleResize = useCallback(\n (size: number, containerHasGrown?: boolean) => {\n const { current: managedItems } = overflowItemsRef;\n const wasOverflowing = managedItems.some(\n (item) => item.isOverflowIndicator\n );\n const { isOverflowing } = measureContainerOverflow(\n overflowContainerRef,\n orientation\n );\n\n innerContainerSizeRef.current = size;\n\n if (!wasOverflowing && isOverflowing) {\n // entering overflow\n // TODO if client is not using an overflow indicator, there is nothing to do here,\n // just let nature take its course. How do we know this ?\n // This is when we need to add width to measurements we are tracking\n resetMeasurements(true, size);\n } else if (wasOverflowing && containerHasGrown) {\n // check to see if we can reinstate one or more items, possibly all\n removeOverflow(size);\n } else if (wasOverflowing && isOverflowing) {\n // Note: container must have shrunk\n // still overflowing, possibly more overflowing than before\n const renderedSize = managedItems\n .filter(notOverflowed)\n .reduce(addAll, 0);\n updateOverflow(size, renderedSize);\n }\n },\n [\n orientation,\n overflowContainerRef,\n overflowItemsRef,\n removeOverflow,\n resetMeasurements,\n updateOverflow,\n ]\n );\n\n return {\n onResize: handleResize,\n resetMeasurements,\n };\n};\n"],"names":["useRef","useIdMemo","useCallback","popNextItemByPriority","notOverflowed","partition","isOverflowed","allExceptOverflowIndicator","getOverflowIndicator","measureContainerOverflow","addAll"],"mappings":"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"}
1
+ {"version":3,"file":"useOverflow.js","sources":["../src/responsive/useOverflow.ts"],"sourcesContent":["import { useIdMemo } from \"@salt-ds/core\";\nimport { useCallback, useRef } from \"react\";\nimport { partition } from \"../utils\";\nimport type {\n OverflowHookProps,\n OverflowHookResult,\n OverflowItem,\n} from \"./overflowTypes\";\nimport {\n addAll,\n allExceptOverflowIndicator,\n getOverflowIndicator,\n isOverflowed,\n measureContainerOverflow,\n notOverflowed,\n popNextItemByPriority,\n} from \"./overflowUtils\";\n\nconst NO_OVERFLOW_INDICATOR = { size: 0 };\n\nconst getPriority = (item: OverflowItem) => item.priority;\n\nconst popNextOverflowedItem = (items: OverflowItem[]) => {\n const minPriority = Math.min(...items.map(getPriority));\n for (let i = 0; i < items.length; i++) {\n if (!items[i].isOverflowIndicator && items[i].priority === minPriority) {\n return items.splice(i, 1)[0];\n }\n }\n return null;\n};\n\nexport const useOverflow = ({\n collectionHook: { dispatch },\n id: idProp,\n label = \"Toolbar\",\n overflowItemsRef,\n overflowContainerRef,\n orientation,\n}: OverflowHookProps): OverflowHookResult => {\n // We need to detect when we enter/exit the overflowed state\n const innerContainerSizeRef = useRef(0);\n const overflowIndicatorSize = useRef(0);\n const id = useIdMemo(idProp);\n\n const setContainerMinSize = useCallback(\n (size?: number) => {\n if (overflowContainerRef.current) {\n const isHorizontal = orientation === \"horizontal\";\n if (size === undefined) {\n const dimension = isHorizontal ? \"width\" : \"height\";\n ({ [dimension]: size } =\n overflowContainerRef.current.getBoundingClientRect());\n }\n if (typeof size === \"number\") {\n const styleDimension = isHorizontal ? \"minWidth\" : \"minHeight\";\n overflowContainerRef.current.style[styleDimension] = `${size}px`;\n }\n }\n },\n [orientation, overflowContainerRef],\n );\n\n const getAllOverflowedItems = useCallback(\n (renderedSize: number, availableSpace: number) => {\n const { current: allItems } = overflowItemsRef;\n const overflowedItems: OverflowItem[] = [];\n const items = allItems.slice();\n while (renderedSize > availableSpace) {\n const overflowedItem = popNextItemByPriority(items);\n if (overflowedItem === null) {\n break;\n }\n renderedSize -= overflowedItem.size;\n overflowedItems.push({\n ...overflowedItem,\n overflowed: true,\n });\n }\n return overflowedItems;\n },\n [overflowItemsRef],\n );\n\n const getOverflowedItems = useCallback(\n (visibleContentSize: number, containerSize: number) => {\n const newlyOverflowedItems = [];\n const { current: managedItems } = overflowItemsRef;\n const visibleItems = managedItems.filter(notOverflowed);\n while (visibleContentSize > containerSize) {\n const overflowedItem = popNextItemByPriority(visibleItems);\n if (overflowedItem === null) {\n // unable to overflow, all items are collapsed, this is our minimum width,\n // enforce it ...\n // TODO what if density changes\n // TODO probably not right, now we overflow even collapsed items, min width should be\n // overflow indicator width plus width of any non-overflowable items\n // setContainerMinSize(visibleContentSize);\n break;\n }\n visibleContentSize -= overflowedItem.size;\n newlyOverflowedItems.push({\n ...overflowedItem,\n overflowed: true,\n });\n }\n return newlyOverflowedItems;\n },\n [overflowItemsRef],\n );\n\n const getReinstatedItems = useCallback(\n (containerSize: number): [number, OverflowItem[]] => {\n const reinstatedItems: OverflowItem[] = [];\n const { current: managedItems } = overflowItemsRef;\n\n const [overflowedItems, visibleItems] = partition(\n managedItems,\n isOverflowed,\n );\n const overflowCount = overflowedItems.length;\n // TODO calculate this without using fullWidth if we have OVERFLOW\n // Need a loop here where we first remove OVERFLOW, then potentially remove\n // COLLAPSE too\n // We want to re-introduce overflowed items before we start to restore collapsed items\n // When we are dealing with overflowed items, we just use the current width of collapsed items.\n let visibleContentSize = visibleItems.reduce(\n allExceptOverflowIndicator,\n 0,\n );\n let diff = containerSize - visibleContentSize;\n const { size: overflowSize = 0 } =\n getOverflowIndicator(managedItems) || NO_OVERFLOW_INDICATOR;\n const totalOverflowedSize = overflowedItems.reduce(\n (sum, item) => sum + item.size,\n 0,\n );\n // It is important to make this check first, because the overflow indicator may have larger size than\n // individual overflowed item(s).\n if (totalOverflowedSize <= diff) {\n reinstatedItems.push(\n ...overflowedItems.map((item) => ({ ...item, overflowed: false })),\n );\n } else {\n while (overflowedItems.length > 0) {\n const nextItem = popNextOverflowedItem(overflowedItems);\n if (nextItem && diff >= nextItem.size) {\n // we have enough free space to reinstate this overflowed item\n // we can only ignore the width of overflow Indicator if either there is only one remaining\n // overflow item (so overflowIndicator will be removed) or diff is big enough to accommodate\n // the overflow Ind.\n if (\n overflowedItems.length === 0 ||\n diff >= nextItem.size + overflowSize\n ) {\n visibleContentSize += nextItem.size;\n diff = diff - nextItem.size;\n reinstatedItems.push({\n ...nextItem,\n overflowed: false,\n });\n } else {\n break;\n }\n } else {\n break;\n }\n }\n }\n return [overflowCount, reinstatedItems];\n },\n [overflowItemsRef],\n );\n\n const resetMeasurements = useCallback(\n (isOverflowing: boolean, innerContainerSize: number) => {\n if (isOverflowing) {\n const { current: managedItems } = overflowItemsRef;\n const renderedSize = managedItems.reduce(allExceptOverflowIndicator, 0);\n const overflowIndicator = managedItems.find(\n (i) => i.isOverflowIndicator,\n );\n if (\n overflowIndicator &&\n overflowIndicator.size !== overflowIndicatorSize.current\n ) {\n overflowIndicatorSize.current = overflowIndicator.size;\n setContainerMinSize(overflowIndicator.size);\n }\n const existingOverflow = managedItems.filter(isOverflowed);\n const updates = getAllOverflowedItems(\n renderedSize,\n innerContainerSize - overflowIndicatorSize.current,\n );\n\n existingOverflow.forEach((item) => {\n if (!updates.some((i) => i.index === item.index)) {\n updates.push({\n ...item,\n overflowed: false,\n });\n }\n });\n\n const overflowAdded = !existingOverflow.length && updates.length;\n\n if (updates.length > 0) {\n if (overflowAdded) {\n dispatch({\n type: \"update-items-add-overflow-indicator\",\n overflowItems: updates,\n overflowItem: {\n fullSize: null,\n id: `${id}-overflow-indicator`,\n index: managedItems.length,\n isOverflowIndicator: true,\n label: \"Overflow Menu\",\n priority: 1,\n source: {},\n } as OverflowItem<\"source\">,\n });\n } else {\n dispatch({\n type: \"update-items\",\n overflowItems: updates,\n });\n }\n return true;\n }\n return false;\n }\n },\n [\n dispatch,\n getAllOverflowedItems,\n id,\n overflowItemsRef,\n setContainerMinSize,\n ],\n );\n\n const updateOverflow = useCallback(\n (containerSize: number, renderedSize: number) => {\n if (containerSize < renderedSize) {\n const overflowItems = getOverflowedItems(renderedSize, containerSize);\n if (overflowItems.length) {\n dispatch({\n type: \"update-items\",\n overflowItems,\n });\n }\n }\n },\n [dispatch, getOverflowedItems],\n );\n\n const removeOverflow = useCallback(\n (containerSize: number) => {\n const [overflowCount, reinstated] = getReinstatedItems(containerSize);\n if (reinstated.length) {\n if (overflowCount === reinstated.length) {\n dispatch({\n type: \"update-items-remove-overflow-indicator\",\n overflowItems: reinstated,\n });\n } else {\n dispatch({\n type: \"update-items\",\n overflowItems: reinstated,\n });\n }\n }\n },\n [dispatch, getReinstatedItems],\n );\n\n const handleResize = useCallback(\n (size: number, containerHasGrown?: boolean) => {\n const { current: managedItems } = overflowItemsRef;\n const wasOverflowing = managedItems.some(\n (item) => item.isOverflowIndicator,\n );\n const { isOverflowing } = measureContainerOverflow(\n overflowContainerRef,\n orientation,\n );\n\n innerContainerSizeRef.current = size;\n\n if (!wasOverflowing && isOverflowing) {\n // entering overflow\n // TODO if client is not using an overflow indicator, there is nothing to do here,\n // just let nature take its course. How do we know this ?\n // This is when we need to add width to measurements we are tracking\n resetMeasurements(true, size);\n } else if (wasOverflowing && containerHasGrown) {\n // check to see if we can reinstate one or more items, possibly all\n removeOverflow(size);\n } else if (wasOverflowing && isOverflowing) {\n // Note: container must have shrunk\n // still overflowing, possibly more overflowing than before\n const renderedSize = managedItems\n .filter(notOverflowed)\n .reduce(addAll, 0);\n updateOverflow(size, renderedSize);\n }\n },\n [\n orientation,\n overflowContainerRef,\n overflowItemsRef,\n removeOverflow,\n resetMeasurements,\n updateOverflow,\n ],\n );\n\n return {\n onResize: handleResize,\n resetMeasurements,\n };\n};\n"],"names":["useRef","useIdMemo","useCallback","popNextItemByPriority","notOverflowed","partition","isOverflowed","allExceptOverflowIndicator","getOverflowIndicator","measureContainerOverflow","addAll"],"mappings":"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"}
@@ -2,10 +2,10 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var React = require('react');
6
5
  var core = require('@salt-ds/core');
7
- var overflowUtils = require('./overflowUtils.js');
6
+ var React = require('react');
8
7
  var OverflowReducer = require('./OverflowReducer.js');
8
+ var overflowUtils = require('./overflowUtils.js');
9
9
 
10
10
  const defaultOptions = {};
11
11
  const defaultChildIdentity = (children) => {
@@ -104,7 +104,7 @@ const useOverflowCollectionItems = ({
104
104
  measureManagedItems();
105
105
  }
106
106
  measure().catch((err) => {
107
- console.warn(`error occurred measuring Overflow Items`, err);
107
+ console.warn("error occurred measuring Overflow Items", err);
108
108
  });
109
109
  }, [measureManagedItems]);
110
110
  const dispatchOverflowAction = React.useCallback(
@@ -1 +1 @@
1
- {"version":3,"file":"useOverflowCollectionItems.js","sources":["../src/responsive/useOverflowCollectionItems.ts"],"sourcesContent":["import {\n useCallback,\n useReducer,\n useRef,\n Children,\n ReactElement,\n ReactNode,\n isValidElement,\n} from \"react\";\nimport { useIsomorphicLayoutEffect } from \"@salt-ds/core\";\n\nimport {\n OverflowItem,\n OverflowCollectionOptions,\n OverflowCollectionHookProps,\n OverflowCollectionHookResult,\n OverflowSource,\n} from \"./overflowTypes\";\nimport { measureOverflowItems } from \"./overflowUtils\";\nimport {\n reducerInitialiser,\n OverflowAction,\n overflowReducer,\n OverflowReducer,\n OverflowReducerInitialisationProps,\n} from \"./OverflowReducer\";\n\nconst defaultOptions: OverflowCollectionOptions = {};\n\ntype WithLabel = { label?: string };\n\nconst defaultChildIdentity = (children: ReactNode) => {\n const childLabels: string[] = [];\n Children.forEach(children, (child) => {\n if (isValidElement(child)) {\n childLabels.push((child as ReactElement<WithLabel>).props.label ?? \"\");\n }\n });\n return `${childLabels.length}:${childLabels.join(\":\")}`;\n};\n\nconst defaultSourceIdentity = (source: WithLabel[]): string => {\n const labels = source.map(({ label }) => label).join(\":\");\n return `${source.length}:${labels}`;\n};\n// We need to track structural changes to controlled source or child elements.\n// Simple identity won't work as child elements will be different on every render.\n// structural changes are addition or removal of items, reordering items.\n// Question, what if user changes prop in declarative TabPanel ?\nconst getItemsIdentity = (\n defaultSource?: OverflowSource[],\n source?: OverflowSource[],\n children?: ReactNode\n): string => {\n let identity;\n if (Array.isArray(defaultSource)) {\n identity = defaultSourceIdentity(defaultSource);\n } else if (Array.isArray(source)) {\n identity = defaultSourceIdentity(source);\n } else {\n identity = defaultChildIdentity(children);\n }\n return identity;\n};\n\ntype OverflowCollectionHook = (\n props: OverflowCollectionHookProps\n) => OverflowCollectionHookResult;\n\nexport const useOverflowCollectionItems: OverflowCollectionHook = ({\n children,\n defaultSource,\n id: idRoot,\n injectedItems = [],\n options = defaultOptions,\n orientation,\n label = \"\",\n source,\n}) => {\n const dataRef = useRef<OverflowItem[]>([]);\n const versionRef = useRef(0);\n const measureTimeout = useRef<number | null>(null);\n const previousIdentityRef = useRef(\"\");\n const fontsLoaded = useRef(false);\n const identity = getItemsIdentity(defaultSource, source, children);\n const isControlled = Array.isArray(source) || Children.count(children) > 0;\n if (isControlled && defaultSource !== undefined) {\n throw Error(\n \"useOverflowCollectionItems: defaultSource prop should not be used in combination with either source prop or children \"\n );\n }\n\n const [data, dispatch] = useReducer<\n OverflowReducer,\n OverflowReducerInitialisationProps\n >(\n overflowReducer,\n {\n children,\n source: source || defaultSource,\n injectedItems,\n idRoot,\n options,\n },\n reducerInitialiser\n );\n\n dataRef.current = data;\n\n const measureManagedItems = useCallback(\n (defer = false) => {\n if (measureTimeout.current) {\n window.clearTimeout(measureTimeout.current);\n measureTimeout.current = null;\n }\n if (defer) {\n measureTimeout.current = window.setTimeout(measureManagedItems, 30);\n } else {\n // If fonts have not yet loaded, measurements WILL be incorrect\n if (fontsLoaded.current) {\n const dimension = orientation === \"horizontal\" ? \"width\" : \"height\";\n const overflowItems = measureOverflowItems(\n dataRef.current,\n dimension\n );\n // TODO if measurements have not changed, do nothing\n // Track the generation of measured items. This can be used to trigger\n // side effects when measurement takes place.\n versionRef.current += 1;\n dispatch({\n type: \"init\",\n overflowItems,\n });\n }\n }\n },\n [orientation]\n );\n\n // Take the initial measurements of overflow items. All subsequent re-measurement will be\n // triggered by either manipulation of the items or item state or updated source.\n useIsomorphicLayoutEffect(() => {\n async function measure(): Promise<void> {\n const { fonts } = document;\n if (fonts) {\n await fonts.ready;\n fontsLoaded.current = true;\n } else {\n fontsLoaded.current = true;\n }\n measureManagedItems();\n }\n\n measure().catch((err) => {\n console.warn(`error occurred measuring Overflow Items`, err);\n });\n }, [measureManagedItems]);\n\n const dispatchOverflowAction = useCallback(\n (action: OverflowAction | { type: \"reset\" }) => {\n if (action.type === \"reset\") {\n measureManagedItems();\n } else {\n dispatch(action);\n\n if (action.type.endsWith(\"overflow-indicator\")) {\n measureManagedItems(true);\n }\n }\n },\n [measureManagedItems]\n );\n\n useIsomorphicLayoutEffect(() => {\n if (previousIdentityRef.current !== \"\") {\n const overflowItems = reducerInitialiser({\n children,\n source: source || defaultSource,\n injectedItems,\n idRoot,\n options,\n });\n\n dispatch({ type: \"init\", overflowItems });\n measureManagedItems(true);\n }\n previousIdentityRef.current = identity;\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [identity]);\n\n return {\n data,\n dispatch: dispatchOverflowAction,\n isControlled,\n version: versionRef.current,\n };\n};\n"],"names":["Children","isValidElement","useRef","useReducer","overflowReducer","reducerInitialiser","useCallback","measureOverflowItems","useIsomorphicLayoutEffect"],"mappings":"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"}
1
+ {"version":3,"file":"useOverflowCollectionItems.js","sources":["../src/responsive/useOverflowCollectionItems.ts"],"sourcesContent":["import { useIsomorphicLayoutEffect } from \"@salt-ds/core\";\nimport {\n Children,\n type ReactElement,\n type ReactNode,\n isValidElement,\n useCallback,\n useReducer,\n useRef,\n} from \"react\";\n\nimport {\n type OverflowAction,\n type OverflowReducer,\n type OverflowReducerInitialisationProps,\n overflowReducer,\n reducerInitialiser,\n} from \"./OverflowReducer\";\nimport type {\n OverflowCollectionHookProps,\n OverflowCollectionHookResult,\n OverflowCollectionOptions,\n OverflowItem,\n OverflowSource,\n} from \"./overflowTypes\";\nimport { measureOverflowItems } from \"./overflowUtils\";\n\nconst defaultOptions: OverflowCollectionOptions = {};\n\ntype WithLabel = { label?: string };\n\nconst defaultChildIdentity = (children: ReactNode) => {\n const childLabels: string[] = [];\n Children.forEach(children, (child) => {\n if (isValidElement(child)) {\n childLabels.push((child as ReactElement<WithLabel>).props.label ?? \"\");\n }\n });\n return `${childLabels.length}:${childLabels.join(\":\")}`;\n};\n\nconst defaultSourceIdentity = (source: WithLabel[]): string => {\n const labels = source.map(({ label }) => label).join(\":\");\n return `${source.length}:${labels}`;\n};\n// We need to track structural changes to controlled source or child elements.\n// Simple identity won't work as child elements will be different on every render.\n// structural changes are addition or removal of items, reordering items.\n// Question, what if user changes prop in declarative TabPanel ?\nconst getItemsIdentity = (\n defaultSource?: OverflowSource[],\n source?: OverflowSource[],\n children?: ReactNode,\n): string => {\n let identity: string;\n if (Array.isArray(defaultSource)) {\n identity = defaultSourceIdentity(defaultSource);\n } else if (Array.isArray(source)) {\n identity = defaultSourceIdentity(source);\n } else {\n identity = defaultChildIdentity(children);\n }\n return identity;\n};\n\ntype OverflowCollectionHook = (\n props: OverflowCollectionHookProps,\n) => OverflowCollectionHookResult;\n\nexport const useOverflowCollectionItems: OverflowCollectionHook = ({\n children,\n defaultSource,\n id: idRoot,\n injectedItems = [],\n options = defaultOptions,\n orientation,\n label = \"\",\n source,\n}) => {\n const dataRef = useRef<OverflowItem[]>([]);\n const versionRef = useRef(0);\n const measureTimeout = useRef<number | null>(null);\n const previousIdentityRef = useRef(\"\");\n const fontsLoaded = useRef(false);\n const identity = getItemsIdentity(defaultSource, source, children);\n const isControlled = Array.isArray(source) || Children.count(children) > 0;\n if (isControlled && defaultSource !== undefined) {\n throw Error(\n \"useOverflowCollectionItems: defaultSource prop should not be used in combination with either source prop or children \",\n );\n }\n\n const [data, dispatch] = useReducer<\n OverflowReducer,\n OverflowReducerInitialisationProps\n >(\n overflowReducer,\n {\n children,\n source: source || defaultSource,\n injectedItems,\n idRoot,\n options,\n },\n reducerInitialiser,\n );\n\n dataRef.current = data;\n\n const measureManagedItems = useCallback(\n (defer = false) => {\n if (measureTimeout.current) {\n window.clearTimeout(measureTimeout.current);\n measureTimeout.current = null;\n }\n if (defer) {\n measureTimeout.current = window.setTimeout(measureManagedItems, 30);\n } else {\n // If fonts have not yet loaded, measurements WILL be incorrect\n if (fontsLoaded.current) {\n const dimension = orientation === \"horizontal\" ? \"width\" : \"height\";\n const overflowItems = measureOverflowItems(\n dataRef.current,\n dimension,\n );\n // TODO if measurements have not changed, do nothing\n // Track the generation of measured items. This can be used to trigger\n // side effects when measurement takes place.\n versionRef.current += 1;\n dispatch({\n type: \"init\",\n overflowItems,\n });\n }\n }\n },\n [orientation],\n );\n\n // Take the initial measurements of overflow items. All subsequent re-measurement will be\n // triggered by either manipulation of the items or item state or updated source.\n useIsomorphicLayoutEffect(() => {\n async function measure(): Promise<void> {\n const { fonts } = document;\n if (fonts) {\n await fonts.ready;\n fontsLoaded.current = true;\n } else {\n fontsLoaded.current = true;\n }\n measureManagedItems();\n }\n\n measure().catch((err) => {\n console.warn(\"error occurred measuring Overflow Items\", err);\n });\n }, [measureManagedItems]);\n\n const dispatchOverflowAction = useCallback(\n (action: OverflowAction | { type: \"reset\" }) => {\n if (action.type === \"reset\") {\n measureManagedItems();\n } else {\n dispatch(action);\n\n if (action.type.endsWith(\"overflow-indicator\")) {\n measureManagedItems(true);\n }\n }\n },\n [measureManagedItems],\n );\n\n useIsomorphicLayoutEffect(() => {\n if (previousIdentityRef.current !== \"\") {\n const overflowItems = reducerInitialiser({\n children,\n source: source || defaultSource,\n injectedItems,\n idRoot,\n options,\n });\n\n dispatch({ type: \"init\", overflowItems });\n measureManagedItems(true);\n }\n previousIdentityRef.current = identity;\n }, [identity]);\n\n return {\n data,\n dispatch: dispatchOverflowAction,\n isControlled,\n version: versionRef.current,\n };\n};\n"],"names":["Children","isValidElement","useRef","useReducer","overflowReducer","reducerInitialiser","useCallback","measureOverflowItems","useIsomorphicLayoutEffect"],"mappings":"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"}
@@ -3,13 +3,13 @@
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var React = require('react');
6
- var overflowUtils = require('./overflowUtils.js');
7
- var useDynamicCollapse = require('./useDynamicCollapse.js');
8
6
  var useInstantCollapse = require('./useInstantCollapse.js');
9
- var useOverflow = require('./useOverflow.js');
7
+ var useDynamicCollapse = require('./useDynamicCollapse.js');
10
8
  var useReclaimSpace = require('./useReclaimSpace.js');
11
9
  var useResizeObserver = require('./useResizeObserver.js');
10
+ var useOverflow = require('./useOverflow.js');
12
11
  require('@salt-ds/core');
12
+ var overflowUtils = require('./overflowUtils.js');
13
13
 
14
14
  const MONITORED_DIMENSIONS = {
15
15
  horizontal: ["width", "scrollHeight"],
@@ -1 +1 @@
1
- {"version":3,"file":"useOverflowLayout.js","sources":["../src/responsive/useOverflowLayout.ts"],"sourcesContent":["import { useCallback, useEffect, useRef } from \"react\";\nimport {\n ElementRef,\n ManagedListRef,\n OverflowItem,\n OverflowLayoutHookProps,\n} from \"./overflowTypes\";\n\nimport { getIsOverflowed, measureContainerOverflow } from \"./overflowUtils\";\nimport { useDynamicCollapse } from \"./useDynamicCollapse\";\nimport { useInstantCollapse } from \"./useInstantCollapse\";\nimport { useOverflow } from \"./useOverflow\";\nimport { useReclaimSpace } from \"./useReclaimSpace\";\nimport { ResizeHandler, useResizeObserver } from \"../responsive\";\n\nconst MONITORED_DIMENSIONS: { [key: string]: string[] } = {\n horizontal: [\"width\", \"scrollHeight\"],\n vertical: [\"height\", \"scrollWidth\"],\n none: [],\n};\n\ntype overflowUpdate = (item1: OverflowItem, item2: OverflowItem) => void;\n\n// we need id, just to be able to assign id to overflowIndicator in useOverflow\nexport const useOverflowLayout = ({\n collectionHook,\n id,\n orientation,\n label = \"Toolbar\",\n disableOverflow = false,\n}: OverflowLayoutHookProps): [ElementRef, overflowUpdate] => {\n const overflowContainerRef: ElementRef = useRef(null);\n const overflowItemsRef: ManagedListRef = useRef([]);\n const measurement = useRef({ innerContainerSize: 0, rootContainerDepth: 0 });\n const { innerContainerSize } = measurement.current;\n\n const { dispatch, version: collectionVersion } = collectionHook;\n overflowItemsRef.current = collectionHook.data;\n\n const {\n onResize: onOverflowResize,\n resetMeasurements: resetOverflowMeasurements,\n } = useOverflow({\n collectionHook,\n id,\n label,\n overflowItemsRef,\n orientation,\n overflowContainerRef,\n });\n\n const hasOverflowedItems = getIsOverflowed(collectionHook.data);\n // const hasOverflowedItems = getIsOverflowed(managedItems);\n\n const {\n onResize: onDynamicResize,\n resetMeasurements: resetDynamicMeasurements,\n } = useDynamicCollapse({\n collectionHook,\n innerContainerSize,\n label,\n overflowItemsRef,\n orientation,\n overflowContainerRef,\n });\n\n const {\n onResize: onInstantResize,\n resetMeasurements: resetInstantMeasurements,\n } = useInstantCollapse({\n collectionHook,\n hasOverflowedItems,\n innerContainerSize,\n label,\n overflowItemsRef,\n orientation,\n overflowContainerRef,\n });\n\n const { onResize: onReclaimResize } = useReclaimSpace({\n collectionHook,\n label,\n overflowItemsRef,\n orientation,\n overflowContainerRef,\n });\n\n const resizeHandler: ResizeHandler = useCallback(\n ({\n scrollHeight,\n height = scrollHeight,\n scrollWidth,\n width = scrollWidth,\n }) => {\n const size = orientation === \"horizontal\" ? width : height;\n if (typeof size === \"number\") {\n const { innerContainerSize } = measurement.current;\n const sizeDiff = size - innerContainerSize;\n // Tiny size diffs seem to be down to the relative sub-pixel innaccuracy of\n // ResizeObserver vs getBoundingClientRect\n if (Math.abs(sizeDiff) > 0.5) {\n measurement.current.innerContainerSize = size;\n const containerHasGrown = size > innerContainerSize;\n // Note: any one of these hooks may trigger a render which\n // may affect the overflow state that the next hook sees.\n // Hence, they all test for overflow internally and independently.\n onDynamicResize(size, containerHasGrown);\n onInstantResize(size, containerHasGrown);\n onOverflowResize(size, containerHasGrown);\n onReclaimResize(size, containerHasGrown);\n }\n }\n },\n [\n onDynamicResize,\n onInstantResize,\n onOverflowResize,\n onReclaimResize,\n orientation,\n ]\n );\n\n const measureAndInitialize = useCallback(() => {\n const { isOverflowing, ...contentWidthAndDepth } = measureContainerOverflow(\n overflowContainerRef,\n orientation\n );\n\n measurement.current = contentWidthAndDepth;\n const { innerContainerSize } = contentWidthAndDepth;\n // TODO check this with complex combinations\n let handled = resetInstantMeasurements(isOverflowing);\n if (!handled) {\n handled = resetDynamicMeasurements();\n if (!handled) {\n resetOverflowMeasurements?.(isOverflowing, innerContainerSize);\n }\n }\n }, [\n orientation,\n resetInstantMeasurements,\n resetDynamicMeasurements,\n resetOverflowMeasurements,\n ]);\n\n const switchPriorities = useCallback(\n (item1: OverflowItem, item2: OverflowItem) => {\n const { priority: priority1 } = item1;\n const { priority: priority2 } = item2;\n if (priority1 !== priority2) {\n dispatch({\n type: \"update-items\",\n overflowItems: [\n { id: item1.id, priority: priority2 },\n { id: item2.id, priority: priority1 },\n ],\n });\n // Why do we need a timeout here when we don't inside resizeHandler ?\n setTimeout(measureAndInitialize, 0);\n }\n },\n [dispatch, measureAndInitialize]\n );\n\n // Important that we register our resize handler before we measure and\n // initialize. The initialization may trigger changes which we want the\n // resize observer to detect (when we have nested overflowables).\n useResizeObserver(\n overflowContainerRef,\n MONITORED_DIMENSIONS[disableOverflow ? \"none\" : orientation],\n resizeHandler\n );\n\n // This hook runs after a measurememnt cycle, not after every single change to\n // collection data. The version attribute has been introduced specifically for this.\n useEffect(() => {\n if (!disableOverflow) {\n measureAndInitialize();\n }\n }, [collectionVersion, disableOverflow, measureAndInitialize]);\n\n return [overflowContainerRef, switchPriorities];\n};\n"],"names":["useRef","useOverflow","getIsOverflowed","useDynamicCollapse","useInstantCollapse","useReclaimSpace","useCallback","innerContainerSize","measureContainerOverflow","useResizeObserver","useEffect"],"mappings":"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"}
1
+ {"version":3,"file":"useOverflowLayout.js","sources":["../src/responsive/useOverflowLayout.ts"],"sourcesContent":["import { useCallback, useEffect, useRef } from \"react\";\nimport type {\n ElementRef,\n ManagedListRef,\n OverflowItem,\n OverflowLayoutHookProps,\n} from \"./overflowTypes\";\n\nimport { type ResizeHandler, useResizeObserver } from \"../responsive\";\nimport { getIsOverflowed, measureContainerOverflow } from \"./overflowUtils\";\nimport { useDynamicCollapse } from \"./useDynamicCollapse\";\nimport { useInstantCollapse } from \"./useInstantCollapse\";\nimport { useOverflow } from \"./useOverflow\";\nimport { useReclaimSpace } from \"./useReclaimSpace\";\n\nconst MONITORED_DIMENSIONS: { [key: string]: string[] } = {\n horizontal: [\"width\", \"scrollHeight\"],\n vertical: [\"height\", \"scrollWidth\"],\n none: [],\n};\n\ntype overflowUpdate = (item1: OverflowItem, item2: OverflowItem) => void;\n\n// we need id, just to be able to assign id to overflowIndicator in useOverflow\nexport const useOverflowLayout = ({\n collectionHook,\n id,\n orientation,\n label = \"Toolbar\",\n disableOverflow = false,\n}: OverflowLayoutHookProps): [ElementRef, overflowUpdate] => {\n const overflowContainerRef: ElementRef = useRef(null);\n const overflowItemsRef: ManagedListRef = useRef([]);\n const measurement = useRef({ innerContainerSize: 0, rootContainerDepth: 0 });\n const { innerContainerSize } = measurement.current;\n\n const { dispatch, version: collectionVersion } = collectionHook;\n overflowItemsRef.current = collectionHook.data;\n\n const {\n onResize: onOverflowResize,\n resetMeasurements: resetOverflowMeasurements,\n } = useOverflow({\n collectionHook,\n id,\n label,\n overflowItemsRef,\n orientation,\n overflowContainerRef,\n });\n\n const hasOverflowedItems = getIsOverflowed(collectionHook.data);\n // const hasOverflowedItems = getIsOverflowed(managedItems);\n\n const {\n onResize: onDynamicResize,\n resetMeasurements: resetDynamicMeasurements,\n } = useDynamicCollapse({\n collectionHook,\n innerContainerSize,\n label,\n overflowItemsRef,\n orientation,\n overflowContainerRef,\n });\n\n const {\n onResize: onInstantResize,\n resetMeasurements: resetInstantMeasurements,\n } = useInstantCollapse({\n collectionHook,\n hasOverflowedItems,\n innerContainerSize,\n label,\n overflowItemsRef,\n orientation,\n overflowContainerRef,\n });\n\n const { onResize: onReclaimResize } = useReclaimSpace({\n collectionHook,\n label,\n overflowItemsRef,\n orientation,\n overflowContainerRef,\n });\n\n const resizeHandler: ResizeHandler = useCallback(\n ({\n scrollHeight,\n height = scrollHeight,\n scrollWidth,\n width = scrollWidth,\n }) => {\n const size = orientation === \"horizontal\" ? width : height;\n if (typeof size === \"number\") {\n const { innerContainerSize } = measurement.current;\n const sizeDiff = size - innerContainerSize;\n // Tiny size diffs seem to be down to the relative sub-pixel innaccuracy of\n // ResizeObserver vs getBoundingClientRect\n if (Math.abs(sizeDiff) > 0.5) {\n measurement.current.innerContainerSize = size;\n const containerHasGrown = size > innerContainerSize;\n // Note: any one of these hooks may trigger a render which\n // may affect the overflow state that the next hook sees.\n // Hence, they all test for overflow internally and independently.\n onDynamicResize(size, containerHasGrown);\n onInstantResize(size, containerHasGrown);\n onOverflowResize(size, containerHasGrown);\n onReclaimResize(size, containerHasGrown);\n }\n }\n },\n [\n onDynamicResize,\n onInstantResize,\n onOverflowResize,\n onReclaimResize,\n orientation,\n ],\n );\n\n const measureAndInitialize = useCallback(() => {\n const { isOverflowing, ...contentWidthAndDepth } = measureContainerOverflow(\n overflowContainerRef,\n orientation,\n );\n\n measurement.current = contentWidthAndDepth;\n const { innerContainerSize } = contentWidthAndDepth;\n // TODO check this with complex combinations\n let handled = resetInstantMeasurements(isOverflowing);\n if (!handled) {\n handled = resetDynamicMeasurements();\n if (!handled) {\n resetOverflowMeasurements?.(isOverflowing, innerContainerSize);\n }\n }\n }, [\n orientation,\n resetInstantMeasurements,\n resetDynamicMeasurements,\n resetOverflowMeasurements,\n ]);\n\n const switchPriorities = useCallback(\n (item1: OverflowItem, item2: OverflowItem) => {\n const { priority: priority1 } = item1;\n const { priority: priority2 } = item2;\n if (priority1 !== priority2) {\n dispatch({\n type: \"update-items\",\n overflowItems: [\n { id: item1.id, priority: priority2 },\n { id: item2.id, priority: priority1 },\n ],\n });\n // Why do we need a timeout here when we don't inside resizeHandler ?\n setTimeout(measureAndInitialize, 0);\n }\n },\n [dispatch, measureAndInitialize],\n );\n\n // Important that we register our resize handler before we measure and\n // initialize. The initialization may trigger changes which we want the\n // resize observer to detect (when we have nested overflowables).\n useResizeObserver(\n overflowContainerRef,\n MONITORED_DIMENSIONS[disableOverflow ? \"none\" : orientation],\n resizeHandler,\n );\n\n // This hook runs after a measurememnt cycle, not after every single change to\n // collection data. The version attribute has been introduced specifically for this.\n useEffect(() => {\n if (!disableOverflow) {\n measureAndInitialize();\n }\n }, [collectionVersion, disableOverflow, measureAndInitialize]);\n\n return [overflowContainerRef, switchPriorities];\n};\n"],"names":["useRef","useOverflow","getIsOverflowed","useDynamicCollapse","useInstantCollapse","useReclaimSpace","useCallback","innerContainerSize","measureContainerOverflow","useResizeObserver","useEffect"],"mappings":";;;;;;;;;;;;;AAeA,MAAM,oBAAoD,GAAA;AAAA,EACxD,UAAA,EAAY,CAAC,OAAA,EAAS,cAAc,CAAA;AAAA,EACpC,QAAA,EAAU,CAAC,QAAA,EAAU,aAAa,CAAA;AAAA,EAClC,MAAM,EAAC;AACT,CAAA,CAAA;AAKO,MAAM,oBAAoB,CAAC;AAAA,EAChC,cAAA;AAAA,EACA,EAAA;AAAA,EACA,WAAA;AAAA,EACA,KAAQ,GAAA,SAAA;AAAA,EACR,eAAkB,GAAA,KAAA;AACpB,CAA6D,KAAA;AAC3D,EAAM,MAAA,oBAAA,GAAmCA,aAAO,IAAI,CAAA,CAAA;AACpD,EAAM,MAAA,gBAAA,GAAmCA,YAAO,CAAA,EAAE,CAAA,CAAA;AAClD,EAAA,MAAM,cAAcA,YAAO,CAAA,EAAE,oBAAoB,CAAG,EAAA,kBAAA,EAAoB,GAAG,CAAA,CAAA;AAC3E,EAAM,MAAA,EAAE,kBAAmB,EAAA,GAAI,WAAY,CAAA,OAAA,CAAA;AAE3C,EAAA,MAAM,EAAE,QAAA,EAAU,OAAS,EAAA,iBAAA,EAAsB,GAAA,cAAA,CAAA;AACjD,EAAA,gBAAA,CAAiB,UAAU,cAAe,CAAA,IAAA,CAAA;AAE1C,EAAM,MAAA;AAAA,IACJ,QAAU,EAAA,gBAAA;AAAA,IACV,iBAAmB,EAAA,yBAAA;AAAA,MACjBC,uBAAY,CAAA;AAAA,IACd,cAAA;AAAA,IACA,EAAA;AAAA,IACA,KAAA;AAAA,IACA,gBAAA;AAAA,IACA,WAAA;AAAA,IACA,oBAAA;AAAA,GACD,CAAA,CAAA;AAED,EAAM,MAAA,kBAAA,GAAqBC,6BAAgB,CAAA,cAAA,CAAe,IAAI,CAAA,CAAA;AAG9D,EAAM,MAAA;AAAA,IACJ,QAAU,EAAA,eAAA;AAAA,IACV,iBAAmB,EAAA,wBAAA;AAAA,MACjBC,qCAAmB,CAAA;AAAA,IACrB,cAAA;AAAA,IACA,kBAAA;AAAA,IACA,KAAA;AAAA,IACA,gBAAA;AAAA,IACA,WAAA;AAAA,IACA,oBAAA;AAAA,GACD,CAAA,CAAA;AAED,EAAM,MAAA;AAAA,IACJ,QAAU,EAAA,eAAA;AAAA,IACV,iBAAmB,EAAA,wBAAA;AAAA,MACjBC,qCAAmB,CAAA;AAAA,IACrB,cAAA;AAAA,IACA,kBAAA;AAAA,IACA,kBAAA;AAAA,IACA,KAAA;AAAA,IACA,gBAAA;AAAA,IACA,WAAA;AAAA,IACA,oBAAA;AAAA,GACD,CAAA,CAAA;AAED,EAAA,MAAM,EAAE,QAAA,EAAU,eAAgB,EAAA,GAAIC,+BAAgB,CAAA;AAAA,IACpD,cAAA;AAAA,IACA,KAAA;AAAA,IACA,gBAAA;AAAA,IACA,WAAA;AAAA,IACA,oBAAA;AAAA,GACD,CAAA,CAAA;AAED,EAAA,MAAM,aAA+B,GAAAC,iBAAA;AAAA,IACnC,CAAC;AAAA,MACC,YAAA;AAAA,MACA,MAAS,GAAA,YAAA;AAAA,MACT,WAAA;AAAA,MACA,KAAQ,GAAA,WAAA;AAAA,KACJ,KAAA;AACJ,MAAM,MAAA,IAAA,GAAO,WAAgB,KAAA,YAAA,GAAe,KAAQ,GAAA,MAAA,CAAA;AACpD,MAAI,IAAA,OAAO,SAAS,QAAU,EAAA;AAC5B,QAAA,MAAM,EAAE,kBAAA,EAAAC,mBAAmB,EAAA,GAAI,WAAY,CAAA,OAAA,CAAA;AAC3C,QAAA,MAAM,WAAW,IAAOA,GAAAA,mBAAAA,CAAAA;AAGxB,QAAA,IAAI,IAAK,CAAA,GAAA,CAAI,QAAQ,CAAA,GAAI,GAAK,EAAA;AAC5B,UAAA,WAAA,CAAY,QAAQ,kBAAqB,GAAA,IAAA,CAAA;AACzC,UAAA,MAAM,oBAAoB,IAAOA,GAAAA,mBAAAA,CAAAA;AAIjC,UAAA,eAAA,CAAgB,MAAM,iBAAiB,CAAA,CAAA;AACvC,UAAA,eAAA,CAAgB,MAAM,iBAAiB,CAAA,CAAA;AACvC,UAAA,gBAAA,CAAiB,MAAM,iBAAiB,CAAA,CAAA;AACxC,UAAA,eAAA,CAAgB,MAAM,iBAAiB,CAAA,CAAA;AAAA,SACzC;AAAA,OACF;AAAA,KACF;AAAA,IACA;AAAA,MACE,eAAA;AAAA,MACA,eAAA;AAAA,MACA,gBAAA;AAAA,MACA,eAAA;AAAA,MACA,WAAA;AAAA,KACF;AAAA,GACF,CAAA;AAEA,EAAM,MAAA,oBAAA,GAAuBD,kBAAY,MAAM;AAC7C,IAAM,MAAA,EAAE,aAAkB,EAAA,GAAA,oBAAA,EAAyB,GAAAE,sCAAA;AAAA,MACjD,oBAAA;AAAA,MACA,WAAA;AAAA,KACF,CAAA;AAEA,IAAA,WAAA,CAAY,OAAU,GAAA,oBAAA,CAAA;AACtB,IAAM,MAAA,EAAE,kBAAAD,EAAAA,mBAAAA,EAAuB,GAAA,oBAAA,CAAA;AAE/B,IAAI,IAAA,OAAA,GAAU,yBAAyB,aAAa,CAAA,CAAA;AACpD,IAAA,IAAI,CAAC,OAAS,EAAA;AACZ,MAAA,OAAA,GAAU,wBAAyB,EAAA,CAAA;AACnC,MAAA,IAAI,CAAC,OAAS,EAAA;AACZ,QAAA,yBAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,yBAAA,CAA4B,aAAeA,EAAAA,mBAAAA,CAAAA,CAAAA;AAAA,OAC7C;AAAA,KACF;AAAA,GACC,EAAA;AAAA,IACD,WAAA;AAAA,IACA,wBAAA;AAAA,IACA,wBAAA;AAAA,IACA,yBAAA;AAAA,GACD,CAAA,CAAA;AAED,EAAA,MAAM,gBAAmB,GAAAD,iBAAA;AAAA,IACvB,CAAC,OAAqB,KAAwB,KAAA;AAC5C,MAAM,MAAA,EAAE,QAAU,EAAA,SAAA,EAAc,GAAA,KAAA,CAAA;AAChC,MAAM,MAAA,EAAE,QAAU,EAAA,SAAA,EAAc,GAAA,KAAA,CAAA;AAChC,MAAA,IAAI,cAAc,SAAW,EAAA;AAC3B,QAAS,QAAA,CAAA;AAAA,UACP,IAAM,EAAA,cAAA;AAAA,UACN,aAAe,EAAA;AAAA,YACb,EAAE,EAAA,EAAI,KAAM,CAAA,EAAA,EAAI,UAAU,SAAU,EAAA;AAAA,YACpC,EAAE,EAAA,EAAI,KAAM,CAAA,EAAA,EAAI,UAAU,SAAU,EAAA;AAAA,WACtC;AAAA,SACD,CAAA,CAAA;AAED,QAAA,UAAA,CAAW,sBAAsB,CAAC,CAAA,CAAA;AAAA,OACpC;AAAA,KACF;AAAA,IACA,CAAC,UAAU,oBAAoB,CAAA;AAAA,GACjC,CAAA;AAKA,EAAAG,mCAAA;AAAA,IACE,oBAAA;AAAA,IACA,oBAAA,CAAqB,kBAAkB,MAAS,GAAA,WAAA,CAAA;AAAA,IAChD,aAAA;AAAA,GACF,CAAA;AAIA,EAAAC,eAAA,CAAU,MAAM;AACd,IAAA,IAAI,CAAC,eAAiB,EAAA;AACpB,MAAqB,oBAAA,EAAA,CAAA;AAAA,KACvB;AAAA,GACC,EAAA,CAAC,iBAAmB,EAAA,eAAA,EAAiB,oBAAoB,CAAC,CAAA,CAAA;AAE7D,EAAO,OAAA,CAAC,sBAAsB,gBAAgB,CAAA,CAAA;AAChD;;;;"}
@@ -21,11 +21,12 @@ const findNextOverflowedItem = (items) => {
21
21
  };
22
22
  const addAllVisible = (sum, m) => sum + (m.overflowed ? 0 : m.size);
23
23
  const canReleaseReclaimedSpace = (size, items) => {
24
+ var _a;
24
25
  const claimant = items.find(hasReclaimedSpace);
25
26
  const overflowedItem = findNextOverflowedItem(items);
26
27
  if (claimant && overflowedItem) {
27
28
  const renderedSize = items.reduce(addAllVisible, 0);
28
- const { size: indicatorSize } = overflowUtils.getOverflowIndicator(items);
29
+ const { size: indicatorSize } = (_a = overflowUtils.getOverflowIndicator(items)) != null ? _a : { size: 0 };
29
30
  const { size: overflowedSize } = overflowedItem;
30
31
  const reclaimableSpace = getReclaimableSpace(claimant);
31
32
  const renderedSizeAfterReclaim = renderedSize - reclaimableSpace - indicatorSize;
@@ -43,23 +44,6 @@ const useReclaimSpace = ({
43
44
  overflowContainerRef: ref,
44
45
  orientation
45
46
  }) => {
46
- React.useCallback(
47
- (visibleContentSize, containerSize) => {
48
- let newlyOverflowedItems = [];
49
- const { current: managedItems } = managedItemsRef;
50
- const visibleItems = managedItems.slice();
51
- while (visibleContentSize > containerSize) {
52
- const overflowedItem = overflowUtils.popNextItemByPriority(visibleItems);
53
- if (overflowedItem === null) {
54
- break;
55
- }
56
- visibleContentSize -= overflowedItem.size;
57
- newlyOverflowedItems.push(overflowedItem);
58
- }
59
- return newlyOverflowedItems;
60
- },
61
- []
62
- );
63
47
  const releaseReclaimedSpace = React.useCallback(() => {
64
48
  const { current: managedItems } = managedItemsRef;
65
49
  const claimant = managedItems.find(hasReclaimedSpace);
@@ -76,7 +60,7 @@ const useReclaimSpace = ({
76
60
  }
77
61
  });
78
62
  }
79
- }, []);
63
+ }, [managedItemsRef, collectionHook.dispatch]);
80
64
  const handleResize = React.useCallback(
81
65
  (size, containerHasGrown) => {
82
66
  const { isOverflowing: willOverflow } = overflowUtils.measureContainerOverflow(
@@ -103,7 +87,13 @@ const useReclaimSpace = ({
103
87
  }
104
88
  }
105
89
  },
106
- []
90
+ [
91
+ ref,
92
+ managedItemsRef,
93
+ releaseReclaimedSpace,
94
+ collectionHook.dispatch,
95
+ orientation
96
+ ]
107
97
  );
108
98
  return {
109
99
  onResize: handleResize
@@ -1 +1 @@
1
- {"version":3,"file":"useReclaimSpace.js","sources":["../src/responsive/useReclaimSpace.ts"],"sourcesContent":["import { useCallback } from \"react\";\nimport {\n OverflowItem,\n OverflowHookProps,\n OverflowHookResult,\n} from \"./overflowTypes\";\n\nimport {\n getOverflowIndicator,\n measureContainerOverflow,\n popNextItemByPriority,\n} from \"./overflowUtils\";\n\nconst getPriority = (item: OverflowItem) => item.priority;\n\nconst canReclaimSpace = (item: OverflowItem) =>\n item.collapsed && item.reclaimSpace;\n\nconst hasReclaimedSpace = (item: OverflowItem) => item.reclaimedSpace;\nconst getReclaimableSpace = ({ size, minSize = 0 }: OverflowItem) =>\n size - minSize;\n\nconst findNextOverflowedItem = (items: OverflowItem[]) => {\n const overflowedItems = items.filter((item) => item.overflowed);\n const minPriority = Math.min(...overflowedItems.map(getPriority));\n for (let i = 0; i < overflowedItems.length; i++) {\n if (overflowedItems[i].priority === minPriority) {\n return overflowedItems[i];\n }\n }\n return null;\n};\n\nexport const addAllVisible = (sum: number, m: OverflowItem) =>\n sum + (m.overflowed ? 0 : m.size);\n\nconst canReleaseReclaimedSpace = (size: number, items: OverflowItem[]) => {\n const claimant = items.find(hasReclaimedSpace);\n const overflowedItem = findNextOverflowedItem(items);\n if (claimant && overflowedItem) {\n const renderedSize = items.reduce(addAllVisible, 0);\n const { size: indicatorSize } = getOverflowIndicator(items)!;\n const { size: overflowedSize } = overflowedItem;\n // TODO we can discount the indicator size ONLY IF overflowed item is only overflowed item\n const reclaimableSpace = getReclaimableSpace(claimant);\n const renderedSizeAfterReclaim =\n renderedSize - reclaimableSpace - indicatorSize;\n const maxAvailableSpace = size - renderedSizeAfterReclaim;\n if (maxAvailableSpace >= overflowedSize) {\n return true;\n }\n }\n};\n\nconst mightBeAbleToReclaimSpace = (items: OverflowItem[]) =>\n items.some(canReclaimSpace);\n\n// We need to release the reclaimed space (i.e take it back from the collapsed item and re-assign it\n// as available space) when container grows and space now allows overflowed item to be 'un-wrapped'\n\nexport const useReclaimSpace = ({\n collectionHook,\n label = \"Toolbar\",\n overflowItemsRef: managedItemsRef,\n overflowContainerRef: ref,\n orientation,\n}: OverflowHookProps): OverflowHookResult => {\n const getAllOverflowedItems = useCallback(\n (visibleContentSize: number, containerSize: number) => {\n let newlyOverflowedItems = [];\n const { current: managedItems } = managedItemsRef;\n const visibleItems = managedItems.slice();\n while (visibleContentSize > containerSize) {\n const overflowedItem = popNextItemByPriority(visibleItems);\n if (overflowedItem === null) {\n break;\n }\n // eslint-disable-next-line no-param-reassign\n visibleContentSize -= overflowedItem.size;\n newlyOverflowedItems.push(overflowedItem);\n }\n return newlyOverflowedItems;\n },\n []\n );\n\n const releaseReclaimedSpace = useCallback(() => {\n const { current: managedItems } = managedItemsRef;\n\n const claimant = managedItems.find(hasReclaimedSpace);\n if (claimant) {\n // Might not always need to collapse, if there is enough available space for it to still be collapsing\n // collapse the claimant and turn off recvlaimed\n collectionHook.dispatch({\n type: \"replace-item\",\n overflowItem: {\n ...claimant,\n collapsed: true,\n collapsing: false,\n reclaimedSpace: undefined,\n size: claimant.minSize as number,\n fullSize: claimant.size,\n },\n });\n }\n }, []);\n const handleResize = useCallback(\n (size: number, containerHasGrown?: boolean) => {\n const { isOverflowing: willOverflow } = measureContainerOverflow(\n ref,\n orientation\n );\n const { current: managedItems } = managedItemsRef;\n\n if (containerHasGrown && canReleaseReclaimedSpace(size, managedItems)) {\n releaseReclaimedSpace();\n } else if (\n !containerHasGrown &&\n willOverflow &&\n mightBeAbleToReclaimSpace(managedItems)\n ) {\n const collapsedChild = managedItems.find(canReclaimSpace);\n if (collapsedChild) {\n collectionHook.dispatch({\n type: \"replace-item\",\n overflowItem: {\n ...collapsedChild,\n collapsed: false,\n collapsing: true,\n reclaimedSpace: true,\n size: collapsedChild.fullSize as number,\n fullSize: null,\n },\n });\n }\n }\n },\n []\n );\n\n return {\n onResize: handleResize,\n };\n};\n"],"names":["getOverflowIndicator","useCallback","popNextItemByPriority","measureContainerOverflow"],"mappings":"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"}
1
+ {"version":3,"file":"useReclaimSpace.js","sources":["../src/responsive/useReclaimSpace.ts"],"sourcesContent":["import { useCallback } from \"react\";\nimport type {\n OverflowHookProps,\n OverflowHookResult,\n OverflowItem,\n} from \"./overflowTypes\";\n\nimport {\n getOverflowIndicator,\n measureContainerOverflow,\n} from \"./overflowUtils\";\n\nconst getPriority = (item: OverflowItem) => item.priority;\n\nconst canReclaimSpace = (item: OverflowItem) =>\n item.collapsed && item.reclaimSpace;\n\nconst hasReclaimedSpace = (item: OverflowItem) => item.reclaimedSpace;\nconst getReclaimableSpace = ({ size, minSize = 0 }: OverflowItem) =>\n size - minSize;\n\nconst findNextOverflowedItem = (items: OverflowItem[]) => {\n const overflowedItems = items.filter((item) => item.overflowed);\n const minPriority = Math.min(...overflowedItems.map(getPriority));\n for (let i = 0; i < overflowedItems.length; i++) {\n if (overflowedItems[i].priority === minPriority) {\n return overflowedItems[i];\n }\n }\n return null;\n};\n\nexport const addAllVisible = (sum: number, m: OverflowItem) =>\n sum + (m.overflowed ? 0 : m.size);\n\nconst canReleaseReclaimedSpace = (size: number, items: OverflowItem[]) => {\n const claimant = items.find(hasReclaimedSpace);\n const overflowedItem = findNextOverflowedItem(items);\n if (claimant && overflowedItem) {\n const renderedSize = items.reduce(addAllVisible, 0);\n const { size: indicatorSize } = getOverflowIndicator(items) ?? { size: 0 };\n const { size: overflowedSize } = overflowedItem;\n // TODO we can discount the indicator size ONLY IF overflowed item is only overflowed item\n const reclaimableSpace = getReclaimableSpace(claimant);\n const renderedSizeAfterReclaim =\n renderedSize - reclaimableSpace - indicatorSize;\n const maxAvailableSpace = size - renderedSizeAfterReclaim;\n if (maxAvailableSpace >= overflowedSize) {\n return true;\n }\n }\n};\n\nconst mightBeAbleToReclaimSpace = (items: OverflowItem[]) =>\n items.some(canReclaimSpace);\n\n// We need to release the reclaimed space (i.e take it back from the collapsed item and re-assign it\n// as available space) when container grows and space now allows overflowed item to be 'un-wrapped'\n\nexport const useReclaimSpace = ({\n collectionHook,\n label = \"Toolbar\",\n overflowItemsRef: managedItemsRef,\n overflowContainerRef: ref,\n orientation,\n}: OverflowHookProps): OverflowHookResult => {\n const releaseReclaimedSpace = useCallback(() => {\n const { current: managedItems } = managedItemsRef;\n\n const claimant = managedItems.find(hasReclaimedSpace);\n if (claimant) {\n // Might not always need to collapse, if there is enough available space for it to still be collapsing then\n // collapse the claimant and turn off reclaimed\n collectionHook.dispatch({\n type: \"replace-item\",\n overflowItem: {\n ...claimant,\n collapsed: true,\n collapsing: false,\n reclaimedSpace: undefined,\n size: claimant.minSize as number,\n fullSize: claimant.size,\n },\n });\n }\n }, [managedItemsRef, collectionHook.dispatch]);\n\n const handleResize = useCallback(\n (size: number, containerHasGrown?: boolean) => {\n const { isOverflowing: willOverflow } = measureContainerOverflow(\n ref,\n orientation,\n );\n const { current: managedItems } = managedItemsRef;\n\n if (containerHasGrown && canReleaseReclaimedSpace(size, managedItems)) {\n releaseReclaimedSpace();\n } else if (\n !containerHasGrown &&\n willOverflow &&\n mightBeAbleToReclaimSpace(managedItems)\n ) {\n const collapsedChild = managedItems.find(canReclaimSpace);\n if (collapsedChild) {\n collectionHook.dispatch({\n type: \"replace-item\",\n overflowItem: {\n ...collapsedChild,\n collapsed: false,\n collapsing: true,\n reclaimedSpace: true,\n size: collapsedChild.fullSize as number,\n fullSize: null,\n },\n });\n }\n }\n },\n [\n ref,\n managedItemsRef,\n releaseReclaimedSpace,\n collectionHook.dispatch,\n orientation,\n ],\n );\n\n return {\n onResize: handleResize,\n };\n};\n"],"names":["getOverflowIndicator","useCallback","measureContainerOverflow"],"mappings":"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"}
@@ -42,7 +42,7 @@ const resizeObserver = typeof ResizeObserver !== "undefined" ? new ResizeObserve
42
42
  }
43
43
  }
44
44
  if (sizeChanged) {
45
- onResize && onResize(measurements);
45
+ onResize == null ? void 0 : onResize(measurements);
46
46
  }
47
47
  }
48
48
  }
@@ -1 +1 @@
1
- {"version":3,"file":"useResizeObserver.js","sources":["../src/responsive/useResizeObserver.ts"],"sourcesContent":["/* eslint-disable no-restricted-syntax */\nimport { useIsomorphicLayoutEffect } from \"@salt-ds/core\";\nimport { useCallback, useRef, RefObject } from \"react\";\nexport const WidthHeight = [\"height\", \"width\"];\nexport const HeightOnly = [\"height\"];\nexport const WidthOnly = [\"width\"];\n\nexport type measurements<T = string | number> = {\n height?: T;\n scrollHeight?: T;\n scrollWidth?: T;\n width?: T;\n};\ntype measuredDimension = keyof measurements<number>;\n\nexport type ResizeHandler = (measurements: measurements<number>) => void;\n\ntype observedDetails = {\n onResize?: ResizeHandler;\n measurements: measurements<number>;\n};\nconst observedMap = new WeakMap<HTMLElement, observedDetails>();\n\nconst getTargetSize = (\n element: HTMLElement,\n contentRect: DOMRectReadOnly,\n dimension: measuredDimension\n): number => {\n switch (dimension) {\n case \"height\":\n return contentRect.height;\n case \"scrollHeight\":\n return element.scrollHeight;\n case \"scrollWidth\":\n return element.scrollWidth;\n case \"width\":\n return contentRect.width;\n default:\n return 0;\n }\n};\n\nconst resizeObserver =\n typeof ResizeObserver !== \"undefined\"\n ? new ResizeObserver((entries: ResizeObserverEntry[]) => {\n for (const entry of entries) {\n const { target, contentRect } = entry;\n const observedTarget = observedMap.get(target as HTMLElement);\n if (observedTarget) {\n const { onResize, measurements } = observedTarget;\n let sizeChanged = false;\n for (const [dimension, size] of Object.entries(measurements)) {\n const newSize = getTargetSize(\n target as HTMLElement,\n contentRect,\n dimension as measuredDimension\n );\n if (newSize !== size) {\n sizeChanged = true;\n measurements[dimension as measuredDimension] = newSize;\n }\n }\n if (sizeChanged) {\n onResize && onResize(measurements);\n }\n }\n }\n })\n : null;\n\n// TODO use an optional lag (default to false) to ask to fire onResize\n// with initial size\n// Note asking for scrollHeight alone will not trigger onResize, this is only triggered by height,\n// with scrollHeight returned as an auxilliary value\nexport function useResizeObserver(\n ref: RefObject<Element | HTMLElement | null>,\n dimensions: string[],\n onResize: ResizeHandler,\n reportInitialSize = false\n): void {\n const dimensionsRef = useRef(dimensions);\n const measure = useCallback((target: HTMLElement): measurements<number> => {\n const rect = target.getBoundingClientRect();\n return dimensionsRef.current.reduce(\n (map: { [key: string]: number }, dim) => {\n map[dim] = getTargetSize(target, rect, dim as measuredDimension);\n return map;\n },\n {}\n );\n }, []);\n\n // TODO use ref to store resizeHandler here\n // resize handler registered with REsizeObserver will never change\n // use ref to store user onResize callback here\n // resizeHandler will call user callback.current\n\n // Keep this effect separate in case user inadvertently passes different\n // dimensions or callback instance each time - we only ever want to\n // initiate new observation when ref changes.\n useIsomorphicLayoutEffect(() => {\n if (!resizeObserver) {\n return undefined;\n }\n\n const target = ref.current as HTMLElement;\n let cleanedUp = false;\n\n async function registerObserver() {\n // Create the map entry immediately. useEffect may fire below\n // before fonts are ready and attempt to update entry\n observedMap.set(target, { measurements: {} as measurements<number> });\n cleanedUp = false;\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n const { fonts } = document as any;\n if (fonts) {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n await fonts.ready;\n }\n if (!cleanedUp && resizeObserver) {\n const observedTarget = observedMap.get(target);\n if (observedTarget) {\n const measurements = measure(target);\n observedTarget.measurements = measurements;\n resizeObserver.observe(target);\n if (reportInitialSize) {\n onResize(measurements);\n }\n }\n }\n }\n\n if (target) {\n // TODO might we want multiple callers to attach a listener to the same element ?\n if (observedMap.has(target)) {\n throw Error(\n \"useResizeObserver attemping to observe same element twice\"\n );\n }\n void registerObserver();\n }\n return () => {\n if (target && observedMap.has(target)) {\n resizeObserver.unobserve(target);\n observedMap.delete(target);\n cleanedUp = true;\n }\n };\n }, [ref, measure]);\n\n useIsomorphicLayoutEffect(() => {\n const target = ref.current as HTMLElement;\n const record = observedMap.get(target);\n if (record) {\n if (dimensionsRef.current !== dimensions) {\n dimensionsRef.current = dimensions;\n const measurements = measure(target);\n record.measurements = measurements;\n }\n // Might not have changed, but no harm ...\n record.onResize = onResize;\n }\n }, [dimensions, measure, ref, onResize]);\n\n // TODO might be a good idea to ref and return the current measurememnts. That way, derived hooks\n // e.g useBreakpoints don't have to measure and client cn make onResize callback simpler\n}\n"],"names":["useRef","useCallback","useIsomorphicLayoutEffect"],"mappings":";;;;;;;AAGa,MAAA,WAAA,GAAc,CAAC,QAAA,EAAU,OAAO,EAAA;AAChC,MAAA,UAAA,GAAa,CAAC,QAAQ,EAAA;AACtB,MAAA,SAAA,GAAY,CAAC,OAAO,EAAA;AAgBjC,MAAM,WAAA,uBAAkB,OAAsC,EAAA,CAAA;AAE9D,MAAM,aAAgB,GAAA,CACpB,OACA,EAAA,WAAA,EACA,SACW,KAAA;AACX,EAAQ,QAAA,SAAA;AAAA,IACD,KAAA,QAAA;AACH,MAAA,OAAO,WAAY,CAAA,MAAA,CAAA;AAAA,IAChB,KAAA,cAAA;AACH,MAAA,OAAO,OAAQ,CAAA,YAAA,CAAA;AAAA,IACZ,KAAA,aAAA;AACH,MAAA,OAAO,OAAQ,CAAA,WAAA,CAAA;AAAA,IACZ,KAAA,OAAA;AACH,MAAA,OAAO,WAAY,CAAA,KAAA,CAAA;AAAA,IAAA;AAEnB,MAAO,OAAA,CAAA,CAAA;AAAA,GAAA;AAEb,CAAA,CAAA;AAEA,MAAM,iBACJ,OAAO,cAAA,KAAmB,cACtB,IAAI,cAAA,CAAe,CAAC,OAAmC,KAAA;AACrD,EAAA,KAAA,MAAW,SAAS,OAAS,EAAA;AAC3B,IAAM,MAAA,EAAE,MAAQ,EAAA,WAAA,EAAgB,GAAA,KAAA,CAAA;AAChC,IAAM,MAAA,cAAA,GAAiB,WAAY,CAAA,GAAA,CAAI,MAAqB,CAAA,CAAA;AAC5D,IAAA,IAAI,cAAgB,EAAA;AAClB,MAAM,MAAA,EAAE,QAAU,EAAA,YAAA,EAAiB,GAAA,cAAA,CAAA;AACnC,MAAA,IAAI,WAAc,GAAA,KAAA,CAAA;AAClB,MAAA,KAAA,MAAW,CAAC,SAAW,EAAA,IAAI,KAAK,MAAO,CAAA,OAAA,CAAQ,YAAY,CAAG,EAAA;AAC5D,QAAA,MAAM,OAAU,GAAA,aAAA;AAAA,UACd,MAAA;AAAA,UACA,WAAA;AAAA,UACA,SAAA;AAAA,SACF,CAAA;AACA,QAAA,IAAI,YAAY,IAAM,EAAA;AACpB,UAAc,WAAA,GAAA,IAAA,CAAA;AACd,UAAA,YAAA,CAAa,SAAkC,CAAA,GAAA,OAAA,CAAA;AAAA,SACjD;AAAA,OACF;AACA,MAAA,IAAI,WAAa,EAAA;AACf,QAAA,QAAA,IAAY,SAAS,YAAY,CAAA,CAAA;AAAA,OACnC;AAAA,KACF;AAAA,GACF;AACF,CAAC,CACD,GAAA,IAAA,CAAA;AAMC,SAAS,iBACd,CAAA,GAAA,EACA,UACA,EAAA,QAAA,EACA,oBAAoB,KACd,EAAA;AACN,EAAM,MAAA,aAAA,GAAgBA,aAAO,UAAU,CAAA,CAAA;AACvC,EAAM,MAAA,OAAA,GAAUC,iBAAY,CAAA,CAAC,MAA8C,KAAA;AACzE,IAAM,MAAA,IAAA,GAAO,OAAO,qBAAsB,EAAA,CAAA;AAC1C,IAAA,OAAO,cAAc,OAAQ,CAAA,MAAA;AAAA,MAC3B,CAAC,KAAgC,GAAQ,KAAA;AACvC,QAAA,GAAA,CAAI,GAAO,CAAA,GAAA,aAAA,CAAc,MAAQ,EAAA,IAAA,EAAM,GAAwB,CAAA,CAAA;AAC/D,QAAO,OAAA,GAAA,CAAA;AAAA,OACT;AAAA,MACA,EAAC;AAAA,KACH,CAAA;AAAA,GACF,EAAG,EAAE,CAAA,CAAA;AAUL,EAAAC,8BAAA,CAA0B,MAAM;AAC9B,IAAA,IAAI,CAAC,cAAgB,EAAA;AACnB,MAAO,OAAA,KAAA,CAAA,CAAA;AAAA,KACT;AAEA,IAAA,MAAM,SAAS,GAAI,CAAA,OAAA,CAAA;AACnB,IAAA,IAAI,SAAY,GAAA,KAAA,CAAA;AAEhB,IAAA,eAAe,gBAAmB,GAAA;AAGhC,MAAA,WAAA,CAAY,IAAI,MAAQ,EAAA,EAAE,YAAc,EAAA,IAA4B,CAAA,CAAA;AACpE,MAAY,SAAA,GAAA,KAAA,CAAA;AAEZ,MAAM,MAAA,EAAE,OAAU,GAAA,QAAA,CAAA;AAClB,MAAA,IAAI,KAAO,EAAA;AAET,QAAA,MAAM,KAAM,CAAA,KAAA,CAAA;AAAA,OACd;AACA,MAAI,IAAA,CAAC,aAAa,cAAgB,EAAA;AAChC,QAAM,MAAA,cAAA,GAAiB,WAAY,CAAA,GAAA,CAAI,MAAM,CAAA,CAAA;AAC7C,QAAA,IAAI,cAAgB,EAAA;AAClB,UAAM,MAAA,YAAA,GAAe,QAAQ,MAAM,CAAA,CAAA;AACnC,UAAA,cAAA,CAAe,YAAe,GAAA,YAAA,CAAA;AAC9B,UAAA,cAAA,CAAe,QAAQ,MAAM,CAAA,CAAA;AAC7B,UAAA,IAAI,iBAAmB,EAAA;AACrB,YAAA,QAAA,CAAS,YAAY,CAAA,CAAA;AAAA,WACvB;AAAA,SACF;AAAA,OACF;AAAA,KACF;AAEA,IAAA,IAAI,MAAQ,EAAA;AAEV,MAAI,IAAA,WAAA,CAAY,GAAI,CAAA,MAAM,CAAG,EAAA;AAC3B,QAAM,MAAA,KAAA;AAAA,UACJ,2DAAA;AAAA,SACF,CAAA;AAAA,OACF;AACA,MAAA,KAAK,gBAAiB,EAAA,CAAA;AAAA,KACxB;AACA,IAAA,OAAO,MAAM;AACX,MAAA,IAAI,MAAU,IAAA,WAAA,CAAY,GAAI,CAAA,MAAM,CAAG,EAAA;AACrC,QAAA,cAAA,CAAe,UAAU,MAAM,CAAA,CAAA;AAC/B,QAAA,WAAA,CAAY,OAAO,MAAM,CAAA,CAAA;AACzB,QAAY,SAAA,GAAA,IAAA,CAAA;AAAA,OACd;AAAA,KACF,CAAA;AAAA,GACC,EAAA,CAAC,GAAK,EAAA,OAAO,CAAC,CAAA,CAAA;AAEjB,EAAAA,8BAAA,CAA0B,MAAM;AAC9B,IAAA,MAAM,SAAS,GAAI,CAAA,OAAA,CAAA;AACnB,IAAM,MAAA,MAAA,GAAS,WAAY,CAAA,GAAA,CAAI,MAAM,CAAA,CAAA;AACrC,IAAA,IAAI,MAAQ,EAAA;AACV,MAAI,IAAA,aAAA,CAAc,YAAY,UAAY,EAAA;AACxC,QAAA,aAAA,CAAc,OAAU,GAAA,UAAA,CAAA;AACxB,QAAM,MAAA,YAAA,GAAe,QAAQ,MAAM,CAAA,CAAA;AACnC,QAAA,MAAA,CAAO,YAAe,GAAA,YAAA,CAAA;AAAA,OACxB;AAEA,MAAA,MAAA,CAAO,QAAW,GAAA,QAAA,CAAA;AAAA,KACpB;AAAA,KACC,CAAC,UAAA,EAAY,OAAS,EAAA,GAAA,EAAK,QAAQ,CAAC,CAAA,CAAA;AAIzC;;;;;;;"}
1
+ {"version":3,"file":"useResizeObserver.js","sources":["../src/responsive/useResizeObserver.ts"],"sourcesContent":["import { useIsomorphicLayoutEffect } from \"@salt-ds/core\";\nimport { type RefObject, useCallback, useRef } from \"react\";\nexport const WidthHeight = [\"height\", \"width\"];\nexport const HeightOnly = [\"height\"];\nexport const WidthOnly = [\"width\"];\n\nexport type measurements<T = string | number> = {\n height?: T;\n scrollHeight?: T;\n scrollWidth?: T;\n width?: T;\n};\ntype measuredDimension = keyof measurements<number>;\n\nexport type ResizeHandler = (measurements: measurements<number>) => void;\n\ntype observedDetails = {\n onResize?: ResizeHandler;\n measurements: measurements<number>;\n};\nconst observedMap = new WeakMap<HTMLElement, observedDetails>();\n\nconst getTargetSize = (\n element: HTMLElement,\n contentRect: DOMRectReadOnly,\n dimension: measuredDimension,\n): number => {\n switch (dimension) {\n case \"height\":\n return contentRect.height;\n case \"scrollHeight\":\n return element.scrollHeight;\n case \"scrollWidth\":\n return element.scrollWidth;\n case \"width\":\n return contentRect.width;\n default:\n return 0;\n }\n};\n\nconst resizeObserver =\n typeof ResizeObserver !== \"undefined\"\n ? new ResizeObserver((entries: ResizeObserverEntry[]) => {\n for (const entry of entries) {\n const { target, contentRect } = entry;\n const observedTarget = observedMap.get(target as HTMLElement);\n if (observedTarget) {\n const { onResize, measurements } = observedTarget;\n let sizeChanged = false;\n for (const [dimension, size] of Object.entries(measurements)) {\n const newSize = getTargetSize(\n target as HTMLElement,\n contentRect,\n dimension as measuredDimension,\n );\n if (newSize !== size) {\n sizeChanged = true;\n measurements[dimension as measuredDimension] = newSize;\n }\n }\n if (sizeChanged) {\n onResize?.(measurements);\n }\n }\n }\n })\n : null;\n\n// TODO use an optional lag (default to false) to ask to fire onResize\n// with initial size\n// Note asking for scrollHeight alone will not trigger onResize, this is only triggered by height,\n// with scrollHeight returned as an auxilliary value\nexport function useResizeObserver(\n ref: RefObject<Element | HTMLElement | null>,\n dimensions: string[],\n onResize: ResizeHandler,\n reportInitialSize = false,\n): void {\n const dimensionsRef = useRef(dimensions);\n const measure = useCallback((target: HTMLElement): measurements<number> => {\n const rect = target.getBoundingClientRect();\n return dimensionsRef.current.reduce(\n (map: { [key: string]: number }, dim) => {\n map[dim] = getTargetSize(target, rect, dim as measuredDimension);\n return map;\n },\n {},\n );\n }, []);\n\n // TODO use ref to store resizeHandler here\n // resize handler registered with REsizeObserver will never change\n // use ref to store user onResize callback here\n // resizeHandler will call user callback.current\n\n // Keep this effect separate in case user inadvertently passes different\n // dimensions or callback instance each time - we only ever want to\n // initiate new observation when ref changes.\n useIsomorphicLayoutEffect(() => {\n if (!resizeObserver) {\n return undefined;\n }\n\n const target = ref.current as HTMLElement;\n let cleanedUp = false;\n\n async function registerObserver() {\n // Create the map entry immediately. useEffect may fire below\n // before fonts are ready and attempt to update entry\n observedMap.set(target, { measurements: {} as measurements<number> });\n cleanedUp = false;\n\n const { fonts } = document;\n if (fonts) {\n await fonts.ready;\n }\n if (!cleanedUp && resizeObserver) {\n const observedTarget = observedMap.get(target);\n if (observedTarget) {\n const measurements = measure(target);\n observedTarget.measurements = measurements;\n resizeObserver.observe(target);\n if (reportInitialSize) {\n onResize(measurements);\n }\n }\n }\n }\n\n if (target) {\n // TODO might we want multiple callers to attach a listener to the same element ?\n if (observedMap.has(target)) {\n throw Error(\n \"useResizeObserver attemping to observe same element twice\",\n );\n }\n void registerObserver();\n }\n return () => {\n if (target && observedMap.has(target)) {\n resizeObserver.unobserve(target);\n observedMap.delete(target);\n cleanedUp = true;\n }\n };\n }, [ref, measure]);\n\n useIsomorphicLayoutEffect(() => {\n const target = ref.current as HTMLElement;\n const record = observedMap.get(target);\n if (record) {\n if (dimensionsRef.current !== dimensions) {\n dimensionsRef.current = dimensions;\n const measurements = measure(target);\n record.measurements = measurements;\n }\n // Might not have changed, but no harm ...\n record.onResize = onResize;\n }\n }, [dimensions, measure, ref, onResize]);\n\n // TODO might be a good idea to ref and return the current measurememnts. That way, derived hooks\n // e.g useBreakpoints don't have to measure and client cn make onResize callback simpler\n}\n"],"names":["useRef","useCallback","useIsomorphicLayoutEffect"],"mappings":"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"}
@@ -2,8 +2,8 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var React = require('react');
6
5
  var core = require('@salt-ds/core');
6
+ var React = require('react');
7
7
  var useResizeObserver = require('./useResizeObserver.js');
8
8
 
9
9
  const NONE = [];
@@ -20,7 +20,7 @@ function useWidth(responsive) {
20
20
  return void 0;
21
21
  }
22
22
  handleResize(ref.current.getBoundingClientRect());
23
- }, [handleResize, responsive]);
23
+ }, [handleResize]);
24
24
  return [ref, width];
25
25
  }
26
26
 
@@ -1 +1 @@
1
- {"version":3,"file":"useWidth.js","sources":["../src/responsive/useWidth.ts"],"sourcesContent":["import { RefObject, useCallback, useRef, useState } from \"react\";\nimport { useIsomorphicLayoutEffect } from \"@salt-ds/core\";\nimport {\n ResizeHandler,\n useResizeObserver,\n WidthOnly,\n} from \"./useResizeObserver\";\n\nconst NONE: string[] = [];\n\nexport function useWidth<Element extends HTMLElement>(\n responsive: boolean\n): [RefObject<Element>, number] {\n const [width, setWidth] = useState<number>();\n const ref = useRef<HTMLElement>(null);\n\n const handleResize: ResizeHandler = useCallback(({ width: newWidth }) => {\n setWidth(newWidth);\n }, []);\n\n const measurementsToObserve = responsive ? WidthOnly : NONE;\n useResizeObserver(ref, measurementsToObserve, handleResize);\n\n useIsomorphicLayoutEffect(() => {\n if (!ref.current) {\n return undefined;\n }\n handleResize(ref.current.getBoundingClientRect());\n }, [handleResize, responsive]);\n\n return [ref, width] as [RefObject<Element>, number];\n}\n"],"names":["useState","useRef","useCallback","WidthOnly","useResizeObserver","useIsomorphicLayoutEffect"],"mappings":";;;;;;;;AAQA,MAAM,OAAiB,EAAC,CAAA;AAEjB,SAAS,SACd,UAC8B,EAAA;AAC9B,EAAA,MAAM,CAAC,KAAA,EAAO,QAAQ,CAAA,GAAIA,cAAiB,EAAA,CAAA;AAC3C,EAAM,MAAA,GAAA,GAAMC,aAAoB,IAAI,CAAA,CAAA;AAEpC,EAAA,MAAM,eAA8BC,iBAAY,CAAA,CAAC,EAAE,KAAA,EAAO,UAAe,KAAA;AACvE,IAAA,QAAA,CAAS,QAAQ,CAAA,CAAA;AAAA,GACnB,EAAG,EAAE,CAAA,CAAA;AAEL,EAAM,MAAA,qBAAA,GAAwB,aAAaC,2BAAY,GAAA,IAAA,CAAA;AACvD,EAAkBC,mCAAA,CAAA,GAAA,EAAK,uBAAuB,YAAY,CAAA,CAAA;AAE1D,EAAAC,8BAAA,CAA0B,MAAM;AAC9B,IAAI,IAAA,CAAC,IAAI,OAAS,EAAA;AAChB,MAAO,OAAA,KAAA,CAAA,CAAA;AAAA,KACT;AACA,IAAa,YAAA,CAAA,GAAA,CAAI,OAAQ,CAAA,qBAAA,EAAuB,CAAA,CAAA;AAAA,GAC/C,EAAA,CAAC,YAAc,EAAA,UAAU,CAAC,CAAA,CAAA;AAE7B,EAAO,OAAA,CAAC,KAAK,KAAK,CAAA,CAAA;AACpB;;;;"}
1
+ {"version":3,"file":"useWidth.js","sources":["../src/responsive/useWidth.ts"],"sourcesContent":["import { useIsomorphicLayoutEffect } from \"@salt-ds/core\";\nimport { type RefObject, useCallback, useRef, useState } from \"react\";\nimport {\n type ResizeHandler,\n WidthOnly,\n useResizeObserver,\n} from \"./useResizeObserver\";\n\nconst NONE: string[] = [];\n\nexport function useWidth<Element extends HTMLElement>(\n responsive: boolean,\n): [RefObject<Element>, number] {\n const [width, setWidth] = useState<number>();\n const ref = useRef<HTMLElement>(null);\n\n const handleResize: ResizeHandler = useCallback(({ width: newWidth }) => {\n setWidth(newWidth);\n }, []);\n\n const measurementsToObserve = responsive ? WidthOnly : NONE;\n useResizeObserver(ref, measurementsToObserve, handleResize);\n\n useIsomorphicLayoutEffect(() => {\n if (!ref.current) {\n return undefined;\n }\n handleResize(ref.current.getBoundingClientRect());\n }, [handleResize]);\n\n return [ref, width] as [RefObject<Element>, number];\n}\n"],"names":["useState","useRef","useCallback","WidthOnly","useResizeObserver","useIsomorphicLayoutEffect"],"mappings":";;;;;;;;AAQA,MAAM,OAAiB,EAAC,CAAA;AAEjB,SAAS,SACd,UAC8B,EAAA;AAC9B,EAAA,MAAM,CAAC,KAAA,EAAO,QAAQ,CAAA,GAAIA,cAAiB,EAAA,CAAA;AAC3C,EAAM,MAAA,GAAA,GAAMC,aAAoB,IAAI,CAAA,CAAA;AAEpC,EAAA,MAAM,eAA8BC,iBAAY,CAAA,CAAC,EAAE,KAAA,EAAO,UAAe,KAAA;AACvE,IAAA,QAAA,CAAS,QAAQ,CAAA,CAAA;AAAA,GACnB,EAAG,EAAE,CAAA,CAAA;AAEL,EAAM,MAAA,qBAAA,GAAwB,aAAaC,2BAAY,GAAA,IAAA,CAAA;AACvD,EAAkBC,mCAAA,CAAA,GAAA,EAAK,uBAAuB,YAAY,CAAA,CAAA;AAE1D,EAAAC,8BAAA,CAA0B,MAAM;AAC9B,IAAI,IAAA,CAAC,IAAI,OAAS,EAAA;AAChB,MAAO,OAAA,KAAA,CAAA,CAAA;AAAA,KACT;AACA,IAAa,YAAA,CAAA,GAAA,CAAI,OAAQ,CAAA,qBAAA,EAAuB,CAAA,CAAA;AAAA,GAClD,EAAG,CAAC,YAAY,CAAC,CAAA,CAAA;AAEjB,EAAO,OAAA,CAAC,KAAK,KAAK,CAAA,CAAA;AACpB;;;;"}
@@ -38,9 +38,8 @@ const liftResponsivePropsToFormField = (props) => {
38
38
  },
39
39
  [{}, {}]
40
40
  );
41
- } else {
42
- return [{}, props];
43
41
  }
42
+ return [{}, props];
44
43
  };
45
44
 
46
45
  exports.isResponsiveAttribute = isResponsiveAttribute;
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","sources":["../src/responsive/utils.ts"],"sourcesContent":["const COLLAPSIBLE = \"data-collapsible\";\n\nexport type dataPadDirection = \"data-pad-start\" | \"data-pad-end\";\n\nconst RESPONSIVE_ATTRIBUTE: { [key: string]: boolean } = {\n [COLLAPSIBLE]: true,\n \"data-pad-start\": true,\n \"data-pad-end\": true,\n};\n\nexport const isResponsiveAttribute = (propName: string): boolean =>\n RESPONSIVE_ATTRIBUTE[propName] ?? false;\n\nconst isCollapsible = (propName: string) => propName === COLLAPSIBLE;\n\nconst COLLAPSIBLE_VALUE: { [key: string]: string } = {\n dynamic: \"dynamic\",\n instant: \"instant\",\n true: \"instant\",\n};\n\nconst collapsibleValue = (value: string) => COLLAPSIBLE_VALUE[value] ?? \"none\";\n\ntype AnyProps = Record<string, unknown>;\ntype ResponsivePropsTuple = [AnyProps, AnyProps];\n/**\n * data- attributes can be used to manage item overflow behaviour. Users may\n * speficy these attributes directly on a Toolbar component, which ultimately\n * gets wrapped by a FormField. We need to 'lift' these attributes to the form\n * field and remove them from the props of the nested component.\n * @param props\n * @returns\n */\nexport const liftResponsivePropsToFormField = (\n props: AnyProps\n): ResponsivePropsTuple => {\n const propNames = Object.keys(props);\n if (propNames.some(isResponsiveAttribute)) {\n return propNames.reduce<ResponsivePropsTuple>(\n (tuple, propName): ResponsivePropsTuple => {\n const [toolbarProps, rest] = tuple;\n const propValue = props[propName];\n if (isResponsiveAttribute(propName)) {\n const value = isCollapsible(propName)\n ? collapsibleValue(propValue as string)\n : propValue;\n\n toolbarProps[propName] = value;\n rest[propName] = undefined;\n }\n return tuple;\n },\n [{}, {}]\n );\n } else {\n return [{}, props];\n }\n};\n"],"names":[],"mappings":";;;;AAAA,MAAM,WAAc,GAAA,kBAAA,CAAA;AAIpB,MAAM,oBAAmD,GAAA;AAAA,EACvD,CAAC,WAAc,GAAA,IAAA;AAAA,EACf,gBAAkB,EAAA,IAAA;AAAA,EAClB,cAAgB,EAAA,IAAA;AAClB,CAAA,CAAA;AAEa,MAAA,qBAAA,GAAwB,CAAC,QAA2B,KAAA;AAVjE,EAAA,IAAA,EAAA,CAAA;AAWE,EAAA,OAAA,CAAA,EAAA,GAAA,oBAAA,CAAqB,cAArB,IAAkC,GAAA,EAAA,GAAA,KAAA,CAAA;AAAA,EAAA;AAEpC,MAAM,aAAA,GAAgB,CAAC,QAAA,KAAqB,QAAa,KAAA,WAAA,CAAA;AAEzD,MAAM,iBAA+C,GAAA;AAAA,EACnD,OAAS,EAAA,SAAA;AAAA,EACT,OAAS,EAAA,SAAA;AAAA,EACT,IAAM,EAAA,SAAA;AACR,CAAA,CAAA;AAEA,MAAM,gBAAA,GAAmB,CAAC,KAAe,KAAA;AArBzC,EAAA,IAAA,EAAA,CAAA;AAqB4C,EAAA,OAAA,CAAA,EAAA,GAAA,iBAAA,CAAkB,WAAlB,IAA4B,GAAA,EAAA,GAAA,MAAA,CAAA;AAAA,CAAA,CAAA;AAY3D,MAAA,8BAAA,GAAiC,CAC5C,KACyB,KAAA;AACzB,EAAM,MAAA,SAAA,GAAY,MAAO,CAAA,IAAA,CAAK,KAAK,CAAA,CAAA;AACnC,EAAI,IAAA,SAAA,CAAU,IAAK,CAAA,qBAAqB,CAAG,EAAA;AACzC,IAAA,OAAO,SAAU,CAAA,MAAA;AAAA,MACf,CAAC,OAAO,QAAmC,KAAA;AACzC,QAAM,MAAA,CAAC,YAAc,EAAA,IAAI,CAAI,GAAA,KAAA,CAAA;AAC7B,QAAA,MAAM,YAAY,KAAM,CAAA,QAAA,CAAA,CAAA;AACxB,QAAI,IAAA,qBAAA,CAAsB,QAAQ,CAAG,EAAA;AACnC,UAAA,MAAM,QAAQ,aAAc,CAAA,QAAQ,CAChC,GAAA,gBAAA,CAAiB,SAAmB,CACpC,GAAA,SAAA,CAAA;AAEJ,UAAA,YAAA,CAAa,QAAY,CAAA,GAAA,KAAA,CAAA;AACzB,UAAA,IAAA,CAAK,QAAY,CAAA,GAAA,KAAA,CAAA,CAAA;AAAA,SACnB;AACA,QAAO,OAAA,KAAA,CAAA;AAAA,OACT;AAAA,MACA,CAAC,EAAI,EAAA,EAAE,CAAA;AAAA,KACT,CAAA;AAAA,GACK,MAAA;AACL,IAAO,OAAA,CAAC,EAAC,EAAG,KAAK,CAAA,CAAA;AAAA,GACnB;AACF;;;;;"}
1
+ {"version":3,"file":"utils.js","sources":["../src/responsive/utils.ts"],"sourcesContent":["const COLLAPSIBLE = \"data-collapsible\";\n\nexport type dataPadDirection = \"data-pad-start\" | \"data-pad-end\";\n\nconst RESPONSIVE_ATTRIBUTE: { [key: string]: boolean } = {\n [COLLAPSIBLE]: true,\n \"data-pad-start\": true,\n \"data-pad-end\": true,\n};\n\nexport const isResponsiveAttribute = (propName: string): boolean =>\n RESPONSIVE_ATTRIBUTE[propName] ?? false;\n\nconst isCollapsible = (propName: string) => propName === COLLAPSIBLE;\n\nconst COLLAPSIBLE_VALUE: { [key: string]: string } = {\n dynamic: \"dynamic\",\n instant: \"instant\",\n true: \"instant\",\n};\n\nconst collapsibleValue = (value: string) => COLLAPSIBLE_VALUE[value] ?? \"none\";\n\ntype AnyProps = Record<string, unknown>;\ntype ResponsivePropsTuple = [AnyProps, AnyProps];\n/**\n * data- attributes can be used to manage item overflow behaviour. Users may\n * speficy these attributes directly on a Toolbar component, which ultimately\n * gets wrapped by a FormField. We need to 'lift' these attributes to the form\n * field and remove them from the props of the nested component.\n * @param props\n * @returns\n */\nexport const liftResponsivePropsToFormField = (\n props: AnyProps,\n): ResponsivePropsTuple => {\n const propNames = Object.keys(props);\n if (propNames.some(isResponsiveAttribute)) {\n return propNames.reduce<ResponsivePropsTuple>(\n (tuple, propName): ResponsivePropsTuple => {\n const [toolbarProps, rest] = tuple;\n const propValue = props[propName];\n if (isResponsiveAttribute(propName)) {\n const value = isCollapsible(propName)\n ? collapsibleValue(propValue as string)\n : propValue;\n\n toolbarProps[propName] = value;\n rest[propName] = undefined;\n }\n return tuple;\n },\n [{}, {}],\n );\n }\n return [{}, props];\n};\n"],"names":[],"mappings":";;;;AAAA,MAAM,WAAc,GAAA,kBAAA,CAAA;AAIpB,MAAM,oBAAmD,GAAA;AAAA,EACvD,CAAC,WAAc,GAAA,IAAA;AAAA,EACf,gBAAkB,EAAA,IAAA;AAAA,EAClB,cAAgB,EAAA,IAAA;AAClB,CAAA,CAAA;AAEa,MAAA,qBAAA,GAAwB,CAAC,QAA2B,KAAA;AAVjE,EAAA,IAAA,EAAA,CAAA;AAWE,EAAA,OAAA,CAAA,EAAA,GAAA,oBAAA,CAAqB,cAArB,IAAkC,GAAA,EAAA,GAAA,KAAA,CAAA;AAAA,EAAA;AAEpC,MAAM,aAAA,GAAgB,CAAC,QAAA,KAAqB,QAAa,KAAA,WAAA,CAAA;AAEzD,MAAM,iBAA+C,GAAA;AAAA,EACnD,OAAS,EAAA,SAAA;AAAA,EACT,OAAS,EAAA,SAAA;AAAA,EACT,IAAM,EAAA,SAAA;AACR,CAAA,CAAA;AAEA,MAAM,gBAAA,GAAmB,CAAC,KAAe,KAAA;AArBzC,EAAA,IAAA,EAAA,CAAA;AAqB4C,EAAA,OAAA,CAAA,EAAA,GAAA,iBAAA,CAAkB,WAAlB,IAA4B,GAAA,EAAA,GAAA,MAAA,CAAA;AAAA,CAAA,CAAA;AAY3D,MAAA,8BAAA,GAAiC,CAC5C,KACyB,KAAA;AACzB,EAAM,MAAA,SAAA,GAAY,MAAO,CAAA,IAAA,CAAK,KAAK,CAAA,CAAA;AACnC,EAAI,IAAA,SAAA,CAAU,IAAK,CAAA,qBAAqB,CAAG,EAAA;AACzC,IAAA,OAAO,SAAU,CAAA,MAAA;AAAA,MACf,CAAC,OAAO,QAAmC,KAAA;AACzC,QAAM,MAAA,CAAC,YAAc,EAAA,IAAI,CAAI,GAAA,KAAA,CAAA;AAC7B,QAAA,MAAM,YAAY,KAAM,CAAA,QAAA,CAAA,CAAA;AACxB,QAAI,IAAA,qBAAA,CAAsB,QAAQ,CAAG,EAAA;AACnC,UAAA,MAAM,QAAQ,aAAc,CAAA,QAAQ,CAChC,GAAA,gBAAA,CAAiB,SAAmB,CACpC,GAAA,SAAA,CAAA;AAEJ,UAAA,YAAA,CAAa,QAAY,CAAA,GAAA,KAAA,CAAA;AACzB,UAAA,IAAA,CAAK,QAAY,CAAA,GAAA,KAAA,CAAA,CAAA;AAAA,SACnB;AACA,QAAO,OAAA,KAAA,CAAA;AAAA,OACT;AAAA,MACA,CAAC,EAAI,EAAA,EAAE,CAAA;AAAA,KACT,CAAA;AAAA,GACF;AACA,EAAO,OAAA,CAAC,EAAC,EAAG,KAAK,CAAA,CAAA;AACnB;;;;;"}
@@ -3,14 +3,14 @@
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
- var React = require('react');
7
- var clsx = require('clsx');
8
6
  var core = require('@salt-ds/core');
7
+ var icons = require('@salt-ds/icons');
8
+ var clsx = require('clsx');
9
+ var React = require('react');
9
10
  var InputLegacy = require('../input-legacy/InputLegacy.js');
10
11
  var StaticInputAdornment = require('../input-legacy/StaticInputAdornment.js');
11
- var icons = require('@salt-ds/icons');
12
- var window = require('@salt-ds/window');
13
12
  var styles = require('@salt-ds/styles');
13
+ var window = require('@salt-ds/window');
14
14
  var SearchInput$1 = require('./SearchInput.css.js');
15
15
 
16
16
  const baseName = "saltSearchInput";