@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":"useQueryInput.js","sources":["../src/query-input/useQueryInput.ts"],"sourcesContent":["import { useControlled, useForkRef } from \"@salt-ds/core\";\nimport {\n ChangeEventHandler,\n FocusEventHandler,\n ForwardedRef,\n KeyboardEventHandler,\n Ref,\n RefObject,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { QueryInputBodyProps } from \"./internal/QueryInputBody\";\nimport { usePopperStatus } from \"./internal/usePopperStatus\";\nimport { ValueSelectorProps } from \"./internal/ValueSelector\";\nimport { QueryInputProps } from \"./QueryInput\";\nimport { QueryInputCategory, QueryInputItem } from \"./queryInputTypes\";\nimport { useWidth } from \"../responsive\";\n\nexport type BooleanOperator = \"or\" | \"and\";\n\nexport interface UseQueryInputResult {\n queryInputProps: {\n onFocus: FocusEventHandler<HTMLDivElement>;\n onBlur: FocusEventHandler<HTMLDivElement>;\n };\n queryInputBodyRef: Ref<HTMLDivElement>;\n queryInputBodyProps: QueryInputBodyProps;\n valueSelectorProps: ValueSelectorProps;\n}\n\nexport function useQueryInput(\n props: QueryInputProps,\n forwardedRef: ForwardedRef<HTMLDivElement>\n): UseQueryInputResult {\n const bodyRef = useRef<HTMLDivElement>(null);\n const popperRef = useRef<HTMLDivElement>(null);\n const inputRef = useRef<HTMLInputElement>(null);\n const [widthBodyRef, bodyWidth] = useWidth<HTMLDivElement>(true);\n\n const forkedRef1 = useForkRef<HTMLDivElement>(\n forwardedRef,\n bodyRef\n ) as RefObject<HTMLDivElement>;\n const queryInputBodyRef = useForkRef<HTMLDivElement>(\n forkedRef1,\n widthBodyRef\n );\n\n const [selectedItems, setSelectedItems] = useControlled({\n controlled: props.selectedItems,\n default: props.defaultSelectedItems || [],\n name: \"QueryInput\",\n state: \"selectedItems\",\n });\n\n const [booleanOperator, setBooleanOperator] = useControlled({\n controlled: props.booleanOperator,\n default: props.defaultBooleanOperator || \"and\",\n name: \"QueryInput\",\n state: \"booleanOperator\",\n });\n\n const popperStatus = usePopperStatus({\n initialOpen: false,\n autoClose: props.autoClose,\n });\n\n const [isFocused, setIsFocused] = useState<boolean>(false);\n const [highlightedIndex, setHighlightedIndex] = useState(0);\n const [highlightedCategoryIndex, setHighlightedCategoryIndex] = useState(0);\n const [highlightedValueIndex, setHighlightedValueIndex] = useState(0);\n const [selectedCategory, setSelectedCategory] =\n useState<QueryInputCategory | null>(null);\n const searchListIndexPositions = useRef<Array<QueryInputCategory | string>>(\n []\n );\n\n const onInputFocus: FocusEventHandler<HTMLInputElement> = (event) => {\n popperStatus.onFocus(event);\n setIsFocused(true);\n };\n\n const onInputBlur: FocusEventHandler<HTMLInputElement> = (event) => {\n if (!inputRef.current) {\n return;\n }\n const relatedTarget = event.relatedTarget as Node | null;\n const isBodyFocused = bodyRef.current === relatedTarget;\n if (isBodyFocused) {\n inputRef.current.focus();\n return;\n }\n const isFocusWithinBody =\n bodyRef.current && bodyRef.current.contains(relatedTarget);\n if (isFocusWithinBody) {\n return;\n }\n const isFocusWithinPopper =\n popperRef.current && popperRef.current.contains(relatedTarget);\n if (isFocusWithinPopper) {\n inputRef.current.focus();\n return;\n }\n setIsFocused(false);\n popperStatus.onBlur(event);\n };\n\n const onFocus: FocusEventHandler<HTMLDivElement> = (event) => {\n setIsFocused(true);\n popperStatus.onFocus(event);\n };\n\n const onBlur: FocusEventHandler<HTMLDivElement> = (event) => {\n let relatedTarget = event.relatedTarget as Node | null;\n const isBodyFocused = bodyRef.current === relatedTarget;\n if (isBodyFocused) {\n return;\n }\n const isFocusWithinBody =\n bodyRef.current && bodyRef.current.contains(relatedTarget);\n if (isFocusWithinBody) {\n return;\n }\n const isFocusWithinPopper =\n popperRef.current && popperRef.current.contains(relatedTarget);\n if (isFocusWithinPopper) {\n return;\n }\n setIsFocused(false);\n popperStatus.onBlur(event);\n };\n\n const onSelectedItemsChange = (newItems: QueryInputItem[] | undefined) => {\n const newItem =\n newItems &&\n newItems.find(\n (item) => item.category == null && item.value === inputValue\n );\n if (newItem) {\n setInputValue(\"\");\n }\n setSelectedItems(newItems || []);\n if (props.onChange) {\n props.onChange(newItems || []);\n }\n popperStatus.onChange();\n };\n\n const onBooleanOperatorChange = (operator: BooleanOperator) => {\n setBooleanOperator(operator);\n if (props.onBooleanOperatorChange) {\n props.onBooleanOperatorChange(operator);\n }\n };\n\n const onSelectedCategoryChange = (category: QueryInputCategory | null) => {\n if (inputRef.current) {\n inputRef.current.focus();\n }\n setSelectedCategory(category);\n };\n\n const [inputValue, setInputValue] = useState<string>(\"\");\n\n const searchListItems = useMemo(() => {\n const [searchListItems, indexPositions] = filterCategories(\n props.categories,\n inputValue\n );\n searchListIndexPositions.current = indexPositions;\n return searchListItems;\n }, [props.categories, inputValue]);\n\n const onInputChange: ChangeEventHandler<HTMLInputElement> = (event) => {\n const newInputValue = event.target.value;\n setInputValue(newInputValue);\n // If we have search results, the first index position will be a header\n setHighlightedIndex(searchListIndexPositions.current.length === 0 ? 0 : 1);\n };\n\n const searchListItemCount = useMemo(() => {\n return searchListItems.reduce(\n (acc, category) => acc + category.values.length,\n 0\n );\n }, [searchListItems]);\n\n const onInputClear = () => {\n onSelectedItemsChange([]);\n };\n\n const onInputClick = () => {\n popperStatus.onClick();\n };\n\n const newItemFromSelected = (): QueryInputItem | undefined => {\n const i = highlightedIndex;\n for (const category of searchListItems) {\n if (i < category.values.length) {\n const value = category.values[i];\n return {\n category: category.name,\n value,\n };\n }\n }\n };\n\n const { displayedItemCount = 10 } = props;\n\n const onSearchListKeyDown = (key: string) => {\n switch (key) {\n case \"Home\":\n setHighlightedIndex(0);\n return;\n case \"End\":\n setHighlightedIndex(searchListItemCount);\n return;\n case \"ArrowUp\":\n setHighlightedIndex((i) =>\n prevSearchItemIndex(i, searchListIndexPositions.current)\n );\n return;\n case \"ArrowDown\":\n // setHighlightedIndex((i) => Math.min(searchListItemCount, i + 1));\n setHighlightedIndex((i) =>\n nextSearchItemIndex(i, searchListIndexPositions.current)\n );\n return;\n case \"PageDown\":\n setHighlightedIndex((i) =>\n Math.min(searchListItemCount, i + displayedItemCount)\n );\n return;\n case \"PageUp\":\n setHighlightedIndex((i) => Math.max(0, i - displayedItemCount));\n return;\n case \"Enter\":\n if (highlightedIndex === searchListItemCount) {\n const newItems = [\n ...selectedItems,\n { category: null, value: inputValue },\n ];\n onSelectedItemsChange(newItems);\n } else {\n if (highlightedIndex >= 0 && highlightedIndex < searchListItemCount) {\n const newItem = newItemFromSelected();\n if (newItem) {\n const newItems = [...selectedItems, newItem];\n onSelectedItemsChange(newItems);\n }\n }\n setInputValue(\"\");\n }\n return;\n default:\n return;\n }\n };\n\n const onCategoryListKeyDown = (key: string) => {\n switch (key) {\n case \"Home\":\n setHighlightedCategoryIndex(0);\n return;\n case \"End\":\n setHighlightedCategoryIndex(props.categories.length - 1);\n return;\n case \"ArrowUp\":\n setHighlightedCategoryIndex((i) => Math.max(0, i - 1));\n return;\n case \"ArrowDown\":\n setHighlightedCategoryIndex((i) =>\n Math.min(props.categories.length - 1, i + 1)\n );\n return;\n case \"PageUp\":\n setHighlightedCategoryIndex((i) => Math.max(0, i - displayedItemCount));\n return;\n case \"PageDown\":\n setHighlightedCategoryIndex((i) =>\n Math.min(props.categories.length - 1, i + displayedItemCount)\n );\n return;\n case \"Enter\":\n if (\n highlightedCategoryIndex >= 0 &&\n highlightedCategoryIndex < props.categories.length\n ) {\n const category = props.categories[highlightedCategoryIndex];\n setSelectedCategory(category);\n }\n return;\n case \"ArrowRight\":\n if (\n highlightedCategoryIndex >= 0 &&\n highlightedCategoryIndex < props.categories.length\n ) {\n const category = props.categories[highlightedCategoryIndex];\n setSelectedCategory(category);\n }\n return;\n default:\n return;\n }\n };\n\n const onValueListKeyDown = (key: string) => {\n switch (key) {\n case \"Home\":\n setHighlightedValueIndex(0);\n return;\n case \"End\":\n setHighlightedValueIndex(selectedCategory!.values.length);\n return;\n case \"ArrowUp\":\n setHighlightedValueIndex((i) => Math.max(0, i - 1));\n return;\n case \"ArrowDown\":\n setHighlightedValueIndex((i) =>\n Math.min(selectedCategory!.values.length, i + 1)\n );\n return;\n case \"PageUp\":\n setHighlightedValueIndex((i) => Math.max(0, i - displayedItemCount));\n return;\n case \"PageDown\":\n setHighlightedValueIndex((i) =>\n Math.min(selectedCategory!.values.length, i + displayedItemCount)\n );\n return;\n case \"Enter\":\n if (highlightedValueIndex === 0) {\n setSelectedCategory(null);\n } else {\n const value = selectedCategory!.values[highlightedValueIndex - 1];\n const newItems = selectedItems.filter(\n (item) =>\n !(\n item.category === selectedCategory!.name && item.value === value\n )\n );\n if (newItems.length === selectedItems.length) {\n newItems.push({ category: selectedCategory!.name, value });\n }\n onSelectedItemsChange(newItems);\n }\n return;\n case \"ArrowLeft\":\n setSelectedCategory(null);\n return;\n default:\n return;\n }\n };\n\n const onKeyDown: KeyboardEventHandler<HTMLInputElement> = (event) => {\n popperStatus.onKeyDown(event);\n let key = event.key;\n if (event.key === \" \" && event.ctrlKey) {\n key = \"Enter\";\n }\n const isSearchListActive = inputValue !== \"\";\n const isCategoryListActive = !isSearchListActive && !selectedCategory;\n const isValueListActive = !isSearchListActive && !isCategoryListActive;\n if (isSearchListActive) {\n onSearchListKeyDown(key);\n } else if (isCategoryListActive) {\n onCategoryListKeyDown(key);\n } else {\n onValueListKeyDown(key);\n }\n switch (event.key) {\n case \"ArrowUp\":\n case \"ArrowDown\":\n case \"Enter\":\n event.preventDefault();\n break;\n case \"ArrowLeft\":\n if (isValueListActive) {\n event.preventDefault();\n }\n break;\n case \"ArrowRight\":\n if (isCategoryListActive) {\n event.preventDefault();\n }\n break;\n case \"Escape\":\n setInputValue(\"\");\n }\n };\n\n const onValueToggle = (category: QueryInputCategory, value: string) => {\n const newItems = selectedItems.filter(\n (item) => !(item.category === category.name && item.value === value)\n );\n if (newItems.length === selectedItems.length) {\n newItems.push({ category: category.name, value });\n }\n onSelectedItemsChange(newItems);\n };\n\n return {\n queryInputBodyRef,\n queryInputProps: {\n onFocus,\n onBlur,\n },\n queryInputBodyProps: {\n inputRef: inputRef,\n disabled: props.disabled,\n selectedItems,\n onFocus,\n onBlur,\n onInputClick,\n onInputFocus,\n onInputBlur,\n onInputClear,\n inputValue,\n onInputChange,\n onSelectedItemsChange,\n onKeyDown,\n isFocused,\n booleanOperator,\n onBooleanOperatorChange,\n },\n valueSelectorProps: {\n isOpen: popperStatus.isOpen,\n categories: props.categories,\n selectedCategory,\n selectedItems,\n onValueToggle,\n onSearchListChange: onSelectedItemsChange,\n anchorElement: bodyRef.current,\n width: bodyWidth,\n onSelectedCategoryChange,\n popperRef,\n inputValue,\n highlightedIndex,\n visibleCategories: searchListItems,\n highlightedCategoryIndex,\n highlightedValueIndex,\n setHighlightedCategoryIndex,\n setHighlightedValueIndex,\n setHighlightedIndex,\n },\n };\n}\n\nfunction filterCategories(\n categories: QueryInputCategory[],\n inputValue?: string\n): [QueryInputCategory[], Array<QueryInputCategory | string>] {\n // Note: if there is no input value, this List would not be display\n if (!inputValue) {\n return [categories, []];\n }\n const query = inputValue.toUpperCase();\n const visibleCategories: QueryInputCategory[] = [];\n const indexPositions: Array<QueryInputCategory | string> = [];\n for (const c of categories) {\n const values = c.values.filter((v) => v.toUpperCase().includes(query));\n if (values.length > 0) {\n const queryInputCategory = {\n name: c.name,\n values,\n };\n visibleCategories.push(queryInputCategory);\n indexPositions.push(queryInputCategory, ...values);\n }\n }\n return [visibleCategories, indexPositions];\n}\n\nfunction nextSearchItemIndex(\n index: number,\n indexPositions: Array<QueryInputCategory | string>\n) {\n const nextIndex = index + 1;\n // Note: allow 1 for the extra ListItem we append to end of List\n if (nextIndex === indexPositions.length + 1) {\n return index;\n } else if (nextIndex === indexPositions.length) {\n return nextIndex;\n } else if (typeof indexPositions[nextIndex] === \"string\") {\n return nextIndex;\n } else {\n return nextIndex + 1;\n }\n}\n\nfunction prevSearchItemIndex(\n index: number,\n indexPositions: Array<QueryInputCategory | string>\n) {\n const nextIndex = index - 1;\n if (nextIndex === 0) {\n return index;\n } else if (typeof indexPositions[nextIndex] === \"string\") {\n return nextIndex;\n } else {\n return nextIndex - 1;\n }\n}\n"],"names":["useRef","useWidth","useForkRef","useControlled","usePopperStatus","useState","useMemo","searchListItems"],"mappings":"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"}
1
+ {"version":3,"file":"useQueryInput.js","sources":["../src/query-input/useQueryInput.ts"],"sourcesContent":["import { useControlled, useForkRef } from \"@salt-ds/core\";\nimport {\n type ChangeEventHandler,\n type FocusEventHandler,\n type ForwardedRef,\n type KeyboardEventHandler,\n type Ref,\n type RefObject,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { useWidth } from \"../responsive\";\nimport type { QueryInputProps } from \"./QueryInput\";\nimport type { QueryInputBodyProps } from \"./internal/QueryInputBody\";\nimport type { ValueSelectorProps } from \"./internal/ValueSelector\";\nimport { usePopperStatus } from \"./internal/usePopperStatus\";\nimport type { QueryInputCategory, QueryInputItem } from \"./queryInputTypes\";\n\nexport type BooleanOperator = \"or\" | \"and\";\n\nexport interface UseQueryInputResult {\n queryInputProps: {\n onFocus: FocusEventHandler<HTMLDivElement>;\n onBlur: FocusEventHandler<HTMLDivElement>;\n };\n queryInputBodyRef: Ref<HTMLDivElement>;\n queryInputBodyProps: QueryInputBodyProps;\n valueSelectorProps: ValueSelectorProps;\n}\n\nexport function useQueryInput(\n props: QueryInputProps,\n forwardedRef: ForwardedRef<HTMLDivElement>,\n): UseQueryInputResult {\n const bodyRef = useRef<HTMLDivElement>(null);\n const popperRef = useRef<HTMLDivElement>(null);\n const inputRef = useRef<HTMLInputElement>(null);\n const [widthBodyRef, bodyWidth] = useWidth<HTMLDivElement>(true);\n\n const forkedRef1 = useForkRef<HTMLDivElement>(\n forwardedRef,\n bodyRef,\n ) as RefObject<HTMLDivElement>;\n const queryInputBodyRef = useForkRef<HTMLDivElement>(\n forkedRef1,\n widthBodyRef,\n );\n\n const [selectedItems, setSelectedItems] = useControlled({\n controlled: props.selectedItems,\n default: props.defaultSelectedItems || [],\n name: \"QueryInput\",\n state: \"selectedItems\",\n });\n\n const [booleanOperator, setBooleanOperator] = useControlled({\n controlled: props.booleanOperator,\n default: props.defaultBooleanOperator || \"and\",\n name: \"QueryInput\",\n state: \"booleanOperator\",\n });\n\n const popperStatus = usePopperStatus({\n initialOpen: false,\n autoClose: props.autoClose,\n });\n\n const [isFocused, setIsFocused] = useState<boolean>(false);\n const [highlightedIndex, setHighlightedIndex] = useState(0);\n const [highlightedCategoryIndex, setHighlightedCategoryIndex] = useState(0);\n const [highlightedValueIndex, setHighlightedValueIndex] = useState(0);\n const [selectedCategory, setSelectedCategory] =\n useState<QueryInputCategory | null>(null);\n const searchListIndexPositions = useRef<Array<QueryInputCategory | string>>(\n [],\n );\n\n const onInputFocus: FocusEventHandler<HTMLInputElement> = (event) => {\n popperStatus.onFocus(event);\n setIsFocused(true);\n };\n\n const onInputBlur: FocusEventHandler<HTMLInputElement> = (event) => {\n if (!inputRef.current) {\n return;\n }\n const relatedTarget = event.relatedTarget as Node | null;\n const isBodyFocused = bodyRef.current === relatedTarget;\n if (isBodyFocused) {\n inputRef.current.focus();\n return;\n }\n const isFocusWithinBody = bodyRef.current?.contains(relatedTarget);\n if (isFocusWithinBody) {\n return;\n }\n const isFocusWithinPopper = popperRef.current?.contains(relatedTarget);\n if (isFocusWithinPopper) {\n inputRef.current.focus();\n return;\n }\n setIsFocused(false);\n popperStatus.onBlur(event);\n };\n\n const onFocus: FocusEventHandler<HTMLDivElement> = (event) => {\n setIsFocused(true);\n popperStatus.onFocus(event);\n };\n\n const onBlur: FocusEventHandler<HTMLDivElement> = (event) => {\n const relatedTarget = event.relatedTarget as Node | null;\n const isBodyFocused = bodyRef.current === relatedTarget;\n if (isBodyFocused) {\n return;\n }\n const isFocusWithinBody = bodyRef.current?.contains(relatedTarget);\n if (isFocusWithinBody) {\n return;\n }\n const isFocusWithinPopper = popperRef.current?.contains(relatedTarget);\n if (isFocusWithinPopper) {\n return;\n }\n setIsFocused(false);\n popperStatus.onBlur(event);\n };\n\n const onSelectedItemsChange = (newItems: QueryInputItem[] | undefined) => {\n const newItem = newItems?.find(\n (item) => item.category == null && item.value === inputValue,\n );\n if (newItem) {\n setInputValue(\"\");\n }\n setSelectedItems(newItems || []);\n if (props.onChange) {\n props.onChange(newItems || []);\n }\n popperStatus.onChange();\n };\n\n const onBooleanOperatorChange = (operator: BooleanOperator) => {\n setBooleanOperator(operator);\n if (props.onBooleanOperatorChange) {\n props.onBooleanOperatorChange(operator);\n }\n };\n\n const onSelectedCategoryChange = (category: QueryInputCategory | null) => {\n if (inputRef.current) {\n inputRef.current.focus();\n }\n setSelectedCategory(category);\n };\n\n const [inputValue, setInputValue] = useState<string>(\"\");\n\n const searchListItems = useMemo(() => {\n const [searchListItems, indexPositions] = filterCategories(\n props.categories,\n inputValue,\n );\n searchListIndexPositions.current = indexPositions;\n return searchListItems;\n }, [props.categories, inputValue]);\n\n const onInputChange: ChangeEventHandler<HTMLInputElement> = (event) => {\n const newInputValue = event.target.value;\n setInputValue(newInputValue);\n // If we have search results, the first index position will be a header\n setHighlightedIndex(searchListIndexPositions.current.length === 0 ? 0 : 1);\n };\n\n const searchListItemCount = useMemo(() => {\n return searchListItems.reduce(\n (acc, category) => acc + category.values.length,\n 0,\n );\n }, [searchListItems]);\n\n const onInputClear = () => {\n onSelectedItemsChange([]);\n };\n\n const onInputClick = () => {\n popperStatus.onClick();\n };\n\n const newItemFromSelected = (): QueryInputItem | undefined => {\n const i = highlightedIndex;\n for (const category of searchListItems) {\n if (i < category.values.length) {\n const value = category.values[i];\n return {\n category: category.name,\n value,\n };\n }\n }\n };\n\n const { displayedItemCount = 10 } = props;\n\n const onSearchListKeyDown = (key: string) => {\n switch (key) {\n case \"Home\":\n setHighlightedIndex(0);\n return;\n case \"End\":\n setHighlightedIndex(searchListItemCount);\n return;\n case \"ArrowUp\":\n setHighlightedIndex((i) =>\n prevSearchItemIndex(i, searchListIndexPositions.current),\n );\n return;\n case \"ArrowDown\":\n // setHighlightedIndex((i) => Math.min(searchListItemCount, i + 1));\n setHighlightedIndex((i) =>\n nextSearchItemIndex(i, searchListIndexPositions.current),\n );\n return;\n case \"PageDown\":\n setHighlightedIndex((i) =>\n Math.min(searchListItemCount, i + displayedItemCount),\n );\n return;\n case \"PageUp\":\n setHighlightedIndex((i) => Math.max(0, i - displayedItemCount));\n return;\n case \"Enter\":\n if (highlightedIndex === searchListItemCount) {\n const newItems = [\n ...selectedItems,\n { category: null, value: inputValue },\n ];\n onSelectedItemsChange(newItems);\n } else {\n if (highlightedIndex >= 0 && highlightedIndex < searchListItemCount) {\n const newItem = newItemFromSelected();\n if (newItem) {\n const newItems = [...selectedItems, newItem];\n onSelectedItemsChange(newItems);\n }\n }\n setInputValue(\"\");\n }\n return;\n default:\n return;\n }\n };\n\n const onCategoryListKeyDown = (key: string) => {\n switch (key) {\n case \"Home\":\n setHighlightedCategoryIndex(0);\n return;\n case \"End\":\n setHighlightedCategoryIndex(props.categories.length - 1);\n return;\n case \"ArrowUp\":\n setHighlightedCategoryIndex((i) => Math.max(0, i - 1));\n return;\n case \"ArrowDown\":\n setHighlightedCategoryIndex((i) =>\n Math.min(props.categories.length - 1, i + 1),\n );\n return;\n case \"PageUp\":\n setHighlightedCategoryIndex((i) => Math.max(0, i - displayedItemCount));\n return;\n case \"PageDown\":\n setHighlightedCategoryIndex((i) =>\n Math.min(props.categories.length - 1, i + displayedItemCount),\n );\n return;\n case \"Enter\":\n if (\n highlightedCategoryIndex >= 0 &&\n highlightedCategoryIndex < props.categories.length\n ) {\n const category = props.categories[highlightedCategoryIndex];\n setSelectedCategory(category);\n }\n return;\n case \"ArrowRight\":\n if (\n highlightedCategoryIndex >= 0 &&\n highlightedCategoryIndex < props.categories.length\n ) {\n const category = props.categories[highlightedCategoryIndex];\n setSelectedCategory(category);\n }\n return;\n default:\n return;\n }\n };\n\n const onValueListKeyDown = (key: string) => {\n switch (key) {\n case \"Home\":\n setHighlightedValueIndex(0);\n return;\n case \"End\":\n if (selectedCategory != null) {\n setHighlightedValueIndex(selectedCategory.values.length);\n }\n return;\n case \"ArrowUp\":\n setHighlightedValueIndex((i) => Math.max(0, i - 1));\n return;\n case \"ArrowDown\":\n setHighlightedValueIndex((i) => {\n if (selectedCategory != null) {\n return Math.min(selectedCategory.values.length, i + 1);\n }\n return i;\n });\n return;\n case \"PageUp\":\n setHighlightedValueIndex((i) => Math.max(0, i - displayedItemCount));\n return;\n case \"PageDown\":\n setHighlightedValueIndex((i) => {\n if (selectedCategory != null) {\n return Math.min(\n selectedCategory.values.length,\n i + displayedItemCount,\n );\n }\n return i;\n });\n return;\n case \"Enter\":\n if (highlightedValueIndex === 0 || selectedCategory == null) {\n setSelectedCategory(null);\n } else {\n const value = selectedCategory.values[highlightedValueIndex - 1];\n const newItems = selectedItems.filter(\n (item) =>\n !(\n item.category === selectedCategory.name && item.value === value\n ),\n );\n if (newItems.length === selectedItems.length) {\n newItems.push({ category: selectedCategory.name, value });\n }\n onSelectedItemsChange(newItems);\n }\n return;\n case \"ArrowLeft\":\n setSelectedCategory(null);\n return;\n default:\n return;\n }\n };\n\n const onKeyDown: KeyboardEventHandler<HTMLInputElement> = (event) => {\n popperStatus.onKeyDown(event);\n let key = event.key;\n if (event.key === \" \" && event.ctrlKey) {\n key = \"Enter\";\n }\n const isSearchListActive = inputValue !== \"\";\n const isCategoryListActive = !isSearchListActive && !selectedCategory;\n const isValueListActive = !isSearchListActive && !isCategoryListActive;\n if (isSearchListActive) {\n onSearchListKeyDown(key);\n } else if (isCategoryListActive) {\n onCategoryListKeyDown(key);\n } else {\n onValueListKeyDown(key);\n }\n switch (event.key) {\n case \"ArrowUp\":\n case \"ArrowDown\":\n case \"Enter\":\n event.preventDefault();\n break;\n case \"ArrowLeft\":\n if (isValueListActive) {\n event.preventDefault();\n }\n break;\n case \"ArrowRight\":\n if (isCategoryListActive) {\n event.preventDefault();\n }\n break;\n case \"Escape\":\n setInputValue(\"\");\n }\n };\n\n const onValueToggle = (category: QueryInputCategory, value: string) => {\n const newItems = selectedItems.filter(\n (item) => !(item.category === category.name && item.value === value),\n );\n if (newItems.length === selectedItems.length) {\n newItems.push({ category: category.name, value });\n }\n onSelectedItemsChange(newItems);\n };\n\n return {\n queryInputBodyRef,\n queryInputProps: {\n onFocus,\n onBlur,\n },\n queryInputBodyProps: {\n inputRef: inputRef,\n disabled: props.disabled,\n selectedItems,\n onFocus,\n onBlur,\n onInputClick,\n onInputFocus,\n onInputBlur,\n onInputClear,\n inputValue,\n onInputChange,\n onSelectedItemsChange,\n onKeyDown,\n isFocused,\n booleanOperator,\n onBooleanOperatorChange,\n },\n valueSelectorProps: {\n isOpen: popperStatus.isOpen,\n categories: props.categories,\n selectedCategory,\n selectedItems,\n onValueToggle,\n onSearchListChange: onSelectedItemsChange,\n anchorElement: bodyRef.current,\n width: bodyWidth,\n onSelectedCategoryChange,\n popperRef,\n inputValue,\n highlightedIndex,\n visibleCategories: searchListItems,\n highlightedCategoryIndex,\n highlightedValueIndex,\n setHighlightedCategoryIndex,\n setHighlightedValueIndex,\n setHighlightedIndex,\n },\n };\n}\n\nfunction filterCategories(\n categories: QueryInputCategory[],\n inputValue?: string,\n): [QueryInputCategory[], Array<QueryInputCategory | string>] {\n // Note: if there is no input value, this List would not be display\n if (!inputValue) {\n return [categories, []];\n }\n const query = inputValue.toUpperCase();\n const visibleCategories: QueryInputCategory[] = [];\n const indexPositions: Array<QueryInputCategory | string> = [];\n for (const c of categories) {\n const values = c.values.filter((v) => v.toUpperCase().includes(query));\n if (values.length > 0) {\n const queryInputCategory = {\n name: c.name,\n values,\n };\n visibleCategories.push(queryInputCategory);\n indexPositions.push(queryInputCategory, ...values);\n }\n }\n return [visibleCategories, indexPositions];\n}\n\nfunction nextSearchItemIndex(\n index: number,\n indexPositions: Array<QueryInputCategory | string>,\n) {\n const nextIndex = index + 1;\n // Note: allow 1 for the extra ListItem we append to end of List\n if (nextIndex === indexPositions.length + 1) {\n return index;\n }\n if (nextIndex === indexPositions.length) {\n return nextIndex;\n }\n if (typeof indexPositions[nextIndex] === \"string\") {\n return nextIndex;\n }\n return nextIndex + 1;\n}\n\nfunction prevSearchItemIndex(\n index: number,\n indexPositions: Array<QueryInputCategory | string>,\n) {\n const nextIndex = index - 1;\n if (nextIndex === 0) {\n return index;\n }\n if (typeof indexPositions[nextIndex] === \"string\") {\n return nextIndex;\n }\n return nextIndex - 1;\n}\n"],"names":["useRef","useWidth","useForkRef","useControlled","usePopperStatus","useState","useMemo","searchListItems"],"mappings":"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"}
@@ -69,7 +69,7 @@ const childItem = (child, id, index, options) => {
69
69
  element: child,
70
70
  label,
71
71
  position: dataPosition,
72
- priority: priority != null ? priority : parseInt(dataPriority),
72
+ priority: priority != null ? priority : Number.parseInt(dataPriority),
73
73
  size: 0,
74
74
  source: null,
75
75
  type: "child"
@@ -89,15 +89,14 @@ const createInjectedContent = (items, idRoot, startIndex) => {
89
89
  const id = `${idRoot}-${index}`;
90
90
  const { source } = item;
91
91
  if (source) {
92
- const injectedItem = sourceItem(source, id, index);
93
- injectedItem.isInjectedItem = true;
94
- return injectedItem;
95
- } else {
96
- const { element } = item;
97
- const injectedItem = childItem(element, id, index);
98
- injectedItem.isInjectedItem = true;
99
- return injectedItem;
92
+ const injectedItem2 = sourceItem(source, id, index);
93
+ injectedItem2.isInjectedItem = true;
94
+ return injectedItem2;
100
95
  }
96
+ const { element } = item;
97
+ const injectedItem = childItem(element, id, index);
98
+ injectedItem.isInjectedItem = true;
99
+ return injectedItem;
101
100
  });
