@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":"useOverflowLayout.js","sources":["../src/responsive/useOverflowLayout.ts"],"sourcesContent":["import { useCallback, useEffect, useRef } from \"react\";\nimport {\n ElementRef,\n ManagedListRef,\n OverflowItem,\n OverflowLayoutHookProps,\n} from \"./overflowTypes\";\n\nimport { getIsOverflowed, measureContainerOverflow } from \"./overflowUtils\";\nimport { useDynamicCollapse } from \"./useDynamicCollapse\";\nimport { useInstantCollapse } from \"./useInstantCollapse\";\nimport { useOverflow } from \"./useOverflow\";\nimport { useReclaimSpace } from \"./useReclaimSpace\";\nimport { ResizeHandler, useResizeObserver } from \"../responsive\";\n\nconst MONITORED_DIMENSIONS: { [key: string]: string[] } = {\n horizontal: [\"width\", \"scrollHeight\"],\n vertical: [\"height\", \"scrollWidth\"],\n none: [],\n};\n\ntype overflowUpdate = (item1: OverflowItem, item2: OverflowItem) => void;\n\n// we need id, just to be able to assign id to overflowIndicator in useOverflow\nexport const useOverflowLayout = ({\n collectionHook,\n id,\n orientation,\n label = \"Toolbar\",\n disableOverflow = false,\n}: OverflowLayoutHookProps): [ElementRef, overflowUpdate] => {\n const overflowContainerRef: ElementRef = useRef(null);\n const overflowItemsRef: ManagedListRef = useRef([]);\n const measurement = useRef({ innerContainerSize: 0, rootContainerDepth: 0 });\n const { innerContainerSize } = measurement.current;\n\n const { dispatch, version: collectionVersion } = collectionHook;\n overflowItemsRef.current = collectionHook.data;\n\n const {\n onResize: onOverflowResize,\n resetMeasurements: resetOverflowMeasurements,\n } = useOverflow({\n collectionHook,\n id,\n label,\n overflowItemsRef,\n orientation,\n overflowContainerRef,\n });\n\n const hasOverflowedItems = getIsOverflowed(collectionHook.data);\n // const hasOverflowedItems = getIsOverflowed(managedItems);\n\n const {\n onResize: onDynamicResize,\n resetMeasurements: resetDynamicMeasurements,\n } = useDynamicCollapse({\n collectionHook,\n innerContainerSize,\n label,\n overflowItemsRef,\n orientation,\n overflowContainerRef,\n });\n\n const {\n onResize: onInstantResize,\n resetMeasurements: resetInstantMeasurements,\n } = useInstantCollapse({\n collectionHook,\n hasOverflowedItems,\n innerContainerSize,\n label,\n overflowItemsRef,\n orientation,\n overflowContainerRef,\n });\n\n const { onResize: onReclaimResize } = useReclaimSpace({\n collectionHook,\n label,\n overflowItemsRef,\n orientation,\n overflowContainerRef,\n });\n\n const resizeHandler: ResizeHandler = useCallback(\n ({\n scrollHeight,\n height = scrollHeight,\n scrollWidth,\n width = scrollWidth,\n }) => {\n const size = orientation === \"horizontal\" ? width : height;\n if (typeof size === \"number\") {\n const { innerContainerSize } = measurement.current;\n const sizeDiff = size - innerContainerSize;\n // Tiny size diffs seem to be down to the relative sub-pixel innaccuracy of\n // ResizeObserver vs getBoundingClientRect\n if (Math.abs(sizeDiff) > 0.5) {\n measurement.current.innerContainerSize = size;\n const containerHasGrown = size > innerContainerSize;\n // Note: any one of these hooks may trigger a render which\n // may affect the overflow state that the next hook sees.\n // Hence, they all test for overflow internally and independently.\n onDynamicResize(size, containerHasGrown);\n onInstantResize(size, containerHasGrown);\n onOverflowResize(size, containerHasGrown);\n onReclaimResize(size, containerHasGrown);\n }\n }\n },\n [\n onDynamicResize,\n onInstantResize,\n onOverflowResize,\n onReclaimResize,\n orientation,\n ]\n );\n\n const measureAndInitialize = useCallback(() => {\n const { isOverflowing, ...contentWidthAndDepth } = measureContainerOverflow(\n overflowContainerRef,\n orientation\n );\n\n measurement.current = contentWidthAndDepth;\n const { innerContainerSize } = contentWidthAndDepth;\n // TODO check this with complex combinations\n let handled = resetInstantMeasurements(isOverflowing);\n if (!handled) {\n handled = resetDynamicMeasurements();\n if (!handled) {\n resetOverflowMeasurements?.(isOverflowing, innerContainerSize);\n }\n }\n }, [\n orientation,\n resetInstantMeasurements,\n resetDynamicMeasurements,\n resetOverflowMeasurements,\n ]);\n\n const switchPriorities = useCallback(\n (item1: OverflowItem, item2: OverflowItem) => {\n const { priority: priority1 } = item1;\n const { priority: priority2 } = item2;\n if (priority1 !== priority2) {\n dispatch({\n type: \"update-items\",\n overflowItems: [\n { id: item1.id, priority: priority2 },\n { id: item2.id, priority: priority1 },\n ],\n });\n // Why do we need a timeout here when we don't inside resizeHandler ?\n setTimeout(measureAndInitialize, 0);\n }\n },\n [dispatch, measureAndInitialize]\n );\n\n // Important that we register our resize handler before we measure and\n // initialize. The initialization may trigger changes which we want the\n // resize observer to detect (when we have nested overflowables).\n useResizeObserver(\n overflowContainerRef,\n MONITORED_DIMENSIONS[disableOverflow ? \"none\" : orientation],\n resizeHandler\n );\n\n // This hook runs after a measurememnt cycle, not after every single change to\n // collection data. The version attribute has been introduced specifically for this.\n useEffect(() => {\n if (!disableOverflow) {\n measureAndInitialize();\n }\n }, [collectionVersion, disableOverflow, measureAndInitialize]);\n\n return [overflowContainerRef, switchPriorities];\n};\n"],"names":["innerContainerSize"],"mappings":"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"}
1
+ {"version":3,"file":"useOverflowLayout.js","sources":["../src/responsive/useOverflowLayout.ts"],"sourcesContent":["import { useCallback, useEffect, useRef } from \"react\";\nimport type {\n ElementRef,\n ManagedListRef,\n OverflowItem,\n OverflowLayoutHookProps,\n} from \"./overflowTypes\";\n\nimport { type ResizeHandler, useResizeObserver } from \"../responsive\";\nimport { getIsOverflowed, measureContainerOverflow } from \"./overflowUtils\";\nimport { useDynamicCollapse } from \"./useDynamicCollapse\";\nimport { useInstantCollapse } from \"./useInstantCollapse\";\nimport { useOverflow } from \"./useOverflow\";\nimport { useReclaimSpace } from \"./useReclaimSpace\";\n\nconst MONITORED_DIMENSIONS: { [key: string]: string[] } = {\n horizontal: [\"width\", \"scrollHeight\"],\n vertical: [\"height\", \"scrollWidth\"],\n none: [],\n};\n\ntype overflowUpdate = (item1: OverflowItem, item2: OverflowItem) => void;\n\n// we need id, just to be able to assign id to overflowIndicator in useOverflow\nexport const useOverflowLayout = ({\n collectionHook,\n id,\n orientation,\n label = \"Toolbar\",\n disableOverflow = false,\n}: OverflowLayoutHookProps): [ElementRef, overflowUpdate] => {\n const overflowContainerRef: ElementRef = useRef(null);\n const overflowItemsRef: ManagedListRef = useRef([]);\n const measurement = useRef({ innerContainerSize: 0, rootContainerDepth: 0 });\n const { innerContainerSize } = measurement.current;\n\n const { dispatch, version: collectionVersion } = collectionHook;\n overflowItemsRef.current = collectionHook.data;\n\n const {\n onResize: onOverflowResize,\n resetMeasurements: resetOverflowMeasurements,\n } = useOverflow({\n collectionHook,\n id,\n label,\n overflowItemsRef,\n orientation,\n overflowContainerRef,\n });\n\n const hasOverflowedItems = getIsOverflowed(collectionHook.data);\n // const hasOverflowedItems = getIsOverflowed(managedItems);\n\n const {\n onResize: onDynamicResize,\n resetMeasurements: resetDynamicMeasurements,\n } = useDynamicCollapse({\n collectionHook,\n innerContainerSize,\n label,\n overflowItemsRef,\n orientation,\n overflowContainerRef,\n });\n\n const {\n onResize: onInstantResize,\n resetMeasurements: resetInstantMeasurements,\n } = useInstantCollapse({\n collectionHook,\n hasOverflowedItems,\n innerContainerSize,\n label,\n overflowItemsRef,\n orientation,\n overflowContainerRef,\n });\n\n const { onResize: onReclaimResize } = useReclaimSpace({\n collectionHook,\n label,\n overflowItemsRef,\n orientation,\n overflowContainerRef,\n });\n\n const resizeHandler: ResizeHandler = useCallback(\n ({\n scrollHeight,\n height = scrollHeight,\n scrollWidth,\n width = scrollWidth,\n }) => {\n const size = orientation === \"horizontal\" ? width : height;\n if (typeof size === \"number\") {\n const { innerContainerSize } = measurement.current;\n const sizeDiff = size - innerContainerSize;\n // Tiny size diffs seem to be down to the relative sub-pixel innaccuracy of\n // ResizeObserver vs getBoundingClientRect\n if (Math.abs(sizeDiff) > 0.5) {\n measurement.current.innerContainerSize = size;\n const containerHasGrown = size > innerContainerSize;\n // Note: any one of these hooks may trigger a render which\n // may affect the overflow state that the next hook sees.\n // Hence, they all test for overflow internally and independently.\n onDynamicResize(size, containerHasGrown);\n onInstantResize(size, containerHasGrown);\n onOverflowResize(size, containerHasGrown);\n onReclaimResize(size, containerHasGrown);\n }\n }\n },\n [\n onDynamicResize,\n onInstantResize,\n onOverflowResize,\n onReclaimResize,\n orientation,\n ],\n );\n\n const measureAndInitialize = useCallback(() => {\n const { isOverflowing, ...contentWidthAndDepth } = measureContainerOverflow(\n overflowContainerRef,\n orientation,\n );\n\n measurement.current = contentWidthAndDepth;\n const { innerContainerSize } = contentWidthAndDepth;\n // TODO check this with complex combinations\n let handled = resetInstantMeasurements(isOverflowing);\n if (!handled) {\n handled = resetDynamicMeasurements();\n if (!handled) {\n resetOverflowMeasurements?.(isOverflowing, innerContainerSize);\n }\n }\n }, [\n orientation,\n resetInstantMeasurements,\n resetDynamicMeasurements,\n resetOverflowMeasurements,\n ]);\n\n const switchPriorities = useCallback(\n (item1: OverflowItem, item2: OverflowItem) => {\n const { priority: priority1 } = item1;\n const { priority: priority2 } = item2;\n if (priority1 !== priority2) {\n dispatch({\n type: \"update-items\",\n overflowItems: [\n { id: item1.id, priority: priority2 },\n { id: item2.id, priority: priority1 },\n ],\n });\n // Why do we need a timeout here when we don't inside resizeHandler ?\n setTimeout(measureAndInitialize, 0);\n }\n },\n [dispatch, measureAndInitialize],\n );\n\n // Important that we register our resize handler before we measure and\n // initialize. The initialization may trigger changes which we want the\n // resize observer to detect (when we have nested overflowables).\n useResizeObserver(\n overflowContainerRef,\n MONITORED_DIMENSIONS[disableOverflow ? \"none\" : orientation],\n resizeHandler,\n );\n\n // This hook runs after a measurememnt cycle, not after every single change to\n // collection data. The version attribute has been introduced specifically for this.\n useEffect(() => {\n if (!disableOverflow) {\n measureAndInitialize();\n }\n }, [collectionVersion, disableOverflow, measureAndInitialize]);\n\n return [overflowContainerRef, switchPriorities];\n};\n"],"names":["innerContainerSize"],"mappings":"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"}
@@ -1,5 +1,5 @@
1
1
  import { useCallback } from 'react';
2
- import { popNextItemByPriority, measureContainerOverflow, getOverflowIndicator } from './overflowUtils.js';
2
+ import { measureContainerOverflow, getOverflowIndicator } from './overflowUtils.js';
3
3
 
4
4
  const getPriority = (item) => item.priority;
5
5
  const canReclaimSpace = (item) => item.collapsed && item.reclaimSpace;
@@ -17,11 +17,12 @@ const findNextOverflowedItem = (items) => {
17
17
  };
18
18
  const addAllVisible = (sum, m) => sum + (m.overflowed ? 0 : m.size);
