@salt-ds/lab 1.0.0-alpha.0 → 1.0.0-alpha.2

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 (785) hide show
  1. package/dist-cjs/packages/lab/src/accordion/Accordion.js +2 -6
  2. package/dist-cjs/packages/lab/src/accordion/Accordion.js.map +1 -1
  3. package/dist-cjs/packages/lab/src/accordion/AccordionDetails.js +3 -7
  4. package/dist-cjs/packages/lab/src/accordion/AccordionDetails.js.map +1 -1
  5. package/dist-cjs/packages/lab/src/accordion/AccordionSection.js +3 -6
  6. package/dist-cjs/packages/lab/src/accordion/AccordionSection.js.map +1 -1
  7. package/dist-cjs/packages/lab/src/accordion/AccordionSummary.js +2 -6
  8. package/dist-cjs/packages/lab/src/accordion/AccordionSummary.js.map +1 -1
  9. package/dist-cjs/packages/lab/src/app-header/AppHeader.js +3 -6
  10. package/dist-cjs/packages/lab/src/app-header/AppHeader.js.map +1 -1
  11. package/dist-cjs/packages/lab/src/avatar/Avatar.js +2 -6
  12. package/dist-cjs/packages/lab/src/avatar/Avatar.js.map +1 -1
  13. package/dist-cjs/packages/lab/src/badge/Badge.js +4 -8
  14. package/dist-cjs/packages/lab/src/badge/Badge.js.map +1 -1
  15. package/dist-cjs/packages/lab/src/banner/Banner.js +5 -9
  16. package/dist-cjs/packages/lab/src/banner/Banner.js.map +1 -1
  17. package/dist-cjs/packages/lab/src/breadcrumbs/Breadcrumb.js +4 -8
  18. package/dist-cjs/packages/lab/src/breadcrumbs/Breadcrumb.js.map +1 -1
  19. package/dist-cjs/packages/lab/src/breadcrumbs/Breadcrumbs.js +3 -4
  20. package/dist-cjs/packages/lab/src/breadcrumbs/Breadcrumbs.js.map +1 -1
  21. package/dist-cjs/packages/lab/src/button-bar/ButtonBar.js +2 -6
  22. package/dist-cjs/packages/lab/src/button-bar/ButtonBar.js.map +1 -1
  23. package/dist-cjs/packages/lab/src/button-bar/OrderedButton.js +3 -6
  24. package/dist-cjs/packages/lab/src/button-bar/OrderedButton.js.map +1 -1
  25. package/dist-cjs/packages/lab/src/calendar/Calendar.js +2 -6
  26. package/dist-cjs/packages/lab/src/calendar/Calendar.js.map +1 -1
  27. package/dist-cjs/packages/lab/src/calendar/internal/CalendarDay.js +34 -54
  28. package/dist-cjs/packages/lab/src/calendar/internal/CalendarDay.js.map +1 -1
  29. package/dist-cjs/packages/lab/src/calendar/internal/CalendarMonth.js +2 -6
  30. package/dist-cjs/packages/lab/src/calendar/internal/CalendarMonth.js.map +1 -1
  31. package/dist-cjs/packages/lab/src/calendar/internal/CalendarNavigation.js +38 -72
  32. package/dist-cjs/packages/lab/src/calendar/internal/CalendarNavigation.js.map +1 -1
  33. package/dist-cjs/packages/lab/src/calendar/internal/CalendarWeekHeader.js +2 -6
  34. package/dist-cjs/packages/lab/src/calendar/internal/CalendarWeekHeader.js.map +1 -1
  35. package/dist-cjs/packages/lab/src/calendar/useSelection.js +3 -6
  36. package/dist-cjs/packages/lab/src/calendar/useSelection.js.map +1 -1
  37. package/dist-cjs/packages/lab/src/carousel/Carousel.js +3 -6
  38. package/dist-cjs/packages/lab/src/carousel/Carousel.js.map +1 -1
  39. package/dist-cjs/packages/lab/src/carousel/CarouselSlide.js +4 -8
  40. package/dist-cjs/packages/lab/src/carousel/CarouselSlide.js.map +1 -1
  41. package/dist-cjs/packages/lab/src/cascading-menu/CascadingMenu.js +2 -1
  42. package/dist-cjs/packages/lab/src/cascading-menu/CascadingMenu.js.map +1 -1
  43. package/dist-cjs/packages/lab/src/cascading-menu/CascadingMenuItem.js +48 -69
  44. package/dist-cjs/packages/lab/src/cascading-menu/CascadingMenuItem.js.map +1 -1
  45. package/dist-cjs/packages/lab/src/cascading-menu/CascadingMenuList.js +5 -9
  46. package/dist-cjs/packages/lab/src/cascading-menu/CascadingMenuList.js.map +1 -1
  47. package/dist-cjs/packages/lab/src/cascading-menu/internal/useClickAway.js +1 -0
  48. package/dist-cjs/packages/lab/src/cascading-menu/internal/useClickAway.js.map +1 -1
  49. package/dist-cjs/packages/lab/src/cascading-menu/internal/useMenuTriggerHandlers.js +1 -0
  50. package/dist-cjs/packages/lab/src/cascading-menu/internal/useMenuTriggerHandlers.js.map +1 -1
  51. package/dist-cjs/packages/lab/src/checkbox/Checkbox.js +2 -6
  52. package/dist-cjs/packages/lab/src/checkbox/Checkbox.js.map +1 -1
  53. package/dist-cjs/packages/lab/src/checkbox/CheckboxBase.js +2 -6
  54. package/dist-cjs/packages/lab/src/checkbox/CheckboxBase.js.map +1 -1
  55. package/dist-cjs/packages/lab/src/checkbox/CheckboxGroup.js +2 -6
  56. package/dist-cjs/packages/lab/src/checkbox/CheckboxGroup.js.map +1 -1
  57. package/dist-cjs/packages/lab/src/checkbox/CheckboxIcon.js +4 -8
  58. package/dist-cjs/packages/lab/src/checkbox/CheckboxIcon.js.map +1 -1
  59. package/dist-cjs/packages/lab/src/color-chooser/AlphaInputField.js +2 -6
  60. package/dist-cjs/packages/lab/src/color-chooser/AlphaInputField.js.map +1 -1
  61. package/dist-cjs/packages/lab/src/color-chooser/ColorChooser.js +7 -11
  62. package/dist-cjs/packages/lab/src/color-chooser/ColorChooser.js.map +1 -1
  63. package/dist-cjs/packages/lab/src/color-chooser/ColorPicker.js +7 -11
  64. package/dist-cjs/packages/lab/src/color-chooser/ColorPicker.js.map +1 -1
  65. package/dist-cjs/packages/lab/src/color-chooser/DictTabs.js +3 -7
  66. package/dist-cjs/packages/lab/src/color-chooser/DictTabs.js.map +1 -1
  67. package/dist-cjs/packages/lab/src/color-chooser/HexInput.js +4 -8
  68. package/dist-cjs/packages/lab/src/color-chooser/HexInput.js.map +1 -1
  69. package/dist-cjs/packages/lab/src/color-chooser/RGBAInput.js +5 -9
  70. package/dist-cjs/packages/lab/src/color-chooser/RGBAInput.js.map +1 -1
  71. package/dist-cjs/packages/lab/src/color-chooser/Swatch.js +2 -6
  72. package/dist-cjs/packages/lab/src/color-chooser/Swatch.js.map +1 -1
  73. package/dist-cjs/packages/lab/src/color-chooser/Swatches.js +6 -10
  74. package/dist-cjs/packages/lab/src/color-chooser/Swatches.js.map +1 -1
  75. package/dist-cjs/packages/lab/src/combo-box/ComboBox.js +1 -0
  76. package/dist-cjs/packages/lab/src/combo-box/ComboBox.js.map +1 -1
  77. package/dist-cjs/packages/lab/src/combo-box/useCombobox.js +1 -0
  78. package/dist-cjs/packages/lab/src/combo-box/useCombobox.js.map +1 -1
  79. package/dist-cjs/packages/lab/src/combo-box-deprecated/ComboBoxDeprecated.js +3 -7
  80. package/dist-cjs/packages/lab/src/combo-box-deprecated/ComboBoxDeprecated.js.map +1 -1
  81. package/dist-cjs/packages/lab/src/combo-box-deprecated/filterHelpers.js +1 -0
  82. package/dist-cjs/packages/lab/src/combo-box-deprecated/filterHelpers.js.map +1 -1
  83. package/dist-cjs/packages/lab/src/combo-box-deprecated/internal/DefaultComboBox.js +21 -39
  84. package/dist-cjs/packages/lab/src/combo-box-deprecated/internal/DefaultComboBox.js.map +1 -1
  85. package/dist-cjs/packages/lab/src/combo-box-deprecated/internal/MultiSelectComboBox.js +28 -49
  86. package/dist-cjs/packages/lab/src/combo-box-deprecated/internal/MultiSelectComboBox.js.map +1 -1
  87. package/dist-cjs/packages/lab/src/combo-box-deprecated/internal/useComboBox.js +1 -0
  88. package/dist-cjs/packages/lab/src/combo-box-deprecated/internal/useComboBox.js.map +1 -1
  89. package/dist-cjs/packages/lab/src/combo-box-deprecated/internal/useMultiSelectComboBox.js +1 -0
  90. package/dist-cjs/packages/lab/src/combo-box-deprecated/internal/useMultiSelectComboBox.js.map +1 -1
  91. package/dist-cjs/packages/lab/src/common-hooks/useAutoSizer.js +3 -2
  92. package/dist-cjs/packages/lab/src/common-hooks/useAutoSizer.js.map +1 -1
  93. package/dist-cjs/packages/lab/src/common-hooks/useViewportTracking.js +3 -2
  94. package/dist-cjs/packages/lab/src/common-hooks/useViewportTracking.js.map +1 -1
  95. package/dist-cjs/packages/lab/src/common-hooks/utils/filter-utils.js +1 -0
  96. package/dist-cjs/packages/lab/src/common-hooks/utils/filter-utils.js.map +1 -1
  97. package/dist-cjs/packages/lab/src/contact-details/ContactAction.js +8 -23
  98. package/dist-cjs/packages/lab/src/contact-details/ContactAction.js.map +1 -1
  99. package/dist-cjs/packages/lab/src/contact-details/ContactAvatar.js +2 -6
  100. package/dist-cjs/packages/lab/src/contact-details/ContactAvatar.js.map +1 -1
  101. package/dist-cjs/packages/lab/src/contact-details/ContactDetails.js +2 -6
  102. package/dist-cjs/packages/lab/src/contact-details/ContactDetails.js.map +1 -1
  103. package/dist-cjs/packages/lab/src/contact-details/ContactFavoriteToggle.js.map +1 -1
  104. package/dist-cjs/packages/lab/src/contact-details/ContactMetadata.js +2 -6
  105. package/dist-cjs/packages/lab/src/contact-details/ContactMetadata.js.map +1 -1
  106. package/dist-cjs/packages/lab/src/contact-details/ContactPrimaryInfo.js +2 -6
  107. package/dist-cjs/packages/lab/src/contact-details/ContactPrimaryInfo.js.map +1 -1
  108. package/dist-cjs/packages/lab/src/contact-details/ContactSecondaryInfo.js +2 -6
  109. package/dist-cjs/packages/lab/src/contact-details/ContactSecondaryInfo.js.map +1 -1
  110. package/dist-cjs/packages/lab/src/contact-details/ContactTertiaryInfo.js +2 -6
  111. package/dist-cjs/packages/lab/src/contact-details/ContactTertiaryInfo.js.map +1 -1
  112. package/dist-cjs/packages/lab/src/contact-details/MailLinkComponent.js +1 -0
  113. package/dist-cjs/packages/lab/src/contact-details/MailLinkComponent.js.map +1 -1
  114. package/dist-cjs/packages/lab/src/contact-details/internal/FavoriteToggleWithTooltip.js +8 -19
  115. package/dist-cjs/packages/lab/src/contact-details/internal/FavoriteToggleWithTooltip.js.map +1 -1
  116. package/dist-cjs/packages/lab/src/contact-details/internal/StarIconContainer.js +3 -7
  117. package/dist-cjs/packages/lab/src/contact-details/internal/StarIconContainer.js.map +1 -1
  118. package/dist-cjs/packages/lab/src/content-status/ContentStatus.js +6 -10
  119. package/dist-cjs/packages/lab/src/content-status/ContentStatus.js.map +1 -1
  120. package/dist-cjs/packages/lab/src/content-status/internal/StatusIndicator.js +4 -9
  121. package/dist-cjs/packages/lab/src/content-status/internal/StatusIndicator.js.map +1 -1
  122. package/dist-cjs/packages/lab/src/control-label/ControlLabel.js +2 -6
  123. package/dist-cjs/packages/lab/src/control-label/ControlLabel.js.map +1 -1
  124. package/dist-cjs/packages/lab/src/deck-item/DeckItem.js +2 -6
  125. package/dist-cjs/packages/lab/src/deck-item/DeckItem.js.map +1 -1
  126. package/dist-cjs/packages/lab/src/deck-layout/DeckLayout.js +4 -7
  127. package/dist-cjs/packages/lab/src/deck-layout/DeckLayout.js.map +1 -1
  128. package/dist-cjs/packages/lab/src/dialog/Dialog.js +2 -6
  129. package/dist-cjs/packages/lab/src/dialog/Dialog.js.map +1 -1
  130. package/dist-cjs/packages/lab/src/dialog/DialogActions.js +2 -6
  131. package/dist-cjs/packages/lab/src/dialog/DialogActions.js.map +1 -1
  132. package/dist-cjs/packages/lab/src/dialog/DialogContent.js +2 -6
  133. package/dist-cjs/packages/lab/src/dialog/DialogContent.js.map +1 -1
  134. package/dist-cjs/packages/lab/src/dialog/DialogTitle.js +2 -6
  135. package/dist-cjs/packages/lab/src/dialog/DialogTitle.js.map +1 -1
  136. package/dist-cjs/packages/lab/src/dropdown/Dropdown.js +1 -0
  137. package/dist-cjs/packages/lab/src/dropdown/Dropdown.js.map +1 -1
  138. package/dist-cjs/packages/lab/src/dropdown/DropdownBase.js +10 -14
  139. package/dist-cjs/packages/lab/src/dropdown/DropdownBase.js.map +1 -1
  140. package/dist-cjs/packages/lab/src/dropdown/DropdownButton.js +2 -6
  141. package/dist-cjs/packages/lab/src/dropdown/DropdownButton.js.map +1 -1
  142. package/dist-cjs/packages/lab/src/dropdown/useDropdown.js +1 -0
  143. package/dist-cjs/packages/lab/src/dropdown/useDropdown.js.map +1 -1
  144. package/dist-cjs/packages/lab/src/dropdown/useDropdownBase.js +1 -0
  145. package/dist-cjs/packages/lab/src/dropdown/useDropdownBase.js.map +1 -1
  146. package/dist-cjs/packages/lab/src/editable-label/EditableLabel.js +2 -6
  147. package/dist-cjs/packages/lab/src/editable-label/EditableLabel.js.map +1 -1
  148. package/dist-cjs/packages/lab/src/file-drop-zone/FileDropZone.js +2 -6
  149. package/dist-cjs/packages/lab/src/file-drop-zone/FileDropZone.js.map +1 -1
  150. package/dist-cjs/packages/lab/src/form-field/FormField.js +61 -78
  151. package/dist-cjs/packages/lab/src/form-field/FormField.js.map +1 -1
  152. package/dist-cjs/packages/lab/src/form-field/FormLabel.js +2 -6
  153. package/dist-cjs/packages/lab/src/form-field/FormLabel.js.map +1 -1
  154. package/dist-cjs/packages/lab/src/form-field/StatusIndicator.js +18 -35
  155. package/dist-cjs/packages/lab/src/form-field/StatusIndicator.js.map +1 -1
  156. package/dist-cjs/packages/lab/src/form-group/FormGroup.js +2 -6
  157. package/dist-cjs/packages/lab/src/form-group/FormGroup.js.map +1 -1
  158. package/dist-cjs/packages/lab/src/formatted-input/FormattedInput.js +2 -6
  159. package/dist-cjs/packages/lab/src/formatted-input/FormattedInput.js.map +1 -1
  160. package/dist-cjs/packages/lab/src/formatted-input/internal/InputWithMask.js +2 -6
  161. package/dist-cjs/packages/lab/src/formatted-input/internal/InputWithMask.js.map +1 -1
  162. package/dist-cjs/packages/lab/src/index.js +3 -19
  163. package/dist-cjs/packages/lab/src/index.js.map +1 -1
  164. package/dist-cjs/packages/lab/src/input/Input.js +4 -8
  165. package/dist-cjs/packages/lab/src/input/Input.js.map +1 -1
  166. package/dist-cjs/packages/lab/src/input/StaticInputAdornment.js +2 -6
  167. package/dist-cjs/packages/lab/src/input/StaticInputAdornment.js.map +1 -1
  168. package/dist-cjs/packages/lab/src/layer-layout/LayerLayout.js +6 -9
  169. package/dist-cjs/packages/lab/src/layer-layout/LayerLayout.js.map +1 -1
  170. package/dist-cjs/packages/lab/src/list/Highlighter.js +1 -0
  171. package/dist-cjs/packages/lab/src/list/Highlighter.js.map +1 -1
  172. package/dist-cjs/packages/lab/src/list/List.js +5 -8
  173. package/dist-cjs/packages/lab/src/list/List.js.map +1 -1
  174. package/dist-cjs/packages/lab/src/list/ListItem.js +3 -7
  175. package/dist-cjs/packages/lab/src/list/ListItem.js.map +1 -1
  176. package/dist-cjs/packages/lab/src/list/VirtualizedList.js +4 -7
  177. package/dist-cjs/packages/lab/src/list/VirtualizedList.js.map +1 -1
  178. package/dist-cjs/packages/lab/src/list/useList.js +2 -1
  179. package/dist-cjs/packages/lab/src/list/useList.js.map +1 -1
  180. package/dist-cjs/packages/lab/src/list/useListHeight.js +1 -0
  181. package/dist-cjs/packages/lab/src/list/useListHeight.js.map +1 -1
  182. package/dist-cjs/packages/lab/src/list/useVirtualization.js +2 -1
  183. package/dist-cjs/packages/lab/src/list/useVirtualization.js.map +1 -1
  184. package/dist-cjs/packages/lab/src/list-deprecated/List.js +5 -26
  185. package/dist-cjs/packages/lab/src/list-deprecated/List.js.map +1 -1
  186. package/dist-cjs/packages/lab/src/list-deprecated/ListBase.js +3 -7
  187. package/dist-cjs/packages/lab/src/list-deprecated/ListBase.js.map +1 -1
  188. package/dist-cjs/packages/lab/src/list-deprecated/ListItemBase.js +29 -63
  189. package/dist-cjs/packages/lab/src/list-deprecated/ListItemBase.js.map +1 -1
  190. package/dist-cjs/packages/lab/src/list-deprecated/internal/Highlighter.js +1 -0
  191. package/dist-cjs/packages/lab/src/list-deprecated/internal/Highlighter.js.map +1 -1
  192. package/dist-cjs/packages/lab/src/list-deprecated/useTypeSelect.js +1 -0
  193. package/dist-cjs/packages/lab/src/list-deprecated/useTypeSelect.js.map +1 -1
  194. package/dist-cjs/packages/lab/src/logo/Logo.js +5 -9
  195. package/dist-cjs/packages/lab/src/logo/Logo.js.map +1 -1
  196. package/dist-cjs/packages/lab/src/menu-button/MenuButtonTrigger.js +2 -6
  197. package/dist-cjs/packages/lab/src/menu-button/MenuButtonTrigger.js.map +1 -1
  198. package/dist-cjs/packages/lab/src/metric/Metric.js +2 -6
  199. package/dist-cjs/packages/lab/src/metric/Metric.js.map +1 -1
  200. package/dist-cjs/packages/lab/src/metric/MetricContent.js +2 -6
  201. package/dist-cjs/packages/lab/src/metric/MetricContent.js.map +1 -1
  202. package/dist-cjs/packages/lab/src/metric/MetricHeader.js +2 -6
  203. package/dist-cjs/packages/lab/src/metric/MetricHeader.js.map +1 -1
  204. package/dist-cjs/packages/lab/src/overlay/Overlay.js +4 -8
  205. package/dist-cjs/packages/lab/src/overlay/Overlay.js.map +1 -1
  206. package/dist-cjs/packages/lab/src/overlay/useOverlay.js +11 -12
  207. package/dist-cjs/packages/lab/src/overlay/useOverlay.js.map +1 -1
  208. package/dist-cjs/packages/lab/src/pagination/ArrowButton.js +2 -6
  209. package/dist-cjs/packages/lab/src/pagination/ArrowButton.js.map +1 -1
  210. package/dist-cjs/packages/lab/src/pagination/CompactInput.js +3 -7
  211. package/dist-cjs/packages/lab/src/pagination/CompactInput.js.map +1 -1
  212. package/dist-cjs/packages/lab/src/pagination/GoToInput.js +3 -7
  213. package/dist-cjs/packages/lab/src/pagination/GoToInput.js.map +1 -1
  214. package/dist-cjs/packages/lab/src/pagination/PageButton.js +2 -6
  215. package/dist-cjs/packages/lab/src/pagination/PageButton.js.map +1 -1
  216. package/dist-cjs/packages/lab/src/pagination/Pagination.js +2 -6
  217. package/dist-cjs/packages/lab/src/pagination/Pagination.js.map +1 -1
  218. package/dist-cjs/packages/lab/src/pagination/Paginator.js +2 -6
  219. package/dist-cjs/packages/lab/src/pagination/Paginator.js.map +1 -1
  220. package/dist-cjs/packages/lab/src/parent-child-item/ParentChildItem.js +2 -6
  221. package/dist-cjs/packages/lab/src/parent-child-item/ParentChildItem.js.map +1 -1
  222. package/dist-cjs/packages/lab/src/parent-child-layout/ParentChildLayout.js +3 -6
  223. package/dist-cjs/packages/lab/src/parent-child-layout/ParentChildLayout.js.map +1 -1
  224. package/dist-cjs/packages/lab/src/pill/ClosablePill.js +2 -6
  225. package/dist-cjs/packages/lab/src/pill/ClosablePill.js.map +1 -1
  226. package/dist-cjs/packages/lab/src/pill/PillBase.js +42 -62
  227. package/dist-cjs/packages/lab/src/pill/PillBase.js.map +1 -1
  228. package/dist-cjs/packages/lab/src/pill/SelectablePill.js +2 -6
  229. package/dist-cjs/packages/lab/src/pill/SelectablePill.js.map +1 -1
  230. package/dist-cjs/packages/lab/src/pill/internal/DeleteButton.js +2 -6
  231. package/dist-cjs/packages/lab/src/pill/internal/DeleteButton.js.map +1 -1
  232. package/dist-cjs/packages/lab/src/pill/internal/DivButton.js +2 -6
  233. package/dist-cjs/packages/lab/src/pill/internal/DivButton.js.map +1 -1
  234. package/dist-cjs/packages/lab/src/progress/CircularProgress/CircularProgress.js +4 -8
  235. package/dist-cjs/packages/lab/src/progress/CircularProgress/CircularProgress.js.map +1 -1
  236. package/dist-cjs/packages/lab/src/progress/LinearProgress/LinearProgress.js +5 -9
  237. package/dist-cjs/packages/lab/src/progress/LinearProgress/LinearProgress.js.map +1 -1
  238. package/dist-cjs/packages/lab/src/query-input/QueryInput.js +2 -6
  239. package/dist-cjs/packages/lab/src/query-input/QueryInput.js.map +1 -1
  240. package/dist-cjs/packages/lab/src/query-input/internal/CategoryList.js +1 -0
  241. package/dist-cjs/packages/lab/src/query-input/internal/CategoryList.js.map +1 -1
  242. package/dist-cjs/packages/lab/src/query-input/internal/CategoryListItem.js +1 -0
  243. package/dist-cjs/packages/lab/src/query-input/internal/CategoryListItem.js.map +1 -1
  244. package/dist-cjs/packages/lab/src/query-input/internal/QueryInputBody.js +1 -0
  245. package/dist-cjs/packages/lab/src/query-input/internal/QueryInputBody.js.map +1 -1
  246. package/dist-cjs/packages/lab/src/query-input/internal/SearchList.js +1 -0
  247. package/dist-cjs/packages/lab/src/query-input/internal/SearchList.js.map +1 -1
  248. package/dist-cjs/packages/lab/src/query-input/internal/ValueList.js +1 -0
  249. package/dist-cjs/packages/lab/src/query-input/internal/ValueList.js.map +1 -1
  250. package/dist-cjs/packages/lab/src/query-input/internal/ValueSelector.js +2 -3
  251. package/dist-cjs/packages/lab/src/query-input/internal/ValueSelector.js.map +1 -1
  252. package/dist-cjs/packages/lab/src/query-input/useQueryInput.js +1 -0
  253. package/dist-cjs/packages/lab/src/query-input/useQueryInput.js.map +1 -1
  254. package/dist-cjs/packages/lab/src/radio-button/RadioButton.js +3 -7
  255. package/dist-cjs/packages/lab/src/radio-button/RadioButton.js.map +1 -1
  256. package/dist-cjs/packages/lab/src/radio-button/RadioButtonBase.js +2 -6
  257. package/dist-cjs/packages/lab/src/radio-button/RadioButtonBase.js.map +1 -1
  258. package/dist-cjs/packages/lab/src/radio-button/RadioButtonGroup.js +3 -7
  259. package/dist-cjs/packages/lab/src/radio-button/RadioButtonGroup.js.map +1 -1
  260. package/dist-cjs/packages/lab/src/radio-button/RadioButtonIcon.js +2 -6
  261. package/dist-cjs/packages/lab/src/radio-button/RadioButtonIcon.js.map +1 -1
  262. package/dist-cjs/packages/lab/src/responsive/useOverflow.js +1 -0
  263. package/dist-cjs/packages/lab/src/responsive/useOverflow.js.map +1 -1
  264. package/dist-cjs/packages/lab/src/responsive/useResizeObserver.js +6 -3
  265. package/dist-cjs/packages/lab/src/responsive/useResizeObserver.js.map +1 -1
  266. package/dist-cjs/packages/lab/src/scrim/Scrim.js +2 -3
  267. package/dist-cjs/packages/lab/src/scrim/Scrim.js.map +1 -1
  268. package/dist-cjs/packages/lab/src/search-input/SearchInput.js +3 -7
  269. package/dist-cjs/packages/lab/src/search-input/SearchInput.js.map +1 -1
  270. package/dist-cjs/packages/lab/src/skip-link/SkipLink.js +3 -7
  271. package/dist-cjs/packages/lab/src/skip-link/SkipLink.js.map +1 -1
  272. package/dist-cjs/packages/lab/src/skip-link/SkipLinks.js +2 -6
  273. package/dist-cjs/packages/lab/src/skip-link/SkipLinks.js.map +1 -1
  274. package/dist-cjs/packages/lab/src/slider/Slider.js +2 -6
  275. package/dist-cjs/packages/lab/src/slider/Slider.js.map +1 -1
  276. package/dist-cjs/packages/lab/src/slider/internal/SliderHandle.js +18 -31
  277. package/dist-cjs/packages/lab/src/slider/internal/SliderHandle.js.map +1 -1
  278. package/dist-cjs/packages/lab/src/slider/internal/SliderRailMarks.js +2 -6
  279. package/dist-cjs/packages/lab/src/slider/internal/SliderRailMarks.js.map +1 -1
  280. package/dist-cjs/packages/lab/src/stepper-input/StepperInput.js +5 -9
  281. package/dist-cjs/packages/lab/src/stepper-input/StepperInput.js.map +1 -1
  282. package/dist-cjs/packages/lab/src/switch/Switch.js +4 -8
  283. package/dist-cjs/packages/lab/src/switch/Switch.js.map +1 -1
  284. package/dist-cjs/packages/lab/src/tabs/Tab.js +2 -6
  285. package/dist-cjs/packages/lab/src/tabs/Tab.js.map +1 -1
  286. package/dist-cjs/packages/lab/src/tabs/TabPanel.js +2 -6
  287. package/dist-cjs/packages/lab/src/tabs/TabPanel.js.map +1 -1
  288. package/dist-cjs/packages/lab/src/tabs/Tabs.js +2 -6
  289. package/dist-cjs/packages/lab/src/tabs/Tabs.js.map +1 -1
  290. package/dist-cjs/packages/lab/src/tabs/Tabstrip.js +37 -48
  291. package/dist-cjs/packages/lab/src/tabs/Tabstrip.js.map +1 -1
  292. package/dist-cjs/packages/lab/src/tabs/drag-drop/Draggable.js +2 -6
  293. package/dist-cjs/packages/lab/src/tabs/drag-drop/Draggable.js.map +1 -1
  294. package/dist-cjs/packages/lab/src/tabs/useActivationIndicator.js +1 -0
  295. package/dist-cjs/packages/lab/src/tabs/useActivationIndicator.js.map +1 -1
  296. package/dist-cjs/packages/lab/src/tabs/useKeyboardNavigation.js +1 -0
  297. package/dist-cjs/packages/lab/src/tabs/useKeyboardNavigation.js.map +1 -1
  298. package/dist-cjs/packages/lab/src/toggle-button/ToggleButton.js +8 -32
  299. package/dist-cjs/packages/lab/src/toggle-button/ToggleButton.js.map +1 -1
  300. package/dist-cjs/packages/lab/src/toggle-button/ToggleButtonGroup.js +2 -6
  301. package/dist-cjs/packages/lab/src/toggle-button/ToggleButtonGroup.js.map +1 -1
  302. package/dist-cjs/packages/lab/src/tokenized-input/TokenizedInput.js.map +1 -1
  303. package/dist-cjs/packages/lab/src/tokenized-input/TokenizedInputBase.js +7 -12
  304. package/dist-cjs/packages/lab/src/tokenized-input/TokenizedInputBase.js.map +1 -1
  305. package/dist-cjs/packages/lab/src/tokenized-input/internal/InputPill.js +2 -6
  306. package/dist-cjs/packages/lab/src/tokenized-input/internal/InputPill.js.map +1 -1
  307. package/dist-cjs/packages/lab/src/tokenized-input/useTokenizedInput.js +1 -0
  308. package/dist-cjs/packages/lab/src/tokenized-input/useTokenizedInput.js.map +1 -1
  309. package/dist-cjs/packages/lab/src/toolbar/Toolbar.js +5 -8
  310. package/dist-cjs/packages/lab/src/toolbar/Toolbar.js.map +1 -1
  311. package/dist-cjs/packages/lab/src/toolbar/Tooltray.js +4 -8
  312. package/dist-cjs/packages/lab/src/toolbar/Tooltray.js.map +1 -1
  313. package/dist-cjs/packages/lab/src/toolbar/internal/renderToolbarItems.js +1 -0
  314. package/dist-cjs/packages/lab/src/toolbar/internal/renderToolbarItems.js.map +1 -1
  315. package/dist-cjs/packages/lab/src/toolbar/overflow-panel/OverflowPanel.js +3 -3
  316. package/dist-cjs/packages/lab/src/toolbar/overflow-panel/OverflowPanel.js.map +1 -1
  317. package/dist-cjs/packages/lab/src/toolbar/overflow-panel/OverflowSeparator.js +2 -6
  318. package/dist-cjs/packages/lab/src/toolbar/overflow-panel/OverflowSeparator.js.map +1 -1
  319. package/dist-cjs/packages/lab/src/toolbar/toolbar-field/useToolbarField.js +3 -7
  320. package/dist-cjs/packages/lab/src/toolbar/toolbar-field/useToolbarField.js.map +1 -1
  321. package/dist-cjs/packages/lab/src/tree/Tree.js +5 -8
  322. package/dist-cjs/packages/lab/src/tree/Tree.js.map +1 -1
  323. package/dist-cjs/packages/lab/src/tree/TreeNode.js +2 -6
  324. package/dist-cjs/packages/lab/src/tree/TreeNode.js.map +1 -1
  325. package/dist-cjs/packages/lab/src/tree/useTree.js +2 -1
  326. package/dist-cjs/packages/lab/src/tree/useTree.js.map +1 -1
  327. package/dist-cjs/packages/lab/src/utils/useFloatingUI.js +38 -0
  328. package/dist-cjs/packages/lab/src/utils/useFloatingUI.js.map +1 -0
  329. package/dist-cjs/packages/lab/src/utils/useIsViewportLargerThanBreakpoint.js +1 -2
  330. package/dist-cjs/packages/lab/src/utils/useIsViewportLargerThanBreakpoint.js.map +1 -1
  331. package/dist-es/packages/lab/src/accordion/Accordion.js +2 -2
  332. package/dist-es/packages/lab/src/accordion/Accordion.js.map +1 -1
  333. package/dist-es/packages/lab/src/accordion/AccordionDetails.js +3 -3
  334. package/dist-es/packages/lab/src/accordion/AccordionDetails.js.map +1 -1
  335. package/dist-es/packages/lab/src/accordion/AccordionSection.js +3 -2
  336. package/dist-es/packages/lab/src/accordion/AccordionSection.js.map +1 -1
  337. package/dist-es/packages/lab/src/accordion/AccordionSummary.js +2 -2
  338. package/dist-es/packages/lab/src/accordion/AccordionSummary.js.map +1 -1
  339. package/dist-es/packages/lab/src/app-header/AppHeader.js +3 -2
  340. package/dist-es/packages/lab/src/app-header/AppHeader.js.map +1 -1
  341. package/dist-es/packages/lab/src/avatar/Avatar.js +2 -2
  342. package/dist-es/packages/lab/src/avatar/Avatar.js.map +1 -1
  343. package/dist-es/packages/lab/src/badge/Badge.js +4 -4
  344. package/dist-es/packages/lab/src/badge/Badge.js.map +1 -1
  345. package/dist-es/packages/lab/src/banner/Banner.js +5 -5
  346. package/dist-es/packages/lab/src/banner/Banner.js.map +1 -1
  347. package/dist-es/packages/lab/src/breadcrumbs/Breadcrumb.js +4 -4
  348. package/dist-es/packages/lab/src/breadcrumbs/Breadcrumb.js.map +1 -1
  349. package/dist-es/packages/lab/src/breadcrumbs/Breadcrumbs.js +3 -3
  350. package/dist-es/packages/lab/src/breadcrumbs/Breadcrumbs.js.map +1 -1
  351. package/dist-es/packages/lab/src/button-bar/ButtonBar.js +2 -2
  352. package/dist-es/packages/lab/src/button-bar/ButtonBar.js.map +1 -1
  353. package/dist-es/packages/lab/src/button-bar/OrderedButton.js +3 -2
  354. package/dist-es/packages/lab/src/button-bar/OrderedButton.js.map +1 -1
  355. package/dist-es/packages/lab/src/calendar/Calendar.js +2 -2
  356. package/dist-es/packages/lab/src/calendar/Calendar.js.map +1 -1
  357. package/dist-es/packages/lab/src/calendar/internal/CalendarDay.js +36 -52
  358. package/dist-es/packages/lab/src/calendar/internal/CalendarDay.js.map +1 -1
  359. package/dist-es/packages/lab/src/calendar/internal/CalendarMonth.js +2 -2
  360. package/dist-es/packages/lab/src/calendar/internal/CalendarMonth.js.map +1 -1
  361. package/dist-es/packages/lab/src/calendar/internal/CalendarNavigation.js +39 -69
  362. package/dist-es/packages/lab/src/calendar/internal/CalendarNavigation.js.map +1 -1
  363. package/dist-es/packages/lab/src/calendar/internal/CalendarWeekHeader.js +2 -2
  364. package/dist-es/packages/lab/src/calendar/internal/CalendarWeekHeader.js.map +1 -1
  365. package/dist-es/packages/lab/src/calendar/useSelection.js +3 -2
  366. package/dist-es/packages/lab/src/calendar/useSelection.js.map +1 -1
  367. package/dist-es/packages/lab/src/carousel/Carousel.js +3 -2
  368. package/dist-es/packages/lab/src/carousel/Carousel.js.map +1 -1
  369. package/dist-es/packages/lab/src/carousel/CarouselSlide.js +4 -4
  370. package/dist-es/packages/lab/src/carousel/CarouselSlide.js.map +1 -1
  371. package/dist-es/packages/lab/src/cascading-menu/CascadingMenu.js +2 -1
  372. package/dist-es/packages/lab/src/cascading-menu/CascadingMenu.js.map +1 -1
  373. package/dist-es/packages/lab/src/cascading-menu/CascadingMenuItem.js +50 -67
  374. package/dist-es/packages/lab/src/cascading-menu/CascadingMenuItem.js.map +1 -1
  375. package/dist-es/packages/lab/src/cascading-menu/CascadingMenuList.js +5 -5
  376. package/dist-es/packages/lab/src/cascading-menu/CascadingMenuList.js.map +1 -1
  377. package/dist-es/packages/lab/src/cascading-menu/internal/useClickAway.js +1 -0
  378. package/dist-es/packages/lab/src/cascading-menu/internal/useClickAway.js.map +1 -1
  379. package/dist-es/packages/lab/src/cascading-menu/internal/useMenuTriggerHandlers.js +1 -0
  380. package/dist-es/packages/lab/src/cascading-menu/internal/useMenuTriggerHandlers.js.map +1 -1
  381. package/dist-es/packages/lab/src/checkbox/Checkbox.js +2 -2
  382. package/dist-es/packages/lab/src/checkbox/Checkbox.js.map +1 -1
  383. package/dist-es/packages/lab/src/checkbox/CheckboxBase.js +2 -2
  384. package/dist-es/packages/lab/src/checkbox/CheckboxBase.js.map +1 -1
  385. package/dist-es/packages/lab/src/checkbox/CheckboxGroup.js +2 -2
  386. package/dist-es/packages/lab/src/checkbox/CheckboxGroup.js.map +1 -1
  387. package/dist-es/packages/lab/src/checkbox/CheckboxIcon.js +4 -4
  388. package/dist-es/packages/lab/src/checkbox/CheckboxIcon.js.map +1 -1
  389. package/dist-es/packages/lab/src/color-chooser/AlphaInputField.js +2 -2
  390. package/dist-es/packages/lab/src/color-chooser/AlphaInputField.js.map +1 -1
  391. package/dist-es/packages/lab/src/color-chooser/ColorChooser.js +7 -7
  392. package/dist-es/packages/lab/src/color-chooser/ColorChooser.js.map +1 -1
  393. package/dist-es/packages/lab/src/color-chooser/ColorPicker.js +7 -7
  394. package/dist-es/packages/lab/src/color-chooser/ColorPicker.js.map +1 -1
  395. package/dist-es/packages/lab/src/color-chooser/DictTabs.js +3 -3
  396. package/dist-es/packages/lab/src/color-chooser/DictTabs.js.map +1 -1
  397. package/dist-es/packages/lab/src/color-chooser/HexInput.js +4 -4
  398. package/dist-es/packages/lab/src/color-chooser/HexInput.js.map +1 -1
  399. package/dist-es/packages/lab/src/color-chooser/RGBAInput.js +5 -5
  400. package/dist-es/packages/lab/src/color-chooser/RGBAInput.js.map +1 -1
  401. package/dist-es/packages/lab/src/color-chooser/Swatch.js +2 -2
  402. package/dist-es/packages/lab/src/color-chooser/Swatch.js.map +1 -1
  403. package/dist-es/packages/lab/src/color-chooser/Swatches.js +6 -6
  404. package/dist-es/packages/lab/src/color-chooser/Swatches.js.map +1 -1
  405. package/dist-es/packages/lab/src/combo-box/ComboBox.js +1 -0
  406. package/dist-es/packages/lab/src/combo-box/ComboBox.js.map +1 -1
  407. package/dist-es/packages/lab/src/combo-box/useCombobox.js +1 -0
  408. package/dist-es/packages/lab/src/combo-box/useCombobox.js.map +1 -1
  409. package/dist-es/packages/lab/src/combo-box-deprecated/ComboBoxDeprecated.js +3 -3
  410. package/dist-es/packages/lab/src/combo-box-deprecated/ComboBoxDeprecated.js.map +1 -1
  411. package/dist-es/packages/lab/src/combo-box-deprecated/filterHelpers.js +1 -0
  412. package/dist-es/packages/lab/src/combo-box-deprecated/filterHelpers.js.map +1 -1
  413. package/dist-es/packages/lab/src/combo-box-deprecated/internal/DefaultComboBox.js +19 -37
  414. package/dist-es/packages/lab/src/combo-box-deprecated/internal/DefaultComboBox.js.map +1 -1
  415. package/dist-es/packages/lab/src/combo-box-deprecated/internal/MultiSelectComboBox.js +26 -47
  416. package/dist-es/packages/lab/src/combo-box-deprecated/internal/MultiSelectComboBox.js.map +1 -1
  417. package/dist-es/packages/lab/src/combo-box-deprecated/internal/useComboBox.js +1 -0
  418. package/dist-es/packages/lab/src/combo-box-deprecated/internal/useComboBox.js.map +1 -1
  419. package/dist-es/packages/lab/src/combo-box-deprecated/internal/useMultiSelectComboBox.js +1 -0
  420. package/dist-es/packages/lab/src/combo-box-deprecated/internal/useMultiSelectComboBox.js.map +1 -1
  421. package/dist-es/packages/lab/src/common-hooks/useAutoSizer.js +4 -3
  422. package/dist-es/packages/lab/src/common-hooks/useAutoSizer.js.map +1 -1
  423. package/dist-es/packages/lab/src/common-hooks/useViewportTracking.js +4 -3
  424. package/dist-es/packages/lab/src/common-hooks/useViewportTracking.js.map +1 -1
  425. package/dist-es/packages/lab/src/common-hooks/utils/filter-utils.js +1 -0
  426. package/dist-es/packages/lab/src/common-hooks/utils/filter-utils.js.map +1 -1
  427. package/dist-es/packages/lab/src/contact-details/ContactAction.js +10 -25
  428. package/dist-es/packages/lab/src/contact-details/ContactAction.js.map +1 -1
  429. package/dist-es/packages/lab/src/contact-details/ContactAvatar.js +2 -2
  430. package/dist-es/packages/lab/src/contact-details/ContactAvatar.js.map +1 -1
  431. package/dist-es/packages/lab/src/contact-details/ContactDetails.js +2 -2
  432. package/dist-es/packages/lab/src/contact-details/ContactDetails.js.map +1 -1
  433. package/dist-es/packages/lab/src/contact-details/ContactFavoriteToggle.js.map +1 -1
  434. package/dist-es/packages/lab/src/contact-details/ContactMetadata.js +2 -2
  435. package/dist-es/packages/lab/src/contact-details/ContactMetadata.js.map +1 -1
  436. package/dist-es/packages/lab/src/contact-details/ContactPrimaryInfo.js +2 -2
  437. package/dist-es/packages/lab/src/contact-details/ContactPrimaryInfo.js.map +1 -1
  438. package/dist-es/packages/lab/src/contact-details/ContactSecondaryInfo.js +2 -2
  439. package/dist-es/packages/lab/src/contact-details/ContactSecondaryInfo.js.map +1 -1
  440. package/dist-es/packages/lab/src/contact-details/ContactTertiaryInfo.js +2 -2
  441. package/dist-es/packages/lab/src/contact-details/ContactTertiaryInfo.js.map +1 -1
  442. package/dist-es/packages/lab/src/contact-details/MailLinkComponent.js +1 -0
  443. package/dist-es/packages/lab/src/contact-details/MailLinkComponent.js.map +1 -1
  444. package/dist-es/packages/lab/src/contact-details/internal/FavoriteToggleWithTooltip.js +9 -20
  445. package/dist-es/packages/lab/src/contact-details/internal/FavoriteToggleWithTooltip.js.map +1 -1
  446. package/dist-es/packages/lab/src/contact-details/internal/StarIconContainer.js +3 -3
  447. package/dist-es/packages/lab/src/contact-details/internal/StarIconContainer.js.map +1 -1
  448. package/dist-es/packages/lab/src/content-status/ContentStatus.js +6 -6
  449. package/dist-es/packages/lab/src/content-status/ContentStatus.js.map +1 -1
  450. package/dist-es/packages/lab/src/content-status/internal/StatusIndicator.js +4 -5
  451. package/dist-es/packages/lab/src/content-status/internal/StatusIndicator.js.map +1 -1
  452. package/dist-es/packages/lab/src/control-label/ControlLabel.js +2 -2
  453. package/dist-es/packages/lab/src/control-label/ControlLabel.js.map +1 -1
  454. package/dist-es/packages/lab/src/deck-item/DeckItem.js +2 -2
  455. package/dist-es/packages/lab/src/deck-item/DeckItem.js.map +1 -1
  456. package/dist-es/packages/lab/src/deck-layout/DeckLayout.js +4 -3
  457. package/dist-es/packages/lab/src/deck-layout/DeckLayout.js.map +1 -1
  458. package/dist-es/packages/lab/src/dialog/Dialog.js +2 -2
  459. package/dist-es/packages/lab/src/dialog/Dialog.js.map +1 -1
  460. package/dist-es/packages/lab/src/dialog/DialogActions.js +2 -2
  461. package/dist-es/packages/lab/src/dialog/DialogActions.js.map +1 -1
  462. package/dist-es/packages/lab/src/dialog/DialogContent.js +2 -2
  463. package/dist-es/packages/lab/src/dialog/DialogContent.js.map +1 -1
  464. package/dist-es/packages/lab/src/dialog/DialogTitle.js +2 -2
  465. package/dist-es/packages/lab/src/dialog/DialogTitle.js.map +1 -1
  466. package/dist-es/packages/lab/src/dropdown/Dropdown.js +1 -0
  467. package/dist-es/packages/lab/src/dropdown/Dropdown.js.map +1 -1
  468. package/dist-es/packages/lab/src/dropdown/DropdownBase.js +7 -7
  469. package/dist-es/packages/lab/src/dropdown/DropdownBase.js.map +1 -1
  470. package/dist-es/packages/lab/src/dropdown/DropdownButton.js +2 -2
  471. package/dist-es/packages/lab/src/dropdown/DropdownButton.js.map +1 -1
  472. package/dist-es/packages/lab/src/dropdown/useDropdown.js +1 -0
  473. package/dist-es/packages/lab/src/dropdown/useDropdown.js.map +1 -1
  474. package/dist-es/packages/lab/src/dropdown/useDropdownBase.js +1 -0
  475. package/dist-es/packages/lab/src/dropdown/useDropdownBase.js.map +1 -1
  476. package/dist-es/packages/lab/src/editable-label/EditableLabel.js +2 -2
  477. package/dist-es/packages/lab/src/editable-label/EditableLabel.js.map +1 -1
  478. package/dist-es/packages/lab/src/file-drop-zone/FileDropZone.js +2 -2
  479. package/dist-es/packages/lab/src/file-drop-zone/FileDropZone.js.map +1 -1
  480. package/dist-es/packages/lab/src/form-field/FormField.js +63 -76
  481. package/dist-es/packages/lab/src/form-field/FormField.js.map +1 -1
  482. package/dist-es/packages/lab/src/form-field/FormLabel.js +2 -2
  483. package/dist-es/packages/lab/src/form-field/FormLabel.js.map +1 -1
  484. package/dist-es/packages/lab/src/form-field/StatusIndicator.js +19 -32
  485. package/dist-es/packages/lab/src/form-field/StatusIndicator.js.map +1 -1
  486. package/dist-es/packages/lab/src/form-group/FormGroup.js +2 -2
  487. package/dist-es/packages/lab/src/form-group/FormGroup.js.map +1 -1
  488. package/dist-es/packages/lab/src/formatted-input/FormattedInput.js +2 -2
  489. package/dist-es/packages/lab/src/formatted-input/FormattedInput.js.map +1 -1
  490. package/dist-es/packages/lab/src/formatted-input/internal/InputWithMask.js +2 -2
  491. package/dist-es/packages/lab/src/formatted-input/internal/InputWithMask.js.map +1 -1
  492. package/dist-es/packages/lab/src/index.js +1 -8
  493. package/dist-es/packages/lab/src/index.js.map +1 -1
  494. package/dist-es/packages/lab/src/input/Input.js +4 -4
  495. package/dist-es/packages/lab/src/input/Input.js.map +1 -1
  496. package/dist-es/packages/lab/src/input/StaticInputAdornment.js +2 -2
  497. package/dist-es/packages/lab/src/input/StaticInputAdornment.js.map +1 -1
  498. package/dist-es/packages/lab/src/layer-layout/LayerLayout.js +6 -5
  499. package/dist-es/packages/lab/src/layer-layout/LayerLayout.js.map +1 -1
  500. package/dist-es/packages/lab/src/list/Highlighter.js +1 -0
  501. package/dist-es/packages/lab/src/list/Highlighter.js.map +1 -1
  502. package/dist-es/packages/lab/src/list/List.js +5 -4
  503. package/dist-es/packages/lab/src/list/List.js.map +1 -1
  504. package/dist-es/packages/lab/src/list/ListItem.js +3 -3
  505. package/dist-es/packages/lab/src/list/ListItem.js.map +1 -1
  506. package/dist-es/packages/lab/src/list/VirtualizedList.js +4 -3
  507. package/dist-es/packages/lab/src/list/VirtualizedList.js.map +1 -1
  508. package/dist-es/packages/lab/src/list/useList.js +2 -1
  509. package/dist-es/packages/lab/src/list/useList.js.map +1 -1
  510. package/dist-es/packages/lab/src/list/useListHeight.js +1 -0
  511. package/dist-es/packages/lab/src/list/useListHeight.js.map +1 -1
  512. package/dist-es/packages/lab/src/list/useVirtualization.js +3 -2
  513. package/dist-es/packages/lab/src/list/useVirtualization.js.map +1 -1
  514. package/dist-es/packages/lab/src/list-deprecated/List.js +5 -26
  515. package/dist-es/packages/lab/src/list-deprecated/List.js.map +1 -1
  516. package/dist-es/packages/lab/src/list-deprecated/ListBase.js +3 -3
  517. package/dist-es/packages/lab/src/list-deprecated/ListBase.js.map +1 -1
  518. package/dist-es/packages/lab/src/list-deprecated/ListItemBase.js +32 -62
  519. package/dist-es/packages/lab/src/list-deprecated/ListItemBase.js.map +1 -1
  520. package/dist-es/packages/lab/src/list-deprecated/internal/Highlighter.js +1 -0
  521. package/dist-es/packages/lab/src/list-deprecated/internal/Highlighter.js.map +1 -1
  522. package/dist-es/packages/lab/src/list-deprecated/useTypeSelect.js +1 -0
  523. package/dist-es/packages/lab/src/list-deprecated/useTypeSelect.js.map +1 -1
  524. package/dist-es/packages/lab/src/logo/Logo.js +5 -5
  525. package/dist-es/packages/lab/src/logo/Logo.js.map +1 -1
  526. package/dist-es/packages/lab/src/menu-button/MenuButtonTrigger.js +2 -2
  527. package/dist-es/packages/lab/src/menu-button/MenuButtonTrigger.js.map +1 -1
  528. package/dist-es/packages/lab/src/metric/Metric.js +2 -2
  529. package/dist-es/packages/lab/src/metric/Metric.js.map +1 -1
  530. package/dist-es/packages/lab/src/metric/MetricContent.js +2 -2
  531. package/dist-es/packages/lab/src/metric/MetricContent.js.map +1 -1
  532. package/dist-es/packages/lab/src/metric/MetricHeader.js +2 -2
  533. package/dist-es/packages/lab/src/metric/MetricHeader.js.map +1 -1
  534. package/dist-es/packages/lab/src/overlay/Overlay.js +4 -4
  535. package/dist-es/packages/lab/src/overlay/Overlay.js.map +1 -1
  536. package/dist-es/packages/lab/src/overlay/useOverlay.js +2 -3
  537. package/dist-es/packages/lab/src/overlay/useOverlay.js.map +1 -1
  538. package/dist-es/packages/lab/src/pagination/ArrowButton.js +2 -2
  539. package/dist-es/packages/lab/src/pagination/ArrowButton.js.map +1 -1
  540. package/dist-es/packages/lab/src/pagination/CompactInput.js +3 -3
  541. package/dist-es/packages/lab/src/pagination/CompactInput.js.map +1 -1
  542. package/dist-es/packages/lab/src/pagination/GoToInput.js +3 -3
  543. package/dist-es/packages/lab/src/pagination/GoToInput.js.map +1 -1
  544. package/dist-es/packages/lab/src/pagination/PageButton.js +2 -2
  545. package/dist-es/packages/lab/src/pagination/PageButton.js.map +1 -1
  546. package/dist-es/packages/lab/src/pagination/Pagination.js +2 -2
  547. package/dist-es/packages/lab/src/pagination/Pagination.js.map +1 -1
  548. package/dist-es/packages/lab/src/pagination/Paginator.js +2 -2
  549. package/dist-es/packages/lab/src/pagination/Paginator.js.map +1 -1
  550. package/dist-es/packages/lab/src/parent-child-item/ParentChildItem.js +2 -2
  551. package/dist-es/packages/lab/src/parent-child-item/ParentChildItem.js.map +1 -1
  552. package/dist-es/packages/lab/src/parent-child-layout/ParentChildLayout.js +3 -2
  553. package/dist-es/packages/lab/src/parent-child-layout/ParentChildLayout.js.map +1 -1
  554. package/dist-es/packages/lab/src/pill/ClosablePill.js +2 -2
  555. package/dist-es/packages/lab/src/pill/ClosablePill.js.map +1 -1
  556. package/dist-es/packages/lab/src/pill/PillBase.js +44 -60
  557. package/dist-es/packages/lab/src/pill/PillBase.js.map +1 -1
  558. package/dist-es/packages/lab/src/pill/SelectablePill.js +2 -2
  559. package/dist-es/packages/lab/src/pill/SelectablePill.js.map +1 -1
  560. package/dist-es/packages/lab/src/pill/internal/DeleteButton.js +2 -2
  561. package/dist-es/packages/lab/src/pill/internal/DeleteButton.js.map +1 -1
  562. package/dist-es/packages/lab/src/pill/internal/DivButton.js +2 -2
  563. package/dist-es/packages/lab/src/pill/internal/DivButton.js.map +1 -1
  564. package/dist-es/packages/lab/src/progress/CircularProgress/CircularProgress.js +4 -4
  565. package/dist-es/packages/lab/src/progress/CircularProgress/CircularProgress.js.map +1 -1
  566. package/dist-es/packages/lab/src/progress/LinearProgress/LinearProgress.js +5 -5
  567. package/dist-es/packages/lab/src/progress/LinearProgress/LinearProgress.js.map +1 -1
  568. package/dist-es/packages/lab/src/query-input/QueryInput.js +2 -2
  569. package/dist-es/packages/lab/src/query-input/QueryInput.js.map +1 -1
  570. package/dist-es/packages/lab/src/query-input/internal/CategoryList.js +1 -0
  571. package/dist-es/packages/lab/src/query-input/internal/CategoryList.js.map +1 -1
  572. package/dist-es/packages/lab/src/query-input/internal/CategoryListItem.js +1 -0
  573. package/dist-es/packages/lab/src/query-input/internal/CategoryListItem.js.map +1 -1
  574. package/dist-es/packages/lab/src/query-input/internal/QueryInputBody.js +1 -0
  575. package/dist-es/packages/lab/src/query-input/internal/QueryInputBody.js.map +1 -1
  576. package/dist-es/packages/lab/src/query-input/internal/SearchList.js +1 -0
  577. package/dist-es/packages/lab/src/query-input/internal/SearchList.js.map +1 -1
  578. package/dist-es/packages/lab/src/query-input/internal/ValueList.js +1 -0
  579. package/dist-es/packages/lab/src/query-input/internal/ValueList.js.map +1 -1
  580. package/dist-es/packages/lab/src/query-input/internal/ValueSelector.js +2 -3
  581. package/dist-es/packages/lab/src/query-input/internal/ValueSelector.js.map +1 -1
  582. package/dist-es/packages/lab/src/query-input/useQueryInput.js +1 -0
  583. package/dist-es/packages/lab/src/query-input/useQueryInput.js.map +1 -1
  584. package/dist-es/packages/lab/src/radio-button/RadioButton.js +3 -3
  585. package/dist-es/packages/lab/src/radio-button/RadioButton.js.map +1 -1
  586. package/dist-es/packages/lab/src/radio-button/RadioButtonBase.js +2 -2
  587. package/dist-es/packages/lab/src/radio-button/RadioButtonBase.js.map +1 -1
  588. package/dist-es/packages/lab/src/radio-button/RadioButtonGroup.js +3 -3
  589. package/dist-es/packages/lab/src/radio-button/RadioButtonGroup.js.map +1 -1
  590. package/dist-es/packages/lab/src/radio-button/RadioButtonIcon.js +2 -2
  591. package/dist-es/packages/lab/src/radio-button/RadioButtonIcon.js.map +1 -1
  592. package/dist-es/packages/lab/src/responsive/useOverflow.js +1 -0
  593. package/dist-es/packages/lab/src/responsive/useOverflow.js.map +1 -1
  594. package/dist-es/packages/lab/src/responsive/useResizeObserver.js +6 -3
  595. package/dist-es/packages/lab/src/responsive/useResizeObserver.js.map +1 -1
  596. package/dist-es/packages/lab/src/scrim/Scrim.js +2 -2
  597. package/dist-es/packages/lab/src/scrim/Scrim.js.map +1 -1
  598. package/dist-es/packages/lab/src/search-input/SearchInput.js +3 -3
  599. package/dist-es/packages/lab/src/search-input/SearchInput.js.map +1 -1
  600. package/dist-es/packages/lab/src/skip-link/SkipLink.js +3 -3
  601. package/dist-es/packages/lab/src/skip-link/SkipLink.js.map +1 -1
  602. package/dist-es/packages/lab/src/skip-link/SkipLinks.js +2 -2
  603. package/dist-es/packages/lab/src/skip-link/SkipLinks.js.map +1 -1
  604. package/dist-es/packages/lab/src/slider/Slider.js +2 -2
  605. package/dist-es/packages/lab/src/slider/Slider.js.map +1 -1
  606. package/dist-es/packages/lab/src/slider/internal/SliderHandle.js +20 -29
  607. package/dist-es/packages/lab/src/slider/internal/SliderHandle.js.map +1 -1
  608. package/dist-es/packages/lab/src/slider/internal/SliderRailMarks.js +2 -2
  609. package/dist-es/packages/lab/src/slider/internal/SliderRailMarks.js.map +1 -1
  610. package/dist-es/packages/lab/src/stepper-input/StepperInput.js +5 -5
  611. package/dist-es/packages/lab/src/stepper-input/StepperInput.js.map +1 -1
  612. package/dist-es/packages/lab/src/switch/Switch.js +4 -4
  613. package/dist-es/packages/lab/src/switch/Switch.js.map +1 -1
  614. package/dist-es/packages/lab/src/tabs/Tab.js +2 -2
  615. package/dist-es/packages/lab/src/tabs/Tab.js.map +1 -1
  616. package/dist-es/packages/lab/src/tabs/TabPanel.js +2 -2
  617. package/dist-es/packages/lab/src/tabs/TabPanel.js.map +1 -1
  618. package/dist-es/packages/lab/src/tabs/Tabs.js +2 -2
  619. package/dist-es/packages/lab/src/tabs/Tabs.js.map +1 -1
  620. package/dist-es/packages/lab/src/tabs/Tabstrip.js +38 -48
  621. package/dist-es/packages/lab/src/tabs/Tabstrip.js.map +1 -1
  622. package/dist-es/packages/lab/src/tabs/drag-drop/Draggable.js +2 -2
  623. package/dist-es/packages/lab/src/tabs/drag-drop/Draggable.js.map +1 -1
  624. package/dist-es/packages/lab/src/tabs/useActivationIndicator.js +1 -0
  625. package/dist-es/packages/lab/src/tabs/useActivationIndicator.js.map +1 -1
  626. package/dist-es/packages/lab/src/tabs/useKeyboardNavigation.js +1 -0
  627. package/dist-es/packages/lab/src/tabs/useKeyboardNavigation.js.map +1 -1
  628. package/dist-es/packages/lab/src/toggle-button/ToggleButton.js +10 -30
  629. package/dist-es/packages/lab/src/toggle-button/ToggleButton.js.map +1 -1
  630. package/dist-es/packages/lab/src/toggle-button/ToggleButtonGroup.js +2 -2
  631. package/dist-es/packages/lab/src/toggle-button/ToggleButtonGroup.js.map +1 -1
  632. package/dist-es/packages/lab/src/tokenized-input/TokenizedInput.js.map +1 -1
  633. package/dist-es/packages/lab/src/tokenized-input/TokenizedInputBase.js +7 -11
  634. package/dist-es/packages/lab/src/tokenized-input/TokenizedInputBase.js.map +1 -1
  635. package/dist-es/packages/lab/src/tokenized-input/internal/InputPill.js +2 -2
  636. package/dist-es/packages/lab/src/tokenized-input/internal/InputPill.js.map +1 -1
  637. package/dist-es/packages/lab/src/tokenized-input/useTokenizedInput.js +1 -0
  638. package/dist-es/packages/lab/src/tokenized-input/useTokenizedInput.js.map +1 -1
  639. package/dist-es/packages/lab/src/toolbar/Toolbar.js +5 -4
  640. package/dist-es/packages/lab/src/toolbar/Toolbar.js.map +1 -1
  641. package/dist-es/packages/lab/src/toolbar/Tooltray.js +4 -4
  642. package/dist-es/packages/lab/src/toolbar/Tooltray.js.map +1 -1
  643. package/dist-es/packages/lab/src/toolbar/internal/renderToolbarItems.js +1 -0
  644. package/dist-es/packages/lab/src/toolbar/internal/renderToolbarItems.js.map +1 -1
  645. package/dist-es/packages/lab/src/toolbar/overflow-panel/OverflowPanel.js +3 -2
  646. package/dist-es/packages/lab/src/toolbar/overflow-panel/OverflowPanel.js.map +1 -1
  647. package/dist-es/packages/lab/src/toolbar/overflow-panel/OverflowSeparator.js +2 -2
  648. package/dist-es/packages/lab/src/toolbar/overflow-panel/OverflowSeparator.js.map +1 -1
  649. package/dist-es/packages/lab/src/toolbar/toolbar-field/useToolbarField.js +3 -3
  650. package/dist-es/packages/lab/src/toolbar/toolbar-field/useToolbarField.js.map +1 -1
  651. package/dist-es/packages/lab/src/tree/Tree.js +5 -4
  652. package/dist-es/packages/lab/src/tree/Tree.js.map +1 -1
  653. package/dist-es/packages/lab/src/tree/TreeNode.js +2 -2
  654. package/dist-es/packages/lab/src/tree/TreeNode.js.map +1 -1
  655. package/dist-es/packages/lab/src/tree/useTree.js +2 -1
  656. package/dist-es/packages/lab/src/tree/useTree.js.map +1 -1
  657. package/dist-es/packages/lab/src/{popper → utils}/useFloatingUI.js +10 -9
  658. package/dist-es/packages/lab/src/utils/useFloatingUI.js.map +1 -0
  659. package/dist-es/packages/lab/src/utils/useIsViewportLargerThanBreakpoint.js +1 -2
  660. package/dist-es/packages/lab/src/utils/useIsViewportLargerThanBreakpoint.js.map +1 -1
  661. package/dist-types/breadcrumbs/Breadcrumb.d.ts +1 -1
  662. package/dist-types/calendar/internal/CalendarCarousel.d.ts +1 -1
  663. package/dist-types/calendar/internal/CalendarDay.d.ts +2 -2
  664. package/dist-types/calendar/internal/CalendarMonth.d.ts +1 -1
  665. package/dist-types/calendar/internal/CalendarNavigation.d.ts +1 -1
  666. package/dist-types/calendar/internal/CalendarWeekHeader.d.ts +2 -2
  667. package/dist-types/calendar/useCalendar.d.ts +1 -1
  668. package/dist-types/calendar/useCalendarDay.d.ts +1 -1
  669. package/dist-types/cascading-menu/CascadingMenuList.d.ts +1 -1
  670. package/dist-types/cascading-menu/CascadingMenuProps.d.ts +1 -1
  671. package/dist-types/combo-box-deprecated/internal/DefaultComboBox.d.ts +1 -3
  672. package/dist-types/combo-box-deprecated/internal/useComboBox.d.ts +10 -11
  673. package/dist-types/combo-box-deprecated/internal/useMultiSelectComboBox.d.ts +27 -22
  674. package/dist-types/contact-details/ContactAction.d.ts +1 -2
  675. package/dist-types/contact-details/ContactFavoriteToggle.d.ts +1 -1
  676. package/dist-types/contact-details/internal/FavoriteToggleWithTooltip.d.ts +1 -1
  677. package/dist-types/content-status/internal/StatusIndicator.d.ts +1 -2
  678. package/dist-types/form-field/StatusIndicator.d.ts +1 -1
  679. package/dist-types/index.d.ts +0 -6
  680. package/dist-types/layer-layout/LayerLayout.d.ts +1 -1
  681. package/dist-types/list-deprecated/ListProps.d.ts +0 -5
  682. package/dist-types/overlay/Overlay.d.ts +1 -1
  683. package/dist-types/overlay/useOverlay.d.ts +2 -2
  684. package/dist-types/pill/PillBase.d.ts +1 -1
  685. package/dist-types/skip-link/SkipLink.d.ts +1 -1
  686. package/dist-types/stepper-input/useStepperInput.d.ts +13 -10
  687. package/dist-types/tabs/Tab.d.ts +1 -1
  688. package/dist-types/tabs/drag-drop/drag-utils.d.ts +8 -8
  689. package/dist-types/tokenized-input/TokenizedInput.d.ts +1 -1
  690. package/dist-types/toolbar/ToolbarProps.d.ts +1 -1
  691. package/dist-types/utils/index.d.ts +1 -0
  692. package/dist-types/utils/useFloatingUI.d.ts +34 -0
  693. package/dist-types/window/ElectronWindow.d.ts +1 -1
  694. package/dist-types/window/WindowContext.d.ts +3 -3
  695. package/package.json +6 -6
  696. package/dist-cjs/packages/lab/src/card/Card.css.js +0 -9
  697. package/dist-cjs/packages/lab/src/card/Card.css.js.map +0 -1
  698. package/dist-cjs/packages/lab/src/card/Card.js +0 -37
  699. package/dist-cjs/packages/lab/src/card/Card.js.map +0 -1
  700. package/dist-cjs/packages/lab/src/panel/Panel.css.js +0 -9
  701. package/dist-cjs/packages/lab/src/panel/Panel.css.js.map +0 -1
  702. package/dist-cjs/packages/lab/src/panel/Panel.js +0 -28
  703. package/dist-cjs/packages/lab/src/panel/Panel.js.map +0 -1
  704. package/dist-cjs/packages/lab/src/popper/useFloatingUI.js +0 -37
  705. package/dist-cjs/packages/lab/src/popper/useFloatingUI.js.map +0 -1
  706. package/dist-cjs/packages/lab/src/spinner/Spinner.css.js +0 -9
  707. package/dist-cjs/packages/lab/src/spinner/Spinner.css.js.map +0 -1
  708. package/dist-cjs/packages/lab/src/spinner/Spinner.js +0 -80
  709. package/dist-cjs/packages/lab/src/spinner/Spinner.js.map +0 -1
  710. package/dist-cjs/packages/lab/src/spinner/svgSpinners/SpinnerLarge.js +0 -71
  711. package/dist-cjs/packages/lab/src/spinner/svgSpinners/SpinnerLarge.js.map +0 -1
  712. package/dist-cjs/packages/lab/src/spinner/svgSpinners/SpinnerMedium.js +0 -71
  713. package/dist-cjs/packages/lab/src/spinner/svgSpinners/SpinnerMedium.js.map +0 -1
  714. package/dist-cjs/packages/lab/src/spinner/svgSpinners/SpinnerSmall.js +0 -71
  715. package/dist-cjs/packages/lab/src/spinner/svgSpinners/SpinnerSmall.js.map +0 -1
  716. package/dist-cjs/packages/lab/src/spinner/svgSpinners/index.js +0 -21
  717. package/dist-cjs/packages/lab/src/spinner/svgSpinners/index.js.map +0 -1
  718. package/dist-cjs/packages/lab/src/split-layout/SplitLayout.css.js +0 -9
  719. package/dist-cjs/packages/lab/src/split-layout/SplitLayout.css.js.map +0 -1
  720. package/dist-cjs/packages/lab/src/split-layout/SplitLayout.js +0 -40
  721. package/dist-cjs/packages/lab/src/split-layout/SplitLayout.js.map +0 -1
  722. package/dist-cjs/packages/lab/src/tooltip/Tooltip.css.js +0 -9
  723. package/dist-cjs/packages/lab/src/tooltip/Tooltip.css.js.map +0 -1
  724. package/dist-cjs/packages/lab/src/tooltip/Tooltip.js +0 -88
  725. package/dist-cjs/packages/lab/src/tooltip/Tooltip.js.map +0 -1
  726. package/dist-cjs/packages/lab/src/tooltip/TooltipContext.js +0 -26
  727. package/dist-cjs/packages/lab/src/tooltip/TooltipContext.js.map +0 -1
  728. package/dist-cjs/packages/lab/src/tooltip/useAriaAnnounce.js +0 -87
  729. package/dist-cjs/packages/lab/src/tooltip/useAriaAnnounce.js.map +0 -1
  730. package/dist-cjs/packages/lab/src/tooltip/useTooltip.js +0 -137
  731. package/dist-cjs/packages/lab/src/tooltip/useTooltip.js.map +0 -1
  732. package/dist-es/packages/lab/src/card/Card.css.js +0 -7
  733. package/dist-es/packages/lab/src/card/Card.css.js.map +0 -1
  734. package/dist-es/packages/lab/src/card/Card.js +0 -29
  735. package/dist-es/packages/lab/src/card/Card.js.map +0 -1
  736. package/dist-es/packages/lab/src/panel/Panel.css.js +0 -7
  737. package/dist-es/packages/lab/src/panel/Panel.css.js.map +0 -1
  738. package/dist-es/packages/lab/src/panel/Panel.js +0 -20
  739. package/dist-es/packages/lab/src/panel/Panel.js.map +0 -1
  740. package/dist-es/packages/lab/src/popper/useFloatingUI.js.map +0 -1
  741. package/dist-es/packages/lab/src/spinner/Spinner.css.js +0 -7
  742. package/dist-es/packages/lab/src/spinner/Spinner.css.js.map +0 -1
  743. package/dist-es/packages/lab/src/spinner/Spinner.js +0 -71
  744. package/dist-es/packages/lab/src/spinner/Spinner.js.map +0 -1
  745. package/dist-es/packages/lab/src/spinner/svgSpinners/SpinnerLarge.js +0 -67
  746. package/dist-es/packages/lab/src/spinner/svgSpinners/SpinnerLarge.js.map +0 -1
  747. package/dist-es/packages/lab/src/spinner/svgSpinners/SpinnerMedium.js +0 -67
  748. package/dist-es/packages/lab/src/spinner/svgSpinners/SpinnerMedium.js.map +0 -1
  749. package/dist-es/packages/lab/src/spinner/svgSpinners/SpinnerSmall.js +0 -67
  750. package/dist-es/packages/lab/src/spinner/svgSpinners/SpinnerSmall.js.map +0 -1
  751. package/dist-es/packages/lab/src/spinner/svgSpinners/index.js +0 -17
  752. package/dist-es/packages/lab/src/spinner/svgSpinners/index.js.map +0 -1
  753. package/dist-es/packages/lab/src/split-layout/SplitLayout.css.js +0 -7
  754. package/dist-es/packages/lab/src/split-layout/SplitLayout.css.js.map +0 -1
  755. package/dist-es/packages/lab/src/split-layout/SplitLayout.js +0 -36
  756. package/dist-es/packages/lab/src/split-layout/SplitLayout.js.map +0 -1
  757. package/dist-es/packages/lab/src/tooltip/Tooltip.css.js +0 -7
  758. package/dist-es/packages/lab/src/tooltip/Tooltip.css.js.map +0 -1
  759. package/dist-es/packages/lab/src/tooltip/Tooltip.js +0 -80
  760. package/dist-es/packages/lab/src/tooltip/Tooltip.js.map +0 -1
  761. package/dist-es/packages/lab/src/tooltip/TooltipContext.js +0 -21
  762. package/dist-es/packages/lab/src/tooltip/TooltipContext.js.map +0 -1
  763. package/dist-es/packages/lab/src/tooltip/useAriaAnnounce.js +0 -83
  764. package/dist-es/packages/lab/src/tooltip/useAriaAnnounce.js.map +0 -1
  765. package/dist-es/packages/lab/src/tooltip/useTooltip.js +0 -133
  766. package/dist-es/packages/lab/src/tooltip/useTooltip.js.map +0 -1
  767. package/dist-types/card/Card.d.ts +0 -18
  768. package/dist-types/card/index.d.ts +0 -1
  769. package/dist-types/panel/Panel.d.ts +0 -20
  770. package/dist-types/panel/index.d.ts +0 -1
  771. package/dist-types/popper/index.d.ts +0 -1
  772. package/dist-types/popper/useFloatingUI.d.ts +0 -5
  773. package/dist-types/spinner/Spinner.d.ts +0 -45
  774. package/dist-types/spinner/index.d.ts +0 -1
  775. package/dist-types/spinner/svgSpinners/SpinnerLarge.d.ts +0 -2
  776. package/dist-types/spinner/svgSpinners/SpinnerMedium.d.ts +0 -2
  777. package/dist-types/spinner/svgSpinners/SpinnerSmall.d.ts +0 -2
  778. package/dist-types/spinner/svgSpinners/index.d.ts +0 -2
  779. package/dist-types/split-layout/SplitLayout.d.ts +0 -32
  780. package/dist-types/split-layout/index.d.ts +0 -1
  781. package/dist-types/tooltip/Tooltip.d.ts +0 -37
  782. package/dist-types/tooltip/TooltipContext.d.ts +0 -22
  783. package/dist-types/tooltip/index.d.ts +0 -3
  784. package/dist-types/tooltip/useAriaAnnounce.d.ts +0 -9
  785. package/dist-types/tooltip/useTooltip.d.ts +0 -31