102
101
  };
103
102
  const defaultOptions = {};
@@ -159,15 +158,15 @@ const restoreCollapsingItem = (items) => {
159
158
  ...item,
160
159
  collapsing: false
161
160
  };
162
- } else if (item === collapsedItem) {
161
+ }
162
+ if (item === collapsedItem) {
163
163
  return {
164
164
  ...item,
165
165
  collapsed: false,
166
166
  collapsing: true
167
167
  };
168
- } else {
169
- return item;
170
168
  }
169
+ return item;
171
170
  });
172
171
  };
173
172
  const collapseDynamicItem = (items, { overflowItem, collapsedSize = 0, minSize = 0 }) => {
@@ -185,14 +184,14 @@ const collapseDynamicItem = (items, { overflowItem, collapsedSize = 0, minSize =
185
184
  minSize,
186
185
  size: collapsedSize
187
186
  };
188
- } else if (item === lastUncollapsedItem) {
187
+ }
188
+ if (item === lastUncollapsedItem) {
189
189
  return {
190
190
  ...item,
191
191
  collapsing: true
192
192
  };
193
- } else {
194
- return item;
195
193
  }
194
+ return item;
196
195
  });
197
196
  };
198
197
  const addSourceItem = (items, { idRoot, source }) => {
@@ -207,12 +206,10 @@ const addOverflowIndicator = (items, { overflowItem }) => {
207
206
  if (items.find((i) => i.label === "Add Tab")) {
208
207
  const [addTab] = items.slice(-1);
209
208
  return items.slice(0, -1).concat({ ...overflowItem, index: addTab.index }).concat({ ...addTab, index: overflowItem.index });
210
- } else {
211
- return items.concat(overflowItem);
212
209
  }
213
- } else {
214
- return items;
210
+ return items.concat(overflowItem);
215
211
  }
212
+ return items;
216
213
  };