19
19
  const canReleaseReclaimedSpace = (size, items) => {
20
+ var _a;
20
21
  const claimant = items.find(hasReclaimedSpace);
21
22
  const overflowedItem = findNextOverflowedItem(items);
22
23
  if (claimant && overflowedItem) {
23
24
  const renderedSize = items.reduce(addAllVisible, 0);
24
- const { size: indicatorSize } = getOverflowIndicator(items);
25
+ const { size: indicatorSize } = (_a = getOverflowIndicator(items)) != null ? _a : { size: 0 };
25
26
  const { size: overflowedSize } = overflowedItem;
26
27
  const reclaimableSpace = getReclaimableSpace(claimant);
27
28
  const renderedSizeAfterReclaim = renderedSize - reclaimableSpace - indicatorSize;
@@ -39,23 +40,6 @@ const useReclaimSpace = ({
39
40
  overflowContainerRef: ref,
40
41
  orientation
41
42
  }) => {
42
- useCallback(
43
- (visibleContentSize, containerSize) => {
44
- let newlyOverflowedItems = [];
45
- const { current: managedItems } = managedItemsRef;
46
- const visibleItems = managedItems.slice();
47
- while (visibleContentSize > containerSize) {
48
- const overflowedItem = popNextItemByPriority(visibleItems);
49
- if (overflowedItem === null) {
50
- break;
51
- }
52
- visibleContentSize -= overflowedItem.size;
53
- newlyOverflowedItems.push(overflowedItem);
54
- }
55
- return newlyOverflowedItems;
56
- },
57
- []
58
- );
59
43
  const releaseReclaimedSpace = useCallback(() => {
60
44
  const { current: managedItems } = managedItemsRef;
61
45
  const claimant = managedItems.find(hasReclaimedSpace);
@@ -72,7 +56,7 @@ const useReclaimSpace = ({
72
56
  }
73
57
  });
74
58
  }
75
- }, []);
59
+ }, [managedItemsRef, collectionHook.dispatch]);
76
60
  const handleResize = useCallback(
77
61
  (size, containerHasGrown) => {
78
62
  const { isOverflowing: willOverflow } = measureContainerOverflow(
@@ -99,7 +83,13 @@ const useReclaimSpace = ({
99
83
  }
100
84
  }
101
85
  },
102
- []
86
+ [
87
+ ref,
88
+ managedItemsRef,
89
+ releaseReclaimedSpace,
90
+ collectionHook.dispatch,
91
+ orientation
92
+ ]
103
93
  );
104
94
  return {
105
95
  onResize: handleResize
@@ -1 +1 @@
1
- {"version":3,"file":"useReclaimSpace.js","sources":["../src/responsive/useReclaimSpace.ts"],"sourcesContent":["import { useCallback } from \"react\";\nimport {\n OverflowItem,\n OverflowHookProps,\n OverflowHookResult,\n} from \"./overflowTypes\";\n\nimport {\n getOverflowIndicator,\n measureContainerOverflow,\n popNextItemByPriority,\n} from \"./overflowUtils\";\n\nconst getPriority = (item: OverflowItem) => item.priority;\n\nconst canReclaimSpace = (item: OverflowItem) =>\n item.collapsed && item.reclaimSpace;\n\nconst hasReclaimedSpace = (item: OverflowItem) => item.reclaimedSpace;\nconst getReclaimableSpace = ({ size, minSize = 0 }: OverflowItem) =>\n size - minSize;\n\nconst findNextOverflowedItem = (items: OverflowItem[]) => {\n const overflowedItems = items.filter((item) => item.overflowed);\n const minPriority = Math.min(...overflowedItems.map(getPriority));\n for (let i = 0; i < overflowedItems.length; i++) {\n if (overflowedItems[i].priority === minPriority) {\n return overflowedItems[i];\n }\n }\n return null;\n};\n\nexport const addAllVisible = (sum: number, m: OverflowItem) =>\n sum + (m.overflowed ? 0 : m.size);\n\nconst canReleaseReclaimedSpace = (size: number, items: OverflowItem[]) => {\n const claimant = items.find(hasReclaimedSpace);\n const overflowedItem = findNextOverflowedItem(items);\n if (claimant && overflowedItem) {\n const renderedSize = items.reduce(addAllVisible, 0);\n const { size: indicatorSize } = getOverflowIndicator(items)!;\n const { size: overflowedSize } = overflowedItem;\n // TODO we can discount the indicator size ONLY IF overflowed item is only overflowed item\n const reclaimableSpace = getReclaimableSpace(claimant);\n const renderedSizeAfterReclaim =\n renderedSize - reclaimableSpace - indicatorSize;\n const maxAvailableSpace = size - renderedSizeAfterReclaim;\n if (maxAvailableSpace >= overflowedSize) {\n return true;\n }\n }\n};\n\nconst mightBeAbleToReclaimSpace = (items: OverflowItem[]) =>\n items.some(canReclaimSpace);\n\n// We need to release the reclaimed space (i.e take it back from the collapsed item and re-assign it\n// as available space) when container grows and space now allows overflowed item to be 'un-wrapped'\n\nexport const useReclaimSpace = ({\n collectionHook,\n label = \"Toolbar\",\n overflowItemsRef: managedItemsRef,\n overflowContainerRef: ref,\n orientation,\n}: OverflowHookProps): OverflowHookResult => {\n const getAllOverflowedItems = useCallback(\n (visibleContentSize: number, containerSize: number) => {\n let newlyOverflowedItems = [];\n const { current: managedItems } = managedItemsRef;\n const visibleItems = managedItems.slice();\n while (visibleContentSize > containerSize) {\n const overflowedItem = popNextItemByPriority(visibleItems);\n if (overflowedItem === null) {\n break;\n }\n // eslint-disable-next-line no-param-reassign\n visibleContentSize -= overflowedItem.size;\n newlyOverflowedItems.push(overflowedItem);\n }\n return newlyOverflowedItems;\n },\n []\n );\n\n const releaseReclaimedSpace = useCallback(() => {\n const { current: managedItems } = managedItemsRef;\n\n const claimant = managedItems.find(hasReclaimedSpace);\n if (claimant) {\n // Might not always need to collapse, if there is enough available space for it to still be collapsing\n // collapse the claimant and turn off recvlaimed\n collectionHook.dispatch({\n type: \"replace-item\",\n overflowItem: {\n ...claimant,\n collapsed: true,\n collapsing: false,\n reclaimedSpace: undefined,\n size: claimant.minSize as number,\n fullSize: claimant.size,\n },\n });\n }\n }, []);\n const handleResize = useCallback(\n (size: number, containerHasGrown?: boolean) => {\n const { isOverflowing: willOverflow } = measureContainerOverflow(\n ref,\n orientation\n );\n const { current: managedItems } = managedItemsRef;\n\n if (containerHasGrown && canReleaseReclaimedSpace(size, managedItems)) {\n releaseReclaimedSpace();\n } else if (\n !containerHasGrown &&\n willOverflow &&\n mightBeAbleToReclaimSpace(managedItems)\n ) {\n const collapsedChild = managedItems.find(canReclaimSpace);\n if (collapsedChild) {\n collectionHook.dispatch({\n type: \"replace-item\",\n overflowItem: {\n ...collapsedChild,\n collapsed: false,\n collapsing: true,\n reclaimedSpace: true,\n size: collapsedChild.fullSize as number,\n fullSize: null,\n },\n });\n }\n }\n },\n []\n );\n\n return {\n onResize: handleResize,\n };\n};\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"useReclaimSpace.js","sources":["../src/responsive/useReclaimSpace.ts"],"sourcesContent":["import { useCallback } from \"react\";\nimport type {\n OverflowHookProps,\n OverflowHookResult,\n OverflowItem,\n} from \"./overflowTypes\";\n\nimport {\n getOverflowIndicator,\n measureContainerOverflow,\n} from \"./overflowUtils\";\n\nconst getPriority = (item: OverflowItem) => item.priority;\n\nconst canReclaimSpace = (item: OverflowItem) =>\n item.collapsed && item.reclaimSpace;\n\nconst hasReclaimedSpace = (item: OverflowItem) => item.reclaimedSpace;\nconst getReclaimableSpace = ({ size, minSize = 0 }: OverflowItem) =>\n size - minSize;\n\nconst findNextOverflowedItem = (items: OverflowItem[]) => {\n const overflowedItems = items.filter((item) => item.overflowed);\n const minPriority = Math.min(...overflowedItems.map(getPriority));\n for (let i = 0; i < overflowedItems.length; i++) {\n if (overflowedItems[i].priority === minPriority) {\n return overflowedItems[i];\n }\n }\n return null;\n};\n\nexport const addAllVisible = (sum: number, m: OverflowItem) =>\n sum + (m.overflowed ? 0 : m.size);\n\nconst canReleaseReclaimedSpace = (size: number, items: OverflowItem[]) => {\n const claimant = items.find(hasReclaimedSpace);\n const overflowedItem = findNextOverflowedItem(items);\n if (claimant && overflowedItem) {\n const renderedSize = items.reduce(addAllVisible, 0);\n const { size: indicatorSize } = getOverflowIndicator(items) ?? { size: 0 };\n const { size: overflowedSize } = overflowedItem;\n // TODO we can discount the indicator size ONLY IF overflowed item is only overflowed item\n const reclaimableSpace = getReclaimableSpace(claimant);\n const renderedSizeAfterReclaim =\n renderedSize - reclaimableSpace - indicatorSize;\n const maxAvailableSpace = size - renderedSizeAfterReclaim;\n if (maxAvailableSpace >= overflowedSize) {\n return true;\n }\n }\n};\n\nconst mightBeAbleToReclaimSpace = (items: OverflowItem[]) =>\n items.some(canReclaimSpace);\n\n// We need to release the reclaimed space (i.e take it back from the collapsed item and re-assign it\n// as available space) when container grows and space now allows overflowed item to be 'un-wrapped'\n\nexport const useReclaimSpace = ({\n collectionHook,\n label = \"Toolbar\",\n overflowItemsRef: managedItemsRef,\n overflowContainerRef: ref,\n orientation,\n}: OverflowHookProps): OverflowHookResult => {\n const releaseReclaimedSpace = useCallback(() => {\n const { current: managedItems } = managedItemsRef;\n\n const claimant = managedItems.find(hasReclaimedSpace);\n if (claimant) {\n // Might not always need to collapse, if there is enough available space for it to still be collapsing then\n // collapse the claimant and turn off reclaimed\n collectionHook.dispatch({\n type: \"replace-item\",\n overflowItem: {\n ...claimant,\n collapsed: true,\n collapsing: false,\n reclaimedSpace: undefined,\n size: claimant.minSize as number,\n fullSize: claimant.size,\n },\n });\n }\n }, [managedItemsRef, collectionHook.dispatch]);\n\n const handleResize = useCallback(\n (size: number, containerHasGrown?: boolean) => {\n const { isOverflowing: willOverflow } = measureContainerOverflow(\n ref,\n orientation,\n );\n const { current: managedItems } = managedItemsRef;\n\n if (containerHasGrown && canReleaseReclaimedSpace(size, managedItems)) {\n releaseReclaimedSpace();\n } else if (\n !containerHasGrown &&\n willOverflow &&\n mightBeAbleToReclaimSpace(managedItems)\n ) {\n const collapsedChild = managedItems.find(canReclaimSpace);\n if (collapsedChild) {\n collectionHook.dispatch({\n type: \"replace-item\",\n overflowItem: {\n ...collapsedChild,\n collapsed: false,\n collapsing: true,\n reclaimedSpace: true,\n size: collapsedChild.fullSize as number,\n fullSize: null,\n },\n });\n }\n }\n },\n [\n ref,\n managedItemsRef,\n releaseReclaimedSpace,\n collectionHook.dispatch,\n orientation,\n ],\n );\n\n return {\n onResize: handleResize,\n };\n};\n"],"names":[],"mappings":";;;AAYA,MAAM,WAAA,GAAc,CAAC,IAAA,KAAuB,IAAK,CAAA,QAAA,CAAA;AAEjD,MAAM,eAAkB,GAAA,CAAC,IACvB,KAAA,IAAA,CAAK,aAAa,IAAK,CAAA,YAAA,CAAA;AAEzB,MAAM,iBAAA,GAAoB,CAAC,IAAA,KAAuB,IAAK,CAAA,cAAA,CAAA;AACvD,MAAM,sBAAsB,CAAC,EAAE,MAAM,OAAU,GAAA,CAAA,OAC7C,IAAO,GAAA,OAAA,CAAA;AAET,MAAM,sBAAA,GAAyB,CAAC,KAA0B,KAAA;AACxD,EAAA,MAAM,kBAAkB,KAAM,CAAA,MAAA,CAAO,CAAC,IAAA,KAAS,KAAK,UAAU,CAAA,CAAA;AAC9D,EAAA,MAAM,cAAc,IAAK,CAAA,GAAA,CAAI,GAAG,eAAgB,CAAA,GAAA,CAAI,WAAW,CAAC,CAAA,CAAA;AAChE,EAAA,KAAA,IAAS,CAAI,GAAA,CAAA,EAAG,CAAI,GAAA,eAAA,CAAgB,QAAQ,CAAK,EAAA,EAAA;AAC/C,IAAI,IAAA,eAAA,CAAgB,CAAG,CAAA,CAAA,QAAA,KAAa,WAAa,EAAA;AAC/C,MAAA,OAAO,eAAgB,CAAA,CAAA,CAAA,CAAA;AAAA,KACzB;AAAA,GACF;AACA,EAAO,OAAA,IAAA,CAAA;AACT,CAAA,CAAA;AAEa,MAAA,aAAA,GAAgB,CAAC,GAAa,EAAA,CAAA,KACzC,OAAO,CAAE,CAAA,UAAA,GAAa,IAAI,CAAE,CAAA,IAAA,EAAA;AAE9B,MAAM,wBAAA,GAA2B,CAAC,IAAA,EAAc,KAA0B,KAAA;AAnC1E,EAAA,IAAA,EAAA,CAAA;AAoCE,EAAM,MAAA,QAAA,GAAW,KAAM,CAAA,IAAA,CAAK,iBAAiB,CAAA,CAAA;AAC7C,EAAM,MAAA,cAAA,GAAiB,uBAAuB,KAAK,CAAA,CAAA;AACnD,EAAA,IAAI,YAAY,cAAgB,EAAA;AAC9B,IAAA,MAAM,YAAe,GAAA,KAAA,CAAM,MAAO,CAAA,aAAA,EAAe,CAAC,CAAA,CAAA;AAClD,IAAM,MAAA,EAAE,IAAM,EAAA,aAAA,EAAkB,GAAA,CAAA,EAAA,GAAA,oBAAA,CAAqB,KAAK,CAA1B,KAAA,IAAA,GAAA,EAAA,GAA+B,EAAE,IAAA,EAAM,CAAE,EAAA,CAAA;AACzE,IAAM,MAAA,EAAE,IAAM,EAAA,cAAA,EAAmB,GAAA,cAAA,CAAA;AAEjC,IAAM,MAAA,gBAAA,GAAmB,oBAAoB,QAAQ,CAAA,CAAA;AACrD,IAAM,MAAA,wBAAA,GACJ,eAAe,gBAAmB,GAAA,aAAA,CAAA;AACpC,IAAA,MAAM,oBAAoB,IAAO,GAAA,wBAAA,CAAA;AACjC,IAAA,IAAI,qBAAqB,cAAgB,EAAA;AACvC,MAAO,OAAA,IAAA,CAAA;AAAA,KACT;AAAA,GACF;AACF,CAAA,CAAA;AAEA,MAAM,yBAA4B,GAAA,CAAC,KACjC,KAAA,KAAA,CAAM,KAAK,eAAe,CAAA,CAAA;AAKrB,MAAM,kBAAkB,CAAC;AAAA,EAC9B,cAAA;AAAA,EACA,KAAQ,GAAA,SAAA;AAAA,EACR,gBAAkB,EAAA,eAAA;AAAA,EAClB,oBAAsB,EAAA,GAAA;AAAA,EACtB,WAAA;AACF,CAA6C,KAAA;AAC3C,EAAM,MAAA,qBAAA,GAAwB,YAAY,MAAM;AAC9C,IAAM,MAAA,EAAE,OAAS,EAAA,YAAA,EAAiB,GAAA,eAAA,CAAA;AAElC,IAAM,MAAA,QAAA,GAAW,YAAa,CAAA,IAAA,CAAK,iBAAiB,CAAA,CAAA;AACpD,IAAA,IAAI,QAAU,EAAA;AAGZ,MAAA,cAAA,CAAe,QAAS,CAAA;AAAA,QACtB,IAAM,EAAA,cAAA;AAAA,QACN,YAAc,EAAA;AAAA,UACZ,GAAG,QAAA;AAAA,UACH,SAAW,EAAA,IAAA;AAAA,UACX,UAAY,EAAA,KAAA;AAAA,UACZ,cAAgB,EAAA,KAAA,CAAA;AAAA,UAChB,MAAM,QAAS,CAAA,OAAA;AAAA,UACf,UAAU,QAAS,CAAA,IAAA;AAAA,SACrB;AAAA,OACD,CAAA,CAAA;AAAA,KACH;AAAA,GACC,EAAA,CAAC,eAAiB,EAAA,cAAA,CAAe,QAAQ,CAAC,CAAA,CAAA;AAE7C,EAAA,MAAM,YAAe,GAAA,WAAA;AAAA,IACnB,CAAC,MAAc,iBAAgC,KAAA;AAC7C,MAAM,MAAA,EAAE,aAAe,EAAA,YAAA,EAAiB,GAAA,wBAAA;AAAA,QACtC,GAAA;AAAA,QACA,WAAA;AAAA,OACF,CAAA;AACA,MAAM,MAAA,EAAE,OAAS,EAAA,YAAA,EAAiB,GAAA,eAAA,CAAA;AAElC,MAAA,IAAI,iBAAqB,IAAA,wBAAA,CAAyB,IAAM,EAAA,YAAY,CAAG,EAAA;AACrE,QAAsB,qBAAA,EAAA,CAAA;AAAA,iBAEtB,CAAC,iBAAA,IACD,YACA,IAAA,yBAAA,CAA0B,YAAY,CACtC,EAAA;AACA,QAAM,MAAA,cAAA,GAAiB,YAAa,CAAA,IAAA,CAAK,eAAe,CAAA,CAAA;AACxD,QAAA,IAAI,cAAgB,EAAA;AAClB,UAAA,cAAA,CAAe,QAAS,CAAA;AAAA,YACtB,IAAM,EAAA,cAAA;AAAA,YACN,YAAc,EAAA;AAAA,cACZ,GAAG,cAAA;AAAA,cACH,SAAW,EAAA,KAAA;AAAA,cACX,UAAY,EAAA,IAAA;AAAA,cACZ,cAAgB,EAAA,IAAA;AAAA,cAChB,MAAM,cAAe,CAAA,QAAA;AAAA,cACrB,QAAU,EAAA,IAAA;AAAA,aACZ;AAAA,WACD,CAAA,CAAA;AAAA,SACH;AAAA,OACF;AAAA,KACF;AAAA,IACA;AAAA,MACE,GAAA;AAAA,MACA,eAAA;AAAA,MACA,qBAAA;AAAA,MACA,cAAe,CAAA,QAAA;AAAA,MACf,WAAA;AAAA,KACF;AAAA,GACF,CAAA;AAEA,EAAO,OAAA;AAAA,IACL,QAAU,EAAA,YAAA;AAAA,GACZ,CAAA;AACF;;;;"}
@@ -38,7 +38,7 @@ const resizeObserver = typeof ResizeObserver !== "undefined" ? new ResizeObserve
38
38
  }
39
39
  }
40
40
  if (sizeChanged) {
41
- onResize && onResize(measurements);
41
+ onResize == null ? void 0 : onResize(measurements);
42
42
  }
43
43
  }
44
44
  }
