@salt-ds/lab 1.0.0-alpha.47 → 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 (1236) hide show
  1. package/css/salt-lab.css +15 -29
  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 +10 -7
  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 +240 -239
  172. package/dist-cjs/date-input/DateInput.js.map +1 -1
  173. package/dist-cjs/date-picker/DatePicker.js +139 -146
  174. package/dist-cjs/date-picker/DatePicker.js.map +1 -1
  175. package/dist-cjs/date-picker/DatePickerContext.js +14 -20
  176. package/dist-cjs/date-picker/DatePickerContext.js.map +1 -1
  177. package/dist-cjs/date-picker/DatePickerPanel.css.js +1 -1
  178. package/dist-cjs/date-picker/DatePickerPanel.js +137 -121
  179. package/dist-cjs/date-picker/DatePickerPanel.js.map +1 -1
  180. package/dist-cjs/deck-item/DeckItem.js +2 -2
  181. package/dist-cjs/deck-item/DeckItem.js.map +1 -1
  182. package/dist-cjs/deck-layout/DeckLayout.js +6 -9
  183. package/dist-cjs/deck-layout/DeckLayout.js.map +1 -1
  184. package/dist-cjs/dropdown/Dropdown.js +12 -12
  185. package/dist-cjs/dropdown/Dropdown.js.map +1 -1
  186. package/dist-cjs/dropdown/DropdownBase.js +3 -3
  187. package/dist-cjs/dropdown/DropdownBase.js.map +1 -1
  188. package/dist-cjs/dropdown/DropdownButton.js +3 -3
  189. package/dist-cjs/dropdown/DropdownButton.js.map +1 -1
  190. package/dist-cjs/dropdown/useClickAway.js +1 -1
  191. package/dist-cjs/dropdown/useClickAway.js.map +1 -1
  192. package/dist-cjs/dropdown/useDropdown.js +13 -14
  193. package/dist-cjs/dropdown/useDropdown.js.map +1 -1
  194. package/dist-cjs/dropdown/useDropdownBase.js +10 -12
  195. package/dist-cjs/dropdown/useDropdownBase.js.map +1 -1
  196. package/dist-cjs/editable-label/EditableLabel.js +7 -7
  197. package/dist-cjs/editable-label/EditableLabel.js.map +1 -1
  198. package/dist-cjs/form-field-context-legacy/FormFieldLegacyContext.js.map +1 -1
  199. package/dist-cjs/form-field-context-legacy/useFormFieldLegacyProps.js +1 -1
  200. package/dist-cjs/form-field-context-legacy/useFormFieldLegacyProps.js.map +1 -1
  201. package/dist-cjs/form-field-legacy/FormActivationIndicator.css.js +1 -1
  202. package/dist-cjs/form-field-legacy/FormActivationIndicator.js +4 -4
  203. package/dist-cjs/form-field-legacy/FormActivationIndicator.js.map +1 -1
  204. package/dist-cjs/form-field-legacy/FormFieldLegacy.css.js +1 -1
  205. package/dist-cjs/form-field-legacy/FormFieldLegacy.js +6 -6
  206. package/dist-cjs/form-field-legacy/FormFieldLegacy.js.map +1 -1
  207. package/dist-cjs/form-field-legacy/FormHelperText.js +4 -5
  208. package/dist-cjs/form-field-legacy/FormHelperText.js.map +1 -1
  209. package/dist-cjs/form-field-legacy/FormLabel.js +4 -4
  210. package/dist-cjs/form-field-legacy/FormLabel.js.map +1 -1
  211. package/dist-cjs/form-field-legacy/NecessityIndicator.js +2 -2
  212. package/dist-cjs/form-field-legacy/NecessityIndicator.js.map +1 -1
  213. package/dist-cjs/form-field-legacy/StatusIndicator.js +6 -6
  214. package/dist-cjs/form-field-legacy/StatusIndicator.js.map +1 -1
  215. package/dist-cjs/form-group/FormGroup.js +2 -2
  216. package/dist-cjs/form-group/FormGroup.js.map +1 -1
  217. package/dist-cjs/formatted-input/FormattedInput.js +2 -2
  218. package/dist-cjs/formatted-input/FormattedInput.js.map +1 -1
  219. package/dist-cjs/formatted-input/internal/InputWithMask.js.map +1 -1
  220. package/dist-cjs/index.js +0 -2
  221. package/dist-cjs/index.js.map +1 -1
  222. package/dist-cjs/input-legacy/InputLegacy.js +5 -5
  223. package/dist-cjs/input-legacy/InputLegacy.js.map +1 -1
  224. package/dist-cjs/input-legacy/StaticInputAdornment.js +3 -3
  225. package/dist-cjs/input-legacy/StaticInputAdornment.js.map +1 -1
  226. package/dist-cjs/input-legacy/useCursorOnFocus.js +2 -2
  227. package/dist-cjs/input-legacy/useCursorOnFocus.js.map +1 -1
  228. package/dist-cjs/layer-layout/LayerLayout.js +4 -4
  229. package/dist-cjs/layer-layout/LayerLayout.js.map +1 -1
  230. package/dist-cjs/list/Highlighter.js +1 -1
  231. package/dist-cjs/list/Highlighter.js.map +1 -1
  232. package/dist-cjs/list/List.css.js +1 -1
  233. package/dist-cjs/list/List.js +4 -6
  234. package/dist-cjs/list/List.js.map +1 -1
  235. package/dist-cjs/list/ListItem.js +3 -3
  236. package/dist-cjs/list/ListItem.js.map +1 -1
  237. package/dist-cjs/list/ListItemGroup.js.map +1 -1
  238. package/dist-cjs/list/ListItemHeader.js.map +1 -1
  239. package/dist-cjs/list/VirtualizedList.js +3 -5
  240. package/dist-cjs/list/VirtualizedList.js.map +1 -1
  241. package/dist-cjs/list/keyset.js +1 -2
  242. package/dist-cjs/list/keyset.js.map +1 -1
  243. package/dist-cjs/list/useList.js.map +1 -1
  244. package/dist-cjs/list/useListHeight.js +1 -1
  245. package/dist-cjs/list/useListHeight.js.map +1 -1
  246. package/dist-cjs/list/useVirtualization.js +2 -2
  247. package/dist-cjs/list/useVirtualization.js.map +1 -1
  248. package/dist-cjs/list-deprecated/List.js.map +1 -1
  249. package/dist-cjs/list-deprecated/ListBase.js +52 -53
  250. package/dist-cjs/list-deprecated/ListBase.js.map +1 -1
  251. package/dist-cjs/list-deprecated/ListItem.js +2 -2
  252. package/dist-cjs/list-deprecated/ListItem.js.map +1 -1
  253. package/dist-cjs/list-deprecated/ListItemBase.js +1 -1
  254. package/dist-cjs/list-deprecated/ListItemBase.js.map +1 -1
  255. package/dist-cjs/list-deprecated/ListItemContext.js +1 -1
  256. package/dist-cjs/list-deprecated/ListItemContext.js.map +1 -1
  257. package/dist-cjs/list-deprecated/ListStateContext.js.map +1 -1
  258. package/dist-cjs/list-deprecated/internal/DescendantContext.js +1 -1
  259. package/dist-cjs/list-deprecated/internal/DescendantContext.js.map +1 -1
  260. package/dist-cjs/list-deprecated/internal/Highlighter.js +2 -2
  261. package/dist-cjs/list-deprecated/internal/Highlighter.js.map +1 -1
  262. package/dist-cjs/list-deprecated/internal/calcPreferredListHeight.js +1 -1
  263. package/dist-cjs/list-deprecated/internal/calcPreferredListHeight.js.map +1 -1
  264. package/dist-cjs/list-deprecated/internal/helpers.js.map +1 -1
  265. package/dist-cjs/list-deprecated/internal/useListAutoSizer.js +1 -1
  266. package/dist-cjs/list-deprecated/internal/useListAutoSizer.js.map +1 -1
  267. package/dist-cjs/list-deprecated/internal/useWidth.js.map +1 -1
  268. package/dist-cjs/list-deprecated/itemToString.js.map +1 -1
  269. package/dist-cjs/list-deprecated/useList.js +4 -22
  270. package/dist-cjs/list-deprecated/useList.js.map +1 -1
  271. package/dist-cjs/list-deprecated/useListItem.js +2 -2
  272. package/dist-cjs/list-deprecated/useListItem.js.map +1 -1
  273. package/dist-cjs/list-deprecated/useTypeSelect.js +1 -1
  274. package/dist-cjs/list-deprecated/useTypeSelect.js.map +1 -1
  275. package/dist-cjs/list-next/ListItemNext.js +3 -3
  276. package/dist-cjs/list-next/ListItemNext.js.map +1 -1
  277. package/dist-cjs/list-next/ListNext.js +4 -4
  278. package/dist-cjs/list-next/ListNext.js.map +1 -1
  279. package/dist-cjs/list-next/ListNextContext.js.map +1 -1
  280. package/dist-cjs/list-next/useList.js +6 -9
  281. package/dist-cjs/list-next/useList.js.map +1 -1
  282. package/dist-cjs/logo/Logo.js +19 -17
  283. package/dist-cjs/logo/Logo.js.map +1 -1
  284. package/dist-cjs/logo/LogoImage.js +3 -3
  285. package/dist-cjs/logo/LogoImage.js.map +1 -1
  286. package/dist-cjs/logo/LogoSeparator.js +3 -3
  287. package/dist-cjs/logo/LogoSeparator.js.map +1 -1
  288. package/dist-cjs/menu-button/MenuButton.js +6 -6
  289. package/dist-cjs/menu-button/MenuButton.js.map +1 -1
  290. package/dist-cjs/menu-button/MenuButtonTrigger.js +3 -3
  291. package/dist-cjs/menu-button/MenuButtonTrigger.js.map +1 -1
  292. package/dist-cjs/metric/Metric.js +1 -1
  293. package/dist-cjs/metric/Metric.js.map +1 -1
  294. package/dist-cjs/metric/MetricContent.js +1 -1
  295. package/dist-cjs/metric/MetricContent.js.map +1 -1
  296. package/dist-cjs/metric/MetricHeader.js +1 -1
  297. package/dist-cjs/metric/MetricHeader.js.map +1 -1
  298. package/dist-cjs/portal/Portal.js +2 -5
  299. package/dist-cjs/portal/Portal.js.map +1 -1
  300. package/dist-cjs/query-input/QueryInput.js +1 -1
  301. package/dist-cjs/query-input/QueryInput.js.map +1 -1
  302. package/dist-cjs/query-input/internal/CategoryList.js +5 -5
  303. package/dist-cjs/query-input/internal/CategoryList.js.map +1 -1
  304. package/dist-cjs/query-input/internal/CategoryListContext.js +1 -1
  305. package/dist-cjs/query-input/internal/CategoryListContext.js.map +1 -1
  306. package/dist-cjs/query-input/internal/CategoryListItem.js.map +1 -1
  307. package/dist-cjs/query-input/internal/QueryInputBody.js.map +1 -1
  308. package/dist-cjs/query-input/internal/SearchList.js +2 -2
  309. package/dist-cjs/query-input/internal/SearchList.js.map +1 -1
  310. package/dist-cjs/query-input/internal/ValueList.js.map +1 -1
  311. package/dist-cjs/query-input/internal/ValueSelector.js +3 -3
  312. package/dist-cjs/query-input/internal/ValueSelector.js.map +1 -1
  313. package/dist-cjs/query-input/internal/usePopperStatus.js.map +1 -1
  314. package/dist-cjs/query-input/useQueryInput.js +36 -22
  315. package/dist-cjs/query-input/useQueryInput.js.map +1 -1
  316. package/dist-cjs/responsive/OverflowReducer.js +16 -19
  317. package/dist-cjs/responsive/OverflowReducer.js.map +1 -1
  318. package/dist-cjs/responsive/overflowUtils.js +22 -26
  319. package/dist-cjs/responsive/overflowUtils.js.map +1 -1
  320. package/dist-cjs/responsive/useDynamicCollapse.js +5 -5
  321. package/dist-cjs/responsive/useDynamicCollapse.js.map +1 -1
  322. package/dist-cjs/responsive/useInstantCollapse.js +3 -4
  323. package/dist-cjs/responsive/useInstantCollapse.js.map +1 -1
  324. package/dist-cjs/responsive/useOverflow.js +11 -6
  325. package/dist-cjs/responsive/useOverflow.js.map +1 -1
  326. package/dist-cjs/responsive/useOverflowCollectionItems.js +3 -3
  327. package/dist-cjs/responsive/useOverflowCollectionItems.js.map +1 -1
  328. package/dist-cjs/responsive/useOverflowLayout.js +3 -3
  329. package/dist-cjs/responsive/useOverflowLayout.js.map +1 -1
  330. package/dist-cjs/responsive/useReclaimSpace.js +10 -20
  331. package/dist-cjs/responsive/useReclaimSpace.js.map +1 -1
  332. package/dist-cjs/responsive/useResizeObserver.js +1 -1
  333. package/dist-cjs/responsive/useResizeObserver.js.map +1 -1
  334. package/dist-cjs/responsive/useWidth.js +2 -2
  335. package/dist-cjs/responsive/useWidth.js.map +1 -1
  336. package/dist-cjs/responsive/utils.js +1 -2
  337. package/dist-cjs/responsive/utils.js.map +1 -1
  338. package/dist-cjs/search-input/SearchInput.js +4 -4
  339. package/dist-cjs/search-input/SearchInput.js.map +1 -1
  340. package/dist-cjs/skip-link/SkipLink.js +3 -3
  341. package/dist-cjs/skip-link/SkipLink.js.map +1 -1
  342. package/dist-cjs/skip-link/SkipLinks.js +3 -3
  343. package/dist-cjs/skip-link/SkipLinks.js.map +1 -1
  344. package/dist-cjs/skip-link/internal/useManageFocusOnTarget.js.map +1 -1
  345. package/dist-cjs/slider/Slider.js +1 -1
  346. package/dist-cjs/slider/Slider.js.map +1 -1
  347. package/dist-cjs/slider/internal/SliderHandle.js +1 -1
  348. package/dist-cjs/slider/internal/SliderHandle.js.map +1 -1
  349. package/dist-cjs/slider/internal/SliderMarkLabels.js +3 -3
  350. package/dist-cjs/slider/internal/SliderMarkLabels.js.map +1 -1
  351. package/dist-cjs/slider/internal/SliderRail.js +2 -2
  352. package/dist-cjs/slider/internal/SliderRail.js.map +1 -1
  353. package/dist-cjs/slider/internal/SliderRailMarks.js +3 -3
  354. package/dist-cjs/slider/internal/SliderRailMarks.js.map +1 -1
  355. package/dist-cjs/slider/internal/SliderSelection.js +1 -1
  356. package/dist-cjs/slider/internal/SliderSelection.js.map +1 -1
  357. package/dist-cjs/slider/internal/styles.js +2 -2
  358. package/dist-cjs/slider/internal/styles.js.map +1 -1
  359. package/dist-cjs/slider/internal/useSliderKeyDown.js.map +1 -1
  360. package/dist-cjs/slider/internal/useSliderMouseDown.js +21 -18
  361. package/dist-cjs/slider/internal/useSliderMouseDown.js.map +1 -1
  362. package/dist-cjs/slider/internal/utils.js +1 -1
  363. package/dist-cjs/slider/internal/utils.js.map +1 -1
  364. package/dist-cjs/stepped-tracker/StepLabel/StepLabel.js +2 -2
  365. package/dist-cjs/stepped-tracker/StepLabel/StepLabel.js.map +1 -1
  366. package/dist-cjs/stepped-tracker/SteppedTracker.js +3 -3
  367. package/dist-cjs/stepped-tracker/SteppedTracker.js.map +1 -1
  368. package/dist-cjs/stepped-tracker/SteppedTrackerContext.js.map +1 -1
  369. package/dist-cjs/stepped-tracker/TrackerStep/TrackerStep.js +4 -4
  370. package/dist-cjs/stepped-tracker/TrackerStep/TrackerStep.js.map +1 -1
  371. package/dist-cjs/stepper-input/StepperInput.js +3 -3
  372. package/dist-cjs/stepper-input/StepperInput.js.map +1 -1
  373. package/dist-cjs/stepper-input/internal/useInterval.js.map +1 -1
  374. package/dist-cjs/stepper-input/internal/useSpinner.js +1 -1
  375. package/dist-cjs/stepper-input/internal/useSpinner.js.map +1 -1
  376. package/dist-cjs/stepper-input/useStepperInput.js +3 -3
  377. package/dist-cjs/stepper-input/useStepperInput.js.map +1 -1
  378. package/dist-cjs/tabs/Tab.js +5 -6
  379. package/dist-cjs/tabs/Tab.js.map +1 -1
  380. package/dist-cjs/tabs/TabActivationIndicator.js +1 -1
  381. package/dist-cjs/tabs/TabActivationIndicator.js.map +1 -1
  382. package/dist-cjs/tabs/TabPanel.js +3 -3
  383. package/dist-cjs/tabs/TabPanel.js.map +1 -1
  384. package/dist-cjs/tabs/Tabs.js +4 -4
  385. package/dist-cjs/tabs/Tabs.js.map +1 -1
  386. package/dist-cjs/tabs/Tabstrip.js +11 -14
  387. package/dist-cjs/tabs/Tabstrip.js.map +1 -1
  388. package/dist-cjs/tabs/drag-drop/Draggable.js +1 -1
  389. package/dist-cjs/tabs/drag-drop/Draggable.js.map +1 -1
  390. package/dist-cjs/tabs/drag-drop/drag-utils.js +29 -26
  391. package/dist-cjs/tabs/drag-drop/drag-utils.js.map +1 -1
  392. package/dist-cjs/tabs/drag-drop/dragDropTypes.js.map +1 -1
  393. package/dist-cjs/tabs/drag-drop/useDragDrop.js.map +1 -1
  394. package/dist-cjs/tabs/drag-drop/useDragDropNaturalMovement.js +5 -4
  395. package/dist-cjs/tabs/drag-drop/useDragDropNaturalMovement.js.map +1 -1
  396. package/dist-cjs/tabs/drag-drop/useDragSpacers.js +19 -16
  397. package/dist-cjs/tabs/drag-drop/useDragSpacers.js.map +1 -1
  398. package/dist-cjs/tabs/useActivationIndicator.js +3 -2
  399. package/dist-cjs/tabs/useActivationIndicator.js.map +1 -1
  400. package/dist-cjs/tabs/useEditableItem.js +1 -1
  401. package/dist-cjs/tabs/useEditableItem.js.map +1 -1
  402. package/dist-cjs/tabs/useItemsWithIds.js +4 -8
  403. package/dist-cjs/tabs/useItemsWithIds.js.map +1 -1
  404. package/dist-cjs/tabs/useKeyboardNavigation.js +26 -32
  405. package/dist-cjs/tabs/useKeyboardNavigation.js.map +1 -1
  406. package/dist-cjs/tabs/useSelection.js +2 -2
  407. package/dist-cjs/tabs/useSelection.js.map +1 -1
  408. package/dist-cjs/tabs/useTabs.js +1 -1
  409. package/dist-cjs/tabs/useTabs.js.map +1 -1
  410. package/dist-cjs/tabs/useTabstrip.js +6 -5
  411. package/dist-cjs/tabs/useTabstrip.js.map +1 -1
  412. package/dist-cjs/tabs-next/OverflowMenu.js +2 -2
  413. package/dist-cjs/tabs-next/OverflowMenu.js.map +1 -1
  414. package/dist-cjs/tabs-next/TabNext.js +74 -72
  415. package/dist-cjs/tabs-next/TabNext.js.map +1 -1
  416. package/dist-cjs/tabs-next/TabNextContext.js.map +1 -1
  417. package/dist-cjs/tabs-next/TabstripNext.js +5 -5
  418. package/dist-cjs/tabs-next/TabstripNext.js.map +1 -1
  419. package/dist-cjs/toast-group/ToastGroup.js +3 -3
  420. package/dist-cjs/toast-group/ToastGroup.js.map +1 -1
  421. package/dist-cjs/tokenized-input/TokenizedInput.js.map +1 -1
  422. package/dist-cjs/tokenized-input/TokenizedInputBase.js +12 -12
  423. package/dist-cjs/tokenized-input/TokenizedInputBase.js.map +1 -1
  424. package/dist-cjs/tokenized-input/internal/InputPill.js +2 -2
  425. package/dist-cjs/tokenized-input/internal/InputPill.js.map +1 -1
  426. package/dist-cjs/tokenized-input/internal/InputRuler.js +3 -3
  427. package/dist-cjs/tokenized-input/internal/InputRuler.js.map +1 -1
  428. package/dist-cjs/tokenized-input/internal/defaultItemToString.js.map +1 -1
  429. package/dist-cjs/tokenized-input/internal/getCursorPosition.js.map +1 -1
  430. package/dist-cjs/tokenized-input/internal/isPlainObject.js.map +1 -1
  431. package/dist-cjs/tokenized-input/internal/useResizeObserver.js.map +1 -1
  432. package/dist-cjs/tokenized-input/internal/useWidth.js +3 -3
  433. package/dist-cjs/tokenized-input/internal/useWidth.js.map +1 -1
  434. package/dist-cjs/tokenized-input/useTokenizedInput.js +12 -9
  435. package/dist-cjs/tokenized-input/useTokenizedInput.js.map +1 -1
  436. package/dist-cjs/tokenized-input-next/TokenizedInputNext.js +5 -5
  437. package/dist-cjs/tokenized-input-next/TokenizedInputNext.js.map +1 -1
  438. package/dist-cjs/tokenized-input-next/internal/InputPill.js +5 -5
  439. package/dist-cjs/tokenized-input-next/internal/InputPill.js.map +1 -1
  440. package/dist-cjs/tokenized-input-next/internal/useResizeObserver.js.map +1 -1
  441. package/dist-cjs/tokenized-input-next/internal/useWidth.js +3 -3
  442. package/dist-cjs/tokenized-input-next/internal/useWidth.js.map +1 -1
  443. package/dist-cjs/tokenized-input-next/useTokenizedInputNext.js +12 -14
  444. package/dist-cjs/tokenized-input-next/useTokenizedInputNext.js.map +1 -1
  445. package/dist-cjs/toolbar/Toolbar.js +3 -3
  446. package/dist-cjs/toolbar/Toolbar.js.map +1 -1
  447. package/dist-cjs/toolbar/ToolbarButton.js +2 -2
  448. package/dist-cjs/toolbar/ToolbarButton.js.map +1 -1
  449. package/dist-cjs/toolbar/Tooltray.js +1 -1
  450. package/dist-cjs/toolbar/Tooltray.js.map +1 -1
  451. package/dist-cjs/toolbar/internal/renderToolbarItems.js +22 -21
  452. package/dist-cjs/toolbar/internal/renderToolbarItems.js.map +1 -1
  453. package/dist-cjs/toolbar/internal/renderTrayTools.js +21 -23
  454. package/dist-cjs/toolbar/internal/renderTrayTools.js.map +1 -1
  455. package/dist-cjs/toolbar/overflow-panel/OverflowPanel.js +19 -21
  456. package/dist-cjs/toolbar/overflow-panel/OverflowPanel.js.map +1 -1
  457. package/dist-cjs/toolbar/overflow-panel/OverflowSeparator.js +2 -2
  458. package/dist-cjs/toolbar/overflow-panel/OverflowSeparator.js.map +1 -1
  459. package/dist-cjs/toolbar/toolbar-field/ToolbarField.js.map +1 -1
  460. package/dist-cjs/toolbar/toolbar-field/useToolbarField.js +8 -8
  461. package/dist-cjs/toolbar/toolbar-field/useToolbarField.js.map +1 -1
  462. package/dist-cjs/tree/Tree.js +9 -6
  463. package/dist-cjs/tree/Tree.js.map +1 -1
  464. package/dist-cjs/tree/TreeNode.js +2 -2
  465. package/dist-cjs/tree/TreeNode.js.map +1 -1
  466. package/dist-cjs/tree/use-tree-keyboard-navigation.js +5 -4
  467. package/dist-cjs/tree/use-tree-keyboard-navigation.js.map +1 -1
  468. package/dist-cjs/tree/useTree.js +1 -3
  469. package/dist-cjs/tree/useTree.js.map +1 -1
  470. package/dist-cjs/utils/forwardCallbackProps.js.map +1 -1
  471. package/dist-cjs/utils/partition.js.map +1 -1
  472. package/dist-cjs/utils/useClickOutside.js.map +1 -1
  473. package/dist-cjs/utils/useEventCallback.js +1 -1
  474. package/dist-cjs/utils/useEventCallback.js.map +1 -1
  475. package/dist-cjs/utils/useIsViewportLargerThanBreakpoint.js.map +1 -1
  476. package/dist-cjs/utils/useLayoutEffectOnce.js +1 -1
  477. package/dist-cjs/utils/useLayoutEffectOnce.js.map +1 -1
  478. package/dist-cjs/utils/useLayoutEffectSkipFirst.js +1 -1
  479. package/dist-cjs/utils/useLayoutEffectSkipFirst.js.map +1 -1
  480. package/dist-cjs/utils/useOverflowDetection.js +3 -3
  481. package/dist-cjs/utils/useOverflowDetection.js.map +1 -1
  482. package/dist-cjs/utils/useSlideSelection.js.map +1 -1
  483. package/dist-cjs/window/ElectronWindow.js +5 -7
  484. package/dist-cjs/window/ElectronWindow.js.map +1 -1
  485. package/dist-cjs/window/WindowContext.js.map +1 -1
  486. package/dist-es/app-header/AppHeader.js +3 -3
  487. package/dist-es/app-header/AppHeader.js.map +1 -1
  488. package/dist-es/breadcrumbs/Breadcrumb.js +1 -1
  489. package/dist-es/breadcrumbs/Breadcrumb.js.map +1 -1
  490. package/dist-es/breadcrumbs/Breadcrumbs.js +3 -4
  491. package/dist-es/breadcrumbs/Breadcrumbs.js.map +1 -1
  492. package/dist-es/breadcrumbs/internal/BreadcrumbsCollapsed.js +4 -4
  493. package/dist-es/breadcrumbs/internal/BreadcrumbsCollapsed.js.map +1 -1
  494. package/dist-es/breadcrumbs/internal/BreadcrumbsContext.js.map +1 -1
  495. package/dist-es/breadcrumbs/internal/BreadcrumbsSeparator.js.map +1 -1
  496. package/dist-es/breadcrumbs/internal/useFocusMenuRemount.js +1 -1
  497. package/dist-es/breadcrumbs/internal/useFocusMenuRemount.js.map +1 -1
  498. package/dist-es/button-bar/ButtonBar.js +10 -12
  499. package/dist-es/button-bar/ButtonBar.js.map +1 -1
  500. package/dist-es/button-bar/OrderedButton.js +2 -2
  501. package/dist-es/button-bar/OrderedButton.js.map +1 -1
  502. package/dist-es/button-bar/internal/ButtonBarContext.js.map +1 -1
  503. package/dist-es/button-bar/internal/DescendantContext.js +1 -1
  504. package/dist-es/button-bar/internal/DescendantContext.js.map +1 -1
  505. package/dist-es/button-bar/internal/useDescendant.js +1 -1
  506. package/dist-es/button-bar/internal/useDescendant.js.map +1 -1
  507. package/dist-es/button-bar/internal/useDescendants.js.map +1 -1
  508. package/dist-es/calendar/Calendar.js +10 -7
  509. package/dist-es/calendar/Calendar.js.map +1 -1
  510. package/dist-es/calendar/internal/CalendarCarousel.js +4 -4
  511. package/dist-es/calendar/internal/CalendarCarousel.js.map +1 -1
  512. package/dist-es/calendar/internal/CalendarContext.js.map +1 -1
  513. package/dist-es/calendar/internal/CalendarDay.css.js +1 -1
  514. package/dist-es/calendar/internal/CalendarDay.js +4 -4
  515. package/dist-es/calendar/internal/CalendarDay.js.map +1 -1
  516. package/dist-es/calendar/internal/CalendarMonth.js +5 -5
  517. package/dist-es/calendar/internal/CalendarMonth.js.map +1 -1
  518. package/dist-es/calendar/internal/CalendarNavigation.js +4 -4
  519. package/dist-es/calendar/internal/CalendarNavigation.js.map +1 -1
  520. package/dist-es/calendar/internal/CalendarWeekHeader.js +5 -5
  521. package/dist-es/calendar/internal/CalendarWeekHeader.js.map +1 -1
  522. package/dist-es/calendar/internal/useFocusManagement.js +1 -1
  523. package/dist-es/calendar/internal/useFocusManagement.js.map +1 -1
  524. package/dist-es/calendar/internal/utils.js.map +1 -1
  525. package/dist-es/calendar/useCalendar.js.map +1 -1
  526. package/dist-es/calendar/useCalendarDay.js.map +1 -1
  527. package/dist-es/calendar/useSelection.js +16 -12
  528. package/dist-es/calendar/useSelection.js.map +1 -1
  529. package/dist-es/carousel/Carousel.js +7 -6
  530. package/dist-es/carousel/Carousel.js.map +1 -1
  531. package/dist-es/carousel/CarouselSlide.js +1 -1
  532. package/dist-es/carousel/CarouselSlide.js.map +1 -1
  533. package/dist-es/cascading-menu/CascadingMenu.js +3 -4
  534. package/dist-es/cascading-menu/CascadingMenu.js.map +1 -1
  535. package/dist-es/cascading-menu/CascadingMenuItem.js +6 -7
  536. package/dist-es/cascading-menu/CascadingMenuItem.js.map +1 -1
  537. package/dist-es/cascading-menu/CascadingMenuList.js +8 -8
  538. package/dist-es/cascading-menu/CascadingMenuList.js.map +1 -1
  539. package/dist-es/cascading-menu/internal/CascadingMenuAction.js.map +1 -1
  540. package/dist-es/cascading-menu/internal/keydownHandlers.js +2 -2
  541. package/dist-es/cascading-menu/internal/keydownHandlers.js.map +1 -1
  542. package/dist-es/cascading-menu/internal/menuPositioning.js.map +1 -1
  543. package/dist-es/cascading-menu/internal/stateUtils.js +1 -2
  544. package/dist-es/cascading-menu/internal/stateUtils.js.map +1 -1
  545. package/dist-es/cascading-menu/internal/useClickAway.js +3 -2
  546. package/dist-es/cascading-menu/internal/useClickAway.js.map +1 -1
  547. package/dist-es/cascading-menu/internal/useMenuTriggerHandlers.js.map +1 -1
  548. package/dist-es/cascading-menu/internal/useMouseHandlers.js +1 -1
  549. package/dist-es/cascading-menu/internal/useMouseHandlers.js.map +1 -1
  550. package/dist-es/cascading-menu/internal/useRefsManager.js.map +1 -1
  551. package/dist-es/cascading-menu/internal/useStateReducer.js +1 -1
  552. package/dist-es/cascading-menu/internal/useStateReducer.js.map +1 -1
  553. package/dist-es/color-chooser/AlphaInputField.js +10 -10
  554. package/dist-es/color-chooser/AlphaInputField.js.map +1 -1
  555. package/dist-es/color-chooser/Color.js +1 -2
  556. package/dist-es/color-chooser/Color.js.map +1 -1
  557. package/dist-es/color-chooser/ColorChooser.css.js +1 -1
  558. package/dist-es/color-chooser/ColorChooser.js +4 -4
  559. package/dist-es/color-chooser/ColorChooser.js.map +1 -1
  560. package/dist-es/color-chooser/ColorHelpers.js +1 -1
  561. package/dist-es/color-chooser/ColorHelpers.js.map +1 -1
  562. package/dist-es/color-chooser/ColorPicker.js +3 -3
  563. package/dist-es/color-chooser/ColorPicker.js.map +1 -1
  564. package/dist-es/color-chooser/DictTabs.js +1 -1
  565. package/dist-es/color-chooser/DictTabs.js.map +1 -1
  566. package/dist-es/color-chooser/GetColorPalettes.js.map +1 -1
  567. package/dist-es/color-chooser/HexInput.js +5 -5
  568. package/dist-es/color-chooser/HexInput.js.map +1 -1
  569. package/dist-es/color-chooser/RGBAInput.js +3 -3
  570. package/dist-es/color-chooser/RGBAInput.js.map +1 -1
  571. package/dist-es/color-chooser/RGBAInputField.js +4 -4
  572. package/dist-es/color-chooser/RGBAInputField.js.map +1 -1
  573. package/dist-es/color-chooser/Swatch.css.js +1 -1
  574. package/dist-es/color-chooser/Swatch.js +1 -1
  575. package/dist-es/color-chooser/Swatch.js.map +1 -1
  576. package/dist-es/color-chooser/Swatches.js +2 -2
  577. package/dist-es/color-chooser/Swatches.js.map +1 -1
  578. package/dist-es/color-chooser/SwatchesPicker.js +2 -2
  579. package/dist-es/color-chooser/SwatchesPicker.js.map +1 -1
  580. package/dist-es/color-chooser/createTabsMapping.js.map +1 -1
  581. package/dist-es/combo-box/ComboBox.js +10 -10
  582. package/dist-es/combo-box/ComboBox.js.map +1 -1
  583. package/dist-es/combo-box/useCombobox.js +13 -20
  584. package/dist-es/combo-box/useCombobox.js.map +1 -1
  585. package/dist-es/combo-box-deprecated/ComboBoxDeprecated.js +5 -5
  586. package/dist-es/combo-box-deprecated/ComboBoxDeprecated.js.map +1 -1
  587. package/dist-es/combo-box-deprecated/internal/DefaultComboBox.js +7 -7
  588. package/dist-es/combo-box-deprecated/internal/DefaultComboBox.js.map +1 -1
  589. package/dist-es/combo-box-deprecated/internal/MultiSelectComboBox.js +3 -3
  590. package/dist-es/combo-box-deprecated/internal/MultiSelectComboBox.js.map +1 -1
  591. package/dist-es/combo-box-deprecated/internal/getAnnouncement.js +2 -2
  592. package/dist-es/combo-box-deprecated/internal/getAnnouncement.js.map +1 -1
  593. package/dist-es/combo-box-deprecated/internal/useComboBox.js +12 -10
  594. package/dist-es/combo-box-deprecated/internal/useComboBox.js.map +1 -1
  595. package/dist-es/combo-box-deprecated/internal/useMultiSelectComboBox.js +11 -15
  596. package/dist-es/combo-box-deprecated/internal/useMultiSelectComboBox.js.map +1 -1
  597. package/dist-es/combo-box-deprecated/internal/usePopperStatus.js.map +1 -1
  598. package/dist-es/common-hooks/calcPreferredHeight.js +1 -1
  599. package/dist-es/common-hooks/calcPreferredHeight.js.map +1 -1
  600. package/dist-es/common-hooks/collectionProvider.js.map +1 -1
  601. package/dist-es/common-hooks/itemToString.js +2 -1
  602. package/dist-es/common-hooks/itemToString.js.map +1 -1
  603. package/dist-es/common-hooks/keyUtils.js +2 -2
  604. package/dist-es/common-hooks/keyUtils.js.map +1 -1
  605. package/dist-es/common-hooks/list-dom-utils.js +4 -3
  606. package/dist-es/common-hooks/list-dom-utils.js.map +1 -1
  607. package/dist-es/common-hooks/selectionTypes.js.map +1 -1
  608. package/dist-es/common-hooks/useAutoSizer.js +2 -2
  609. package/dist-es/common-hooks/useAutoSizer.js.map +1 -1
  610. package/dist-es/common-hooks/useCollapsibleGroups.js.map +1 -1
  611. package/dist-es/common-hooks/useCollectionItems.js +13 -9
  612. package/dist-es/common-hooks/useCollectionItems.js.map +1 -1
  613. package/dist-es/common-hooks/useImperativeScrollingAPI.js +11 -7
  614. package/dist-es/common-hooks/useImperativeScrollingAPI.js.map +1 -1
  615. package/dist-es/common-hooks/useKeyboardNavigation.js +78 -82
  616. package/dist-es/common-hooks/useKeyboardNavigation.js.map +1 -1
  617. package/dist-es/common-hooks/useKeyboardNavigationPanel.js +14 -13
  618. package/dist-es/common-hooks/useKeyboardNavigationPanel.js.map +1 -1
  619. package/dist-es/common-hooks/useSelection.js +0 -1
  620. package/dist-es/common-hooks/useSelection.js.map +1 -1
  621. package/dist-es/common-hooks/useTypeahead.js.map +1 -1
  622. package/dist-es/common-hooks/useViewportTracking.js +24 -23
  623. package/dist-es/common-hooks/useViewportTracking.js.map +1 -1
  624. package/dist-es/common-hooks/utils/collection-item-utils.js +29 -29
  625. package/dist-es/common-hooks/utils/collection-item-utils.js.map +1 -1
  626. package/dist-es/common-hooks/utils/isSelected.js.map +1 -1
  627. package/dist-es/contact-details/ContactAction.js +1 -1
  628. package/dist-es/contact-details/ContactAction.js.map +1 -1
  629. package/dist-es/contact-details/ContactActions.js +2 -2
  630. package/dist-es/contact-details/ContactActions.js.map +1 -1
  631. package/dist-es/contact-details/ContactAvatar.js +3 -3
  632. package/dist-es/contact-details/ContactAvatar.js.map +1 -1
  633. package/dist-es/contact-details/ContactDetails.js +1 -1
  634. package/dist-es/contact-details/ContactDetails.js.map +1 -1
  635. package/dist-es/contact-details/ContactFavoriteToggle.js.map +1 -1
  636. package/dist-es/contact-details/ContactMetadata.js.map +1 -1
  637. package/dist-es/contact-details/ContactMetadataItem.js.map +1 -1
  638. package/dist-es/contact-details/ContactPrimaryInfo.js.map +1 -1
  639. package/dist-es/contact-details/ContactSecondaryInfo.js.map +1 -1
  640. package/dist-es/contact-details/ContactTertiaryInfo.js.map +1 -1
  641. package/dist-es/contact-details/MailLinkComponent.js.map +1 -1
  642. package/dist-es/contact-details/internal/ContactDetailsContext.js +1 -1
  643. package/dist-es/contact-details/internal/ContactDetailsContext.js.map +1 -1
  644. package/dist-es/contact-details/internal/FavoriteToggle.js.map +1 -1
  645. package/dist-es/contact-details/internal/FavoriteToggleWithTooltip.js +1 -1
  646. package/dist-es/contact-details/internal/FavoriteToggleWithTooltip.js.map +1 -1
  647. package/dist-es/contact-details/internal/StarIcon.js.map +1 -1
  648. package/dist-es/contact-details/internal/StarIconContainer.js +2 -2
  649. package/dist-es/contact-details/internal/StarIconContainer.js.map +1 -1
  650. package/dist-es/contact-details/internal/useComponentSize.js +7 -10
  651. package/dist-es/contact-details/internal/useComponentSize.js.map +1 -1
  652. package/dist-es/content-status/ContentStatus.js +1 -1
  653. package/dist-es/content-status/ContentStatus.js.map +1 -1
  654. package/dist-es/content-status/internal/StatusIndicator.js.map +1 -1
  655. package/dist-es/date-input/DateInput.js +240 -239
  656. package/dist-es/date-input/DateInput.js.map +1 -1
  657. package/dist-es/date-picker/DatePicker.js +139 -146
  658. package/dist-es/date-picker/DatePicker.js.map +1 -1
  659. package/dist-es/date-picker/DatePickerContext.js +14 -20
  660. package/dist-es/date-picker/DatePickerContext.js.map +1 -1
  661. package/dist-es/date-picker/DatePickerPanel.css.js +1 -1
  662. package/dist-es/date-picker/DatePickerPanel.js +137 -121
  663. package/dist-es/date-picker/DatePickerPanel.js.map +1 -1
  664. package/dist-es/deck-item/DeckItem.js +2 -2
  665. package/dist-es/deck-item/DeckItem.js.map +1 -1
  666. package/dist-es/deck-layout/DeckLayout.js +6 -9
  667. package/dist-es/deck-layout/DeckLayout.js.map +1 -1
  668. package/dist-es/dropdown/Dropdown.js +12 -12
  669. package/dist-es/dropdown/Dropdown.js.map +1 -1
  670. package/dist-es/dropdown/DropdownBase.js +3 -3
  671. package/dist-es/dropdown/DropdownBase.js.map +1 -1
  672. package/dist-es/dropdown/DropdownButton.js +3 -3
  673. package/dist-es/dropdown/DropdownButton.js.map +1 -1
  674. package/dist-es/dropdown/useClickAway.js +1 -1
  675. package/dist-es/dropdown/useClickAway.js.map +1 -1
  676. package/dist-es/dropdown/useDropdown.js +13 -14
  677. package/dist-es/dropdown/useDropdown.js.map +1 -1
  678. package/dist-es/dropdown/useDropdownBase.js +10 -12
  679. package/dist-es/dropdown/useDropdownBase.js.map +1 -1
  680. package/dist-es/editable-label/EditableLabel.js +7 -7
  681. package/dist-es/editable-label/EditableLabel.js.map +1 -1
  682. package/dist-es/form-field-context-legacy/FormFieldLegacyContext.js.map +1 -1
  683. package/dist-es/form-field-context-legacy/useFormFieldLegacyProps.js +1 -1
  684. package/dist-es/form-field-context-legacy/useFormFieldLegacyProps.js.map +1 -1
  685. package/dist-es/form-field-legacy/FormActivationIndicator.css.js +1 -1
  686. package/dist-es/form-field-legacy/FormActivationIndicator.js +4 -4
  687. package/dist-es/form-field-legacy/FormActivationIndicator.js.map +1 -1
  688. package/dist-es/form-field-legacy/FormFieldLegacy.css.js +1 -1
  689. package/dist-es/form-field-legacy/FormFieldLegacy.js +6 -6
  690. package/dist-es/form-field-legacy/FormFieldLegacy.js.map +1 -1
  691. package/dist-es/form-field-legacy/FormHelperText.js +4 -5
  692. package/dist-es/form-field-legacy/FormHelperText.js.map +1 -1
  693. package/dist-es/form-field-legacy/FormLabel.js +4 -4
  694. package/dist-es/form-field-legacy/FormLabel.js.map +1 -1
  695. package/dist-es/form-field-legacy/NecessityIndicator.js +2 -2
  696. package/dist-es/form-field-legacy/NecessityIndicator.js.map +1 -1
  697. package/dist-es/form-field-legacy/StatusIndicator.js +6 -6
  698. package/dist-es/form-field-legacy/StatusIndicator.js.map +1 -1
  699. package/dist-es/form-group/FormGroup.js +2 -2
  700. package/dist-es/form-group/FormGroup.js.map +1 -1
  701. package/dist-es/formatted-input/FormattedInput.js +2 -2
  702. package/dist-es/formatted-input/FormattedInput.js.map +1 -1
  703. package/dist-es/formatted-input/internal/InputWithMask.js.map +1 -1
  704. package/dist-es/index.js +0 -1
  705. package/dist-es/index.js.map +1 -1
  706. package/dist-es/input-legacy/InputLegacy.js +5 -5
  707. package/dist-es/input-legacy/InputLegacy.js.map +1 -1
  708. package/dist-es/input-legacy/StaticInputAdornment.js +3 -3
  709. package/dist-es/input-legacy/StaticInputAdornment.js.map +1 -1
  710. package/dist-es/input-legacy/useCursorOnFocus.js +2 -2
  711. package/dist-es/input-legacy/useCursorOnFocus.js.map +1 -1
  712. package/dist-es/layer-layout/LayerLayout.js +4 -4
  713. package/dist-es/layer-layout/LayerLayout.js.map +1 -1
  714. package/dist-es/list/Highlighter.js +1 -1
  715. package/dist-es/list/Highlighter.js.map +1 -1
  716. package/dist-es/list/List.css.js +1 -1
  717. package/dist-es/list/List.js +4 -6
  718. package/dist-es/list/List.js.map +1 -1
  719. package/dist-es/list/ListItem.js +3 -3
  720. package/dist-es/list/ListItem.js.map +1 -1
  721. package/dist-es/list/ListItemGroup.js.map +1 -1
  722. package/dist-es/list/ListItemHeader.js.map +1 -1
  723. package/dist-es/list/VirtualizedList.js +3 -5
  724. package/dist-es/list/VirtualizedList.js.map +1 -1
  725. package/dist-es/list/keyset.js +1 -2
  726. package/dist-es/list/keyset.js.map +1 -1
  727. package/dist-es/list/useList.js.map +1 -1
  728. package/dist-es/list/useListHeight.js +1 -1
  729. package/dist-es/list/useListHeight.js.map +1 -1
  730. package/dist-es/list/useVirtualization.js +2 -2
  731. package/dist-es/list/useVirtualization.js.map +1 -1
  732. package/dist-es/list-deprecated/List.js.map +1 -1
  733. package/dist-es/list-deprecated/ListBase.js +52 -53
  734. package/dist-es/list-deprecated/ListBase.js.map +1 -1
  735. package/dist-es/list-deprecated/ListItem.js +2 -2
  736. package/dist-es/list-deprecated/ListItem.js.map +1 -1
  737. package/dist-es/list-deprecated/ListItemBase.js +1 -1
  738. package/dist-es/list-deprecated/ListItemBase.js.map +1 -1
  739. package/dist-es/list-deprecated/ListItemContext.js +1 -1
  740. package/dist-es/list-deprecated/ListItemContext.js.map +1 -1
  741. package/dist-es/list-deprecated/ListStateContext.js.map +1 -1
  742. package/dist-es/list-deprecated/internal/DescendantContext.js +1 -1
  743. package/dist-es/list-deprecated/internal/DescendantContext.js.map +1 -1
  744. package/dist-es/list-deprecated/internal/Highlighter.js +2 -2
  745. package/dist-es/list-deprecated/internal/Highlighter.js.map +1 -1
  746. package/dist-es/list-deprecated/internal/calcPreferredListHeight.js +1 -1
  747. package/dist-es/list-deprecated/internal/calcPreferredListHeight.js.map +1 -1
  748. package/dist-es/list-deprecated/internal/helpers.js.map +1 -1
  749. package/dist-es/list-deprecated/internal/useListAutoSizer.js +1 -1
  750. package/dist-es/list-deprecated/internal/useListAutoSizer.js.map +1 -1
  751. package/dist-es/list-deprecated/internal/useWidth.js.map +1 -1
  752. package/dist-es/list-deprecated/itemToString.js.map +1 -1
  753. package/dist-es/list-deprecated/useList.js +4 -22
  754. package/dist-es/list-deprecated/useList.js.map +1 -1
  755. package/dist-es/list-deprecated/useListItem.js +2 -2
  756. package/dist-es/list-deprecated/useListItem.js.map +1 -1
  757. package/dist-es/list-deprecated/useTypeSelect.js +1 -1
  758. package/dist-es/list-deprecated/useTypeSelect.js.map +1 -1
  759. package/dist-es/list-next/ListItemNext.js +3 -3
  760. package/dist-es/list-next/ListItemNext.js.map +1 -1
  761. package/dist-es/list-next/ListNext.js +4 -4
  762. package/dist-es/list-next/ListNext.js.map +1 -1
  763. package/dist-es/list-next/ListNextContext.js.map +1 -1
  764. package/dist-es/list-next/useList.js +6 -9
  765. package/dist-es/list-next/useList.js.map +1 -1
  766. package/dist-es/logo/Logo.js +19 -17
  767. package/dist-es/logo/Logo.js.map +1 -1
  768. package/dist-es/logo/LogoImage.js +3 -3
  769. package/dist-es/logo/LogoImage.js.map +1 -1
  770. package/dist-es/logo/LogoSeparator.js +3 -3
  771. package/dist-es/logo/LogoSeparator.js.map +1 -1
  772. package/dist-es/menu-button/MenuButton.js +6 -6
  773. package/dist-es/menu-button/MenuButton.js.map +1 -1
  774. package/dist-es/menu-button/MenuButtonTrigger.js +3 -3
  775. package/dist-es/menu-button/MenuButtonTrigger.js.map +1 -1
  776. package/dist-es/metric/Metric.js +1 -1
  777. package/dist-es/metric/Metric.js.map +1 -1
  778. package/dist-es/metric/MetricContent.js +1 -1
  779. package/dist-es/metric/MetricContent.js.map +1 -1
  780. package/dist-es/metric/MetricHeader.js +1 -1
  781. package/dist-es/metric/MetricHeader.js.map +1 -1
  782. package/dist-es/portal/Portal.js +2 -5
  783. package/dist-es/portal/Portal.js.map +1 -1
  784. package/dist-es/query-input/QueryInput.js +1 -1
  785. package/dist-es/query-input/QueryInput.js.map +1 -1
  786. package/dist-es/query-input/internal/CategoryList.js +5 -5
  787. package/dist-es/query-input/internal/CategoryList.js.map +1 -1
  788. package/dist-es/query-input/internal/CategoryListContext.js +1 -1
  789. package/dist-es/query-input/internal/CategoryListContext.js.map +1 -1
  790. package/dist-es/query-input/internal/CategoryListItem.js.map +1 -1
  791. package/dist-es/query-input/internal/QueryInputBody.js.map +1 -1
  792. package/dist-es/query-input/internal/SearchList.js +2 -2
  793. package/dist-es/query-input/internal/SearchList.js.map +1 -1
  794. package/dist-es/query-input/internal/ValueList.js.map +1 -1
  795. package/dist-es/query-input/internal/ValueSelector.js +3 -3
  796. package/dist-es/query-input/internal/ValueSelector.js.map +1 -1
  797. package/dist-es/query-input/internal/usePopperStatus.js.map +1 -1
  798. package/dist-es/query-input/useQueryInput.js +36 -22
  799. package/dist-es/query-input/useQueryInput.js.map +1 -1
  800. package/dist-es/responsive/OverflowReducer.js +16 -19
  801. package/dist-es/responsive/OverflowReducer.js.map +1 -1
  802. package/dist-es/responsive/overflowUtils.js +22 -26
  803. package/dist-es/responsive/overflowUtils.js.map +1 -1
  804. package/dist-es/responsive/useDynamicCollapse.js +5 -5
  805. package/dist-es/responsive/useDynamicCollapse.js.map +1 -1
  806. package/dist-es/responsive/useInstantCollapse.js +3 -4
  807. package/dist-es/responsive/useInstantCollapse.js.map +1 -1
  808. package/dist-es/responsive/useOverflow.js +11 -6
  809. package/dist-es/responsive/useOverflow.js.map +1 -1
  810. package/dist-es/responsive/useOverflowCollectionItems.js +3 -3
  811. package/dist-es/responsive/useOverflowCollectionItems.js.map +1 -1
  812. package/dist-es/responsive/useOverflowLayout.js +3 -3
  813. package/dist-es/responsive/useOverflowLayout.js.map +1 -1
  814. package/dist-es/responsive/useReclaimSpace.js +11 -21
  815. package/dist-es/responsive/useReclaimSpace.js.map +1 -1
  816. package/dist-es/responsive/useResizeObserver.js +1 -1
  817. package/dist-es/responsive/useResizeObserver.js.map +1 -1
  818. package/dist-es/responsive/useWidth.js +2 -2
  819. package/dist-es/responsive/useWidth.js.map +1 -1
  820. package/dist-es/responsive/utils.js +1 -2
  821. package/dist-es/responsive/utils.js.map +1 -1
  822. package/dist-es/search-input/SearchInput.js +4 -4
  823. package/dist-es/search-input/SearchInput.js.map +1 -1
  824. package/dist-es/skip-link/SkipLink.js +3 -3
  825. package/dist-es/skip-link/SkipLink.js.map +1 -1
  826. package/dist-es/skip-link/SkipLinks.js +3 -3
  827. package/dist-es/skip-link/SkipLinks.js.map +1 -1
  828. package/dist-es/skip-link/internal/useManageFocusOnTarget.js.map +1 -1
  829. package/dist-es/slider/Slider.js +1 -1
  830. package/dist-es/slider/Slider.js.map +1 -1
  831. package/dist-es/slider/internal/SliderHandle.js +1 -1
  832. package/dist-es/slider/internal/SliderHandle.js.map +1 -1
  833. package/dist-es/slider/internal/SliderMarkLabels.js +3 -3
  834. package/dist-es/slider/internal/SliderMarkLabels.js.map +1 -1
  835. package/dist-es/slider/internal/SliderRail.js +2 -2
  836. package/dist-es/slider/internal/SliderRail.js.map +1 -1
  837. package/dist-es/slider/internal/SliderRailMarks.js +4 -4
  838. package/dist-es/slider/internal/SliderRailMarks.js.map +1 -1
  839. package/dist-es/slider/internal/SliderSelection.js +1 -1
  840. package/dist-es/slider/internal/SliderSelection.js.map +1 -1
  841. package/dist-es/slider/internal/styles.js +2 -2
  842. package/dist-es/slider/internal/styles.js.map +1 -1
  843. package/dist-es/slider/internal/useSliderKeyDown.js.map +1 -1
  844. package/dist-es/slider/internal/useSliderMouseDown.js +21 -18
  845. package/dist-es/slider/internal/useSliderMouseDown.js.map +1 -1
  846. package/dist-es/slider/internal/utils.js +1 -1
  847. package/dist-es/slider/internal/utils.js.map +1 -1
  848. package/dist-es/stepped-tracker/StepLabel/StepLabel.js +2 -2
  849. package/dist-es/stepped-tracker/StepLabel/StepLabel.js.map +1 -1
  850. package/dist-es/stepped-tracker/SteppedTracker.js +3 -3
  851. package/dist-es/stepped-tracker/SteppedTracker.js.map +1 -1
  852. package/dist-es/stepped-tracker/SteppedTrackerContext.js.map +1 -1
  853. package/dist-es/stepped-tracker/TrackerStep/TrackerStep.js +4 -4
  854. package/dist-es/stepped-tracker/TrackerStep/TrackerStep.js.map +1 -1
  855. package/dist-es/stepper-input/StepperInput.js +3 -3
  856. package/dist-es/stepper-input/StepperInput.js.map +1 -1
  857. package/dist-es/stepper-input/internal/useInterval.js.map +1 -1
  858. package/dist-es/stepper-input/internal/useSpinner.js +1 -1
  859. package/dist-es/stepper-input/internal/useSpinner.js.map +1 -1
  860. package/dist-es/stepper-input/useStepperInput.js +3 -3
  861. package/dist-es/stepper-input/useStepperInput.js.map +1 -1
  862. package/dist-es/tabs/Tab.js +5 -6
  863. package/dist-es/tabs/Tab.js.map +1 -1
  864. package/dist-es/tabs/TabActivationIndicator.js +1 -1
  865. package/dist-es/tabs/TabActivationIndicator.js.map +1 -1
  866. package/dist-es/tabs/TabPanel.js +3 -3
  867. package/dist-es/tabs/TabPanel.js.map +1 -1
  868. package/dist-es/tabs/Tabs.js +4 -4
  869. package/dist-es/tabs/Tabs.js.map +1 -1
  870. package/dist-es/tabs/Tabstrip.js +11 -14
  871. package/dist-es/tabs/Tabstrip.js.map +1 -1
  872. package/dist-es/tabs/drag-drop/Draggable.js +1 -1
  873. package/dist-es/tabs/drag-drop/Draggable.js.map +1 -1
  874. package/dist-es/tabs/drag-drop/drag-utils.js +29 -26
  875. package/dist-es/tabs/drag-drop/drag-utils.js.map +1 -1
  876. package/dist-es/tabs/drag-drop/dragDropTypes.js.map +1 -1
  877. package/dist-es/tabs/drag-drop/useDragDrop.js.map +1 -1
  878. package/dist-es/tabs/drag-drop/useDragDropNaturalMovement.js +5 -4
  879. package/dist-es/tabs/drag-drop/useDragDropNaturalMovement.js.map +1 -1
  880. package/dist-es/tabs/drag-drop/useDragSpacers.js +19 -16
  881. package/dist-es/tabs/drag-drop/useDragSpacers.js.map +1 -1
  882. package/dist-es/tabs/useActivationIndicator.js +3 -2
  883. package/dist-es/tabs/useActivationIndicator.js.map +1 -1
  884. package/dist-es/tabs/useEditableItem.js +1 -1
  885. package/dist-es/tabs/useEditableItem.js.map +1 -1
  886. package/dist-es/tabs/useItemsWithIds.js +5 -9
  887. package/dist-es/tabs/useItemsWithIds.js.map +1 -1
  888. package/dist-es/tabs/useKeyboardNavigation.js +26 -32
  889. package/dist-es/tabs/useKeyboardNavigation.js.map +1 -1
  890. package/dist-es/tabs/useSelection.js +2 -2
  891. package/dist-es/tabs/useSelection.js.map +1 -1
  892. package/dist-es/tabs/useTabs.js +1 -1
  893. package/dist-es/tabs/useTabs.js.map +1 -1
  894. package/dist-es/tabs/useTabstrip.js +6 -5
  895. package/dist-es/tabs/useTabstrip.js.map +1 -1
  896. package/dist-es/tabs-next/OverflowMenu.js +2 -2
  897. package/dist-es/tabs-next/OverflowMenu.js.map +1 -1
  898. package/dist-es/tabs-next/TabNext.js +74 -72
  899. package/dist-es/tabs-next/TabNext.js.map +1 -1
  900. package/dist-es/tabs-next/TabNextContext.js.map +1 -1
  901. package/dist-es/tabs-next/TabstripNext.js +5 -5
  902. package/dist-es/tabs-next/TabstripNext.js.map +1 -1
  903. package/dist-es/toast-group/ToastGroup.js +3 -3
  904. package/dist-es/toast-group/ToastGroup.js.map +1 -1
  905. package/dist-es/tokenized-input/TokenizedInput.js.map +1 -1
  906. package/dist-es/tokenized-input/TokenizedInputBase.js +12 -12
  907. package/dist-es/tokenized-input/TokenizedInputBase.js.map +1 -1
  908. package/dist-es/tokenized-input/internal/InputPill.js +2 -2
  909. package/dist-es/tokenized-input/internal/InputPill.js.map +1 -1
  910. package/dist-es/tokenized-input/internal/InputRuler.js +3 -3
  911. package/dist-es/tokenized-input/internal/InputRuler.js.map +1 -1
  912. package/dist-es/tokenized-input/internal/defaultItemToString.js.map +1 -1
  913. package/dist-es/tokenized-input/internal/getCursorPosition.js.map +1 -1
  914. package/dist-es/tokenized-input/internal/isPlainObject.js.map +1 -1
  915. package/dist-es/tokenized-input/internal/useResizeObserver.js.map +1 -1
  916. package/dist-es/tokenized-input/internal/useWidth.js +3 -3
  917. package/dist-es/tokenized-input/internal/useWidth.js.map +1 -1
  918. package/dist-es/tokenized-input/useTokenizedInput.js +12 -9
  919. package/dist-es/tokenized-input/useTokenizedInput.js.map +1 -1
  920. package/dist-es/tokenized-input-next/TokenizedInputNext.js +5 -5
  921. package/dist-es/tokenized-input-next/TokenizedInputNext.js.map +1 -1
  922. package/dist-es/tokenized-input-next/internal/InputPill.js +5 -5
  923. package/dist-es/tokenized-input-next/internal/InputPill.js.map +1 -1
  924. package/dist-es/tokenized-input-next/internal/useResizeObserver.js.map +1 -1
  925. package/dist-es/tokenized-input-next/internal/useWidth.js +3 -3
  926. package/dist-es/tokenized-input-next/internal/useWidth.js.map +1 -1
  927. package/dist-es/tokenized-input-next/useTokenizedInputNext.js +12 -14
  928. package/dist-es/tokenized-input-next/useTokenizedInputNext.js.map +1 -1
  929. package/dist-es/toolbar/Toolbar.js +3 -3
  930. package/dist-es/toolbar/Toolbar.js.map +1 -1
  931. package/dist-es/toolbar/ToolbarButton.js +2 -2
  932. package/dist-es/toolbar/ToolbarButton.js.map +1 -1
  933. package/dist-es/toolbar/Tooltray.js +1 -1
  934. package/dist-es/toolbar/Tooltray.js.map +1 -1
  935. package/dist-es/toolbar/internal/renderToolbarItems.js +22 -21
  936. package/dist-es/toolbar/internal/renderToolbarItems.js.map +1 -1
  937. package/dist-es/toolbar/internal/renderTrayTools.js +21 -23
  938. package/dist-es/toolbar/internal/renderTrayTools.js.map +1 -1
  939. package/dist-es/toolbar/overflow-panel/OverflowPanel.js +19 -21
  940. package/dist-es/toolbar/overflow-panel/OverflowPanel.js.map +1 -1
  941. package/dist-es/toolbar/overflow-panel/OverflowSeparator.js +2 -2
  942. package/dist-es/toolbar/overflow-panel/OverflowSeparator.js.map +1 -1
  943. package/dist-es/toolbar/toolbar-field/ToolbarField.js.map +1 -1
  944. package/dist-es/toolbar/toolbar-field/useToolbarField.js +8 -8
  945. package/dist-es/toolbar/toolbar-field/useToolbarField.js.map +1 -1
  946. package/dist-es/tree/Tree.js +9 -6
  947. package/dist-es/tree/Tree.js.map +1 -1
  948. package/dist-es/tree/TreeNode.js +2 -2
  949. package/dist-es/tree/TreeNode.js.map +1 -1
  950. package/dist-es/tree/use-tree-keyboard-navigation.js +5 -4
  951. package/dist-es/tree/use-tree-keyboard-navigation.js.map +1 -1
  952. package/dist-es/tree/useTree.js +1 -3
  953. package/dist-es/tree/useTree.js.map +1 -1
  954. package/dist-es/utils/forwardCallbackProps.js.map +1 -1
  955. package/dist-es/utils/partition.js.map +1 -1
  956. package/dist-es/utils/useClickOutside.js.map +1 -1
  957. package/dist-es/utils/useEventCallback.js +1 -1
  958. package/dist-es/utils/useEventCallback.js.map +1 -1
  959. package/dist-es/utils/useIsViewportLargerThanBreakpoint.js.map +1 -1
  960. package/dist-es/utils/useLayoutEffectOnce.js +1 -1
  961. package/dist-es/utils/useLayoutEffectOnce.js.map +1 -1
  962. package/dist-es/utils/useLayoutEffectSkipFirst.js +1 -1
  963. package/dist-es/utils/useLayoutEffectSkipFirst.js.map +1 -1
  964. package/dist-es/utils/useOverflowDetection.js +3 -3
  965. package/dist-es/utils/useOverflowDetection.js.map +1 -1
  966. package/dist-es/utils/useSlideSelection.js.map +1 -1
  967. package/dist-es/window/ElectronWindow.js +5 -7
  968. package/dist-es/window/ElectronWindow.js.map +1 -1
  969. package/dist-es/window/WindowContext.js.map +1 -1
  970. package/dist-types/app-header/AppHeader.d.ts +1 -1
  971. package/dist-types/breadcrumbs/Breadcrumb.d.ts +3 -3
  972. package/dist-types/breadcrumbs/Breadcrumbs.d.ts +2 -2
  973. package/dist-types/breadcrumbs/internal/BreadcrumbsCollapsed.d.ts +4 -4
  974. package/dist-types/breadcrumbs/internal/BreadcrumbsSeparator.d.ts +2 -2
  975. package/dist-types/button-bar/ButtonBar.d.ts +2 -2
  976. package/dist-types/button-bar/OrderedButton.d.ts +1 -1
  977. package/dist-types/button-bar/internal/DescendantContext.d.ts +2 -2
  978. package/dist-types/button-bar/internal/useDescendants.d.ts +1 -1
  979. package/dist-types/calendar/Calendar.d.ts +3 -3
  980. package/dist-types/calendar/internal/CalendarCarousel.d.ts +1 -1
  981. package/dist-types/calendar/internal/CalendarContext.d.ts +1 -1
  982. package/dist-types/calendar/internal/CalendarDay.d.ts +4 -4
  983. package/dist-types/calendar/internal/CalendarMonth.d.ts +3 -3
  984. package/dist-types/calendar/internal/CalendarNavigation.d.ts +3 -3
  985. package/dist-types/calendar/internal/CalendarWeekHeader.d.ts +1 -1
  986. package/dist-types/calendar/internal/useFocusManagement.d.ts +2 -2
  987. package/dist-types/calendar/internal/utils.d.ts +1 -1
  988. package/dist-types/calendar/useCalendar.d.ts +8 -11
  989. package/dist-types/calendar/useCalendarDay.d.ts +4 -4
  990. package/dist-types/calendar/useSelection.d.ts +4 -4
  991. package/dist-types/carousel/Carousel.d.ts +2 -2
  992. package/dist-types/carousel/CarouselSlide.d.ts +1 -1
  993. package/dist-types/cascading-menu/CascadingMenu.d.ts +1 -1
  994. package/dist-types/cascading-menu/CascadingMenuItem.d.ts +3 -3
  995. package/dist-types/cascading-menu/CascadingMenuList.d.ts +6 -6
  996. package/dist-types/cascading-menu/CascadingMenuProps.d.ts +5 -5
  997. package/dist-types/cascading-menu/internal/CascadingMenuAction.d.ts +1 -1
  998. package/dist-types/cascading-menu/internal/keydownHandlers.d.ts +2 -2
  999. package/dist-types/cascading-menu/internal/stateUtils.d.ts +1 -1
  1000. package/dist-types/cascading-menu/internal/useMenuTriggerHandlers.d.ts +4 -4
  1001. package/dist-types/cascading-menu/internal/useMouseHandlers.d.ts +2 -2
  1002. package/dist-types/cascading-menu/internal/useStateReducer.d.ts +3 -3
  1003. package/dist-types/color-chooser/AlphaInputField.d.ts +2 -1
  1004. package/dist-types/color-chooser/ColorChooser.d.ts +3 -3
  1005. package/dist-types/color-chooser/ColorPicker.d.ts +1 -1
  1006. package/dist-types/color-chooser/DictTabs.d.ts +3 -3
  1007. package/dist-types/color-chooser/RGBAInput.d.ts +2 -2
  1008. package/dist-types/color-chooser/RGBAInputField.d.ts +1 -1
  1009. package/dist-types/color-chooser/Swatch.d.ts +1 -1
  1010. package/dist-types/color-chooser/Swatches.d.ts +1 -1
  1011. package/dist-types/color-chooser/SwatchesPicker.d.ts +1 -1
  1012. package/dist-types/color-chooser/createTabsMapping.d.ts +3 -3
  1013. package/dist-types/combo-box/ComboBox.d.ts +5 -5
  1014. package/dist-types/combo-box/useCombobox.d.ts +5 -5
  1015. package/dist-types/combo-box-deprecated/ComboBoxDeprecated.d.ts +3 -3
  1016. package/dist-types/combo-box-deprecated/internal/DefaultComboBox.d.ts +5 -5
  1017. package/dist-types/combo-box-deprecated/internal/MultiSelectComboBox.d.ts +3 -3
  1018. package/dist-types/combo-box-deprecated/internal/useComboBox.d.ts +65 -59
  1019. package/dist-types/combo-box-deprecated/internal/useMultiSelectComboBox.d.ts +189 -172
  1020. package/dist-types/combo-box-deprecated/internal/usePopperStatus.d.ts +1 -1
  1021. package/dist-types/common-hooks/collectionProvider.d.ts +3 -3
  1022. package/dist-types/common-hooks/collectionTypes.d.ts +2 -2
  1023. package/dist-types/common-hooks/keyUtils.d.ts +1 -1
  1024. package/dist-types/common-hooks/navigationTypes.d.ts +3 -3
  1025. package/dist-types/common-hooks/selectionTypes.d.ts +2 -2
  1026. package/dist-types/common-hooks/useAutoSizer.d.ts +1 -1
  1027. package/dist-types/common-hooks/useCollapsibleGroups.d.ts +2 -2
  1028. package/dist-types/common-hooks/useCollectionItems.d.ts +1 -1
  1029. package/dist-types/common-hooks/useImperativeScrollingAPI.d.ts +2 -2
  1030. package/dist-types/common-hooks/useKeyboardNavigation.d.ts +2 -2
  1031. package/dist-types/common-hooks/useKeyboardNavigationPanel.d.ts +1 -1
  1032. package/dist-types/common-hooks/useSelection.d.ts +1 -1
  1033. package/dist-types/common-hooks/useTypeahead.d.ts +1 -1
  1034. package/dist-types/common-hooks/useViewportTracking.d.ts +2 -2
  1035. package/dist-types/common-hooks/utils/collection-item-utils.d.ts +2 -2
  1036. package/dist-types/common-hooks/utils/isSelected.d.ts +1 -1
  1037. package/dist-types/contact-details/ContactAction.d.ts +3 -3
  1038. package/dist-types/contact-details/ContactActions.d.ts +1 -1
  1039. package/dist-types/contact-details/ContactAvatar.d.ts +1 -1
  1040. package/dist-types/contact-details/ContactDetails.d.ts +1 -1
  1041. package/dist-types/contact-details/ContactFavoriteToggle.d.ts +2 -2
  1042. package/dist-types/contact-details/ContactMetadata.d.ts +1 -1
  1043. package/dist-types/contact-details/ContactMetadataItem.d.ts +3 -3
  1044. package/dist-types/contact-details/ContactPrimaryInfo.d.ts +1 -1
  1045. package/dist-types/contact-details/ContactSecondaryInfo.d.ts +3 -3
  1046. package/dist-types/contact-details/ContactTertiaryInfo.d.ts +2 -2
  1047. package/dist-types/contact-details/MailLinkComponent.d.ts +2 -2
  1048. package/dist-types/contact-details/internal/ContactDetailsContext.d.ts +1 -1
  1049. package/dist-types/contact-details/internal/FavoriteToggle.d.ts +3 -2
  1050. package/dist-types/contact-details/internal/FavoriteToggleWithTooltip.d.ts +2 -2
  1051. package/dist-types/contact-details/internal/StarIconContainer.d.ts +1 -1
  1052. package/dist-types/contact-details/internal/useComponentSize.d.ts +1 -1
  1053. package/dist-types/contact-details/types.d.ts +1 -1
  1054. package/dist-types/content-status/ContentStatus.d.ts +2 -2
  1055. package/dist-types/content-status/internal/StatusIndicator.d.ts +3 -3
  1056. package/dist-types/date-input/DateInput.d.ts +11 -10
  1057. package/dist-types/date-picker/DatePicker.d.ts +19 -23
  1058. package/dist-types/date-picker/DatePickerContext.d.ts +9 -11
  1059. package/dist-types/date-picker/DatePickerPanel.d.ts +7 -9
  1060. package/dist-types/deck-item/DeckItem.d.ts +2 -2
  1061. package/dist-types/deck-layout/DeckLayout.d.ts +2 -2
  1062. package/dist-types/dropdown/Dropdown.d.ts +4 -4
  1063. package/dist-types/dropdown/DropdownBase.d.ts +1 -1
  1064. package/dist-types/dropdown/DropdownButton.d.ts +3 -3
  1065. package/dist-types/dropdown/dropdownTypes.d.ts +2 -2
  1066. package/dist-types/dropdown/useClickAway.d.ts +1 -1
  1067. package/dist-types/dropdown/useDropdown.d.ts +3 -3
  1068. package/dist-types/dropdown/useDropdownBase.d.ts +2 -2
  1069. package/dist-types/focus-manager/FocusManager.d.ts +2 -2
  1070. package/dist-types/form-field-context-legacy/FormFieldLegacyContext.d.ts +2 -2
  1071. package/dist-types/form-field-context-legacy/useFormFieldLegacyProps.d.ts +1 -1
  1072. package/dist-types/form-field-legacy/FormActivationIndicator.d.ts +2 -2
  1073. package/dist-types/form-field-legacy/FormFieldLegacy.d.ts +6 -6
  1074. package/dist-types/form-field-legacy/FormHelperText.d.ts +3 -3
  1075. package/dist-types/form-field-legacy/FormLabel.d.ts +5 -5
  1076. package/dist-types/form-field-legacy/NecessityIndicator.d.ts +2 -2
  1077. package/dist-types/form-field-legacy/StatusIndicator.d.ts +4 -4
  1078. package/dist-types/form-group/FormGroup.d.ts +1 -1
  1079. package/dist-types/formatted-input/FormattedInput.d.ts +1 -1
  1080. package/dist-types/formatted-input/internal/InputWithMask.d.ts +2 -2
  1081. package/dist-types/index.d.ts +0 -1
  1082. package/dist-types/input-legacy/InputLegacy.d.ts +1 -1
  1083. package/dist-types/input-legacy/StaticInputAdornment.d.ts +1 -1
  1084. package/dist-types/input-legacy/useCursorOnFocus.d.ts +1 -1
  1085. package/dist-types/layer-layout/LayerLayout.d.ts +2 -2
  1086. package/dist-types/list/Highlighter.d.ts +1 -1
  1087. package/dist-types/list/List.d.ts +3 -3
  1088. package/dist-types/list/ListItem.d.ts +2 -2
  1089. package/dist-types/list/ListItemGroup.d.ts +1 -1
  1090. package/dist-types/list/ListItemHeader.d.ts +1 -1
  1091. package/dist-types/list/VirtualizedList.d.ts +3 -3
  1092. package/dist-types/list/listTypes.d.ts +3 -2
  1093. package/dist-types/list/useList.d.ts +2 -2
  1094. package/dist-types/list/useListHeight.d.ts +1 -1
  1095. package/dist-types/list/useVirtualization.d.ts +2 -2
  1096. package/dist-types/list-deprecated/List.d.ts +3 -3
  1097. package/dist-types/list-deprecated/ListBase.d.ts +2 -2
  1098. package/dist-types/list-deprecated/ListItem.d.ts +2 -2
  1099. package/dist-types/list-deprecated/ListItemBase.d.ts +1 -1
  1100. package/dist-types/list-deprecated/ListItemContext.d.ts +1 -1
  1101. package/dist-types/list-deprecated/ListProps.d.ts +1 -1
  1102. package/dist-types/list-deprecated/internal/DescendantContext.d.ts +1 -1
  1103. package/dist-types/list-deprecated/internal/Highlighter.d.ts +1 -1
  1104. package/dist-types/list-deprecated/internal/useListAutoSizer.d.ts +1 -1
  1105. package/dist-types/list-deprecated/internal/useWidth.d.ts +1 -1
  1106. package/dist-types/list-deprecated/useList.d.ts +2 -2
  1107. package/dist-types/list-deprecated/useListItem.d.ts +3 -3
  1108. package/dist-types/list-next/ListItemNext.d.ts +1 -1
  1109. package/dist-types/list-next/ListNext.d.ts +1 -1
  1110. package/dist-types/list-next/ListNextContext.d.ts +1 -1
  1111. package/dist-types/list-next/useList.d.ts +1 -1
  1112. package/dist-types/logo/Logo.d.ts +1 -1
  1113. package/dist-types/logo/LogoImage.d.ts +1 -1
  1114. package/dist-types/logo/LogoSeparator.d.ts +1 -1
  1115. package/dist-types/menu-button/MenuButton.d.ts +3 -3
  1116. package/dist-types/menu-button/MenuButtonTrigger.d.ts +2 -2
  1117. package/dist-types/metric/Metric.d.ts +2 -2
  1118. package/dist-types/metric/MetricContent.d.ts +2 -2
  1119. package/dist-types/metric/MetricHeader.d.ts +2 -2
  1120. package/dist-types/portal/Portal.d.ts +1 -1
  1121. package/dist-types/query-input/QueryInput.d.ts +3 -3
  1122. package/dist-types/query-input/internal/CategoryList.d.ts +3 -3
  1123. package/dist-types/query-input/internal/CategoryListItem.d.ts +2 -2
  1124. package/dist-types/query-input/internal/QueryInputBody.d.ts +4 -4
  1125. package/dist-types/query-input/internal/SearchList.d.ts +3 -3
  1126. package/dist-types/query-input/internal/ValueList.d.ts +3 -3
  1127. package/dist-types/query-input/internal/ValueSelector.d.ts +3 -3
  1128. package/dist-types/query-input/internal/usePopperStatus.d.ts +1 -1
  1129. package/dist-types/query-input/useQueryInput.d.ts +4 -4
  1130. package/dist-types/responsive/OverflowReducer.d.ts +2 -2
  1131. package/dist-types/responsive/overflowTypes.d.ts +2 -2
  1132. package/dist-types/responsive/overflowUtils.d.ts +2 -2
  1133. package/dist-types/responsive/useDynamicCollapse.d.ts +2 -2
  1134. package/dist-types/responsive/useInstantCollapse.d.ts +2 -2
  1135. package/dist-types/responsive/useOverflow.d.ts +1 -1
  1136. package/dist-types/responsive/useOverflowCollectionItems.d.ts +1 -1
  1137. package/dist-types/responsive/useOverflowLayout.d.ts +1 -1
  1138. package/dist-types/responsive/useReclaimSpace.d.ts +1 -1
  1139. package/dist-types/responsive/useResizeObserver.d.ts +1 -1
  1140. package/dist-types/responsive/useWidth.d.ts +1 -1
  1141. package/dist-types/search-input/SearchInput.d.ts +2 -2
  1142. package/dist-types/skip-link/SkipLink.d.ts +2 -2
  1143. package/dist-types/skip-link/SkipLinks.d.ts +1 -1
  1144. package/dist-types/skip-link/internal/useManageFocusOnTarget.d.ts +1 -1
  1145. package/dist-types/slider/Slider.d.ts +3 -3
  1146. package/dist-types/slider/internal/SliderHandle.d.ts +1 -1
  1147. package/dist-types/slider/internal/SliderMarkLabels.d.ts +2 -2
  1148. package/dist-types/slider/internal/SliderRail.d.ts +1 -3
  1149. package/dist-types/slider/internal/SliderRailMarks.d.ts +2 -2
  1150. package/dist-types/slider/internal/SliderSelection.d.ts +1 -1
  1151. package/dist-types/slider/internal/styles.d.ts +3 -3
  1152. package/dist-types/slider/internal/useSliderKeyDown.d.ts +2 -2
  1153. package/dist-types/slider/internal/useSliderMouseDown.d.ts +3 -3
  1154. package/dist-types/slider/internal/utils.d.ts +2 -2
  1155. package/dist-types/stepped-tracker/StepLabel/StepLabel.d.ts +2 -2
  1156. package/dist-types/stepped-tracker/SteppedTracker.d.ts +1 -1
  1157. package/dist-types/stepped-tracker/SteppedTrackerContext.d.ts +3 -3
  1158. package/dist-types/stepped-tracker/TrackerConnector/TrackerConnector.d.ts +1 -1
  1159. package/dist-types/stepped-tracker/TrackerStep/TrackerStep.d.ts +1 -1
  1160. package/dist-types/stepper-input/StepperInput.d.ts +2 -2
  1161. package/dist-types/stepper-input/internal/useInterval.d.ts +1 -1
  1162. package/dist-types/stepper-input/useStepperInput.d.ts +3 -3
  1163. package/dist-types/tabs/Tab.d.ts +1 -1
  1164. package/dist-types/tabs/TabActivationIndicator.d.ts +1 -1
  1165. package/dist-types/tabs/TabPanel.d.ts +1 -1
  1166. package/dist-types/tabs/Tabs.d.ts +1 -1
  1167. package/dist-types/tabs/TabsTypes.d.ts +4 -4
  1168. package/dist-types/tabs/Tabstrip.d.ts +1 -1
  1169. package/dist-types/tabs/drag-drop/Draggable.d.ts +2 -2
  1170. package/dist-types/tabs/drag-drop/DropIndicator.d.ts +1 -1
  1171. package/dist-types/tabs/drag-drop/drag-utils.d.ts +2 -2
  1172. package/dist-types/tabs/drag-drop/dragDropTypes.d.ts +2 -2
  1173. package/dist-types/tabs/drag-drop/useDragDrop.d.ts +1 -1
  1174. package/dist-types/tabs/drag-drop/useDragDropNaturalMovement.d.ts +1 -1
  1175. package/dist-types/tabs/drag-drop/useDragSpacers.d.ts +3 -3
  1176. package/dist-types/tabs/useActivationIndicator.d.ts +2 -2
  1177. package/dist-types/tabs/useEditableItem.d.ts +2 -2
  1178. package/dist-types/tabs/useItemsWithIds.d.ts +2 -2
  1179. package/dist-types/tabs/useKeyboardNavigation.d.ts +2 -2
  1180. package/dist-types/tabs/useSelection.d.ts +1 -1
  1181. package/dist-types/tabs/useTabs.d.ts +2 -2
  1182. package/dist-types/tabs/useTabstrip.d.ts +6 -6
  1183. package/dist-types/tabs-next/OverflowMenu.d.ts +2 -2
  1184. package/dist-types/tabs-next/TabNext.d.ts +1 -1
  1185. package/dist-types/tabs-next/TabNextContext.d.ts +1 -1
  1186. package/dist-types/tabs-next/TabstripNext.d.ts +1 -1
  1187. package/dist-types/toast-group/ToastGroup.d.ts +1 -1
  1188. package/dist-types/tokenized-input/TokenizedInput.d.ts +3 -3
  1189. package/dist-types/tokenized-input/TokenizedInputBase.d.ts +4 -4
  1190. package/dist-types/tokenized-input/internal/InputPill.d.ts +2 -2
  1191. package/dist-types/tokenized-input/internal/InputRuler.d.ts +1 -1
  1192. package/dist-types/tokenized-input/internal/getCursorPosition.d.ts +1 -1
  1193. package/dist-types/tokenized-input/internal/useResizeObserver.d.ts +1 -1
  1194. package/dist-types/tokenized-input/internal/useWidth.d.ts +1 -1
  1195. package/dist-types/tokenized-input/useTokenizedInput.d.ts +3 -3
  1196. package/dist-types/tokenized-input-next/TokenizedInputNext.d.ts +3 -3
  1197. package/dist-types/tokenized-input-next/internal/InputPill.d.ts +2 -2
  1198. package/dist-types/tokenized-input-next/internal/useResizeObserver.d.ts +1 -1
  1199. package/dist-types/tokenized-input-next/internal/useWidth.d.ts +1 -1
  1200. package/dist-types/tokenized-input-next/useTokenizedInputNext.d.ts +2 -2
  1201. package/dist-types/toolbar/Toolbar.d.ts +1 -1
  1202. package/dist-types/toolbar/ToolbarButton.d.ts +1 -1
  1203. package/dist-types/toolbar/ToolbarProps.d.ts +2 -2
  1204. package/dist-types/toolbar/Tooltray.d.ts +2 -2
  1205. package/dist-types/toolbar/TooltrayProps.d.ts +2 -2
  1206. package/dist-types/toolbar/internal/ToolbarButtonRefsContext.d.ts +1 -1
  1207. package/dist-types/toolbar/internal/renderToolbarItems.d.ts +2 -2
  1208. package/dist-types/toolbar/internal/renderTrayTools.d.ts +3 -3
  1209. package/dist-types/toolbar/overflow-panel/OverflowPanel.d.ts +1 -1
  1210. package/dist-types/toolbar/overflow-panel/OverflowSeparator.d.ts +1 -1
  1211. package/dist-types/toolbar/toolbar-field/ToolbarField.d.ts +1 -1
  1212. package/dist-types/toolbar/toolbar-field/toolbarFieldTypes.d.ts +1 -1
  1213. package/dist-types/toolbar/toolbar-field/useToolbarField.d.ts +2 -2
  1214. package/dist-types/tree/Tree.d.ts +2 -2
  1215. package/dist-types/tree/TreeNode.d.ts +2 -2
  1216. package/dist-types/tree/treeTypes.d.ts +4 -4
  1217. package/dist-types/tree/use-tree-keyboard-navigation.d.ts +2 -2
  1218. package/dist-types/tree/useTree.d.ts +3 -3
  1219. package/dist-types/utils/useClickOutside.d.ts +1 -1
  1220. package/dist-types/utils/useIsViewportLargerThanBreakpoint.d.ts +1 -1
  1221. package/dist-types/utils/useLayoutEffectOnce.d.ts +1 -1
  1222. package/dist-types/utils/useLayoutEffectSkipFirst.d.ts +1 -1
  1223. package/dist-types/utils/useOverflowDetection.d.ts +1 -1
  1224. package/dist-types/utils/useSlideSelection.d.ts +1 -1
  1225. package/dist-types/window/WindowContext.d.ts +1 -1
  1226. package/package.json +4 -4
  1227. package/dist-cjs/divider/Divider.css.js +0 -6
  1228. package/dist-cjs/divider/Divider.css.js.map +0 -1
  1229. package/dist-cjs/divider/Divider.js +0 -44
  1230. package/dist-cjs/divider/Divider.js.map +0 -1
  1231. package/dist-es/divider/Divider.css.js +0 -4
  1232. package/dist-es/divider/Divider.css.js.map +0 -1
  1233. package/dist-es/divider/Divider.js +0 -40
  1234. package/dist-es/divider/Divider.js.map +0 -1
  1235. package/dist-types/divider/Divider.d.ts +0 -12
  1236. package/dist-types/divider/index.d.ts +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"useList.js","sources":["../src/list-deprecated/useList.ts"],"sourcesContent":["import {\n ownerDocument,\n useControlled,\n useForkRef,\n useId,\n useIsFocusVisible,\n} from \"@salt-ds/core\";\n\nimport {\n AriaAttributes,\n Dispatch,\n FocusEvent,\n KeyboardEvent,\n KeyboardEventHandler,\n MouseEvent,\n Ref,\n SetStateAction,\n useCallback,\n useEffect,\n useRef,\n useState,\n} from \"react\";\nimport {\n ListMultiSelectionVariant,\n ListProps,\n ListSelectionVariant,\n} from \"./ListProps\";\n\ntype keyHandler = (event: KeyboardEvent<HTMLInputElement>) => void;\n\ninterface listBoxAriaProps\n extends Pick<\n AriaAttributes,\n \"aria-activedescendant\" | \"aria-multiselectable\"\n > {\n role: string; // We will default it to be 'listbox', but users can override\n}\nexport interface ListState<\n Item = string,\n Variant extends ListSelectionVariant = \"default\"\n> {\n id?: string;\n focusVisible: boolean;\n selectedItem?: Variant extends ListMultiSelectionVariant ? Array<Item> : Item;\n highlightedIndex?: number;\n isDeselectable: boolean;\n isMultiSelect: boolean;\n isDisabled: boolean;\n}\n\nexport interface ListHelpers<\n Item = string,\n Variant extends ListSelectionVariant = \"default\"\n> {\n setFocusVisible: (visible: boolean) => void;\n setSelectedItem: Dispatch<\n SetStateAction<\n (Variant extends ListMultiSelectionVariant ? Item[] : Item) | undefined\n >\n >;\n setHighlightedIndex: (highlightedIndex?: number) => void;\n handleSelect: (\n event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>,\n index: number | undefined,\n item: Item\n ) => void;\n keyDownHandlers: { [key: string]: KeyboardEventHandler };\n // TODO: Form Field\n}\n\nexport function useList<Item, Variant extends ListSelectionVariant>(\n props: ListProps<Item, Variant> = {}\n): {\n focusedRef: Ref<any>;\n listProps: Partial<ListProps<Item, Variant>> & listBoxAriaProps;\n state: ListState<Item, Variant>;\n helpers: ListHelpers<Item, Variant>;\n} {\n validateProps(props);\n\n const generatedId = useId(props.id);\n\n const {\n id = generatedId,\n source = [],\n itemCount = source.length,\n getItemId = (index) => `${id}-item-${index}`,\n getItemAtIndex: getItemAtIndexProp,\n getItemIndex: getItemIndexProp,\n displayedItemCount = 10,\n initialSelectedItem,\n selectionVariant,\n disabled = false,\n onBlur,\n onChange,\n onFocus,\n onKeyDown,\n onMouseDown,\n onMouseLeave,\n onSelect,\n disableMouseDown,\n restoreLastFocus,\n highlightedIndex: highlightedIndexProp,\n selectedItem: selectedItemProp,\n tabToSelect,\n ...restProps\n } = props;\n\n const {\n isFocusVisibleRef,\n onFocus: handleFocusVisible,\n onBlur: handleBlurVisible,\n ref: focusVisibleRef,\n } = useIsFocusVisible();\n\n const { current: isDeselectable } = useRef(\n selectionVariant === \"deselectable\"\n );\n const { current: isMultiSelect } = useRef(\n selectionVariant === \"multiple\" ||\n selectionVariant === \"extended\" ||\n Array.isArray(initialSelectedItem) ||\n Array.isArray(selectedItemProp)\n );\n\n const { current: isExtendedSelect } = useRef(selectionVariant === \"extended\");\n\n let getItemIndex = useCallback(\n (item: Item) => source.indexOf(item),\n [source]\n );\n let getItemAtIndex = useCallback((index: number) => source[index], [source]);\n\n const indexComparator = useCallback(\n (a: Item, b: Item) => getItemIndex(a) - getItemIndex(b),\n [getItemIndex]\n );\n\n // Only use getItemIndex and getItemAtIndex if both are defined; otherwise keep the defaults\n if (\n typeof getItemIndexProp === \"function\" &&\n typeof getItemAtIndexProp === \"function\"\n ) {\n getItemIndex = getItemIndexProp;\n getItemAtIndex = getItemAtIndexProp;\n }\n\n const rootRef = useRef();\n const [focusVisible, setFocusVisible] = useState(false);\n const [lastFocusedIndex, setLastFocusedIndex] = useState(-1);\n\n const [selectedItem, setSelectedItem] = useControlled<\n undefined | (Variant extends ListMultiSelectionVariant ? Item[] : Item)\n >({\n controlled: selectedItemProp,\n default:\n initialSelectedItem ??\n ((isMultiSelect\n ? []\n : null) as unknown as Variant extends ListMultiSelectionVariant\n ? Item[]\n : Item),\n name: \"useList\",\n state: \"selectedItem\",\n });\n\n const [highlightedIndex, setHighlightedIndex] = useControlled<\n number | undefined\n >({\n controlled: highlightedIndexProp,\n default: undefined,\n name: \"useList\",\n state: \"highlightedIndex\",\n });\n\n const handleSingleSelect = useCallback(\n (\n event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>,\n index: number | undefined,\n item: Item\n ) => {\n const isSelected = item === selectedItem;\n let nextItem;\n\n if (isSelected && !isDeselectable) {\n return;\n }\n\n if (!isSelected) {\n nextItem = item;\n setHighlightedIndex(index);\n } else {\n nextItem = null;\n }\n\n setSelectedItem(\n nextItem as Variant extends ListMultiSelectionVariant ? Item[] : Item\n );\n\n if (onChange) {\n onChange(\n event,\n nextItem as Variant extends ListMultiSelectionVariant ? Item[] : Item\n );\n }\n },\n [\n isDeselectable,\n onChange,\n selectedItem,\n setHighlightedIndex,\n setSelectedItem,\n ]\n );\n\n const handleMultiSelect = useCallback(\n (\n event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>,\n index: number | undefined,\n item: Item\n ) => {\n const isSelected = (selectedItem as Item[]).indexOf(item as Item) !== -1;\n let nextItems = selectedItem as Item[];\n\n if (!isSelected) {\n nextItems = nextItems.concat([item]).sort(indexComparator);\n setHighlightedIndex(index);\n } else {\n nextItems = nextItems.filter((selected: any) => selected !== item);\n }\n\n setSelectedItem(\n nextItems as Variant extends ListMultiSelectionVariant ? Item[] : Item\n );\n\n if (onChange) {\n onChange(\n event,\n nextItems as Variant extends ListMultiSelectionVariant ? Item[] : Item\n );\n }\n },\n [\n indexComparator,\n onChange,\n selectedItem,\n setHighlightedIndex,\n setSelectedItem,\n ]\n );\n\n const handleRangeSelect = useCallback(\n (\n event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>,\n index?: number\n ) => {\n const currentSelection =\n event.ctrlKey || event.metaKey ? selectedItem : ([] as Item[]);\n\n const lastSelectedItemIndex =\n (selectedItem as Item[]).length > 0\n ? getItemIndex(\n (selectedItem as Item[])[(selectedItem as Item[]).length - 1]\n )\n : 0;\n\n const startRegion = Math.min(\n index ?? lastSelectedItemIndex,\n lastSelectedItemIndex\n );\n const endRegion = Math.max(\n index ?? lastSelectedItemIndex,\n lastSelectedItemIndex\n );\n const rangeSelection = source.slice(startRegion, endRegion + 1);\n // concat the current selection with a new selection and remove duplicates for overlaps\n const nextItems = [\n ...new Set([...(currentSelection as Item[]), ...rangeSelection]),\n ];\n // remove text selection caused by shift clicking\n ownerDocument(event.currentTarget).getSelection()?.removeAllRanges();\n setSelectedItem(\n nextItems as Variant extends ListMultiSelectionVariant ? Item[] : Item\n );\n\n if (onChange) {\n onChange(\n event,\n nextItems as Variant extends ListMultiSelectionVariant ? Item[] : Item\n );\n }\n },\n [getItemIndex, onChange, selectedItem, setSelectedItem, source]\n );\n\n const handleExtendedSelect = useCallback(\n (\n event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>,\n index: number | undefined,\n item: Item\n ) => {\n let nextItems = selectedItem as Item[];\n if (event.shiftKey) {\n handleRangeSelect(event, index);\n } else if (\n (selectedItem as Item[]).length === 0 ||\n event.ctrlKey ||\n event.metaKey\n ) {\n console.log(\"handleMulti\");\n handleMultiSelect(event, index, item);\n } else {\n nextItems = [item] as Item[];\n setSelectedItem(\n nextItems as Variant extends ListMultiSelectionVariant ? Item[] : Item\n );\n\n if (onChange) {\n onChange(\n event,\n nextItems as Variant extends ListMultiSelectionVariant\n ? Item[]\n : Item\n );\n }\n }\n },\n [\n handleMultiSelect,\n handleRangeSelect,\n onChange,\n selectedItem,\n setSelectedItem,\n ]\n );\n\n const handleSelect = useCallback(\n (\n event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>,\n index: number | undefined,\n item: Item | null\n ) => {\n if (item == null || (item as any).disabled) {\n return;\n }\n\n if (onSelect) {\n console.log(\"onSelect\");\n onSelect(event, item);\n }\n\n if (isExtendedSelect) {\n handleExtendedSelect(event, index, item);\n } else if (isMultiSelect) {\n handleMultiSelect(event, index, item);\n } else {\n handleSingleSelect(event, index, item);\n }\n },\n [\n handleExtendedSelect,\n handleMultiSelect,\n handleSingleSelect,\n isExtendedSelect,\n isMultiSelect,\n onSelect,\n ]\n );\n\n const saveFocusedIndex = (index: number) => {\n setLastFocusedIndex(index);\n return index;\n };\n\n const keyDownHandlers: { [key: string]: keyHandler } = {\n ArrowUp: (event) => {\n event.preventDefault();\n setHighlightedIndex((prevHighlightedIndex?: number) =>\n saveFocusedIndex(Math.max(0, (prevHighlightedIndex ?? itemCount) - 1))\n );\n },\n ArrowDown: (event) => {\n event.preventDefault();\n setHighlightedIndex((prevHighlightedIndex?: number) =>\n saveFocusedIndex(\n Math.min(itemCount - 1, (prevHighlightedIndex ?? -1) + 1)\n )\n );\n },\n PageUp: (event) => {\n event.preventDefault();\n setHighlightedIndex((prevHighlightedIndex?: number) =>\n saveFocusedIndex(\n Math.max(\n 0,\n (prevHighlightedIndex ?? displayedItemCount) - displayedItemCount\n )\n )\n );\n },\n PageDown: (event) => {\n event.preventDefault();\n setHighlightedIndex((prevHighlightedIndex?: number) =>\n saveFocusedIndex(\n Math.min(\n itemCount - 1,\n (prevHighlightedIndex ?? 0) + displayedItemCount\n )\n )\n );\n },\n Home: (event) => {\n event.preventDefault();\n setHighlightedIndex(saveFocusedIndex(0));\n },\n End: (event) => {\n event.preventDefault();\n setHighlightedIndex(saveFocusedIndex(itemCount - 1));\n },\n Enter: (event) => {\n event.preventDefault();\n handleSelect(\n event,\n highlightedIndex,\n highlightedIndex != null && highlightedIndex > -1\n ? getItemAtIndex(highlightedIndex)\n : null\n );\n },\n \" \": (event) => {\n event.preventDefault();\n handleSelect(\n event,\n highlightedIndex,\n highlightedIndex != null && highlightedIndex > -1\n ? getItemAtIndex(highlightedIndex)\n : null\n );\n },\n Tab: (event) => {\n if (tabToSelect) {\n handleSelect(\n event,\n highlightedIndex,\n highlightedIndex != null && highlightedIndex > -1\n ? getItemAtIndex(highlightedIndex)\n : null\n );\n } else {\n setHighlightedIndex(undefined);\n }\n },\n };\n\n const handleKeyDown: keyHandler = (event) => {\n if (isFocusVisibleRef.current) {\n setFocusVisible(true);\n }\n\n const handler: keyHandler = keyDownHandlers[event.key];\n\n if (handler) {\n handler(event);\n }\n\n if (onKeyDown) {\n onKeyDown(event);\n }\n };\n\n const handleFocus = (event: FocusEvent<HTMLDivElement>) => {\n handleFocusVisible(event);\n if (isFocusVisibleRef.current) {\n setFocusVisible(true);\n }\n\n // Work out the index to highlight\n if (highlightedIndex === undefined) {\n const firstSelectedItem = isMultiSelect\n ? (selectedItem as Item[])[0]\n : (selectedItem as Item | undefined);\n\n setHighlightedIndex(\n Math.max(\n restoreLastFocus\n ? lastFocusedIndex\n : firstSelectedItem\n ? getItemIndex(firstSelectedItem)\n : -1,\n 0\n )\n );\n }\n\n if (onFocus) {\n onFocus(event);\n }\n };\n\n const handleBlur = (event: FocusEvent<HTMLDivElement>) => {\n setHighlightedIndex(undefined);\n handleBlurVisible();\n if (!isFocusVisibleRef.current) {\n setFocusVisible(false);\n }\n\n if (onBlur) {\n onBlur(event);\n }\n };\n\n const handleMouseDown = (event: MouseEvent<HTMLDivElement>) => {\n if (disableMouseDown) {\n event.preventDefault();\n } else if (onMouseDown) {\n onMouseDown(event);\n }\n };\n\n const handleMouseLeave = (event: MouseEvent<HTMLDivElement>) => {\n if (focusVisible && id) {\n // Get the root node of the component if we have access to it otherwise default to current document\n const rootNode = (\n rootRef.current || ownerDocument(event.currentTarget)\n ).getRootNode();\n\n const listNode = (rootNode as Document).getElementById(id);\n\n // Safety check as `mouseleave` could have been accidentally triggered by an opening tooltip\n // when you use keyboard to navigate, hence the focusVisible check earlier\n if (listNode?.contains(event.target as Node)) {\n setHighlightedIndex(undefined);\n }\n } else {\n setHighlightedIndex(undefined);\n }\n\n if (onMouseLeave) {\n onMouseLeave(event);\n }\n };\n\n const eventHandlers = {\n onFocus: handleFocus,\n onBlur: handleBlur,\n onKeyDown: handleKeyDown,\n onMouseDown: handleMouseDown,\n onMouseLeave: handleMouseLeave,\n };\n\n const ariaProps: listBoxAriaProps = {\n role: \"listbox\",\n \"aria-activedescendant\":\n highlightedIndex !== undefined && highlightedIndex >= 0\n ? getItemId(highlightedIndex)\n : undefined,\n };\n\n if (isMultiSelect) {\n ariaProps[\"aria-multiselectable\"] = true;\n }\n\n return {\n focusedRef: useForkRef(rootRef, focusVisibleRef),\n state: {\n id,\n focusVisible,\n selectedItem,\n highlightedIndex,\n isDeselectable,\n isMultiSelect,\n isDisabled: disabled,\n },\n helpers: {\n setFocusVisible,\n setSelectedItem,\n setHighlightedIndex,\n keyDownHandlers,\n handleSelect,\n },\n listProps: {\n id,\n source,\n itemCount,\n disableMouseDown,\n displayedItemCount,\n getItemAtIndex,\n getItemIndex,\n getItemId,\n disabled,\n ...ariaProps,\n ...restProps,\n ...(disabled ? {} : eventHandlers),\n },\n };\n}\n\nconst validateProps = <Item, Variant extends ListSelectionVariant>(\n props: ListProps<Item, Variant>\n) => {\n if (process.env.NODE_ENV !== \"production\") {\n const { source, itemCount, getItemIndex, getItemAtIndex } = props;\n\n const hasIndexer =\n typeof getItemIndex === \"function\" &&\n typeof getItemAtIndex === \"function\";\n\n const hasNoIndexer =\n getItemIndex === undefined && getItemAtIndex === undefined;\n\n const sourceNotArray = !Array.isArray(source);\n\n useEffect(() => {\n if (sourceNotArray) {\n console.error(\"`source` for useList must be an array.\");\n }\n }, [sourceNotArray]);\n\n useEffect(() => {\n if (!hasNoIndexer && !hasIndexer) {\n console.error(\n \"useList needs to have both `getItemIndex` and `getItemAtIndex`.\"\n );\n }\n\n if (!hasNoIndexer && itemCount === undefined) {\n console.error(\n \"useList needs to have `itemCount` if an indexer is used.\"\n );\n }\n }, [hasIndexer, hasNoIndexer, itemCount]);\n }\n};\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"useList.js","sources":["../src/list-deprecated/useList.ts"],"sourcesContent":["import {\n ownerDocument,\n useControlled,\n useForkRef,\n useId,\n useIsFocusVisible,\n} from \"@salt-ds/core\";\n\nimport {\n type AriaAttributes,\n type Dispatch,\n type FocusEvent,\n type KeyboardEvent,\n type KeyboardEventHandler,\n type MouseEvent,\n type Ref,\n type SetStateAction,\n useCallback,\n useEffect,\n useRef,\n useState,\n} from \"react\";\nimport type {\n ListMultiSelectionVariant,\n ListProps,\n ListSelectionVariant,\n} from \"./ListProps\";\n\ntype keyHandler = (event: KeyboardEvent<HTMLInputElement>) => void;\n\ninterface listBoxAriaProps\n extends Pick<\n AriaAttributes,\n \"aria-activedescendant\" | \"aria-multiselectable\"\n > {\n role: string; // We will default it to be 'listbox', but users can override\n}\nexport interface ListState<\n Item = string,\n Variant extends ListSelectionVariant = \"default\",\n> {\n id?: string;\n focusVisible: boolean;\n selectedItem?: Variant extends ListMultiSelectionVariant ? Array<Item> : Item;\n highlightedIndex?: number;\n isDeselectable: boolean;\n isMultiSelect: boolean;\n isDisabled: boolean;\n}\n\nexport interface ListHelpers<\n Item = string,\n Variant extends ListSelectionVariant = \"default\",\n> {\n setFocusVisible: (visible: boolean) => void;\n setSelectedItem: Dispatch<\n SetStateAction<\n (Variant extends ListMultiSelectionVariant ? Item[] : Item) | undefined\n >\n >;\n setHighlightedIndex: (highlightedIndex?: number) => void;\n handleSelect: (\n event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>,\n index: number | undefined,\n item: Item,\n ) => void;\n keyDownHandlers: { [key: string]: KeyboardEventHandler };\n // TODO: Form Field\n}\n\nexport function useList<Item, Variant extends ListSelectionVariant>(\n props: ListProps<Item, Variant> = {},\n): {\n focusedRef: Ref<any>;\n listProps: Partial<ListProps<Item, Variant>> & listBoxAriaProps;\n state: ListState<Item, Variant>;\n helpers: ListHelpers<Item, Variant>;\n} {\n validateProps(props);\n\n const generatedId = useId(props.id);\n\n const {\n id = generatedId,\n source = [],\n itemCount = source.length,\n getItemId = (index) => `${id}-item-${index}`,\n getItemAtIndex: getItemAtIndexProp,\n getItemIndex: getItemIndexProp,\n displayedItemCount = 10,\n initialSelectedItem,\n selectionVariant,\n disabled = false,\n onBlur,\n onChange,\n onFocus,\n onKeyDown,\n onMouseDown,\n onMouseLeave,\n onSelect,\n disableMouseDown,\n restoreLastFocus,\n highlightedIndex: highlightedIndexProp,\n selectedItem: selectedItemProp,\n tabToSelect,\n ...restProps\n } = props;\n\n const {\n isFocusVisibleRef,\n onFocus: handleFocusVisible,\n onBlur: handleBlurVisible,\n ref: focusVisibleRef,\n } = useIsFocusVisible();\n\n const { current: isDeselectable } = useRef(\n selectionVariant === \"deselectable\",\n );\n const { current: isMultiSelect } = useRef(\n selectionVariant === \"multiple\" ||\n selectionVariant === \"extended\" ||\n Array.isArray(initialSelectedItem) ||\n Array.isArray(selectedItemProp),\n );\n\n const { current: isExtendedSelect } = useRef(selectionVariant === \"extended\");\n\n let getItemIndex = useCallback(\n (item: Item) => source.indexOf(item),\n [source],\n );\n let getItemAtIndex = useCallback((index: number) => source[index], [source]);\n\n const indexComparator = useCallback(\n (a: Item, b: Item) => getItemIndex(a) - getItemIndex(b),\n [getItemIndex],\n );\n\n // Only use getItemIndex and getItemAtIndex if both are defined; otherwise keep the defaults\n if (\n typeof getItemIndexProp === \"function\" &&\n typeof getItemAtIndexProp === \"function\"\n ) {\n getItemIndex = getItemIndexProp;\n getItemAtIndex = getItemAtIndexProp;\n }\n\n const rootRef = useRef();\n const [focusVisible, setFocusVisible] = useState(false);\n const [lastFocusedIndex, setLastFocusedIndex] = useState(-1);\n\n const [selectedItem, setSelectedItem] = useControlled<\n undefined | (Variant extends ListMultiSelectionVariant ? Item[] : Item)\n >({\n controlled: selectedItemProp,\n default:\n initialSelectedItem ??\n ((isMultiSelect\n ? []\n : null) as unknown as Variant extends ListMultiSelectionVariant\n ? Item[]\n : Item),\n name: \"useList\",\n state: \"selectedItem\",\n });\n\n const [highlightedIndex, setHighlightedIndex] = useControlled<\n number | undefined\n >({\n controlled: highlightedIndexProp,\n default: undefined,\n name: \"useList\",\n state: \"highlightedIndex\",\n });\n\n const handleSingleSelect = useCallback(\n (\n event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>,\n index: number | undefined,\n item: Item,\n ) => {\n const isSelected = item === selectedItem;\n let nextItem: Item | null;\n\n if (isSelected && !isDeselectable) {\n return;\n }\n\n if (!isSelected) {\n nextItem = item;\n setHighlightedIndex(index);\n } else {\n nextItem = null;\n }\n\n setSelectedItem(\n nextItem as Variant extends ListMultiSelectionVariant ? Item[] : Item,\n );\n\n if (onChange) {\n onChange(\n event,\n nextItem as Variant extends ListMultiSelectionVariant ? Item[] : Item,\n );\n }\n },\n [isDeselectable, onChange, selectedItem],\n );\n\n const handleMultiSelect = useCallback(\n (\n event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>,\n index: number | undefined,\n item: Item,\n ) => {\n const isSelected = (selectedItem as Item[]).indexOf(item as Item) !== -1;\n let nextItems = selectedItem as Item[];\n\n if (!isSelected) {\n nextItems = nextItems.concat([item]).sort(indexComparator);\n setHighlightedIndex(index);\n } else {\n nextItems = nextItems.filter((selected) => selected !== item);\n }\n\n setSelectedItem(\n nextItems as Variant extends ListMultiSelectionVariant ? Item[] : Item,\n );\n\n if (onChange) {\n onChange(\n event,\n nextItems as Variant extends ListMultiSelectionVariant\n ? Item[]\n : Item,\n );\n }\n },\n [indexComparator, onChange, selectedItem],\n );\n\n const handleRangeSelect = useCallback(\n (\n event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>,\n index?: number,\n ) => {\n const currentSelection =\n event.ctrlKey || event.metaKey ? selectedItem : ([] as Item[]);\n\n const lastSelectedItemIndex =\n (selectedItem as Item[]).length > 0\n ? getItemIndex(\n (selectedItem as Item[])[(selectedItem as Item[]).length - 1],\n )\n : 0;\n\n const startRegion = Math.min(\n index ?? lastSelectedItemIndex,\n lastSelectedItemIndex,\n );\n const endRegion = Math.max(\n index ?? lastSelectedItemIndex,\n lastSelectedItemIndex,\n );\n const rangeSelection = source.slice(startRegion, endRegion + 1);\n // concat the current selection with a new selection and remove duplicates for overlaps\n const nextItems = [\n ...new Set([...(currentSelection as Item[]), ...rangeSelection]),\n ];\n // remove text selection caused by shift clicking\n ownerDocument(event.currentTarget).getSelection()?.removeAllRanges();\n setSelectedItem(\n nextItems as Variant extends ListMultiSelectionVariant ? Item[] : Item,\n );\n\n if (onChange) {\n onChange(\n event,\n nextItems as Variant extends ListMultiSelectionVariant\n ? Item[]\n : Item,\n );\n }\n },\n [getItemIndex, onChange, selectedItem, source],\n );\n\n const handleExtendedSelect = useCallback(\n (\n event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>,\n index: number | undefined,\n item: Item,\n ) => {\n let nextItems = selectedItem as Item[];\n if (event.shiftKey) {\n handleRangeSelect(event, index);\n } else if (\n (selectedItem as Item[]).length === 0 ||\n event.ctrlKey ||\n event.metaKey\n ) {\n console.log(\"handleMulti\");\n handleMultiSelect(event, index, item);\n } else {\n nextItems = [item] as Item[];\n setSelectedItem(\n nextItems as Variant extends ListMultiSelectionVariant\n ? Item[]\n : Item,\n );\n\n if (onChange) {\n onChange(\n event,\n nextItems as Variant extends ListMultiSelectionVariant\n ? Item[]\n : Item,\n );\n }\n }\n },\n [handleMultiSelect, handleRangeSelect, onChange, selectedItem],\n );\n\n const handleSelect = useCallback(\n (\n event: MouseEvent<HTMLElement> | KeyboardEvent<HTMLElement>,\n index: number | undefined,\n item: Item | null,\n ) => {\n if (item == null || (item as any).disabled) {\n return;\n }\n\n if (onSelect) {\n console.log(\"onSelect\");\n onSelect(event, item);\n }\n\n if (isExtendedSelect) {\n handleExtendedSelect(event, index, item);\n } else if (isMultiSelect) {\n handleMultiSelect(event, index, item);\n } else {\n handleSingleSelect(event, index, item);\n }\n },\n [\n handleExtendedSelect,\n handleMultiSelect,\n handleSingleSelect,\n isExtendedSelect,\n isMultiSelect,\n onSelect,\n ],\n );\n\n const saveFocusedIndex = (index: number) => {\n setLastFocusedIndex(index);\n return index;\n };\n\n const keyDownHandlers: { [key: string]: keyHandler } = {\n ArrowUp: (event) => {\n event.preventDefault();\n setHighlightedIndex((prevHighlightedIndex?: number) =>\n saveFocusedIndex(Math.max(0, (prevHighlightedIndex ?? itemCount) - 1)),\n );\n },\n ArrowDown: (event) => {\n event.preventDefault();\n setHighlightedIndex((prevHighlightedIndex?: number) =>\n saveFocusedIndex(\n Math.min(itemCount - 1, (prevHighlightedIndex ?? -1) + 1),\n ),\n );\n },\n PageUp: (event) => {\n event.preventDefault();\n setHighlightedIndex((prevHighlightedIndex?: number) =>\n saveFocusedIndex(\n Math.max(\n 0,\n (prevHighlightedIndex ?? displayedItemCount) - displayedItemCount,\n ),\n ),\n );\n },\n PageDown: (event) => {\n event.preventDefault();\n setHighlightedIndex((prevHighlightedIndex?: number) =>\n saveFocusedIndex(\n Math.min(\n itemCount - 1,\n (prevHighlightedIndex ?? 0) + displayedItemCount,\n ),\n ),\n );\n },\n Home: (event) => {\n event.preventDefault();\n setHighlightedIndex(saveFocusedIndex(0));\n },\n End: (event) => {\n event.preventDefault();\n setHighlightedIndex(saveFocusedIndex(itemCount - 1));\n },\n Enter: (event) => {\n event.preventDefault();\n handleSelect(\n event,\n highlightedIndex,\n highlightedIndex != null && highlightedIndex > -1\n ? getItemAtIndex(highlightedIndex)\n : null,\n );\n },\n \" \": (event) => {\n event.preventDefault();\n handleSelect(\n event,\n highlightedIndex,\n highlightedIndex != null && highlightedIndex > -1\n ? getItemAtIndex(highlightedIndex)\n : null,\n );\n },\n Tab: (event) => {\n if (tabToSelect) {\n handleSelect(\n event,\n highlightedIndex,\n highlightedIndex != null && highlightedIndex > -1\n ? getItemAtIndex(highlightedIndex)\n : null,\n );\n } else {\n setHighlightedIndex(undefined);\n }\n },\n };\n\n const handleKeyDown: keyHandler = (event) => {\n if (isFocusVisibleRef.current) {\n setFocusVisible(true);\n }\n\n const handler: keyHandler = keyDownHandlers[event.key];\n\n if (handler) {\n handler(event);\n }\n\n if (onKeyDown) {\n onKeyDown(event);\n }\n };\n\n const handleFocus = (event: FocusEvent<HTMLDivElement>) => {\n handleFocusVisible(event);\n if (isFocusVisibleRef.current) {\n setFocusVisible(true);\n }\n\n // Work out the index to highlight\n if (highlightedIndex === undefined) {\n const firstSelectedItem = isMultiSelect\n ? (selectedItem as Item[])[0]\n : (selectedItem as Item | undefined);\n\n setHighlightedIndex(\n Math.max(\n restoreLastFocus\n ? lastFocusedIndex\n : firstSelectedItem\n ? getItemIndex(firstSelectedItem)\n : -1,\n 0,\n ),\n );\n }\n\n if (onFocus) {\n onFocus(event);\n }\n };\n\n const handleBlur = (event: FocusEvent<HTMLDivElement>) => {\n setHighlightedIndex(undefined);\n handleBlurVisible();\n if (!isFocusVisibleRef.current) {\n setFocusVisible(false);\n }\n\n if (onBlur) {\n onBlur(event);\n }\n };\n\n const handleMouseDown = (event: MouseEvent<HTMLDivElement>) => {\n if (disableMouseDown) {\n event.preventDefault();\n } else if (onMouseDown) {\n onMouseDown(event);\n }\n };\n\n const handleMouseLeave = (event: MouseEvent<HTMLDivElement>) => {\n if (focusVisible && id) {\n // Get the root node of the component if we have access to it otherwise default to current document\n const rootNode = (\n rootRef.current || ownerDocument(event.currentTarget)\n ).getRootNode();\n\n const listNode = (rootNode as Document).getElementById(id);\n\n // Safety check as `mouseleave` could have been accidentally triggered by an opening tooltip\n // when you use keyboard to navigate, hence the focusVisible check earlier\n if (listNode?.contains(event.target as Node)) {\n setHighlightedIndex(undefined);\n }\n } else {\n setHighlightedIndex(undefined);\n }\n\n if (onMouseLeave) {\n onMouseLeave(event);\n }\n };\n\n const eventHandlers = {\n onFocus: handleFocus,\n onBlur: handleBlur,\n onKeyDown: handleKeyDown,\n onMouseDown: handleMouseDown,\n onMouseLeave: handleMouseLeave,\n };\n\n const ariaProps: listBoxAriaProps = {\n role: \"listbox\",\n \"aria-activedescendant\":\n highlightedIndex !== undefined && highlightedIndex >= 0\n ? getItemId(highlightedIndex)\n : undefined,\n };\n\n if (isMultiSelect) {\n ariaProps[\"aria-multiselectable\"] = true;\n }\n\n return {\n focusedRef: useForkRef(rootRef, focusVisibleRef),\n state: {\n id,\n focusVisible,\n selectedItem,\n highlightedIndex,\n isDeselectable,\n isMultiSelect,\n isDisabled: disabled,\n },\n helpers: {\n setFocusVisible,\n setSelectedItem,\n setHighlightedIndex,\n keyDownHandlers,\n handleSelect,\n },\n listProps: {\n id,\n source,\n itemCount,\n disableMouseDown,\n displayedItemCount,\n getItemAtIndex,\n getItemIndex,\n getItemId,\n disabled,\n ...ariaProps,\n ...restProps,\n ...(disabled ? {} : eventHandlers),\n },\n };\n}\n\nconst validateProps = <Item, Variant extends ListSelectionVariant>(\n props: ListProps<Item, Variant>,\n) => {\n if (process.env.NODE_ENV !== \"production\") {\n const { source, itemCount, getItemIndex, getItemAtIndex } = props;\n\n const hasIndexer =\n typeof getItemIndex === \"function\" &&\n typeof getItemAtIndex === \"function\";\n\n const hasNoIndexer =\n getItemIndex === undefined && getItemAtIndex === undefined;\n\n const sourceNotArray = !Array.isArray(source);\n\n useEffect(() => {\n if (sourceNotArray) {\n console.error(\"`source` for useList must be an array.\");\n }\n }, [sourceNotArray]);\n\n useEffect(() => {\n if (!hasNoIndexer && !hasIndexer) {\n console.error(\n \"useList needs to have both `getItemIndex` and `getItemAtIndex`.\",\n );\n }\n\n if (!hasNoIndexer && itemCount === undefined) {\n console.error(\n \"useList needs to have `itemCount` if an indexer is used.\",\n );\n }\n }, [hasIndexer, hasNoIndexer, itemCount]);\n }\n};\n"],"names":[],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { useMemo, useCallback, useEffect } from 'react';