217
214
  const overflowReducer = (state, action) => {
218
215
  var _a;
@@ -1 +1 @@
1
- {"version":3,"file":"OverflowReducer.js","sources":["../src/responsive/OverflowReducer.ts"],"sourcesContent":["/**\n * This reducer manages a collection of items that represent the content of an overflowable container.\n * The items are mostly content configured by the caller of the container, either data passed though\n * the source prop or as child elements. We also support 'injected' items. These allow for additional UI\n * controls to be inserted into the container, eg an 'Add Item' button.\n */\nimport React, { isValidElement, ReactElement, ReactNode, Reducer } from \"react\";\n\nimport {\n InjectedChildItem,\n InjectedSourceItem,\n OverflowItem,\n OverflowItems,\n OverflowCollectionOptions,\n OverflowSource,\n} from \"./overflowTypes\";\n\ninterface InitAction {\n type: \"init\";\n overflowItems?: OverflowItem[];\n}\n\ninterface SourceAction {\n type: \"add-source-item\";\n idRoot: string;\n source: any;\n}\ninterface AddChildAction {\n type: \"add-child-item\";\n idRoot: string;\n indexPosition?: number;\n element: ReactElement;\n}\ninterface RemoveItemAction {\n type: \"remove-item\";\n indexPosition: number;\n}\n\ninterface MultiItemAction {\n type: \"update-items\" | \"update-items-remove-overflow-indicator\";\n overflowItems: Partial<Omit<OverflowItem, \"id\">> & Pick<OverflowItem, \"id\">[];\n}\ninterface SingleItemAction {\n type:\n | \"add-overflow-indicator\"\n | \"replace-item\"\n | \"collapsing-item\"\n | \"uncollapse-dynamic-item\"\n | \"collapse-instant-item\";\n\n overflowItem: OverflowItem;\n}\n\ninterface CombinedItemAction {\n type: \"update-items-add-overflow-indicator\";\n overflowItem: OverflowItem<any>;\n overflowItems: OverflowItem[];\n}\n\ninterface EmptyPayloadAction {\n type: \"restore-collapsing-item\";\n}\ninterface DynamicCollapseAction extends Omit<SingleItemAction, \"type\"> {\n type: \"collapse-dynamic-item\";\n collapsedSize: number;\n minSize: number;\n}\n\nexport type OverflowAction =\n | AddChildAction\n | CombinedItemAction\n | DynamicCollapseAction\n | EmptyPayloadAction\n | InitAction\n | MultiItemAction\n | RemoveItemAction\n | SingleItemAction\n | SourceAction;\n\nconst DEFAULT_PRIORITY = 3;\n\nconst mapReactElementChildren = (\n children: ReactNode,\n fn: (el: ReactElement, index: number) => OverflowItem\n): OverflowItem[] => {\n const childElements: OverflowItem[] = [];\n React.Children.forEach(children, (child, i) => {\n if (isValidElement(child)) {\n childElements.push(fn(child, i));\n }\n });\n return childElements;\n};\n\nconst sourceItem = (\n item: OverflowSource,\n id: string,\n index: number,\n options?: OverflowCollectionOptions\n): OverflowItem<\"source\"> => {\n const priority =\n options?.getPriority?.(item, index) ?? item.priority ?? DEFAULT_PRIORITY;\n\n return {\n //TODO editable closeable configurable via item\n closeable: item.closeable || options?.closeable,\n editable: options?.editable,\n element: null,\n fullSize: null,\n id: item.id ?? id,\n index,\n label: item.label,\n position: item.position,\n priority,\n size: 0,\n source: item,\n type: \"source\",\n };\n};\n\nconst createSourceItems = (\n source: any,\n idRoot: string,\n options?: OverflowCollectionOptions\n): OverflowItem<\"source\">[] | undefined => {\n if (Array.isArray(source)) {\n return source.map((item, index) => {\n const priority = options?.getPriority?.(source, index);\n return sourceItem(item, `${idRoot}-${index}`, index, options);\n });\n }\n};\n\ntype OverflowChild = {\n closeable?: boolean;\n disabled?: boolean;\n id?: string;\n label?: string;\n \"data-collapsible\"?: boolean;\n \"data-editable\"?: boolean;\n \"data-position\"?: number;\n \"data-priority\"?: string;\n};\n\nconst childItem = (\n child: ReactElement,\n id: string,\n index: number,\n options?: OverflowCollectionOptions\n): OverflowItem<\"child\"> => {\n const {\n closeable,\n disabled,\n id: idProp,\n label,\n \"data-collapsible\": collapsible,\n \"data-editable\": editable,\n \"data-position\": dataPosition,\n \"data-priority\": dataPriority = \"2\",\n } = child.props as OverflowChild;\n\n const priority = options?.getPriority?.(child, index);\n\n return {\n closeable: closeable || options?.closeable,\n collapsible,\n editable: editable ? true : options?.editable,\n disabled,\n fullSize: null,\n id: idProp ?? id,\n index,\n element: child,\n label,\n position: dataPosition,\n priority: priority ?? parseInt(dataPriority),\n size: 0,\n source: null,\n type: \"child\",\n } as OverflowItem;\n};\n\nconst createChildItems = (\n children: React.ReactNode,\n idRoot: string,\n options?: OverflowCollectionOptions\n): OverflowItem<\"child\">[] | undefined => {\n if (children) {\n return mapReactElementChildren(children, (child, index) => {\n const id = `${idRoot}-${index}`;\n return childItem(child, id, index, options);\n });\n }\n};\n\nconst createInjectedContent = (\n items: Array<InjectedSourceItem | InjectedChildItem>,\n idRoot: string,\n startIndex: number\n): OverflowItem<\"source\" | \"child\">[] => {\n return items.map((item, i) => {\n const index = startIndex + i;\n const id = `${idRoot}-${index}`;\n const { source } = item as InjectedSourceItem;\n if (source) {\n const injectedItem = sourceItem(source, id, index);\n injectedItem.isInjectedItem = true;\n return injectedItem;\n } else {\n const { element } = item as InjectedChildItem;\n const injectedItem = childItem(element, id, index);\n injectedItem.isInjectedItem = true;\n return injectedItem;\n }\n });\n};\n\nexport type OverflowReducer = Reducer<OverflowItems, OverflowAction>;\n\nconst defaultOptions = {};\n\nexport type OverflowReducerInitialisationProps = {\n children?: ReactNode;\n source?: OverflowSource[];\n injectedItems?: any[];\n idRoot: string;\n options?: OverflowCollectionOptions;\n};\n\nexport const reducerInitialiser: (\n props: OverflowReducerInitialisationProps\n) => OverflowItems = ({\n children,\n source,\n injectedItems = [],\n idRoot,\n options = defaultOptions,\n}) => {\n const providedContent: OverflowItems =\n createChildItems(children, idRoot, options) ||\n createSourceItems(source, idRoot, options) ||\n [];\n const injectedContent = createInjectedContent(\n injectedItems,\n idRoot,\n providedContent.length\n );\n return providedContent.concat(injectedContent);\n};\n\nconst collapsingItem = (\n items: OverflowItem[],\n { overflowItem }: SingleItemAction\n) =>\n items.map((item) =>\n item === overflowItem\n ? {\n ...item,\n collapsing: true,\n }\n : item\n );\n\nconst uncollapseDynamicItem = (\n items: OverflowItem[],\n { overflowItem }: SingleItemAction\n) =>\n items.map((item) =>\n item === overflowItem\n ? {\n ...item,\n collapsed: false,\n collapsing: true,\n size: item.fullSize as number,\n fullSize: null,\n }\n : item\n );\n\nconst collapseInstantItem = (\n items: OverflowItem[],\n { overflowItem }: SingleItemAction\n) =>\n items.map((item) =>\n item === overflowItem\n ? {\n ...item,\n collapsed: true,\n }\n : item\n );\n\nconst replaceItem = (\n items: OverflowItem[],\n { overflowItem }: SingleItemAction\n) =>\n items.map((item) =>\n item.index === overflowItem?.index ? overflowItem : item\n );\n\nconst updateItems = (\n items: OverflowItem[],\n { overflowItems = [] }: MultiItemAction\n) => {\n return items.map((item) => {\n const targetItem = overflowItems.find((i) => i.id === item.id);\n return targetItem ? { ...item, ...targetItem } : item;\n });\n};\n\nconst restoreCollapsingItem = (items: OverflowItem[]) => {\n const collapsingItem = items.find(\n ({ collapsible, collapsing }) => collapsible === \"dynamic\" && collapsing\n );\n const collapsedItem = items.find(\n ({ collapsible, collapsed }) => collapsible === \"dynamic\" && collapsed\n );\n return items.map((item) => {\n if (item === collapsingItem) {\n return {\n ...item,\n collapsing: false,\n };\n } else if (item === collapsedItem) {\n return {\n ...item,\n collapsed: false,\n collapsing: true,\n };\n } else {\n return item;\n }\n });\n};\n\nconst collapseDynamicItem = (\n items: OverflowItem[],\n { overflowItem, collapsedSize = 0, minSize = 0 }: DynamicCollapseAction\n) => {\n const remainingUncollpasedItems = items.filter(\n (i) => i.collapsible === \"dynamic\" && !i.collapsed && i !== overflowItem\n );\n const lastUncollapsedItem = remainingUncollpasedItems.pop();\n\n return items.map((item) => {\n if (item === overflowItem) {\n return {\n ...item,\n collapsing: false,\n collapsed: true,\n fullSize: item.size,\n minSize,\n size: collapsedSize,\n };\n } else if (item === lastUncollapsedItem) {\n return {\n ...item,\n collapsing: true,\n };\n } else {\n return item;\n }\n });\n};\n\nconst addSourceItem = (\n items: OverflowItem<any>[],\n { idRoot, source }: SourceAction\n): OverflowItem[] => {\n const index = items.length;\n return items.concat(sourceItem(source, `${idRoot}-${index}`, index));\n};\n\nconst removeItem = (\n items: OverflowItem<any>[],\n { indexPosition }: RemoveItemAction\n): OverflowItem[] => {\n return items.slice(0, indexPosition).concat(items.slice(indexPosition + 1));\n};\n\nconst addOverflowIndicator = (\n items: OverflowItem<any>[],\n { overflowItem }: SingleItemAction\n) => {\n // Guard against accidental duplicate overflowIndicator\n if (!items.find((i) => i.isOverflowIndicator)) {\n if (items.find((i) => i.label === \"Add Tab\")) {\n const [addTab] = items.slice(-1);\n return items\n .slice(0, -1)\n .concat({ ...overflowItem, index: addTab.index })\n .concat({ ...addTab, index: overflowItem.index });\n } else {\n return items.concat(overflowItem);\n }\n } else {\n return items;\n }\n};\n\nexport const overflowReducer: OverflowReducer = (state, action) => {\n switch (action.type) {\n case \"init\":\n return action.overflowItems ?? state;\n case \"add-overflow-indicator\":\n return addOverflowIndicator(state, action);\n\n case \"update-items\":\n return updateItems(state, action);\n\n case \"replace-item\":\n return replaceItem(state, action);\n\n case \"update-items-add-overflow-indicator\":\n return addOverflowIndicator(\n updateItems(state, {\n type: \"update-items\",\n overflowItems: action.overflowItems,\n }),\n { type: \"add-overflow-indicator\", overflowItem: action.overflowItem }\n );\n\n case \"update-items-remove-overflow-indicator\":\n return updateItems(state, {\n type: \"update-items\",\n overflowItems: action.overflowItems,\n }).filter((item) => !item.isOverflowIndicator);\n\n case \"collapsing-item\":\n return collapsingItem(state, action);\n\n case \"collapse-dynamic-item\":\n return collapseDynamicItem(state, action);\n\n case \"uncollapse-dynamic-item\":\n return uncollapseDynamicItem(state, action);\n\n case \"restore-collapsing-item\":\n return restoreCollapsingItem(state);\n\n case \"collapse-instant-item\":\n return collapseInstantItem(state, action);\n\n case \"add-source-item\":\n return addSourceItem(state, action);\n\n case \"remove-item\":\n return removeItem(state, action);\n\n default:\n return state;\n }\n};\n"],"names":["React","isValidElement","collapsingItem"],"mappings":"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"}
1
+ {"version":3,"file":"OverflowReducer.js","sources":["../src/responsive/OverflowReducer.ts"],"sourcesContent":["/**\n * This reducer manages a collection of items that represent the content of an overflowable container.\n * The items are mostly content configured by the caller of the container, either data passed though\n * the source prop or as child elements. We also support 'injected' items. These allow for additional UI\n * controls to be inserted into the container, eg an 'Add Item' button.\n */\nimport React, {\n isValidElement,\n type ReactElement,\n type ReactNode,\n type Reducer,\n} from \"react\";\n\nimport type {\n InjectedChildItem,\n InjectedSourceItem,\n OverflowCollectionOptions,\n OverflowItem,\n OverflowItems,\n OverflowSource,\n} from \"./overflowTypes\";\n\ninterface InitAction {\n type: \"init\";\n overflowItems?: OverflowItem[];\n}\n\ninterface SourceAction {\n type: \"add-source-item\";\n idRoot: string;\n source: any;\n}\ninterface AddChildAction {\n type: \"add-child-item\";\n idRoot: string;\n indexPosition?: number;\n element: ReactElement;\n}\ninterface RemoveItemAction {\n type: \"remove-item\";\n indexPosition: number;\n}\n\ninterface MultiItemAction {\n type: \"update-items\" | \"update-items-remove-overflow-indicator\";\n overflowItems: Partial<Omit<OverflowItem, \"id\">> & Pick<OverflowItem, \"id\">[];\n}\ninterface SingleItemAction {\n type:\n | \"add-overflow-indicator\"\n | \"replace-item\"\n | \"collapsing-item\"\n | \"uncollapse-dynamic-item\"\n | \"collapse-instant-item\";\n\n overflowItem: OverflowItem;\n}\n\ninterface CombinedItemAction {\n type: \"update-items-add-overflow-indicator\";\n overflowItem: OverflowItem<any>;\n overflowItems: OverflowItem[];\n}\n\ninterface EmptyPayloadAction {\n type: \"restore-collapsing-item\";\n}\ninterface DynamicCollapseAction extends Omit<SingleItemAction, \"type\"> {\n type: \"collapse-dynamic-item\";\n collapsedSize: number;\n minSize: number;\n}\n\nexport type OverflowAction =\n | AddChildAction\n | CombinedItemAction\n | DynamicCollapseAction\n | EmptyPayloadAction\n | InitAction\n | MultiItemAction\n | RemoveItemAction\n | SingleItemAction\n | SourceAction;\n\nconst DEFAULT_PRIORITY = 3;\n\nconst mapReactElementChildren = (\n children: ReactNode,\n fn: (el: ReactElement, index: number) => OverflowItem,\n): OverflowItem[] => {\n const childElements: OverflowItem[] = [];\n React.Children.forEach(children, (child, i) => {\n if (isValidElement(child)) {\n childElements.push(fn(child, i));\n }\n });\n return childElements;\n};\n\nconst sourceItem = (\n item: OverflowSource,\n id: string,\n index: number,\n options?: OverflowCollectionOptions,\n): OverflowItem<\"source\"> => {\n const priority =\n options?.getPriority?.(item, index) ?? item.priority ?? DEFAULT_PRIORITY;\n\n return {\n //TODO editable closeable configurable via item\n closeable: item.closeable || options?.closeable,\n editable: options?.editable,\n element: null,\n fullSize: null,\n id: item.id ?? id,\n index,\n label: item.label,\n position: item.position,\n priority,\n size: 0,\n source: item,\n type: \"source\",\n };\n};\n\nconst createSourceItems = (\n source: any,\n idRoot: string,\n options?: OverflowCollectionOptions,\n): OverflowItem<\"source\">[] | undefined => {\n if (Array.isArray(source)) {\n return source.map((item, index) => {\n const priority = options?.getPriority?.(source, index);\n return sourceItem(item, `${idRoot}-${index}`, index, options);\n });\n }\n};\n\ntype OverflowChild = {\n closeable?: boolean;\n disabled?: boolean;\n id?: string;\n label?: string;\n \"data-collapsible\"?: boolean;\n \"data-editable\"?: boolean;\n \"data-position\"?: number;\n \"data-priority\"?: string;\n};\n\nconst childItem = (\n child: ReactElement,\n id: string,\n index: number,\n options?: OverflowCollectionOptions,\n): OverflowItem<\"child\"> => {\n const {\n closeable,\n disabled,\n id: idProp,\n label,\n \"data-collapsible\": collapsible,\n \"data-editable\": editable,\n \"data-position\": dataPosition,\n \"data-priority\": dataPriority = \"2\",\n } = child.props as OverflowChild;\n\n const priority = options?.getPriority?.(child, index);\n\n return {\n closeable: closeable || options?.closeable,\n collapsible,\n editable: editable ? true : options?.editable,\n disabled,\n fullSize: null,\n id: idProp ?? id,\n index,\n element: child,\n label,\n position: dataPosition,\n priority: priority ?? Number.parseInt(dataPriority),\n size: 0,\n source: null,\n type: \"child\",\n } as OverflowItem;\n};\n\nconst createChildItems = (\n children: React.ReactNode,\n idRoot: string,\n options?: OverflowCollectionOptions,\n): OverflowItem<\"child\">[] | undefined => {\n if (children) {\n return mapReactElementChildren(children, (child, index) => {\n const id = `${idRoot}-${index}`;\n return childItem(child, id, index, options);\n });\n }\n};\n\nconst createInjectedContent = (\n items: Array<InjectedSourceItem | InjectedChildItem>,\n idRoot: string,\n startIndex: number,\n): OverflowItem<\"source\" | \"child\">[] => {\n return items.map((item, i) => {\n const index = startIndex + i;\n const id = `${idRoot}-${index}`;\n const { source } = item as InjectedSourceItem;\n if (source) {\n const injectedItem = sourceItem(source, id, index);\n injectedItem.isInjectedItem = true;\n return injectedItem;\n }\n const { element } = item as InjectedChildItem;\n const injectedItem = childItem(element, id, index);\n injectedItem.isInjectedItem = true;\n return injectedItem;\n });\n};\n\nexport type OverflowReducer = Reducer<OverflowItems, OverflowAction>;\n\nconst defaultOptions = {};\n\nexport type OverflowReducerInitialisationProps = {\n children?: ReactNode;\n source?: OverflowSource[];\n injectedItems?: any[];\n idRoot: string;\n options?: OverflowCollectionOptions;\n};\n\nexport const reducerInitialiser: (\n props: OverflowReducerInitialisationProps,\n) => OverflowItems = ({\n children,\n source,\n injectedItems = [],\n idRoot,\n options = defaultOptions,\n}) => {\n const providedContent: OverflowItems =\n createChildItems(children, idRoot, options) ||\n createSourceItems(source, idRoot, options) ||\n [];\n const injectedContent = createInjectedContent(\n injectedItems,\n idRoot,\n providedContent.length,\n );\n return providedContent.concat(injectedContent);\n};\n\nconst collapsingItem = (\n items: OverflowItem[],\n { overflowItem }: SingleItemAction,\n) =>\n items.map((item) =>\n item === overflowItem\n ? {\n ...item,\n collapsing: true,\n }\n : item,\n );\n\nconst uncollapseDynamicItem = (\n items: OverflowItem[],\n { overflowItem }: SingleItemAction,\n) =>\n items.map((item) =>\n item === overflowItem\n ? {\n ...item,\n collapsed: false,\n collapsing: true,\n size: item.fullSize as number,\n fullSize: null,\n }\n : item,\n );\n\nconst collapseInstantItem = (\n items: OverflowItem[],\n { overflowItem }: SingleItemAction,\n) =>\n items.map((item) =>\n item === overflowItem\n ? {\n ...item,\n collapsed: true,\n }\n : item,\n );\n\nconst replaceItem = (\n items: OverflowItem[],\n { overflowItem }: SingleItemAction,\n) =>\n items.map((item) =>\n item.index === overflowItem?.index ? overflowItem : item,\n );\n\nconst updateItems = (\n items: OverflowItem[],\n { overflowItems = [] }: MultiItemAction,\n) => {\n return items.map((item) => {\n const targetItem = overflowItems.find((i) => i.id === item.id);\n return targetItem ? { ...item, ...targetItem } : item;\n });\n};\n\nconst restoreCollapsingItem = (items: OverflowItem[]) => {\n const collapsingItem = items.find(\n ({ collapsible, collapsing }) => collapsible === \"dynamic\" && collapsing,\n );\n const collapsedItem = items.find(\n ({ collapsible, collapsed }) => collapsible === \"dynamic\" && collapsed,\n );\n return items.map((item) => {\n if (item === collapsingItem) {\n return {\n ...item,\n collapsing: false,\n };\n }\n if (item === collapsedItem) {\n return {\n ...item,\n collapsed: false,\n collapsing: true,\n };\n }\n return item;\n });\n};\n\nconst collapseDynamicItem = (\n items: OverflowItem[],\n { overflowItem, collapsedSize = 0, minSize = 0 }: DynamicCollapseAction,\n) => {\n const remainingUncollpasedItems = items.filter(\n (i) => i.collapsible === \"dynamic\" && !i.collapsed && i !== overflowItem,\n );\n const lastUncollapsedItem = remainingUncollpasedItems.pop();\n\n return items.map((item) => {\n if (item === overflowItem) {\n return {\n ...item,\n collapsing: false,\n collapsed: true,\n fullSize: item.size,\n minSize,\n size: collapsedSize,\n };\n }\n if (item === lastUncollapsedItem) {\n return {\n ...item,\n collapsing: true,\n };\n }\n return item;\n });\n};\n\nconst addSourceItem = (\n items: OverflowItem<any>[],\n { idRoot, source }: SourceAction,\n): OverflowItem[] => {\n const index = items.length;\n return items.concat(sourceItem(source, `${idRoot}-${index}`, index));\n};\n\nconst removeItem = (\n items: OverflowItem<any>[],\n { indexPosition }: RemoveItemAction,\n): OverflowItem[] => {\n return items.slice(0, indexPosition).concat(items.slice(indexPosition + 1));\n};\n\nconst addOverflowIndicator = (\n items: OverflowItem<any>[],\n { overflowItem }: SingleItemAction,\n) => {\n // Guard against accidental duplicate overflowIndicator\n if (!items.find((i) => i.isOverflowIndicator)) {\n if (items.find((i) => i.label === \"Add Tab\")) {\n const [addTab] = items.slice(-1);\n return items\n .slice(0, -1)\n .concat({ ...overflowItem, index: addTab.index })\n .concat({ ...addTab, index: overflowItem.index });\n }\n return items.concat(overflowItem);\n }\n return items;\n};\n\nexport const overflowReducer: OverflowReducer = (state, action) => {\n switch (action.type) {\n case \"init\":\n return action.overflowItems ?? state;\n case \"add-overflow-indicator\":\n return addOverflowIndicator(state, action);\n\n case \"update-items\":\n return updateItems(state, action);\n\n case \"replace-item\":\n return replaceItem(state, action);\n\n case \"update-items-add-overflow-indicator\":\n return addOverflowIndicator(\n updateItems(state, {\n type: \"update-items\",\n overflowItems: action.overflowItems,\n }),\n { type: \"add-overflow-indicator\", overflowItem: action.overflowItem },\n );\n\n case \"update-items-remove-overflow-indicator\":\n return updateItems(state, {\n type: \"update-items\",\n overflowItems: action.overflowItems,\n }).filter((item) => !item.isOverflowIndicator);\n\n case \"collapsing-item\":\n return collapsingItem(state, action);\n\n case \"collapse-dynamic-item\":\n return collapseDynamicItem(state, action);\n\n case \"uncollapse-dynamic-item\":\n return uncollapseDynamicItem(state, action);\n\n case \"restore-collapsing-item\":\n return restoreCollapsingItem(state);\n\n case \"collapse-instant-item\":\n return collapseInstantItem(state, action);\n\n case \"add-source-item\":\n return addSourceItem(state, action);\n\n case \"remove-item\":\n return removeItem(state, action);\n\n default:\n return state;\n }\n};\n"],"names":["React","isValidElement","injectedItem","collapsingItem"],"mappings":"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"}
@@ -29,32 +29,29 @@ const measureContainer = (ref, orientation = "horizontal") => {
29
29
  rootContainerDepth: height,
30
30
  innerContainerDepth: innerHeight
31
31
  };
32
- } else {
33
- return {
34
- innerContainerSize: innerHeight,
35
- rootContainerDepth: width,
36
- innerContainerDepth: innerWidth
37
- };
38
32
  }