@@ -1 +1 @@
1
- {"version":3,"file":"useResizeObserver.js","sources":["../src/responsive/useResizeObserver.ts"],"sourcesContent":["/* eslint-disable no-restricted-syntax */\nimport { useIsomorphicLayoutEffect } from \"@salt-ds/core\";\nimport { useCallback, useRef, RefObject } from \"react\";\nexport const WidthHeight = [\"height\", \"width\"];\nexport const HeightOnly = [\"height\"];\nexport const WidthOnly = [\"width\"];\n\nexport type measurements<T = string | number> = {\n height?: T;\n scrollHeight?: T;\n scrollWidth?: T;\n width?: T;\n};\ntype measuredDimension = keyof measurements<number>;\n\nexport type ResizeHandler = (measurements: measurements<number>) => void;\n\ntype observedDetails = {\n onResize?: ResizeHandler;\n measurements: measurements<number>;\n};\nconst observedMap = new WeakMap<HTMLElement, observedDetails>();\n\nconst getTargetSize = (\n element: HTMLElement,\n contentRect: DOMRectReadOnly,\n dimension: measuredDimension\n): number => {\n switch (dimension) {\n case \"height\":\n return contentRect.height;\n case \"scrollHeight\":\n return element.scrollHeight;\n case \"scrollWidth\":\n return element.scrollWidth;\n case \"width\":\n return contentRect.width;\n default:\n return 0;\n }\n};\n\nconst resizeObserver =\n typeof ResizeObserver !== \"undefined\"\n ? new ResizeObserver((entries: ResizeObserverEntry[]) => {\n for (const entry of entries) {\n const { target, contentRect } = entry;\n const observedTarget = observedMap.get(target as HTMLElement);\n if (observedTarget) {\n const { onResize, measurements } = observedTarget;\n let sizeChanged = false;\n for (const [dimension, size] of Object.entries(measurements)) {\n const newSize = getTargetSize(\n target as HTMLElement,\n contentRect,\n dimension as measuredDimension\n );\n if (newSize !== size) {\n sizeChanged = true;\n measurements[dimension as measuredDimension] = newSize;\n }\n }\n if (sizeChanged) {\n onResize && onResize(measurements);\n }\n }\n }\n })\n : null;\n\n// TODO use an optional lag (default to false) to ask to fire onResize\n// with initial size\n// Note asking for scrollHeight alone will not trigger onResize, this is only triggered by height,\n// with scrollHeight returned as an auxilliary value\nexport function useResizeObserver(\n ref: RefObject<Element | HTMLElement | null>,\n dimensions: string[],\n onResize: ResizeHandler,\n reportInitialSize = false\n): void {\n const dimensionsRef = useRef(dimensions);\n const measure = useCallback((target: HTMLElement): measurements<number> => {\n const rect = target.getBoundingClientRect();\n return dimensionsRef.current.reduce(\n (map: { [key: string]: number }, dim) => {\n map[dim] = getTargetSize(target, rect, dim as measuredDimension);\n return map;\n },\n {}\n );\n }, []);\n\n // TODO use ref to store resizeHandler here\n // resize handler registered with REsizeObserver will never change\n // use ref to store user onResize callback here\n // resizeHandler will call user callback.current\n\n // Keep this effect separate in case user inadvertently passes different\n // dimensions or callback instance each time - we only ever want to\n // initiate new observation when ref changes.\n useIsomorphicLayoutEffect(() => {\n if (!resizeObserver) {\n return undefined;\n }\n\n const target = ref.current as HTMLElement;\n let cleanedUp = false;\n\n async function registerObserver() {\n // Create the map entry immediately. useEffect may fire below\n // before fonts are ready and attempt to update entry\n observedMap.set(target, { measurements: {} as measurements<number> });\n cleanedUp = false;\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n const { fonts } = document as any;\n if (fonts) {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n await fonts.ready;\n }\n if (!cleanedUp && resizeObserver) {\n const observedTarget = observedMap.get(target);\n if (observedTarget) {\n const measurements = measure(target);\n observedTarget.measurements = measurements;\n resizeObserver.observe(target);\n if (reportInitialSize) {\n onResize(measurements);\n }\n }\n }\n }\n\n if (target) {\n // TODO might we want multiple callers to attach a listener to the same element ?\n if (observedMap.has(target)) {\n throw Error(\n \"useResizeObserver attemping to observe same element twice\"\n );\n }\n void registerObserver();\n }\n return () => {\n if (target && observedMap.has(target)) {\n resizeObserver.unobserve(target);\n observedMap.delete(target);\n cleanedUp = true;\n }\n };\n }, [ref, measure]);\n\n useIsomorphicLayoutEffect(() => {\n const target = ref.current as HTMLElement;\n const record = observedMap.get(target);\n if (record) {\n if (dimensionsRef.current !== dimensions) {\n dimensionsRef.current = dimensions;\n const measurements = measure(target);\n record.measurements = measurements;\n }\n // Might not have changed, but no harm ...\n record.onResize = onResize;\n }\n }, [dimensions, measure, ref, onResize]);\n\n // TODO might be a good idea to ref and return the current measurememnts. That way, derived hooks\n // e.g useBreakpoints don't have to measure and client cn make onResize callback simpler\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"useResizeObserver.js","sources":["../src/responsive/useResizeObserver.ts"],"sourcesContent":["import { useIsomorphicLayoutEffect } from \"@salt-ds/core\";\nimport { type RefObject, useCallback, useRef } from \"react\";\nexport const WidthHeight = [\"height\", \"width\"];\nexport const HeightOnly = [\"height\"];\nexport const WidthOnly = [\"width\"];\n\nexport type measurements<T = string | number> = {\n height?: T;\n scrollHeight?: T;\n scrollWidth?: T;\n width?: T;\n};\ntype measuredDimension = keyof measurements<number>;\n\nexport type ResizeHandler = (measurements: measurements<number>) => void;\n\ntype observedDetails = {\n onResize?: ResizeHandler;\n measurements: measurements<number>;\n};\nconst observedMap = new WeakMap<HTMLElement, observedDetails>();\n\nconst getTargetSize = (\n element: HTMLElement,\n contentRect: DOMRectReadOnly,\n dimension: measuredDimension,\n): number => {\n switch (dimension) {\n case \"height\":\n return contentRect.height;\n case \"scrollHeight\":\n return element.scrollHeight;\n case \"scrollWidth\":\n return element.scrollWidth;\n case \"width\":\n return contentRect.width;\n default:\n return 0;\n }\n};\n\nconst resizeObserver =\n typeof ResizeObserver !== \"undefined\"\n ? new ResizeObserver((entries: ResizeObserverEntry[]) => {\n for (const entry of entries) {\n const { target, contentRect } = entry;\n const observedTarget = observedMap.get(target as HTMLElement);\n if (observedTarget) {\n const { onResize, measurements } = observedTarget;\n let sizeChanged = false;\n for (const [dimension, size] of Object.entries(measurements)) {\n const newSize = getTargetSize(\n target as HTMLElement,\n contentRect,\n dimension as measuredDimension,\n );\n if (newSize !== size) {\n sizeChanged = true;\n measurements[dimension as measuredDimension] = newSize;\n }\n }\n if (sizeChanged) {\n onResize?.(measurements);\n }\n }\n }\n })\n : null;\n\n// TODO use an optional lag (default to false) to ask to fire onResize\n// with initial size\n// Note asking for scrollHeight alone will not trigger onResize, this is only triggered by height,\n// with scrollHeight returned as an auxilliary value\nexport function useResizeObserver(\n ref: RefObject<Element | HTMLElement | null>,\n dimensions: string[],\n onResize: ResizeHandler,\n reportInitialSize = false,\n): void {\n const dimensionsRef = useRef(dimensions);\n const measure = useCallback((target: HTMLElement): measurements<number> => {\n const rect = target.getBoundingClientRect();\n return dimensionsRef.current.reduce(\n (map: { [key: string]: number }, dim) => {\n map[dim] = getTargetSize(target, rect, dim as measuredDimension);\n return map;\n },\n {},\n );\n }, []);\n\n // TODO use ref to store resizeHandler here\n // resize handler registered with REsizeObserver will never change\n // use ref to store user onResize callback here\n // resizeHandler will call user callback.current\n\n // Keep this effect separate in case user inadvertently passes different\n // dimensions or callback instance each time - we only ever want to\n // initiate new observation when ref changes.\n useIsomorphicLayoutEffect(() => {\n if (!resizeObserver) {\n return undefined;\n }\n\n const target = ref.current as HTMLElement;\n let cleanedUp = false;\n\n async function registerObserver() {\n // Create the map entry immediately. useEffect may fire below\n // before fonts are ready and attempt to update entry\n observedMap.set(target, { measurements: {} as measurements<number> });\n cleanedUp = false;\n\n const { fonts } = document;\n if (fonts) {\n await fonts.ready;\n }\n if (!cleanedUp && resizeObserver) {\n const observedTarget = observedMap.get(target);\n if (observedTarget) {\n const measurements = measure(target);\n observedTarget.measurements = measurements;\n resizeObserver.observe(target);\n if (reportInitialSize) {\n onResize(measurements);\n }\n }\n }\n }\n\n if (target) {\n // TODO might we want multiple callers to attach a listener to the same element ?\n if (observedMap.has(target)) {\n throw Error(\n \"useResizeObserver attemping to observe same element twice\",\n );\n }\n void registerObserver();\n }\n return () => {\n if (target && observedMap.has(target)) {\n resizeObserver.unobserve(target);\n observedMap.delete(target);\n cleanedUp = true;\n }\n };\n }, [ref, measure]);\n\n useIsomorphicLayoutEffect(() => {\n const target = ref.current as HTMLElement;\n const record = observedMap.get(target);\n if (record) {\n if (dimensionsRef.current !== dimensions) {\n dimensionsRef.current = dimensions;\n const measurements = measure(target);\n record.measurements = measurements;\n }\n // Might not have changed, but no harm ...\n record.onResize = onResize;\n }\n }, [dimensions, measure, ref, onResize]);\n\n // TODO might be a good idea to ref and return the current measurememnts. That way, derived hooks\n // e.g useBreakpoints don't have to measure and client cn make onResize callback simpler\n}\n"],"names":[],"mappings":"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"}
@@ -1,5 +1,5 @@
1
- import { useState, useRef, useCallback } from 'react';
2
1
  import { useIsomorphicLayoutEffect } from '@salt-ds/core';
2
+ import { useState, useRef, useCallback } from 'react';
3
3
  import { useResizeObserver, WidthOnly } from './useResizeObserver.js';
4
4
 
5
5
  const NONE = [];
@@ -16,7 +16,7 @@ function useWidth(responsive) {
16
16
  return void 0;
17
17
  }
18
18
  handleResize(ref.current.getBoundingClientRect());
19
- }, [handleResize, responsive]);
19
+ }, [handleResize]);
20
20
  return [ref, width];
21
21
  }
22
22
 
@@ -1 +1 @@
1
- {"version":3,"file":"useWidth.js","sources":["../src/responsive/useWidth.ts"],"sourcesContent":["import { RefObject, useCallback, useRef, useState } from \"react\";\nimport { useIsomorphicLayoutEffect } from \"@salt-ds/core\";\nimport {\n ResizeHandler,\n useResizeObserver,\n WidthOnly,\n} from \"./useResizeObserver\";\n\nconst NONE: string[] = [];\n\nexport function useWidth<Element extends HTMLElement>(\n responsive: boolean\n): [RefObject<Element>, number] {\n const [width, setWidth] = useState<number>();\n const ref = useRef<HTMLElement>(null);\n\n const handleResize: ResizeHandler = useCallback(({ width: newWidth }) => {\n setWidth(newWidth);\n }, []);\n\n const measurementsToObserve = responsive ? WidthOnly : NONE;\n useResizeObserver(ref, measurementsToObserve, handleResize);\n\n useIsomorphicLayoutEffect(() => {\n if (!ref.current) {\n return undefined;\n }\n handleResize(ref.current.getBoundingClientRect());\n }, [handleResize, responsive]);\n\n return [ref, width] as [RefObject<Element>, number];\n}\n"],"names":[],"mappings":";;;;AAQA,MAAM,OAAiB,EAAC,CAAA;AAEjB,SAAS,SACd,UAC8B,EAAA;AAC9B,EAAA,MAAM,CAAC,KAAA,EAAO,QAAQ,CAAA,GAAI,QAAiB,EAAA,CAAA;AAC3C,EAAM,MAAA,GAAA,GAAM,OAAoB,IAAI,CAAA,CAAA;AAEpC,EAAA,MAAM,eAA8B,WAAY,CAAA,CAAC,EAAE,KAAA,EAAO,UAAe,KAAA;AACvE,IAAA,QAAA,CAAS,QAAQ,CAAA,CAAA;AAAA,GACnB,EAAG,EAAE,CAAA,CAAA;AAEL,EAAM,MAAA,qBAAA,GAAwB,aAAa,SAAY,GAAA,IAAA,CAAA;AACvD,EAAkB,iBAAA,CAAA,GAAA,EAAK,uBAAuB,YAAY,CAAA,CAAA;AAE1D,EAAA,yBAAA,CAA0B,MAAM;AAC9B,IAAI,IAAA,CAAC,IAAI,OAAS,EAAA;AAChB,MAAO,OAAA,KAAA,CAAA,CAAA;AAAA,KACT;AACA,IAAa,YAAA,CAAA,GAAA,CAAI,OAAQ,CAAA,qBAAA,EAAuB,CAAA,CAAA;AAAA,GAC/C,EAAA,CAAC,YAAc,EAAA,UAAU,CAAC,CAAA,CAAA;AAE7B,EAAO,OAAA,CAAC,KAAK,KAAK,CAAA,CAAA;AACpB;;;;"}
1
+ {"version":3,"file":"useWidth.js","sources":["../src/responsive/useWidth.ts"],"sourcesContent":["import { useIsomorphicLayoutEffect } from \"@salt-ds/core\";\nimport { type RefObject, useCallback, useRef, useState } from \"react\";\nimport {\n type ResizeHandler,\n WidthOnly,\n useResizeObserver,\n} from \"./useResizeObserver\";\n\nconst NONE: string[] = [];\n\nexport function useWidth<Element extends HTMLElement>(\n responsive: boolean,\n): [RefObject<Element>, number] {\n const [width, setWidth] = useState<number>();\n const ref = useRef<HTMLElement>(null);\n\n const handleResize: ResizeHandler = useCallback(({ width: newWidth }) => {\n setWidth(newWidth);\n }, []);\n\n const measurementsToObserve = responsive ? WidthOnly : NONE;\n useResizeObserver(ref, measurementsToObserve, handleResize);\n\n useIsomorphicLayoutEffect(() => {\n if (!ref.current) {\n return undefined;\n }\n handleResize(ref.current.getBoundingClientRect());\n }, [handleResize]);\n\n return [ref, width] as [RefObject<Element>, number];\n}\n"],"names":[],"mappings":";;;;AAQA,MAAM,OAAiB,EAAC,CAAA;AAEjB,SAAS,SACd,UAC8B,EAAA;AAC9B,EAAA,MAAM,CAAC,KAAA,EAAO,QAAQ,CAAA,GAAI,QAAiB,EAAA,CAAA;AAC3C,EAAM,MAAA,GAAA,GAAM,OAAoB,IAAI,CAAA,CAAA;AAEpC,EAAA,MAAM,eAA8B,WAAY,CAAA,CAAC,EAAE,KAAA,EAAO,UAAe,KAAA;AACvE,IAAA,QAAA,CAAS,QAAQ,CAAA,CAAA;AAAA,GACnB,EAAG,EAAE,CAAA,CAAA;AAEL,EAAM,MAAA,qBAAA,GAAwB,aAAa,SAAY,GAAA,IAAA,CAAA;AACvD,EAAkB,iBAAA,CAAA,GAAA,EAAK,uBAAuB,YAAY,CAAA,CAAA;AAE1D,EAAA,yBAAA,CAA0B,MAAM;AAC9B,IAAI,IAAA,CAAC,IAAI,OAAS,EAAA;AAChB,MAAO,OAAA,KAAA,CAAA,CAAA;AAAA,KACT;AACA,IAAa,YAAA,CAAA,GAAA,CAAI,OAAQ,CAAA,qBAAA,EAAuB,CAAA,CAAA;AAAA,GAClD,EAAG,CAAC,YAAY,CAAC,CAAA,CAAA;AAEjB,EAAO,OAAA,CAAC,KAAK,KAAK,CAAA,CAAA;AACpB;;;;"}
@@ -34,9 +34,8 @@ const liftResponsivePropsToFormField = (props) => {
34
34
  },