2
- import { useListStateContext } from './ListStateContext.js';
3
2
  import { useListItemContext } from './ListItemContext.js';
3
+ import { useListStateContext } from './ListStateContext.js';
4
4
 
5
5
  function useListItem(props) {
6
6
  var _a;
@@ -92,7 +92,7 @@ function useListItem(props) {
92
92
  highlighted,
93
93
  itemTextHighlightPattern,
94
94
  focusVisible: focusVisible && highlighted,
95
- tooltipText: itemToString(item),
95
+ tooltipText: item ? itemToString(item) : void 0,
96
96
  ...ariaProps,
97
97
  ...restProps,
98
98
  ...disabled ? {} : eventHandlers
@@ -1 +1 @@
1
- {"version":3,"file":"useListItem.js","sources":["../src/list-deprecated/useListItem.ts"],"sourcesContent":["import { useEffect, useMemo, useCallback, MouseEvent } from \"react\";\nimport { ListChildComponentProps } from \"react-window\";\n\nimport { ListItemProps } from \"./ListItem\";\nimport { ListItemBaseProps } from \"./ListItemBase\";\n\nimport { useListStateContext } from \"./ListStateContext\";\nimport { useListItemContext } from \"./ListItemContext\";\n\ntype UseItemHookReturnType<Item> = {\n /**\n * Item data\n */\n item: Item;\n /**\n * Utility function for converting item data to a string\n */\n itemToString: (item: Item) => string;\n /**\n * Properties applied to a basic list item component\n */\n itemProps: ListItemBaseProps;\n};\n\nexport interface IndexedListItemProps<Item> extends ListItemProps<Item> {\n ariaProps?: {\n role?: string;\n \"aria-disabled\"?: string;\n \"aria-checked\"?: string;\n \"aria-posinset\"?: number;\n \"aria-setsize\"?: number;\n };\n\n index: number;\n itemHeight?: number | string;\n}\n\nexport function useListItem<Item>(\n props: IndexedListItemProps<Item>\n): UseItemHookReturnType<Item> {\n validateProps(props);\n\n const context = useListItemContext<Item>();\n const { state, helpers } = useListStateContext();\n const { setHighlightedIndex, setFocusVisible, handleSelect } = helpers;\n const {\n focusVisible,\n highlightedIndex,\n selectedItem,\n isDeselectable,\n isDisabled,\n isMultiSelect,\n } = state;\n const {\n index,\n item,\n onClick,\n onMouseDown,\n onMouseMove,\n id = context.getItemId(index),\n itemHeight = context.getItemHeight?.(index),\n itemToString = context.itemToString,\n itemTextHighlightPattern = context.itemTextHighlightPattern,\n // An item can be disabled by\n // 1. Setting disabled attribute on the item object, or\n // 2. Passing a disabled prop directly or\n // 3. Using the disabled state in list context\n //TODO Not sure where disabled needs to be defined\n disabled = (item as any).disabled || isDisabled,\n ariaProps: ariaPropsProp,\n style: styleProp,\n ...restProps\n } = props;\n\n const style = useMemo(\n () => ({\n height: itemHeight,\n ...styleProp,\n }),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [itemHeight, JSON.stringify(styleProp)]\n );\n\n const highlighted = index === highlightedIndex;\n const selected = isMultiSelect\n ? selectedItem.indexOf(item) !== -1\n : item === selectedItem;\n\n const handleClick = useCallback(\n (event: MouseEvent<HTMLDivElement>) => {\n handleSelect(event, index, item);\n\n if (onClick) {\n onClick(event);\n }\n },\n [handleSelect, index, item, onClick]\n );\n\n const handleMouseMove = useCallback(\n (event: MouseEvent<HTMLDivElement>) => {\n setHighlightedIndex(index);\n setFocusVisible(false);\n\n if (onMouseMove) {\n onMouseMove(event);\n }\n },\n [index, setFocusVisible, setHighlightedIndex, onMouseMove]\n );\n\n const handleMouseDown = (\n event: MouseEvent<HTMLDivElement, globalThis.MouseEvent>\n ) => {\n if (context.disableMouseDown) {\n event.preventDefault();\n } else if (onMouseDown) {\n onMouseDown(event);\n }\n };\n\n const eventHandlers = {\n onClick: handleClick,\n onMouseMove: handleMouseMove,\n onMouseDown: handleMouseDown,\n };\n\n const ariaProps = {\n role: \"option\",\n ...(disabled && { \"aria-disabled\": true }),\n ...ariaPropsProp,\n };\n\n if (selected) {\n ariaProps[`${isMultiSelect ? \"aria-selected\" : \"aria-checked\"}`] = true;\n }\n\n return {\n item: item!,\n itemToString,\n itemProps: {\n \"data-option-index\": index,\n id,\n style,\n deselectable: isDeselectable || isMultiSelect,\n disabled,\n selected,\n highlighted,\n itemTextHighlightPattern,\n focusVisible: focusVisible && highlighted,\n tooltipText: itemToString(item!),\n ...ariaProps,\n ...restProps,\n ...(disabled ? {} : eventHandlers),\n },\n };\n}\n\ntype VirtualizedListItemProps = Pick<\n ListChildComponentProps,\n \"index\" | \"style\" | \"data\"\n>;\n\nexport const useVirtualizedListItem = (props: VirtualizedListItemProps) => {\n const { index, data, style = {} } = props;\n // Filter out inline width added by `react-window` so that it can only be defined using css.\n const { width: _unusedWidth, height: itemHeight, ...restStyle } = style;\n\n return useListItem({\n index,\n itemHeight,\n style: restStyle,\n item: data[index],\n ariaProps: {\n \"aria-posinset\": index + 1,\n \"aria-setsize\": data.length,\n },\n });\n};\n\nconst validateProps = <Item>(props: IndexedListItemProps<Item>) => {\n const { index, item } = props;\n\n /* eslint-disable react-hooks/rules-of-hooks */\n useEffect(() => {\n if (item === undefined) {\n console.warn(\"useListItem needs `item`.\");\n }\n if (index === undefined) {\n console.warn(\"useListItem needs to know item's index.\");\n }\n }, [index, item]);\n /* eslint-enable react-hooks/rules-of-hooks */\n};\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"useListItem.js","sources":["../src/list-deprecated/useListItem.ts"],"sourcesContent":["import { type MouseEvent, useCallback, useEffect, useMemo } from \"react\";\nimport type { ListChildComponentProps } from \"react-window\";\n\nimport type { ListItemProps } from \"./ListItem\";\nimport type { ListItemBaseProps } from \"./ListItemBase\";\n\nimport { useListItemContext } from \"./ListItemContext\";\nimport { useListStateContext } from \"./ListStateContext\";\n\ntype UseItemHookReturnType<Item> = {\n /**\n * Item data\n */\n item: Item;\n /**\n * Utility function for converting item data to a string\n */\n itemToString: (item: Item) => string;\n /**\n * Properties applied to a basic list item component\n */\n itemProps: ListItemBaseProps;\n};\n\nexport interface IndexedListItemProps<Item> extends ListItemProps<Item> {\n ariaProps?: {\n role?: string;\n \"aria-disabled\"?: string;\n \"aria-checked\"?: string;\n \"aria-posinset\"?: number;\n \"aria-setsize\"?: number;\n };\n\n index: number;\n itemHeight?: number | string;\n}\n\nexport function useListItem<Item>(\n props: IndexedListItemProps<Item>,\n): UseItemHookReturnType<Item> {\n validateProps(props);\n\n const context = useListItemContext<Item>();\n const { state, helpers } = useListStateContext();\n const { setHighlightedIndex, setFocusVisible, handleSelect } = helpers;\n const {\n focusVisible,\n highlightedIndex,\n selectedItem,\n isDeselectable,\n isDisabled,\n isMultiSelect,\n } = state;\n const {\n index,\n item,\n onClick,\n onMouseDown,\n onMouseMove,\n id = context.getItemId(index),\n itemHeight = context.getItemHeight?.(index),\n itemToString = context.itemToString,\n itemTextHighlightPattern = context.itemTextHighlightPattern,\n // An item can be disabled by\n // 1. Setting disabled attribute on the item object, or\n // 2. Passing a disabled prop directly or\n // 3. Using the disabled state in list context\n //TODO Not sure where disabled needs to be defined\n disabled = (item as any).disabled || isDisabled,\n ariaProps: ariaPropsProp,\n style: styleProp,\n ...restProps\n } = props;\n\n // biome-ignore lint/correctness/useExhaustiveDependencies: JSON.stringify is used to compare objects\n const style = useMemo(\n () => ({\n height: itemHeight,\n ...styleProp,\n }),\n [itemHeight, JSON.stringify(styleProp)],\n );\n\n const highlighted = index === highlightedIndex;\n const selected = isMultiSelect\n ? selectedItem.indexOf(item) !== -1\n : item === selectedItem;\n\n const handleClick = useCallback(\n (event: MouseEvent<HTMLDivElement>) => {\n handleSelect(event, index, item);\n\n if (onClick) {\n onClick(event);\n }\n },\n [handleSelect, index, item, onClick],\n );\n\n const handleMouseMove = useCallback(\n (event: MouseEvent<HTMLDivElement>) => {\n setHighlightedIndex(index);\n setFocusVisible(false);\n\n if (onMouseMove) {\n onMouseMove(event);\n }\n },\n [index, setFocusVisible, setHighlightedIndex, onMouseMove],\n );\n\n const handleMouseDown = (\n event: MouseEvent<HTMLDivElement, globalThis.MouseEvent>,\n ) => {\n if (context.disableMouseDown) {\n event.preventDefault();\n } else if (onMouseDown) {\n onMouseDown(event);\n }\n };\n\n const eventHandlers = {\n onClick: handleClick,\n onMouseMove: handleMouseMove,\n onMouseDown: handleMouseDown,\n };\n\n const ariaProps = {\n role: \"option\",\n ...(disabled && { \"aria-disabled\": true }),\n ...ariaPropsProp,\n };\n\n if (selected) {\n ariaProps[`${isMultiSelect ? \"aria-selected\" : \"aria-checked\"}`] = true;\n }\n\n return {\n item: item!,\n itemToString,\n itemProps: {\n \"data-option-index\": index,\n id,\n style,\n deselectable: isDeselectable || isMultiSelect,\n disabled,\n selected,\n highlighted,\n itemTextHighlightPattern,\n focusVisible: focusVisible && highlighted,\n tooltipText: item ? itemToString(item) : undefined,\n ...ariaProps,\n ...restProps,\n ...(disabled ? {} : eventHandlers),\n },\n };\n}\n\ntype VirtualizedListItemProps = Pick<\n ListChildComponentProps,\n \"index\" | \"style\" | \"data\"\n>;\n\nexport const useVirtualizedListItem = (props: VirtualizedListItemProps) => {\n const { index, data, style = {} } = props;\n // Filter out inline width added by `react-window` so that it can only be defined using css.\n const { width: _unusedWidth, height: itemHeight, ...restStyle } = style;\n\n return useListItem({\n index,\n itemHeight,\n style: restStyle,\n item: data[index],\n ariaProps: {\n \"aria-posinset\": index + 1,\n \"aria-setsize\": data.length,\n },\n });\n};\n\nconst validateProps = <Item>(props: IndexedListItemProps<Item>) => {\n const { index, item } = props;\n\n /* eslint-disable react-hooks/rules-of-hooks */\n useEffect(() => {\n if (item === undefined) {\n console.warn(\"useListItem needs `item`.\");\n }\n if (index === undefined) {\n console.warn(\"useListItem needs to know item's index.\");\n }\n }, [index, item]);\n /* eslint-enable react-hooks/rules-of-hooks */\n};\n"],"names":[],"mappings":"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"}
@@ -23,7 +23,7 @@ function useTypeSelect(options) {
23
23
  while (index < itemCount) {
24
24
  const item = getItemAtIndex(index);
25
25
  const textValue = itemToString$1 ? itemToString$1(item) : item;
26
- if (textValue && textValue.match(new RegExp(`^${escapeRegExp(searchTerm)}`, "i"))) {
26
+ if (textValue == null ? void 0 : textValue.match(new RegExp(`^${escapeRegExp(searchTerm)}`, "i"))) {
27
27
  return index;
28
28
  }
29
29
  index = index + 1;
@@ -1 +1 @@
1
- {"version":3,"file":"useTypeSelect.js","sources":["../src/list-deprecated/useTypeSelect.js"],"sourcesContent":["import { useCallback, useRef } from \"react\";\nimport { escapeRegExp } from \"../utils\";\n\nimport { itemToString as defaultItemToString } from \"./itemToString\";\n\nconst TYPE_SELECT_TIMEOUT = 1500;\n\nexport function useTypeSelect(options) {\n const {\n getItemAtIndex,\n highlightedIndex,\n itemCount,\n itemToString = defaultItemToString,\n onTypeSelect,\n setFocusVisible,\n setHighlightedIndex,\n } = options;\n\n const getItemIndexForSearch = useCallback(\n (searchTerm, fromIndex) => {\n if (itemCount === 0) {\n return null;\n }\n\n let index = fromIndex || 0;\n while (index < itemCount) {\n const item = getItemAtIndex(index);\n const textValue = itemToString ? itemToString(item) : item;\n if (\n textValue &&\n textValue.match(new RegExp(`^${escapeRegExp(searchTerm)}`, \"i\"))\n ) {\n return index;\n }\n\n index = index + 1;\n }\n\n return null;\n },\n [itemCount, itemToString, getItemAtIndex]\n );\n\n const state = useRef({\n search: \"\",\n timeout: null,\n }).current;\n\n // eslint-disable-next-line complexity\n const onKeyDownCapture = (event) => {\n const character = getStringForKey(event.key);\n if (!character || event.ctrlKey || event.metaKey) {\n return;\n }\n\n // Do not propagate the Spacebar event if it's meant to be part of the search.\n // When we time out, the search term becomes empty, hence the check on length.\n // Trimming is to account for the case of pressing the Spacebar more than once,\n // which should cycle through the selection/deselection of the focused item.\n if (character !== \" \" || state.search.trim().length > 0) {\n event.preventDefault();\n event.stopPropagation();\n }\n\n // When typing same character sebsequently and *quickly*, we treat it as cyling through items\n // starting with that char instead of seaching for double character, because in most cases\n // there won't be any option having same characters at the beginning. This should be only\n // impacting beginning of the words because length of `character` would be 1.\n if (character !== state.search) {\n state.search += character;\n }\n\n // Prioritize items after the currently focused item, falling back to searching the whole list.\n // We want to cycle through choices when keep typing the same first character, hence the +1\n // condition. All subsequent characters should stay at the current item otherwise it will\n // always jumping around.\n let index = getItemIndexForSearch(\n state.search,\n state.search.length > 1 ? highlightedIndex : highlightedIndex + 1\n );\n\n // If no key found, search from the top.\n if (index == null) {\n index = getItemIndexForSearch(state.search);\n }\n\n if (index != null) {\n setFocusVisible(true);\n // TODO: Maybe we can repurpose this setHighlightedIndex so that the user controls it's meant to set\n // hightlighted index when expanded v.s. selected item when collapsed\n setHighlightedIndex(index);\n if (onTypeSelect) {\n onTypeSelect(index);\n }\n }\n\n clearTimeout(state.timeout);\n state.timeout = setTimeout(() => {\n state.search = \"\";\n }, TYPE_SELECT_TIMEOUT);\n };\n\n return {\n // Using a capturing listener to catch the keydown event before\n // other hooks in order to handle the Spacebar event.\n onKeyDownCapture,\n };\n}\n\nfunction getStringForKey(key) {\n // If the key is of length 1, it is an ASCII value.\n // Otherwise, if there are no ASCII characters in the key name,\n // it is a Unicode character.\n // See https://www.w3.org/TR/uievents-key/\n if (key.length === 1 || !/^[A-Z]/i.test(key)) {\n return key;\n }\n\n return \"\";\n}\n"],"names":["itemToString","defaultItemToString"],"mappings":"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"}
1
+ {"version":3,"file":"useTypeSelect.js","sources":["../src/list-deprecated/useTypeSelect.js"],"sourcesContent":["import { useCallback, useRef } from \"react\";\nimport { escapeRegExp } from \"../utils\";\n\nimport { itemToString as defaultItemToString } from \"./itemToString\";\n\nconst TYPE_SELECT_TIMEOUT = 1500;\n\nexport function useTypeSelect(options) {\n const {\n getItemAtIndex,\n highlightedIndex,\n itemCount,\n itemToString = defaultItemToString,\n onTypeSelect,\n setFocusVisible,\n setHighlightedIndex,\n } = options;\n\n const getItemIndexForSearch = useCallback(\n (searchTerm, fromIndex) => {\n if (itemCount === 0) {\n return null;\n }\n\n let index = fromIndex || 0;\n while (index < itemCount) {\n const item = getItemAtIndex(index);\n const textValue = itemToString ? itemToString(item) : item;\n if (textValue?.match(new RegExp(`^${escapeRegExp(searchTerm)}`, \"i\"))) {\n return index;\n }\n\n index = index + 1;\n }\n\n return null;\n },\n [itemCount, itemToString, getItemAtIndex],\n );\n\n const state = useRef({\n search: \"\",\n timeout: null,\n }).current;\n\n const onKeyDownCapture = (event) => {\n const character = getStringForKey(event.key);\n if (!character || event.ctrlKey || event.metaKey) {\n return;\n }\n\n // Do not propagate the Spacebar event if it's meant to be part of the search.\n // When we time out, the search term becomes empty, hence the check on length.\n // Trimming is to account for the case of pressing the Spacebar more than once,\n // which should cycle through the selection/deselection of the focused item.\n if (character !== \" \" || state.search.trim().length > 0) {\n event.preventDefault();\n event.stopPropagation();\n }\n\n // When typing same character sebsequently and *quickly*, we treat it as cyling through items\n // starting with that char instead of seaching for double character, because in most cases\n // there won't be any option having same characters at the beginning. This should be only\n // impacting beginning of the words because length of `character` would be 1.\n if (character !== state.search) {\n state.search += character;\n }\n\n // Prioritize items after the currently focused item, falling back to searching the whole list.\n // We want to cycle through choices when keep typing the same first character, hence the +1\n // condition. All subsequent characters should stay at the current item otherwise it will\n // always jumping around.\n let index = getItemIndexForSearch(\n state.search,\n state.search.length > 1 ? highlightedIndex : highlightedIndex + 1,\n );\n\n // If no key found, search from the top.\n if (index == null) {\n index = getItemIndexForSearch(state.search);\n }\n\n if (index != null) {\n setFocusVisible(true);\n // TODO: Maybe we can repurpose this setHighlightedIndex so that the user controls it's meant to set\n // hightlighted index when expanded v.s. selected item when collapsed\n setHighlightedIndex(index);\n if (onTypeSelect) {\n onTypeSelect(index);\n }\n }\n\n clearTimeout(state.timeout);\n state.timeout = setTimeout(() => {\n state.search = \"\";\n }, TYPE_SELECT_TIMEOUT);\n };\n\n return {\n // Using a capturing listener to catch the keydown event before\n // other hooks in order to handle the Spacebar event.\n onKeyDownCapture,\n };\n}\n\nfunction getStringForKey(key) {\n // If the key is of length 1, it is an ASCII value.\n // Otherwise, if there are no ASCII characters in the key name,\n // it is a Unicode character.\n // See https://www.w3.org/TR/uievents-key/\n if (key.length === 1 || !/^[A-Z]/i.test(key)) {\n return key;\n }\n\n return \"\";\n}\n"],"names":["itemToString","defaultItemToString"],"mappings":";;;;;AAKA,MAAM,mBAAsB,GAAA,IAAA,CAAA;AAErB,SAAS,cAAc,OAAS,EAAA;AACrC,EAAM,MAAA;AAAA,IACJ,cAAA;AAAA,IACA,gBAAA;AAAA,IACA,SAAA;AAAA,kBACAA,cAAe,GAAAC,YAAA;AAAA,IACf,YAAA;AAAA,IACA,eAAA;AAAA,IACA,mBAAA;AAAA,GACE,GAAA,OAAA,CAAA;AAEJ,EAAA,MAAM,qBAAwB,GAAA,WAAA;AAAA,IAC5B,CAAC,YAAY,SAAc,KAAA;AACzB,MAAA,IAAI,cAAc,CAAG,EAAA;AACnB,QAAO,OAAA,IAAA,CAAA;AAAA,OACT;AAEA,MAAA,IAAI,QAAQ,SAAa,IAAA,CAAA,CAAA;AACzB,MAAA,OAAO,QAAQ,SAAW,EAAA;AACxB,QAAM,MAAA,IAAA,GAAO,eAAe,KAAK,CAAA,CAAA;AACjC,QAAA,MAAM,SAAY,GAAAD,cAAA,GAAeA,cAAa,CAAA,IAAI,CAAI,GAAA,IAAA,CAAA;AACtD,QAAI,IAAA,SAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,SAAA,CAAW,MAAM,IAAI,MAAA,CAAO,IAAI,YAAa,CAAA,UAAU,CAAK,CAAA,CAAA,EAAA,GAAG,CAAI,CAAA,EAAA;AACrE,UAAO,OAAA,KAAA,CAAA;AAAA,SACT;AAEA,QAAA,KAAA,GAAQ,KAAQ,GAAA,CAAA,CAAA;AAAA,OAClB;AAEA,MAAO,OAAA,IAAA,CAAA;AAAA,KACT;AAAA,IACA,CAAC,SAAW,EAAAA,cAAA,EAAc,cAAc,CAAA;AAAA,GAC1C,CAAA;AAEA,EAAA,MAAM,QAAQ,MAAO,CAAA;AAAA,IACnB,MAAQ,EAAA,EAAA;AAAA,IACR,OAAS,EAAA,IAAA;AAAA,GACV,CAAE,CAAA,OAAA,CAAA;AAEH,EAAM,MAAA,gBAAA,GAAmB,CAAC,KAAU,KAAA;AAClC,IAAM,MAAA,SAAA,GAAY,eAAgB,CAAA,KAAA,CAAM,GAAG,CAAA,CAAA;AAC3C,IAAA,IAAI,CAAC,SAAA,IAAa,KAAM,CAAA,OAAA,IAAW,MAAM,OAAS,EAAA;AAChD,MAAA,OAAA;AAAA,KACF;AAMA,IAAA,IAAI,cAAc,GAAO,IAAA,KAAA,CAAM,OAAO,IAAK,EAAA,CAAE,SAAS,CAAG,EAAA;AACvD,MAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,MAAA,KAAA,CAAM,eAAgB,EAAA,CAAA;AAAA,KACxB;AAMA,IAAI,IAAA,SAAA,KAAc,MAAM,MAAQ,EAAA;AAC9B,MAAA,KAAA,CAAM,MAAU,IAAA,SAAA,CAAA;AAAA,KAClB;AAMA,IAAA,IAAI,KAAQ,GAAA,qBAAA;AAAA,MACV,KAAM,CAAA,MAAA;AAAA,MACN,KAAM,CAAA,MAAA,CAAO,MAAS,GAAA,CAAA,GAAI,mBAAmB,gBAAmB,GAAA,CAAA;AAAA,KAClE,CAAA;AAGA,IAAA,IAAI,SAAS,IAAM,EAAA;AACjB,MAAQ,KAAA,GAAA,qBAAA,CAAsB,MAAM,MAAM,CAAA,CAAA;AAAA,KAC5C;AAEA,IAAA,IAAI,SAAS,IAAM,EAAA;AACjB,MAAA,eAAA,CAAgB,IAAI,CAAA,CAAA;AAGpB,MAAA,mBAAA,CAAoB,KAAK,CAAA,CAAA;AACzB,MAAA,IAAI,YAAc,EAAA;AAChB,QAAA,YAAA,CAAa,KAAK,CAAA,CAAA;AAAA,OACpB;AAAA,KACF;AAEA,IAAA,YAAA,CAAa,MAAM,OAAO,CAAA,CAAA;AAC1B,IAAM,KAAA,CAAA,OAAA,GAAU,WAAW,MAAM;AAC/B,MAAA,KAAA,CAAM,MAAS,GAAA,EAAA,CAAA;AAAA,OACd,mBAAmB,CAAA,CAAA;AAAA,GACxB,CAAA;AAEA,EAAO,OAAA;AAAA,IAGL,gBAAA;AAAA,GACF,CAAA;AACF,CAAA;AAEA,SAAS,gBAAgB,GAAK,EAAA;AAK5B,EAAA,IAAI,IAAI,MAAW,KAAA,CAAA,IAAK,CAAC,SAAU,CAAA,IAAA,CAAK,GAAG,CAAG,EAAA;AAC5C,IAAO,OAAA,GAAA,CAAA;AAAA,GACT;AAEA,EAAO,OAAA,EAAA,CAAA;AACT;;;;"}
@@ -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, useIdMemo } 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 './ListItemNext.css.js';
8
8
  import { useListItem } from './ListNextContext.js';
9
9
 
@@ -1 +1 @@
1
- {"version":3,"file":"ListItemNext.js","sources":["../src/list-next/ListItemNext.tsx"],"sourcesContent":["import { forwardRef, HTMLAttributes, MouseEvent } from \"react\";\nimport { clsx } from \"clsx\";\nimport { makePrefixer, useIdMemo } from \"@salt-ds/core\";\n\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport listItemNextCss from \"./ListItemNext.css\";\nimport { useListItem } from \"./ListNextContext\";\n\nconst withBaseName = makePrefixer(\"saltListItemNext\");\n\nexport interface ListItemNextProps extends HTMLAttributes<HTMLLIElement> {\n /**\n * If true, the particular list item in list will be disabled.\n */\n disabled?: boolean;\n /**\n * List item id.\n */\n id?: string;\n /**\n * List item value.\n */\n value: string;\n}\n\nexport const ListItemNext = forwardRef<HTMLLIElement, ListItemNextProps>(\n function ListItemNext(\n {\n children,\n className,\n disabled: disabledProp,\n id: idProp,\n value,\n onClick,\n ...props\n },\n ref\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-list-item-next\",\n css: listItemNextCss,\n window: targetWindow,\n });\n const id = useIdMemo(idProp);\n\n const listContext = useListItem();\n if (!listContext) return null;\n\n const {\n id: contextId,\n disabled: contextDisabled,\n select,\n isSelected,\n isFocused,\n highlight,\n isHighlighted,\n } = listContext;\n\n const itemId = `${contextId || \"listNext\"}--${id}`;\n const disabled = disabledProp || contextDisabled;\n const selected = isSelected(value);\n const focused = isFocused(value);\n const highlighted = isHighlighted(value);\n\n const handleClick = (event: MouseEvent<HTMLLIElement>) => {\n if (!disabled) {\n select(event);\n onClick?.(event);\n }\n };\n\n const handleMouseMove = (event: MouseEvent<HTMLLIElement>) => {\n if (!highlighted) {\n highlight(event);\n }\n };\n\n return (\n <li\n ref={ref}\n className={clsx(\n withBaseName(),\n {\n [withBaseName(\"disabled\")]: disabled,\n [withBaseName(\"highlighted\")]: highlighted,\n [withBaseName(\"focused\")]: focused,\n },\n className\n )}\n role=\"option\"\n aria-disabled={disabled || undefined}\n aria-selected={selected || undefined}\n id={itemId}\n data-value={value}\n onClick={handleClick}\n onMouseMove={handleMouseMove}\n {...props}\n >\n {children}\n </li>\n );\n }\n);\n"],"names":["ListItemNext","listItemNextCss"],"mappings":";;;;;;;;;AASA,MAAM,YAAA,GAAe,aAAa,kBAAkB,CAAA,CAAA;AAiB7C,MAAM,YAAe,GAAA,UAAA;AAAA,EAC1B,SAASA,aACP,CAAA;AAAA,IACE,QAAA;AAAA,IACA,SAAA;AAAA,IACA,QAAU,EAAA,YAAA;AAAA,IACV,EAAI,EAAA,MAAA;AAAA,IACJ,KAAA;AAAA,IACA,OAAA;AAAA,IACG,GAAA,KAAA;AAAA,KAEL,GACA,EAAA;AACA,IAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,IAAyB,wBAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,qBAAA;AAAA,MACR,GAAK,EAAAC,QAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AACD,IAAM,MAAA,EAAA,GAAK,UAAU,MAAM,CAAA,CAAA;AAE3B,IAAA,MAAM,cAAc,WAAY,EAAA,CAAA;AAChC,IAAA,IAAI,CAAC,WAAA;AAAa,MAAO,OAAA,IAAA,CAAA;AAEzB,IAAM,MAAA;AAAA,MACJ,EAAI,EAAA,SAAA;AAAA,MACJ,QAAU,EAAA,eAAA;AAAA,MACV,MAAA;AAAA,MACA,UAAA;AAAA,MACA,SAAA;AAAA,MACA,SAAA;AAAA,MACA,aAAA;AAAA,KACE,GAAA,WAAA,CAAA;AAEJ,IAAM,MAAA,MAAA,GAAS,CAAG,EAAA,SAAA,IAAa,UAAe,CAAA,EAAA,EAAA,EAAA,CAAA,CAAA,CAAA;AAC9C,IAAA,MAAM,WAAW,YAAgB,IAAA,eAAA,CAAA;AACjC,IAAM,MAAA,QAAA,GAAW,WAAW,KAAK,CAAA,CAAA;AACjC,IAAM,MAAA,OAAA,GAAU,UAAU,KAAK,CAAA,CAAA;AAC/B,IAAM,MAAA,WAAA,GAAc,cAAc,KAAK,CAAA,CAAA;AAEvC,IAAM,MAAA,WAAA,GAAc,CAAC,KAAqC,KAAA;AACxD,MAAA,IAAI,CAAC,QAAU,EAAA;AACb,QAAA,MAAA,CAAO,KAAK,CAAA,CAAA;AACZ,QAAU,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,CAAA,KAAA,CAAA,CAAA;AAAA,OACZ;AAAA,KACF,CAAA;AAEA,IAAM,MAAA,eAAA,GAAkB,CAAC,KAAqC,KAAA;AAC5D,MAAA,IAAI,CAAC,WAAa,EAAA;AAChB,QAAA,SAAA,CAAU,KAAK,CAAA,CAAA;AAAA,OACjB;AAAA,KACF,CAAA;AAEA,IAAA,uBACG,GAAA,CAAA,IAAA,EAAA;AAAA,MACC,GAAA;AAAA,MACA,SAAW,EAAA,IAAA;AAAA,QACT,YAAa,EAAA;AAAA,QACb;AAAA,UACE,CAAC,YAAa,CAAA,UAAU,CAAI,GAAA,QAAA;AAAA,UAC5B,CAAC,YAAa,CAAA,aAAa,CAAI,GAAA,WAAA;AAAA,UAC/B,CAAC,YAAa,CAAA,SAAS,CAAI,GAAA,OAAA;AAAA,SAC7B;AAAA,QACA,SAAA;AAAA,OACF;AAAA,MACA,IAAK,EAAA,QAAA;AAAA,MACL,iBAAe,QAAY,IAAA,KAAA,CAAA;AAAA,MAC3B,iBAAe,QAAY,IAAA,KAAA,CAAA;AAAA,MAC3B,EAAI,EAAA,MAAA;AAAA,MACJ,YAAY,EAAA,KAAA;AAAA,MACZ,OAAS,EAAA,WAAA;AAAA,MACT,WAAa,EAAA,eAAA;AAAA,MACZ,GAAG,KAAA;AAAA,MAEH,QAAA;AAAA,KACH,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
1
+ {"version":3,"file":"ListItemNext.js","sources":["../src/list-next/ListItemNext.tsx"],"sourcesContent":["import { makePrefixer, useIdMemo } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { type HTMLAttributes, type MouseEvent, forwardRef } from \"react\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport listItemNextCss from \"./ListItemNext.css\";\nimport { useListItem } from \"./ListNextContext\";\n\nconst withBaseName = makePrefixer(\"saltListItemNext\");\n\nexport interface ListItemNextProps extends HTMLAttributes<HTMLLIElement> {\n /**\n * If true, the particular list item in list will be disabled.\n */\n disabled?: boolean;\n /**\n * List item id.\n */\n id?: string;\n /**\n * List item value.\n */\n value: string;\n}\n\nexport const ListItemNext = forwardRef<HTMLLIElement, ListItemNextProps>(\n function ListItemNext(\n {\n children,\n className,\n disabled: disabledProp,\n id: idProp,\n value,\n onClick,\n ...props\n },\n ref,\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-list-item-next\",\n css: listItemNextCss,\n window: targetWindow,\n });\n const id = useIdMemo(idProp);\n\n const listContext = useListItem();\n if (!listContext) return null;\n\n const {\n id: contextId,\n disabled: contextDisabled,\n select,\n isSelected,\n isFocused,\n highlight,\n isHighlighted,\n } = listContext;\n\n const itemId = `${contextId || \"listNext\"}--${id}`;\n const disabled = disabledProp || contextDisabled;\n const selected = isSelected(value);\n const focused = isFocused(value);\n const highlighted = isHighlighted(value);\n\n const handleClick = (event: MouseEvent<HTMLLIElement>) => {\n if (!disabled) {\n select(event);\n onClick?.(event);\n }\n };\n\n const handleMouseMove = (event: MouseEvent<HTMLLIElement>) => {\n if (!highlighted) {\n highlight(event);\n }\n };\n\n return (\n <li\n ref={ref}\n className={clsx(\n withBaseName(),\n {\n [withBaseName(\"disabled\")]: disabled,\n [withBaseName(\"highlighted\")]: highlighted,\n [withBaseName(\"focused\")]: focused,\n },\n className,\n )}\n role=\"option\"\n aria-disabled={disabled || undefined}\n aria-selected={selected || undefined}\n id={itemId}\n data-value={value}\n onClick={handleClick}\n onMouseMove={handleMouseMove}\n {...props}\n >\n {children}\n </li>\n );\n },\n);\n"],"names":["ListItemNext","listItemNextCss"],"mappings":";;;;;;;;;AASA,MAAM,YAAA,GAAe,aAAa,kBAAkB,CAAA,CAAA;AAiB7C,MAAM,YAAe,GAAA,UAAA;AAAA,EAC1B,SAASA,aACP,CAAA;AAAA,IACE,QAAA;AAAA,IACA,SAAA;AAAA,IACA,QAAU,EAAA,YAAA;AAAA,IACV,EAAI,EAAA,MAAA;AAAA,IACJ,KAAA;AAAA,IACA,OAAA;AAAA,IACG,GAAA,KAAA;AAAA,KAEL,GACA,EAAA;AACA,IAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,IAAyB,wBAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,qBAAA;AAAA,MACR,GAAK,EAAAC,QAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AACD,IAAM,MAAA,EAAA,GAAK,UAAU,MAAM,CAAA,CAAA;AAE3B,IAAA,MAAM,cAAc,WAAY,EAAA,CAAA;AAChC,IAAA,IAAI,CAAC,WAAA;AAAa,MAAO,OAAA,IAAA,CAAA;AAEzB,IAAM,MAAA;AAAA,MACJ,EAAI,EAAA,SAAA;AAAA,MACJ,QAAU,EAAA,eAAA;AAAA,MACV,MAAA;AAAA,MACA,UAAA;AAAA,MACA,SAAA;AAAA,MACA,SAAA;AAAA,MACA,aAAA;AAAA,KACE,GAAA,WAAA,CAAA;AAEJ,IAAM,MAAA,MAAA,GAAS,CAAG,EAAA,SAAA,IAAa,UAAe,CAAA,EAAA,EAAA,EAAA,CAAA,CAAA,CAAA;AAC9C,IAAA,MAAM,WAAW,YAAgB,IAAA,eAAA,CAAA;AACjC,IAAM,MAAA,QAAA,GAAW,WAAW,KAAK,CAAA,CAAA;AACjC,IAAM,MAAA,OAAA,GAAU,UAAU,KAAK,CAAA,CAAA;AAC/B,IAAM,MAAA,WAAA,GAAc,cAAc,KAAK,CAAA,CAAA;AAEvC,IAAM,MAAA,WAAA,GAAc,CAAC,KAAqC,KAAA;AACxD,MAAA,IAAI,CAAC,QAAU,EAAA;AACb,QAAA,MAAA,CAAO,KAAK,CAAA,CAAA;AACZ,QAAU,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,CAAA,KAAA,CAAA,CAAA;AAAA,OACZ;AAAA,KACF,CAAA;AAEA,IAAM,MAAA,eAAA,GAAkB,CAAC,KAAqC,KAAA;AAC5D,MAAA,IAAI,CAAC,WAAa,EAAA;AAChB,QAAA,SAAA,CAAU,KAAK,CAAA,CAAA;AAAA,OACjB;AAAA,KACF,CAAA;AAEA,IAAA,uBACG,GAAA,CAAA,IAAA,EAAA;AAAA,MACC,GAAA;AAAA,MACA,SAAW,EAAA,IAAA;AAAA,QACT,YAAa,EAAA;AAAA,QACb;AAAA,UACE,CAAC,YAAa,CAAA,UAAU,CAAI,GAAA,QAAA;AAAA,UAC5B,CAAC,YAAa,CAAA,aAAa,CAAI,GAAA,WAAA;AAAA,UAC/B,CAAC,YAAa,CAAA,SAAS,CAAI,GAAA,OAAA;AAAA,SAC7B;AAAA,QACA,SAAA;AAAA,OACF;AAAA,MACA,IAAK,EAAA,QAAA;AAAA,MACL,iBAAe,QAAY,IAAA,KAAA,CAAA;AAAA,MAC3B,iBAAe,QAAY,IAAA,KAAA,CAAA;AAAA,MAC3B,EAAI,EAAA,MAAA;AAAA,MACJ,YAAY,EAAA,KAAA;AAAA,MACZ,OAAS,EAAA,WAAA;AAAA,MACT,WAAa,EAAA,eAAA;AAAA,MACZ,GAAG,KAAA;AAAA,MAEH,QAAA;AAAA,KACH,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
@@ -1,12 +1,12 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
2
  import { makePrefixer, useId, useForkRef } from '@salt-ds/core';
3
- import { forwardRef, useRef } from 'react';
4
- import { clsx } from 'clsx';
5
- import { useList } from './useList.js';
6
- import { useWindow } from '@salt-ds/window';
7
3
  import { useComponentCssInjection } from '@salt-ds/styles';
4
+ import { useWindow } from '@salt-ds/window';
5
+ import { clsx } from 'clsx';
6
+ import { forwardRef, useRef } from 'react';
8
7
  import css_248z from './ListNext.css.js';
9
8
  import { ListNextContext } from './ListNextContext.js';
9
+ import { useList } from './useList.js';
10
10
 
11
11
  const withBaseName = makePrefixer("saltListNext");
12
12
  const ListNext = forwardRef(
@@ -1 +1 @@
1
- {"version":3,"file":"ListNext.js","sources":["../src/list-next/ListNext.tsx"],"sourcesContent":["import { makePrefixer, useForkRef, useId } from \"@salt-ds/core\";\nimport {\n ComponentPropsWithoutRef,\n FocusEvent,\n forwardRef,\n KeyboardEvent,\n MouseEvent,\n SyntheticEvent,\n useRef,\n} from \"react\";\nimport { clsx } from \"clsx\";\nimport { useList } from \"./useList\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport listNextCss from \"./ListNext.css\";\nimport { ListNextContext } from \"./ListNextContext\";\n\nconst withBaseName = makePrefixer(\"saltListNext\");\n\nexport interface ListNextProps\n extends Omit<ComponentPropsWithoutRef<\"ul\">, \"onChange\" | \"onSelect\"> {\n /**\n * If true, all items in list will be disabled.\n */\n disabled?: boolean;\n /* If `true`, the component will not receive focus. */\n disableFocus?: boolean;\n /* Value for the controlled version. */\n highlightedItem?: string;\n /* Value for the controlled version. */\n selected?: string;\n /* Callback for change event. Returns current selection.*/\n onChange?: (\n event: SyntheticEvent,\n data: { value: string | undefined }\n ) => void;\n /* Callback for select event. Returns new selected item.*/\n onSelect?: (event: SyntheticEvent, data: { value: string }) => void;\n /* Initial selection. */\n defaultSelected?: string;\n}\n\nexport const ListNext = forwardRef<HTMLUListElement, ListNextProps>(\n function ListNext(\n {\n children,\n className,\n disabled,\n disableFocus,\n id,\n onSelect,\n onFocus,\n onBlur,\n onKeyDown,\n onMouseOver,\n highlightedItem,\n selected,\n defaultSelected,\n onChange,\n ...rest\n },\n ref\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-list-next\",\n css: listNextCss,\n window: targetWindow,\n });\n\n const listId = useId(id);\n const listRef = useRef<HTMLUListElement>(null);\n const handleRef = useForkRef(listRef, ref);\n const {\n focusHandler,\n keyDownHandler,\n blurHandler,\n mouseOverHandler,\n activeDescendant,\n contextValue,\n focusVisibleRef,\n } = useList({\n disabled,\n highlightedItem,\n selected,\n defaultSelected,\n onChange,\n onSelect,\n id: listId,\n ref: listRef,\n });\n\n const setListRef = useForkRef(focusVisibleRef, handleRef);\n\n const handleFocus = (event: FocusEvent<HTMLUListElement>) => {\n focusHandler(event);\n onFocus?.(event);\n };\n\n const handleKeyDown = (event: KeyboardEvent<HTMLUListElement>) => {\n if (disableFocus) {\n event.preventDefault();\n return;\n }\n keyDownHandler(event);\n onKeyDown?.(event);\n };\n\n const handleBlur = (event: FocusEvent<HTMLUListElement>) => {\n blurHandler();\n onBlur?.(event);\n };\n\n const handleMouseOver = (event: MouseEvent<HTMLUListElement>) => {\n mouseOverHandler();\n onMouseOver?.(event);\n };\n\n return (\n <ListNextContext.Provider value={contextValue}>\n <ul\n // TODO: fix type from useIsFocusVisible\n // @ts-ignore\n ref={setListRef}\n id={listId}\n className={clsx(withBaseName(), className)}\n role=\"listbox\"\n tabIndex={disabled || disableFocus ? -1 : 0}\n aria-activedescendant={disabled ? undefined : activeDescendant}\n aria-disabled={disabled}\n onFocus={handleFocus}\n onKeyDown={handleKeyDown}\n onBlur={handleBlur}\n onMouseOver={handleMouseOver}\n {...rest}\n >\n {children}\n </ul>\n </ListNextContext.Provider>\n );\n }\n);\n"],"names":["ListNext","listNextCss"],"mappings":"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"}
1
+ {"version":3,"file":"ListNext.js","sources":["../src/list-next/ListNext.tsx"],"sourcesContent":["import { makePrefixer, useForkRef, useId } from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport {\n type ComponentPropsWithoutRef,\n type FocusEvent,\n type KeyboardEvent,\n type MouseEvent,\n type SyntheticEvent,\n forwardRef,\n useRef,\n} from \"react\";\nimport listNextCss from \"./ListNext.css\";\nimport { ListNextContext } from \"./ListNextContext\";\nimport { useList } from \"./useList\";\n\nconst withBaseName = makePrefixer(\"saltListNext\");\n\nexport interface ListNextProps\n extends Omit<ComponentPropsWithoutRef<\"ul\">, \"onChange\" | \"onSelect\"> {\n /**\n * If true, all items in list will be disabled.\n */\n disabled?: boolean;\n /* If `true`, the component will not receive focus. */\n disableFocus?: boolean;\n /* Value for the controlled version. */\n highlightedItem?: string;\n /* Value for the controlled version. */\n selected?: string;\n /* Callback for change event. Returns current selection.*/\n onChange?: (\n event: SyntheticEvent,\n data: { value: string | undefined },\n ) => void;\n /* Callback for select event. Returns new selected item.*/\n onSelect?: (event: SyntheticEvent, data: { value: string }) => void;\n /* Initial selection. */\n defaultSelected?: string;\n}\n\nexport const ListNext = forwardRef<HTMLUListElement, ListNextProps>(\n function ListNext(\n {\n children,\n className,\n disabled,\n disableFocus,\n id,\n onSelect,\n onFocus,\n onBlur,\n onKeyDown,\n onMouseOver,\n highlightedItem,\n selected,\n defaultSelected,\n onChange,\n ...rest\n },\n ref,\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-list-next\",\n css: listNextCss,\n window: targetWindow,\n });\n\n const listId = useId(id);\n const listRef = useRef<HTMLUListElement>(null);\n const handleRef = useForkRef(listRef, ref);\n const {\n focusHandler,\n keyDownHandler,\n blurHandler,\n mouseOverHandler,\n activeDescendant,\n contextValue,\n focusVisibleRef,\n } = useList({\n disabled,\n highlightedItem,\n selected,\n defaultSelected,\n onChange,\n onSelect,\n id: listId,\n ref: listRef,\n });\n\n const setListRef = useForkRef(focusVisibleRef, handleRef);\n\n const handleFocus = (event: FocusEvent<HTMLUListElement>) => {\n focusHandler(event);\n onFocus?.(event);\n };\n\n const handleKeyDown = (event: KeyboardEvent<HTMLUListElement>) => {\n if (disableFocus) {\n event.preventDefault();\n return;\n }\n keyDownHandler(event);\n onKeyDown?.(event);\n };\n\n const handleBlur = (event: FocusEvent<HTMLUListElement>) => {\n blurHandler();\n onBlur?.(event);\n };\n\n const handleMouseOver = (event: MouseEvent<HTMLUListElement>) => {\n mouseOverHandler();\n onMouseOver?.(event);\n };\n\n return (\n <ListNextContext.Provider value={contextValue}>\n <ul\n // TODO: fix type from useIsFocusVisible\n // @ts-ignore\n ref={setListRef}\n id={listId}\n className={clsx(withBaseName(), className)}\n role=\"listbox\"\n tabIndex={disabled || disableFocus ? -1 : 0}\n aria-activedescendant={disabled ? undefined : activeDescendant}\n aria-disabled={disabled}\n onFocus={handleFocus}\n onKeyDown={handleKeyDown}\n onBlur={handleBlur}\n onMouseOver={handleMouseOver}\n {...rest}\n >\n {children}\n </ul>\n </ListNextContext.Provider>\n );\n },\n);\n"],"names":["ListNext","listNextCss"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"ListNextContext.js","sources":["../src/list-next/ListNextContext.tsx"],"sourcesContent":["import { createContext } from \"@salt-ds/core\";\nimport { SyntheticEvent, useContext } from \"react\";\n\nexport interface ListNextContextValue {\n disabled?: boolean;\n id?: string;\n select: (event: SyntheticEvent<HTMLLIElement>) => void;\n isSelected: (value: string) => boolean;\n isFocused: (value: string) => boolean;\n highlight: (event: SyntheticEvent<HTMLLIElement>) => void;\n isHighlighted: (value: string) => boolean;\n}\n\nexport const ListNextContext = createContext<ListNextContextValue | undefined>(\n \"ListNextContext\",\n undefined\n);\n\nexport function useListItem() {\n return useContext(ListNextContext);\n}\n"],"names":[],"mappings":";;;AAaO,MAAM,eAAkB,GAAA,aAAA;AAAA,EAC7B,iBAAA;AAAA,EACA,KAAA,CAAA;AACF,EAAA;AAEO,SAAS,WAAc,GAAA;AAC5B,EAAA,OAAO,WAAW,eAAe,CAAA,CAAA;AACnC;;;;"}
1
+ {"version":3,"file":"ListNextContext.js","sources":["../src/list-next/ListNextContext.tsx"],"sourcesContent":["import { createContext } from \"@salt-ds/core\";\nimport { type SyntheticEvent, useContext } from \"react\";\n\nexport interface ListNextContextValue {\n disabled?: boolean;\n id?: string;\n select: (event: SyntheticEvent<HTMLLIElement>) => void;\n isSelected: (value: string) => boolean;\n isFocused: (value: string) => boolean;\n highlight: (event: SyntheticEvent<HTMLLIElement>) => void;\n isHighlighted: (value: string) => boolean;\n}\n\nexport const ListNextContext = createContext<ListNextContextValue | undefined>(\n \"ListNextContext\",\n undefined,\n);\n\nexport function useListItem() {\n return useContext(ListNextContext);\n}\n"],"names":[],"mappings":";;;AAaO,MAAM,eAAkB,GAAA,aAAA;AAAA,EAC7B,iBAAA;AAAA,EACA,KAAA,CAAA;AACF,EAAA;AAEO,SAAS,WAAc,GAAA;AAC5B,EAAA,OAAO,WAAW,eAAe,CAAA,CAAA;AACnC;;;;"}
@@ -1,5 +1,5 @@
1
- import { useCallback, useState, useEffect, useMemo } from 'react';
2
1
  import { useControlled, useIsFocusVisible } from '@salt-ds/core';
2
+ import { useCallback, useState, useEffect, useMemo } from 'react';
3
3
 
4
4
  const useList = ({
5
5
  disabled = false,
@@ -61,7 +61,7 @@ const useList = ({
61
61
  setActiveDescendant(element.id);
62
62
  updateScroll(element);
63
63
  },
64
- [setHighlightedItem, updateScroll]
64
+ [updateScroll]
65
65
  );
66
66
  const selectItem = useCallback(
67
67
  (element) => {
@@ -71,7 +71,7 @@ const useList = ({
71
71
  updateHighlighted(element);
72
72
  }
73
73
  },
74
- [setSelectedItem, updateHighlighted]
74
+ [updateHighlighted]
75
75
  );
76
76
  useEffect(() => {
77
77
  var _a;
@@ -130,12 +130,9 @@ const useList = ({
130
130
  (value) => selectedItem === value,
131
131
  [selectedItem]
132
132
  );
133
- const highlight = useCallback(
134
- (event) => {
135
- setHighlightedItem(event.currentTarget.dataset.value);
136
- },
137
- [setHighlightedItem]
138
- );
133
+ const highlight = useCallback((event) => {
134
+ setHighlightedItem(event.currentTarget.dataset.value);
135
+ }, []);
139
136
  const isHighlighted = useCallback(
140
137
  (value) => highlightedItem === value,
141
138
  [highlightedItem]
@@ -1 +1 @@
1
- {"version":3,"file":"useList.js","sources":["../src/list-next/useList.ts"],"sourcesContent":["import {\n FocusEvent,\n KeyboardEvent,\n RefObject,\n SyntheticEvent,\n useCallback,\n useEffect,\n useMemo,\n useState,\n} from \"react\";\nimport { useControlled, useIsFocusVisible } from \"@salt-ds/core\";\n\nexport interface UseListProps {\n /**\n * If true, all items in list will be disabled.\n */\n disabled?: boolean;\n /* Highlighted index for when the list is controlled. */\n highlightedItem?: string;\n /* Selected value for when the list is controlled. */\n selected?: string;\n /* Initial selected value for when the list is controlled. */\n defaultSelected?: string;\n /* Callback for change event. This is called when the selected value changes */\n onChange?: (e: SyntheticEvent, data: { value: string | undefined }) => void;\n /* Callback for select event. This is called when any selection occurs, even if a previously selected value is selected again. */\n onSelect?: (e: SyntheticEvent, data: { value: string }) => void;\n /* List id. */\n id?: string;\n /* List ref. */\n ref: RefObject<HTMLUListElement>;\n}\n\nexport const useList = ({\n disabled = false,\n highlightedItem: highlightedItemProp,\n selected: selectedProp,\n defaultSelected,\n onChange,\n onSelect,\n id,\n ref,\n}: UseListProps) => {\n const getOptions: () => HTMLElement[] = useCallback(() => {\n return Array.from(\n ref.current?.querySelectorAll('[role=\"option\"]:not([aria-disabled])') ??\n []\n );\n }, [ref]);\n\n const [focusVisible, setFocusVisible] = useState(false);\n const [activeDescendant, setActiveDescendant] = useState<string | undefined>(\n undefined\n );\n\n const [highlightedItem, setHighlightedItem] = useControlled({\n controlled: highlightedItemProp,\n default: undefined,\n name: \"ListNext\",\n state: \"highlighted\",\n });\n\n const [selectedItem, setSelectedItem] = useControlled({\n controlled: selectedProp,\n default: defaultSelected,\n name: \"ListNext\",\n state: \"selected\",\n });\n\n const {\n isFocusVisibleRef,\n onFocus: handleFocusVisible,\n onBlur: handleBlurVisible,\n ref: focusVisibleRef,\n } = useIsFocusVisible();\n\n const updateScroll = useCallback(\n (currentTarget: Element) => {\n const list = ref.current;\n if (!list || !currentTarget) return;\n const { offsetTop, offsetHeight } = currentTarget as HTMLLIElement;\n const listHeight = list?.clientHeight;\n const listScrollTop = list?.scrollTop;\n if (offsetTop < listScrollTop) {\n list.scrollTop = offsetTop;\n } else if (offsetTop + offsetHeight > listScrollTop + listHeight) {\n list.scrollTop = offsetTop + offsetHeight - listHeight;\n }\n },\n [ref]\n );\n\n const updateHighlighted = useCallback(\n (element: HTMLElement) => {\n setHighlightedItem(element.dataset.value);\n setActiveDescendant(element.id);\n updateScroll(element);\n },\n [setHighlightedItem, updateScroll]\n );\n\n const selectItem = useCallback(\n (element: HTMLElement) => {\n const newValue = element?.dataset.value;\n if (newValue) {\n setSelectedItem(newValue);\n updateHighlighted(element);\n }\n },\n [setSelectedItem, updateHighlighted]\n );\n\n // Effect to move the cursor when items change controlled.\n // this could be following active descendant if there is no better way of doing it when controlled\n useEffect(() => {\n const activeOptions = getOptions();\n const highlightedIndex = activeOptions.findIndex(\n (i) => i.dataset.value === highlightedItem\n );\n if (highlightedIndex) {\n setActiveDescendant(activeOptions[highlightedIndex]?.id);\n highlightedItem && updateScroll(activeOptions[highlightedIndex]);\n }\n }, [highlightedItem, getOptions, updateScroll]);\n\n const focusFirstItem = () => {\n // Find first active item\n const activeOptions = getOptions();\n const firstItem = activeOptions[0];\n if (firstItem) {\n updateHighlighted(firstItem);\n }\n };\n const focusLastItem = () => {\n // Find last active item\n const activeOptions = getOptions();\n const lastItem = activeOptions[activeOptions.length - 1];\n if (lastItem) {\n updateHighlighted(lastItem);\n updateScroll(lastItem);\n }\n };\n\n const findNextOption = (\n currentOption: HTMLElement | null,\n moves: number\n ): HTMLElement => {\n const activeOptions = getOptions();\n // Returns next item, if no current option it will return 0\n const nextOptionIndex = currentOption\n ? activeOptions.indexOf(currentOption) + moves\n : 0;\n return (\n activeOptions[nextOptionIndex] || activeOptions[activeOptions.length - 1]\n );\n };\n\n const findPreviousOption = (\n currentOption: HTMLElement,\n moves: number\n ): HTMLElement => {\n // Return the previous option if it exists; otherwise, returns first option\n const activeOptions = getOptions();\n const currentOptionIndex = activeOptions.findIndex(\n (i) => i.id === currentOption.id\n );\n return activeOptions[currentOptionIndex - moves] || activeOptions[0];\n };\n\n // CONTEXT CALLBACKS\n const select = useCallback(\n (event: SyntheticEvent<HTMLLIElement>) => {\n const newValue = event.currentTarget.dataset.value;\n const activeOptions = getOptions();\n const isActiveOption =\n activeOptions.findIndex((i) => i.id === event.currentTarget.id) !== -1;\n if (newValue && isActiveOption) {\n onSelect?.(event, { value: newValue });\n if (selectedItem !== newValue) {\n selectItem(event.currentTarget);\n onChange?.(event, { value: selectedItem });\n }\n }\n },\n [selectItem, selectedItem, onChange, onSelect, getOptions]\n );\n\n const isSelected = useCallback(\n (value: string) => selectedItem === value,\n [selectedItem]\n );\n\n const highlight = useCallback(\n (event: SyntheticEvent<HTMLLIElement>) => {\n setHighlightedItem(event.currentTarget.dataset.value);\n },\n [setHighlightedItem]\n );\n\n const isHighlighted = useCallback(\n (value: string) => highlightedItem === value,\n [highlightedItem]\n );\n\n const isFocused = useCallback(\n (value: string) => isHighlighted(value) && focusVisible,\n [focusVisible, isHighlighted]\n );\n\n const getActiveItem = () => {\n const activeOptions = getOptions();\n const activeIndex = activeOptions.findIndex(\n (i) => i.id === activeDescendant\n );\n return activeOptions[activeIndex];\n };\n\n // HANDLERS\n const blurHandler = () => {\n handleBlurVisible();\n if (!isFocusVisibleRef.current) {\n setFocusVisible(false);\n }\n };\n\n const mouseOverHandler = () => {\n if (focusVisible) {\n setFocusVisible(false);\n }\n };\n\n // takes care of focus when using keyboard navigation\n const focusHandler = (event: FocusEvent<HTMLUListElement | HTMLElement>) => {\n handleFocusVisible(event);\n if (isFocusVisibleRef.current) {\n setFocusVisible(true);\n }\n const activeElement = getActiveItem();\n if (activeElement) {\n updateHighlighted(activeElement);\n } else {\n focusFirstItem();\n }\n };\n\n // takes care of keydown when using keyboard navigation\n const keyDownHandler = (event: KeyboardEvent<HTMLElement>) => {\n const { key } = event;\n const currentItem = getActiveItem();\n let nextItem = currentItem;\n if (isFocusVisibleRef.current || !focusVisible) {\n setFocusVisible(true);\n }\n switch (key) {\n case \"ArrowUp\":\n case \"ArrowDown\":\n if (!currentItem) {\n focusFirstItem();\n break;\n }\n nextItem =\n key === \"ArrowUp\"\n ? findPreviousOption(currentItem, 1)\n : findNextOption(currentItem, 1);\n\n if (nextItem && nextItem !== currentItem) {\n event.preventDefault();\n updateHighlighted(nextItem);\n }\n break;\n case \"Home\":\n event.preventDefault();\n focusFirstItem();\n break;\n case \"End\":\n event.preventDefault();\n focusLastItem();\n break;\n case \" \":\n case \"Enter\":\n event.preventDefault();\n if (nextItem) {\n selectItem(nextItem);\n onChange?.(event, { value: nextItem.dataset.value || \"\" });\n }\n break;\n case \"PageDown\":\n case \"PageUp\":\n event.preventDefault();\n break;\n default:\n break;\n }\n };\n\n // CONTEXT\n const contextValue = useMemo(\n () => ({\n disabled,\n id,\n select,\n isSelected,\n isFocused,\n highlight,\n isHighlighted,\n }),\n [disabled, id, select, isSelected, isFocused, highlight, isHighlighted]\n );\n\n return {\n focusHandler,\n keyDownHandler,\n blurHandler,\n mouseOverHandler,\n activeDescendant,\n selectedItem,\n highlightedItem,\n setSelectedItem,\n setHighlightedItem,\n contextValue,\n focusVisibleRef,\n };\n};\n"],"names":[],"mappings":";;;AAiCO,MAAM,UAAU,CAAC;AAAA,EACtB,QAAW,GAAA,KAAA;AAAA,EACX,eAAiB,EAAA,mBAAA;AAAA,EACjB,QAAU,EAAA,YAAA;AAAA,EACV,eAAA;AAAA,EACA,QAAA;AAAA,EACA,QAAA;AAAA,EACA,EAAA;AAAA,EACA,GAAA;AACF,CAAoB,KAAA;AAClB,EAAM,MAAA,UAAA,GAAkC,YAAY,MAAM;AA3C5D,IAAA,IAAA,EAAA,EAAA,EAAA,CAAA;AA4CI,IAAA,OAAO,KAAM,CAAA,IAAA;AAAA,MAAA,CACX,eAAI,OAAJ,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAa,gBAAiB,CAAA,sCAAA,CAAA,KAA9B,YACE,EAAC;AAAA,KACL,CAAA;AAAA,GACF,EAAG,CAAC,GAAG,CAAC,CAAA,CAAA;AAER,EAAA,MAAM,CAAC,YAAA,EAAc,eAAe,CAAA,GAAI,SAAS,KAAK,CAAA,CAAA;AACtD,EAAM,MAAA,CAAC,gBAAkB,EAAA,mBAAmB,CAAI,GAAA,QAAA;AAAA,IAC9C,KAAA,CAAA;AAAA,GACF,CAAA;AAEA,EAAA,MAAM,CAAC,eAAA,EAAiB,kBAAkB,CAAA,GAAI,aAAc,CAAA;AAAA,IAC1D,UAAY,EAAA,mBAAA;AAAA,IACZ,OAAS,EAAA,KAAA,CAAA;AAAA,IACT,IAAM,EAAA,UAAA;AAAA,IACN,KAAO,EAAA,aAAA;AAAA,GACR,CAAA,CAAA;AAED,EAAA,MAAM,CAAC,YAAA,EAAc,eAAe,CAAA,GAAI,aAAc,CAAA;AAAA,IACpD,UAAY,EAAA,YAAA;AAAA,IACZ,OAAS,EAAA,eAAA;AAAA,IACT,IAAM,EAAA,UAAA;AAAA,IACN,KAAO,EAAA,UAAA;AAAA,GACR,CAAA,CAAA;AAED,EAAM,MAAA;AAAA,IACJ,iBAAA;AAAA,IACA,OAAS,EAAA,kBAAA;AAAA,IACT,MAAQ,EAAA,iBAAA;AAAA,IACR,GAAK,EAAA,eAAA;AAAA,MACH,iBAAkB,EAAA,CAAA;AAEtB,EAAA,MAAM,YAAe,GAAA,WAAA;AAAA,IACnB,CAAC,aAA2B,KAAA;AAC1B,MAAA,MAAM,OAAO,GAAI,CAAA,OAAA,CAAA;AACjB,MAAI,IAAA,CAAC,QAAQ,CAAC,aAAA;AAAe,QAAA,OAAA;AAC7B,MAAM,MAAA,EAAE,SAAW,EAAA,YAAA,EAAiB,GAAA,aAAA,CAAA;AACpC,MAAA,MAAM,aAAa,IAAM,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,IAAA,CAAA,YAAA,CAAA;AACzB,MAAA,MAAM,gBAAgB,IAAM,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,IAAA,CAAA,SAAA,CAAA;AAC5B,MAAA,IAAI,YAAY,aAAe,EAAA;AAC7B,QAAA,IAAA,CAAK,SAAY,GAAA,SAAA,CAAA;AAAA,OACR,MAAA,IAAA,SAAA,GAAY,YAAe,GAAA,aAAA,GAAgB,UAAY,EAAA;AAChE,QAAK,IAAA,CAAA,SAAA,GAAY,YAAY,YAAe,GAAA,UAAA,CAAA;AAAA,OAC9C;AAAA,KACF;AAAA,IACA,CAAC,GAAG,CAAA;AAAA,GACN,CAAA;AAEA,EAAA,MAAM,iBAAoB,GAAA,WAAA;AAAA,IACxB,CAAC,OAAyB,KAAA;AACxB,MAAmB,kBAAA,CAAA,OAAA,CAAQ,QAAQ,KAAK,CAAA,CAAA;AACxC,MAAA,mBAAA,CAAoB,QAAQ,EAAE,CAAA,CAAA;AAC9B,MAAA,YAAA,CAAa,OAAO,CAAA,CAAA;AAAA,KACtB;AAAA,IACA,CAAC,oBAAoB,YAAY,CAAA;AAAA,GACnC,CAAA;AAEA,EAAA,MAAM,UAAa,GAAA,WAAA;AAAA,IACjB,CAAC,OAAyB,KAAA;AACxB,MAAM,MAAA,QAAA,GAAW,mCAAS,OAAQ,CAAA,KAAA,CAAA;AAClC,MAAA,IAAI,QAAU,EAAA;AACZ,QAAA,eAAA,CAAgB,QAAQ,CAAA,CAAA;AACxB,QAAA,iBAAA,CAAkB,OAAO,CAAA,CAAA;AAAA,OAC3B;AAAA,KACF;AAAA,IACA,CAAC,iBAAiB,iBAAiB,CAAA;AAAA,GACrC,CAAA;AAIA,EAAA,SAAA,CAAU,MAAM;AAlHlB,IAAA,IAAA,EAAA,CAAA;AAmHI,IAAA,MAAM,gBAAgB,UAAW,EAAA,CAAA;AACjC,IAAA,MAAM,mBAAmB,aAAc,CAAA,SAAA;AAAA,MACrC,CAAC,CAAA,KAAM,CAAE,CAAA,OAAA,CAAQ,KAAU,KAAA,eAAA;AAAA,KAC7B,CAAA;AACA,IAAA,IAAI,gBAAkB,EAAA;AACpB,MAAoB,mBAAA,CAAA,CAAA,EAAA,GAAA,aAAA,CAAc,gBAAd,CAAA,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAiC,EAAE,CAAA,CAAA;AACvD,MAAmB,eAAA,IAAA,YAAA,CAAa,cAAc,gBAAiB,CAAA,CAAA,CAAA;AAAA,KACjE;AAAA,GACC,EAAA,CAAC,eAAiB,EAAA,UAAA,EAAY,YAAY,CAAC,CAAA,CAAA;AAE9C,EAAA,MAAM,iBAAiB,MAAM;AAE3B,IAAA,MAAM,gBAAgB,UAAW,EAAA,CAAA;AACjC,IAAA,MAAM,YAAY,aAAc,CAAA,CAAA,CAAA,CAAA;AAChC,IAAA,IAAI,SAAW,EAAA;AACb,MAAA,iBAAA,CAAkB,SAAS,CAAA,CAAA;AAAA,KAC7B;AAAA,GACF,CAAA;AACA,EAAA,MAAM,gBAAgB,MAAM;AAE1B,IAAA,MAAM,gBAAgB,UAAW,EAAA,CAAA;AACjC,IAAM,MAAA,QAAA,GAAW,aAAc,CAAA,aAAA,CAAc,MAAS,GAAA,CAAA,CAAA,CAAA;AACtD,IAAA,IAAI,QAAU,EAAA;AACZ,MAAA,iBAAA,CAAkB,QAAQ,CAAA,CAAA;AAC1B,MAAA,YAAA,CAAa,QAAQ,CAAA,CAAA;AAAA,KACvB;AAAA,GACF,CAAA;AAEA,EAAM,MAAA,cAAA,GAAiB,CACrB,aAAA,EACA,KACgB,KAAA;AAChB,IAAA,MAAM,gBAAgB,UAAW,EAAA,CAAA;AAEjC,IAAA,MAAM,kBAAkB,aACpB,GAAA,aAAA,CAAc,OAAQ,CAAA,aAAa,IAAI,KACvC,GAAA,CAAA,CAAA;AACJ,IAAA,OACE,aAAc,CAAA,eAAA,CAAA,IAAoB,aAAc,CAAA,aAAA,CAAc,MAAS,GAAA,CAAA,CAAA,CAAA;AAAA,GAE3E,CAAA;AAEA,EAAM,MAAA,kBAAA,GAAqB,CACzB,aAAA,EACA,KACgB,KAAA;AAEhB,IAAA,MAAM,gBAAgB,UAAW,EAAA,CAAA;AACjC,IAAA,MAAM,qBAAqB,aAAc,CAAA,SAAA;AAAA,MACvC,CAAC,CAAA,KAAM,CAAE,CAAA,EAAA,KAAO,aAAc,CAAA,EAAA;AAAA,KAChC,CAAA;AACA,IAAO,OAAA,aAAA,CAAc,kBAAqB,GAAA,KAAA,CAAA,IAAU,aAAc,CAAA,CAAA,CAAA,CAAA;AAAA,GACpE,CAAA;AAGA,EAAA,MAAM,MAAS,GAAA,WAAA;AAAA,IACb,CAAC,KAAyC,KAAA;AACxC,MAAM,MAAA,QAAA,GAAW,KAAM,CAAA,aAAA,CAAc,OAAQ,CAAA,KAAA,CAAA;AAC7C,MAAA,MAAM,gBAAgB,UAAW,EAAA,CAAA;AACjC,MAAM,MAAA,cAAA,GACJ,aAAc,CAAA,SAAA,CAAU,CAAC,CAAA,KAAM,EAAE,EAAO,KAAA,KAAA,CAAM,aAAc,CAAA,EAAE,CAAM,KAAA,CAAA,CAAA,CAAA;AACtE,MAAA,IAAI,YAAY,cAAgB,EAAA;AAC9B,QAAW,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAA,KAAA,EAAO,EAAE,KAAA,EAAO,QAAS,EAAA,CAAA,CAAA;AACpC,QAAA,IAAI,iBAAiB,QAAU,EAAA;AAC7B,UAAA,UAAA,CAAW,MAAM,aAAa,CAAA,CAAA;AAC9B,UAAW,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAA,KAAA,EAAO,EAAE,KAAA,EAAO,YAAa,EAAA,CAAA,CAAA;AAAA,SAC1C;AAAA,OACF;AAAA,KACF;AAAA,IACA,CAAC,UAAA,EAAY,YAAc,EAAA,QAAA,EAAU,UAAU,UAAU,CAAA;AAAA,GAC3D,CAAA;AAEA,EAAA,MAAM,UAAa,GAAA,WAAA;AAAA,IACjB,CAAC,UAAkB,YAAiB,KAAA,KAAA;AAAA,IACpC,CAAC,YAAY,CAAA;AAAA,GACf,CAAA;AAEA,EAAA,MAAM,SAAY,GAAA,WAAA;AAAA,IAChB,CAAC,KAAyC,KAAA;AACxC,MAAmB,kBAAA,CAAA,KAAA,CAAM,aAAc,CAAA,OAAA,CAAQ,KAAK,CAAA,CAAA;AAAA,KACtD;AAAA,IACA,CAAC,kBAAkB,CAAA;AAAA,GACrB,CAAA;AAEA,EAAA,MAAM,aAAgB,GAAA,WAAA;AAAA,IACpB,CAAC,UAAkB,eAAoB,KAAA,KAAA;AAAA,IACvC,CAAC,eAAe,CAAA;AAAA,GAClB,CAAA;AAEA,EAAA,MAAM,SAAY,GAAA,WAAA;AAAA,IAChB,CAAC,KAAA,KAAkB,aAAc,CAAA,KAAK,CAAK,IAAA,YAAA;AAAA,IAC3C,CAAC,cAAc,aAAa,CAAA;AAAA,GAC9B,CAAA;AAEA,EAAA,MAAM,gBAAgB,MAAM;AAC1B,IAAA,MAAM,gBAAgB,UAAW,EAAA,CAAA;AACjC,IAAA,MAAM,cAAc,aAAc,CAAA,SAAA;AAAA,MAChC,CAAC,CAAM,KAAA,CAAA,CAAE,EAAO,KAAA,gBAAA;AAAA,KAClB,CAAA;AACA,IAAA,OAAO,aAAc,CAAA,WAAA,CAAA,CAAA;AAAA,GACvB,CAAA;AAGA,EAAA,MAAM,cAAc,MAAM;AACxB,IAAkB,iBAAA,EAAA,CAAA;AAClB,IAAI,IAAA,CAAC,kBAAkB,OAAS,EAAA;AAC9B,MAAA,eAAA,CAAgB,KAAK,CAAA,CAAA;AAAA,KACvB;AAAA,GACF,CAAA;AAEA,EAAA,MAAM,mBAAmB,MAAM;AAC7B,IAAA,IAAI,YAAc,EAAA;AAChB,MAAA,eAAA,CAAgB,KAAK,CAAA,CAAA;AAAA,KACvB;AAAA,GACF,CAAA;AAGA,EAAM,MAAA,YAAA,GAAe,CAAC,KAAsD,KAAA;AAC1E,IAAA,kBAAA,CAAmB,KAAK,CAAA,CAAA;AACxB,IAAA,IAAI,kBAAkB,OAAS,EAAA;AAC7B,MAAA,eAAA,CAAgB,IAAI,CAAA,CAAA;AAAA,KACtB;AACA,IAAA,MAAM,gBAAgB,aAAc,EAAA,CAAA;AACpC,IAAA,IAAI,aAAe,EAAA;AACjB,MAAA,iBAAA,CAAkB,aAAa,CAAA,CAAA;AAAA,KAC1B,MAAA;AACL,MAAe,cAAA,EAAA,CAAA;AAAA,KACjB;AAAA,GACF,CAAA;AAGA,EAAM,MAAA,cAAA,GAAiB,CAAC,KAAsC,KAAA;AAC5D,IAAM,MAAA,EAAE,KAAQ,GAAA,KAAA,CAAA;AAChB,IAAA,MAAM,cAAc,aAAc,EAAA,CAAA;AAClC,IAAA,IAAI,QAAW,GAAA,WAAA,CAAA;AACf,IAAI,IAAA,iBAAA,CAAkB,OAAW,IAAA,CAAC,YAAc,EAAA;AAC9C,MAAA,eAAA,CAAgB,IAAI,CAAA,CAAA;AAAA,KACtB;AACA,IAAQ,QAAA,GAAA;AAAA,MACD,KAAA,SAAA,CAAA;AAAA,MACA,KAAA,WAAA;AACH,QAAA,IAAI,CAAC,WAAa,EAAA;AAChB,UAAe,cAAA,EAAA,CAAA;AACf,UAAA,MAAA;AAAA,SACF;AACA,QACE,QAAA,GAAA,GAAA,KAAQ,YACJ,kBAAmB,CAAA,WAAA,EAAa,CAAC,CACjC,GAAA,cAAA,CAAe,aAAa,CAAC,CAAA,CAAA;AAEnC,QAAI,IAAA,QAAA,IAAY,aAAa,WAAa,EAAA;AACxC,UAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,UAAA,iBAAA,CAAkB,QAAQ,CAAA,CAAA;AAAA,SAC5B;AACA,QAAA,MAAA;AAAA,MACG,KAAA,MAAA;AACH,QAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,QAAe,cAAA,EAAA,CAAA;AACf,QAAA,MAAA;AAAA,MACG,KAAA,KAAA;AACH,QAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,QAAc,aAAA,EAAA,CAAA;AACd,QAAA,MAAA;AAAA,MACG,KAAA,GAAA,CAAA;AAAA,MACA,KAAA,OAAA;AACH,QAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,QAAA,IAAI,QAAU,EAAA;AACZ,UAAA,UAAA,CAAW,QAAQ,CAAA,CAAA;AACnB,UAAA,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAW,OAAO,EAAE,KAAA,EAAO,QAAS,CAAA,OAAA,CAAQ,SAAS,EAAG,EAAA,CAAA,CAAA;AAAA,SAC1D;AACA,QAAA,MAAA;AAAA,MACG,KAAA,UAAA,CAAA;AAAA,MACA,KAAA,QAAA;AACH,QAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,QAAA,MAAA;AAEA,KAAA;AAAA,GAEN,CAAA;AAGA,EAAA,MAAM,YAAe,GAAA,OAAA;AAAA,IACnB,OAAO;AAAA,MACL,QAAA;AAAA,MACA,EAAA;AAAA,MACA,MAAA;AAAA,MACA,UAAA;AAAA,MACA,SAAA;AAAA,MACA,SAAA;AAAA,MACA,aAAA;AAAA,KACF,CAAA;AAAA,IACA,CAAC,QAAU,EAAA,EAAA,EAAI,QAAQ,UAAY,EAAA,SAAA,EAAW,WAAW,aAAa,CAAA;AAAA,GACxE,CAAA;AAEA,EAAO,OAAA;AAAA,IACL,YAAA;AAAA,IACA,cAAA;AAAA,IACA,WAAA;AAAA,IACA,gBAAA;AAAA,IACA,gBAAA;AAAA,IACA,YAAA;AAAA,IACA,eAAA;AAAA,IACA,eAAA;AAAA,IACA,kBAAA;AAAA,IACA,YAAA;AAAA,IACA,eAAA;AAAA,GACF,CAAA;AACF;;;;"}
1
+ {"version":3,"file":"useList.js","sources":["../src/list-next/useList.ts"],"sourcesContent":["import { useControlled, useIsFocusVisible } from \"@salt-ds/core\";\nimport {\n type FocusEvent,\n type KeyboardEvent,\n type RefObject,\n type SyntheticEvent,\n useCallback,\n useEffect,\n useMemo,\n useState,\n} from \"react\";\n\nexport interface UseListProps {\n /**\n * If true, all items in list will be disabled.\n */\n disabled?: boolean;\n /* Highlighted index for when the list is controlled. */\n highlightedItem?: string;\n /* Selected value for when the list is controlled. */\n selected?: string;\n /* Initial selected value for when the list is controlled. */\n defaultSelected?: string;\n /* Callback for change event. This is called when the selected value changes */\n onChange?: (e: SyntheticEvent, data: { value: string | undefined }) => void;\n /* Callback for select event. This is called when any selection occurs, even if a previously selected value is selected again. */\n onSelect?: (e: SyntheticEvent, data: { value: string }) => void;\n /* List id. */\n id?: string;\n /* List ref. */\n ref: RefObject<HTMLUListElement>;\n}\n\nexport const useList = ({\n disabled = false,\n highlightedItem: highlightedItemProp,\n selected: selectedProp,\n defaultSelected,\n onChange,\n onSelect,\n id,\n ref,\n}: UseListProps) => {\n const getOptions: () => HTMLElement[] = useCallback(() => {\n return Array.from(\n ref.current?.querySelectorAll('[role=\"option\"]:not([aria-disabled])') ??\n [],\n );\n }, [ref]);\n\n const [focusVisible, setFocusVisible] = useState(false);\n const [activeDescendant, setActiveDescendant] = useState<string | undefined>(\n undefined,\n );\n\n const [highlightedItem, setHighlightedItem] = useControlled({\n controlled: highlightedItemProp,\n default: undefined,\n name: \"ListNext\",\n state: \"highlighted\",\n });\n\n const [selectedItem, setSelectedItem] = useControlled({\n controlled: selectedProp,\n default: defaultSelected,\n name: \"ListNext\",\n state: \"selected\",\n });\n\n const {\n isFocusVisibleRef,\n onFocus: handleFocusVisible,\n onBlur: handleBlurVisible,\n ref: focusVisibleRef,\n } = useIsFocusVisible();\n\n const updateScroll = useCallback(\n (currentTarget: Element) => {\n const list = ref.current;\n if (!list || !currentTarget) return;\n const { offsetTop, offsetHeight } = currentTarget as HTMLLIElement;\n const listHeight = list?.clientHeight;\n const listScrollTop = list?.scrollTop;\n if (offsetTop < listScrollTop) {\n list.scrollTop = offsetTop;\n } else if (offsetTop + offsetHeight > listScrollTop + listHeight) {\n list.scrollTop = offsetTop + offsetHeight - listHeight;\n }\n },\n [ref],\n );\n\n const updateHighlighted = useCallback(\n (element: HTMLElement) => {\n setHighlightedItem(element.dataset.value);\n setActiveDescendant(element.id);\n updateScroll(element);\n },\n [updateScroll],\n );\n\n const selectItem = useCallback(\n (element: HTMLElement) => {\n const newValue = element?.dataset.value;\n if (newValue) {\n setSelectedItem(newValue);\n updateHighlighted(element);\n }\n },\n [updateHighlighted],\n );\n\n // Effect to move the cursor when items change controlled.\n // this could be following active descendant if there is no better way of doing it when controlled\n useEffect(() => {\n const activeOptions = getOptions();\n const highlightedIndex = activeOptions.findIndex(\n (i) => i.dataset.value === highlightedItem,\n );\n if (highlightedIndex) {\n setActiveDescendant(activeOptions[highlightedIndex]?.id);\n highlightedItem && updateScroll(activeOptions[highlightedIndex]);\n }\n }, [highlightedItem, getOptions, updateScroll]);\n\n const focusFirstItem = () => {\n // Find first active item\n const activeOptions = getOptions();\n const firstItem = activeOptions[0];\n if (firstItem) {\n updateHighlighted(firstItem);\n }\n };\n const focusLastItem = () => {\n // Find last active item\n const activeOptions = getOptions();\n const lastItem = activeOptions[activeOptions.length - 1];\n if (lastItem) {\n updateHighlighted(lastItem);\n updateScroll(lastItem);\n }\n };\n\n const findNextOption = (\n currentOption: HTMLElement | null,\n moves: number,\n ): HTMLElement => {\n const activeOptions = getOptions();\n // Returns next item, if no current option it will return 0\n const nextOptionIndex = currentOption\n ? activeOptions.indexOf(currentOption) + moves\n : 0;\n return (\n activeOptions[nextOptionIndex] || activeOptions[activeOptions.length - 1]\n );\n };\n\n const findPreviousOption = (\n currentOption: HTMLElement,\n moves: number,\n ): HTMLElement => {\n // Return the previous option if it exists; otherwise, returns first option\n const activeOptions = getOptions();\n const currentOptionIndex = activeOptions.findIndex(\n (i) => i.id === currentOption.id,\n );\n return activeOptions[currentOptionIndex - moves] || activeOptions[0];\n };\n\n // CONTEXT CALLBACKS\n const select = useCallback(\n (event: SyntheticEvent<HTMLLIElement>) => {\n const newValue = event.currentTarget.dataset.value;\n const activeOptions = getOptions();\n const isActiveOption =\n activeOptions.findIndex((i) => i.id === event.currentTarget.id) !== -1;\n if (newValue && isActiveOption) {\n onSelect?.(event, { value: newValue });\n if (selectedItem !== newValue) {\n selectItem(event.currentTarget);\n onChange?.(event, { value: selectedItem });\n }\n }\n },\n [selectItem, selectedItem, onChange, onSelect, getOptions],\n );\n\n const isSelected = useCallback(\n (value: string) => selectedItem === value,\n [selectedItem],\n );\n\n const highlight = useCallback((event: SyntheticEvent<HTMLLIElement>) => {\n setHighlightedItem(event.currentTarget.dataset.value);\n }, []);\n\n const isHighlighted = useCallback(\n (value: string) => highlightedItem === value,\n [highlightedItem],\n );\n\n const isFocused = useCallback(\n (value: string) => isHighlighted(value) && focusVisible,\n [focusVisible, isHighlighted],\n );\n\n const getActiveItem = () => {\n const activeOptions = getOptions();\n const activeIndex = activeOptions.findIndex(\n (i) => i.id === activeDescendant,\n );\n return activeOptions[activeIndex];\n };\n\n // HANDLERS\n const blurHandler = () => {\n handleBlurVisible();\n if (!isFocusVisibleRef.current) {\n setFocusVisible(false);\n }\n };\n\n const mouseOverHandler = () => {\n if (focusVisible) {\n setFocusVisible(false);\n }\n };\n\n // takes care of focus when using keyboard navigation\n const focusHandler = (event: FocusEvent<HTMLUListElement | HTMLElement>) => {\n handleFocusVisible(event);\n if (isFocusVisibleRef.current) {\n setFocusVisible(true);\n }\n const activeElement = getActiveItem();\n if (activeElement) {\n updateHighlighted(activeElement);\n } else {\n focusFirstItem();\n }\n };\n\n // takes care of keydown when using keyboard navigation\n const keyDownHandler = (event: KeyboardEvent<HTMLElement>) => {\n const { key } = event;\n const currentItem = getActiveItem();\n let nextItem = currentItem;\n if (isFocusVisibleRef.current || !focusVisible) {\n setFocusVisible(true);\n }\n switch (key) {\n case \"ArrowUp\":\n case \"ArrowDown\":\n if (!currentItem) {\n focusFirstItem();\n break;\n }\n nextItem =\n key === \"ArrowUp\"\n ? findPreviousOption(currentItem, 1)\n : findNextOption(currentItem, 1);\n\n if (nextItem && nextItem !== currentItem) {\n event.preventDefault();\n updateHighlighted(nextItem);\n }\n break;\n case \"Home\":\n event.preventDefault();\n focusFirstItem();\n break;\n case \"End\":\n event.preventDefault();\n focusLastItem();\n break;\n case \" \":\n case \"Enter\":\n event.preventDefault();\n if (nextItem) {\n selectItem(nextItem);\n onChange?.(event, { value: nextItem.dataset.value || \"\" });\n }\n break;\n case \"PageDown\":\n case \"PageUp\":\n event.preventDefault();\n break;\n default:\n break;\n }\n };\n\n // CONTEXT\n const contextValue = useMemo(\n () => ({\n disabled,\n id,\n select,\n isSelected,\n isFocused,\n highlight,\n isHighlighted,\n }),\n [disabled, id, select, isSelected, isFocused, highlight, isHighlighted],\n );\n\n return {\n focusHandler,\n keyDownHandler,\n blurHandler,\n mouseOverHandler,\n activeDescendant,\n selectedItem,\n highlightedItem,\n setSelectedItem,\n setHighlightedItem,\n contextValue,\n focusVisibleRef,\n };\n};\n"],"names":[],"mappings":"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"}
@@ -1,26 +1,28 @@
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 './Logo.css.js';
8
8
 
9
9
  const withBaseName = makePrefixer("saltLogo");
10
- const Logo = forwardRef(function Logo2(props, ref) {
11
- const { className, ...rest } = props;
12
- const targetWindow = useWindow();
13
- useComponentCssInjection({
14
- testId: "salt-logo",
15
- css: css_248z,
16
- window: targetWindow
17
- });
18
- return /* @__PURE__ */ jsx("span", {
19
- className: clsx(withBaseName(), className),
20
- ref,
21
- ...rest
22
- });
23
- });
10
+ const Logo = forwardRef(
11
+ function Logo2(props, ref) {
12
+ const { className, ...rest } = props;
13
+ const targetWindow = useWindow();
14
+ useComponentCssInjection({
15
+ testId: "salt-logo",
16
+ css: css_248z,
17
+ window: targetWindow
18
+ });
19
+ return /* @__PURE__ */ jsx("span", {
20
+ className: clsx(withBaseName(), className),
21
+ ref,
22
+ ...rest
23
+ });
24
+ }
25
+ );
24
26
 
25
27
  export { Logo };
26
28
  //# sourceMappingURL=Logo.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Logo.js","sources":["../src/logo/Logo.tsx"],"sourcesContent":["import { ComponentPropsWithoutRef, forwardRef } 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 logoCss from \"./Logo.css\";\n\nexport type LogoProps = ComponentPropsWithoutRef<\"span\">;\n\nconst withBaseName = makePrefixer(\"saltLogo\");\n\nexport const Logo = forwardRef<HTMLSpanElement, LogoProps>(function Logo(\n props,\n ref\n) {\n const { className, ...rest } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-logo\",\n css: logoCss,\n window: targetWindow,\n });\n\n return (\n <span className={clsx(withBaseName(), className)} ref={ref} {...rest} />\n );\n});\n"],"names":["Logo","logoCss"],"mappings":";;;;;;;;AAWA,MAAM,YAAA,GAAe,aAAa,UAAU,CAAA,CAAA;AAErC,MAAM,IAAO,GAAA,UAAA,CAAuC,SAASA,KAAAA,CAClE,OACA,GACA,EAAA;AACA,EAAM,MAAA,EAAE,SAAc,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AAE/B,EAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,WAAA;AAAA,IACR,GAAK,EAAAC,QAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,uBACG,GAAA,CAAA,MAAA,EAAA;AAAA,IAAK,SAAW,EAAA,IAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,IAAG,GAAA;AAAA,IAAW,GAAG,IAAA;AAAA,GAAM,CAAA,CAAA;AAE1E,CAAC;;;;"}
1
+ {"version":3,"file":"Logo.js","sources":["../src/logo/Logo.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { type ComponentPropsWithoutRef, forwardRef } from \"react\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport logoCss from \"./Logo.css\";\n\nexport type LogoProps = ComponentPropsWithoutRef<\"span\">;\n\nconst withBaseName = makePrefixer(\"saltLogo\");\n\nexport const Logo = forwardRef<HTMLSpanElement, LogoProps>(\n function Logo(props, ref) {\n const { className, ...rest } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-logo\",\n css: logoCss,\n window: targetWindow,\n });\n\n return (\n <span className={clsx(withBaseName(), className)} ref={ref} {...rest} />\n );\n },\n);\n"],"names":["Logo","logoCss"],"mappings":";;;;;;;;AAWA,MAAM,YAAA,GAAe,aAAa,UAAU,CAAA,CAAA;AAErC,MAAM,IAAO,GAAA,UAAA;AAAA,EAClB,SAASA,KAAK,CAAA,KAAA,EAAO,GAAK,EAAA;AACxB,IAAM,MAAA,EAAE,SAAc,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AAE/B,IAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,IAAyB,wBAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,WAAA;AAAA,MACR,GAAK,EAAAC,QAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAA,uBACG,GAAA,CAAA,MAAA,EAAA;AAAA,MAAK,SAAW,EAAA,IAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,MAAG,GAAA;AAAA,MAAW,GAAG,IAAA;AAAA,KAAM,CAAA,CAAA;AAAA,GAE1E;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';
6
3
  import { useComponentCssInjection } from '@salt-ds/styles';
4
+ import { useWindow } from '@salt-ds/window';
5
+ import { clsx } from 'clsx';
6
+ import { forwardRef } from 'react';
7
7
  import css_248z from './LogoImage.css.js';
8
8
 
9
9
  const withBaseName = makePrefixer("saltLogoImage");
@@ -1 +1 @@
1
- {"version":3,"file":"LogoImage.js","sources":["../src/logo/LogoImage.tsx"],"sourcesContent":["import { ComponentPropsWithoutRef, forwardRef } from \"react\";\nimport { clsx } from \"clsx\";\nimport { makePrefixer } from \"@salt-ds/core\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport logoImageCss from \"./LogoImage.css\";\n\nexport interface LogoImageProps\n extends Omit<ComponentPropsWithoutRef<\"img\">, \"alt\"> {\n alt: string;\n}\n\nconst withBaseName = makePrefixer(\"saltLogoImage\");\n\nexport const LogoImage = forwardRef<HTMLImageElement, LogoImageProps>(\n function LogoImage(props, ref) {\n const { className, alt, ...rest } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-logo-image\",\n css: logoImageCss,\n window: targetWindow,\n });\n\n return (\n <img\n {...rest}\n alt={alt}\n className={clsx(withBaseName(), className)}\n ref={ref}\n />\n );\n }\n);\n"],"names":["LogoImage","logoImageCss"],"mappings":";;;;;;;;AAYA,MAAM,YAAA,GAAe,aAAa,eAAe,CAAA,CAAA;AAE1C,MAAM,SAAY,GAAA,UAAA;AAAA,EACvB,SAASA,UAAU,CAAA,KAAA,EAAO,GAAK,EAAA;AAC7B,IAAA,MAAM,EAAE,SAAA,EAAW,GAAQ,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AAEpC,IAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,IAAyB,wBAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,iBAAA;AAAA,MACR,GAAK,EAAAC,QAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,MACE,GAAG,IAAA;AAAA,MACJ,GAAA;AAAA,MACA,SAAW,EAAA,IAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,MACzC,GAAA;AAAA,KACF,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
1
+ {"version":3,"file":"LogoImage.js","sources":["../src/logo/LogoImage.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport { type ComponentPropsWithoutRef, forwardRef } from \"react\";\nimport logoImageCss from \"./LogoImage.css\";\n\nexport interface LogoImageProps\n extends Omit<ComponentPropsWithoutRef<\"img\">, \"alt\"> {\n alt: string;\n}\n\nconst withBaseName = makePrefixer(\"saltLogoImage\");\n\nexport const LogoImage = forwardRef<HTMLImageElement, LogoImageProps>(\n function LogoImage(props, ref) {\n const { className, alt, ...rest } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-logo-image\",\n css: logoImageCss,\n window: targetWindow,\n });\n\n return (\n <img\n {...rest}\n alt={alt}\n className={clsx(withBaseName(), className)}\n ref={ref}\n />\n );\n },\n);\n"],"names":["LogoImage","logoImageCss"],"mappings":";;;;;;;;AAYA,MAAM,YAAA,GAAe,aAAa,eAAe,CAAA,CAAA;AAE1C,MAAM,SAAY,GAAA,UAAA;AAAA,EACvB,SAASA,UAAU,CAAA,KAAA,EAAO,GAAK,EAAA;AAC7B,IAAA,MAAM,EAAE,SAAA,EAAW,GAAQ,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AAEpC,IAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,IAAyB,wBAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,iBAAA;AAAA,MACR,GAAK,EAAAC,QAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,MACE,GAAG,IAAA;AAAA,MACJ,GAAA;AAAA,MACA,SAAW,EAAA,IAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,MACzC,GAAA;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 './LogoSeparator.css.js';
8
8
 
9
9
  const withBaseName = makePrefixer("saltLogoSeparator");
@@ -1 +1 @@
1
- {"version":3,"file":"LogoSeparator.js","sources":["../src/logo/LogoSeparator.tsx"],"sourcesContent":["import { ComponentPropsWithoutRef, forwardRef } 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 logoSeparatorCss from \"./LogoSeparator.css\";\n\nexport type LogoSeparatorProps = ComponentPropsWithoutRef<\"span\">;\n\nconst withBaseName = makePrefixer(\"saltLogoSeparator\");\n\nexport const LogoSeparator = forwardRef<HTMLImageElement, LogoSeparatorProps>(\n function LogoSeparator(props, ref) {\n const { className, ...rest } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-logo-separator\",\n css: logoSeparatorCss,\n window: targetWindow,\n });\n\n return (\n <span {...rest} className={clsx(withBaseName(), className)} ref={ref} />\n );\n }\n);\n"],"names":["LogoSeparator","logoSeparatorCss"],"mappings":";;;;;;;;AAWA,MAAM,YAAA,GAAe,aAAa,mBAAmB,CAAA,CAAA;AAE9C,MAAM,aAAgB,GAAA,UAAA;AAAA,EAC3B,SAASA,cAAc,CAAA,KAAA,EAAO,GAAK,EAAA;AACjC,IAAM,MAAA,EAAE,SAAc,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AAE/B,IAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,IAAyB,wBAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,qBAAA;AAAA,MACR,GAAK,EAAAC,QAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAA,uBACG,GAAA,CAAA,MAAA,EAAA;AAAA,MAAM,GAAG,IAAA;AAAA,MAAM,SAAW,EAAA,IAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,MAAG,GAAA;AAAA,KAAU,CAAA,CAAA;AAAA,GAE1E;AACF;;;;"}
1
+ {"version":3,"file":"LogoSeparator.js","sources":["../src/logo/LogoSeparator.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { type ComponentPropsWithoutRef, forwardRef } from \"react\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport logoSeparatorCss from \"./LogoSeparator.css\";\n\nexport type LogoSeparatorProps = ComponentPropsWithoutRef<\"span\">;\n\nconst withBaseName = makePrefixer(\"saltLogoSeparator\");\n\nexport const LogoSeparator = forwardRef<HTMLImageElement, LogoSeparatorProps>(\n function LogoSeparator(props, ref) {\n const { className, ...rest } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-logo-separator\",\n css: logoSeparatorCss,\n window: targetWindow,\n });\n\n return (\n <span {...rest} className={clsx(withBaseName(), className)} ref={ref} />\n );\n },\n);\n"],"names":["LogoSeparator","logoSeparatorCss"],"mappings":";;;;;;;;AAWA,MAAM,YAAA,GAAe,aAAa,mBAAmB,CAAA,CAAA;AAE9C,MAAM,aAAgB,GAAA,UAAA;AAAA,EAC3B,SAASA,cAAc,CAAA,KAAA,EAAO,GAAK,EAAA;AACjC,IAAM,MAAA,EAAE,SAAc,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AAE/B,IAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,IAAyB,wBAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,qBAAA;AAAA,MACR,GAAK,EAAAC,QAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAA,uBACG,GAAA,CAAA,MAAA,EAAA;AAAA,MAAM,GAAG,IAAA;AAAA,MAAM,SAAW,EAAA,IAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,MAAG,GAAA;AAAA,KAAU,CAAA,CAAA;AAAA,GAE1E;AACF;;;;"}