39
- } else {
40
- throw Error("measureContainer, innerContainer has no parent element");
33
+ return {
34
+ innerContainerSize: innerHeight,
35
+ rootContainerDepth: width,
36
+ innerContainerDepth: innerWidth
37
+ };
41
38
  }
39
+ throw Error("measureContainer, innerContainer has no parent element");
42
40
  };
43
41
  const isContainerOverflowing = (containerDepth, parentContainerDepth, innerElement, orientation) => {
44
42
  const isHorizontal = orientation === "horizontal";
45
43
  if (containerDepth > parentContainerDepth) {
46
44
  return true;
47
- } else {
48
- const { bottom, right } = innerElement.getBoundingClientRect();
49
- const maxPos = Array.from(innerElement.childNodes).reduce(
50
- (maxVal, child) => {
51
- const rect = child.getBoundingClientRect();
52
- return Math.max(isHorizontal ? rect.bottom : rect.right, maxVal);
53
- },
54
- isHorizontal ? bottom : right
55
- );
56
- return isHorizontal ? maxPos > bottom : maxPos > right;
57
45
  }
46
+ const { bottom, right } = innerElement.getBoundingClientRect();
47
+ const maxPos = Array.from(innerElement.childNodes).reduce(
48
+ (maxVal, child) => {
49
+ const rect = child.getBoundingClientRect();
50
+ return Math.max(isHorizontal ? rect.bottom : rect.right, maxVal);
51
+ },
52
+ isHorizontal ? bottom : right
53
+ );
54
+ return isHorizontal ? maxPos > bottom : maxPos > right;
58
55
  };