35
35
  [{}, {}]
36
36
  );
37
- } else {
38
- return [{}, props];
39
37
  }
38
+ return [{}, props];
40
39
  };
41
40
 
42
41
  export { isResponsiveAttribute, liftResponsivePropsToFormField };
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","sources":["../src/responsive/utils.ts"],"sourcesContent":["const COLLAPSIBLE = \"data-collapsible\";\n\nexport type dataPadDirection = \"data-pad-start\" | \"data-pad-end\";\n\nconst RESPONSIVE_ATTRIBUTE: { [key: string]: boolean } = {\n [COLLAPSIBLE]: true,\n \"data-pad-start\": true,\n \"data-pad-end\": true,\n};\n\nexport const isResponsiveAttribute = (propName: string): boolean =>\n RESPONSIVE_ATTRIBUTE[propName] ?? false;\n\nconst isCollapsible = (propName: string) => propName === COLLAPSIBLE;\n\nconst COLLAPSIBLE_VALUE: { [key: string]: string } = {\n dynamic: \"dynamic\",\n instant: \"instant\",\n true: \"instant\",\n};\n\nconst collapsibleValue = (value: string) => COLLAPSIBLE_VALUE[value] ?? \"none\";\n\ntype AnyProps = Record<string, unknown>;\ntype ResponsivePropsTuple = [AnyProps, AnyProps];\n/**\n * data- attributes can be used to manage item overflow behaviour. Users may\n * speficy these attributes directly on a Toolbar component, which ultimately\n * gets wrapped by a FormField. We need to 'lift' these attributes to the form\n * field and remove them from the props of the nested component.\n * @param props\n * @returns\n */\nexport const liftResponsivePropsToFormField = (\n props: AnyProps\n): ResponsivePropsTuple => {\n const propNames = Object.keys(props);\n if (propNames.some(isResponsiveAttribute)) {\n return propNames.reduce<ResponsivePropsTuple>(\n (tuple, propName): ResponsivePropsTuple => {\n const [toolbarProps, rest] = tuple;\n const propValue = props[propName];\n if (isResponsiveAttribute(propName)) {\n const value = isCollapsible(propName)\n ? collapsibleValue(propValue as string)\n : propValue;\n\n toolbarProps[propName] = value;\n rest[propName] = undefined;\n }\n return tuple;\n },\n [{}, {}]\n );\n } else {\n return [{}, props];\n }\n};\n"],"names":[],"mappings":"AAAA,MAAM,WAAc,GAAA,kBAAA,CAAA;AAIpB,MAAM,oBAAmD,GAAA;AAAA,EACvD,CAAC,WAAc,GAAA,IAAA;AAAA,EACf,gBAAkB,EAAA,IAAA;AAAA,EAClB,cAAgB,EAAA,IAAA;AAClB,CAAA,CAAA;AAEa,MAAA,qBAAA,GAAwB,CAAC,QAA2B,KAAA;AAVjE,EAAA,IAAA,EAAA,CAAA;AAWE,EAAA,OAAA,CAAA,EAAA,GAAA,oBAAA,CAAqB,cAArB,IAAkC,GAAA,EAAA,GAAA,KAAA,CAAA;AAAA,EAAA;AAEpC,MAAM,aAAA,GAAgB,CAAC,QAAA,KAAqB,QAAa,KAAA,WAAA,CAAA;AAEzD,MAAM,iBAA+C,GAAA;AAAA,EACnD,OAAS,EAAA,SAAA;AAAA,EACT,OAAS,EAAA,SAAA;AAAA,EACT,IAAM,EAAA,SAAA;AACR,CAAA,CAAA;AAEA,MAAM,gBAAA,GAAmB,CAAC,KAAe,KAAA;AArBzC,EAAA,IAAA,EAAA,CAAA;AAqB4C,EAAA,OAAA,CAAA,EAAA,GAAA,iBAAA,CAAkB,WAAlB,IAA4B,GAAA,EAAA,GAAA,MAAA,CAAA;AAAA,CAAA,CAAA;AAY3D,MAAA,8BAAA,GAAiC,CAC5C,KACyB,KAAA;AACzB,EAAM,MAAA,SAAA,GAAY,MAAO,CAAA,IAAA,CAAK,KAAK,CAAA,CAAA;AACnC,EAAI,IAAA,SAAA,CAAU,IAAK,CAAA,qBAAqB,CAAG,EAAA;AACzC,IAAA,OAAO,SAAU,CAAA,MAAA;AAAA,MACf,CAAC,OAAO,QAAmC,KAAA;AACzC,QAAM,MAAA,CAAC,YAAc,EAAA,IAAI,CAAI,GAAA,KAAA,CAAA;AAC7B,QAAA,MAAM,YAAY,KAAM,CAAA,QAAA,CAAA,CAAA;AACxB,QAAI,IAAA,qBAAA,CAAsB,QAAQ,CAAG,EAAA;AACnC,UAAA,MAAM,QAAQ,aAAc,CAAA,QAAQ,CAChC,GAAA,gBAAA,CAAiB,SAAmB,CACpC,GAAA,SAAA,CAAA;AAEJ,UAAA,YAAA,CAAa,QAAY,CAAA,GAAA,KAAA,CAAA;AACzB,UAAA,IAAA,CAAK,QAAY,CAAA,GAAA,KAAA,CAAA,CAAA;AAAA,SACnB;AACA,QAAO,OAAA,KAAA,CAAA;AAAA,OACT;AAAA,MACA,CAAC,EAAI,EAAA,EAAE,CAAA;AAAA,KACT,CAAA;AAAA,GACK,MAAA;AACL,IAAO,OAAA,CAAC,EAAC,EAAG,KAAK,CAAA,CAAA;AAAA,GACnB;AACF;;;;"}
1
+ {"version":3,"file":"utils.js","sources":["../src/responsive/utils.ts"],"sourcesContent":["const COLLAPSIBLE = \"data-collapsible\";\n\nexport type dataPadDirection = \"data-pad-start\" | \"data-pad-end\";\n\nconst RESPONSIVE_ATTRIBUTE: { [key: string]: boolean } = {\n [COLLAPSIBLE]: true,\n \"data-pad-start\": true,\n \"data-pad-end\": true,\n};\n\nexport const isResponsiveAttribute = (propName: string): boolean =>\n RESPONSIVE_ATTRIBUTE[propName] ?? false;\n\nconst isCollapsible = (propName: string) => propName === COLLAPSIBLE;\n\nconst COLLAPSIBLE_VALUE: { [key: string]: string } = {\n dynamic: \"dynamic\",\n instant: \"instant\",\n true: \"instant\",\n};\n\nconst collapsibleValue = (value: string) => COLLAPSIBLE_VALUE[value] ?? \"none\";\n\ntype AnyProps = Record<string, unknown>;\ntype ResponsivePropsTuple = [AnyProps, AnyProps];\n/**\n * data- attributes can be used to manage item overflow behaviour. Users may\n * speficy these attributes directly on a Toolbar component, which ultimately\n * gets wrapped by a FormField. We need to 'lift' these attributes to the form\n * field and remove them from the props of the nested component.\n * @param props\n * @returns\n */\nexport const liftResponsivePropsToFormField = (\n props: AnyProps,\n): ResponsivePropsTuple => {\n const propNames = Object.keys(props);\n if (propNames.some(isResponsiveAttribute)) {\n return propNames.reduce<ResponsivePropsTuple>(\n (tuple, propName): ResponsivePropsTuple => {\n const [toolbarProps, rest] = tuple;\n const propValue = props[propName];\n if (isResponsiveAttribute(propName)) {\n const value = isCollapsible(propName)\n ? collapsibleValue(propValue as string)\n : propValue;\n\n toolbarProps[propName] = value;\n rest[propName] = undefined;\n }\n return tuple;\n },\n [{}, {}],\n );\n }\n return [{}, props];\n};\n"],"names":[],"mappings":"AAAA,MAAM,WAAc,GAAA,kBAAA,CAAA;AAIpB,MAAM,oBAAmD,GAAA;AAAA,EACvD,CAAC,WAAc,GAAA,IAAA;AAAA,EACf,gBAAkB,EAAA,IAAA;AAAA,EAClB,cAAgB,EAAA,IAAA;AAClB,CAAA,CAAA;AAEa,MAAA,qBAAA,GAAwB,CAAC,QAA2B,KAAA;AAVjE,EAAA,IAAA,EAAA,CAAA;AAWE,EAAA,OAAA,CAAA,EAAA,GAAA,oBAAA,CAAqB,cAArB,IAAkC,GAAA,EAAA,GAAA,KAAA,CAAA;AAAA,EAAA;AAEpC,MAAM,aAAA,GAAgB,CAAC,QAAA,KAAqB,QAAa,KAAA,WAAA,CAAA;AAEzD,MAAM,iBAA+C,GAAA;AAAA,EACnD,OAAS,EAAA,SAAA;AAAA,EACT,OAAS,EAAA,SAAA;AAAA,EACT,IAAM,EAAA,SAAA;AACR,CAAA,CAAA;AAEA,MAAM,gBAAA,GAAmB,CAAC,KAAe,KAAA;AArBzC,EAAA,IAAA,EAAA,CAAA;AAqB4C,EAAA,OAAA,CAAA,EAAA,GAAA,iBAAA,CAAkB,WAAlB,IAA4B,GAAA,EAAA,GAAA,MAAA,CAAA;AAAA,CAAA,CAAA;AAY3D,MAAA,8BAAA,GAAiC,CAC5C,KACyB,KAAA;AACzB,EAAM,MAAA,SAAA,GAAY,MAAO,CAAA,IAAA,CAAK,KAAK,CAAA,CAAA;AACnC,EAAI,IAAA,SAAA,CAAU,IAAK,CAAA,qBAAqB,CAAG,EAAA;AACzC,IAAA,OAAO,SAAU,CAAA,MAAA;AAAA,MACf,CAAC,OAAO,QAAmC,KAAA;AACzC,QAAM,MAAA,CAAC,YAAc,EAAA,IAAI,CAAI,GAAA,KAAA,CAAA;AAC7B,QAAA,MAAM,YAAY,KAAM,CAAA,QAAA,CAAA,CAAA;AACxB,QAAI,IAAA,qBAAA,CAAsB,QAAQ,CAAG,EAAA;AACnC,UAAA,MAAM,QAAQ,aAAc,CAAA,QAAQ,CAChC,GAAA,gBAAA,CAAiB,SAAmB,CACpC,GAAA,SAAA,CAAA;AAEJ,UAAA,YAAA,CAAa,QAAY,CAAA,GAAA,KAAA,CAAA;AACzB,UAAA,IAAA,CAAK,QAAY,CAAA,GAAA,KAAA,CAAA,CAAA;AAAA,SACnB;AACA,QAAO,OAAA,KAAA,CAAA;AAAA,OACT;AAAA,MACA,CAAC,EAAI,EAAA,EAAE,CAAA;AAAA,KACT,CAAA;AAAA,GACF;AACA,EAAO,OAAA,CAAC,EAAC,EAAG,KAAK,CAAA,CAAA;AACnB;;;;"}
@@ -1,12 +1,12 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
- import { forwardRef, useRef } from 'react';
3
- import { clsx } from 'clsx';
4
2
  import { useForkRef, useControlled, Button } from '@salt-ds/core';
3
+ import { CloseIcon, SearchIcon } from '@salt-ds/icons';
4
+ import { clsx } from 'clsx';
5
+ import { forwardRef, useRef } from 'react';
5
6
  import { InputLegacy } from '../input-legacy/InputLegacy.js';
6
7
  import { StaticInputAdornment } from '../input-legacy/StaticInputAdornment.js';
7
- import { CloseIcon, SearchIcon } from '@salt-ds/icons';
8
- import { useWindow } from '@salt-ds/window';
9
8
  import { useComponentCssInjection } from '@salt-ds/styles';
9
+ import { useWindow } from '@salt-ds/window';
10
10
  import css_248z from './SearchInput.css.js';
11
11
 
12
12
  const baseName = "saltSearchInput";