@@ -1 +1 @@
1
- {"version":3,"file":"StatusIndicator.js","sources":["../src/content-status/internal/StatusIndicator.tsx"],"sourcesContent":["import {\n makePrefixer,\n StatusIndicator as BaseStatusIndicator,\n StatusIndicatorProps as BaseStatusIndicatorProps,\n} from \"@salt-ds/core\";\nimport { ReactElement } from \"react\";\nimport cx from \"classnames\";\n\nimport { CircularProgress, CircularProgressProps } from \"../../progress\";\nimport { Spinner, SpinnerProps } from \"../../spinner\";\n\nexport interface StatusIndicatorProps\n extends Pick<SpinnerProps, \"disableAnnouncer\">,\n Pick<CircularProgressProps, \"unit\" | \"value\"> {\n title?: string;\n message?: string;\n CircularProgressProps?: Partial<CircularProgressProps>;\n SpinnerProps?: Partial<SpinnerProps>;\n id?: string;\n status?: BaseStatusIndicatorProps[\"status\"] | \"loading\";\n}\n\nconst withBaseName = makePrefixer(\"saltContentStatus\");\n\nexport function StatusIndicator({\n status = \"info\",\n disableAnnouncer,\n unit,\n value,\n title,\n message,\n CircularProgressProps: {\n className: circularProgressClassName,\n ...restCircularProgressProps\n } = {},\n SpinnerProps: { className: spinnerClassName, ...restSpinnerProps } = {},\n id,\n}: StatusIndicatorProps): ReactElement {\n if (status === \"loading\") {\n if (value !== undefined) {\n return (\n <CircularProgress\n aria-label={title || message}\n className={cx(\n withBaseName(\"determinateLoading\"),\n circularProgressClassName\n )}\n size=\"small\"\n unit={unit}\n value={value}\n {...restCircularProgressProps}\n />\n );\n }\n return (\n <Spinner\n className={cx(withBaseName(\"indeterminateLoading\"), spinnerClassName)}\n // Announcement of the content status is more useful than completion announcement from spinner\n completionAnnouncement={null}\n data-testid={`spinner-${id!}`}\n disableAnnouncer={disableAnnouncer}\n {...restSpinnerProps}\n />\n );\n }\n\n return (\n <BaseStatusIndicator\n status={status}\n data-jpmui-test={`icon-${status}-${id!}`}\n size={2}\n />\n );\n}\n"],"names":["BaseStatusIndicator"],"mappings":";;;;;;;AAsBA,MAAM,YAAA,GAAe,aAAa,mBAAmB,CAAA,CAAA;AAE9C,SAAS,eAAgB,CAAA;AAAA,EAC9B,MAAS,GAAA,MAAA;AAAA,EACT,gBAAA;AAAA,EACA,IAAA;AAAA,EACA,KAAA;AAAA,EACA,KAAA;AAAA,EACA,OAAA;AAAA,EACA,qBAAuB,EAAA;AAAA,IACrB,SAAW,EAAA,yBAAA;AAAA,IACR,GAAA,yBAAA;AAAA,MACD,EAAC;AAAA,EACL,cAAc,EAAE,SAAA,EAAW,gBAAqB,EAAA,GAAA,gBAAA,KAAqB,EAAC;AAAA,EACtE,EAAA;AACF,CAAuC,EAAA;AACrC,EAAA,IAAI,WAAW,SAAW,EAAA;AACxB,IAAA,IAAI,UAAU,KAAW,CAAA,EAAA;AACvB,MAAA,uBACG,GAAA,CAAA,gBAAA,EAAA;AAAA,QACC,cAAY,KAAS,IAAA,OAAA;AAAA,QACrB,SAAW,EAAA,EAAA;AAAA,UACT,aAAa,oBAAoB,CAAA;AAAA,UACjC,yBAAA;AAAA,SACF;AAAA,QACA,IAAK,EAAA,OAAA;AAAA,QACL,IAAA;AAAA,QACA,KAAA;AAAA,QACC,GAAG,yBAAA;AAAA,OACN,CAAA,CAAA;AAAA,KAEJ;AACA,IAAA,uBACG,GAAA,CAAA,OAAA,EAAA;AAAA,MACC,SAAW,EAAA,EAAA,CAAG,YAAa,CAAA,sBAAsB,GAAG,gBAAgB,CAAA;AAAA,MAEpE,sBAAwB,EAAA,IAAA;AAAA,MACxB,eAAa,CAAW,QAAA,EAAA,EAAA,CAAA,CAAA;AAAA,MACxB,gBAAA;AAAA,MACC,GAAG,gBAAA;AAAA,KACN,CAAA,CAAA;AAAA,GAEJ;AAEA,EAAA,uBACG,GAAA,CAAAA,iBAAA,EAAA;AAAA,IACC,MAAA;AAAA,IACA,iBAAA,EAAiB,QAAQ,MAAU,CAAA,CAAA,EAAA,EAAA,CAAA,CAAA;AAAA,IACnC,IAAM,EAAA,CAAA;AAAA,GACR,CAAA,CAAA;AAEJ;;;;"}
1
+ {"version":3,"file":"StatusIndicator.js","sources":["../src/content-status/internal/StatusIndicator.tsx"],"sourcesContent":["import {\n makePrefixer,\n StatusIndicator as BaseStatusIndicator,\n StatusIndicatorProps as BaseStatusIndicatorProps,\n Spinner,\n SpinnerProps,\n} from \"@salt-ds/core\";\nimport { ReactElement } from \"react\";\nimport { clsx } from \"clsx\";\n\nimport { CircularProgress, CircularProgressProps } from \"../../progress\";\n\nexport interface StatusIndicatorProps\n extends Pick<SpinnerProps, \"disableAnnouncer\">,\n Pick<CircularProgressProps, \"unit\" | \"value\"> {\n title?: string;\n message?: string;\n CircularProgressProps?: Partial<CircularProgressProps>;\n SpinnerProps?: Partial<SpinnerProps>;\n id?: string;\n status?: BaseStatusIndicatorProps[\"status\"] | \"loading\";\n}\n\nconst withBaseName = makePrefixer(\"saltContentStatus\");\n\nexport function StatusIndicator({\n status = \"info\",\n disableAnnouncer,\n unit,\n value,\n title,\n message,\n CircularProgressProps: {\n className: circularProgressClassName,\n ...restCircularProgressProps\n } = {},\n SpinnerProps: { className: spinnerClassName, ...restSpinnerProps } = {},\n id,\n}: StatusIndicatorProps): ReactElement {\n if (status === \"loading\") {\n if (value !== undefined) {\n return (\n <CircularProgress\n aria-label={title || message}\n className={clsx(\n withBaseName(\"determinateLoading\"),\n circularProgressClassName\n )}\n size=\"small\"\n unit={unit}\n value={value}\n {...restCircularProgressProps}\n />\n );\n }\n return (\n <Spinner\n className={clsx(withBaseName(\"indeterminateLoading\"), spinnerClassName)}\n // Announcement of the content status is more useful than completion announcement from spinner\n completionAnnouncement={null}\n data-testid={`spinner-${id!}`}\n disableAnnouncer={disableAnnouncer}\n {...restSpinnerProps}\n />\n );\n }\n\n return (\n <BaseStatusIndicator\n status={status}\n data-jpmui-test={`icon-${status}-${id!}`}\n size={2}\n />\n );\n}\n"],"names":["BaseStatusIndicator"],"mappings":";;;;;;AAuBA,MAAM,YAAA,GAAe,aAAa,mBAAmB,CAAA,CAAA;AAE9C,SAAS,eAAgB,CAAA;AAAA,EAC9B,MAAS,GAAA,MAAA;AAAA,EACT,gBAAA;AAAA,EACA,IAAA;AAAA,EACA,KAAA;AAAA,EACA,KAAA;AAAA,EACA,OAAA;AAAA,EACA,qBAAuB,EAAA;AAAA,IACrB,SAAW,EAAA,yBAAA;AAAA,IACR,GAAA,yBAAA;AAAA,MACD,EAAC;AAAA,EACL,cAAc,EAAE,SAAA,EAAW,gBAAqB,EAAA,GAAA,gBAAA,KAAqB,EAAC;AAAA,EACtE,EAAA;AACF,CAAuC,EAAA;AACrC,EAAA,IAAI,WAAW,SAAW,EAAA;AACxB,IAAA,IAAI,UAAU,KAAW,CAAA,EAAA;AACvB,MAAA,uBACG,GAAA,CAAA,gBAAA,EAAA;AAAA,QACC,cAAY,KAAS,IAAA,OAAA;AAAA,QACrB,SAAW,EAAA,IAAA;AAAA,UACT,aAAa,oBAAoB,CAAA;AAAA,UACjC,yBAAA;AAAA,SACF;AAAA,QACA,IAAK,EAAA,OAAA;AAAA,QACL,IAAA;AAAA,QACA,KAAA;AAAA,QACC,GAAG,yBAAA;AAAA,OACN,CAAA,CAAA;AAAA,KAEJ;AACA,IAAA,uBACG,GAAA,CAAA,OAAA,EAAA;AAAA,MACC,SAAW,EAAA,IAAA,CAAK,YAAa,CAAA,sBAAsB,GAAG,gBAAgB,CAAA;AAAA,MAEtE,sBAAwB,EAAA,IAAA;AAAA,MACxB,eAAa,CAAW,QAAA,EAAA,EAAA,CAAA,CAAA;AAAA,MACxB,gBAAA;AAAA,MACC,GAAG,gBAAA;AAAA,KACN,CAAA,CAAA;AAAA,GAEJ;AAEA,EAAA,uBACG,GAAA,CAAAA,iBAAA,EAAA;AAAA,IACC,MAAA;AAAA,IACA,iBAAA,EAAiB,QAAQ,MAAU,CAAA,CAAA,EAAA,EAAA,CAAA,CAAA;AAAA,IACnC,IAAM,EAAA,CAAA;AAAA,GACR,CAAA,CAAA;AAEJ;;;;"}
@@ -1,13 +1,13 @@
1
1
  import { jsxs, jsx } from 'react/jsx-runtime';