59
56
  const measureContainerOverflow = (ref, orientation = "horizontal") => {
60
57
  const { innerContainerDepth, innerContainerSize, rootContainerDepth } = measureContainer(ref, orientation);
@@ -72,13 +69,13 @@ function measureElementSize(element, dimension = "width", includeAutoMargin = fa
72
69
  const { padEnd = false, padStart = false } = element.dataset;
73
70
  const style = getComputedStyle(element);
74
71
  const [start, end] = dimension === "width" ? LEFT_RIGHT : TOP_BOTTOM;
75
- const marginStart = padStart && !includeAutoMargin ? 0 : parseInt(style.getPropertyValue(`margin-${start}`), 10);
76
- const marginEnd = padEnd && !includeAutoMargin ? 0 : parseInt(style.getPropertyValue(`margin-${end}`), 10);
72
+ const marginStart = padStart && !includeAutoMargin ? 0 : Number.parseInt(style.getPropertyValue(`margin-${start}`), 10);
73
+ const marginEnd = padEnd && !includeAutoMargin ? 0 : Number.parseInt(style.getPropertyValue(`margin-${end}`), 10);
77
74
  let minWidth = size;
78
- const flexShrink = parseInt(style.getPropertyValue("flex-shrink"), 10);
75
+ const flexShrink = Number.parseInt(style.getPropertyValue("flex-shrink"), 10);
79
76
  if (flexShrink > 0) {
80
- const flexBasis = parseInt(style.getPropertyValue("flex-basis"), 10);
81
- if (!isNaN(flexBasis) && flexBasis > 0) {
77
+ const flexBasis = Number.parseInt(style.getPropertyValue("flex-basis"), 10);
78
+ if (!Number.isNaN(flexBasis) && flexBasis > 0) {
82
79
  minWidth = flexBasis;
83
80
  }
84
81
  }
@@ -115,9 +112,8 @@ const measureOverflowItems = (items, dimension) => {
115
112
  size: measurements[i]
116
113
  }
117
114
  );
118
- } else {
119
- return items;
120
115
  }
116
+ return items;
121
117
  };