@@ -1 +1 @@
1
- {"version":3,"file":"SearchInput.js","sources":["../src/search-input/SearchInput.tsx"],"sourcesContent":["import {\n ChangeEvent,\n ComponentType,\n forwardRef,\n KeyboardEvent,\n SyntheticEvent,\n useRef,\n} from \"react\";\nimport { clsx } from \"clsx\";\nimport { Button, useControlled, useForkRef } from \"@salt-ds/core\";\nimport {\n InputLegacy as Input,\n InputLegacyProps as InputProps,\n StaticInputAdornment,\n} from \"../input-legacy\";\nimport { CloseIcon, SearchIcon } from \"@salt-ds/icons\";\n\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport searchInputCss from \"./SearchInput.css\";\n\nconst baseName = \"saltSearchInput\";\n\n//TODO formfield integration\n\nexport interface SearchInputProps extends Omit<InputProps, \"onSubmit\"> {\n /**\n * Override \"search\" icon.\n * Set to `null` to hide.\n */\n IconComponent?: ComponentType<any> | null;\n /**\n * Callback for when clear button is clicked.\n */\n onClear?: () => void;\n /**\n * Callback for change event.\n * Event is either an Input change event or a Button click event.\n */\n onChange?: (event: SyntheticEvent<unknown>, value: string) => void;\n /**\n * Callback to trigger search.\n */\n onSubmit?: (value: InputProps[\"value\"]) => void;\n}\n\nexport const SearchInput = forwardRef<HTMLInputElement, SearchInputProps>(\n function SearchInput(\n {\n IconComponent = SearchIcon,\n className,\n onChange,\n onClear,\n onKeyUp,\n onSubmit,\n value: valueProp,\n defaultValue,\n ...other\n },\n ref\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-search-input\",\n css: searchInputCss,\n window: targetWindow,\n });\n\n const inputRef = useRef<HTMLInputElement>(null);\n const handleRef = useForkRef(inputRef, ref);\n\n const [value, setValue, isControlled] = useControlled({\n controlled: valueProp,\n default: defaultValue,\n name: \"SearchInput\",\n state: \"value\",\n });\n\n const handleChange = (\n event: ChangeEvent<HTMLInputElement>,\n newValue: string\n ) => {\n setValue(newValue);\n onChange?.(event, newValue);\n };\n\n const handleClear = (event: SyntheticEvent<HTMLButtonElement>) => {\n setValue(\"\");\n if (!isControlled) {\n onChange?.(event, \"\");\n }\n onClear?.();\n inputRef.current?.focus();\n };\n\n const handleKeyUp = (event: KeyboardEvent<HTMLInputElement>) => {\n if (event.key === \"Enter\" && onSubmit && value) {\n onSubmit?.(value);\n }\n\n onKeyUp?.(event);\n };\n\n return (\n <Input\n className={clsx(baseName, className)}\n ref={handleRef}\n endAdornment={\n !!value && (\n <Button\n className={clsx(`${baseName}-clearButton`)}\n onClick={handleClear}\n variant=\"secondary\"\n >\n <CloseIcon\n aria-label=\"clear input\"\n className={`${baseName}-clearIcon`}\n />\n </Button>\n )\n }\n onChange={handleChange}\n onKeyUp={handleKeyUp}\n startAdornment={\n IconComponent && (\n <StaticInputAdornment>\n <IconComponent className={`${baseName}-icon`} />\n </StaticInputAdornment>\n )\n }\n value={value || \"\"}\n {...other}\n />\n );\n }\n);\n"],"names":["SearchInput","searchInputCss","Input"],"mappings":";;;;;;;;;;;AAsBA,MAAM,QAAW,GAAA,iBAAA,CAAA;AAyBV,MAAM,WAAc,GAAA,UAAA;AAAA,EACzB,SAASA,YACP,CAAA;AAAA,IACE,aAAgB,GAAA,UAAA;AAAA,IAChB,SAAA;AAAA,IACA,QAAA;AAAA,IACA,OAAA;AAAA,IACA,OAAA;AAAA,IACA,QAAA;AAAA,IACA,KAAO,EAAA,SAAA;AAAA,IACP,YAAA;AAAA,IACG,GAAA,KAAA;AAAA,KAEL,GACA,EAAA;AACA,IAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,IAAyB,wBAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,mBAAA;AAAA,MACR,GAAK,EAAAC,QAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAM,MAAA,QAAA,GAAW,OAAyB,IAAI,CAAA,CAAA;AAC9C,IAAM,MAAA,SAAA,GAAY,UAAW,CAAA,QAAA,EAAU,GAAG,CAAA,CAAA;AAE1C,IAAA,MAAM,CAAC,KAAA,EAAO,QAAU,EAAA,YAAY,IAAI,aAAc,CAAA;AAAA,MACpD,UAAY,EAAA,SAAA;AAAA,MACZ,OAAS,EAAA,YAAA;AAAA,MACT,IAAM,EAAA,aAAA;AAAA,MACN,KAAO,EAAA,OAAA;AAAA,KACR,CAAA,CAAA;AAED,IAAM,MAAA,YAAA,GAAe,CACnB,KAAA,EACA,QACG,KAAA;AACH,MAAA,QAAA,CAAS,QAAQ,CAAA,CAAA;AACjB,MAAA,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAW,KAAO,EAAA,QAAA,CAAA,CAAA;AAAA,KACpB,CAAA;AAEA,IAAM,MAAA,WAAA,GAAc,CAAC,KAA6C,KAAA;AAvFtE,MAAA,IAAA,EAAA,CAAA;AAwFM,MAAA,QAAA,CAAS,EAAE,CAAA,CAAA;AACX,MAAA,IAAI,CAAC,YAAc,EAAA;AACjB,QAAA,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAW,KAAO,EAAA,EAAA,CAAA,CAAA;AAAA,OACpB;AACA,MAAA,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,EAAA,CAAA;AACA,MAAA,CAAA,EAAA,GAAA,QAAA,CAAS,YAAT,IAAkB,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,KAAA,EAAA,CAAA;AAAA,KACpB,CAAA;AAEA,IAAM,MAAA,WAAA,GAAc,CAAC,KAA2C,KAAA;AAC9D,MAAA,IAAI,KAAM,CAAA,GAAA,KAAQ,OAAW,IAAA,QAAA,IAAY,KAAO,EAAA;AAC9C,QAAW,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAA,KAAA,CAAA,CAAA;AAAA,OACb;AAEA,MAAU,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,CAAA,KAAA,CAAA,CAAA;AAAA,KACZ,CAAA;AAEA,IAAA,uBACG,GAAA,CAAAC,WAAA,EAAA;AAAA,MACC,SAAA,EAAW,IAAK,CAAA,QAAA,EAAU,SAAS,CAAA;AAAA,MACnC,GAAK,EAAA,SAAA;AAAA,MACL,YACE,EAAA,CAAC,CAAC,KAAA,oBACC,GAAA,CAAA,MAAA,EAAA;AAAA,QACC,SAAA,EAAW,IAAK,CAAA,CAAA,EAAG,QAAsB,CAAA,YAAA,CAAA,CAAA;AAAA,QACzC,OAAS,EAAA,WAAA;AAAA,QACT,OAAQ,EAAA,WAAA;AAAA,QAER,QAAC,kBAAA,GAAA,CAAA,SAAA,EAAA;AAAA,UACC,YAAW,EAAA,aAAA;AAAA,UACX,WAAW,CAAG,EAAA,QAAA,CAAA,UAAA,CAAA;AAAA,SAChB,CAAA;AAAA,OACF,CAAA;AAAA,MAGJ,QAAU,EAAA,YAAA;AAAA,MACV,OAAS,EAAA,WAAA;AAAA,MACT,cAAA,EACE,iCACG,GAAA,CAAA,oBAAA,EAAA;AAAA,QACC,QAAC,kBAAA,GAAA,CAAA,aAAA,EAAA;AAAA,UAAc,WAAW,CAAG,EAAA,QAAA,CAAA,KAAA,CAAA;AAAA,SAAiB,CAAA;AAAA,OAChD,CAAA;AAAA,MAGJ,OAAO,KAAS,IAAA,EAAA;AAAA,MACf,GAAG,KAAA;AAAA,KACN,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
1
+ {"version":3,"file":"SearchInput.js","sources":["../src/search-input/SearchInput.tsx"],"sourcesContent":["import { Button, useControlled, useForkRef } from \"@salt-ds/core\";\nimport { CloseIcon, SearchIcon } from \"@salt-ds/icons\";\nimport { clsx } from \"clsx\";\nimport {\n type ChangeEvent,\n type ComponentType,\n type KeyboardEvent,\n type SyntheticEvent,\n forwardRef,\n useRef,\n} from \"react\";\nimport {\n InputLegacy as Input,\n type InputLegacyProps as InputProps,\n StaticInputAdornment,\n} from \"../input-legacy\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport searchInputCss from \"./SearchInput.css\";\n\nconst baseName = \"saltSearchInput\";\n\n//TODO formfield integration\n\nexport interface SearchInputProps extends Omit<InputProps, \"onSubmit\"> {\n /**\n * Override \"search\" icon.\n * Set to `null` to hide.\n */\n IconComponent?: ComponentType<any> | null;\n /**\n * Callback for when clear button is clicked.\n */\n onClear?: () => void;\n /**\n * Callback for change event.\n * Event is either an Input change event or a Button click event.\n */\n onChange?: (event: SyntheticEvent<unknown>, value: string) => void;\n /**\n * Callback to trigger search.\n */\n onSubmit?: (value: InputProps[\"value\"]) => void;\n}\n\nexport const SearchInput = forwardRef<HTMLInputElement, SearchInputProps>(\n function SearchInput(\n {\n IconComponent = SearchIcon,\n className,\n onChange,\n onClear,\n onKeyUp,\n onSubmit,\n value: valueProp,\n defaultValue,\n ...other\n },\n ref,\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-search-input\",\n css: searchInputCss,\n window: targetWindow,\n });\n\n const inputRef = useRef<HTMLInputElement>(null);\n const handleRef = useForkRef(inputRef, ref);\n\n const [value, setValue, isControlled] = useControlled({\n controlled: valueProp,\n default: defaultValue,\n name: \"SearchInput\",\n state: \"value\",\n });\n\n const handleChange = (\n event: ChangeEvent<HTMLInputElement>,\n newValue: string,\n ) => {\n setValue(newValue);\n onChange?.(event, newValue);\n };\n\n const handleClear = (event: SyntheticEvent<HTMLButtonElement>) => {\n setValue(\"\");\n if (!isControlled) {\n onChange?.(event, \"\");\n }\n onClear?.();\n inputRef.current?.focus();\n };\n\n const handleKeyUp = (event: KeyboardEvent<HTMLInputElement>) => {\n if (event.key === \"Enter\" && onSubmit && value) {\n onSubmit?.(value);\n }\n\n onKeyUp?.(event);\n };\n\n return (\n <Input\n className={clsx(baseName, className)}\n ref={handleRef}\n endAdornment={\n !!value && (\n <Button\n className={clsx(`${baseName}-clearButton`)}\n onClick={handleClear}\n variant=\"secondary\"\n >\n <CloseIcon\n aria-label=\"clear input\"\n className={`${baseName}-clearIcon`}\n />\n </Button>\n )\n }\n onChange={handleChange}\n onKeyUp={handleKeyUp}\n startAdornment={\n IconComponent && (\n <StaticInputAdornment>\n <IconComponent className={`${baseName}-icon`} />\n </StaticInputAdornment>\n )\n }\n value={value || \"\"}\n {...other}\n />\n );\n },\n);\n"],"names":["SearchInput","searchInputCss","Input"],"mappings":"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"}
@@ -1,10 +1,10 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
- import { forwardRef } from 'react';
3
2
  import { makePrefixer, Link } from '@salt-ds/core';
3
+ import { useComponentCssInjection } from '@salt-ds/styles';
4
+ import { useWindow } from '@salt-ds/window';
4
5
  import { clsx } from 'clsx';
6
+ import { forwardRef } from 'react';
5
7
  import { useManageFocusOnTarget } from './internal/useManageFocusOnTarget.js';
6
- import { useWindow } from '@salt-ds/window';
7
- import { useComponentCssInjection } from '@salt-ds/styles';
8
8
  import css_248z from './SkipLink.css.js';
9
9
 
10
10
  const withBaseName = makePrefixer("saltSkipLink");
@@ -1 +1 @@
1
- {"version":3,"file":"SkipLink.js","sources":["../src/skip-link/SkipLink.tsx"],"sourcesContent":["import { forwardRef, RefObject } from \"react\";\nimport { Link, LinkProps, makePrefixer } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { useManageFocusOnTarget } from \"./internal/useManageFocusOnTarget\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport skipLinkCss from \"./SkipLink.css\";\n\ninterface SkipLinkProps extends LinkProps {\n /**\n * This is a ref that has access to the target element.\n *\n * This will be used to apply focus to that element\n *\n * Refs are referentially stable so if this changes it won't be picked up\n * will need to find a better way of passing in the target element to apply the attributes\n */\n targetRef?: RefObject<HTMLElement>;\n}\n\nconst withBaseName = makePrefixer(\"saltSkipLink\");\n\nexport const SkipLink = forwardRef<HTMLAnchorElement, SkipLinkProps>(\n function SkipLink({ className, targetRef, ...rest }, ref) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-skip-link\",\n css: skipLinkCss,\n window: targetWindow,\n });\n\n const targetClass = clsx(withBaseName(\"target\"), className);\n\n const eventHandlers = useManageFocusOnTarget({ targetRef, targetClass });\n\n return (\n <li>\n <Link\n {...eventHandlers}\n {...rest}\n className={clsx(withBaseName(), className)}\n ref={ref}\n />\n </li>\n );\n }\n);\n"],"names":["SkipLink","skipLinkCss"],"mappings":";;;;;;;;;AAqBA,MAAM,YAAA,GAAe,aAAa,cAAc,CAAA,CAAA;AAEzC,MAAM,QAAW,GAAA,UAAA;AAAA,EACtB,SAASA,SAAS,CAAA,EAAE,WAAW,SAAc,EAAA,GAAA,IAAA,IAAQ,GAAK,EAAA;AACxD,IAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,IAAyB,wBAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,gBAAA;AAAA,MACR,GAAK,EAAAC,QAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAA,MAAM,WAAc,GAAA,IAAA,CAAK,YAAa,CAAA,QAAQ,GAAG,SAAS,CAAA,CAAA;AAE1D,IAAA,MAAM,aAAgB,GAAA,sBAAA,CAAuB,EAAE,SAAA,EAAW,aAAa,CAAA,CAAA;AAEvE,IAAA,uBACG,GAAA,CAAA,IAAA,EAAA;AAAA,MACC,QAAC,kBAAA,GAAA,CAAA,IAAA,EAAA;AAAA,QACE,GAAG,aAAA;AAAA,QACH,GAAG,IAAA;AAAA,QACJ,SAAW,EAAA,IAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,QACzC,GAAA;AAAA,OACF,CAAA;AAAA,KACF,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
1
+ {"version":3,"file":"SkipLink.js","sources":["../src/skip-link/SkipLink.tsx"],"sourcesContent":["import { Link, type LinkProps, makePrefixer } from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport { type RefObject, forwardRef } from \"react\";\nimport { useManageFocusOnTarget } from \"./internal/useManageFocusOnTarget\";\n\nimport skipLinkCss from \"./SkipLink.css\";\n\ninterface SkipLinkProps extends LinkProps {\n /**\n * This is a ref that has access to the target element.\n *\n * This will be used to apply focus to that element\n *\n * Refs are referentially stable so if this changes it won't be picked up\n * will need to find a better way of passing in the target element to apply the attributes\n */\n targetRef?: RefObject<HTMLElement>;\n}\n\nconst withBaseName = makePrefixer(\"saltSkipLink\");\n\nexport const SkipLink = forwardRef<HTMLAnchorElement, SkipLinkProps>(\n function SkipLink({ className, targetRef, ...rest }, ref) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-skip-link\",\n css: skipLinkCss,\n window: targetWindow,\n });\n\n const targetClass = clsx(withBaseName(\"target\"), className);\n\n const eventHandlers = useManageFocusOnTarget({ targetRef, targetClass });\n\n return (\n <li>\n <Link\n {...eventHandlers}\n {...rest}\n className={clsx(withBaseName(), className)}\n ref={ref}\n />\n </li>\n );\n },\n);\n"],"names":["SkipLink","skipLinkCss"],"mappings":";;;;;;;;;AAqBA,MAAM,YAAA,GAAe,aAAa,cAAc,CAAA,CAAA;AAEzC,MAAM,QAAW,GAAA,UAAA;AAAA,EACtB,SAASA,SAAS,CAAA,EAAE,WAAW,SAAc,EAAA,GAAA,IAAA,IAAQ,GAAK,EAAA;AACxD,IAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,IAAyB,wBAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,gBAAA;AAAA,MACR,GAAK,EAAAC,QAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAA,MAAM,WAAc,GAAA,IAAA,CAAK,YAAa,CAAA,QAAQ,GAAG,SAAS,CAAA,CAAA;AAE1D,IAAA,MAAM,aAAgB,GAAA,sBAAA,CAAuB,EAAE,SAAA,EAAW,aAAa,CAAA,CAAA;AAEvE,IAAA,uBACG,GAAA,CAAA,IAAA,EAAA;AAAA,MACC,QAAC,kBAAA,GAAA,CAAA,IAAA,EAAA;AAAA,QACE,GAAG,aAAA;AAAA,QACH,GAAG,IAAA;AAAA,QACJ,SAAW,EAAA,IAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,QACzC,GAAA;AAAA,OACF,CAAA;AAAA,KACF,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
@@ -1,9 +1,9 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
- import { forwardRef } from 'react';
3
- import { clsx } from 'clsx';
4
2
  import { makePrefixer } from '@salt-ds/core';
5
- import { useWindow } from '@salt-ds/window';
3
+ import { clsx } from 'clsx';
4
+ import { forwardRef } from 'react';
6
5
  import { useComponentCssInjection } from '@salt-ds/styles';
6
+ import { useWindow } from '@salt-ds/window';
7
7
  import css_248z from './SkipLinks.css.js';
8
8
 
9
9
  const withBaseName = makePrefixer("saltSkipLinks");
@@ -1 +1 @@
1
- {"version":3,"file":"SkipLinks.js","sources":["../src/skip-link/SkipLinks.tsx"],"sourcesContent":["import { forwardRef, HTMLAttributes } from \"react\";\nimport { clsx } from \"clsx\";\nimport { makePrefixer } from \"@salt-ds/core\";\n\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport skipLinksCss from \"./SkipLinks.css\";\n\nconst withBaseName = makePrefixer(\"saltSkipLinks\");\n\nexport const SkipLinks = forwardRef<\n HTMLUListElement,\n HTMLAttributes<HTMLUListElement>\n>(function SkipLinks(props, ref) {\n const { className, children, ...restProps } = props;\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-skip-links\",\n css: skipLinksCss,\n window: targetWindow,\n });\n\n return (\n <ul {...restProps} className={clsx(withBaseName(), className)} ref={ref}>\n {children}\n </ul>\n );\n});\n"],"names":["SkipLinks","skipLinksCss"],"mappings":";;;;;;;;AASA,MAAM,YAAA,GAAe,aAAa,eAAe,CAAA,CAAA;AAE1C,MAAM,SAAY,GAAA,UAAA,CAGvB,SAASA,UAAAA,CAAU,OAAO,GAAK,EAAA;AAC/B,EAAA,MAAM,EAAE,SAAA,EAAW,QAAa,EAAA,GAAA,SAAA,EAAc,GAAA,KAAA,CAAA;AAC9C,EAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,iBAAA;AAAA,IACR,GAAK,EAAAC,QAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,uBACG,GAAA,CAAA,IAAA,EAAA;AAAA,IAAI,GAAG,SAAA;AAAA,IAAW,SAAW,EAAA,IAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,IAAG,GAAA;AAAA,IAC5D,QAAA;AAAA,GACH,CAAA,CAAA;AAEJ,CAAC;;;;"}
1
+ {"version":3,"file":"SkipLinks.js","sources":["../src/skip-link/SkipLinks.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { type HTMLAttributes, forwardRef } from \"react\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport skipLinksCss from \"./SkipLinks.css\";\n\nconst withBaseName = makePrefixer(\"saltSkipLinks\");\n\nexport const SkipLinks = forwardRef<\n HTMLUListElement,\n HTMLAttributes<HTMLUListElement>\n>(function SkipLinks(props, ref) {\n const { className, children, ...restProps } = props;\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-skip-links\",\n css: skipLinksCss,\n window: targetWindow,\n });\n\n return (\n <ul {...restProps} className={clsx(withBaseName(), className)} ref={ref}>\n {children}\n </ul>\n );\n});\n"],"names":["SkipLinks","skipLinksCss"],"mappings":";;;;;;;;AASA,MAAM,YAAA,GAAe,aAAa,eAAe,CAAA,CAAA;AAE1C,MAAM,SAAY,GAAA,UAAA,CAGvB,SAASA,UAAAA,CAAU,OAAO,GAAK,EAAA;AAC/B,EAAA,MAAM,EAAE,SAAA,EAAW,QAAa,EAAA,GAAA,SAAA,EAAc,GAAA,KAAA,CAAA;AAC9C,EAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,iBAAA;AAAA,IACR,GAAK,EAAAC,QAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,uBACG,GAAA,CAAA,IAAA,EAAA;AAAA,IAAI,GAAG,SAAA;AAAA,IAAW,SAAW,EAAA,IAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,IAAG,GAAA;AAAA,IAC5D,QAAA;AAAA,GACH,CAAA,CAAA;AAEJ,CAAC;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"useManageFocusOnTarget.js","sources":["../src/skip-link/internal/useManageFocusOnTarget.ts"],"sourcesContent":["import { RefObject, useEffect, useMemo, useRef, useState } from \"react\";\n\nconst FOCUS_TIMEOUT = 50;\n\nexport const useManageFocusOnTarget = ({\n targetRef,\n targetClass,\n}: {\n targetRef: RefObject<HTMLElement> | undefined;\n targetClass: string;\n}):\n | { onBlur: () => NodeJS.Timeout; onClick: () => void }\n | Record<string, undefined> => {\n const [target, setTarget] = useState<HTMLElement>();\n\n const hasTabIndex = useRef<boolean | string>();\n const shouldRemoveTabIndex = useRef<boolean>();\n\n useEffect(() => {\n if (targetRef?.current) {\n setTarget(targetRef.current);\n }\n }, [targetRef]);\n\n return useMemo(() => {\n if (!target) {\n return {};\n }\n\n const addTabIndex = () => {\n const tabIndex = target.getAttribute(\"tabIndex\");\n hasTabIndex.current = tabIndex || tabIndex === \"0\";\n\n if (!hasTabIndex.current) {\n shouldRemoveTabIndex.current = true;\n target.setAttribute(\"tabIndex\", \"-1\");\n }\n };\n\n const removeTabIndex = () => {\n if (!hasTabIndex.current && shouldRemoveTabIndex.current) {\n target.removeAttribute(\"tabIndex\");\n }\n };\n\n const handleFocusOnTarget = () => {\n shouldRemoveTabIndex.current = false;\n target.classList.add(targetClass);\n };\n\n const handleBlurFromTarget = () => {\n shouldRemoveTabIndex.current = true;\n removeTabIndex();\n target.classList.remove(targetClass);\n };\n\n return {\n onBlur: () => setTimeout(removeTabIndex, FOCUS_TIMEOUT),\n onClick: () => {\n addTabIndex();\n setTimeout(() => {\n target.focus();\n }, FOCUS_TIMEOUT);\n\n target.addEventListener(\"focus\", handleFocusOnTarget, { once: true });\n target.addEventListener(\"blur\", handleBlurFromTarget, { once: true });\n },\n };\n }, [target, targetClass]);\n};\n"],"names":[],"mappings":";;AAEA,MAAM,aAAgB,GAAA,EAAA,CAAA;AAEf,MAAM,yBAAyB,CAAC;AAAA,EACrC,SAAA;AAAA,EACA,WAAA;AACF,CAKiC,KAAA;AAC/B,EAAA,MAAM,CAAC,MAAA,EAAQ,SAAS,CAAA,GAAI,QAAsB,EAAA,CAAA;AAElD,EAAA,MAAM,cAAc,MAAyB,EAAA,CAAA;AAC7C,EAAA,MAAM,uBAAuB,MAAgB,EAAA,CAAA;AAE7C,EAAA,SAAA,CAAU,MAAM;AACd,IAAA,IAAI,uCAAW,OAAS,EAAA;AACtB,MAAA,SAAA,CAAU,UAAU,OAAO,CAAA,CAAA;AAAA,KAC7B;AAAA,GACF,EAAG,CAAC,SAAS,CAAC,CAAA,CAAA;AAEd,EAAA,OAAO,QAAQ,MAAM;AACnB,IAAA,IAAI,CAAC,MAAQ,EAAA;AACX,MAAA,OAAO,EAAC,CAAA;AAAA,KACV;AAEA,IAAA,MAAM,cAAc,MAAM;AACxB,MAAM,MAAA,QAAA,GAAW,MAAO,CAAA,YAAA,CAAa,UAAU,CAAA,CAAA;AAC/C,MAAY,WAAA,CAAA,OAAA,GAAU,YAAY,QAAa,KAAA,GAAA,CAAA;AAE/C,MAAI,IAAA,CAAC,YAAY,OAAS,EAAA;AACxB,QAAA,oBAAA,CAAqB,OAAU,GAAA,IAAA,CAAA;AAC/B,QAAO,MAAA,CAAA,YAAA,CAAa,YAAY,IAAI,CAAA,CAAA;AAAA,OACtC;AAAA,KACF,CAAA;AAEA,IAAA,MAAM,iBAAiB,MAAM;AAC3B,MAAA,IAAI,CAAC,WAAA,CAAY,OAAW,IAAA,oBAAA,CAAqB,OAAS,EAAA;AACxD,QAAA,MAAA,CAAO,gBAAgB,UAAU,CAAA,CAAA;AAAA,OACnC;AAAA,KACF,CAAA;AAEA,IAAA,MAAM,sBAAsB,MAAM;AAChC,MAAA,oBAAA,CAAqB,OAAU,GAAA,KAAA,CAAA;AAC/B,MAAO,MAAA,CAAA,SAAA,CAAU,IAAI,WAAW,CAAA,CAAA;AAAA,KAClC,CAAA;AAEA,IAAA,MAAM,uBAAuB,MAAM;AACjC,MAAA,oBAAA,CAAqB,OAAU,GAAA,IAAA,CAAA;AAC/B,MAAe,cAAA,EAAA,CAAA;AACf,MAAO,MAAA,CAAA,SAAA,CAAU,OAAO,WAAW,CAAA,CAAA;AAAA,KACrC,CAAA;AAEA,IAAO,OAAA;AAAA,MACL,MAAQ,EAAA,MAAM,UAAW,CAAA,cAAA,EAAgB,aAAa,CAAA;AAAA,MACtD,SAAS,MAAM;AACb,QAAY,WAAA,EAAA,CAAA;AACZ,QAAA,UAAA,CAAW,MAAM;AACf,UAAA,MAAA,CAAO,KAAM,EAAA,CAAA;AAAA,WACZ,aAAa,CAAA,CAAA;AAEhB,QAAA,MAAA,CAAO,iBAAiB,OAAS,EAAA,mBAAA,EAAqB,EAAE,IAAA,EAAM,MAAM,CAAA,CAAA;AACpE,QAAA,MAAA,CAAO,iBAAiB,MAAQ,EAAA,oBAAA,EAAsB,EAAE,IAAA,EAAM,MAAM,CAAA,CAAA;AAAA,OACtE;AAAA,KACF,CAAA;AAAA,GACC,EAAA,CAAC,MAAQ,EAAA,WAAW,CAAC,CAAA,CAAA;AAC1B;;;;"}
1
+ {"version":3,"file":"useManageFocusOnTarget.js","sources":["../src/skip-link/internal/useManageFocusOnTarget.ts"],"sourcesContent":["import { type RefObject, useEffect, useMemo, useRef, useState } from \"react\";\n\nconst FOCUS_TIMEOUT = 50;\n\nexport const useManageFocusOnTarget = ({\n targetRef,\n targetClass,\n}: {\n targetRef: RefObject<HTMLElement> | undefined;\n targetClass: string;\n}):\n | { onBlur: () => NodeJS.Timeout; onClick: () => void }\n | Record<string, undefined> => {\n const [target, setTarget] = useState<HTMLElement>();\n\n const hasTabIndex = useRef<boolean | string>();\n const shouldRemoveTabIndex = useRef<boolean>();\n\n useEffect(() => {\n if (targetRef?.current) {\n setTarget(targetRef.current);\n }\n }, [targetRef]);\n\n return useMemo(() => {\n if (!target) {\n return {};\n }\n\n const addTabIndex = () => {\n const tabIndex = target.getAttribute(\"tabIndex\");\n hasTabIndex.current = tabIndex || tabIndex === \"0\";\n\n if (!hasTabIndex.current) {\n shouldRemoveTabIndex.current = true;\n target.setAttribute(\"tabIndex\", \"-1\");\n }\n };\n\n const removeTabIndex = () => {\n if (!hasTabIndex.current && shouldRemoveTabIndex.current) {\n target.removeAttribute(\"tabIndex\");\n }\n };\n\n const handleFocusOnTarget = () => {\n shouldRemoveTabIndex.current = false;\n target.classList.add(targetClass);\n };\n\n const handleBlurFromTarget = () => {\n shouldRemoveTabIndex.current = true;\n removeTabIndex();\n target.classList.remove(targetClass);\n };\n\n return {\n onBlur: () => setTimeout(removeTabIndex, FOCUS_TIMEOUT),\n onClick: () => {\n addTabIndex();\n setTimeout(() => {\n target.focus();\n }, FOCUS_TIMEOUT);\n\n target.addEventListener(\"focus\", handleFocusOnTarget, { once: true });\n target.addEventListener(\"blur\", handleBlurFromTarget, { once: true });\n },\n };\n }, [target, targetClass]);\n};\n"],"names":[],"mappings":";;AAEA,MAAM,aAAgB,GAAA,EAAA,CAAA;AAEf,MAAM,yBAAyB,CAAC;AAAA,EACrC,SAAA;AAAA,EACA,WAAA;AACF,CAKiC,KAAA;AAC/B,EAAA,MAAM,CAAC,MAAA,EAAQ,SAAS,CAAA,GAAI,QAAsB,EAAA,CAAA;AAElD,EAAA,MAAM,cAAc,MAAyB,EAAA,CAAA;AAC7C,EAAA,MAAM,uBAAuB,MAAgB,EAAA,CAAA;AAE7C,EAAA,SAAA,CAAU,MAAM;AACd,IAAA,IAAI,uCAAW,OAAS,EAAA;AACtB,MAAA,SAAA,CAAU,UAAU,OAAO,CAAA,CAAA;AAAA,KAC7B;AAAA,GACF,EAAG,CAAC,SAAS,CAAC,CAAA,CAAA;AAEd,EAAA,OAAO,QAAQ,MAAM;AACnB,IAAA,IAAI,CAAC,MAAQ,EAAA;AACX,MAAA,OAAO,EAAC,CAAA;AAAA,KACV;AAEA,IAAA,MAAM,cAAc,MAAM;AACxB,MAAM,MAAA,QAAA,GAAW,MAAO,CAAA,YAAA,CAAa,UAAU,CAAA,CAAA;AAC/C,MAAY,WAAA,CAAA,OAAA,GAAU,YAAY,QAAa,KAAA,GAAA,CAAA;AAE/C,MAAI,IAAA,CAAC,YAAY,OAAS,EAAA;AACxB,QAAA,oBAAA,CAAqB,OAAU,GAAA,IAAA,CAAA;AAC/B,QAAO,MAAA,CAAA,YAAA,CAAa,YAAY,IAAI,CAAA,CAAA;AAAA,OACtC;AAAA,KACF,CAAA;AAEA,IAAA,MAAM,iBAAiB,MAAM;AAC3B,MAAA,IAAI,CAAC,WAAA,CAAY,OAAW,IAAA,oBAAA,CAAqB,OAAS,EAAA;AACxD,QAAA,MAAA,CAAO,gBAAgB,UAAU,CAAA,CAAA;AAAA,OACnC;AAAA,KACF,CAAA;AAEA,IAAA,MAAM,sBAAsB,MAAM;AAChC,MAAA,oBAAA,CAAqB,OAAU,GAAA,KAAA,CAAA;AAC/B,MAAO,MAAA,CAAA,SAAA,CAAU,IAAI,WAAW,CAAA,CAAA;AAAA,KAClC,CAAA;AAEA,IAAA,MAAM,uBAAuB,MAAM;AACjC,MAAA,oBAAA,CAAqB,OAAU,GAAA,IAAA,CAAA;AAC/B,MAAe,cAAA,EAAA,CAAA;AACf,MAAO,MAAA,CAAA,SAAA,CAAU,OAAO,WAAW,CAAA,CAAA;AAAA,KACrC,CAAA;AAEA,IAAO,OAAA;AAAA,MACL,MAAQ,EAAA,MAAM,UAAW,CAAA,cAAA,EAAgB,aAAa,CAAA;AAAA,MACtD,SAAS,MAAM;AACb,QAAY,WAAA,EAAA,CAAA;AACZ,QAAA,UAAA,CAAW,MAAM;AACf,UAAA,MAAA,CAAO,KAAM,EAAA,CAAA;AAAA,WACZ,aAAa,CAAA,CAAA;AAEhB,QAAA,MAAA,CAAO,iBAAiB,OAAS,EAAA,mBAAA,EAAqB,EAAE,IAAA,EAAM,MAAM,CAAA,CAAA;AACpE,QAAA,MAAA,CAAO,iBAAiB,MAAQ,EAAA,oBAAA,EAAsB,EAAE,IAAA,EAAM,MAAM,CAAA,CAAA;AAAA,OACtE;AAAA,KACF,CAAA;AAAA,GACC,EAAA,CAAC,MAAQ,EAAA,WAAW,CAAC,CAAA,CAAA;AAC1B;;;;"}
@@ -11,8 +11,8 @@ import { createTrackStyle, createHandleStyles } from './internal/styles.js';
11
11
  import { useSliderKeyDown } from './internal/useSliderKeyDown.js';
12
12
  import { useSliderMouseDown } from './internal/useSliderMouseDown.js';
13
13
  import { useValueUpdater } from './internal/utils.js';
14
- import { useWindow } from '@salt-ds/window';
15
14
  import { useComponentCssInjection } from '@salt-ds/styles';
15
+ import { useWindow } from '@salt-ds/window';
16
16
  import css_248z from './Slider.css.js';
17
17
 
18
18
  const withBaseName = makePrefixer("saltSlider");
@@ -1 +1 @@
1
- {"version":3,"file":"Slider.js","sources":["../src/slider/Slider.tsx"],"sourcesContent":["import { makePrefixer, useControlled } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport {\n CSSProperties,\n forwardRef,\n HTMLAttributes,\n useMemo,\n useRef,\n} from \"react\";\nimport { SliderHandle } from \"./internal/SliderHandle\";\nimport { SliderMarkLabels } from \"./internal/SliderMarkLabels\";\nimport { SliderRail } from \"./internal/SliderRail\";\nimport { SliderMark, SliderRailMarks } from \"./internal/SliderRailMarks\";\nimport { SliderSelection } from \"./internal/SliderSelection\";\nimport { createHandleStyles, createTrackStyle } from \"./internal/styles\";\nimport { useSliderKeyDown } from \"./internal/useSliderKeyDown\";\nimport { useSliderMouseDown } from \"./internal/useSliderMouseDown\";\nimport { useValueUpdater } from \"./internal/utils\";\nimport { SliderChangeHandler, SliderValue } from \"./types\";\n\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport sliderCss from \"./Slider.css\";\n\nconst withBaseName = makePrefixer(\"saltSlider\");\n\nconst defaultMin = 0;\nconst defaultMax = 100;\nconst defaultStep = 1;\n\nexport interface SliderProps\n extends Omit<HTMLAttributes<HTMLDivElement>, \"onChange\" | \"defaultValue\"> {\n label?: string;\n min?: number;\n max?: number;\n step?: number;\n pageStep?: number;\n value?: SliderValue;\n defaultValue?: SliderValue;\n pushable?: boolean;\n pushDistance?: number;\n disabled?: boolean;\n onChange?: SliderChangeHandler;\n marks?: SliderMark[];\n hideMarks?: boolean;\n hideMarkLabels?: boolean;\n}\n\nexport const Slider = forwardRef<HTMLDivElement, SliderProps>(function Slider(\n {\n min = defaultMin,\n max = defaultMax,\n step = defaultStep,\n pageStep = step,\n value: valueProp,\n defaultValue = defaultMin,\n onChange,\n label,\n className,\n pushable,\n pushDistance = 0,\n disabled,\n marks,\n hideMarks,\n hideMarkLabels,\n ...restProps\n },\n ref\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-slider\",\n css: sliderCss,\n window: targetWindow,\n });\n\n const trackRef = useRef<HTMLDivElement>(null);\n\n const [value, setValue] = useControlled<SliderValue>({\n controlled: valueProp,\n default: defaultValue,\n name: \"Slider\",\n state: \"Value\",\n });\n\n const updateValueItem = useValueUpdater(pushable, pushDistance, min, max);\n\n const trackStyle = useMemo(\n () => createTrackStyle(min, max, value),\n [min, max, value]\n );\n\n const valueLength = Array.isArray(value) ? value.length : 1;\n\n const handleStyles: CSSProperties[] = useMemo(\n () => createHandleStyles(valueLength),\n [valueLength]\n );\n\n const onMouseDown = useSliderMouseDown(\n trackRef,\n value,\n min,\n max,\n step,\n updateValueItem,\n setValue,\n onChange\n );\n\n const onKeyDown = useSliderKeyDown(\n value,\n min,\n max,\n pageStep,\n step,\n updateValueItem,\n setValue,\n onChange\n );\n\n return (\n <div\n className={clsx(\n withBaseName(),\n {\n [withBaseName(\"disabled\")]: disabled,\n },\n className\n )}\n ref={ref}\n onKeyDown={disabled ? undefined : onKeyDown}\n aria-label={`${label} slider from ${min} to ${max}`}\n role=\"group\"\n >\n {label !== undefined ? (\n <div className={withBaseName(\"label\")}>{label}</div>\n ) : null}\n <div\n className={withBaseName(\"clickable\")}\n onMouseDown={disabled ? undefined : onMouseDown}\n >\n <div\n className={withBaseName(\"track\")}\n style={trackStyle}\n ref={trackRef}\n >\n <SliderRail />\n {marks && !hideMarks ? (\n <SliderRailMarks min={min} max={max} marks={marks} />\n ) : null}\n {marks && !hideMarkLabels ? (\n <SliderMarkLabels min={min} max={max} marks={marks} />\n ) : null}\n <SliderSelection valueLength={valueLength} />\n {(Array.isArray(value) ? value : [value]).map((v, i) => (\n <SliderHandle\n key={i}\n min={min}\n max={max}\n value={v}\n index={i}\n disabled={!!disabled}\n valueLength={valueLength}\n style={handleStyles[i]}\n />\n ))}\n </div>\n </div>\n </div>\n );\n});\n"],"names":["Slider","sliderCss"],"mappings":"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"}
1
+ {"version":3,"file":"Slider.js","sources":["../src/slider/Slider.tsx"],"sourcesContent":["import { makePrefixer, useControlled } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport {\n type CSSProperties,\n type HTMLAttributes,\n forwardRef,\n useMemo,\n useRef,\n} from \"react\";\nimport { SliderHandle } from \"./internal/SliderHandle\";\nimport { SliderMarkLabels } from \"./internal/SliderMarkLabels\";\nimport { SliderRail } from \"./internal/SliderRail\";\nimport { type SliderMark, SliderRailMarks } from \"./internal/SliderRailMarks\";\nimport { SliderSelection } from \"./internal/SliderSelection\";\nimport { createHandleStyles, createTrackStyle } from \"./internal/styles\";\nimport { useSliderKeyDown } from \"./internal/useSliderKeyDown\";\nimport { useSliderMouseDown } from \"./internal/useSliderMouseDown\";\nimport { useValueUpdater } from \"./internal/utils\";\nimport type { SliderChangeHandler, SliderValue } from \"./types\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport sliderCss from \"./Slider.css\";\n\nconst withBaseName = makePrefixer(\"saltSlider\");\n\nconst defaultMin = 0;\nconst defaultMax = 100;\nconst defaultStep = 1;\n\nexport interface SliderProps\n extends Omit<HTMLAttributes<HTMLDivElement>, \"onChange\" | \"defaultValue\"> {\n label?: string;\n min?: number;\n max?: number;\n step?: number;\n pageStep?: number;\n value?: SliderValue;\n defaultValue?: SliderValue;\n pushable?: boolean;\n pushDistance?: number;\n disabled?: boolean;\n onChange?: SliderChangeHandler;\n marks?: SliderMark[];\n hideMarks?: boolean;\n hideMarkLabels?: boolean;\n}\n\nexport const Slider = forwardRef<HTMLDivElement, SliderProps>(function Slider(\n {\n min = defaultMin,\n max = defaultMax,\n step = defaultStep,\n pageStep = step,\n value: valueProp,\n defaultValue = defaultMin,\n onChange,\n label,\n className,\n pushable,\n pushDistance = 0,\n disabled,\n marks,\n hideMarks,\n hideMarkLabels,\n ...restProps\n },\n ref,\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-slider\",\n css: sliderCss,\n window: targetWindow,\n });\n\n const trackRef = useRef<HTMLDivElement>(null);\n\n const [value, setValue] = useControlled<SliderValue>({\n controlled: valueProp,\n default: defaultValue,\n name: \"Slider\",\n state: \"Value\",\n });\n\n const updateValueItem = useValueUpdater(pushable, pushDistance, min, max);\n\n const trackStyle = useMemo(\n () => createTrackStyle(min, max, value),\n [min, max, value],\n );\n\n const valueLength = Array.isArray(value) ? value.length : 1;\n\n const handleStyles: CSSProperties[] = useMemo(\n () => createHandleStyles(valueLength),\n [valueLength],\n );\n\n const onMouseDown = useSliderMouseDown(\n trackRef,\n value,\n min,\n max,\n step,\n updateValueItem,\n setValue,\n onChange,\n );\n\n const onKeyDown = useSliderKeyDown(\n value,\n min,\n max,\n pageStep,\n step,\n updateValueItem,\n setValue,\n onChange,\n );\n\n return (\n <div\n className={clsx(\n withBaseName(),\n {\n [withBaseName(\"disabled\")]: disabled,\n },\n className,\n )}\n ref={ref}\n onKeyDown={disabled ? undefined : onKeyDown}\n aria-label={`${label} slider from ${min} to ${max}`}\n role=\"group\"\n >\n {label !== undefined ? (\n <div className={withBaseName(\"label\")}>{label}</div>\n ) : null}\n <div\n className={withBaseName(\"clickable\")}\n onMouseDown={disabled ? undefined : onMouseDown}\n >\n <div\n className={withBaseName(\"track\")}\n style={trackStyle}\n ref={trackRef}\n >\n <SliderRail />\n {marks && !hideMarks ? (\n <SliderRailMarks min={min} max={max} marks={marks} />\n ) : null}\n {marks && !hideMarkLabels ? (\n <SliderMarkLabels min={min} max={max} marks={marks} />\n ) : null}\n <SliderSelection valueLength={valueLength} />\n {(Array.isArray(value) ? value : [value]).map((v, i) => (\n <SliderHandle\n key={i}\n min={min}\n max={max}\n value={v}\n index={i}\n disabled={!!disabled}\n valueLength={valueLength}\n style={handleStyles[i]}\n />\n ))}\n </div>\n </div>\n </div>\n );\n});\n"],"names":["Slider","sliderCss"],"mappings":"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"}
@@ -2,8 +2,8 @@ import { jsx } from 'react/jsx-runtime';
2
2
  import { makePrefixer, Tooltip } from '@salt-ds/core';
3
3
  import { clsx } from 'clsx';
4
4
  import { getSliderAriaLabel } from './utils.js';
5
- import { useWindow } from '@salt-ds/window';
6
5
  import { useComponentCssInjection } from '@salt-ds/styles';
6
+ import { useWindow } from '@salt-ds/window';
7
7
  import css_248z from '../Slider.css.js';
8
8
 
9
9
  const withBaseName = makePrefixer("saltSliderHandle");
@@ -1 +1 @@
1
- {"version":3,"file":"SliderHandle.js","sources":["../src/slider/internal/SliderHandle.tsx"],"sourcesContent":["import { makePrefixer, Tooltip } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { CSSProperties } from \"react\";\nimport { getSliderAriaLabel } from \"./utils\";\n\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport sliderCss from \"../Slider.css\";\n\nconst withBaseName = makePrefixer(\"saltSliderHandle\");\n\nexport interface SliderHandleProps {\n min: number;\n max: number;\n value: number;\n index: number;\n disabled: boolean;\n valueLength: number;\n style: CSSProperties;\n}\n\nexport function SliderHandle(props: SliderHandleProps): JSX.Element {\n const { min, max, value, disabled, valueLength, index, style } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-slider\",\n css: sliderCss,\n window: targetWindow,\n });\n\n return (\n <Tooltip content={value} placement=\"top\">\n <div\n className={clsx(withBaseName(), {\n [withBaseName(\"min\")]: value === min,\n [withBaseName(\"max\")]: value === max,\n })}\n style={style}\n role=\"slider\"\n aria-valuemin={min}\n aria-valuemax={max}\n aria-valuenow={value}\n aria-disabled={disabled}\n aria-label={getSliderAriaLabel(valueLength, index)}\n tabIndex={0}\n data-handle-index={index}\n />\n </Tooltip>\n );\n}\n"],"names":["sliderCss"],"mappings":";;;;;;;;AASA,MAAM,YAAA,GAAe,aAAa,kBAAkB,CAAA,CAAA;AAY7C,SAAS,aAAa,KAAuC,EAAA;AAClE,EAAM,MAAA,EAAE,KAAK,GAAK,EAAA,KAAA,EAAO,UAAU,WAAa,EAAA,KAAA,EAAO,OAAU,GAAA,KAAA,CAAA;AAEjE,EAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,aAAA;AAAA,IACR,GAAK,EAAAA,QAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,uBACG,GAAA,CAAA,OAAA,EAAA;AAAA,IAAQ,OAAS,EAAA,KAAA;AAAA,IAAO,SAAU,EAAA,KAAA;AAAA,IACjC,QAAC,kBAAA,GAAA,CAAA,KAAA,EAAA;AAAA,MACC,SAAA,EAAW,IAAK,CAAA,YAAA,EAAgB,EAAA;AAAA,QAC9B,CAAC,YAAA,CAAa,KAAK,CAAA,GAAI,KAAU,KAAA,GAAA;AAAA,QACjC,CAAC,YAAA,CAAa,KAAK,CAAA,GAAI,KAAU,KAAA,GAAA;AAAA,OAClC,CAAA;AAAA,MACD,KAAA;AAAA,MACA,IAAK,EAAA,QAAA;AAAA,MACL,eAAe,EAAA,GAAA;AAAA,MACf,eAAe,EAAA,GAAA;AAAA,MACf,eAAe,EAAA,KAAA;AAAA,MACf,eAAe,EAAA,QAAA;AAAA,MACf,YAAA,EAAY,kBAAmB,CAAA,WAAA,EAAa,KAAK,CAAA;AAAA,MACjD,QAAU,EAAA,CAAA;AAAA,MACV,mBAAmB,EAAA,KAAA;AAAA,KACrB,CAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
1
+ {"version":3,"file":"SliderHandle.js","sources":["../src/slider/internal/SliderHandle.tsx"],"sourcesContent":["import { Tooltip, makePrefixer } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport type { CSSProperties } from \"react\";\nimport { getSliderAriaLabel } from \"./utils\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport sliderCss from \"../Slider.css\";\n\nconst withBaseName = makePrefixer(\"saltSliderHandle\");\n\nexport interface SliderHandleProps {\n min: number;\n max: number;\n value: number;\n index: number;\n disabled: boolean;\n valueLength: number;\n style: CSSProperties;\n}\n\nexport function SliderHandle(props: SliderHandleProps): JSX.Element {\n const { min, max, value, disabled, valueLength, index, style } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-slider\",\n css: sliderCss,\n window: targetWindow,\n });\n\n return (\n <Tooltip content={value} placement=\"top\">\n <div\n className={clsx(withBaseName(), {\n [withBaseName(\"min\")]: value === min,\n [withBaseName(\"max\")]: value === max,\n })}\n style={style}\n role=\"slider\"\n aria-valuemin={min}\n aria-valuemax={max}\n aria-valuenow={value}\n aria-disabled={disabled}\n aria-label={getSliderAriaLabel(valueLength, index)}\n tabIndex={0}\n data-handle-index={index}\n />\n </Tooltip>\n );\n}\n"],"names":["sliderCss"],"mappings":";;;;;;;;AASA,MAAM,YAAA,GAAe,aAAa,kBAAkB,CAAA,CAAA;AAY7C,SAAS,aAAa,KAAuC,EAAA;AAClE,EAAM,MAAA,EAAE,KAAK,GAAK,EAAA,KAAA,EAAO,UAAU,WAAa,EAAA,KAAA,EAAO,OAAU,GAAA,KAAA,CAAA;AAEjE,EAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,aAAA;AAAA,IACR,GAAK,EAAAA,QAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,uBACG,GAAA,CAAA,OAAA,EAAA;AAAA,IAAQ,OAAS,EAAA,KAAA;AAAA,IAAO,SAAU,EAAA,KAAA;AAAA,IACjC,QAAC,kBAAA,GAAA,CAAA,KAAA,EAAA;AAAA,MACC,SAAA,EAAW,IAAK,CAAA,YAAA,EAAgB,EAAA;AAAA,QAC9B,CAAC,YAAA,CAAa,KAAK,CAAA,GAAI,KAAU,KAAA,GAAA;AAAA,QACjC,CAAC,YAAA,CAAa,KAAK,CAAA,GAAI,KAAU,KAAA,GAAA;AAAA,OAClC,CAAA;AAAA,MACD,KAAA;AAAA,MACA,IAAK,EAAA,QAAA;AAAA,MACL,eAAe,EAAA,GAAA;AAAA,MACf,eAAe,EAAA,GAAA;AAAA,MACf,eAAe,EAAA,KAAA;AAAA,MACf,eAAe,EAAA,QAAA;AAAA,MACf,YAAA,EAAY,kBAAmB,CAAA,WAAA,EAAa,KAAK,CAAA;AAAA,MACjD,QAAU,EAAA,CAAA;AAAA,MACV,mBAAmB,EAAA,KAAA;AAAA,KACrB,CAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
@@ -1,10 +1,10 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
2
  import { makePrefixer } from '@salt-ds/core';
3
+ import { useMemo } from 'react';
3
4
  import { createSliderMarkLabelsStyle, createSliderMarkLabelStyles } from './styles.js';
4
5
  import { isLabeledMark } from './utils.js';
5
- import { useMemo } from 'react';
6
- import { useWindow } from '@salt-ds/window';
7
6
  import { useComponentCssInjection } from '@salt-ds/styles';
7
+ import { useWindow } from '@salt-ds/window';
8
8
  import css_248z from '../Slider.css.js';
9
9
 
10
10
  const withBaseName = makePrefixer("saltSliderMarkLabels");
@@ -32,7 +32,7 @@ function SliderMarkLabels(props) {
32
32
  className: withBaseName("label"),
33
33
  style: labelStyles[i],
34
34
  children: isLabeledMark(mark) ? mark.label : `${mark}`
35
- }, i);
35
+ }, isLabeledMark(mark) ? mark.value : mark);
36
36
  })