2
2
  import { forwardRef } from 'react';
3
- import cx from 'classnames';
3
+ import { clsx } from 'clsx';
4
4
  import './ControlLabel.css.js';
5
5
 
6
6
  const baseName = "saltControlLabel";
7
7
  const ControlLabel = forwardRef(
8
8
  ({ children, className, disabled, label, labelPlacement = "left", ...other }, ref) => {
9
9
  return /* @__PURE__ */ jsxs("label", {
10
- className: cx(
10
+ className: clsx(
11
11
  baseName,
12
12
  {
13
13
  [`${baseName}-disabled`]: disabled
@@ -1 +1 @@
1
- {"version":3,"file":"ControlLabel.js","sources":["../src/control-label/ControlLabel.tsx"],"sourcesContent":["// TODO Label positioning\nimport React, { forwardRef, LabelHTMLAttributes, ReactNode } from \"react\";\nimport classnames from \"classnames\";\n\nimport \"./ControlLabel.css\";\n\nexport interface ControlLabelProps\n extends LabelHTMLAttributes<HTMLLabelElement> {\n disabled?: boolean;\n label?: ReactNode;\n labelPlacement?: \"left\" | \"right\";\n}\n\nexport const baseName = \"saltControlLabel\";\n\nexport const ControlLabel = forwardRef<HTMLLabelElement, ControlLabelProps>(\n (\n { children, className, disabled, label, labelPlacement = \"left\", ...other },\n ref\n ) => {\n return (\n <label\n className={classnames(\n baseName,\n {\n [`${baseName}-disabled`]: disabled,\n },\n className\n )}\n ref={ref}\n {...other}\n >\n {labelPlacement === \"left\" && (\n <span className={`${baseName}-label`}>{label}</span>\n )}\n {children}\n {labelPlacement === \"right\" && (\n <span className={`${baseName}-labelRight`}>{label}</span>\n )}\n </label>\n );\n }\n);\n"],"names":["classnames"],"mappings":";;;;;AAaO,MAAM,QAAW,GAAA,mBAAA;AAEjB,MAAM,YAAe,GAAA,UAAA;AAAA,EAC1B,CACE,EAAE,QAAA,EAAU,SAAW,EAAA,QAAA,EAAU,OAAO,cAAiB,GAAA,MAAA,EAAA,GAAW,KAAM,EAAA,EAC1E,GACG,KAAA;AACH,IAAA,uBACG,IAAA,CAAA,OAAA,EAAA;AAAA,MACC,SAAW,EAAAA,EAAA;AAAA,QACT,QAAA;AAAA,QACA;AAAA,UACE,CAAC,GAAG,QAAsB,CAAA,SAAA,CAAA,GAAA,QAAA;AAAA,SAC5B;AAAA,QACA,SAAA;AAAA,OACF;AAAA,MACA,GAAA;AAAA,MACC,GAAG,KAAA;AAAA,MAEH,QAAA,EAAA;AAAA,QAAA,cAAA,KAAmB,0BACjB,GAAA,CAAA,MAAA,EAAA;AAAA,UAAK,WAAW,CAAG,EAAA,QAAA,CAAA,MAAA,CAAA;AAAA,UAAmB,QAAA,EAAA,KAAA;AAAA,SAAM,CAAA;AAAA,QAE9C,QAAA;AAAA,QACA,cAAA,KAAmB,2BACjB,GAAA,CAAA,MAAA,EAAA;AAAA,UAAK,WAAW,CAAG,EAAA,QAAA,CAAA,WAAA,CAAA;AAAA,UAAwB,QAAA,EAAA,KAAA;AAAA,SAAM,CAAA;AAAA,OAAA;AAAA,KAEtD,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
1
+ {"version":3,"file":"ControlLabel.js","sources":["../src/control-label/ControlLabel.tsx"],"sourcesContent":["// TODO Label positioning\nimport React, { forwardRef, LabelHTMLAttributes, ReactNode } from \"react\";\nimport { clsx } from \"clsx\";\n\nimport \"./ControlLabel.css\";\n\nexport interface ControlLabelProps\n extends LabelHTMLAttributes<HTMLLabelElement> {\n disabled?: boolean;\n label?: ReactNode;\n labelPlacement?: \"left\" | \"right\";\n}\n\nexport const baseName = \"saltControlLabel\";\n\nexport const ControlLabel = forwardRef<HTMLLabelElement, ControlLabelProps>(\n (\n { children, className, disabled, label, labelPlacement = \"left\", ...other },\n ref\n ) => {\n return (\n <label\n className={clsx(\n baseName,\n {\n [`${baseName}-disabled`]: disabled,\n },\n className\n )}\n ref={ref}\n {...other}\n >\n {labelPlacement === \"left\" && (\n <span className={`${baseName}-label`}>{label}</span>\n )}\n {children}\n {labelPlacement === \"right\" && (\n <span className={`${baseName}-labelRight`}>{label}</span>\n )}\n </label>\n );\n }\n);\n"],"names":[],"mappings":";;;;;AAaO,MAAM,QAAW,GAAA,mBAAA;AAEjB,MAAM,YAAe,GAAA,UAAA;AAAA,EAC1B,CACE,EAAE,QAAA,EAAU,SAAW,EAAA,QAAA,EAAU,OAAO,cAAiB,GAAA,MAAA,EAAA,GAAW,KAAM,EAAA,EAC1E,GACG,KAAA;AACH,IAAA,uBACG,IAAA,CAAA,OAAA,EAAA;AAAA,MACC,SAAW,EAAA,IAAA;AAAA,QACT,QAAA;AAAA,QACA;AAAA,UACE,CAAC,GAAG,QAAsB,CAAA,SAAA,CAAA,GAAA,QAAA;AAAA,SAC5B;AAAA,QACA,SAAA;AAAA,OACF;AAAA,MACA,GAAA;AAAA,MACC,GAAG,KAAA;AAAA,MAEH,QAAA,EAAA;AAAA,QAAA,cAAA,KAAmB,0BACjB,GAAA,CAAA,MAAA,EAAA;AAAA,UAAK,WAAW,CAAG,EAAA,QAAA,CAAA,MAAA,CAAA;AAAA,UAAmB,QAAA,EAAA,KAAA;AAAA,SAAM,CAAA;AAAA,QAE9C,QAAA;AAAA,QACA,cAAA,KAAmB,2BACjB,GAAA,CAAA,MAAA,EAAA;AAAA,UAAK,WAAW,CAAG,EAAA,QAAA,CAAA,WAAA,CAAA;AAAA,UAAwB,QAAA,EAAA,KAAA;AAAA,SAAM,CAAA;AAAA,OAAA;AAAA,KAEtD,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
@@ -1,5 +1,5 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
- import cx from 'classnames';
2
+ import { clsx } from 'clsx';
3
3
  import { forwardRef, useRef, useMemo } from 'react';
4
4
  import { makePrefixer, useId, useForkRef } from '@salt-ds/core';
5
5
  import './DeckItem.css.js';
@@ -28,7 +28,7 @@ const DeckItem = forwardRef(
28
28
  ];
29
29
  const id = useId(idProp);
30
30
  return /* @__PURE__ */ jsx("div", {
31
- className: cx(
31
+ className: clsx(
32
32
  withBaseName(),
33
33
  withBaseName(`${animation ? animation : "static"}-${position}`),
34
34
  {
@@ -1 +1 @@
1
- {"version":3,"file":"DeckItem.js","sources":["../src/deck-item/DeckItem.tsx"],"sourcesContent":["import cx from \"classnames\";\nimport { forwardRef, HTMLAttributes, useMemo, useRef } from \"react\";\nimport { makePrefixer, useForkRef, useId } from \"@salt-ds/core\";\nimport { LayoutAnimation } from \"../deck-layout\";\nimport \"./DeckItem.css\";\n\nconst withBaseName = makePrefixer(\"saltDeckItem\");\n\nexport interface DeckItemProps extends HTMLAttributes<HTMLDivElement> {\n activeIndex?: number;\n animation?: LayoutAnimation;\n index: number;\n role?: string;\n}\n\nexport const DeckItem = forwardRef<HTMLDivElement, DeckItemProps>(\n function DeckItem(\n {\n activeIndex = 0,\n animation,\n children,\n className,\n index,\n role = \"group\",\n id: idProp,\n ...rest\n },\n ref\n ) {\n const sliderRef = useRef<HTMLDivElement | null>(null);\n\n const isCurrent = activeIndex === index;\n\n const position = useMemo(() => {\n return isCurrent ? \"current\" : activeIndex < index ? \"next\" : \"previous\";\n }, [activeIndex, index, isCurrent]);\n\n const classesIndex = animation && position === \"current\" ? 0 : 1;\n\n const getActiveClasses = [\n `${animation || \"fade\"}-in`, // in-right\n `${animation || \"fade\"}-out`, // out-left\n ];\n\n const id = useId(idProp);\n\n return (\n <div\n className={cx(\n withBaseName(),\n withBaseName(`${animation ? animation : \"static\"}-${position}`),\n {\n [withBaseName(getActiveClasses[classesIndex])]:\n animation === \"fade\",\n },\n className\n )}\n ref={useForkRef(ref, sliderRef)}\n role={role}\n tabIndex={isCurrent ? 0 : -1}\n id={id}\n {...rest}\n >\n {children}\n </div>\n );\n }\n);\n"],"names":["DeckItem"],"mappings":";;;;;;AAMA,MAAM,YAAA,GAAe,aAAa,cAAc,CAAA,CAAA;AASzC,MAAM,QAAW,GAAA,UAAA;AAAA,EACtB,SAASA,SACP,CAAA;AAAA,IACE,WAAc,GAAA,CAAA;AAAA,IACd,SAAA;AAAA,IACA,QAAA;AAAA,IACA,SAAA;AAAA,IACA,KAAA;AAAA,IACA,IAAO,GAAA,OAAA;AAAA,IACP,EAAI,EAAA,MAAA;AAAA,IACD,GAAA,IAAA;AAAA,KAEL,GACA,EAAA;AACA,IAAM,MAAA,SAAA,GAAY,OAA8B,IAAI,CAAA,CAAA;AAEpD,IAAA,MAAM,YAAY,WAAgB,KAAA,KAAA,CAAA;AAElC,IAAM,MAAA,QAAA,GAAW,QAAQ,MAAM;AAC7B,MAAA,OAAO,SAAY,GAAA,SAAA,GAAY,WAAc,GAAA,KAAA,GAAQ,MAAS,GAAA,UAAA,CAAA;AAAA,KAC7D,EAAA,CAAC,WAAa,EAAA,KAAA,EAAO,SAAS,CAAC,CAAA,CAAA;AAElC,IAAA,MAAM,YAAe,GAAA,SAAA,IAAa,QAAa,KAAA,SAAA,GAAY,CAAI,GAAA,CAAA,CAAA;AAE/D,IAAA,MAAM,gBAAmB,GAAA;AAAA,MACvB,GAAG,SAAa,IAAA,MAAA,CAAA,GAAA,CAAA;AAAA,MAChB,GAAG,SAAa,IAAA,MAAA,CAAA,IAAA,CAAA;AAAA,KAClB,CAAA;AAEA,IAAM,MAAA,EAAA,GAAK,MAAM,MAAM,CAAA,CAAA;AAEvB,IAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,MACC,SAAW,EAAA,EAAA;AAAA,QACT,YAAa,EAAA;AAAA,QACb,YAAa,CAAA,CAAA,EAAG,SAAY,GAAA,SAAA,GAAY,YAAY,QAAU,CAAA,CAAA,CAAA;AAAA,QAC9D;AAAA,UACE,CAAC,YAAA,CAAa,gBAAiB,CAAA,YAAA,CAAa,IAC1C,SAAc,KAAA,MAAA;AAAA,SAClB;AAAA,QACA,SAAA;AAAA,OACF;AAAA,MACA,GAAA,EAAK,UAAW,CAAA,GAAA,EAAK,SAAS,CAAA;AAAA,MAC9B,IAAA;AAAA,MACA,QAAA,EAAU,YAAY,CAAI,GAAA,CAAA,CAAA;AAAA,MAC1B,EAAA;AAAA,MACC,GAAG,IAAA;AAAA,MAEH,QAAA;AAAA,KACH,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
1
+ {"version":3,"file":"DeckItem.js","sources":["../src/deck-item/DeckItem.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport { forwardRef, HTMLAttributes, useMemo, useRef } from \"react\";\nimport { makePrefixer, useForkRef, useId } from \"@salt-ds/core\";\nimport { LayoutAnimation } from \"../deck-layout\";\nimport \"./DeckItem.css\";\n\nconst withBaseName = makePrefixer(\"saltDeckItem\");\n\nexport interface DeckItemProps extends HTMLAttributes<HTMLDivElement> {\n activeIndex?: number;\n animation?: LayoutAnimation;\n index: number;\n role?: string;\n}\n\nexport const DeckItem = forwardRef<HTMLDivElement, DeckItemProps>(\n function DeckItem(\n {\n activeIndex = 0,\n animation,\n children,\n className,\n index,\n role = \"group\",\n id: idProp,\n ...rest\n },\n ref\n ) {\n const sliderRef = useRef<HTMLDivElement | null>(null);\n\n const isCurrent = activeIndex === index;\n\n const position = useMemo(() => {\n return isCurrent ? \"current\" : activeIndex < index ? \"next\" : \"previous\";\n }, [activeIndex, index, isCurrent]);\n\n const classesIndex = animation && position === \"current\" ? 0 : 1;\n\n const getActiveClasses = [\n `${animation || \"fade\"}-in`, // in-right\n `${animation || \"fade\"}-out`, // out-left\n ];\n\n const id = useId(idProp);\n\n return (\n <div\n className={clsx(\n withBaseName(),\n withBaseName(`${animation ? animation : \"static\"}-${position}`),\n {\n [withBaseName(getActiveClasses[classesIndex])]:\n animation === \"fade\",\n },\n className\n )}\n ref={useForkRef(ref, sliderRef)}\n role={role}\n tabIndex={isCurrent ? 0 : -1}\n id={id}\n {...rest}\n >\n {children}\n </div>\n );\n }\n);\n"],"names":["DeckItem"],"mappings":";;;;;;AAMA,MAAM,YAAA,GAAe,aAAa,cAAc,CAAA,CAAA;AASzC,MAAM,QAAW,GAAA,UAAA;AAAA,EACtB,SAASA,SACP,CAAA;AAAA,IACE,WAAc,GAAA,CAAA;AAAA,IACd,SAAA;AAAA,IACA,QAAA;AAAA,IACA,SAAA;AAAA,IACA,KAAA;AAAA,IACA,IAAO,GAAA,OAAA;AAAA,IACP,EAAI,EAAA,MAAA;AAAA,IACD,GAAA,IAAA;AAAA,KAEL,GACA,EAAA;AACA,IAAM,MAAA,SAAA,GAAY,OAA8B,IAAI,CAAA,CAAA;AAEpD,IAAA,MAAM,YAAY,WAAgB,KAAA,KAAA,CAAA;AAElC,IAAM,MAAA,QAAA,GAAW,QAAQ,MAAM;AAC7B,MAAA,OAAO,SAAY,GAAA,SAAA,GAAY,WAAc,GAAA,KAAA,GAAQ,MAAS,GAAA,UAAA,CAAA;AAAA,KAC7D,EAAA,CAAC,WAAa,EAAA,KAAA,EAAO,SAAS,CAAC,CAAA,CAAA;AAElC,IAAA,MAAM,YAAe,GAAA,SAAA,IAAa,QAAa,KAAA,SAAA,GAAY,CAAI,GAAA,CAAA,CAAA;AAE/D,IAAA,MAAM,gBAAmB,GAAA;AAAA,MACvB,GAAG,SAAa,IAAA,MAAA,CAAA,GAAA,CAAA;AAAA,MAChB,GAAG,SAAa,IAAA,MAAA,CAAA,IAAA,CAAA;AAAA,KAClB,CAAA;AAEA,IAAM,MAAA,EAAA,GAAK,MAAM,MAAM,CAAA,CAAA;AAEvB,IAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,MACC,SAAW,EAAA,IAAA;AAAA,QACT,YAAa,EAAA;AAAA,QACb,YAAa,CAAA,CAAA,EAAG,SAAY,GAAA,SAAA,GAAY,YAAY,QAAU,CAAA,CAAA,CAAA;AAAA,QAC9D;AAAA,UACE,CAAC,YAAA,CAAa,gBAAiB,CAAA,YAAA,CAAa,IAC1C,SAAc,KAAA,MAAA;AAAA,SAClB;AAAA,QACA,SAAA;AAAA,OACF;AAAA,MACA,GAAA,EAAK,UAAW,CAAA,GAAA,EAAK,SAAS,CAAA;AAAA,MAC9B,IAAA;AAAA,MACA,QAAA,EAAU,YAAY,CAAI,GAAA,CAAA,CAAA;AAAA,MAC1B,EAAA;AAAA,MACC,GAAG,IAAA;AAAA,MAEH,QAAA;AAAA,KACH,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
@@ -3,9 +3,10 @@ import { forwardRef, useState, useCallback, Children } from 'react';
3
3
  import { makePrefixer, useIsomorphicLayoutEffect } from '@salt-ds/core';
4
4
  import { DeckItem } from '../deck-item/DeckItem.js';
5
5
  import '../responsive/useResizeObserver.js';
6
+ import '../utils/useFloatingUI.js';
6
7
  import { useWidth } from '../responsive/useWidth.js';
7
8
  import './DeckLayout.css.js';
8
- import cx from 'classnames';
9
+ import { clsx } from 'clsx';
9
10
 
10
11
  const withBaseName = makePrefixer("saltDeckLayout");
11
12
  const DeckLayout = forwardRef(
@@ -51,12 +52,12 @@ const DeckLayout = forwardRef(
51
52
  "--deckLayout-transform-value": `-${activeIndex * 100}%`
52
53
  };
53
54
  return /* @__PURE__ */ jsx("div", {
54
- className: cx(withBaseName(), className),
55
+ className: clsx(withBaseName(), className),
55
56
  style: deckLayoutStyles,
56
57
  ref,
57
58
  ...rest,
58
59
  children: /* @__PURE__ */ jsx("div", {
59
- className: cx(
60
+ className: clsx(
60
61
  {
61
62
  [withBaseName("animate")]: animation
62
63
  },
@@ -1 +1 @@
1
- {"version":3,"file":"DeckLayout.js","sources":["../src/deck-layout/DeckLayout.tsx"],"sourcesContent":["import {\n Children,\n forwardRef,\n HTMLAttributes,\n useState,\n useCallback,\n CSSProperties,\n} from \"react\";\nimport { makePrefixer, useIsomorphicLayoutEffect } from \"@salt-ds/core\";\nimport { DeckItem, DeckItemProps } from \"../deck-item\";\nimport { useWidth } from \"../responsive\";\nimport \"./DeckLayout.css\";\n\nimport cx from \"classnames\";\n\nexport type LayoutAnimation = \"slide\" | \"fade\";\nexport type LayoutAnimationDirection = \"horizontal\" | \"vertical\";\nexport type LayoutAnimationTransition = \"increase\" | \"decrease\";\n\nexport interface DeckLayoutProps extends HTMLAttributes<HTMLDivElement> {\n /**\n * The initial item to render.\n **/\n activeIndex?: number;\n /**\n * The animation when the slides are shown.\n **/\n animation?: LayoutAnimation;\n /**\n * The direction in which items will transition.\n **/\n direction?: LayoutAnimationDirection;\n /**\n * Props to be passed to the DeckItem component.\n */\n deckItemProps?: Partial<DeckItemProps>;\n}\n\nconst withBaseName = makePrefixer(\"saltDeckLayout\");\n\nexport const DeckLayout = forwardRef<HTMLDivElement, DeckLayoutProps>(\n function DeckLayout(\n {\n activeIndex = 0,\n animation,\n className,\n children,\n direction = \"horizontal\",\n style,\n deckItemProps,\n ...rest\n },\n ref\n ) {\n const [deckItemRef, deckItemWidth] = useWidth<HTMLDivElement>(true);\n\n const [deckItemHeight, setDeckItemHeight] = useState<number>(0);\n\n const handleResize = useCallback(function handleResize(\n contentRect: DOMRect\n ) {\n setDeckItemHeight(contentRect.height);\n },\n []);\n\n useIsomorphicLayoutEffect(() => {\n if (!deckItemRef.current) {\n return undefined;\n }\n\n handleResize(deckItemRef.current.getBoundingClientRect());\n\n const observer = new ResizeObserver(\n ([{ contentRect }]: ResizeObserverEntry[]) => {\n handleResize(contentRect);\n }\n );\n observer.observe(deckItemRef.current);\n\n return () => {\n observer.disconnect();\n };\n }, [deckItemRef, handleResize]);\n\n const deckLayoutStyles = {\n ...style,\n \"--deckLayout-width\": `${deckItemWidth}px`,\n \"--deckLayout-height\": `${deckItemHeight}px`,\n };\n\n const innerStyles = {\n \"--deckLayout-transform-value\": `-${activeIndex * 100}%`,\n } as CSSProperties;\n\n return (\n <div\n className={cx(withBaseName(), className)}\n style={deckLayoutStyles}\n ref={ref}\n {...rest}\n >\n <div\n className={cx(\n {\n [withBaseName(\"animate\")]: animation,\n },\n {\n [withBaseName(`${animation || \"slide\"}-${direction}`)]: animation,\n }\n )}\n style={innerStyles}\n >\n {Children.map(children, (child, index) => {\n return (\n <DeckItem\n ref={deckItemRef}\n index={index}\n activeIndex={activeIndex}\n animation={animation}\n {...deckItemProps}\n >\n {child}\n </DeckItem>\n );\n })}\n </div>\n </div>\n );\n }\n);\n"],"names":["DeckLayout","handleResize"],"mappings":"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"}
1
+ {"version":3,"file":"DeckLayout.js","sources":["../src/deck-layout/DeckLayout.tsx"],"sourcesContent":["import {\n Children,\n forwardRef,\n HTMLAttributes,\n useState,\n useCallback,\n CSSProperties,\n} from \"react\";\nimport { makePrefixer, useIsomorphicLayoutEffect } from \"@salt-ds/core\";\nimport { DeckItem, DeckItemProps } from \"../deck-item\";\nimport { useWidth } from \"../responsive\";\nimport \"./DeckLayout.css\";\n\nimport { clsx } from \"clsx\";\n\nexport type LayoutAnimation = \"slide\" | \"fade\";\nexport type LayoutAnimationDirection = \"horizontal\" | \"vertical\";\nexport type LayoutAnimationTransition = \"increase\" | \"decrease\";\n\nexport interface DeckLayoutProps extends HTMLAttributes<HTMLDivElement> {\n /**\n * The initial item to render.\n **/\n activeIndex?: number;\n /**\n * The animation when the slides are shown.\n **/\n animation?: LayoutAnimation;\n /**\n * The direction in which items will transition.\n **/\n direction?: LayoutAnimationDirection;\n /**\n * Props to be passed to the DeckItem component.\n */\n deckItemProps?: Partial<DeckItemProps>;\n}\n\nconst withBaseName = makePrefixer(\"saltDeckLayout\");\n\nexport const DeckLayout = forwardRef<HTMLDivElement, DeckLayoutProps>(\n function DeckLayout(\n {\n activeIndex = 0,\n animation,\n className,\n children,\n direction = \"horizontal\",\n style,\n deckItemProps,\n ...rest\n },\n ref\n ) {\n const [deckItemRef, deckItemWidth] = useWidth<HTMLDivElement>(true);\n\n const [deckItemHeight, setDeckItemHeight] = useState<number>(0);\n\n const handleResize = useCallback(function handleResize(\n contentRect: DOMRect\n ) {\n setDeckItemHeight(contentRect.height);\n },\n []);\n\n useIsomorphicLayoutEffect(() => {\n if (!deckItemRef.current) {\n return undefined;\n }\n\n handleResize(deckItemRef.current.getBoundingClientRect());\n\n const observer = new ResizeObserver(\n ([{ contentRect }]: ResizeObserverEntry[]) => {\n handleResize(contentRect);\n }\n );\n observer.observe(deckItemRef.current);\n\n return () => {\n observer.disconnect();\n };\n }, [deckItemRef, handleResize]);\n\n const deckLayoutStyles = {\n ...style,\n \"--deckLayout-width\": `${deckItemWidth}px`,\n \"--deckLayout-height\": `${deckItemHeight}px`,\n };\n\n const innerStyles = {\n \"--deckLayout-transform-value\": `-${activeIndex * 100}%`,\n } as CSSProperties;\n\n return (\n <div\n className={clsx(withBaseName(), className)}\n style={deckLayoutStyles}\n ref={ref}\n {...rest}\n >\n <div\n className={clsx(\n {\n [withBaseName(\"animate\")]: animation,\n },\n {\n [withBaseName(`${animation || \"slide\"}-${direction}`)]: animation,\n }\n )}\n style={innerStyles}\n >\n {Children.map(children, (child, index) => {\n return (\n <DeckItem\n ref={deckItemRef}\n index={index}\n activeIndex={activeIndex}\n animation={animation}\n {...deckItemProps}\n >\n {child}\n </DeckItem>\n );\n })}\n </div>\n </div>\n );\n }\n);\n"],"names":["DeckLayout","handleResize"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
2
  import { makePrefixer, useId } from '@salt-ds/core';
3
- import cx from 'classnames';
3
+ import { clsx } from 'clsx';
4
4
  import { forwardRef, useState, useEffect, useCallback, useRef } from 'react';
5
5
  import { DialogContext } from './internal/DialogContext.js';
6
6
  import { Scrim } from '../scrim/Scrim.js';
@@ -65,7 +65,7 @@ const Dialog = forwardRef(function Dialog2(props, ref) {
65
65
  id,
66
66
  children: /* @__PURE__ */ jsx("div", {
67
67
  ...rest,
68
- className: cx(withBaseName(), className, {
68
+ className: clsx(withBaseName(), className, {
69
69
  [withBaseName("infoShadow")]: status === "info"
70
70
  }),
71
71
  style: { width },
@@ -1 +1 @@
1
- {"version":3,"file":"Dialog.js","sources":["../src/dialog/Dialog.tsx"],"sourcesContent":["import { makePrefixer, useId, ValidationStatus } from \"@salt-ds/core\";\nimport classnames from \"classnames\";\nimport {\n forwardRef,\n HTMLAttributes,\n useCallback,\n useEffect,\n useRef,\n useState,\n} from \"react\";\nimport { DialogContext } from \"./internal/DialogContext\";\nimport { Scrim, ScrimProps } from \"../scrim\";\nimport { useWindow } from \"../window\";\nimport { Portal } from \"../portal\";\n\nimport \"./Dialog.css\";\n\nexport interface DialogProps extends HTMLAttributes<HTMLDivElement> {\n autoFocusRef?: ScrimProps[\"autoFocusRef\"];\n height?: string | number;\n onClose?: () => void;\n open?: boolean;\n status?: ValidationStatus;\n width?: string | number;\n enableBackdropClick?: boolean;\n disablePortal?: boolean;\n}\n\nconst withBaseName = makePrefixer(\"saltDialog\");\n\n/**\n * The Dialog is a window that contains text and interactive components.\n * By default, Dialog is non-modal, but supports modal behaviour as well.\n */\nexport const Dialog = forwardRef<HTMLDivElement, DialogProps>(function Dialog(\n props,\n ref\n) {\n const {\n autoFocusRef,\n children,\n className,\n height,\n id,\n onClose,\n open: openProp,\n status,\n width,\n enableBackdropClick,\n disablePortal,\n ...rest\n } = props;\n\n const Window = useWindow();\n const [open, setOpen] = useState(openProp);\n\n useEffect(() => {\n setOpen(openProp);\n }, [openProp]);\n\n const dialogId = useId();\n\n const handleClose = useCallback(() => {\n onClose?.();\n setOpen(false);\n }, [onClose, setOpen]);\n\n const handleBackdropClick = useCallback(() => {\n if (enableBackdropClick) {\n handleClose();\n }\n }, [enableBackdropClick, handleClose]);\n\n const contentElementRef = useRef<HTMLDivElement | null>(null);\n\n const setContentElement = useCallback((node: HTMLDivElement) => {\n contentElementRef.current = node;\n }, []);\n\n if (!open) {\n return null;\n }\n\n return (\n <DialogContext.Provider value={{ status, dialogId, setContentElement }}>\n <Portal disablePortal={disablePortal}>\n <Scrim\n autoFocusRef={autoFocusRef}\n fallbackFocusRef={contentElementRef}\n open={open}\n closeWithEscape\n onBackDropClick={handleBackdropClick}\n onClose={handleClose}\n aria-labelledby={`${dialogId}-heading`}\n aria-describedby={`${dialogId}-body`}\n >\n <Window id={id}>\n <div\n {...rest}\n className={classnames(withBaseName(), className, {\n [withBaseName(\"infoShadow\")]: status === \"info\",\n })}\n style={{ width }}\n ref={ref}\n >\n {children}\n </div>\n </Window>\n </Scrim>\n </Portal>\n </DialogContext.Provider>\n );\n});\n"],"names":["Dialog","classnames"],"mappings":"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"}
1
+ {"version":3,"file":"Dialog.js","sources":["../src/dialog/Dialog.tsx"],"sourcesContent":["import { makePrefixer, useId, ValidationStatus } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport {\n forwardRef,\n HTMLAttributes,\n useCallback,\n useEffect,\n useRef,\n useState,\n} from \"react\";\nimport { DialogContext } from \"./internal/DialogContext\";\nimport { Scrim, ScrimProps } from \"../scrim\";\nimport { useWindow } from \"../window\";\nimport { Portal } from \"../portal\";\n\nimport \"./Dialog.css\";\n\nexport interface DialogProps extends HTMLAttributes<HTMLDivElement> {\n autoFocusRef?: ScrimProps[\"autoFocusRef\"];\n height?: string | number;\n onClose?: () => void;\n open?: boolean;\n status?: ValidationStatus;\n width?: string | number;\n enableBackdropClick?: boolean;\n disablePortal?: boolean;\n}\n\nconst withBaseName = makePrefixer(\"saltDialog\");\n\n/**\n * The Dialog is a window that contains text and interactive components.\n * By default, Dialog is non-modal, but supports modal behaviour as well.\n */\nexport const Dialog = forwardRef<HTMLDivElement, DialogProps>(function Dialog(\n props,\n ref\n) {\n const {\n autoFocusRef,\n children,\n className,\n height,\n id,\n onClose,\n open: openProp,\n status,\n width,\n enableBackdropClick,\n disablePortal,\n ...rest\n } = props;\n\n const Window = useWindow();\n const [open, setOpen] = useState(openProp);\n\n useEffect(() => {\n setOpen(openProp);\n }, [openProp]);\n\n const dialogId = useId();\n\n const handleClose = useCallback(() => {\n onClose?.();\n setOpen(false);\n }, [onClose, setOpen]);\n\n const handleBackdropClick = useCallback(() => {\n if (enableBackdropClick) {\n handleClose();\n }\n }, [enableBackdropClick, handleClose]);\n\n const contentElementRef = useRef<HTMLDivElement | null>(null);\n\n const setContentElement = useCallback((node: HTMLDivElement) => {\n contentElementRef.current = node;\n }, []);\n\n if (!open) {\n return null;\n }\n\n return (\n <DialogContext.Provider value={{ status, dialogId, setContentElement }}>\n <Portal disablePortal={disablePortal}>\n <Scrim\n autoFocusRef={autoFocusRef}\n fallbackFocusRef={contentElementRef}\n open={open}\n closeWithEscape\n onBackDropClick={handleBackdropClick}\n onClose={handleClose}\n aria-labelledby={`${dialogId}-heading`}\n aria-describedby={`${dialogId}-body`}\n >\n <Window id={id}>\n <div\n {...rest}\n className={clsx(withBaseName(), className, {\n [withBaseName(\"infoShadow\")]: status === \"info\",\n })}\n style={{ width }}\n ref={ref}\n >\n {children}\n </div>\n </Window>\n </Scrim>\n </Portal>\n </DialogContext.Provider>\n );\n});\n"],"names":["Dialog"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
2
  import { forwardRef } from 'react';
3
- import cx from 'classnames';
3
+ import { clsx } from 'clsx';
4
4
  import { makePrefixer } from '@salt-ds/core';
5
5
  import './DialogActions.css.js';
6
6
 
@@ -10,7 +10,7 @@ const DialogActions = forwardRef(
10
10
  const { className, children, ...rest } = props;
11
11
  return /* @__PURE__ */ jsx("div", {
12
12
  ...rest,
13
- className: cx(withBaseName(), className),
13
+ className: clsx(withBaseName(), className),
14
14
  ref,
15
15
  children
16
16
  });
@@ -1 +1 @@
1
- {"version":3,"file":"DialogActions.js","sources":["../src/dialog/DialogActions.tsx"],"sourcesContent":["import { forwardRef, HTMLAttributes } from \"react\";\nimport classnames from \"classnames\";\nimport { makePrefixer } from \"@salt-ds/core\";\n\nimport \"./DialogActions.css\";\n\nexport interface DialogActionsProps extends HTMLAttributes<HTMLDivElement> {}\n\nconst withBaseName = makePrefixer(\"saltDialogActions\");\n\nexport const DialogActions = forwardRef<HTMLDivElement, DialogActionsProps>(\n function DialogActions(props, ref) {\n const { className, children, ...rest } = props;\n\n return (\n <div\n {...rest}\n className={classnames(withBaseName(), className)}\n ref={ref}\n >\n {children}\n </div>\n );\n }\n);\n"],"names":["DialogActions","classnames"],"mappings":";;;;;;AAQA,MAAM,YAAA,GAAe,aAAa,mBAAmB,CAAA,CAAA;AAE9C,MAAM,aAAgB,GAAA,UAAA;AAAA,EAC3B,SAASA,cAAc,CAAA,KAAA,EAAO,GAAK,EAAA;AACjC,IAAA,MAAM,EAAE,SAAA,EAAW,QAAa,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AAEzC,IAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,MACE,GAAG,IAAA;AAAA,MACJ,SAAW,EAAAC,EAAA,CAAW,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,MAC/C,GAAA;AAAA,MAEC,QAAA;AAAA,KACH,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
1
+ {"version":3,"file":"DialogActions.js","sources":["../src/dialog/DialogActions.tsx"],"sourcesContent":["import { forwardRef, HTMLAttributes } from \"react\";\nimport { clsx } from \"clsx\";\nimport { makePrefixer } from \"@salt-ds/core\";\n\nimport \"./DialogActions.css\";\n\nexport interface DialogActionsProps extends HTMLAttributes<HTMLDivElement> {}\n\nconst withBaseName = makePrefixer(\"saltDialogActions\");\n\nexport const DialogActions = forwardRef<HTMLDivElement, DialogActionsProps>(\n function DialogActions(props, ref) {\n const { className, children, ...rest } = props;\n\n return (\n <div {...rest} className={clsx(withBaseName(), className)} ref={ref}>\n {children}\n </div>\n );\n }\n);\n"],"names":["DialogActions"],"mappings":";;;;;;AAQA,MAAM,YAAA,GAAe,aAAa,mBAAmB,CAAA,CAAA;AAE9C,MAAM,aAAgB,GAAA,UAAA;AAAA,EAC3B,SAASA,cAAc,CAAA,KAAA,EAAO,GAAK,EAAA;AACjC,IAAA,MAAM,EAAE,SAAA,EAAW,QAAa,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AAEzC,IAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,MAAK,GAAG,IAAA;AAAA,MAAM,SAAW,EAAA,IAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,MAAG,GAAA;AAAA,MACxD,QAAA;AAAA,KACH,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
@@ -1,6 +1,6 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
2
  import { makePrefixer, useForkRef } from '@salt-ds/core';
3
- import cx from 'classnames';
3
+ import { clsx } from 'clsx';
4
4
  import { forwardRef, useContext } from 'react';
5
5
  import { DialogContext } from './internal/DialogContext.js';
6
6
  import './DialogContent.css.js';
@@ -13,7 +13,7 @@ const DialogContent = forwardRef(
13
13
  const handleRef = useForkRef(ref, setContentElement);
14
14
  return /* @__PURE__ */ jsx("div", {
15
15
  ...rest,
16
- className: cx(
16
+ className: clsx(
17
17
  withBaseName(),
18
18
  className,
19
19
  {
@@ -1 +1 @@
1
- {"version":3,"file":"DialogContent.js","sources":["../src/dialog/DialogContent.tsx"],"sourcesContent":["import { makePrefixer, useForkRef } from \"@salt-ds/core\";\nimport classnames from \"classnames\";\nimport { forwardRef, HTMLAttributes, useContext } from \"react\";\nimport { DialogContext } from \"./internal/DialogContext\";\n\nimport \"./DialogContent.css\";\n\nexport interface DialogContentProps extends HTMLAttributes<HTMLDivElement> {}\n\nconst withBaseName = makePrefixer(\"saltDialogContent\");\n\nexport const DialogContent = forwardRef<HTMLDivElement, DialogContentProps>(\n function DialogContent(props, ref) {\n const { children, className, ...rest } = props;\n const { status, dialogId, setContentElement } = useContext(DialogContext);\n\n const handleRef = useForkRef(ref, setContentElement);\n\n return (\n <div\n {...rest}\n className={classnames(\n withBaseName(),\n className,\n {\n [withBaseName(\"leftGutter\")]: !!status,\n },\n className\n )}\n id={`${dialogId}-body`}\n ref={handleRef}\n >\n {children}\n </div>\n );\n }\n);\n"],"names":["DialogContent","classnames"],"mappings":";;;;;;;AASA,MAAM,YAAA,GAAe,aAAa,mBAAmB,CAAA,CAAA;AAE9C,MAAM,aAAgB,GAAA,UAAA;AAAA,EAC3B,SAASA,cAAc,CAAA,KAAA,EAAO,GAAK,EAAA;AACjC,IAAA,MAAM,EAAE,QAAA,EAAU,SAAc,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AACzC,IAAA,MAAM,EAAE,MAAQ,EAAA,QAAA,EAAU,iBAAkB,EAAA,GAAI,WAAW,aAAa,CAAA,CAAA;AAExE,IAAM,MAAA,SAAA,GAAY,UAAW,CAAA,GAAA,EAAK,iBAAiB,CAAA,CAAA;AAEnD,IAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,MACE,GAAG,IAAA;AAAA,MACJ,SAAW,EAAAC,EAAA;AAAA,QACT,YAAa,EAAA;AAAA,QACb,SAAA;AAAA,QACA;AAAA,UACE,CAAC,YAAA,CAAa,YAAY,CAAA,GAAI,CAAC,CAAC,MAAA;AAAA,SAClC;AAAA,QACA,SAAA;AAAA,OACF;AAAA,MACA,IAAI,CAAG,EAAA,QAAA,CAAA,KAAA,CAAA;AAAA,MACP,GAAK,EAAA,SAAA;AAAA,MAEJ,QAAA;AAAA,KACH,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
1
+ {"version":3,"file":"DialogContent.js","sources":["../src/dialog/DialogContent.tsx"],"sourcesContent":["import { makePrefixer, useForkRef } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { forwardRef, HTMLAttributes, useContext } from \"react\";\nimport { DialogContext } from \"./internal/DialogContext\";\n\nimport \"./DialogContent.css\";\n\nexport interface DialogContentProps extends HTMLAttributes<HTMLDivElement> {}\n\nconst withBaseName = makePrefixer(\"saltDialogContent\");\n\nexport const DialogContent = forwardRef<HTMLDivElement, DialogContentProps>(\n function DialogContent(props, ref) {\n const { children, className, ...rest } = props;\n const { status, dialogId, setContentElement } = useContext(DialogContext);\n\n const handleRef = useForkRef(ref, setContentElement);\n\n return (\n <div\n {...rest}\n className={clsx(\n withBaseName(),\n className,\n {\n [withBaseName(\"leftGutter\")]: !!status,\n },\n className\n )}\n id={`${dialogId}-body`}\n ref={handleRef}\n >\n {children}\n </div>\n );\n }\n);\n"],"names":["DialogContent"],"mappings":";;;;;;;AASA,MAAM,YAAA,GAAe,aAAa,mBAAmB,CAAA,CAAA;AAE9C,MAAM,aAAgB,GAAA,UAAA;AAAA,EAC3B,SAASA,cAAc,CAAA,KAAA,EAAO,GAAK,EAAA;AACjC,IAAA,MAAM,EAAE,QAAA,EAAU,SAAc,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AACzC,IAAA,MAAM,EAAE,MAAQ,EAAA,QAAA,EAAU,iBAAkB,EAAA,GAAI,WAAW,aAAa,CAAA,CAAA;AAExE,IAAM,MAAA,SAAA,GAAY,UAAW,CAAA,GAAA,EAAK,iBAAiB,CAAA,CAAA;AAEnD,IAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,MACE,GAAG,IAAA;AAAA,MACJ,SAAW,EAAA,IAAA;AAAA,QACT,YAAa,EAAA;AAAA,QACb,SAAA;AAAA,QACA;AAAA,UACE,CAAC,YAAA,CAAa,YAAY,CAAA,GAAI,CAAC,CAAC,MAAA;AAAA,SAClC;AAAA,QACA,SAAA;AAAA,OACF;AAAA,MACA,IAAI,CAAG,EAAA,QAAA,CAAA,KAAA,CAAA;AAAA,MACP,GAAK,EAAA,SAAA;AAAA,MAEJ,QAAA;AAAA,KACH,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
@@ -1,7 +1,7 @@
1
1
  import { jsxs, jsx } from 'react/jsx-runtime';
2
2
  import { makePrefixer, Button, StatusIndicator } from '@salt-ds/core';
3
3
  import { CloseIcon } from '@salt-ds/icons';
4
- import cx from 'classnames';
4
+ import { clsx } from 'clsx';
5
5
  import { forwardRef, useContext } from 'react';
6
6
  import { DialogContext } from './internal/DialogContext.js';
7
7
  import './DialogTitle.css.js';
@@ -12,7 +12,7 @@ const DialogTitle = forwardRef(
12
12
  const { children, className, onClose, ...rest } = props;
13
13
  const { status, dialogId } = useContext(DialogContext);
14
14
  return /* @__PURE__ */ jsxs("div", {
15
- className: cx(withBaseName(), className),
15
+ className: clsx(withBaseName(), className),
16
16
  ref,
17
17
  ...rest,
18
18
  children: [
@@ -1 +1 @@
1
- {"version":3,"file":"DialogTitle.js","sources":["../src/dialog/DialogTitle.tsx"],"sourcesContent":["import { Button, makePrefixer, StatusIndicator } from \"@salt-ds/core\";\nimport { CloseIcon } from \"@salt-ds/icons\";\nimport classnames from \"classnames\";\nimport { forwardRef, HTMLAttributes, SyntheticEvent, useContext } from \"react\";\nimport { DialogContext } from \"./internal/DialogContext\";\n\nimport \"./DialogTitle.css\";\nexport interface DialogTitleProps extends HTMLAttributes<HTMLDivElement> {\n /**\n * Disable the built-in ARIA heading attributes.\n */\n disableAria?: boolean;\n onClose?: (event: SyntheticEvent) => void;\n}\n\nconst withBaseName = makePrefixer(\"saltDialogTitle\");\n\nexport const DialogTitle = forwardRef<HTMLDivElement, DialogTitleProps>(\n function DialogTitle(props, ref) {\n const { children, className, onClose, ...rest } = props;\n const { status, dialogId } = useContext(DialogContext);\n\n return (\n <div\n className={classnames(withBaseName(), className)}\n ref={ref}\n {...rest}\n >\n {onClose && (\n <Button\n className={withBaseName(\"close\")}\n onClick={onClose}\n variant=\"secondary\"\n >\n <CloseIcon\n aria-label=\"close dialog\"\n className={withBaseName(\"closeIcon\")}\n />\n </Button>\n )}\n {status && (\n <StatusIndicator\n className={withBaseName(\"statusIndicator\")}\n status={status}\n />\n )}\n <span aria-level={1} id={`${dialogId}-heading`} role=\"heading\">\n {children}\n </span>\n </div>\n );\n }\n);\n"],"names":["DialogTitle","classnames"],"mappings":";;;;;;;;AAeA,MAAM,YAAA,GAAe,aAAa,iBAAiB,CAAA,CAAA;AAE5C,MAAM,WAAc,GAAA,UAAA;AAAA,EACzB,SAASA,YAAY,CAAA,KAAA,EAAO,GAAK,EAAA;AAC/B,IAAA,MAAM,EAAE,QAAA,EAAU,SAAW,EAAA,OAAA,EAAA,GAAY,MAAS,GAAA,KAAA,CAAA;AAClD,IAAA,MAAM,EAAE,MAAA,EAAQ,QAAS,EAAA,GAAI,WAAW,aAAa,CAAA,CAAA;AAErD,IAAA,uBACG,IAAA,CAAA,KAAA,EAAA;AAAA,MACC,SAAW,EAAAC,EAAA,CAAW,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,MAC/C,GAAA;AAAA,MACC,GAAG,IAAA;AAAA,MAEH,QAAA,EAAA;AAAA,QAAA,OAAA,oBACE,GAAA,CAAA,MAAA,EAAA;AAAA,UACC,SAAA,EAAW,aAAa,OAAO,CAAA;AAAA,UAC/B,OAAS,EAAA,OAAA;AAAA,UACT,OAAQ,EAAA,WAAA;AAAA,UAER,QAAC,kBAAA,GAAA,CAAA,SAAA,EAAA;AAAA,YACC,YAAW,EAAA,cAAA;AAAA,YACX,SAAA,EAAW,aAAa,WAAW,CAAA;AAAA,WACrC,CAAA;AAAA,SACF,CAAA;AAAA,QAED,0BACE,GAAA,CAAA,eAAA,EAAA;AAAA,UACC,SAAA,EAAW,aAAa,iBAAiB,CAAA;AAAA,UACzC,MAAA;AAAA,SACF,CAAA;AAAA,wBAED,GAAA,CAAA,MAAA,EAAA;AAAA,UAAK,YAAY,EAAA,CAAA;AAAA,UAAG,IAAI,CAAG,EAAA,QAAA,CAAA,QAAA,CAAA;AAAA,UAAoB,IAAK,EAAA,SAAA;AAAA,UAClD,QAAA;AAAA,SACH,CAAA;AAAA,OAAA;AAAA,KACF,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
1
+ {"version":3,"file":"DialogTitle.js","sources":["../src/dialog/DialogTitle.tsx"],"sourcesContent":["import { Button, makePrefixer, StatusIndicator } from \"@salt-ds/core\";\nimport { CloseIcon } from \"@salt-ds/icons\";\nimport { clsx } from \"clsx\";\nimport { forwardRef, HTMLAttributes, SyntheticEvent, useContext } from \"react\";\nimport { DialogContext } from \"./internal/DialogContext\";\n\nimport \"./DialogTitle.css\";\nexport interface DialogTitleProps extends HTMLAttributes<HTMLDivElement> {\n /**\n * Disable the built-in ARIA heading attributes.\n */\n disableAria?: boolean;\n onClose?: (event: SyntheticEvent) => void;\n}\n\nconst withBaseName = makePrefixer(\"saltDialogTitle\");\n\nexport const DialogTitle = forwardRef<HTMLDivElement, DialogTitleProps>(\n function DialogTitle(props, ref) {\n const { children, className, onClose, ...rest } = props;\n const { status, dialogId } = useContext(DialogContext);\n\n return (\n <div className={clsx(withBaseName(), className)} ref={ref} {...rest}>\n {onClose && (\n <Button\n className={withBaseName(\"close\")}\n onClick={onClose}\n variant=\"secondary\"\n >\n <CloseIcon\n aria-label=\"close dialog\"\n className={withBaseName(\"closeIcon\")}\n />\n </Button>\n )}\n {status && (\n <StatusIndicator\n className={withBaseName(\"statusIndicator\")}\n status={status}\n />\n )}\n <span aria-level={1} id={`${dialogId}-heading`} role=\"heading\">\n {children}\n </span>\n </div>\n );\n }\n);\n"],"names":["DialogTitle"],"mappings":";;;;;;;;AAeA,MAAM,YAAA,GAAe,aAAa,iBAAiB,CAAA,CAAA;AAE5C,MAAM,WAAc,GAAA,UAAA;AAAA,EACzB,SAASA,YAAY,CAAA,KAAA,EAAO,GAAK,EAAA;AAC/B,IAAA,MAAM,EAAE,QAAA,EAAU,SAAW,EAAA,OAAA,EAAA,GAAY,MAAS,GAAA,KAAA,CAAA;AAClD,IAAA,MAAM,EAAE,MAAA,EAAQ,QAAS,EAAA,GAAI,WAAW,aAAa,CAAA,CAAA;AAErD,IAAA,uBACG,IAAA,CAAA,KAAA,EAAA;AAAA,MAAI,SAAW,EAAA,IAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,MAAG,GAAA;AAAA,MAAW,GAAG,IAAA;AAAA,MAC5D,QAAA,EAAA;AAAA,QAAA,OAAA,oBACE,GAAA,CAAA,MAAA,EAAA;AAAA,UACC,SAAA,EAAW,aAAa,OAAO,CAAA;AAAA,UAC/B,OAAS,EAAA,OAAA;AAAA,UACT,OAAQ,EAAA,WAAA;AAAA,UAER,QAAC,kBAAA,GAAA,CAAA,SAAA,EAAA;AAAA,YACC,YAAW,EAAA,cAAA;AAAA,YACX,SAAA,EAAW,aAAa,WAAW,CAAA;AAAA,WACrC,CAAA;AAAA,SACF,CAAA;AAAA,QAED,0BACE,GAAA,CAAA,eAAA,EAAA;AAAA,UACC,SAAA,EAAW,aAAa,iBAAiB,CAAA;AAAA,UACzC,MAAA;AAAA,SACF,CAAA;AAAA,wBAED,GAAA,CAAA,MAAA,EAAA;AAAA,UAAK,YAAY,EAAA,CAAA;AAAA,UAAG,IAAI,CAAG,EAAA,QAAA,CAAA,QAAA,CAAA;AAAA,UAAoB,IAAK,EAAA,SAAA;AAAA,UAClD,QAAA;AAAA,SACH,CAAA;AAAA,OAAA;AAAA,KACF,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
@@ -7,6 +7,7 @@ import '../common-hooks/keyUtils.js';
7
7
  import { useCollectionItems } from '../common-hooks/useCollectionItems.js';
8
8
  import '../responsive/useResizeObserver.js';
9
9
  import { forwardCallbackProps } from '../utils/forwardCallbackProps.js';
10
+ import '../utils/useFloatingUI.js';
10
11
  import { List } from '../list/List.js';
11
12
  import { DropdownBase } from './DropdownBase.js';
12
13
  import { DropdownButton } from './DropdownButton.js';
@@ -1 +1 @@
1
- {"version":3,"file":"Dropdown.js","sources":["../src/dropdown/Dropdown.tsx"],"sourcesContent":["import { useForkRef, useIdMemo as useId } from \"@salt-ds/core\";\nimport {\n cloneElement,\n ForwardedRef,\n forwardRef,\n ReactElement,\n useCallback,\n useRef,\n} from \"react\";\n\nimport {\n CollectionItem,\n CollectionProvider,\n itemToString as defaultItemToString,\n SelectionProps,\n SelectionStrategy,\n SingleSelectionStrategy,\n useCollectionItems,\n} from \"../common-hooks\";\nimport { List } from \"../list/List\";\nimport { ListProps } from \"../list/listTypes\";\nimport { DropdownBase, MaybeChildProps } from \"./DropdownBase\";\nimport { DropdownButton } from \"./DropdownButton\";\nimport { DropdownBaseProps } from \"./dropdownTypes\";\nimport { useDropdown } from \"./useDropdown\";\nimport { forwardCallbackProps } from \"../utils\";\n\nexport interface DropdownProps<\n Item = string,\n Selection extends SelectionStrategy = \"default\"\n> extends DropdownBaseProps,\n Pick<\n ListProps<Item, Selection>,\n \"ListItem\" | \"itemToString\" | \"source\" | \"width\"\n >,\n SelectionProps<Item, Selection> {\n ListProps?: Omit<\n ListProps<Item, Selection>,\n \"ListItem\" | \"itemToString\" | \"source\"\n >;\n}\n\nexport const Dropdown = forwardRef(function Dropdown<\n Item = string,\n Selection extends SelectionStrategy = \"default\"\n>(\n {\n \"aria-label\": ariaLabel,\n children,\n defaultIsOpen,\n defaultSelected,\n id: idProp,\n isOpen: isOpenProp,\n itemToString = defaultItemToString,\n onOpenChange,\n onSelectionChange,\n selected: selectedProp,\n selectionStrategy,\n source,\n triggerComponent,\n ListItem,\n ListProps,\n width = 180,\n ...props\n }: DropdownProps<Item, Selection>,\n forwardedRef: ForwardedRef<HTMLDivElement>\n) {\n const id = useId(idProp);\n const rootRef = useRef<HTMLDivElement>(null);\n const forkedRef = useForkRef<HTMLDivElement>(rootRef, forwardedRef);\n\n const collectionHook = useCollectionItems<Item>({\n id,\n source,\n children,\n options: {\n itemToString,\n },\n });\n\n const {\n highlightedIndex,\n triggerLabel,\n listHandlers,\n listControlProps,\n selected,\n ...dropdownListHook\n } = useDropdown<Item, Selection>({\n collectionHook,\n defaultHighlightedIndex: ListProps?.defaultHighlightedIndex,\n defaultIsOpen,\n defaultSelected: collectionHook.itemToCollectionItem<\n Selection,\n typeof defaultSelected\n >(defaultSelected),\n highlightedIndex: ListProps?.highlightedIndex,\n isOpen: isOpenProp,\n itemToString,\n label: \"Dropdown\",\n onHighlight: ListProps?.onHighlight,\n onOpenChange,\n onSelectionChange,\n selected: collectionHook.itemToCollectionItem<\n Selection,\n typeof selectedProp\n >(selectedProp),\n selectionStrategy,\n });\n\n const collectionItemsToItem = useCallback(\n (\n itemOrItems?: CollectionItem<Item> | null | CollectionItem<Item>[]\n ):\n | undefined\n | (Selection extends SingleSelectionStrategy ? Item | null : Item[]) => {\n type returnType = Selection extends SingleSelectionStrategy\n ? Item | null\n : Item[];\n if (Array.isArray(itemOrItems)) {\n return itemOrItems.map((i) => i.value) as returnType;\n } else if (itemOrItems) {\n return itemOrItems.value as returnType;\n }\n },\n []\n );\n\n const getTriggerComponent = () => {\n const ariaProps = {\n \"aria-activedescendant\": dropdownListHook.isOpen\n ? listControlProps?.[\"aria-activedescendant\"]\n : undefined,\n \"aria-label\": ariaLabel,\n };\n if (triggerComponent) {\n const ownProps = triggerComponent.props as MaybeChildProps;\n return cloneElement(\n triggerComponent,\n forwardCallbackProps(ownProps, {\n ...listControlProps,\n ...ariaProps,\n })\n );\n } else {\n return (\n <DropdownButton\n label={triggerLabel}\n {...listControlProps}\n {...ariaProps}\n />\n );\n }\n };\n\n return (\n <CollectionProvider<Item> collectionHook={collectionHook}>\n <DropdownBase\n {...props}\n id={id}\n isOpen={dropdownListHook.isOpen}\n onOpenChange={dropdownListHook.onOpenChange}\n ref={forkedRef}\n width={width}\n >\n {getTriggerComponent()}\n <List<Item, Selection>\n ListItem={ListItem}\n itemToString={itemToString}\n {...ListProps}\n highlightedIndex={highlightedIndex}\n listHandlers={listHandlers}\n onSelectionChange={onSelectionChange}\n selected={collectionItemsToItem(selected)}\n selectionStrategy={selectionStrategy}\n data-testid=\"dropdown-list\"\n />\n </DropdownBase>\n </CollectionProvider>\n );\n}) as <Item, Selection extends SelectionStrategy = \"default\">(\n props: DropdownProps<Item, Selection> & {\n ref?: ForwardedRef<HTMLDivElement>;\n }\n) => ReactElement<DropdownProps<Item, Selection>>;\n"],"names":["Dropdown","itemToString","defaultItemToString","ListProps","useId"],"mappings":"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"}
1
+ {"version":3,"file":"Dropdown.js","sources":["../src/dropdown/Dropdown.tsx"],"sourcesContent":["import { useForkRef, useIdMemo as useId } from \"@salt-ds/core\";\nimport {\n cloneElement,\n ForwardedRef,\n forwardRef,\n ReactElement,\n useCallback,\n useRef,\n} from \"react\";\n\nimport {\n CollectionItem,\n CollectionProvider,\n itemToString as defaultItemToString,\n SelectionProps,\n SelectionStrategy,\n SingleSelectionStrategy,\n useCollectionItems,\n} from \"../common-hooks\";\nimport { List } from \"../list/List\";\nimport { ListProps } from \"../list/listTypes\";\nimport { DropdownBase, MaybeChildProps } from \"./DropdownBase\";\nimport { DropdownButton } from \"./DropdownButton\";\nimport { DropdownBaseProps } from \"./dropdownTypes\";\nimport { useDropdown } from \"./useDropdown\";\nimport { forwardCallbackProps } from \"../utils\";\n\nexport interface DropdownProps<\n Item = string,\n Selection extends SelectionStrategy = \"default\"\n> extends DropdownBaseProps,\n Pick<\n ListProps<Item, Selection>,\n \"ListItem\" | \"itemToString\" | \"source\" | \"width\"\n >,\n SelectionProps<Item, Selection> {\n ListProps?: Omit<\n ListProps<Item, Selection>,\n \"ListItem\" | \"itemToString\" | \"source\"\n >;\n}\n\nexport const Dropdown = forwardRef(function Dropdown<\n Item = string,\n Selection extends SelectionStrategy = \"default\"\n>(\n {\n \"aria-label\": ariaLabel,\n children,\n defaultIsOpen,\n defaultSelected,\n id: idProp,\n isOpen: isOpenProp,\n itemToString = defaultItemToString,\n onOpenChange,\n onSelectionChange,\n selected: selectedProp,\n selectionStrategy,\n source,\n triggerComponent,\n ListItem,\n ListProps,\n width = 180,\n ...props\n }: DropdownProps<Item, Selection>,\n forwardedRef: ForwardedRef<HTMLDivElement>\n) {\n const id = useId(idProp);\n const rootRef = useRef<HTMLDivElement>(null);\n const forkedRef = useForkRef<HTMLDivElement>(rootRef, forwardedRef);\n\n const collectionHook = useCollectionItems<Item>({\n id,\n source,\n children,\n options: {\n itemToString,\n },\n });\n\n const {\n highlightedIndex,\n triggerLabel,\n listHandlers,\n listControlProps,\n selected,\n ...dropdownListHook\n } = useDropdown<Item, Selection>({\n collectionHook,\n defaultHighlightedIndex: ListProps?.defaultHighlightedIndex,\n defaultIsOpen,\n defaultSelected: collectionHook.itemToCollectionItem<\n Selection,\n typeof defaultSelected\n >(defaultSelected),\n highlightedIndex: ListProps?.highlightedIndex,\n isOpen: isOpenProp,\n itemToString,\n label: \"Dropdown\",\n onHighlight: ListProps?.onHighlight,\n onOpenChange,\n onSelectionChange,\n selected: collectionHook.itemToCollectionItem<\n Selection,\n typeof selectedProp\n >(selectedProp),\n selectionStrategy,\n });\n\n const collectionItemsToItem = useCallback(\n (\n itemOrItems?: CollectionItem<Item> | null | CollectionItem<Item>[]\n ):\n | undefined\n | (Selection extends SingleSelectionStrategy ? Item | null : Item[]) => {\n type returnType = Selection extends SingleSelectionStrategy\n ? Item | null\n : Item[];\n if (Array.isArray(itemOrItems)) {\n return itemOrItems.map((i) => i.value) as returnType;\n } else if (itemOrItems) {\n return itemOrItems.value as returnType;\n }\n },\n []\n );\n\n const getTriggerComponent = () => {\n const ariaProps = {\n \"aria-activedescendant\": dropdownListHook.isOpen\n ? listControlProps?.[\"aria-activedescendant\"]\n : undefined,\n \"aria-label\": ariaLabel,\n };\n if (triggerComponent) {\n const ownProps = triggerComponent.props as MaybeChildProps;\n return cloneElement(\n triggerComponent,\n forwardCallbackProps(ownProps, {\n ...listControlProps,\n ...ariaProps,\n })\n );\n } else {\n return (\n <DropdownButton\n label={triggerLabel}\n {...listControlProps}\n {...ariaProps}\n />\n );\n }\n };\n\n return (\n <CollectionProvider<Item> collectionHook={collectionHook}>\n <DropdownBase\n {...props}\n id={id}\n isOpen={dropdownListHook.isOpen}\n onOpenChange={dropdownListHook.onOpenChange}\n ref={forkedRef}\n width={width}\n >\n {getTriggerComponent()}\n <List<Item, Selection>\n ListItem={ListItem}\n itemToString={itemToString}\n {...ListProps}\n highlightedIndex={highlightedIndex}\n listHandlers={listHandlers}\n onSelectionChange={onSelectionChange}\n selected={collectionItemsToItem(selected)}\n selectionStrategy={selectionStrategy}\n data-testid=\"dropdown-list\"\n />\n </DropdownBase>\n </CollectionProvider>\n );\n}) as <Item, Selection extends SelectionStrategy = \"default\">(\n props: DropdownProps<Item, Selection> & {\n ref?: ForwardedRef<HTMLDivElement>;\n }\n) => ReactElement<DropdownProps<Item, Selection>>;\n"],"names":["Dropdown","itemToString","defaultItemToString","ListProps","useId"],"mappings":"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"}
@@ -1,11 +1,11 @@
1
1
  import { jsxs, jsx } from 'react/jsx-runtime';
2
- import { flip, shift, limitShift, size } from '@floating-ui/react-dom-interactions';
3
- import { makePrefixer, useIdMemo, useForkRef } from '@salt-ds/core';
4
- import cx from 'classnames';
2
+ import { flip, shift, limitShift, size } from '@floating-ui/react';
3
+ import { makePrefixer, useIdMemo, useFloatingUI, useForkRef } from '@salt-ds/core';
4
+ import { clsx } from 'clsx';
5
5
  import { forwardRef, useRef, Children, useState, cloneElement } from 'react';
6
6
  import { forwardCallbackProps } from '../utils/forwardCallbackProps.js';
7
+ import '../utils/useFloatingUI.js';
7
8
  import { useDropdownBase } from './useDropdownBase.js';
8
- import { useFloatingUI } from '../popper/useFloatingUI.js';
9
9
  import { Portal } from '../portal/Portal.js';
10
10
  import { useWindow, isDesktop } from '../window/WindowContext.js';
11
11
  import '../window/ElectronWindow.js';
@@ -33,7 +33,7 @@ const DropdownBase = forwardRef(
33
33
  ...htmlAttributes
34
34
  }, forwardedRef) {
35
35
  const rootRef = useRef(null);
36
- const className = cx(withBaseName(), classNameProp, {
36
+ const className = clsx(withBaseName(), classNameProp, {
37
37
  [withBaseName("fullWidth")]: fullWidth,
38
38
  [withBaseName("disabled")]: disabled
39
39
  });
@@ -114,7 +114,7 @@ const DropdownBase = forwardRef(
114
114
  return cloneElement(popupComponent, {
115
115
  ...ownProps,
116
116
  ...restComponentProps,
117
- className: cx(className2, withBaseName("popup-component")),
117
+ className: clsx(className2, withBaseName("popup-component")),
118
118
  id: id2,
119
119
  width: ownWidth != null ? ownWidth : width2
120
120
  });
@@ -131,7 +131,7 @@ const DropdownBase = forwardRef(
131
131
  disablePortal,
132
132
  container,
133
133
  children: /* @__PURE__ */ jsx(Window, {
134
- className: cx(withBaseName("popup"), classNameProp),
134
+ className: clsx(withBaseName("popup"), classNameProp),
135
135
  id: `${id}-popup`,
136
136
  style: {
137
137
  top: y != null ? y : "",
@@ -1 +1 @@
1
- {"version":3,"file":"DropdownBase.js","sources":["../src/dropdown/DropdownBase.tsx"],"sourcesContent":["import {\n flip,\n limitShift,\n shift,\n size,\n} from \"@floating-ui/react-dom-interactions\";\nimport { makePrefixer, useForkRef, useIdMemo as useId } from \"@salt-ds/core\";\nimport cx from \"classnames\";\nimport { Children, cloneElement, forwardRef, useRef, useState } from \"react\";\nimport { forwardCallbackProps } from \"../utils\";\nimport { DropdownBaseProps } from \"./dropdownTypes\";\nimport { useDropdownBase } from \"./useDropdownBase\";\nimport { useFloatingUI } from \"../popper\";\nimport { Portal } from \"../portal\";\nimport { isDesktop, useWindow } from \"../window\";\n\nimport \"./Dropdown.css\";\n\n// Any component may be passed as our trigger or popup component.\n// Define the common props that we will act on, if present,\n// so we can type them.\nexport type MaybeChildProps = {\n className?: string;\n id?: string;\n role?: string;\n width: number | string;\n};\n\nconst withBaseName = makePrefixer(\"saltDropdown\");\n\nexport const DropdownBase = forwardRef<HTMLDivElement, DropdownBaseProps>(\n function Dropdown(\n {\n \"aria-labelledby\": ariaLabelledByProp,\n children,\n className: classNameProp,\n container,\n defaultIsOpen,\n disabled,\n disablePortal,\n fullWidth,\n id: idProp,\n isOpen: isOpenProp,\n onKeyDown,\n onOpenChange,\n openOnFocus,\n placement = \"bottom-start\",\n popupWidth,\n width,\n ...htmlAttributes\n },\n forwardedRef\n ) {\n const rootRef = useRef<HTMLDivElement>(null);\n const className = cx(withBaseName(), classNameProp, {\n [withBaseName(\"fullWidth\")]: fullWidth,\n [withBaseName(\"disabled\")]: disabled,\n });\n const [trigger, popupComponent] = Children.toArray(\n children\n ) as JSX.Element[];\n const id = useId(idProp);\n const Window = useWindow();\n\n const { componentProps, popperRef, isOpen, triggerProps } = useDropdownBase(\n {\n ariaLabelledBy: ariaLabelledByProp,\n defaultIsOpen,\n disabled,\n fullWidth,\n id,\n isOpen: isOpenProp,\n onOpenChange,\n onKeyDown,\n openOnFocus,\n popupComponent,\n popupWidth,\n rootRef,\n width,\n }\n );\n const [maxPopupHeight, setMaxPopupHeight] = useState<number | undefined>(\n undefined\n );\n\n const middleware = isDesktop\n ? []\n : [\n flip({\n fallbackPlacements: [\"bottom-start\", \"top-start\"],\n }),\n shift({ limiter: limitShift() }),\n size({\n apply({ availableHeight }) {\n setMaxPopupHeight(availableHeight);\n },\n }),\n ];\n\n const { reference, floating, x, y, strategy } = useFloatingUI({\n placement,\n middleware,\n });\n\n const handlePopperListAdapterRef = useForkRef<HTMLDivElement>(\n reference,\n forwardedRef\n );\n const handleRootRef = useForkRef(rootRef, handlePopperListAdapterRef);\n const handleFloatingRef = useForkRef<HTMLDivElement>(floating, popperRef);\n // TODO maybe we should pass style, with maxHeight, to the popupComponent\n\n const getTriggerComponent = () => {\n const {\n id: defaultId,\n role: defaultRole,\n ...restTriggerProps\n } = triggerProps;\n\n const {\n id = defaultId,\n role = defaultRole,\n ...ownProps\n } = trigger.props as MaybeChildProps;\n\n return cloneElement(\n trigger,\n forwardCallbackProps(ownProps, {\n ...restTriggerProps,\n id,\n role,\n })\n );\n };\n\n const getPopupComponent = () => {\n const { id: defaultId, width, ...restComponentProps } = componentProps;\n const {\n className,\n id = defaultId,\n width: ownWidth,\n ...ownProps\n } = popupComponent.props as MaybeChildProps;\n return cloneElement(popupComponent, {\n ...ownProps,\n ...restComponentProps,\n className: cx(className, withBaseName(\"popup-component\")),\n id,\n width: ownWidth ?? width,\n });\n };\n\n return (\n <div\n {...htmlAttributes}\n className={className}\n data-testid=\"dropdown\"\n id={idProp}\n ref={handleRootRef}\n >\n {getTriggerComponent()}\n {isOpen && (\n <Portal disablePortal={disablePortal} container={container}>\n <Window\n className={cx(withBaseName(\"popup\"), classNameProp)}\n id={`${id}-popup`}\n style={{\n top: y ?? \"\",\n left: x ?? \"\",\n position: strategy,\n maxHeight: maxPopupHeight ?? undefined,\n }}\n ref={handleFloatingRef}\n >\n {getPopupComponent()}\n </Window>\n </Portal>\n )}\n </div>\n );\n }\n);\n"],"names":["useId","id","width","className"],"mappings":"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"}
1
+ {"version":3,"file":"DropdownBase.js","sources":["../src/dropdown/DropdownBase.tsx"],"sourcesContent":["import { flip, limitShift, shift, size } from \"@floating-ui/react\";\nimport {\n makePrefixer,\n useFloatingUI,\n useForkRef,\n useIdMemo as useId,\n} from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { Children, cloneElement, forwardRef, useRef, useState } from \"react\";\nimport { forwardCallbackProps } from \"../utils\";\nimport { DropdownBaseProps } from \"./dropdownTypes\";\nimport { useDropdownBase } from \"./useDropdownBase\";\nimport { Portal } from \"../portal\";\nimport { isDesktop, useWindow } from \"../window\";\n\nimport \"./Dropdown.css\";\n\n// Any component may be passed as our trigger or popup component.\n// Define the common props that we will act on, if present,\n// so we can type them.\nexport type MaybeChildProps = {\n className?: string;\n id?: string;\n role?: string;\n width: number | string;\n};\n\nconst withBaseName = makePrefixer(\"saltDropdown\");\n\nexport const DropdownBase = forwardRef<HTMLDivElement, DropdownBaseProps>(\n function Dropdown(\n {\n \"aria-labelledby\": ariaLabelledByProp,\n children,\n className: classNameProp,\n container,\n defaultIsOpen,\n disabled,\n disablePortal,\n fullWidth,\n id: idProp,\n isOpen: isOpenProp,\n onKeyDown,\n onOpenChange,\n openOnFocus,\n placement = \"bottom-start\",\n popupWidth,\n width,\n ...htmlAttributes\n },\n forwardedRef\n ) {\n const rootRef = useRef<HTMLDivElement>(null);\n const className = clsx(withBaseName(), classNameProp, {\n [withBaseName(\"fullWidth\")]: fullWidth,\n [withBaseName(\"disabled\")]: disabled,\n });\n const [trigger, popupComponent] = Children.toArray(\n children\n ) as JSX.Element[];\n const id = useId(idProp);\n const Window = useWindow();\n\n const { componentProps, popperRef, isOpen, triggerProps } = useDropdownBase(\n {\n ariaLabelledBy: ariaLabelledByProp,\n defaultIsOpen,\n disabled,\n fullWidth,\n id,\n isOpen: isOpenProp,\n onOpenChange,\n onKeyDown,\n openOnFocus,\n popupComponent,\n popupWidth,\n rootRef,\n width,\n }\n );\n const [maxPopupHeight, setMaxPopupHeight] = useState<number | undefined>(\n undefined\n );\n\n const middleware = isDesktop\n ? []\n : [\n flip({\n fallbackPlacements: [\"bottom-start\", \"top-start\"],\n }),\n shift({ limiter: limitShift() }),\n size({\n apply({ availableHeight }) {\n setMaxPopupHeight(availableHeight);\n },\n }),\n ];\n\n const { reference, floating, x, y, strategy } = useFloatingUI({\n placement,\n middleware,\n });\n\n const handlePopperListAdapterRef = useForkRef<HTMLDivElement>(\n reference,\n forwardedRef\n );\n const handleRootRef = useForkRef(rootRef, handlePopperListAdapterRef);\n const handleFloatingRef = useForkRef<HTMLDivElement>(floating, popperRef);\n // TODO maybe we should pass style, with maxHeight, to the popupComponent\n\n const getTriggerComponent = () => {\n const {\n id: defaultId,\n role: defaultRole,\n ...restTriggerProps\n } = triggerProps;\n\n const {\n id = defaultId,\n role = defaultRole,\n ...ownProps\n } = trigger.props as MaybeChildProps;\n\n return cloneElement(\n trigger,\n forwardCallbackProps(ownProps, {\n ...restTriggerProps,\n id,\n role,\n })\n );\n };\n\n const getPopupComponent = () => {\n const { id: defaultId, width, ...restComponentProps } = componentProps;\n const {\n className,\n id = defaultId,\n width: ownWidth,\n ...ownProps\n } = popupComponent.props as MaybeChildProps;\n return cloneElement(popupComponent, {\n ...ownProps,\n ...restComponentProps,\n className: clsx(className, withBaseName(\"popup-component\")),\n id,\n width: ownWidth ?? width,\n });\n };\n\n return (\n <div\n {...htmlAttributes}\n className={className}\n data-testid=\"dropdown\"\n id={idProp}\n ref={handleRootRef}\n >\n {getTriggerComponent()}\n {isOpen && (\n <Portal disablePortal={disablePortal} container={container}>\n <Window\n className={clsx(withBaseName(\"popup\"), classNameProp)}\n id={`${id}-popup`}\n style={{\n top: y ?? \"\",\n left: x ?? \"\",\n position: strategy,\n maxHeight: maxPopupHeight ?? undefined,\n }}\n ref={handleFloatingRef}\n >\n {getPopupComponent()}\n </Window>\n </Portal>\n )}\n </div>\n );\n }\n);\n"],"names":["useId","id","width","className"],"mappings":"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"}
@@ -3,7 +3,7 @@ import { makePrefixer, Button } from '@salt-ds/core';
3
3
  import { ChevronDownIcon, DEFAULT_ICON_SIZE } from '@salt-ds/icons';
4
4
  import '../form-field-context/FormFieldContext.js';
5
5
  import { useFormFieldProps } from '../form-field-context/useFormFieldProps.js';
6
- import cx from 'classnames';
6
+ import { clsx } from 'clsx';
7
7
  import { forwardRef } from 'react';
8
8
  import './DropdownButton.css.js';
9
9
 
@@ -25,7 +25,7 @@ const DropdownButton = forwardRef(function DropdownButton2({
25
25
  }, ref) {
26
26
  const { inFormField } = useFormFieldProps();
27
27
  return /* @__PURE__ */ jsx(Button, {
28
- className: cx(
28
+ className: clsx(
29
29
  withBaseName(),
30
30
  {
31
31
  [withBaseName("fullwidth")]: fullWidth,
@@ -1 +1 @@
1
- {"version":3,"file":"DropdownButton.js","sources":["../src/dropdown/DropdownButton.tsx"],"sourcesContent":["import { Button, ButtonProps, makePrefixer } from \"@salt-ds/core\";\nimport { ChevronDownIcon, IconProps, DEFAULT_ICON_SIZE } from \"@salt-ds/icons\";\nimport { useFormFieldProps } from \"../form-field-context\";\nimport classnames from \"classnames\";\nimport { AriaAttributes, ComponentType, ForwardedRef, forwardRef } from \"react\";\n\nimport \"./DropdownButton.css\";\n\nexport interface DropdownButtonProps extends ButtonProps {\n /**\n * Replace the default Icon component\n */\n IconComponent?: ComponentType<any>;\n /**\n * Whether the dropdown button should hide role='option' via 'aria-hidden'\n */\n ariaHideOptionRole?: boolean;\n /**\n * If, `true`, the Dropdown button will occupy the full width of it's container\n */\n fullWidth?: boolean;\n /**\n * Sets the size of the down arrow icon. If this is not specified, a default size based on density is used.\n */\n iconSize?: IconProps[\"size\"];\n /**\n * Is the dropdown list open\n */\n isOpen?: boolean;\n /**\n * Label for the dropdown button\n */\n label?: string;\n /**\n * Id for the label. This is needed for ARIA attributes.\n */\n labelId?: string;\n /**\n * When the dropdown is collapsed this value is set as aria-posinset on the span containing the selected value\n * **/\n posInSet?: number;\n /**\n * When the dropdown is collapsed this value is set as aria-setsize on the span containing the selected value\n * **/\n setSize?: number;\n /**\n *\n * **/\n labelAriaAttributes?: Pick<\n AriaAttributes,\n \"aria-posinset\" | \"aria-setsize\" | \"aria-selected\"\n >;\n}\n\nconst withBaseName = makePrefixer(\"saltDropdownButton\");\n\nexport const DropdownButton = forwardRef(function DropdownButton(\n {\n IconComponent = ChevronDownIcon,\n ariaHideOptionRole,\n className,\n disabled,\n iconSize = DEFAULT_ICON_SIZE,\n isOpen,\n label,\n labelId,\n fullWidth,\n posInSet,\n setSize,\n labelAriaAttributes,\n ...rest\n }: DropdownButtonProps,\n ref: ForwardedRef<HTMLButtonElement>\n) {\n const { inFormField } = useFormFieldProps();\n // FIXME: use polymorphic button\n // We don't want the 'button' tag to be shown in the DOM to trigger some accessibility testing\n // tool's false alarm on role of 'listbox'\n return (\n <Button\n className={classnames(\n withBaseName(),\n {\n [withBaseName(\"fullwidth\")]: fullWidth,\n [withBaseName(\"formField\")]: inFormField,\n },\n className\n )}\n data-testid=\"dropdown-button\"\n disabled={disabled}\n variant=\"secondary\"\n {...rest}\n ref={ref}\n >\n <div className={withBaseName(\"content\")}>\n <span\n // 'hidden' so that screen reader won't be confused the additional 'option' which is just a label\n aria-hidden={ariaHideOptionRole ? \"true\" : undefined}\n {...labelAriaAttributes}\n className={withBaseName(\"buttonLabel\")}\n id={labelId}\n // 'option' role here is to suppress accessibility testing tool warning about 'listbox' missing children role.\n role=\"option\"\n >\n {label}\n </span>\n <IconComponent\n className={withBaseName(\"icon\")}\n size={iconSize}\n aria-label={null}\n aria-hidden=\"true\"\n />\n </div>\n </Button>\n );\n});\n"],"names":["DropdownButton","classnames"],"mappings":";;;;;;;;;AAsDA,MAAM,YAAA,GAAe,aAAa,oBAAoB,CAAA,CAAA;AAEzC,MAAA,cAAA,GAAiB,UAAW,CAAA,SAASA,eAChD,CAAA;AAAA,EACE,aAAgB,GAAA,eAAA;AAAA,EAChB,kBAAA;AAAA,EACA,SAAA;AAAA,EACA,QAAA;AAAA,EACA,QAAW,GAAA,iBAAA;AAAA,EACX,MAAA;AAAA,EACA,KAAA;AAAA,EACA,OAAA;AAAA,EACA,SAAA;AAAA,EACA,QAAA;AAAA,EACA,OAAA;AAAA,EACA,mBAAA;AAAA,EACG,GAAA,IAAA;AACL,CAAA,EACA,GACA,EAAA;AACA,EAAM,MAAA,EAAE,WAAY,EAAA,GAAI,iBAAkB,EAAA,CAAA;AAI1C,EAAA,uBACG,GAAA,CAAA,MAAA,EAAA;AAAA,IACC,SAAW,EAAAC,EAAA;AAAA,MACT,YAAa,EAAA;AAAA,MACb;AAAA,QACE,CAAC,YAAa,CAAA,WAAW,CAAI,GAAA,SAAA;AAAA,QAC7B,CAAC,YAAa,CAAA,WAAW,CAAI,GAAA,WAAA;AAAA,OAC/B;AAAA,MACA,SAAA;AAAA,KACF;AAAA,IACA,aAAY,EAAA,iBAAA;AAAA,IACZ,QAAA;AAAA,IACA,OAAQ,EAAA,WAAA;AAAA,IACP,GAAG,IAAA;AAAA,IACJ,GAAA;AAAA,IAEA,QAAC,kBAAA,IAAA,CAAA,KAAA,EAAA;AAAA,MAAI,SAAA,EAAW,aAAa,SAAS,CAAA;AAAA,MACpC,QAAA,EAAA;AAAA,wBAAC,GAAA,CAAA,MAAA,EAAA;AAAA,UAEC,aAAA,EAAa,qBAAqB,MAAS,GAAA,KAAA,CAAA;AAAA,UAC1C,GAAG,mBAAA;AAAA,UACJ,SAAA,EAAW,aAAa,aAAa,CAAA;AAAA,UACrC,EAAI,EAAA,OAAA;AAAA,UAEJ,IAAK,EAAA,QAAA;AAAA,UAEJ,QAAA,EAAA,KAAA;AAAA,SACH,CAAA;AAAA,wBACC,GAAA,CAAA,aAAA,EAAA;AAAA,UACC,SAAA,EAAW,aAAa,MAAM,CAAA;AAAA,UAC9B,IAAM,EAAA,QAAA;AAAA,UACN,YAAY,EAAA,IAAA;AAAA,UACZ,aAAY,EAAA,MAAA;AAAA,SACd,CAAA;AAAA,OAAA;AAAA,KACF,CAAA;AAAA,GACF,CAAA,CAAA;AAEJ,CAAC;;;;"}
1
+ {"version":3,"file":"DropdownButton.js","sources":["../src/dropdown/DropdownButton.tsx"],"sourcesContent":["import { Button, ButtonProps, makePrefixer } from \"@salt-ds/core\";\nimport { ChevronDownIcon, IconProps, DEFAULT_ICON_SIZE } from \"@salt-ds/icons\";\nimport { useFormFieldProps } from \"../form-field-context\";\nimport { clsx } from \"clsx\";\nimport { AriaAttributes, ComponentType, ForwardedRef, forwardRef } from \"react\";\n\nimport \"./DropdownButton.css\";\n\nexport interface DropdownButtonProps extends ButtonProps {\n /**\n * Replace the default Icon component\n */\n IconComponent?: ComponentType<any>;\n /**\n * Whether the dropdown button should hide role='option' via 'aria-hidden'\n */\n ariaHideOptionRole?: boolean;\n /**\n * If, `true`, the Dropdown button will occupy the full width of it's container\n */\n fullWidth?: boolean;\n /**\n * Sets the size of the down arrow icon. If this is not specified, a default size based on density is used.\n */\n iconSize?: IconProps[\"size\"];\n /**\n * Is the dropdown list open\n */\n isOpen?: boolean;\n /**\n * Label for the dropdown button\n */\n label?: string;\n /**\n * Id for the label. This is needed for ARIA attributes.\n */\n labelId?: string;\n /**\n * When the dropdown is collapsed this value is set as aria-posinset on the span containing the selected value\n * **/\n posInSet?: number;\n /**\n * When the dropdown is collapsed this value is set as aria-setsize on the span containing the selected value\n * **/\n setSize?: number;\n /**\n *\n * **/\n labelAriaAttributes?: Pick<\n AriaAttributes,\n \"aria-posinset\" | \"aria-setsize\" | \"aria-selected\"\n >;\n}\n\nconst withBaseName = makePrefixer(\"saltDropdownButton\");\n\nexport const DropdownButton = forwardRef(function DropdownButton(\n {\n IconComponent = ChevronDownIcon,\n ariaHideOptionRole,\n className,\n disabled,\n iconSize = DEFAULT_ICON_SIZE,\n isOpen,\n label,\n labelId,\n fullWidth,\n posInSet,\n setSize,\n labelAriaAttributes,\n ...rest\n }: DropdownButtonProps,\n ref: ForwardedRef<HTMLButtonElement>\n) {\n const { inFormField } = useFormFieldProps();\n // FIXME: use polymorphic button\n // We don't want the 'button' tag to be shown in the DOM to trigger some accessibility testing\n // tool's false alarm on role of 'listbox'\n return (\n <Button\n className={clsx(\n withBaseName(),\n {\n [withBaseName(\"fullwidth\")]: fullWidth,\n [withBaseName(\"formField\")]: inFormField,\n },\n className\n )}\n data-testid=\"dropdown-button\"\n disabled={disabled}\n variant=\"secondary\"\n {...rest}\n ref={ref}\n >\n <div className={withBaseName(\"content\")}>\n <span\n // 'hidden' so that screen reader won't be confused the additional 'option' which is just a label\n aria-hidden={ariaHideOptionRole ? \"true\" : undefined}\n {...labelAriaAttributes}\n className={withBaseName(\"buttonLabel\")}\n id={labelId}\n // 'option' role here is to suppress accessibility testing tool warning about 'listbox' missing children role.\n role=\"option\"\n >\n {label}\n </span>\n <IconComponent\n className={withBaseName(\"icon\")}\n size={iconSize}\n aria-label={null}\n aria-hidden=\"true\"\n />\n </div>\n </Button>\n );\n});\n"],"names":["DropdownButton"],"mappings":";;;;;;;;;AAsDA,MAAM,YAAA,GAAe,aAAa,oBAAoB,CAAA,CAAA;AAEzC,MAAA,cAAA,GAAiB,UAAW,CAAA,SAASA,eAChD,CAAA;AAAA,EACE,aAAgB,GAAA,eAAA;AAAA,EAChB,kBAAA;AAAA,EACA,SAAA;AAAA,EACA,QAAA;AAAA,EACA,QAAW,GAAA,iBAAA;AAAA,EACX,MAAA;AAAA,EACA,KAAA;AAAA,EACA,OAAA;AAAA,EACA,SAAA;AAAA,EACA,QAAA;AAAA,EACA,OAAA;AAAA,EACA,mBAAA;AAAA,EACG,GAAA,IAAA;AACL,CAAA,EACA,GACA,EAAA;AACA,EAAM,MAAA,EAAE,WAAY,EAAA,GAAI,iBAAkB,EAAA,CAAA;AAI1C,EAAA,uBACG,GAAA,CAAA,MAAA,EAAA;AAAA,IACC,SAAW,EAAA,IAAA;AAAA,MACT,YAAa,EAAA;AAAA,MACb;AAAA,QACE,CAAC,YAAa,CAAA,WAAW,CAAI,GAAA,SAAA;AAAA,QAC7B,CAAC,YAAa,CAAA,WAAW,CAAI,GAAA,WAAA;AAAA,OAC/B;AAAA,MACA,SAAA;AAAA,KACF;AAAA,IACA,aAAY,EAAA,iBAAA;AAAA,IACZ,QAAA;AAAA,IACA,OAAQ,EAAA,WAAA;AAAA,IACP,GAAG,IAAA;AAAA,IACJ,GAAA;AAAA,IAEA,QAAC,kBAAA,IAAA,CAAA,KAAA,EAAA;AAAA,MAAI,SAAA,EAAW,aAAa,SAAS,CAAA;AAAA,MACpC,QAAA,EAAA;AAAA,wBAAC,GAAA,CAAA,MAAA,EAAA;AAAA,UAEC,aAAA,EAAa,qBAAqB,MAAS,GAAA,KAAA,CAAA;AAAA,UAC1C,GAAG,mBAAA;AAAA,UACJ,SAAA,EAAW,aAAa,aAAa,CAAA;AAAA,UACrC,EAAI,EAAA,OAAA;AAAA,UAEJ,IAAK,EAAA,QAAA;AAAA,UAEJ,QAAA,EAAA,KAAA;AAAA,SACH,CAAA;AAAA,wBACC,GAAA,CAAA,aAAA,EAAA;AAAA,UACC,SAAA,EAAW,aAAa,MAAM,CAAA;AAAA,UAC9B,IAAM,EAAA,QAAA;AAAA,UACN,YAAY,EAAA,IAAA;AAAA,UACZ,aAAY,EAAA,MAAA;AAAA,SACd,CAAA;AAAA,OAAA;AAAA,KACF,CAAA;AAAA,GACF,CAAA,CAAA;AAEJ,CAAC;;;;"}
@@ -8,6 +8,7 @@ import '../list/VirtualizedList.js';
8
8
  import '../common-hooks/collectionProvider.js';
9
9
  import { itemToString } from '../common-hooks/itemToString.js';
10
10
  import '../common-hooks/keyUtils.js';
11
+ import '../utils/useFloatingUI.js';
11
12
  import 'react/jsx-runtime';
12
13
  import '../responsive/useResizeObserver.js';
13
14
 
@@ -1 +1 @@
1
- {"version":3,"file":"useDropdown.js","sources":["../src/dropdown/useDropdown.ts"],"sourcesContent":["import { useControlled } from \"@salt-ds/core\";\nimport { useCallback, useMemo } from \"react\";\nimport { ListHookProps, ListHookResult, useList } from \"../list\";\nimport { DropdownHookResult, DropdownHookProps } from \"./dropdownTypes\";\nimport {\n CollectionItem,\n itemToString as defaultItemToString,\n SelectionChangeHandler,\n SelectionStrategy,\n} from \"../common-hooks\";\n\nconst NULL_REF = { current: null };\n\nexport interface DropdownListHookProps<Item, Strategy extends SelectionStrategy>\n extends Partial<Omit<DropdownHookProps, \"onKeyDown\">>,\n Omit<ListHookProps<Item, Strategy>, \"containerRef\"> {\n itemToString?: (item: Item) => string;\n}\n\nexport interface DropdownListHookResult<\n Item,\n Selection extends SelectionStrategy\n> extends Partial<ListHookResult<Item, Selection>>,\n Partial<DropdownHookResult> {\n onOpenChange: any;\n triggerLabel?: string;\n}\n\nexport const useDropdown = <\n Item,\n Selection extends SelectionStrategy = \"default\"\n>({\n collectionHook,\n defaultHighlightedIndex: defaultHighlightedIndexProp,\n defaultIsOpen,\n defaultSelected,\n highlightedIndex: highlightedIndexProp,\n isOpen: isOpenProp,\n itemToString = defaultItemToString,\n onHighlight,\n onOpenChange,\n onSelectionChange,\n selected,\n selectionStrategy,\n}: DropdownListHookProps<Item, Selection>): DropdownListHookResult<\n Item,\n Selection\n> => {\n const isMultiSelect =\n selectionStrategy === \"multiple\" || selectionStrategy === \"extended\";\n\n const [isOpen, setIsOpen] = useControlled<boolean>({\n controlled: isOpenProp,\n default: defaultIsOpen ?? false,\n name: \"useDropdownList\",\n });\n\n const handleSelectionChange = useCallback<\n SelectionChangeHandler<Item, Selection>\n >(\n (evt, selected) => {\n if (!isMultiSelect) {\n setIsOpen(false);\n onOpenChange?.(false);\n }\n onSelectionChange?.(evt, selected);\n },\n [isMultiSelect, onOpenChange, onSelectionChange, setIsOpen]\n );\n\n const listHook = useList<Item, Selection>({\n collectionHook,\n defaultHighlightedIndex:\n defaultHighlightedIndexProp ?? highlightedIndexProp === undefined\n ? 0\n : undefined,\n defaultSelected,\n label: \"useDropDownList\",\n onSelectionChange: handleSelectionChange,\n containerRef: NULL_REF,\n highlightedIndex: highlightedIndexProp,\n onHighlight,\n selected,\n selectionStrategy,\n tabToSelect: !isMultiSelect,\n });\n\n const handleOpenChange = useCallback(\n (open: boolean) => {\n setIsOpen(open);\n onOpenChange?.(open);\n },\n [onOpenChange, setIsOpen]\n );\n\n const triggerLabel = useMemo(() => {\n if (isMultiSelect && Array.isArray(listHook.selected)) {\n const selectedItems = listHook.selected as CollectionItem<Item>[];\n if (selectedItems.length === 0) {\n return undefined;\n } else if (selectedItems.length === 1) {\n const { value } = selectedItems[0];\n return value === null ? undefined : itemToString(value);\n } else {\n return `${selectedItems.length} items selected`;\n }\n } else {\n const selectedItem = listHook.selected as CollectionItem<Item>;\n return selectedItem == null || selectedItem.value === null\n ? undefined\n : itemToString(selectedItem.value);\n }\n }, [isMultiSelect, itemToString, listHook.selected]);\n\n return {\n isOpen,\n onOpenChange: handleOpenChange,\n triggerLabel,\n ...listHook,\n };\n};\n"],"names":["itemToString","defaultItemToString","selected"],"mappings":"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"}
1
+ {"version":3,"file":"useDropdown.js","sources":["../src/dropdown/useDropdown.ts"],"sourcesContent":["import { useControlled } from \"@salt-ds/core\";\nimport { useCallback, useMemo } from \"react\";\nimport { ListHookProps, ListHookResult, useList } from \"../list\";\nimport { DropdownHookResult, DropdownHookProps } from \"./dropdownTypes\";\nimport {\n CollectionItem,\n itemToString as defaultItemToString,\n SelectionChangeHandler,\n SelectionStrategy,\n} from \"../common-hooks\";\n\nconst NULL_REF = { current: null };\n\nexport interface DropdownListHookProps<Item, Strategy extends SelectionStrategy>\n extends Partial<Omit<DropdownHookProps, \"onKeyDown\">>,\n Omit<ListHookProps<Item, Strategy>, \"containerRef\"> {\n itemToString?: (item: Item) => string;\n}\n\nexport interface DropdownListHookResult<\n Item,\n Selection extends SelectionStrategy\n> extends Partial<ListHookResult<Item, Selection>>,\n Partial<DropdownHookResult> {\n onOpenChange: any;\n triggerLabel?: string;\n}\n\nexport const useDropdown = <\n Item,\n Selection extends SelectionStrategy = \"default\"\n>({\n collectionHook,\n defaultHighlightedIndex: defaultHighlightedIndexProp,\n defaultIsOpen,\n defaultSelected,\n highlightedIndex: highlightedIndexProp,\n isOpen: isOpenProp,\n itemToString = defaultItemToString,\n onHighlight,\n onOpenChange,\n onSelectionChange,\n selected,\n selectionStrategy,\n}: DropdownListHookProps<Item, Selection>): DropdownListHookResult<\n Item,\n Selection\n> => {\n const isMultiSelect =\n selectionStrategy === \"multiple\" || selectionStrategy === \"extended\";\n\n const [isOpen, setIsOpen] = useControlled<boolean>({\n controlled: isOpenProp,\n default: defaultIsOpen ?? false,\n name: \"useDropdownList\",\n });\n\n const handleSelectionChange = useCallback<\n SelectionChangeHandler<Item, Selection>\n >(\n (evt, selected) => {\n if (!isMultiSelect) {\n setIsOpen(false);\n onOpenChange?.(false);\n }\n onSelectionChange?.(evt, selected);\n },\n [isMultiSelect, onOpenChange, onSelectionChange, setIsOpen]\n );\n\n const listHook = useList<Item, Selection>({\n collectionHook,\n defaultHighlightedIndex:\n defaultHighlightedIndexProp ?? highlightedIndexProp === undefined\n ? 0\n : undefined,\n defaultSelected,\n label: \"useDropDownList\",\n onSelectionChange: handleSelectionChange,\n containerRef: NULL_REF,\n highlightedIndex: highlightedIndexProp,\n onHighlight,\n selected,\n selectionStrategy,\n tabToSelect: !isMultiSelect,\n });\n\n const handleOpenChange = useCallback(\n (open: boolean) => {\n setIsOpen(open);\n onOpenChange?.(open);\n },\n [onOpenChange, setIsOpen]\n );\n\n const triggerLabel = useMemo(() => {\n if (isMultiSelect && Array.isArray(listHook.selected)) {\n const selectedItems = listHook.selected as CollectionItem<Item>[];\n if (selectedItems.length === 0) {\n return undefined;\n } else if (selectedItems.length === 1) {\n const { value } = selectedItems[0];\n return value === null ? undefined : itemToString(value);\n } else {\n return `${selectedItems.length} items selected`;\n }\n } else {\n const selectedItem = listHook.selected as CollectionItem<Item>;\n return selectedItem == null || selectedItem.value === null\n ? undefined\n : itemToString(selectedItem.value);\n }\n }, [isMultiSelect, itemToString, listHook.selected]);\n\n return {\n isOpen,\n onOpenChange: handleOpenChange,\n triggerLabel,\n ...listHook,\n };\n};\n"],"names":["itemToString","defaultItemToString","selected"],"mappings":"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"}
@@ -3,6 +3,7 @@ import { useRef, useCallback, useState } from 'react';
3
3
  import { useClickAway } from './useClickAway.js';
4
4
  import 'react/jsx-runtime';
5
5
  import { useResizeObserver, WidthOnly } from '../responsive/useResizeObserver.js';
6
+ import '../utils/useFloatingUI.js';
6
7
  import '../form-field-context/FormFieldContext.js';
7
8
  import { useFormFieldProps } from '../form-field-context/useFormFieldProps.js';
8
9
 
@@ -1 +1 @@
1
- {"version":3,"file":"useDropdownBase.js","sources":["../src/dropdown/useDropdownBase.ts"],"sourcesContent":["import { useControlled } from \"@salt-ds/core\";\nimport { KeyboardEvent, useCallback, useRef, useState } from \"react\";\n\nimport { DropdownHookProps, DropdownHookResult } from \"./dropdownTypes\";\nimport { useClickAway } from \"./useClickAway\";\nimport { measurements, useResizeObserver, WidthOnly } from \"../responsive\";\nimport { useFormFieldProps } from \"../form-field-context\";\n\nconst NO_OBSERVER: string[] = [];\n\nexport const useDropdownBase = ({\n ariaLabelledBy: ariaLabelledByProp,\n defaultIsOpen,\n disabled,\n // TODO check how we're using fullWidth, do we need a separate value for the popup component\n fullWidth: fullWidthProp,\n id,\n isOpen: isOpenProp,\n onOpenChange,\n onKeyDown: onKeyDownProp,\n openOnFocus,\n popupComponent: { props: componentProps },\n popupWidth: popupWidthProp,\n rootRef,\n width,\n}: DropdownHookProps): DropdownHookResult => {\n const justFocused = useRef<number | null>(null);\n const popperRef = useRef<HTMLElement | null>(null);\n const popperCallbackRef = useCallback((element: HTMLElement | null) => {\n popperRef.current = element;\n }, []);\n const [isOpen, setIsOpen] = useControlled({\n controlled: isOpenProp,\n default: Boolean(defaultIsOpen),\n name: \"useDropdown\",\n state: \"isOpen\",\n });\n\n const {\n inFormField,\n // onFocus: formFieldOnFocus,\n // onBlur: formFieldOnBlur,\n a11yProps: { \"aria-labelledby\": ariaLabelledBy, ...restA11yProps } = {},\n } = useFormFieldProps();\n\n const [popup, setPopup] = useState<measurements>({\n width: popupWidthProp ?? width ?? 0,\n });\n\n const showDropdown = useCallback(() => {\n setIsOpen(true);\n onOpenChange?.(true);\n }, [onOpenChange, setIsOpen]);\n\n const hideDropdown = useCallback(() => {\n setIsOpen(false);\n onOpenChange?.(false);\n }, [onOpenChange, setIsOpen]);\n\n useClickAway({\n popperRef,\n rootRef,\n isOpen,\n onClose: hideDropdown,\n });\n\n const handleTriggerFocus = useCallback(() => {\n setIsOpen(true);\n onOpenChange?.(true);\n // Suppress response to click if click was the cause of focus\n justFocused.current = window.setTimeout(() => {\n justFocused.current = null;\n }, 1000);\n }, [onOpenChange, setIsOpen]);\n\n const handleTriggerToggle = useCallback(\n (e: MouseEvent) => {\n // Do not trigger menu open for 'Enter' and 'SPACE' key as they're handled in `handleKeyDown`\n if (\n [\"Enter\", \" \"].indexOf(\n (e as unknown as KeyboardEvent<HTMLDivElement>).key\n ) === -1\n ) {\n const newIsOpen = !isOpen;\n setIsOpen(newIsOpen);\n onOpenChange?.(newIsOpen);\n }\n },\n [isOpen, setIsOpen, onOpenChange]\n );\n\n const handleKeydown = useCallback(\n (evt: KeyboardEvent<HTMLElement>) => {\n if ((evt.key === \"Tab\" || evt.key === \"Escape\") && isOpen) {\n // No preventDefault here, this behaviour does not need to be exclusive\n hideDropdown();\n } else if (\n (evt.key === \"Enter\" || evt.key === \"ArrowDown\" || evt.key === \" \") &&\n !isOpen\n ) {\n evt.preventDefault();\n showDropdown();\n } else {\n onKeyDownProp?.(evt);\n }\n },\n [hideDropdown, isOpen, onKeyDownProp, showDropdown]\n );\n\n const fullWidth = fullWidthProp ?? inFormField;\n const measurements = fullWidth ? WidthOnly : NO_OBSERVER;\n useResizeObserver(rootRef, measurements, setPopup, fullWidth);\n\n const componentId = `${id}-dropdown`;\n\n const getAriaLabelledBy = (\n labelledBy: string | undefined,\n labelledByProp: string | undefined\n ): string | undefined => {\n if (labelledBy === undefined && labelledByProp === undefined) {\n return undefined;\n } else {\n return [labelledBy, labelledByProp].filter((x) => !!x).join(\" \");\n }\n };\n\n // TODO do we use aria-popup - valid values are menu, disloag, grid, tree, listbox\n const triggerProps = {\n ...restA11yProps,\n \"aria-expanded\": isOpen,\n \"aria-labelledby\": getAriaLabelledBy(ariaLabelledBy, ariaLabelledByProp),\n \"aria-owns\": isOpen ? componentId : undefined,\n id: `${id}-control`,\n onClick: disabled || openOnFocus ? undefined : handleTriggerToggle,\n onFocus: openOnFocus && !disabled ? handleTriggerFocus : undefined,\n role: \"listbox\",\n onKeyDown: disabled ? undefined : handleKeydown,\n style: { width: fullWidth ? undefined : width },\n };\n\n const dropdownComponentProps = {\n \"aria-labelledby\": ariaLabelledBy,\n id: componentId,\n width: popup.width,\n };\n\n return {\n componentProps: dropdownComponentProps,\n popperRef: popperCallbackRef,\n isOpen,\n label: \"Dropdown Button\",\n triggerProps,\n };\n};\n"],"names":["measurements"],"mappings":"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"}
1
+ {"version":3,"file":"useDropdownBase.js","sources":["../src/dropdown/useDropdownBase.ts"],"sourcesContent":["import { useControlled } from \"@salt-ds/core\";\nimport { KeyboardEvent, useCallback, useRef, useState } from \"react\";\n\nimport { DropdownHookProps, DropdownHookResult } from \"./dropdownTypes\";\nimport { useClickAway } from \"./useClickAway\";\nimport { measurements, useResizeObserver, WidthOnly } from \"../responsive\";\nimport { useFormFieldProps } from \"../form-field-context\";\n\nconst NO_OBSERVER: string[] = [];\n\nexport const useDropdownBase = ({\n ariaLabelledBy: ariaLabelledByProp,\n defaultIsOpen,\n disabled,\n // TODO check how we're using fullWidth, do we need a separate value for the popup component\n fullWidth: fullWidthProp,\n id,\n isOpen: isOpenProp,\n onOpenChange,\n onKeyDown: onKeyDownProp,\n openOnFocus,\n popupComponent: { props: componentProps },\n popupWidth: popupWidthProp,\n rootRef,\n width,\n}: DropdownHookProps): DropdownHookResult => {\n const justFocused = useRef<number | null>(null);\n const popperRef = useRef<HTMLElement | null>(null);\n const popperCallbackRef = useCallback((element: HTMLElement | null) => {\n popperRef.current = element;\n }, []);\n const [isOpen, setIsOpen] = useControlled({\n controlled: isOpenProp,\n default: Boolean(defaultIsOpen),\n name: \"useDropdown\",\n state: \"isOpen\",\n });\n\n const {\n inFormField,\n // onFocus: formFieldOnFocus,\n // onBlur: formFieldOnBlur,\n a11yProps: { \"aria-labelledby\": ariaLabelledBy, ...restA11yProps } = {},\n } = useFormFieldProps();\n\n const [popup, setPopup] = useState<measurements>({\n width: popupWidthProp ?? width ?? 0,\n });\n\n const showDropdown = useCallback(() => {\n setIsOpen(true);\n onOpenChange?.(true);\n }, [onOpenChange, setIsOpen]);\n\n const hideDropdown = useCallback(() => {\n setIsOpen(false);\n onOpenChange?.(false);\n }, [onOpenChange, setIsOpen]);\n\n useClickAway({\n popperRef,\n rootRef,\n isOpen,\n onClose: hideDropdown,\n });\n\n const handleTriggerFocus = useCallback(() => {\n setIsOpen(true);\n onOpenChange?.(true);\n // Suppress response to click if click was the cause of focus\n justFocused.current = window.setTimeout(() => {\n justFocused.current = null;\n }, 1000);\n }, [onOpenChange, setIsOpen]);\n\n const handleTriggerToggle = useCallback(\n (e: MouseEvent) => {\n // Do not trigger menu open for 'Enter' and 'SPACE' key as they're handled in `handleKeyDown`\n if (\n [\"Enter\", \" \"].indexOf(\n (e as unknown as KeyboardEvent<HTMLDivElement>).key\n ) === -1\n ) {\n const newIsOpen = !isOpen;\n setIsOpen(newIsOpen);\n onOpenChange?.(newIsOpen);\n }\n },\n [isOpen, setIsOpen, onOpenChange]\n );\n\n const handleKeydown = useCallback(\n (evt: KeyboardEvent<HTMLElement>) => {\n if ((evt.key === \"Tab\" || evt.key === \"Escape\") && isOpen) {\n // No preventDefault here, this behaviour does not need to be exclusive\n hideDropdown();\n } else if (\n (evt.key === \"Enter\" || evt.key === \"ArrowDown\" || evt.key === \" \") &&\n !isOpen\n ) {\n evt.preventDefault();\n showDropdown();\n } else {\n onKeyDownProp?.(evt);\n }\n },\n [hideDropdown, isOpen, onKeyDownProp, showDropdown]\n );\n\n const fullWidth = fullWidthProp ?? inFormField;\n const measurements = fullWidth ? WidthOnly : NO_OBSERVER;\n useResizeObserver(rootRef, measurements, setPopup, fullWidth);\n\n const componentId = `${id}-dropdown`;\n\n const getAriaLabelledBy = (\n labelledBy: string | undefined,\n labelledByProp: string | undefined\n ): string | undefined => {\n if (labelledBy === undefined && labelledByProp === undefined) {\n return undefined;\n } else {\n return [labelledBy, labelledByProp].filter((x) => !!x).join(\" \");\n }\n };\n\n // TODO do we use aria-popup - valid values are menu, disloag, grid, tree, listbox\n const triggerProps = {\n ...restA11yProps,\n \"aria-expanded\": isOpen,\n \"aria-labelledby\": getAriaLabelledBy(ariaLabelledBy, ariaLabelledByProp),\n \"aria-owns\": isOpen ? componentId : undefined,\n id: `${id}-control`,\n onClick: disabled || openOnFocus ? undefined : handleTriggerToggle,\n onFocus: openOnFocus && !disabled ? handleTriggerFocus : undefined,\n role: \"listbox\",\n onKeyDown: disabled ? undefined : handleKeydown,\n style: { width: fullWidth ? undefined : width },\n };\n\n const dropdownComponentProps = {\n \"aria-labelledby\": ariaLabelledBy,\n id: componentId,\n width: popup.width,\n };\n\n return {\n componentProps: dropdownComponentProps,\n popperRef: popperCallbackRef,\n isOpen,\n label: \"Dropdown Button\",\n triggerProps,\n };\n};\n"],"names":["measurements"],"mappings":"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"}
@@ -1,5 +1,5 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
- import cx from 'classnames';
2
+ import { clsx } from 'clsx';
3
3
  import { forwardRef, useRef, useCallback } from 'react';
4
4
  import { useControlled, useIsomorphicLayoutEffect } from '@salt-ds/core';
5
5
  import { Input } from '../input/Input.js';
@@ -79,7 +79,7 @@ const EditableLabel = forwardRef(function EditableLabel2({
79
79
  exitEditMode({ cancelEdit: true });
80
80
  }
81
81
  };
82
- const className = cx(classBase, classNameProp, {
82
+ const className = clsx(classBase, classNameProp, {
83
83
  [`${classBase}-editing`]: editing
84
84
  });
85
85
  return /* @__PURE__ */ jsx("div", {