122
118
  const addAll = (sum, m) => sum + m.size;
123
119
  const getElementForItem = (ref, item) => ref.current.querySelector(
@@ -126,7 +122,7 @@ const getElementForItem = (ref, item) => ref.current.querySelector(
126
122
  const getRuntimePadding = (el, ...dimensions) => {
127
123
  const targetStyle = getComputedStyle(el);
128
124
  return dimensions.map(
129
- (dimension) => parseInt(targetStyle.getPropertyValue(`padding-${dimension}`), 10)
125
+ (dimension) => Number.parseInt(targetStyle.getPropertyValue(`padding-${dimension}`), 10)
130
126
  );
131
127
  };
132
128
 
@@ -1 +1 @@
1
- {"version":3,"file":"overflowUtils.js","sources":["../src/responsive/overflowUtils.tsx"],"sourcesContent":["import {\n collapsibleType,\n ElementRef,\n OverflowItem,\n orientationType,\n} from \"./overflowTypes\";\n\nexport const DropdownPlaceholder = () => null;\nexport const getDropdownPlaceholder = () => <DropdownPlaceholder />;\n\nexport type heightOrWidth = \"width\" | \"height\";\nexport const NO_DATA = {};\nconst LEFT_RIGHT = [\"left\", \"right\"];\nconst TOP_BOTTOM = [\"top\", \"bottom\"];\n\nexport const allExceptOverflowIndicator = (sum: number, m: OverflowItem) =>\n sum + (m.isOverflowIndicator ? 0 : m.size);\n\nexport const isCollapsed = (item: OverflowItem): boolean =>\n item.collapsed === true;\nexport const isCollapsing = (item: OverflowItem): boolean =>\n item.collapsing === true;\nexport const isCollapsedOrCollapsing = (item: OverflowItem): boolean =>\n isCollapsed(item) || isCollapsing(item);\nexport const isOverflowed = (item: OverflowItem): boolean =>\n item.overflowed === true;\nexport const notOverflowed = (item: OverflowItem): boolean =>\n !isOverflowed(item);\n\nexport const isCollapsible = (item: OverflowItem) =>\n item.collapsible === \"instant\" || item.collapsible === \"dynamic\";\n\nexport const getIsOverflowed = (managedItems: OverflowItem[]) =>\n managedItems.some(isOverflowed);\n\nexport const measureContainer = (\n ref: ElementRef,\n orientation: orientationType = \"horizontal\"\n): {\n innerContainerSize: number;\n rootContainerDepth: number;\n innerContainerDepth: number;\n} => {\n const innerElement = ref.current as HTMLElement;\n const container = innerElement.parentElement;\n if (container) {\n const { width: innerWidth, height: innerHeight } =\n innerElement.getBoundingClientRect();\n const { width, height } = container.getBoundingClientRect();\n if (orientation === \"horizontal\") {\n return {\n innerContainerSize: innerWidth,\n rootContainerDepth: height,\n innerContainerDepth: innerHeight,\n };\n } else {\n return {\n innerContainerSize: innerHeight,\n rootContainerDepth: width,\n innerContainerDepth: innerWidth,\n };\n }\n } else {\n throw Error(\"measureContainer, innerContainer has no parent element\");\n }\n};\n\nconst isContainerOverflowing = (\n containerDepth: number,\n parentContainerDepth: number,\n innerElement: HTMLElement,\n orientation: orientationType\n) => {\n const isHorizontal = orientation === \"horizontal\";\n // If true, this is a reliable indication of content wrapping, but the containerDepth\n // is not always correct\n if (containerDepth > parentContainerDepth) {\n return true;\n } else {\n // ... hence - expensive, but catches those situations where the containerDepth is wrong\n const { bottom, right } = innerElement.getBoundingClientRect();\n const maxPos = Array.from(innerElement.childNodes).reduce<number>(\n (maxVal, child) => {\n const rect = (child as HTMLElement).getBoundingClientRect();\n return Math.max(isHorizontal ? rect.bottom : rect.right, maxVal);\n },\n isHorizontal ? bottom : right\n );\n return isHorizontal ? maxPos > bottom : maxPos > right;\n }\n};\n\nexport const measureContainerOverflow = (\n ref: ElementRef,\n orientation: orientationType = \"horizontal\"\n): {\n isOverflowing: boolean;\n innerContainerSize: number;\n rootContainerDepth: number;\n} => {\n const { innerContainerDepth, innerContainerSize, rootContainerDepth } =\n measureContainer(ref, orientation);\n const innerElement = ref.current as HTMLElement;\n const isOverflowing = isContainerOverflowing(\n innerContainerDepth,\n rootContainerDepth,\n innerElement,\n orientation\n );\n\n return { isOverflowing, innerContainerSize, rootContainerDepth };\n};\n\n/**\n * Compute element size including margin.\n * Exclude margin where this has been applied for alignment, via margin: auto\n * which can be identified by the data-pad-end, data-pad-start attributes.\n **/\nexport function measureElementSize(\n element: HTMLElement,\n dimension: heightOrWidth = \"width\",\n includeAutoMargin = false\n): number {\n const { [dimension]: size } = element.getBoundingClientRect();\n const { padEnd = false, padStart = false } = element.dataset;\n const style = getComputedStyle(element);\n const [start, end] = dimension === \"width\" ? LEFT_RIGHT : TOP_BOTTOM;\n const marginStart =\n padStart && !includeAutoMargin\n ? 0\n : parseInt(style.getPropertyValue(`margin-${start}`), 10);\n const marginEnd =\n padEnd && !includeAutoMargin\n ? 0\n : parseInt(style.getPropertyValue(`margin-${end}`), 10);\n\n let minWidth = size;\n const flexShrink = parseInt(style.getPropertyValue(\"flex-shrink\"), 10);\n if (flexShrink > 0) {\n const flexBasis = parseInt(style.getPropertyValue(\"flex-basis\"), 10);\n // TODO should we consider percentage values ?\n // TODO are we still using flexBasis ?\n if (!isNaN(flexBasis) && flexBasis > 0) {\n minWidth = flexBasis;\n }\n }\n\n return marginStart + minWidth + marginEnd;\n}\n\nexport const byDescendingPriority = (m1: OverflowItem, m2: OverflowItem) => {\n let result = m1.priority - m2.priority;\n if (result === 0) {\n result = m1.index - m2.index;\n }\n return result;\n};\n\n// Helper function to try and determine the display label for an overflow item\n// Currently, Tab uses data-text, so this works for any Tab. Need to decide\n// whether this is appropriate for other components.\n// Note: Tab uses data-text for another reason, it is not implemented there just to\n// support this function.\n// There may be an aria attribute we should use instead\n// function getElementText(element: HTMLElement) {\n// if (element.dataset.text) {\n// return element.dataset.text;\n// }\n// const textNode = element.querySelector(\"[data-text]\") as HTMLElement;\n// if (textNode) {\n// return textNode.dataset.text;\n// }\n// return \"\";\n// }\n// const asCollapsibleType = (value?: string): collapsibleType | undefined =>\n// value === \"instant\" || value == \"dynamic\"\n// ? (value as collapsibleType)\n// : undefined;\n\nexport const getOverflowIndicator = (managedItems: OverflowItem[]) =>\n managedItems.find((item) => item.isOverflowIndicator);\n\n// TODO whats the right way to deduce the label. AccessibleText added\n// to eg delete button makes innerText unreliable.\n// const getLabelForElement = (element: HTMLElement) =>\n// element.title || getElementText(element) || element.innerText;\n\nconst getPriority = (item: OverflowItem) => item.priority;\n\nexport const popNextItemByPriority = (\n items: OverflowItem[]\n): OverflowItem | null => {\n const maxPriority = Math.max(...items.map(getPriority));\n for (let i = items.length - 1; i >= 0; i--) {\n if (!items[i].isOverflowIndicator && items[i].priority === maxPriority) {\n return items.splice(i, 1)[0];\n }\n }\n return null;\n};\n\nexport const measureOverflowItems = (\n items: OverflowItem[],\n dimension: heightOrWidth\n): OverflowItem[] => {\n const measurements = items.map(({ id }) => {\n const childElement = document.getElementById(id);\n const size = childElement ? measureElementSize(childElement, dimension) : 0;\n return size;\n });\n\n if (measurements.some((size, i) => size !== items[i].size)) {\n return items.map((item, i) =>\n item.size === measurements[i]\n ? item\n : {\n ...item,\n size: measurements[i],\n }\n );\n } else {\n return items;\n }\n};\n\nexport const addAll = (sum: number, m: OverflowItem): number => sum + m.size;\n\nexport const getElementForItem = (ref: ElementRef, item: OverflowItem) =>\n ref.current!.querySelector(\n `:scope > [data-index='${item.index}']`\n ) as HTMLElement;\n\ntype dimension = \"left\" | \"right\" | \"top\" | \"bottom\";\n\nexport const getRuntimePadding = (\n el: HTMLElement,\n ...dimensions: dimension[]\n): number[] => {\n const targetStyle = getComputedStyle(el);\n return dimensions.map((dimension) =>\n parseInt(targetStyle.getPropertyValue(`padding-${dimension}`), 10)\n );\n};\n"],"names":["jsx"],"mappings":"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"}
1
+ {"version":3,"file":"overflowUtils.js","sources":["../src/responsive/overflowUtils.tsx"],"sourcesContent":["import {\n type ElementRef,\n type OverflowItem,\n collapsibleType,\n type orientationType,\n} from \"./overflowTypes\";\n\nexport const DropdownPlaceholder = () => null;\nexport const getDropdownPlaceholder = () => <DropdownPlaceholder />;\n\nexport type heightOrWidth = \"width\" | \"height\";\nexport const NO_DATA = {};\nconst LEFT_RIGHT = [\"left\", \"right\"];\nconst TOP_BOTTOM = [\"top\", \"bottom\"];\n\nexport const allExceptOverflowIndicator = (sum: number, m: OverflowItem) =>\n sum + (m.isOverflowIndicator ? 0 : m.size);\n\nexport const isCollapsed = (item: OverflowItem): boolean =>\n item.collapsed === true;\nexport const isCollapsing = (item: OverflowItem): boolean =>\n item.collapsing === true;\nexport const isCollapsedOrCollapsing = (item: OverflowItem): boolean =>\n isCollapsed(item) || isCollapsing(item);\nexport const isOverflowed = (item: OverflowItem): boolean =>\n item.overflowed === true;\nexport const notOverflowed = (item: OverflowItem): boolean =>\n !isOverflowed(item);\n\nexport const isCollapsible = (item: OverflowItem) =>\n item.collapsible === \"instant\" || item.collapsible === \"dynamic\";\n\nexport const getIsOverflowed = (managedItems: OverflowItem[]) =>\n managedItems.some(isOverflowed);\n\nexport const measureContainer = (\n ref: ElementRef,\n orientation: orientationType = \"horizontal\",\n): {\n innerContainerSize: number;\n rootContainerDepth: number;\n innerContainerDepth: number;\n} => {\n const innerElement = ref.current as HTMLElement;\n const container = innerElement.parentElement;\n if (container) {\n const { width: innerWidth, height: innerHeight } =\n innerElement.getBoundingClientRect();\n const { width, height } = container.getBoundingClientRect();\n if (orientation === \"horizontal\") {\n return {\n innerContainerSize: innerWidth,\n rootContainerDepth: height,\n innerContainerDepth: innerHeight,\n };\n }\n return {\n innerContainerSize: innerHeight,\n rootContainerDepth: width,\n innerContainerDepth: innerWidth,\n };\n }\n throw Error(\"measureContainer, innerContainer has no parent element\");\n};\n\nconst isContainerOverflowing = (\n containerDepth: number,\n parentContainerDepth: number,\n innerElement: HTMLElement,\n orientation: orientationType,\n) => {\n const isHorizontal = orientation === \"horizontal\";\n // If true, this is a reliable indication of content wrapping, but the containerDepth\n // is not always correct\n if (containerDepth > parentContainerDepth) {\n return true;\n }\n // ... hence - expensive, but catches those situations where the containerDepth is wrong\n const { bottom, right } = innerElement.getBoundingClientRect();\n const maxPos = Array.from(innerElement.childNodes).reduce<number>(\n (maxVal, child) => {\n const rect = (child as HTMLElement).getBoundingClientRect();\n return Math.max(isHorizontal ? rect.bottom : rect.right, maxVal);\n },\n isHorizontal ? bottom : right,\n );\n return isHorizontal ? maxPos > bottom : maxPos > right;\n};\n\nexport const measureContainerOverflow = (\n ref: ElementRef,\n orientation: orientationType = \"horizontal\",\n): {\n isOverflowing: boolean;\n innerContainerSize: number;\n rootContainerDepth: number;\n} => {\n const { innerContainerDepth, innerContainerSize, rootContainerDepth } =\n measureContainer(ref, orientation);\n const innerElement = ref.current as HTMLElement;\n const isOverflowing = isContainerOverflowing(\n innerContainerDepth,\n rootContainerDepth,\n innerElement,\n orientation,\n );\n\n return { isOverflowing, innerContainerSize, rootContainerDepth };\n};\n\n/**\n * Compute element size including margin.\n * Exclude margin where this has been applied for alignment, via margin: auto\n * which can be identified by the data-pad-end, data-pad-start attributes.\n **/\nexport function measureElementSize(\n element: HTMLElement,\n dimension: heightOrWidth = \"width\",\n includeAutoMargin = false,\n): number {\n const { [dimension]: size } = element.getBoundingClientRect();\n const { padEnd = false, padStart = false } = element.dataset;\n const style = getComputedStyle(element);\n const [start, end] = dimension === \"width\" ? LEFT_RIGHT : TOP_BOTTOM;\n const marginStart =\n padStart && !includeAutoMargin\n ? 0\n : Number.parseInt(style.getPropertyValue(`margin-${start}`), 10);\n const marginEnd =\n padEnd && !includeAutoMargin\n ? 0\n : Number.parseInt(style.getPropertyValue(`margin-${end}`), 10);\n\n let minWidth = size;\n const flexShrink = Number.parseInt(style.getPropertyValue(\"flex-shrink\"), 10);\n if (flexShrink > 0) {\n const flexBasis = Number.parseInt(style.getPropertyValue(\"flex-basis\"), 10);\n // TODO should we consider percentage values ?\n // TODO are we still using flexBasis ?\n if (!Number.isNaN(flexBasis) && flexBasis > 0) {\n minWidth = flexBasis;\n }\n }\n\n return marginStart + minWidth + marginEnd;\n}\n\nexport const byDescendingPriority = (m1: OverflowItem, m2: OverflowItem) => {\n let result = m1.priority - m2.priority;\n if (result === 0) {\n result = m1.index - m2.index;\n }\n return result;\n};\n\n// Helper function to try and determine the display label for an overflow item\n// Currently, Tab uses data-text, so this works for any Tab. Need to decide\n// whether this is appropriate for other components.\n// Note: Tab uses data-text for another reason, it is not implemented there just to\n// support this function.\n// There may be an aria attribute we should use instead\n// function getElementText(element: HTMLElement) {\n// if (element.dataset.text) {\n// return element.dataset.text;\n// }\n// const textNode = element.querySelector(\"[data-text]\") as HTMLElement;\n// if (textNode) {\n// return textNode.dataset.text;\n// }\n// return \"\";\n// }\n// const asCollapsibleType = (value?: string): collapsibleType | undefined =>\n// value === \"instant\" || value == \"dynamic\"\n// ? (value as collapsibleType)\n// : undefined;\n\nexport const getOverflowIndicator = (managedItems: OverflowItem[]) =>\n managedItems.find((item) => item.isOverflowIndicator);\n\n// TODO whats the right way to deduce the label. AccessibleText added\n// to eg delete button makes innerText unreliable.\n// const getLabelForElement = (element: HTMLElement) =>\n// element.title || getElementText(element) || element.innerText;\n\nconst getPriority = (item: OverflowItem) => item.priority;\n\nexport const popNextItemByPriority = (\n items: OverflowItem[],\n): OverflowItem | null => {\n const maxPriority = Math.max(...items.map(getPriority));\n for (let i = items.length - 1; i >= 0; i--) {\n if (!items[i].isOverflowIndicator && items[i].priority === maxPriority) {\n return items.splice(i, 1)[0];\n }\n }\n return null;\n};\n\nexport const measureOverflowItems = (\n items: OverflowItem[],\n dimension: heightOrWidth,\n): OverflowItem[] => {\n const measurements = items.map(({ id }) => {\n const childElement = document.getElementById(id);\n const size = childElement ? measureElementSize(childElement, dimension) : 0;\n return size;\n });\n\n if (measurements.some((size, i) => size !== items[i].size)) {\n return items.map((item, i) =>\n item.size === measurements[i]\n ? item\n : {\n ...item,\n size: measurements[i],\n },\n );\n }\n return items;\n};\n\nexport const addAll = (sum: number, m: OverflowItem): number => sum + m.size;\n\nexport const getElementForItem = (ref: ElementRef, item: OverflowItem) =>\n ref.current!.querySelector(\n `:scope > [data-index='${item.index}']`,\n ) as HTMLElement;\n\ntype dimension = \"left\" | \"right\" | \"top\" | \"bottom\";\n\nexport const getRuntimePadding = (\n el: HTMLElement,\n ...dimensions: dimension[]\n): number[] => {\n const targetStyle = getComputedStyle(el);\n return dimensions.map((dimension) =>\n Number.parseInt(targetStyle.getPropertyValue(`padding-${dimension}`), 10),\n );\n};\n"],"names":["jsx"],"mappings":"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"}
@@ -7,7 +7,10 @@ var React = require('react');
7
7
  var overflowUtils = require('./overflowUtils.js');
8
8
 
9
9
  const UNCOLLAPSED_DYNAMIC_ITEMS = '[data-collapsible="dynamic"]:not([data-collapsed="true"]):not([data-collapsing="true"])';
10
- const hasUncollapsedDynamicItems = (containerRef) => containerRef.current.querySelector(UNCOLLAPSED_DYNAMIC_ITEMS) !== null;
10
+ const hasUncollapsedDynamicItems = (containerRef) => {
11
+ var _a;
12
+ return ((_a = containerRef.current) == null ? void 0 : _a.querySelector(UNCOLLAPSED_DYNAMIC_ITEMS)) !== null;
13
+ };
11
14
  const thereAreCollapsibleItemsAndTheyAreAllCollapsed = (items) => {
12
15
  const collapsibleItems = items.filter(overflowUtils.isCollapsible);
13
16
  return collapsibleItems.length > 0 && collapsibleItems.every(overflowUtils.isCollapsed);
@@ -15,8 +18,6 @@ const thereAreCollapsibleItemsAndTheyAreAllCollapsed = (items) => {
15
18
  const nextItemToCollapse = (listItems) => listItems.filter(overflowUtils.isCollapsible).sort(overflowUtils.byDescendingPriority).slice(-1)[0];
16
19
  const useDynamicCollapse = ({
17
20
  collectionHook,
18
- innerContainerSize = 0,
19
- label = "Toolbar",
20
21
  overflowItemsRef: managedItemsRef,
21
22
  overflowContainerRef: ref,
22
23
  orientation
@@ -129,9 +130,8 @@ const useDynamicCollapse = ({
129
130
  overflowItem: collapsingItem
130
131
  });
131
132
  return true;
132
- } else {
133
- return false;
134
133
  }
134
+ return false;
135
135
  }, [dispatch, managedItemsRef, ref]);
136
136
  core.useIsomorphicLayoutEffect(() => {
137
137
  if (newCollapsingItem) {
@@ -1 +1 @@
1
- {"version":3,"file":"useDynamicCollapse.js","sources":["../src/responsive/useDynamicCollapse.ts"],"sourcesContent":["import { useIsomorphicLayoutEffect } from \"@salt-ds/core\";\nimport { useCallback, useState } from \"react\";\nimport {\n ElementRef,\n OverflowItem,\n OverflowHookProps,\n DynamicCollapseHookResult,\n} from \"./overflowTypes\";\nimport {\n byDescendingPriority,\n getElementForItem,\n getRuntimePadding,\n isCollapsed,\n isCollapsible,\n measureContainerOverflow,\n measureElementSize,\n} from \"./overflowUtils\";\n\nconst UNCOLLAPSED_DYNAMIC_ITEMS =\n '[data-collapsible=\"dynamic\"]:not([data-collapsed=\"true\"]):not([data-collapsing=\"true\"])';\n\nconst hasUncollapsedDynamicItems = (containerRef: ElementRef) =>\n containerRef.current!.querySelector(UNCOLLAPSED_DYNAMIC_ITEMS) !== null;\n\nconst thereAreCollapsibleItemsAndTheyAreAllCollapsed = (\n items: OverflowItem[]\n) => {\n const collapsibleItems = items.filter(isCollapsible);\n return collapsibleItems.length > 0 && collapsibleItems.every(isCollapsed);\n};\n\nconst nextItemToCollapse = (listItems: OverflowItem[]): OverflowItem =>\n listItems.filter(isCollapsible).sort(byDescendingPriority).slice(-1)[0];\n\nexport const useDynamicCollapse = ({\n collectionHook,\n innerContainerSize = 0,\n label = \"Toolbar\",\n overflowItemsRef: managedItemsRef,\n overflowContainerRef: ref,\n orientation,\n}: OverflowHookProps): DynamicCollapseHookResult => {\n const { dispatch } = collectionHook;\n const [newCollapsingItem, setNewCollapsingItem] =\n useState<OverflowItem | null>(null);\n const restoreCollapsingItem = useCallback(() => {\n dispatch({\n type: \"restore-collapsing-item\",\n });\n }, [dispatch]);\n\n const collapseCollapsingItem = useCallback(\n (item: OverflowItem, target: HTMLElement, minSize: number) => {\n const styleDimension =\n orientation === \"horizontal\" ? \"minWidth\" : \"minHeight\";\n // TODO do we really want to do this here ?\n target.style[styleDimension] = `${minSize}px`;\n const size = measureElementSize(target);\n\n dispatch({\n type: \"collapse-dynamic-item\",\n overflowItem: item,\n collapsedSize: size,\n minSize,\n });\n },\n [dispatch, orientation]\n );\n\n const checkDynamicContent = useCallback(\n (containerHasGrown?: boolean) => {\n const { current: managedItems } = managedItemsRef;\n // The order must matter here\n const collapsingChild = managedItems.find(\n ({ collapsible, collapsing }) => collapsible === \"dynamic\" && collapsing\n );\n const collapsedChild = managedItems.find(\n ({ collapsible, collapsed }) => collapsible === \"dynamic\" && collapsed\n );\n\n if (!collapsingChild && !collapsedChild) {\n return;\n }\n if (collapsedChild && !collapsingChild) {\n // TODO do we need a check to see whether we now have enough space to completely uncollapse the item ?\n // We may be able to uncollapse one or more items before the one we set to collapsing\n\n dispatch({\n type: \"uncollapse-dynamic-item\",\n overflowItem: collapsedChild,\n });\n } else if (collapsingChild) {\n if (containerHasGrown && collapsedChild) {\n const collapsingElement = getElementForItem(ref, collapsingChild);\n const dimension = orientation === \"horizontal\" ? \"width\" : \"height\";\n // can we avoid measuring ths element on every resize event ?\n const size = measureElementSize(collapsingElement, dimension);\n // collapsingElement.getBoundingClientRect();\n\n // We don't restore a collapsing item unless there is at least one collapsed item\n if (collapsedChild && size === collapsingChild.size) {\n restoreCollapsingItem();\n }\n } else {\n // Note we are going to compare width with minWidth. Margin is ignored\n // use getBoundingClientRect rather than measureNode\n const dimension = orientation === \"horizontal\" ? \"width\" : \"height\";\n const collapsingElement = getElementForItem(ref, collapsingChild);\n const { [dimension]: measuredSizeOfCollapsingElement } =\n collapsingElement.getBoundingClientRect();\n // minsize should be the size of the last item in the tooltray\n const [padStart, padEnd] = getRuntimePadding(\n collapsingElement,\n \"left\",\n \"right\"\n );\n //TODO we don't really want to measure the last item in the collapsing container\n // we want to measure the width of the item that will be the last to overflow.\n const lastTooltrayItem = collapsingElement.querySelector(\n \".Responsive-inner > :last-child\"\n );\n if (lastTooltrayItem) {\n const { [dimension]: childMinSize } =\n lastTooltrayItem.getBoundingClientRect();\n const minSize = padStart + childMinSize + padEnd;\n if (Math.floor(measuredSizeOfCollapsingElement) <= minSize) {\n collapseCollapsingItem(\n collapsingChild,\n collapsingElement,\n minSize\n );\n }\n }\n }\n }\n },\n [\n collapseCollapsingItem,\n dispatch,\n managedItemsRef,\n orientation,\n ref,\n restoreCollapsingItem,\n ]\n );\n\n const handleResize = useCallback(\n (size: number, containerHasGrown?: boolean) => {\n const { current: managedItems } = managedItemsRef;\n const { isOverflowing: willOverflow } = measureContainerOverflow(\n ref,\n orientation\n );\n\n const collapsingItem = managedItems.find((item) => item.collapsing);\n\n if (collapsingItem) {\n checkDynamicContent(containerHasGrown);\n } else if (\n containerHasGrown &&\n !willOverflow &&\n thereAreCollapsibleItemsAndTheyAreAllCollapsed(managedItems)\n ) {\n checkDynamicContent(true);\n }\n },\n [checkDynamicContent, managedItemsRef, orientation, ref]\n );\n\n const resetMeasurements = useCallback(() => {\n const { current: managedItems } = managedItemsRef;\n const hasDynamicItems = hasUncollapsedDynamicItems(ref);\n if (hasDynamicItems) {\n const collapsingItem = nextItemToCollapse(managedItems);\n setNewCollapsingItem(collapsingItem);\n\n dispatch({\n type: \"collapsing-item\",\n overflowItem: collapsingItem,\n });\n return true;\n } else {\n return false;\n }\n }, [dispatch, managedItemsRef, ref]);\n\n useIsomorphicLayoutEffect(() => {\n if (newCollapsingItem) {\n checkDynamicContent(false);\n }\n }, [checkDynamicContent, newCollapsingItem]);\n\n return {\n onResize: handleResize,\n resetMeasurements,\n };\n};\n"],"names":["isCollapsible","isCollapsed","byDescendingPriority","useState","useCallback","measureElementSize","getElementForItem","getRuntimePadding","measureContainerOverflow","useIsomorphicLayoutEffect"],"mappings":"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"}
1
+ {"version":3,"file":"useDynamicCollapse.js","sources":["../src/responsive/useDynamicCollapse.ts"],"sourcesContent":["import { useIsomorphicLayoutEffect } from \"@salt-ds/core\";\nimport { useCallback, useState } from \"react\";\nimport type {\n DynamicCollapseHookResult,\n ElementRef,\n OverflowHookProps,\n OverflowItem,\n} from \"./overflowTypes\";\nimport {\n byDescendingPriority,\n getElementForItem,\n getRuntimePadding,\n isCollapsed,\n isCollapsible,\n measureContainerOverflow,\n measureElementSize,\n} from \"./overflowUtils\";\n\nconst UNCOLLAPSED_DYNAMIC_ITEMS =\n '[data-collapsible=\"dynamic\"]:not([data-collapsed=\"true\"]):not([data-collapsing=\"true\"])';\n\nconst hasUncollapsedDynamicItems = (containerRef: ElementRef) =>\n containerRef.current?.querySelector(UNCOLLAPSED_DYNAMIC_ITEMS) !== null;\n\nconst thereAreCollapsibleItemsAndTheyAreAllCollapsed = (\n items: OverflowItem[],\n) => {\n const collapsibleItems = items.filter(isCollapsible);\n return collapsibleItems.length > 0 && collapsibleItems.every(isCollapsed);\n};\n\nconst nextItemToCollapse = (listItems: OverflowItem[]): OverflowItem =>\n listItems.filter(isCollapsible).sort(byDescendingPriority).slice(-1)[0];\n\nexport const useDynamicCollapse = ({\n collectionHook,\n overflowItemsRef: managedItemsRef,\n overflowContainerRef: ref,\n orientation,\n}: OverflowHookProps): DynamicCollapseHookResult => {\n const { dispatch } = collectionHook;\n const [newCollapsingItem, setNewCollapsingItem] =\n useState<OverflowItem | null>(null);\n const restoreCollapsingItem = useCallback(() => {\n dispatch({\n type: \"restore-collapsing-item\",\n });\n }, [dispatch]);\n\n const collapseCollapsingItem = useCallback(\n (item: OverflowItem, target: HTMLElement, minSize: number) => {\n const styleDimension =\n orientation === \"horizontal\" ? \"minWidth\" : \"minHeight\";\n // TODO do we really want to do this here ?\n target.style[styleDimension] = `${minSize}px`;\n const size = measureElementSize(target);\n\n dispatch({\n type: \"collapse-dynamic-item\",\n overflowItem: item,\n collapsedSize: size,\n minSize,\n });\n },\n [dispatch, orientation],\n );\n\n const checkDynamicContent = useCallback(\n (containerHasGrown?: boolean) => {\n const { current: managedItems } = managedItemsRef;\n // The order must matter here\n const collapsingChild = managedItems.find(\n ({ collapsible, collapsing }) =>\n collapsible === \"dynamic\" && collapsing,\n );\n const collapsedChild = managedItems.find(\n ({ collapsible, collapsed }) => collapsible === \"dynamic\" && collapsed,\n );\n\n if (!collapsingChild && !collapsedChild) {\n return;\n }\n if (collapsedChild && !collapsingChild) {\n // TODO do we need a check to see whether we now have enough space to completely uncollapse the item ?\n // We may be able to uncollapse one or more items before the one we set to collapsing\n\n dispatch({\n type: \"uncollapse-dynamic-item\",\n overflowItem: collapsedChild,\n });\n } else if (collapsingChild) {\n if (containerHasGrown && collapsedChild) {\n const collapsingElement = getElementForItem(ref, collapsingChild);\n const dimension = orientation === \"horizontal\" ? \"width\" : \"height\";\n // can we avoid measuring ths element on every resize event ?\n const size = measureElementSize(collapsingElement, dimension);\n // collapsingElement.getBoundingClientRect();\n\n // We don't restore a collapsing item unless there is at least one collapsed item\n if (collapsedChild && size === collapsingChild.size) {\n restoreCollapsingItem();\n }\n } else {\n // Note we are going to compare width with minWidth. Margin is ignored\n // use getBoundingClientRect rather than measureNode\n const dimension = orientation === \"horizontal\" ? \"width\" : \"height\";\n const collapsingElement = getElementForItem(ref, collapsingChild);\n const { [dimension]: measuredSizeOfCollapsingElement } =\n collapsingElement.getBoundingClientRect();\n // minsize should be the size of the last item in the tooltray\n const [padStart, padEnd] = getRuntimePadding(\n collapsingElement,\n \"left\",\n \"right\",\n );\n //TODO we don't really want to measure the last item in the collapsing container\n // we want to measure the width of the item that will be the last to overflow.\n const lastTooltrayItem = collapsingElement.querySelector(\n \".Responsive-inner > :last-child\",\n );\n if (lastTooltrayItem) {\n const { [dimension]: childMinSize } =\n lastTooltrayItem.getBoundingClientRect();\n const minSize = padStart + childMinSize + padEnd;\n if (Math.floor(measuredSizeOfCollapsingElement) <= minSize) {\n collapseCollapsingItem(\n collapsingChild,\n collapsingElement,\n minSize,\n );\n }\n }\n }\n }\n },\n [\n collapseCollapsingItem,\n dispatch,\n managedItemsRef,\n orientation,\n ref,\n restoreCollapsingItem,\n ],\n );\n\n const handleResize = useCallback(\n (size: number, containerHasGrown?: boolean) => {\n const { current: managedItems } = managedItemsRef;\n const { isOverflowing: willOverflow } = measureContainerOverflow(\n ref,\n orientation,\n );\n\n const collapsingItem = managedItems.find((item) => item.collapsing);\n\n if (collapsingItem) {\n checkDynamicContent(containerHasGrown);\n } else if (\n containerHasGrown &&\n !willOverflow &&\n thereAreCollapsibleItemsAndTheyAreAllCollapsed(managedItems)\n ) {\n checkDynamicContent(true);\n }\n },\n [checkDynamicContent, managedItemsRef, orientation, ref],\n );\n\n const resetMeasurements = useCallback(() => {\n const { current: managedItems } = managedItemsRef;\n const hasDynamicItems = hasUncollapsedDynamicItems(ref);\n if (hasDynamicItems) {\n const collapsingItem = nextItemToCollapse(managedItems);\n setNewCollapsingItem(collapsingItem);\n\n dispatch({\n type: \"collapsing-item\",\n overflowItem: collapsingItem,\n });\n return true;\n }\n return false;\n }, [dispatch, managedItemsRef, ref]);\n\n useIsomorphicLayoutEffect(() => {\n if (newCollapsingItem) {\n checkDynamicContent(false);\n }\n }, [checkDynamicContent, newCollapsingItem]);\n\n return {\n onResize: handleResize,\n resetMeasurements,\n };\n};\n"],"names":["isCollapsible","isCollapsed","byDescendingPriority","useState","useCallback","measureElementSize","getElementForItem","getRuntimePadding","measureContainerOverflow","useIsomorphicLayoutEffect"],"mappings":"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"}
@@ -18,13 +18,14 @@ const findItemToCollapse = (items) => {
18
18
  }
19
19
  };
20
20
  const uncollapseItems = (items, containerSize) => {
21
+ var _a;
21
22
  const visibleContentSize = items.reduce(overflowUtils.allExceptOverflowIndicator, 0);
22
23
  let diff = containerSize - visibleContentSize;
23
24
  const collapsed = items.filter((item) => item.collapsible === "instant" && item.collapsed).sort((i1, i2) => i2.index - i1.index);
24
25
  const result = [];
25
26
  while (collapsed.length) {
26
27
  const item = collapsed.pop();
27
- const itemDiff = item.fullSize - item.size;
28
+ const itemDiff = ((_a = item.fullSize) != null ? _a : 0) - item.size;
28
29
  if (diff >= itemDiff) {
29
30
  result.push({
30
31
  ...item,
@@ -43,7 +44,6 @@ const useInstantCollapse = ({
43
44
  collectionHook,
44
45
  hasOverflowedItems,
45
46
  innerContainerSize = 0,
46
- label = "Toolbar",
47
47
  overflowContainerRef: ref,
48
48
  overflowItemsRef,
49
49
  orientation
@@ -116,9 +116,8 @@ const useInstantCollapse = ({
116
116
  overflowItem
117
117
  });
118
118
  return true;
119
- } else {
120
- return false;
121
119
  }
120
+ return false;
122
121
  }
123
122
  },
124
123
  [dispatch, overflowItemsRef]