37
37
  });
38
38
  }
@@ -1 +1 @@
1
- {"version":3,"file":"SliderMarkLabels.js","sources":["../src/slider/internal/SliderMarkLabels.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport {\n createSliderMarkLabelsStyle,\n createSliderMarkLabelStyles,\n} from \"./styles\";\nimport { isLabeledMark } from \"./utils\";\nimport { SliderMark } from \"./SliderRailMarks\";\nimport { useMemo } from \"react\";\n\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport sliderCss from \"../Slider.css\";\n\nconst withBaseName = makePrefixer(\"saltSliderMarkLabels\");\n\nexport interface SliderMarkLabelsProps {\n min: number;\n max: number;\n marks: SliderMark[];\n}\n\nexport function SliderMarkLabels(props: SliderMarkLabelsProps) {\n const { min, max, marks } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-slider\",\n css: sliderCss,\n window: targetWindow,\n });\n\n const style = useMemo(\n () => createSliderMarkLabelsStyle(min, max, marks),\n [min, max, marks]\n );\n const labelStyles = useMemo(\n () => createSliderMarkLabelStyles(marks),\n [marks]\n );\n return (\n <div className={withBaseName()} style={style}>\n {marks.map((mark, i) => {\n return (\n <div key={i} className={withBaseName(\"label\")} style={labelStyles[i]}>\n {isLabeledMark(mark) ? mark.label : `${mark}`}\n </div>\n );\n })}\n </div>\n );\n}\n"],"names":["sliderCss"],"mappings":";;;;;;;;;AAaA,MAAM,YAAA,GAAe,aAAa,sBAAsB,CAAA,CAAA;AAQjD,SAAS,iBAAiB,KAA8B,EAAA;AAC7D,EAAA,MAAM,EAAE,GAAA,EAAK,GAAK,EAAA,KAAA,EAAU,GAAA,KAAA,CAAA;AAE5B,EAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,aAAA;AAAA,IACR,GAAK,EAAAA,QAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,MAAM,KAAQ,GAAA,OAAA;AAAA,IACZ,MAAM,2BAAA,CAA4B,GAAK,EAAA,GAAA,EAAK,KAAK,CAAA;AAAA,IACjD,CAAC,GAAK,EAAA,GAAA,EAAK,KAAK,CAAA;AAAA,GAClB,CAAA;AACA,EAAA,MAAM,WAAc,GAAA,OAAA;AAAA,IAClB,MAAM,4BAA4B,KAAK,CAAA;AAAA,IACvC,CAAC,KAAK,CAAA;AAAA,GACR,CAAA;AACA,EAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,IAAI,WAAW,YAAa,EAAA;AAAA,IAAG,KAAA;AAAA,IAC7B,QAAM,EAAA,KAAA,CAAA,GAAA,CAAI,CAAC,IAAA,EAAM,CAAM,KAAA;AACtB,MAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,QAAY,SAAA,EAAW,aAAa,OAAO,CAAA;AAAA,QAAG,OAAO,WAAY,CAAA,CAAA,CAAA;AAAA,QAC/D,QAAc,EAAA,aAAA,CAAA,IAAI,CAAI,GAAA,IAAA,CAAK,QAAQ,CAAG,EAAA,IAAA,CAAA,CAAA;AAAA,OAAA,EAD/B,CAEV,CAAA,CAAA;AAAA,KAEH,CAAA;AAAA,GACH,CAAA,CAAA;AAEJ;;;;"}
1
+ {"version":3,"file":"SliderMarkLabels.js","sources":["../src/slider/internal/SliderMarkLabels.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport { useMemo } from \"react\";\nimport type { SliderMark } from \"./SliderRailMarks\";\nimport {\n createSliderMarkLabelStyles,\n createSliderMarkLabelsStyle,\n} from \"./styles\";\nimport { isLabeledMark } from \"./utils\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport sliderCss from \"../Slider.css\";\n\nconst withBaseName = makePrefixer(\"saltSliderMarkLabels\");\n\nexport interface SliderMarkLabelsProps {\n min: number;\n max: number;\n marks: SliderMark[];\n}\n\nexport function SliderMarkLabels(props: SliderMarkLabelsProps) {\n const { min, max, marks } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-slider\",\n css: sliderCss,\n window: targetWindow,\n });\n\n const style = useMemo(\n () => createSliderMarkLabelsStyle(min, max, marks),\n [min, max, marks],\n );\n const labelStyles = useMemo(\n () => createSliderMarkLabelStyles(marks),\n [marks],\n );\n return (\n <div className={withBaseName()} style={style}>\n {marks.map((mark, i) => {\n return (\n <div\n key={isLabeledMark(mark) ? mark.value : mark}\n className={withBaseName(\"label\")}\n style={labelStyles[i]}\n >\n {isLabeledMark(mark) ? mark.label : `${mark}`}\n </div>\n );\n })}\n </div>\n );\n}\n"],"names":["sliderCss"],"mappings":";;;;;;;;;AAaA,MAAM,YAAA,GAAe,aAAa,sBAAsB,CAAA,CAAA;AAQjD,SAAS,iBAAiB,KAA8B,EAAA;AAC7D,EAAA,MAAM,EAAE,GAAA,EAAK,GAAK,EAAA,KAAA,EAAU,GAAA,KAAA,CAAA;AAE5B,EAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,aAAA;AAAA,IACR,GAAK,EAAAA,QAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,MAAM,KAAQ,GAAA,OAAA;AAAA,IACZ,MAAM,2BAAA,CAA4B,GAAK,EAAA,GAAA,EAAK,KAAK,CAAA;AAAA,IACjD,CAAC,GAAK,EAAA,GAAA,EAAK,KAAK,CAAA;AAAA,GAClB,CAAA;AACA,EAAA,MAAM,WAAc,GAAA,OAAA;AAAA,IAClB,MAAM,4BAA4B,KAAK,CAAA;AAAA,IACvC,CAAC,KAAK,CAAA;AAAA,GACR,CAAA;AACA,EAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,IAAI,WAAW,YAAa,EAAA;AAAA,IAAG,KAAA;AAAA,IAC7B,QAAM,EAAA,KAAA,CAAA,GAAA,CAAI,CAAC,IAAA,EAAM,CAAM,KAAA;AACtB,MAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,QAEC,SAAA,EAAW,aAAa,OAAO,CAAA;AAAA,QAC/B,OAAO,WAAY,CAAA,CAAA,CAAA;AAAA,QAElB,QAAc,EAAA,aAAA,CAAA,IAAI,CAAI,GAAA,IAAA,CAAK,QAAQ,CAAG,EAAA,IAAA,CAAA,CAAA;AAAA,OAAA,EAJlC,aAAc,CAAA,IAAI,CAAI,GAAA,IAAA,CAAK,QAAQ,IAK1C,CAAA,CAAA;AAAA,KAEH,CAAA;AAAA,GACH,CAAA,CAAA;AAEJ;;;;"}
@@ -1,11 +1,11 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
2
  import { makePrefixer } from '@salt-ds/core';
3
- import { useWindow } from '@salt-ds/window';
4
3
  import { useComponentCssInjection } from '@salt-ds/styles';
4
+ import { useWindow } from '@salt-ds/window';
5
5
  import css_248z from '../Slider.css.js';
6
6
 
7
7
  const withBaseName = makePrefixer("saltSliderRail");
8
- function SliderRail(props) {
8
+ function SliderRail() {
9
9
  const targetWindow = useWindow();
10
10
  useComponentCssInjection({
11
11
  testId: "salt-slider",
@@ -1 +1 @@
1
- {"version":3,"file":"SliderRail.js","sources":["../src/slider/internal/SliderRail.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\n\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport sliderCss from \"../Slider.css\";\n\nexport interface SliderRailProps {}\n\nconst withBaseName = makePrefixer(\"saltSliderRail\");\n\nexport function SliderRail(props: SliderRailProps) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-slider\",\n css: sliderCss,\n window: targetWindow,\n });\n return <div className={withBaseName()} />;\n}\n"],"names":["sliderCss"],"mappings":";;;;;;AAQA,MAAM,YAAA,GAAe,aAAa,gBAAgB,CAAA,CAAA;AAE3C,SAAS,WAAW,KAAwB,EAAA;AACjD,EAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,aAAA;AAAA,IACR,GAAK,EAAAA,QAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AACD,EAAA,uBAAQ,GAAA,CAAA,KAAA,EAAA;AAAA,IAAI,WAAW,YAAa,EAAA;AAAA,GAAG,CAAA,CAAA;AACzC;;;;"}
1
+ {"version":3,"file":"SliderRail.js","sources":["../src/slider/internal/SliderRail.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport sliderCss from \"../Slider.css\";\n\nconst withBaseName = makePrefixer(\"saltSliderRail\");\n\nexport function SliderRail() {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-slider\",\n css: sliderCss,\n window: targetWindow,\n });\n return <div className={withBaseName()} />;\n}\n"],"names":["sliderCss"],"mappings":";;;;;;AAMA,MAAM,YAAA,GAAe,aAAa,gBAAgB,CAAA,CAAA;AAE3C,SAAS,UAAa,GAAA;AAC3B,EAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,aAAA;AAAA,IACR,GAAK,EAAAA,QAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AACD,EAAA,uBAAQ,GAAA,CAAA,KAAA,EAAA;AAAA,IAAI,WAAW,YAAa,EAAA;AAAA,GAAG,CAAA,CAAA;AACzC;;;;"}
@@ -1,11 +1,11 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
- import { useMemo } from 'react';
3
2
  import { makePrefixer } from '@salt-ds/core';
4
3
  import { clsx } from 'clsx';
4
+ import { useMemo } from 'react';
5
5
  import { createSliderRailMarksStyle, createHandleStyles } from './styles.js';
6
- import { isMarkAtMax } from './utils.js';
7
- import { useWindow } from '@salt-ds/window';
6
+ import { isMarkAtMax, isLabeledMark } from './utils.js';
8
7
  import { useComponentCssInjection } from '@salt-ds/styles';
8
+ import { useWindow } from '@salt-ds/window';
9
9
  import css_248z from '../Slider.css.js';
10
10
 
11
11
  const withBaseName = makePrefixer("saltSliderRailMarks");
@@ -35,7 +35,7 @@ function SliderRailMarks(props) {
35
35
  [withBaseName("max")]: isMarkAtMax(max, mark)
36
36
  }),
37
37
  style: markStyles[i]
38
- }, `Mark${i}`);
38
+ }, isLabeledMark(mark) ? mark.value : mark);
39
39
  })
40
40
  });
41
41
  }
@@ -1 +1 @@
1
- {"version":3,"file":"SliderRailMarks.js","sources":["../src/slider/internal/SliderRailMarks.tsx"],"sourcesContent":["import { ReactNode, useMemo } from \"react\";\nimport { makePrefixer } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { createHandleStyles, createSliderRailMarksStyle } from \"./styles\";\nimport { isMarkAtMax } from \"./utils\";\n\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport sliderCss from \"../Slider.css\";\n\nconst withBaseName = makePrefixer(\"saltSliderRailMarks\");\n\nexport interface LabeledMark {\n value: number;\n label: ReactNode;\n}\n\nexport type SliderMark = number | LabeledMark;\n\nexport interface SliderRailMarksProps {\n min: number;\n max: number;\n marks: SliderMark[];\n}\n\nexport function SliderRailMarks(props: SliderRailMarksProps) {\n const { min, max, marks } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-slider\",\n css: sliderCss,\n window: targetWindow,\n });\n\n const style = useMemo(\n () => createSliderRailMarksStyle(min, max, marks),\n [min, max, marks]\n );\n const marksLength = marks.length;\n const markStyles = useMemo(\n () => createHandleStyles(marksLength),\n [marksLength]\n );\n\n return (\n <div className={withBaseName()} style={style}>\n {marks.map((mark, i) => {\n return (\n <div\n key={`Mark${i}`}\n className={clsx(withBaseName(\"mark\"), {\n [withBaseName(\"max\")]: isMarkAtMax(max, mark),\n })}\n style={markStyles[i]}\n />\n );\n })}\n </div>\n );\n}\n"],"names":["sliderCss"],"mappings":";;;;;;;;;;AAUA,MAAM,YAAA,GAAe,aAAa,qBAAqB,CAAA,CAAA;AAehD,SAAS,gBAAgB,KAA6B,EAAA;AAC3D,EAAA,MAAM,EAAE,GAAA,EAAK,GAAK,EAAA,KAAA,EAAU,GAAA,KAAA,CAAA;AAE5B,EAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,aAAA;AAAA,IACR,GAAK,EAAAA,QAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,MAAM,KAAQ,GAAA,OAAA;AAAA,IACZ,MAAM,0BAAA,CAA2B,GAAK,EAAA,GAAA,EAAK,KAAK,CAAA;AAAA,IAChD,CAAC,GAAK,EAAA,GAAA,EAAK,KAAK,CAAA;AAAA,GAClB,CAAA;AACA,EAAA,MAAM,cAAc,KAAM,CAAA,MAAA,CAAA;AAC1B,EAAA,MAAM,UAAa,GAAA,OAAA;AAAA,IACjB,MAAM,mBAAmB,WAAW,CAAA;AAAA,IACpC,CAAC,WAAW,CAAA;AAAA,GACd,CAAA;AAEA,EAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,IAAI,WAAW,YAAa,EAAA;AAAA,IAAG,KAAA;AAAA,IAC7B,QAAM,EAAA,KAAA,CAAA,GAAA,CAAI,CAAC,IAAA,EAAM,CAAM,KAAA;AACtB,MAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,QAEC,SAAW,EAAA,IAAA,CAAK,YAAa,CAAA,MAAM,CAAG,EAAA;AAAA,UACpC,CAAC,YAAa,CAAA,KAAK,CAAI,GAAA,WAAA,CAAY,KAAK,IAAI,CAAA;AAAA,SAC7C,CAAA;AAAA,QACD,OAAO,UAAW,CAAA,CAAA,CAAA;AAAA,OAAA,EAJb,OAAO,CAKd,CAAA,CAAA,CAAA,CAAA;AAAA,KAEH,CAAA;AAAA,GACH,CAAA,CAAA;AAEJ;;;;"}
1
+ {"version":3,"file":"SliderRailMarks.js","sources":["../src/slider/internal/SliderRailMarks.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { type ReactNode, useMemo } from \"react\";\nimport { createHandleStyles, createSliderRailMarksStyle } from \"./styles\";\nimport { isLabeledMark, isMarkAtMax } from \"./utils\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport sliderCss from \"../Slider.css\";\n\nconst withBaseName = makePrefixer(\"saltSliderRailMarks\");\n\nexport interface LabeledMark {\n value: number;\n label: ReactNode;\n}\n\nexport type SliderMark = number | LabeledMark;\n\nexport interface SliderRailMarksProps {\n min: number;\n max: number;\n marks: SliderMark[];\n}\n\nexport function SliderRailMarks(props: SliderRailMarksProps) {\n const { min, max, marks } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-slider\",\n css: sliderCss,\n window: targetWindow,\n });\n\n const style = useMemo(\n () => createSliderRailMarksStyle(min, max, marks),\n [min, max, marks],\n );\n const marksLength = marks.length;\n const markStyles = useMemo(\n () => createHandleStyles(marksLength),\n [marksLength],\n );\n\n return (\n <div className={withBaseName()} style={style}>\n {marks.map((mark, i) => {\n return (\n <div\n key={isLabeledMark(mark) ? mark.value : mark}\n className={clsx(withBaseName(\"mark\"), {\n [withBaseName(\"max\")]: isMarkAtMax(max, mark),\n })}\n style={markStyles[i]}\n />\n );\n })}\n </div>\n );\n}\n"],"names":["sliderCss"],"mappings":";;;;;;;;;;AAUA,MAAM,YAAA,GAAe,aAAa,qBAAqB,CAAA,CAAA;AAehD,SAAS,gBAAgB,KAA6B,EAAA;AAC3D,EAAA,MAAM,EAAE,GAAA,EAAK,GAAK,EAAA,KAAA,EAAU,GAAA,KAAA,CAAA;AAE5B,EAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,aAAA;AAAA,IACR,GAAK,EAAAA,QAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,MAAM,KAAQ,GAAA,OAAA;AAAA,IACZ,MAAM,0BAAA,CAA2B,GAAK,EAAA,GAAA,EAAK,KAAK,CAAA;AAAA,IAChD,CAAC,GAAK,EAAA,GAAA,EAAK,KAAK,CAAA;AAAA,GAClB,CAAA;AACA,EAAA,MAAM,cAAc,KAAM,CAAA,MAAA,CAAA;AAC1B,EAAA,MAAM,UAAa,GAAA,OAAA;AAAA,IACjB,MAAM,mBAAmB,WAAW,CAAA;AAAA,IACpC,CAAC,WAAW,CAAA;AAAA,GACd,CAAA;AAEA,EAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,IAAI,WAAW,YAAa,EAAA;AAAA,IAAG,KAAA;AAAA,IAC7B,QAAM,EAAA,KAAA,CAAA,GAAA,CAAI,CAAC,IAAA,EAAM,CAAM,KAAA;AACtB,MAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,QAEC,SAAW,EAAA,IAAA,CAAK,YAAa,CAAA,MAAM,CAAG,EAAA;AAAA,UACpC,CAAC,YAAa,CAAA,KAAK,CAAI,GAAA,WAAA,CAAY,KAAK,IAAI,CAAA;AAAA,SAC7C,CAAA;AAAA,QACD,OAAO,UAAW,CAAA,CAAA,CAAA;AAAA,OAAA,EAJb,aAAc,CAAA,IAAI,CAAI,GAAA,IAAA,CAAK,QAAQ,IAK1C,CAAA,CAAA;AAAA,KAEH,CAAA;AAAA,GACH,CAAA,CAAA;AAEJ;;;;"}