@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":"CascadingMenuItem.js","sources":["../src/cascading-menu/CascadingMenuItem.tsx"],"sourcesContent":["import { makePrefixer, useForkRef } from \"@salt-ds/core\";\nimport { ChevronRightIcon } from \"@salt-ds/icons\";\nimport classnames from \"classnames\";\nimport {\n forwardRef,\n KeyboardEvent,\n MouseEvent,\n useEffect,\n useRef,\n useState,\n} from \"react\";\nimport { ListItem, ListItemProps } from \"../list-deprecated\";\nimport { MenuDescriptor } from \"./CascadingMenuProps\";\nimport { Tooltip, useTooltip } from \"../tooltip\";\n\nimport \"./CascadingMenuItem.css\";\n\nconst noop = () => undefined;\nconst withBaseName = makePrefixer(\"saltMenuItem\");\n\nconst getIcon = (sourceItem: MenuDescriptor, isDisabled = false) => {\n const CustomIcon = sourceItem.icon;\n if (CustomIcon) {\n return (\n <CustomIcon\n className={classnames(withBaseName(\"menuItemStartAdornment\"), {\n [withBaseName(\"menuItemDisabled\")]: isDisabled,\n })}\n />\n );\n } else {\n return null;\n }\n};\n\nexport interface MenuItemProps extends ListItemProps<MenuDescriptor> {\n blurSelected: boolean;\n className?: string;\n hasEndAdornment: boolean;\n hasScrollbar: boolean;\n hasStartAdornment: boolean;\n hasSubMenu: boolean;\n isInteracted: boolean;\n isChildMenuOpen: boolean;\n isNavigatingWithKeyboard: boolean;\n itemToString: Required<ListItemProps<MenuDescriptor>>[\"itemToString\"];\n onItemClick?: (\n sourceItem: MenuDescriptor,\n event: MouseEvent | KeyboardEvent\n ) => void;\n sourceItem: MenuDescriptor;\n tooltipEnterDelay: number;\n tooltipLeaveDelay: number;\n}\n\nexport const DefaultMenuItem = forwardRef<HTMLDivElement, MenuItemProps>(\n function (props, ref) {\n const {\n blurSelected,\n className,\n hasEndAdornment,\n hasScrollbar,\n hasStartAdornment,\n onItemClick,\n itemToString,\n isInteracted,\n isNavigatingWithKeyboard,\n isChildMenuOpen,\n hasSubMenu,\n sourceItem,\n tooltipEnterDelay,\n tooltipLeaveDelay,\n ...restProps\n } = props;\n\n const menuTextRef = useRef<HTMLDivElement>(null);\n const [hasTooltip, setHasTooltip] = useState(false);\n const menuText = itemToString(sourceItem);\n\n useEffect(() => {\n const element = menuTextRef.current;\n if (element) {\n if (element.offsetWidth < element.scrollWidth) {\n setHasTooltip(true);\n }\n }\n }, [menuText]);\n\n const isDisabled = sourceItem.disabled;\n const divider = sourceItem.divider;\n\n const onClick = isDisabled || hasSubMenu ? noop : onItemClick;\n\n const handleOnClick = (event: MouseEvent) => {\n if (!isDisabled && !hasSubMenu) {\n onClick?.(sourceItem, event);\n }\n };\n const interactionClasses = isNavigatingWithKeyboard\n ? {\n [withBaseName(`menuItemKeyboardActive`)]:\n !isDisabled && isInteracted && !blurSelected,\n [withBaseName(`menuItemKeyboardDisabled`)]:\n isDisabled && isInteracted,\n }\n : {\n [withBaseName(`menuItemHover`)]: !isDisabled && !blurSelected,\n };\n\n const icon = hasStartAdornment ? getIcon(sourceItem, isDisabled) : null;\n const tooltipTitle = sourceItem.tooltip || menuText;\n const { getTooltipProps, getTriggerProps } = useTooltip({\n disableFocusListener: true,\n disableHoverListener: true,\n enterDelay: tooltipEnterDelay,\n leaveDelay: tooltipLeaveDelay,\n placement: \"top\",\n disabled: !tooltipTitle || !hasTooltip || isChildMenuOpen,\n });\n\n const { ref: triggerRef, ...triggerProps } = getTriggerProps<\n typeof ListItem\n >({\n \"aria-expanded\": isChildMenuOpen || undefined,\n className: classnames(\n withBaseName(),\n {\n [withBaseName(\"menuItemDivider\")]: divider,\n [withBaseName(\"menuItemBlurSelected\")]: blurSelected,\n [withBaseName(\"menuItemSelected\")]:\n !isDisabled && !hasSubMenu && isInteracted,\n ...interactionClasses,\n [withBaseName(\"menuItemWithScrollbar\")]: hasScrollbar,\n },\n className\n ),\n disabled: isDisabled,\n role: \"menuitem\",\n onClick: handleOnClick,\n item: sourceItem,\n // TODO highlightProps - see original code?\n ...restProps,\n });\n\n const handleRef = useForkRef<HTMLDivElement>(triggerRef, ref);\n\n return (\n <>\n <Tooltip\n {...getTooltipProps({\n title: tooltipTitle,\n })}\n />\n <ListItem {...triggerProps} ref={handleRef}>\n {hasStartAdornment && (\n <div className={withBaseName(\"menuItemStartAdornmentContainer\")}>\n {icon}\n </div>\n )}\n <div\n className={classnames(withBaseName(\"menuItemText\"), {\n [withBaseName(\"menuItemDisabled\")]: isDisabled,\n })}\n ref={menuTextRef}\n >\n {menuText}\n </div>\n {hasEndAdornment && (\n <div\n className={classnames(\n withBaseName(\"menuItemEndAdornmentContainer\"),\n {\n [withBaseName(\"menuItemAdornmentHidden\")]: !hasSubMenu,\n }\n )}\n >\n <ChevronRightIcon\n className={classnames(withBaseName(\"menuItemEndAdornment\"), {\n [withBaseName(\"menuItemDisabled\")]: isDisabled,\n })}\n />\n </div>\n )}\n {divider && <div role=\"separator\" />}\n </ListItem>\n </>\n );\n }\n);\n"],"names":["classnames","ListItem"],"mappings":"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"}
1
+ {"version":3,"file":"CascadingMenuItem.js","sources":["../src/cascading-menu/CascadingMenuItem.tsx"],"sourcesContent":["import { makePrefixer, Tooltip } from \"@salt-ds/core\";\nimport { ChevronRightIcon } from \"@salt-ds/icons\";\nimport { clsx } from \"clsx\";\nimport {\n forwardRef,\n KeyboardEvent,\n MouseEvent,\n useEffect,\n useRef,\n useState,\n} from \"react\";\nimport { ListItem, ListItemProps } from \"../list-deprecated\";\nimport { MenuDescriptor } from \"./CascadingMenuProps\";\n\nimport \"./CascadingMenuItem.css\";\n\nconst noop = () => undefined;\nconst withBaseName = makePrefixer(\"saltMenuItem\");\n\nconst getIcon = (sourceItem: MenuDescriptor, isDisabled = false) => {\n const CustomIcon = sourceItem.icon;\n if (CustomIcon) {\n return (\n <CustomIcon\n className={clsx(withBaseName(\"menuItemStartAdornment\"), {\n [withBaseName(\"menuItemDisabled\")]: isDisabled,\n })}\n />\n );\n } else {\n return null;\n }\n};\n\nexport interface MenuItemProps extends ListItemProps<MenuDescriptor> {\n blurSelected: boolean;\n className?: string;\n hasEndAdornment: boolean;\n hasScrollbar: boolean;\n hasStartAdornment: boolean;\n hasSubMenu: boolean;\n isInteracted: boolean;\n isChildMenuOpen: boolean;\n isNavigatingWithKeyboard: boolean;\n itemToString: Required<ListItemProps<MenuDescriptor>>[\"itemToString\"];\n onItemClick?: (\n sourceItem: MenuDescriptor,\n event: MouseEvent | KeyboardEvent\n ) => void;\n sourceItem: MenuDescriptor;\n tooltipEnterDelay: number;\n tooltipLeaveDelay: number;\n}\n\nexport const DefaultMenuItem = forwardRef<HTMLDivElement, MenuItemProps>(\n function (props, ref) {\n const {\n blurSelected,\n className,\n hasEndAdornment,\n hasScrollbar,\n hasStartAdornment,\n onItemClick,\n itemToString,\n isInteracted,\n isNavigatingWithKeyboard,\n isChildMenuOpen,\n hasSubMenu,\n sourceItem,\n tooltipEnterDelay,\n tooltipLeaveDelay,\n ...restProps\n } = props;\n\n const menuTextRef = useRef<HTMLDivElement>(null);\n const [hasTooltip, setHasTooltip] = useState(false);\n const menuText = itemToString(sourceItem);\n\n useEffect(() => {\n const element = menuTextRef.current;\n if (element) {\n if (element.offsetWidth < element.scrollWidth) {\n setHasTooltip(true);\n }\n }\n }, [menuText]);\n\n const isDisabled = sourceItem.disabled;\n const divider = sourceItem.divider;\n\n const onClick = isDisabled || hasSubMenu ? noop : onItemClick;\n\n const handleOnClick = (event: MouseEvent) => {\n if (!isDisabled && !hasSubMenu) {\n onClick?.(sourceItem, event);\n }\n };\n const interactionClasses = isNavigatingWithKeyboard\n ? {\n [withBaseName(`menuItemKeyboardActive`)]:\n !isDisabled && isInteracted && !blurSelected,\n [withBaseName(`menuItemKeyboardDisabled`)]:\n isDisabled && isInteracted,\n }\n : {\n [withBaseName(`menuItemHover`)]: !isDisabled && !blurSelected,\n };\n\n const icon = hasStartAdornment ? getIcon(sourceItem, isDisabled) : null;\n const tooltipTitle = sourceItem.tooltip || menuText;\n\n return (\n <Tooltip\n disableFocusListener\n disableHoverListener\n enterDelay={tooltipEnterDelay}\n leaveDelay={tooltipLeaveDelay}\n placement=\"top\"\n disabled={!tooltipTitle || !hasTooltip || isChildMenuOpen}\n content={tooltipTitle}\n >\n <ListItem\n ref={ref}\n aria-expanded={isChildMenuOpen || undefined}\n className={clsx(\n withBaseName(),\n {\n [withBaseName(\"menuItemDivider\")]: divider,\n [withBaseName(\"menuItemBlurSelected\")]: blurSelected,\n [withBaseName(\"menuItemSelected\")]:\n !isDisabled && !hasSubMenu && isInteracted,\n ...interactionClasses,\n [withBaseName(\"menuItemWithScrollbar\")]: hasScrollbar,\n },\n className\n )}\n disabled={isDisabled}\n role=\"menuitem\"\n onClick={handleOnClick}\n item={sourceItem}\n // TODO highlightProps - see original code?\n {...restProps}\n >\n {hasStartAdornment && (\n <div className={withBaseName(\"menuItemStartAdornmentContainer\")}>\n {icon}\n </div>\n )}\n <div\n className={clsx(withBaseName(\"menuItemText\"), {\n [withBaseName(\"menuItemDisabled\")]: isDisabled,\n })}\n ref={menuTextRef}\n >\n {menuText}\n </div>\n {hasEndAdornment && (\n <div\n className={clsx(withBaseName(\"menuItemEndAdornmentContainer\"), {\n [withBaseName(\"menuItemAdornmentHidden\")]: !hasSubMenu,\n })}\n >\n <ChevronRightIcon\n className={clsx(withBaseName(\"menuItemEndAdornment\"), {\n [withBaseName(\"menuItemDisabled\")]: isDisabled,\n })}\n />\n </div>\n )}\n {divider && <div role=\"separator\" />}\n </ListItem>\n </Tooltip>\n );\n }\n);\n"],"names":["ListItem"],"mappings":"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"}
@@ -1,13 +1,15 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
- import { useForkRef, useIsomorphicLayoutEffect } from '@salt-ds/core';
3
- import cx from 'classnames';
2
+ import { useForkRef, useFloatingUI, useIsomorphicLayoutEffect } from '@salt-ds/core';
3
+ import { clsx } from 'clsx';
4
4
  import { forwardRef, useState, useCallback, useEffect, useMemo } from 'react';
5
+ import { Portal } from '../portal/Portal.js';
5
6
  import { List } from '../list-deprecated/List.js';
6
7
  import '../list-deprecated/ListBase.js';
7
8
  import '../list-deprecated/ListItemBase.js';
8
9
  import '../list-deprecated/ListItem.js';
9
10
  import '../list-deprecated/ListItemContext.js';
10
11
  import '../list-deprecated/ListStateContext.js';
12
+ import '../utils/useFloatingUI.js';
11
13
  import { DefaultMenuItem } from './CascadingMenuItem.js';
12
14
  import { CascadingMenuAction } from './internal/CascadingMenuAction.js';
13
15
  import { getKeyDownHandlers } from './internal/keydownHandlers.js';
@@ -17,8 +19,6 @@ import { useMouseHandlers } from './internal/useMouseHandlers.js';
17
19
  import { stateChangeTypes } from './stateChangeTypes.js';
18
20
  import { useWindow } from '../window/WindowContext.js';
19
21
  import '../window/ElectronWindow.js';
20
- import { useFloatingUI } from '../popper/useFloatingUI.js';
21
- import { Portal } from '../portal/Portal.js';
22
22
  import './CascadingMenuList.css.js';
23
23
 
24
24
  const CascadingMenuList = forwardRef(function CascadingMenuList2(props, ref) {
@@ -134,7 +134,7 @@ const CascadingMenuList = forwardRef(function CascadingMenuList2(props, ref) {
134
134
  },
135
135
  ref: floating,
136
136
  children: /* @__PURE__ */ jsx(List, {
137
- className: cx(baseClass, className),
137
+ className: clsx(baseClass, className),
138
138
  height: menuContainerHeight,
139
139
  highlightedIndex: highlightedItemIndex === null ? -1 : highlightedItemIndex,
140
140
  id: menuId,
@@ -1 +1 @@
1
- {"version":3,"file":"CascadingMenuList.js","sources":["../src/cascading-menu/CascadingMenuList.tsx"],"sourcesContent":["import { useForkRef, useIsomorphicLayoutEffect } from \"@salt-ds/core\";\nimport classnames from \"classnames\";\nimport { forwardRef, useCallback, useEffect, useMemo, useState } from \"react\";\nimport { List, ListProps } from \"../list-deprecated\";\n\nimport { DefaultMenuItem, MenuItemProps } from \"./CascadingMenuItem\";\nimport { CascadingMenuAction } from \"./internal/CascadingMenuAction\";\nimport { getKeyDownHandlers } from \"./internal/keydownHandlers\";\nimport {\n getHeight,\n getMaxHeight,\n screenBounds,\n} from \"./internal/menuPositioning\";\nimport { hasIcon, hasSubMenu, menuState } from \"./internal/stateUtils\";\nimport { useMouseHandlers } from \"./internal/useMouseHandlers\";\nimport { refsManager } from \"./internal/useRefsManager\";\nimport { stateChangeTypes } from \"./stateChangeTypes\";\nimport { useWindow } from \"../window\";\nimport { useFloatingUI, UseFloatingUIProps } from \"../popper\";\nimport { Portal } from \"../portal\";\n\nimport \"./CascadingMenuList.css\";\n\nexport interface CascadingMenuListProps {\n className?: string;\n data: menuState;\n delay?: number;\n disableMouseOutInteractions?: boolean;\n // TODO any\n dispatch: (action: any) => void;\n getBoundingClientRect?: (element: HTMLElement) => DOMRect;\n getScreenBounds?: () => screenBounds;\n height?: number;\n highlightedItemIndex: number | null;\n isChildMenuOpen: boolean;\n itemToString: MenuItemProps[\"itemToString\"];\n isNavigatingWithKeyboard: boolean;\n isRoot: boolean;\n maxWidth?: ListProps[\"maxWidth\"];\n menuId: string;\n menuTriggerRef: HTMLElement | null;\n minWidth?: ListProps[\"minWidth\"];\n onItemClick?: MenuItemProps[\"onItemClick\"];\n parentElement?: HTMLElement | null;\n refsManager: refsManager;\n rootPlacement?: UseFloatingUIProps[\"placement\"];\n rootPlacementOffset?: string;\n rowHeight?: number;\n setIsNavigatingWithKeyboard: (value: boolean) => void;\n tooltipEnterDelay: number;\n tooltipLeaveDelay: number;\n}\n\nexport const CascadingMenuList = forwardRef<\n HTMLDivElement,\n CascadingMenuListProps\n>(function CascadingMenuList(props, ref) {\n const {\n className,\n maxWidth,\n minWidth,\n itemToString,\n onItemClick,\n refsManager,\n dispatch,\n rowHeight: rowHeightProp,\n isNavigatingWithKeyboard,\n data,\n tooltipEnterDelay,\n tooltipLeaveDelay,\n height: heightProp,\n isChildMenuOpen,\n isRoot,\n highlightedItemIndex,\n menuId,\n parentElement = null,\n getScreenBounds,\n disableMouseOutInteractions,\n rootPlacementOffset,\n rootPlacement = \"bottom-start\",\n } = props;\n\n const baseClass = \"saltCascadingMenuList\";\n\n const [menuRef, setInternalMenuRef] = useState<HTMLElement | null>(null);\n const setMenuRef = useCallback(\n (node: HTMLElement) => {\n refsManager.set(menuId, node);\n },\n [refsManager, menuId]\n );\n\n // TODO removed useCharacteristic here\n const sizeStackable = 36;\n const defaultRowHeight = sizeStackable;\n\n // TODO removed useCharacteristic here\n const spacing = 8;\n\n const isMenuActiveState = useState(true);\n const [isMenuActive, setIsMenuActive] = isMenuActiveState;\n const listRef = useForkRef<HTMLElement>(ref, setInternalMenuRef);\n const handleRef = useForkRef(setMenuRef, listRef);\n\n useEffect(() => {\n if (menuRef && menuRef.focus) {\n // timeout prevents scrolling issue by waiting a split second\n // and menu should be correctly positioned by then and\n // focusing popper content offscreen will not scroll page\n // it would be better to maybe use popper onUpdate callback\n // or some kind of polling mechanism to confirm placement is\n // correct before focus call\n const id = setTimeout(() => {\n menuRef.focus();\n });\n return () => {\n clearTimeout(id);\n };\n }\n }, [menuRef, rootPlacementOffset]);\n\n const handleKeyDown = getKeyDownHandlers(props, setIsMenuActive);\n\n const onFocusHandler = useCallback(() => {\n setIsMenuActive(true);\n // When navigating via keyboard on open highlight first time in the list\n if (isNavigatingWithKeyboard) {\n if (!highlightedItemIndex) {\n dispatch({\n type: CascadingMenuAction.SET_CURRENT_INTERACTED_ITEM,\n cause: stateChangeTypes.KEYBOARD_NAV_AUTO_FOCUS,\n targetId: menuId,\n highlightedItemIndex: 0,\n });\n }\n }\n }, [\n setIsMenuActive,\n isNavigatingWithKeyboard,\n highlightedItemIndex,\n dispatch,\n menuId,\n ]);\n\n const [handleMouseMove, handleMouseOut] = useMouseHandlers(\n props,\n isMenuActiveState,\n menuRef\n );\n\n const hasEndAdornment = useMemo(\n () => data.menuItems.some(hasSubMenu),\n [data]\n );\n const hasStartAdornment = useMemo(() => data.menuItems.some(hasIcon), [data]);\n const rowHeight = rowHeightProp != null ? rowHeightProp : defaultRowHeight;\n const maxHeight = getMaxHeight(heightProp, spacing, getScreenBounds);\n const calculatedMenuHeight = rowHeight * data.menuItems.length;\n const menuHeight = getHeight(heightProp, calculatedMenuHeight, maxHeight);\n const hasScrollbar = menuHeight >= maxHeight;\n\n // menu container size is 2px larger than the list to include the border\n const menuContainerHeight = menuHeight + 2;\n const Window = useWindow();\n const { reference, floating, x, y, strategy } = useFloatingUI({\n placement: isRoot ? rootPlacement : \"right-start\",\n });\n useIsomorphicLayoutEffect(() => {\n if (parentElement) {\n reference(\n isRoot\n ? parentElement\n : parentElement.querySelector(\n `#${\n parentElement.getAttribute(\"aria-activedescendant\") as string\n }`\n )\n );\n }\n }, [reference, isRoot, parentElement]);\n\n if (parentElement === null) {\n return null;\n }\n\n return (\n <Portal>\n <Window\n className={`${baseClass}-popper`}\n id={menuId}\n style={{\n top: y ?? \"\",\n left: x ?? \"\",\n position: strategy,\n }}\n ref={floating}\n >\n <List\n className={classnames(baseClass, className)}\n height={menuContainerHeight}\n highlightedIndex={\n highlightedItemIndex === null ? -1 : highlightedItemIndex\n }\n id={menuId}\n itemHeight={rowHeight}\n itemToString={itemToString}\n key={menuId}\n listRef={handleRef}\n maxWidth={maxWidth}\n minWidth={minWidth}\n onFocus={onFocusHandler}\n onKeyDown={handleKeyDown}\n onMouseOut={disableMouseOutInteractions ? undefined : handleMouseOut}\n role=\"menu\"\n width=\"auto\"\n >\n {data.menuItems.map((menuItem, idx) => {\n const isInteracted = highlightedItemIndex === idx;\n return (\n <DefaultMenuItem\n blurSelected={!isMenuActive && isInteracted}\n hasEndAdornment={hasEndAdornment}\n hasScrollbar={hasScrollbar}\n hasStartAdornment={hasStartAdornment}\n hasSubMenu={hasSubMenu(menuItem)}\n isChildMenuOpen={isChildMenuOpen}\n isInteracted={isInteracted}\n isNavigatingWithKeyboard={isNavigatingWithKeyboard}\n itemToString={itemToString}\n key={idx}\n onItemClick={onItemClick}\n onMouseMove={() => handleMouseMove(idx)}\n sourceItem={menuItem}\n tooltipEnterDelay={tooltipEnterDelay}\n tooltipLeaveDelay={tooltipLeaveDelay}\n />\n );\n })}\n </List>\n </Window>\n </Portal>\n );\n});\n"],"names":["CascadingMenuList","refsManager","classnames"],"mappings":"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"}
1
+ {"version":3,"file":"CascadingMenuList.js","sources":["../src/cascading-menu/CascadingMenuList.tsx"],"sourcesContent":["import {\n useFloatingUI,\n UseFloatingUIProps,\n useForkRef,\n useIsomorphicLayoutEffect,\n} from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { forwardRef, useCallback, useEffect, useMemo, useState } from \"react\";\nimport { Portal } from \"../portal\";\nimport { List, ListProps } from \"../list-deprecated\";\n\nimport { DefaultMenuItem, MenuItemProps } from \"./CascadingMenuItem\";\nimport { CascadingMenuAction } from \"./internal/CascadingMenuAction\";\nimport { getKeyDownHandlers } from \"./internal/keydownHandlers\";\nimport {\n getHeight,\n getMaxHeight,\n screenBounds,\n} from \"./internal/menuPositioning\";\nimport { hasIcon, hasSubMenu, menuState } from \"./internal/stateUtils\";\nimport { useMouseHandlers } from \"./internal/useMouseHandlers\";\nimport { refsManager } from \"./internal/useRefsManager\";\nimport { stateChangeTypes } from \"./stateChangeTypes\";\nimport { useWindow } from \"../window\";\n\nimport \"./CascadingMenuList.css\";\n\nexport interface CascadingMenuListProps {\n className?: string;\n data: menuState;\n delay?: number;\n disableMouseOutInteractions?: boolean;\n // TODO any\n dispatch: (action: any) => void;\n getBoundingClientRect?: (element: HTMLElement) => DOMRect;\n getScreenBounds?: () => screenBounds;\n height?: number;\n highlightedItemIndex: number | null;\n isChildMenuOpen: boolean;\n itemToString: MenuItemProps[\"itemToString\"];\n isNavigatingWithKeyboard: boolean;\n isRoot: boolean;\n maxWidth?: ListProps[\"maxWidth\"];\n menuId: string;\n menuTriggerRef: HTMLElement | null;\n minWidth?: ListProps[\"minWidth\"];\n onItemClick?: MenuItemProps[\"onItemClick\"];\n parentElement?: HTMLElement | null;\n refsManager: refsManager;\n rootPlacement?: UseFloatingUIProps[\"placement\"];\n rootPlacementOffset?: string;\n rowHeight?: number;\n setIsNavigatingWithKeyboard: (value: boolean) => void;\n tooltipEnterDelay: number;\n tooltipLeaveDelay: number;\n}\n\nexport const CascadingMenuList = forwardRef<\n HTMLDivElement,\n CascadingMenuListProps\n>(function CascadingMenuList(props, ref) {\n const {\n className,\n maxWidth,\n minWidth,\n itemToString,\n onItemClick,\n refsManager,\n dispatch,\n rowHeight: rowHeightProp,\n isNavigatingWithKeyboard,\n data,\n tooltipEnterDelay,\n tooltipLeaveDelay,\n height: heightProp,\n isChildMenuOpen,\n isRoot,\n highlightedItemIndex,\n menuId,\n parentElement = null,\n getScreenBounds,\n disableMouseOutInteractions,\n rootPlacementOffset,\n rootPlacement = \"bottom-start\",\n } = props;\n\n const baseClass = \"saltCascadingMenuList\";\n\n const [menuRef, setInternalMenuRef] = useState<HTMLElement | null>(null);\n const setMenuRef = useCallback(\n (node: HTMLElement) => {\n refsManager.set(menuId, node);\n },\n [refsManager, menuId]\n );\n\n // TODO removed useCharacteristic here\n const sizeStackable = 36;\n const defaultRowHeight = sizeStackable;\n\n // TODO removed useCharacteristic here\n const spacing = 8;\n\n const isMenuActiveState = useState(true);\n const [isMenuActive, setIsMenuActive] = isMenuActiveState;\n const listRef = useForkRef<HTMLElement>(ref, setInternalMenuRef);\n const handleRef = useForkRef(setMenuRef, listRef);\n\n useEffect(() => {\n if (menuRef && menuRef.focus) {\n // timeout prevents scrolling issue by waiting a split second\n // and menu should be correctly positioned by then and\n // focusing popper content offscreen will not scroll page\n // it would be better to maybe use popper onUpdate callback\n // or some kind of polling mechanism to confirm placement is\n // correct before focus call\n const id = setTimeout(() => {\n menuRef.focus();\n });\n return () => {\n clearTimeout(id);\n };\n }\n }, [menuRef, rootPlacementOffset]);\n\n const handleKeyDown = getKeyDownHandlers(props, setIsMenuActive);\n\n const onFocusHandler = useCallback(() => {\n setIsMenuActive(true);\n // When navigating via keyboard on open highlight first time in the list\n if (isNavigatingWithKeyboard) {\n if (!highlightedItemIndex) {\n dispatch({\n type: CascadingMenuAction.SET_CURRENT_INTERACTED_ITEM,\n cause: stateChangeTypes.KEYBOARD_NAV_AUTO_FOCUS,\n targetId: menuId,\n highlightedItemIndex: 0,\n });\n }\n }\n }, [\n setIsMenuActive,\n isNavigatingWithKeyboard,\n highlightedItemIndex,\n dispatch,\n menuId,\n ]);\n\n const [handleMouseMove, handleMouseOut] = useMouseHandlers(\n props,\n isMenuActiveState,\n menuRef\n );\n\n const hasEndAdornment = useMemo(\n () => data.menuItems.some(hasSubMenu),\n [data]\n );\n const hasStartAdornment = useMemo(() => data.menuItems.some(hasIcon), [data]);\n const rowHeight = rowHeightProp != null ? rowHeightProp : defaultRowHeight;\n const maxHeight = getMaxHeight(heightProp, spacing, getScreenBounds);\n const calculatedMenuHeight = rowHeight * data.menuItems.length;\n const menuHeight = getHeight(heightProp, calculatedMenuHeight, maxHeight);\n const hasScrollbar = menuHeight >= maxHeight;\n\n // menu container size is 2px larger than the list to include the border\n const menuContainerHeight = menuHeight + 2;\n const Window = useWindow();\n const { reference, floating, x, y, strategy } = useFloatingUI({\n placement: isRoot ? rootPlacement : \"right-start\",\n });\n useIsomorphicLayoutEffect(() => {\n if (parentElement) {\n reference(\n isRoot\n ? parentElement\n : parentElement.querySelector(\n `#${\n parentElement.getAttribute(\"aria-activedescendant\") as string\n }`\n )\n );\n }\n }, [reference, isRoot, parentElement]);\n\n if (parentElement === null) {\n return null;\n }\n\n return (\n <Portal>\n <Window\n className={`${baseClass}-popper`}\n id={menuId}\n style={{\n top: y ?? \"\",\n left: x ?? \"\",\n position: strategy,\n }}\n ref={floating}\n >\n <List\n className={clsx(baseClass, className)}\n height={menuContainerHeight}\n highlightedIndex={\n highlightedItemIndex === null ? -1 : highlightedItemIndex\n }\n id={menuId}\n itemHeight={rowHeight}\n itemToString={itemToString}\n key={menuId}\n listRef={handleRef}\n maxWidth={maxWidth}\n minWidth={minWidth}\n onFocus={onFocusHandler}\n onKeyDown={handleKeyDown}\n onMouseOut={disableMouseOutInteractions ? undefined : handleMouseOut}\n role=\"menu\"\n width=\"auto\"\n >\n {data.menuItems.map((menuItem, idx) => {\n const isInteracted = highlightedItemIndex === idx;\n return (\n <DefaultMenuItem\n blurSelected={!isMenuActive && isInteracted}\n hasEndAdornment={hasEndAdornment}\n hasScrollbar={hasScrollbar}\n hasStartAdornment={hasStartAdornment}\n hasSubMenu={hasSubMenu(menuItem)}\n isChildMenuOpen={isChildMenuOpen}\n isInteracted={isInteracted}\n isNavigatingWithKeyboard={isNavigatingWithKeyboard}\n itemToString={itemToString}\n key={idx}\n onItemClick={onItemClick}\n onMouseMove={() => handleMouseMove(idx)}\n sourceItem={menuItem}\n tooltipEnterDelay={tooltipEnterDelay}\n tooltipLeaveDelay={tooltipLeaveDelay}\n />\n );\n })}\n </List>\n </Window>\n </Portal>\n );\n});\n"],"names":["CascadingMenuList","refsManager"],"mappings":"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"}
@@ -1,5 +1,6 @@
1
1
  import { useEffect } from 'react';
2
2
  import { useEventCallback } from '../../utils/useEventCallback.js';
3
+ import '../../utils/useFloatingUI.js';
3
4
  import '@salt-ds/core';
4
5
  import { useMountedRef } from './useMountedRef.js';
5
6
 
@@ -1 +1 @@
1
- {"version":3,"file":"useClickAway.js","sources":["../src/cascading-menu/internal/useClickAway.ts"],"sourcesContent":["import { useEffect } from \"react\";\nimport { useEventCallback } from \"../../utils\";\n\nimport { useMountedRef } from \"./useMountedRef\";\n\nfunction eventComingFromNodes(nodes: HTMLElement[], event: MouseEvent) {\n return nodes.some(\n (node) =>\n node != null &&\n (node === event.target || node.contains(event.target as HTMLElement))\n );\n}\n\ntype clickAwayHook = (\n nodes: HTMLElement[] | (() => HTMLElement[]) | null,\n containingDocument: Document,\n onClickAway: (event: FocusEvent) => void,\n onClick: (event: MouseEvent) => void,\n mouseEvent?: keyof DocumentEventMap\n) => void;\n\nexport const useClickAway: clickAwayHook = (\n nodes,\n containingDocument,\n onClickAway,\n onClick = () => undefined,\n mouseEvent = \"mouseup\"\n) => {\n //TODO can we get rid of this if it's just for IE11 ?\n const mountedRef = useMountedRef();\n\n const handleClickAway = useEventCallback((event: MouseEvent) => {\n // Ignore events that have been `event.preventDefault()` marked.\n if (event.defaultPrevented) {\n return;\n }\n\n // IE 11 support, which trigger the handleClickAway even after the unbind\n if (!mountedRef.current) {\n return;\n }\n\n onClick(event);\n\n if (!nodes) {\n return;\n }\n\n const resolvedNodes = typeof nodes === \"function\" ? nodes() : nodes;\n const isEventComingFromNodes = eventComingFromNodes(resolvedNodes, event);\n\n const ownerDocumentNode = resolvedNodes.find((node) =>\n // node could be null, e.g. left click on surrounding area of context menu examples\n node ? node.ownerDocument : false\n );\n const doc =\n containingDocument ||\n (ownerDocumentNode && ownerDocumentNode.ownerDocument);\n\n if (\n doc.documentElement &&\n doc.documentElement.contains(event.target as HTMLElement) &&\n !isEventComingFromNodes\n ) {\n onClickAway(event);\n }\n });\n\n useEffect(() => {\n if (containingDocument) {\n containingDocument.addEventListener(\n mouseEvent,\n handleClickAway as EventListener\n );\n containingDocument.defaultView?.addEventListener(\"blur\", onClickAway);\n }\n return () => {\n if (containingDocument) {\n containingDocument.removeEventListener(\n mouseEvent,\n handleClickAway as EventListener\n );\n containingDocument.defaultView?.removeEventListener(\n \"blur\",\n onClickAway\n );\n }\n };\n }, [handleClickAway, mouseEvent, containingDocument, onClickAway]);\n};\n"],"names":["_a"],"mappings":";;;;;AAKA,SAAS,oBAAA,CAAqB,OAAsB,KAAmB,EAAA;AACrE,EAAA,OAAO,KAAM,CAAA,IAAA;AAAA,IACX,CAAC,IACC,KAAA,IAAA,IAAQ,IACP,KAAA,IAAA,KAAS,MAAM,MAAU,IAAA,IAAA,CAAK,QAAS,CAAA,KAAA,CAAM,MAAqB,CAAA,CAAA;AAAA,GACvE,CAAA;AACF,CAAA;AAUa,MAAA,YAAA,GAA8B,CACzC,KACA,EAAA,kBAAA,EACA,aACA,OAAU,GAAA,MAAM,KAChB,CAAA,EAAA,UAAA,GAAa,SACV,KAAA;AAEH,EAAA,MAAM,aAAa,aAAc,EAAA,CAAA;AAEjC,EAAM,MAAA,eAAA,GAAkB,gBAAiB,CAAA,CAAC,KAAsB,KAAA;AAE9D,IAAA,IAAI,MAAM,gBAAkB,EAAA;AAC1B,MAAA,OAAA;AAAA,KACF;AAGA,IAAI,IAAA,CAAC,WAAW,OAAS,EAAA;AACvB,MAAA,OAAA;AAAA,KACF;AAEA,IAAA,OAAA,CAAQ,KAAK,CAAA,CAAA;AAEb,IAAA,IAAI,CAAC,KAAO,EAAA;AACV,MAAA,OAAA;AAAA,KACF;AAEA,IAAA,MAAM,aAAgB,GAAA,OAAO,KAAU,KAAA,UAAA,GAAa,OAAU,GAAA,KAAA,CAAA;AAC9D,IAAM,MAAA,sBAAA,GAAyB,oBAAqB,CAAA,aAAA,EAAe,KAAK,CAAA,CAAA;AAExE,IAAA,MAAM,oBAAoB,aAAc,CAAA,IAAA;AAAA,MAAK,CAAC,IAAA,KAE5C,IAAO,GAAA,IAAA,CAAK,aAAgB,GAAA,KAAA;AAAA,KAC9B,CAAA;AACA,IAAM,MAAA,GAAA,GACJ,kBACC,IAAA,iBAAA,IAAqB,iBAAkB,CAAA,aAAA,CAAA;AAE1C,IACE,IAAA,GAAA,CAAI,mBACJ,GAAI,CAAA,eAAA,CAAgB,SAAS,KAAM,CAAA,MAAqB,CACxD,IAAA,CAAC,sBACD,EAAA;AACA,MAAA,WAAA,CAAY,KAAK,CAAA,CAAA;AAAA,KACnB;AAAA,GACD,CAAA,CAAA;AAED,EAAA,SAAA,CAAU,MAAM;AApElB,IAAA,IAAA,EAAA,CAAA;AAqEI,IAAA,IAAI,kBAAoB,EAAA;AACtB,MAAmB,kBAAA,CAAA,gBAAA;AAAA,QACjB,UAAA;AAAA,QACA,eAAA;AAAA,OACF,CAAA;AACA,MAAmB,CAAA,EAAA,GAAA,kBAAA,CAAA,WAAA,KAAnB,IAAgC,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,gBAAA,CAAiB,MAAQ,EAAA,WAAA,CAAA,CAAA;AAAA,KAC3D;AACA,IAAA,OAAO,MAAM;AA5EjB,MAAAA,IAAAA,GAAAA,CAAAA;AA6EM,MAAA,IAAI,kBAAoB,EAAA;AACtB,QAAmB,kBAAA,CAAA,mBAAA;AAAA,UACjB,UAAA;AAAA,UACA,eAAA;AAAA,SACF,CAAA;AACA,QAAA,CAAAA,GAAA,GAAA,kBAAA,CAAmB,WAAnB,KAAA,IAAA,GAAA,KAAA,CAAA,GAAAA,GAAgC,CAAA,mBAAA;AAAA,UAC9B,MAAA;AAAA,UACA,WAAA;AAAA,SAAA,CAAA;AAAA,OAEJ;AAAA,KACF,CAAA;AAAA,KACC,CAAC,eAAA,EAAiB,UAAY,EAAA,kBAAA,EAAoB,WAAW,CAAC,CAAA,CAAA;AACnE;;;;"}
1
+ {"version":3,"file":"useClickAway.js","sources":["../src/cascading-menu/internal/useClickAway.ts"],"sourcesContent":["import { useEffect } from \"react\";\nimport { useEventCallback } from \"../../utils\";\n\nimport { useMountedRef } from \"./useMountedRef\";\n\nfunction eventComingFromNodes(nodes: HTMLElement[], event: MouseEvent) {\n return nodes.some(\n (node) =>\n node != null &&\n (node === event.target || node.contains(event.target as HTMLElement))\n );\n}\n\ntype clickAwayHook = (\n nodes: HTMLElement[] | (() => HTMLElement[]) | null,\n containingDocument: Document,\n onClickAway: (event: FocusEvent) => void,\n onClick: (event: MouseEvent) => void,\n mouseEvent?: keyof DocumentEventMap\n) => void;\n\nexport const useClickAway: clickAwayHook = (\n nodes,\n containingDocument,\n onClickAway,\n onClick = () => undefined,\n mouseEvent = \"mouseup\"\n) => {\n //TODO can we get rid of this if it's just for IE11 ?\n const mountedRef = useMountedRef();\n\n const handleClickAway = useEventCallback((event: MouseEvent) => {\n // Ignore events that have been `event.preventDefault()` marked.\n if (event.defaultPrevented) {\n return;\n }\n\n // IE 11 support, which trigger the handleClickAway even after the unbind\n if (!mountedRef.current) {\n return;\n }\n\n onClick(event);\n\n if (!nodes) {\n return;\n }\n\n const resolvedNodes = typeof nodes === \"function\" ? nodes() : nodes;\n const isEventComingFromNodes = eventComingFromNodes(resolvedNodes, event);\n\n const ownerDocumentNode = resolvedNodes.find((node) =>\n // node could be null, e.g. left click on surrounding area of context menu examples\n node ? node.ownerDocument : false\n );\n const doc =\n containingDocument ||\n (ownerDocumentNode && ownerDocumentNode.ownerDocument);\n\n if (\n doc.documentElement &&\n doc.documentElement.contains(event.target as HTMLElement) &&\n !isEventComingFromNodes\n ) {\n onClickAway(event);\n }\n });\n\n useEffect(() => {\n if (containingDocument) {\n containingDocument.addEventListener(\n mouseEvent,\n handleClickAway as EventListener\n );\n containingDocument.defaultView?.addEventListener(\"blur\", onClickAway);\n }\n return () => {\n if (containingDocument) {\n containingDocument.removeEventListener(\n mouseEvent,\n handleClickAway as EventListener\n );\n containingDocument.defaultView?.removeEventListener(\n \"blur\",\n onClickAway\n );\n }\n };\n }, [handleClickAway, mouseEvent, containingDocument, onClickAway]);\n};\n"],"names":["_a"],"mappings":";;;;;;AAKA,SAAS,oBAAA,CAAqB,OAAsB,KAAmB,EAAA;AACrE,EAAA,OAAO,KAAM,CAAA,IAAA;AAAA,IACX,CAAC,IACC,KAAA,IAAA,IAAQ,IACP,KAAA,IAAA,KAAS,MAAM,MAAU,IAAA,IAAA,CAAK,QAAS,CAAA,KAAA,CAAM,MAAqB,CAAA,CAAA;AAAA,GACvE,CAAA;AACF,CAAA;AAUa,MAAA,YAAA,GAA8B,CACzC,KACA,EAAA,kBAAA,EACA,aACA,OAAU,GAAA,MAAM,KAChB,CAAA,EAAA,UAAA,GAAa,SACV,KAAA;AAEH,EAAA,MAAM,aAAa,aAAc,EAAA,CAAA;AAEjC,EAAM,MAAA,eAAA,GAAkB,gBAAiB,CAAA,CAAC,KAAsB,KAAA;AAE9D,IAAA,IAAI,MAAM,gBAAkB,EAAA;AAC1B,MAAA,OAAA;AAAA,KACF;AAGA,IAAI,IAAA,CAAC,WAAW,OAAS,EAAA;AACvB,MAAA,OAAA;AAAA,KACF;AAEA,IAAA,OAAA,CAAQ,KAAK,CAAA,CAAA;AAEb,IAAA,IAAI,CAAC,KAAO,EAAA;AACV,MAAA,OAAA;AAAA,KACF;AAEA,IAAA,MAAM,aAAgB,GAAA,OAAO,KAAU,KAAA,UAAA,GAAa,OAAU,GAAA,KAAA,CAAA;AAC9D,IAAM,MAAA,sBAAA,GAAyB,oBAAqB,CAAA,aAAA,EAAe,KAAK,CAAA,CAAA;AAExE,IAAA,MAAM,oBAAoB,aAAc,CAAA,IAAA;AAAA,MAAK,CAAC,IAAA,KAE5C,IAAO,GAAA,IAAA,CAAK,aAAgB,GAAA,KAAA;AAAA,KAC9B,CAAA;AACA,IAAM,MAAA,GAAA,GACJ,kBACC,IAAA,iBAAA,IAAqB,iBAAkB,CAAA,aAAA,CAAA;AAE1C,IACE,IAAA,GAAA,CAAI,mBACJ,GAAI,CAAA,eAAA,CAAgB,SAAS,KAAM,CAAA,MAAqB,CACxD,IAAA,CAAC,sBACD,EAAA;AACA,MAAA,WAAA,CAAY,KAAK,CAAA,CAAA;AAAA,KACnB;AAAA,GACD,CAAA,CAAA;AAED,EAAA,SAAA,CAAU,MAAM;AApElB,IAAA,IAAA,EAAA,CAAA;AAqEI,IAAA,IAAI,kBAAoB,EAAA;AACtB,MAAmB,kBAAA,CAAA,gBAAA;AAAA,QACjB,UAAA;AAAA,QACA,eAAA;AAAA,OACF,CAAA;AACA,MAAmB,CAAA,EAAA,GAAA,kBAAA,CAAA,WAAA,KAAnB,IAAgC,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,gBAAA,CAAiB,MAAQ,EAAA,WAAA,CAAA,CAAA;AAAA,KAC3D;AACA,IAAA,OAAO,MAAM;AA5EjB,MAAAA,IAAAA,GAAAA,CAAAA;AA6EM,MAAA,IAAI,kBAAoB,EAAA;AACtB,QAAmB,kBAAA,CAAA,mBAAA;AAAA,UACjB,UAAA;AAAA,UACA,eAAA;AAAA,SACF,CAAA;AACA,QAAA,CAAAA,GAAA,GAAA,kBAAA,CAAmB,WAAnB,KAAA,IAAA,GAAA,KAAA,CAAA,GAAAA,GAAgC,CAAA,mBAAA;AAAA,UAC9B,MAAA;AAAA,UACA,WAAA;AAAA,SAAA,CAAA;AAAA,OAEJ;AAAA,KACF,CAAA;AAAA,KACC,CAAC,eAAA,EAAiB,UAAY,EAAA,kBAAA,EAAoB,WAAW,CAAC,CAAA,CAAA;AACnE;;;;"}
@@ -1,5 +1,6 @@
1
1
  import { isValidElement } from 'react';
2
2
  import { useEventCallback } from '../../utils/useEventCallback.js';
3
+ import '../../utils/useFloatingUI.js';
3
4
  import '@salt-ds/core';
4
5
  import { stateChangeTypes } from '../stateChangeTypes.js';
5
6
  import { CascadingMenuAction } from './CascadingMenuAction.js';
@@ -1 +1 @@
1
- {"version":3,"file":"useMenuTriggerHandlers.js","sources":["../src/cascading-menu/internal/useMenuTriggerHandlers.ts"],"sourcesContent":["import { useEventCallback } from \"../../utils\";\nimport { stateChangeTypes } from \"../stateChangeTypes\";\nimport { CascadingMenuAction } from \"./CascadingMenuAction\";\nimport { CascadingMenuProps } from \"../CascadingMenuProps\";\nimport { menuState } from \"./stateUtils\";\nimport { stateItem } from \"./useStateReducer\";\nimport {\n HTMLAttributes,\n isValidElement,\n MouseEvent,\n KeyboardEvent,\n} from \"react\";\n\ninterface useMenuTriggerHandlersProps {\n dispatch: (action: any) => void;\n children: CascadingMenuProps[\"children\"];\n setIsNavigatingWithKeyboard: (value: boolean) => void;\n openCloseMenu: (open: boolean) => void;\n rootMenuState: stateItem;\n rootMenuId: string | undefined;\n menusDataById: Record<string, menuState>;\n}\n\nexport function useMenuTriggerHandlers({\n dispatch,\n children,\n setIsNavigatingWithKeyboard,\n openCloseMenu,\n rootMenuState,\n rootMenuId,\n menusDataById = {},\n}: useMenuTriggerHandlersProps) {\n const handleOnClick = useEventCallback((event: MouseEvent<HTMLElement>) => {\n const { type } = event;\n\n setIsNavigatingWithKeyboard(false);\n if (type === \"click\") {\n if (isValidElement(children)) {\n const childrenProps = children.props as HTMLAttributes<HTMLElement>;\n childrenProps.onClick?.(event);\n }\n openCloseMenu(!rootMenuState);\n }\n });\n\n const handleOnKeydown = useEventCallback(\n (event: KeyboardEvent<HTMLElement>) => {\n const { key } = event;\n\n switch (key) {\n case \"Spacebar\":\n case \" \":\n case \"Enter\":\n event.stopPropagation();\n event.preventDefault();\n setIsNavigatingWithKeyboard(true);\n dispatch({\n type: rootMenuState\n ? CascadingMenuAction.CLOSE_MENU\n : CascadingMenuAction.OPEN_MENU,\n cause: stateChangeTypes.KEYBOARD_TOGGLE,\n targetId: rootMenuId,\n });\n break;\n case \"ArrowDown\":\n event.stopPropagation();\n event.preventDefault();\n setIsNavigatingWithKeyboard(true);\n if (rootMenuState) {\n break;\n }\n dispatch({\n type: CascadingMenuAction.OPEN_MENU,\n cause: stateChangeTypes.KEYBOARD_TOGGLE,\n targetId: rootMenuId,\n });\n break;\n case \"ArrowUp\":\n event.stopPropagation();\n event.preventDefault();\n setIsNavigatingWithKeyboard(true);\n if (rootMenuState || !rootMenuId) {\n break;\n }\n dispatch({\n type: CascadingMenuAction.OPEN_MENU,\n cause: stateChangeTypes.KEYBOARD_TOGGLE,\n targetId: rootMenuId,\n });\n dispatch({\n type: CascadingMenuAction.SET_CURRENT_INTERACTED_ITEM,\n cause: stateChangeTypes.ITEM_KEYDOWN_ARROW_UP,\n targetId: rootMenuId,\n highlightedItemIndex:\n menusDataById[rootMenuId].menuItems.length - 1,\n });\n break;\n default:\n break;\n }\n\n if (isValidElement(children)) {\n const childrenProps = children.props as HTMLAttributes<HTMLElement>;\n childrenProps.onKeyDown?.(event);\n }\n }\n );\n\n return [handleOnClick, handleOnKeydown] as const;\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"useMenuTriggerHandlers.js","sources":["../src/cascading-menu/internal/useMenuTriggerHandlers.ts"],"sourcesContent":["import { useEventCallback } from \"../../utils\";\nimport { stateChangeTypes } from \"../stateChangeTypes\";\nimport { CascadingMenuAction } from \"./CascadingMenuAction\";\nimport { CascadingMenuProps } from \"../CascadingMenuProps\";\nimport { menuState } from \"./stateUtils\";\nimport { stateItem } from \"./useStateReducer\";\nimport {\n HTMLAttributes,\n isValidElement,\n MouseEvent,\n KeyboardEvent,\n} from \"react\";\n\ninterface useMenuTriggerHandlersProps {\n dispatch: (action: any) => void;\n children: CascadingMenuProps[\"children\"];\n setIsNavigatingWithKeyboard: (value: boolean) => void;\n openCloseMenu: (open: boolean) => void;\n rootMenuState: stateItem;\n rootMenuId: string | undefined;\n menusDataById: Record<string, menuState>;\n}\n\nexport function useMenuTriggerHandlers({\n dispatch,\n children,\n setIsNavigatingWithKeyboard,\n openCloseMenu,\n rootMenuState,\n rootMenuId,\n menusDataById = {},\n}: useMenuTriggerHandlersProps) {\n const handleOnClick = useEventCallback((event: MouseEvent<HTMLElement>) => {\n const { type } = event;\n\n setIsNavigatingWithKeyboard(false);\n if (type === \"click\") {\n if (isValidElement(children)) {\n const childrenProps = children.props as HTMLAttributes<HTMLElement>;\n childrenProps.onClick?.(event);\n }\n openCloseMenu(!rootMenuState);\n }\n });\n\n const handleOnKeydown = useEventCallback(\n (event: KeyboardEvent<HTMLElement>) => {\n const { key } = event;\n\n switch (key) {\n case \"Spacebar\":\n case \" \":\n case \"Enter\":\n event.stopPropagation();\n event.preventDefault();\n setIsNavigatingWithKeyboard(true);\n dispatch({\n type: rootMenuState\n ? CascadingMenuAction.CLOSE_MENU\n : CascadingMenuAction.OPEN_MENU,\n cause: stateChangeTypes.KEYBOARD_TOGGLE,\n targetId: rootMenuId,\n });\n break;\n case \"ArrowDown\":\n event.stopPropagation();\n event.preventDefault();\n setIsNavigatingWithKeyboard(true);\n if (rootMenuState) {\n break;\n }\n dispatch({\n type: CascadingMenuAction.OPEN_MENU,\n cause: stateChangeTypes.KEYBOARD_TOGGLE,\n targetId: rootMenuId,\n });\n break;\n case \"ArrowUp\":\n event.stopPropagation();\n event.preventDefault();\n setIsNavigatingWithKeyboard(true);\n if (rootMenuState || !rootMenuId) {\n break;\n }\n dispatch({\n type: CascadingMenuAction.OPEN_MENU,\n cause: stateChangeTypes.KEYBOARD_TOGGLE,\n targetId: rootMenuId,\n });\n dispatch({\n type: CascadingMenuAction.SET_CURRENT_INTERACTED_ITEM,\n cause: stateChangeTypes.ITEM_KEYDOWN_ARROW_UP,\n targetId: rootMenuId,\n highlightedItemIndex:\n menusDataById[rootMenuId].menuItems.length - 1,\n });\n break;\n default:\n break;\n }\n\n if (isValidElement(children)) {\n const childrenProps = children.props as HTMLAttributes<HTMLElement>;\n childrenProps.onKeyDown?.(event);\n }\n }\n );\n\n return [handleOnClick, handleOnKeydown] as const;\n}\n"],"names":[],"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, useContext } from 'react';
4
4
  import { createChainedFunction } from '@salt-ds/core';
5
5
  import { ControlLabel } from '../control-label/ControlLabel.js';
@@ -39,7 +39,7 @@ const Checkbox = forwardRef(
39
39
  }
40
40
  return /* @__PURE__ */ jsx("div", {
41
41
  ...rest,
42
- className: cx(classBase, className, {
42
+ className: clsx(classBase, className, {
43
43
  [`${classBase}-disabled`]: disabled
44
44
  }),
45
45
  "data-testid": "checkbox",
@@ -1 +1 @@
1
- {"version":3,"file":"Checkbox.js","sources":["../src/checkbox/Checkbox.tsx"],"sourcesContent":["import classnames from \"classnames\";\nimport { forwardRef, useContext } from \"react\";\nimport { createChainedFunction } from \"@salt-ds/core\";\nimport { ControlLabel, ControlLabelProps } from \"../control-label\";\nimport { CheckboxBase, CheckboxBaseProps } from \"./CheckboxBase\";\nimport { CheckboxGroupContext } from \"./internal/CheckboxGroupContext\";\n\nimport \"./Checkbox.css\";\n\nexport interface CheckboxProps extends CheckboxBaseProps {\n label?: ControlLabelProps[\"label\"];\n LabelProps?: Partial<ControlLabelProps>;\n}\n\nconst classBase = \"saltCheckbox\";\n\nexport const Checkbox = forwardRef<HTMLDivElement, CheckboxProps>(\n function Checkbox(props, ref) {\n const {\n checked: checkedProp,\n className,\n defaultChecked: defaultCheckedProp,\n disabled,\n indeterminate,\n inputProps,\n label,\n LabelProps,\n onChange,\n value,\n ...rest\n } = props;\n\n const groupContext = useContext(CheckboxGroupContext);\n\n const handleChange = createChainedFunction(\n onChange,\n groupContext?.onChange\n );\n\n let checked = checkedProp;\n let defaultChecked = defaultCheckedProp;\n\n if (groupContext) {\n if (typeof checked === \"undefined\" && typeof value === \"string\") {\n checked = groupContext?.checkedValues?.includes(value);\n }\n\n defaultChecked = undefined;\n }\n\n return (\n <div\n {...rest}\n className={classnames(classBase, className, {\n [`${classBase}-disabled`]: disabled,\n })}\n data-testid=\"checkbox\"\n ref={ref}\n >\n <ControlLabel\n {...LabelProps}\n className={`${classBase}-label`}\n disabled={disabled}\n label={label}\n labelPlacement={\"right\"}\n >\n <CheckboxBase\n checked={checked}\n disabled={disabled}\n defaultChecked={defaultChecked}\n indeterminate={indeterminate}\n onChange={handleChange}\n value={value}\n />\n </ControlLabel>\n </div>\n );\n }\n);\n"],"names":["Checkbox","classnames"],"mappings":";;;;;;;;;AAcA,MAAM,SAAY,GAAA,cAAA,CAAA;AAEX,MAAM,QAAW,GAAA,UAAA;AAAA,EACtB,SAASA,SAAS,CAAA,KAAA,EAAO,GAAK,EAAA;AAjBhC,IAAA,IAAA,EAAA,CAAA;AAkBI,IAAM,MAAA;AAAA,MACJ,OAAS,EAAA,WAAA;AAAA,MACT,SAAA;AAAA,MACA,cAAgB,EAAA,kBAAA;AAAA,MAChB,QAAA;AAAA,MACA,aAAA;AAAA,MACA,UAAA;AAAA,MACA,KAAA;AAAA,MACA,UAAA;AAAA,MACA,QAAA;AAAA,MACA,KAAA;AAAA,MACG,GAAA,IAAA;AAAA,KACD,GAAA,KAAA,CAAA;AAEJ,IAAM,MAAA,YAAA,GAAe,WAAW,oBAAoB,CAAA,CAAA;AAEpD,IAAA,MAAM,YAAe,GAAA,qBAAA;AAAA,MACnB,QAAA;AAAA,MACA,YAAc,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,YAAA,CAAA,QAAA;AAAA,KAChB,CAAA;AAEA,IAAA,IAAI,OAAU,GAAA,WAAA,CAAA;AACd,IAAA,IAAI,cAAiB,GAAA,kBAAA,CAAA;AAErB,IAAA,IAAI,YAAc,EAAA;AAChB,MAAA,IAAI,OAAO,OAAA,KAAY,WAAe,IAAA,OAAO,UAAU,QAAU,EAAA;AAC/D,QAAU,OAAA,GAAA,CAAA,EAAA,GAAA,YAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,YAAA,CAAc,aAAd,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAA6B,QAAS,CAAA,KAAA,CAAA,CAAA;AAAA,OAClD;AAEA,MAAiB,cAAA,GAAA,KAAA,CAAA,CAAA;AAAA,KACnB;AAEA,IAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,MACE,GAAG,IAAA;AAAA,MACJ,SAAA,EAAWC,EAAW,CAAA,SAAA,EAAW,SAAW,EAAA;AAAA,QAC1C,CAAC,GAAG,SAAuB,CAAA,SAAA,CAAA,GAAA,QAAA;AAAA,OAC5B,CAAA;AAAA,MACD,aAAY,EAAA,UAAA;AAAA,MACZ,GAAA;AAAA,MAEA,QAAC,kBAAA,GAAA,CAAA,YAAA,EAAA;AAAA,QACE,GAAG,UAAA;AAAA,QACJ,WAAW,CAAG,EAAA,SAAA,CAAA,MAAA,CAAA;AAAA,QACd,QAAA;AAAA,QACA,KAAA;AAAA,QACA,cAAgB,EAAA,OAAA;AAAA,QAEhB,QAAC,kBAAA,GAAA,CAAA,YAAA,EAAA;AAAA,UACC,OAAA;AAAA,UACA,QAAA;AAAA,UACA,cAAA;AAAA,UACA,aAAA;AAAA,UACA,QAAU,EAAA,YAAA;AAAA,UACV,KAAA;AAAA,SACF,CAAA;AAAA,OACF,CAAA;AAAA,KACF,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
1
+ {"version":3,"file":"Checkbox.js","sources":["../src/checkbox/Checkbox.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport { forwardRef, useContext } from \"react\";\nimport { createChainedFunction } from \"@salt-ds/core\";\nimport { ControlLabel, ControlLabelProps } from \"../control-label\";\nimport { CheckboxBase, CheckboxBaseProps } from \"./CheckboxBase\";\nimport { CheckboxGroupContext } from \"./internal/CheckboxGroupContext\";\n\nimport \"./Checkbox.css\";\n\nexport interface CheckboxProps extends CheckboxBaseProps {\n label?: ControlLabelProps[\"label\"];\n LabelProps?: Partial<ControlLabelProps>;\n}\n\nconst classBase = \"saltCheckbox\";\n\nexport const Checkbox = forwardRef<HTMLDivElement, CheckboxProps>(\n function Checkbox(props, ref) {\n const {\n checked: checkedProp,\n className,\n defaultChecked: defaultCheckedProp,\n disabled,\n indeterminate,\n inputProps,\n label,\n LabelProps,\n onChange,\n value,\n ...rest\n } = props;\n\n const groupContext = useContext(CheckboxGroupContext);\n\n const handleChange = createChainedFunction(\n onChange,\n groupContext?.onChange\n );\n\n let checked = checkedProp;\n let defaultChecked = defaultCheckedProp;\n\n if (groupContext) {\n if (typeof checked === \"undefined\" && typeof value === \"string\") {\n checked = groupContext?.checkedValues?.includes(value);\n }\n\n defaultChecked = undefined;\n }\n\n return (\n <div\n {...rest}\n className={clsx(classBase, className, {\n [`${classBase}-disabled`]: disabled,\n })}\n data-testid=\"checkbox\"\n ref={ref}\n >\n <ControlLabel\n {...LabelProps}\n className={`${classBase}-label`}\n disabled={disabled}\n label={label}\n labelPlacement={\"right\"}\n >\n <CheckboxBase\n checked={checked}\n disabled={disabled}\n defaultChecked={defaultChecked}\n indeterminate={indeterminate}\n onChange={handleChange}\n value={value}\n />\n </ControlLabel>\n </div>\n );\n }\n);\n"],"names":["Checkbox"],"mappings":";;;;;;;;;AAcA,MAAM,SAAY,GAAA,cAAA,CAAA;AAEX,MAAM,QAAW,GAAA,UAAA;AAAA,EACtB,SAASA,SAAS,CAAA,KAAA,EAAO,GAAK,EAAA;AAjBhC,IAAA,IAAA,EAAA,CAAA;AAkBI,IAAM,MAAA;AAAA,MACJ,OAAS,EAAA,WAAA;AAAA,MACT,SAAA;AAAA,MACA,cAAgB,EAAA,kBAAA;AAAA,MAChB,QAAA;AAAA,MACA,aAAA;AAAA,MACA,UAAA;AAAA,MACA,KAAA;AAAA,MACA,UAAA;AAAA,MACA,QAAA;AAAA,MACA,KAAA;AAAA,MACG,GAAA,IAAA;AAAA,KACD,GAAA,KAAA,CAAA;AAEJ,IAAM,MAAA,YAAA,GAAe,WAAW,oBAAoB,CAAA,CAAA;AAEpD,IAAA,MAAM,YAAe,GAAA,qBAAA;AAAA,MACnB,QAAA;AAAA,MACA,YAAc,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,YAAA,CAAA,QAAA;AAAA,KAChB,CAAA;AAEA,IAAA,IAAI,OAAU,GAAA,WAAA,CAAA;AACd,IAAA,IAAI,cAAiB,GAAA,kBAAA,CAAA;AAErB,IAAA,IAAI,YAAc,EAAA;AAChB,MAAA,IAAI,OAAO,OAAA,KAAY,WAAe,IAAA,OAAO,UAAU,QAAU,EAAA;AAC/D,QAAU,OAAA,GAAA,CAAA,EAAA,GAAA,YAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,YAAA,CAAc,aAAd,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAA6B,QAAS,CAAA,KAAA,CAAA,CAAA;AAAA,OAClD;AAEA,MAAiB,cAAA,GAAA,KAAA,CAAA,CAAA;AAAA,KACnB;AAEA,IAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,MACE,GAAG,IAAA;AAAA,MACJ,SAAA,EAAW,IAAK,CAAA,SAAA,EAAW,SAAW,EAAA;AAAA,QACpC,CAAC,GAAG,SAAuB,CAAA,SAAA,CAAA,GAAA,QAAA;AAAA,OAC5B,CAAA;AAAA,MACD,aAAY,EAAA,UAAA;AAAA,MACZ,GAAA;AAAA,MAEA,QAAC,kBAAA,GAAA,CAAA,YAAA,EAAA;AAAA,QACE,GAAG,UAAA;AAAA,QACJ,WAAW,CAAG,EAAA,SAAA,CAAA,MAAA,CAAA;AAAA,QACd,QAAA;AAAA,QACA,KAAA;AAAA,QACA,cAAgB,EAAA,OAAA;AAAA,QAEhB,QAAC,kBAAA,GAAA,CAAA,YAAA,EAAA;AAAA,UACC,OAAA;AAAA,UACA,QAAA;AAAA,UACA,cAAA;AAAA,UACA,aAAA;AAAA,UACA,QAAU,EAAA,YAAA;AAAA,UACV,KAAA;AAAA,SACF,CAAA;AAAA,OACF,CAAA;AAAA,KACF,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
@@ -1,5 +1,5 @@
1
1
  import { jsxs, jsx } from 'react/jsx-runtime';
2
- import cx from 'classnames';
2
+ import { clsx } from 'clsx';
3
3
  import { forwardRef, useRef, useState, useCallback } from 'react';
4
4
  import { makePrefixer, useControlled } from '@salt-ds/core';
5
5
  import { CheckboxIcon } from './CheckboxIcon.js';
@@ -57,7 +57,7 @@ const CheckboxBase = forwardRef(
57
57
  },
58
58
  [onBlur]
59
59
  );
60
- const className = cx(withBaseName(), classNameProp, {
60
+ const className = clsx(withBaseName(), classNameProp, {
61
61
  saltFocusVisible: focusVisible
62
62
  });
63
63
  return /* @__PURE__ */ jsxs("span", {
@@ -1 +1 @@
1
- {"version":3,"file":"CheckboxBase.js","sources":["../src/checkbox/CheckboxBase.tsx"],"sourcesContent":["import classnames from \"classnames\";\nimport {\n ChangeEvent,\n FocusEvent,\n FocusEventHandler,\n forwardRef,\n HTMLAttributes,\n InputHTMLAttributes,\n useCallback,\n useRef,\n useState,\n} from \"react\";\nimport { makePrefixer, useControlled } from \"@salt-ds/core\";\nimport { CheckboxIcon } from \"./CheckboxIcon\";\n\nimport \"./CheckboxBase.css\";\n\nconst withBaseName = makePrefixer(\"saltCheckboxBase\");\n\nexport interface CheckboxBaseProps\n extends Omit<HTMLAttributes<HTMLDivElement>, \"onChange\"> {\n checked?: boolean;\n defaultChecked?: boolean;\n disabled?: boolean;\n indeterminate?: boolean;\n inputProps?: Partial<InputHTMLAttributes<HTMLInputElement>>;\n name?: string;\n onBlur?: FocusEventHandler<HTMLInputElement>;\n /**\n * Callback when checked state is changed\n */\n onChange?: (event: ChangeEvent<HTMLInputElement>, checked: boolean) => void;\n onFocus?: FocusEventHandler<HTMLInputElement>;\n value?: string;\n}\n\nexport const CheckboxBase = forwardRef<HTMLDivElement, CheckboxBaseProps>(\n function CheckboxBase(\n {\n checked: checkedProp,\n className: classNameProp,\n defaultChecked,\n disabled,\n indeterminate,\n inputProps,\n name,\n onBlur,\n onChange,\n onFocus,\n value,\n ...rest\n },\n ref\n ) {\n // null is needed here so we can modify the ref on line 70\n const inputRef = useRef<HTMLInputElement | null>(null);\n\n const [checked, setChecked] = useControlled({\n controlled: checkedProp,\n default: Boolean(defaultChecked),\n name: \"Checkbox\",\n state: \"checked\",\n });\n\n const [focusVisible, setFocusVisible] = useState(false);\n\n const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n // Workaround for https://github.com/facebook/react/issues/9023\n if (event.nativeEvent.defaultPrevented) {\n return;\n }\n\n const value = event.target.checked;\n setChecked(value);\n onChange?.(event, value);\n };\n\n const handleFocus = useCallback(\n (event: FocusEvent<HTMLInputElement>) => {\n // Fix for https://github.com/facebook/react/issues/7769\n if (!inputRef.current) {\n inputRef.current = event.currentTarget;\n }\n\n // TODO :focus-visible not yet supported on Safari, so we'll need to use the\n // useIsFocusVisible polyfill\n if (inputRef.current?.matches(\":focus-visible\")) {\n setFocusVisible(true);\n }\n\n onFocus && onFocus(event);\n },\n [onFocus]\n );\n\n const handleBlur = useCallback(\n (event: FocusEvent<HTMLInputElement>) => {\n setFocusVisible(false);\n onBlur && onBlur(event);\n },\n [onBlur]\n );\n\n const className = classnames(withBaseName(), classNameProp, {\n saltFocusVisible: focusVisible,\n });\n return (\n <span {...rest} className={className} ref={ref}>\n <input\n aria-checked={indeterminate ? \"mixed\" : checked}\n name={name}\n value={value}\n {...inputProps}\n checked={checkedProp}\n className={withBaseName(\"input\")}\n data-indeterminate={indeterminate}\n defaultChecked={defaultChecked}\n disabled={disabled}\n onBlur={handleBlur}\n onChange={handleChange}\n onFocus={handleFocus}\n ref={inputRef}\n type=\"checkbox\"\n />\n <CheckboxIcon\n checked={checked}\n disabled={disabled}\n indeterminate={indeterminate}\n />\n </span>\n );\n }\n);\n"],"names":["CheckboxBase","value","classnames"],"mappings":"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"}
1
+ {"version":3,"file":"CheckboxBase.js","sources":["../src/checkbox/CheckboxBase.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport {\n ChangeEvent,\n FocusEvent,\n FocusEventHandler,\n forwardRef,\n HTMLAttributes,\n InputHTMLAttributes,\n useCallback,\n useRef,\n useState,\n} from \"react\";\nimport { makePrefixer, useControlled } from \"@salt-ds/core\";\nimport { CheckboxIcon } from \"./CheckboxIcon\";\n\nimport \"./CheckboxBase.css\";\n\nconst withBaseName = makePrefixer(\"saltCheckboxBase\");\n\nexport interface CheckboxBaseProps\n extends Omit<HTMLAttributes<HTMLDivElement>, \"onChange\"> {\n checked?: boolean;\n defaultChecked?: boolean;\n disabled?: boolean;\n indeterminate?: boolean;\n inputProps?: Partial<InputHTMLAttributes<HTMLInputElement>>;\n name?: string;\n onBlur?: FocusEventHandler<HTMLInputElement>;\n /**\n * Callback when checked state is changed\n */\n onChange?: (event: ChangeEvent<HTMLInputElement>, checked: boolean) => void;\n onFocus?: FocusEventHandler<HTMLInputElement>;\n value?: string;\n}\n\nexport const CheckboxBase = forwardRef<HTMLDivElement, CheckboxBaseProps>(\n function CheckboxBase(\n {\n checked: checkedProp,\n className: classNameProp,\n defaultChecked,\n disabled,\n indeterminate,\n inputProps,\n name,\n onBlur,\n onChange,\n onFocus,\n value,\n ...rest\n },\n ref\n ) {\n // null is needed here so we can modify the ref on line 70\n const inputRef = useRef<HTMLInputElement | null>(null);\n\n const [checked, setChecked] = useControlled({\n controlled: checkedProp,\n default: Boolean(defaultChecked),\n name: \"Checkbox\",\n state: \"checked\",\n });\n\n const [focusVisible, setFocusVisible] = useState(false);\n\n const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n // Workaround for https://github.com/facebook/react/issues/9023\n if (event.nativeEvent.defaultPrevented) {\n return;\n }\n\n const value = event.target.checked;\n setChecked(value);\n onChange?.(event, value);\n };\n\n const handleFocus = useCallback(\n (event: FocusEvent<HTMLInputElement>) => {\n // Fix for https://github.com/facebook/react/issues/7769\n if (!inputRef.current) {\n inputRef.current = event.currentTarget;\n }\n\n // TODO :focus-visible not yet supported on Safari, so we'll need to use the\n // useIsFocusVisible polyfill\n if (inputRef.current?.matches(\":focus-visible\")) {\n setFocusVisible(true);\n }\n\n onFocus && onFocus(event);\n },\n [onFocus]\n );\n\n const handleBlur = useCallback(\n (event: FocusEvent<HTMLInputElement>) => {\n setFocusVisible(false);\n onBlur && onBlur(event);\n },\n [onBlur]\n );\n\n const className = clsx(withBaseName(), classNameProp, {\n saltFocusVisible: focusVisible,\n });\n return (\n <span {...rest} className={className} ref={ref}>\n <input\n aria-checked={indeterminate ? \"mixed\" : checked}\n name={name}\n value={value}\n {...inputProps}\n checked={checkedProp}\n className={withBaseName(\"input\")}\n data-indeterminate={indeterminate}\n defaultChecked={defaultChecked}\n disabled={disabled}\n onBlur={handleBlur}\n onChange={handleChange}\n onFocus={handleFocus}\n ref={inputRef}\n type=\"checkbox\"\n />\n <CheckboxIcon\n checked={checked}\n disabled={disabled}\n indeterminate={indeterminate}\n />\n </span>\n );\n }\n);\n"],"names":["CheckboxBase","value"],"mappings":";;;;;;;AAiBA,MAAM,YAAA,GAAe,aAAa,kBAAkB,CAAA,CAAA;AAmB7C,MAAM,YAAe,GAAA,UAAA;AAAA,EAC1B,SAASA,aACP,CAAA;AAAA,IACE,OAAS,EAAA,WAAA;AAAA,IACT,SAAW,EAAA,aAAA;AAAA,IACX,cAAA;AAAA,IACA,QAAA;AAAA,IACA,aAAA;AAAA,IACA,UAAA;AAAA,IACA,IAAA;AAAA,IACA,MAAA;AAAA,IACA,QAAA;AAAA,IACA,OAAA;AAAA,IACA,KAAA;AAAA,IACG,GAAA,IAAA;AAAA,KAEL,GACA,EAAA;AAEA,IAAM,MAAA,QAAA,GAAW,OAAgC,IAAI,CAAA,CAAA;AAErD,IAAA,MAAM,CAAC,OAAA,EAAS,UAAU,CAAA,GAAI,aAAc,CAAA;AAAA,MAC1C,UAAY,EAAA,WAAA;AAAA,MACZ,OAAA,EAAS,QAAQ,cAAc,CAAA;AAAA,MAC/B,IAAM,EAAA,UAAA;AAAA,MACN,KAAO,EAAA,SAAA;AAAA,KACR,CAAA,CAAA;AAED,IAAA,MAAM,CAAC,YAAA,EAAc,eAAe,CAAA,GAAI,SAAS,KAAK,CAAA,CAAA;AAEtD,IAAM,MAAA,YAAA,GAAe,CAAC,KAAyC,KAAA;AAE7D,MAAI,IAAA,KAAA,CAAM,YAAY,gBAAkB,EAAA;AACtC,QAAA,OAAA;AAAA,OACF;AAEA,MAAMC,MAAAA,MAAAA,GAAQ,MAAM,MAAO,CAAA,OAAA,CAAA;AAC3B,MAAA,UAAA,CAAWA,MAAK,CAAA,CAAA;AAChB,MAAA,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAW,KAAOA,EAAAA,MAAAA,CAAAA,CAAAA;AAAA,KACpB,CAAA;AAEA,IAAA,MAAM,WAAc,GAAA,WAAA;AAAA,MAClB,CAAC,KAAwC,KAAA;AA9E/C,QAAA,IAAA,EAAA,CAAA;AAgFQ,QAAI,IAAA,CAAC,SAAS,OAAS,EAAA;AACrB,UAAA,QAAA,CAAS,UAAU,KAAM,CAAA,aAAA,CAAA;AAAA,SAC3B;AAIA,QAAA,IAAA,CAAI,EAAS,GAAA,QAAA,CAAA,OAAA,KAAT,IAAkB,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,OAAA,CAAQ,gBAAmB,CAAA,EAAA;AAC/C,UAAA,eAAA,CAAgB,IAAI,CAAA,CAAA;AAAA,SACtB;AAEA,QAAA,OAAA,IAAW,QAAQ,KAAK,CAAA,CAAA;AAAA,OAC1B;AAAA,MACA,CAAC,OAAO,CAAA;AAAA,KACV,CAAA;AAEA,IAAA,MAAM,UAAa,GAAA,WAAA;AAAA,MACjB,CAAC,KAAwC,KAAA;AACvC,QAAA,eAAA,CAAgB,KAAK,CAAA,CAAA;AACrB,QAAA,MAAA,IAAU,OAAO,KAAK,CAAA,CAAA;AAAA,OACxB;AAAA,MACA,CAAC,MAAM,CAAA;AAAA,KACT,CAAA;AAEA,IAAA,MAAM,SAAY,GAAA,IAAA,CAAK,YAAa,EAAA,EAAG,aAAe,EAAA;AAAA,MACpD,gBAAkB,EAAA,YAAA;AAAA,KACnB,CAAA,CAAA;AACD,IAAA,uBACG,IAAA,CAAA,MAAA,EAAA;AAAA,MAAM,GAAG,IAAA;AAAA,MAAM,SAAA;AAAA,MAAsB,GAAA;AAAA,MACpC,QAAA,EAAA;AAAA,wBAAC,GAAA,CAAA,OAAA,EAAA;AAAA,UACC,cAAA,EAAc,gBAAgB,OAAU,GAAA,OAAA;AAAA,UACxC,IAAA;AAAA,UACA,KAAA;AAAA,UACC,GAAG,UAAA;AAAA,UACJ,OAAS,EAAA,WAAA;AAAA,UACT,SAAA,EAAW,aAAa,OAAO,CAAA;AAAA,UAC/B,oBAAoB,EAAA,aAAA;AAAA,UACpB,cAAA;AAAA,UACA,QAAA;AAAA,UACA,MAAQ,EAAA,UAAA;AAAA,UACR,QAAU,EAAA,YAAA;AAAA,UACV,OAAS,EAAA,WAAA;AAAA,UACT,GAAK,EAAA,QAAA;AAAA,UACL,IAAK,EAAA,UAAA;AAAA,SACP,CAAA;AAAA,wBACC,GAAA,CAAA,YAAA,EAAA;AAAA,UACC,OAAA;AAAA,UACA,QAAA;AAAA,UACA,aAAA;AAAA,SACF,CAAA;AAAA,OAAA;AAAA,KACF,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 } from 'react';
4
4
  import { useControlled } from '@salt-ds/core';
5
5
  import { FormGroup } from '../form-group/FormGroup.js';
@@ -35,7 +35,7 @@ const CheckboxGroup = forwardRef(function CheckboxGroup2({
35
35
  return /* @__PURE__ */ jsx(CheckboxGroupContext.Provider, {
36
36
  value: { name, onChange: handleChange, checkedValues },
37
37
  children: /* @__PURE__ */ jsx("fieldset", {
38
- className: cx(classBase, {
38
+ className: clsx(classBase, {
39
39
  [`${classBase}-horizontal`]: row
40
40
  }),
41
41
  ref,
@@ -1 +1 @@
1
- {"version":3,"file":"CheckboxGroup.js","sources":["../src/checkbox/CheckboxGroup.tsx"],"sourcesContent":["import cx from \"classnames\";\nimport {\n ChangeEvent,\n ChangeEventHandler,\n forwardRef,\n HTMLAttributes,\n ReactNode,\n} from \"react\";\nimport { useControlled } from \"@salt-ds/core\";\nimport { FormGroup, FormGroupProps } from \"../form-group\";\nimport { CheckboxGroupContext } from \"./internal/CheckboxGroupContext\";\n\nimport \"./CheckboxGroup.css\";\n\nexport interface CheckboxGroupProps extends FormGroupProps {\n /**\n * The current checked options.\n */\n checkedValues?: string[];\n /**\n * The default selected options for un-controlled component.\n */\n defaultCheckedValues?: string[];\n /**\n * Props spread onto the FormControl component that wraps the checkboxes.\n */\n FormControlProps?: Partial<HTMLAttributes<HTMLFieldSetElement>>;\n /**\n * Props spread onto the legend.\n */\n LegendProps?: unknown;\n /**\n * The label for the group legend\n */\n legend?: ReactNode;\n /**\n * The name used to reference the value of the control.\n */\n name?: string;\n /**\n * Callback fired when a checkbox is clicked.\n * `event.target.value` returns the value of the checkbox that was clicked.\n */\n onChange?: ChangeEventHandler<HTMLInputElement>;\n}\n\nconst classBase = \"saltCheckboxGroup\";\n\nexport const CheckboxGroup = forwardRef<\n HTMLFieldSetElement,\n CheckboxGroupProps\n>(function CheckboxGroup(\n {\n checkedValues: checkedValuesProp,\n defaultCheckedValues = [],\n children,\n className,\n FormControlProps,\n row,\n name,\n onChange,\n ...other\n },\n ref\n) {\n const [checkedValues, setCheckedValues] = useControlled({\n controlled: checkedValuesProp,\n default: defaultCheckedValues,\n name: \"CheckboxGroup\",\n state: \"checkedValues\",\n });\n\n const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n setCheckedValues((oldValues: string[] = []) => {\n const name = event.target.value;\n const isSelected = oldValues.includes(name);\n\n return isSelected\n ? oldValues.filter((value) => value !== name)\n : oldValues.concat(name);\n });\n\n onChange?.(event);\n };\n\n return (\n <CheckboxGroupContext.Provider\n value={{ name, onChange: handleChange, checkedValues }}\n >\n <fieldset\n className={cx(classBase, {\n [`${classBase}-horizontal`]: row,\n })}\n ref={ref}\n >\n <FormGroup className={`${classBase}-formGroup`} row={row} {...other}>\n {children}\n </FormGroup>\n </fieldset>\n </CheckboxGroupContext.Provider>\n );\n});\n"],"names":["CheckboxGroup","name"],"mappings":";;;;;;;;AA8CA,MAAM,SAAY,GAAA,mBAAA,CAAA;AAEL,MAAA,aAAA,GAAgB,UAG3B,CAAA,SAASA,cACT,CAAA;AAAA,EACE,aAAe,EAAA,iBAAA;AAAA,EACf,uBAAuB,EAAC;AAAA,EACxB,QAAA;AAAA,EACA,SAAA;AAAA,EACA,gBAAA;AAAA,EACA,GAAA;AAAA,EACA,IAAA;AAAA,EACA,QAAA;AAAA,EACG,GAAA,KAAA;AACL,CAAA,EACA,GACA,EAAA;AACA,EAAA,MAAM,CAAC,aAAA,EAAe,gBAAgB,CAAA,GAAI,aAAc,CAAA;AAAA,IACtD,UAAY,EAAA,iBAAA;AAAA,IACZ,OAAS,EAAA,oBAAA;AAAA,IACT,IAAM,EAAA,eAAA;AAAA,IACN,KAAO,EAAA,eAAA;AAAA,GACR,CAAA,CAAA;AAED,EAAM,MAAA,YAAA,GAAe,CAAC,KAAyC,KAAA;AAC7D,IAAiB,gBAAA,CAAA,CAAC,SAAsB,GAAA,EAAO,KAAA;AAC7C,MAAMC,MAAAA,KAAAA,GAAO,MAAM,MAAO,CAAA,KAAA,CAAA;AAC1B,MAAM,MAAA,UAAA,GAAa,SAAU,CAAA,QAAA,CAASA,KAAI,CAAA,CAAA;AAE1C,MAAO,OAAA,UAAA,GACH,SAAU,CAAA,MAAA,CAAO,CAAC,KAAA,KAAU,UAAUA,KAAI,CAAA,GAC1C,SAAU,CAAA,MAAA,CAAOA,KAAI,CAAA,CAAA;AAAA,KAC1B,CAAA,CAAA;AAED,IAAW,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAA,KAAA,CAAA,CAAA;AAAA,GACb,CAAA;AAEA,EACE,uBAAA,GAAA,CAAC,qBAAqB,QAArB,EAAA;AAAA,IACC,KAAO,EAAA,EAAE,IAAM,EAAA,QAAA,EAAU,cAAc,aAAc,EAAA;AAAA,IAErD,QAAC,kBAAA,GAAA,CAAA,UAAA,EAAA;AAAA,MACC,SAAA,EAAW,GAAG,SAAW,EAAA;AAAA,QACvB,CAAC,GAAG,SAAyB,CAAA,WAAA,CAAA,GAAA,GAAA;AAAA,OAC9B,CAAA;AAAA,MACD,GAAA;AAAA,MAEA,QAAC,kBAAA,GAAA,CAAA,SAAA,EAAA;AAAA,QAAU,WAAW,CAAG,EAAA,SAAA,CAAA,UAAA,CAAA;AAAA,QAAuB,GAAA;AAAA,QAAW,GAAG,KAAA;AAAA,QAC3D,QAAA;AAAA,OACH,CAAA;AAAA,KACF,CAAA;AAAA,GACF,CAAA,CAAA;AAEJ,CAAC;;;;"}
1
+ {"version":3,"file":"CheckboxGroup.js","sources":["../src/checkbox/CheckboxGroup.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport {\n ChangeEvent,\n ChangeEventHandler,\n forwardRef,\n HTMLAttributes,\n ReactNode,\n} from \"react\";\nimport { useControlled } from \"@salt-ds/core\";\nimport { FormGroup, FormGroupProps } from \"../form-group\";\nimport { CheckboxGroupContext } from \"./internal/CheckboxGroupContext\";\n\nimport \"./CheckboxGroup.css\";\n\nexport interface CheckboxGroupProps extends FormGroupProps {\n /**\n * The current checked options.\n */\n checkedValues?: string[];\n /**\n * The default selected options for un-controlled component.\n */\n defaultCheckedValues?: string[];\n /**\n * Props spread onto the FormControl component that wraps the checkboxes.\n */\n FormControlProps?: Partial<HTMLAttributes<HTMLFieldSetElement>>;\n /**\n * Props spread onto the legend.\n */\n LegendProps?: unknown;\n /**\n * The label for the group legend\n */\n legend?: ReactNode;\n /**\n * The name used to reference the value of the control.\n */\n name?: string;\n /**\n * Callback fired when a checkbox is clicked.\n * `event.target.value` returns the value of the checkbox that was clicked.\n */\n onChange?: ChangeEventHandler<HTMLInputElement>;\n}\n\nconst classBase = \"saltCheckboxGroup\";\n\nexport const CheckboxGroup = forwardRef<\n HTMLFieldSetElement,\n CheckboxGroupProps\n>(function CheckboxGroup(\n {\n checkedValues: checkedValuesProp,\n defaultCheckedValues = [],\n children,\n className,\n FormControlProps,\n row,\n name,\n onChange,\n ...other\n },\n ref\n) {\n const [checkedValues, setCheckedValues] = useControlled({\n controlled: checkedValuesProp,\n default: defaultCheckedValues,\n name: \"CheckboxGroup\",\n state: \"checkedValues\",\n });\n\n const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n setCheckedValues((oldValues: string[] = []) => {\n const name = event.target.value;\n const isSelected = oldValues.includes(name);\n\n return isSelected\n ? oldValues.filter((value) => value !== name)\n : oldValues.concat(name);\n });\n\n onChange?.(event);\n };\n\n return (\n <CheckboxGroupContext.Provider\n value={{ name, onChange: handleChange, checkedValues }}\n >\n <fieldset\n className={clsx(classBase, {\n [`${classBase}-horizontal`]: row,\n })}\n ref={ref}\n >\n <FormGroup className={`${classBase}-formGroup`} row={row} {...other}>\n {children}\n </FormGroup>\n </fieldset>\n </CheckboxGroupContext.Provider>\n );\n});\n"],"names":["CheckboxGroup","name"],"mappings":";;;;;;;;AA8CA,MAAM,SAAY,GAAA,mBAAA,CAAA;AAEL,MAAA,aAAA,GAAgB,UAG3B,CAAA,SAASA,cACT,CAAA;AAAA,EACE,aAAe,EAAA,iBAAA;AAAA,EACf,uBAAuB,EAAC;AAAA,EACxB,QAAA;AAAA,EACA,SAAA;AAAA,EACA,gBAAA;AAAA,EACA,GAAA;AAAA,EACA,IAAA;AAAA,EACA,QAAA;AAAA,EACG,GAAA,KAAA;AACL,CAAA,EACA,GACA,EAAA;AACA,EAAA,MAAM,CAAC,aAAA,EAAe,gBAAgB,CAAA,GAAI,aAAc,CAAA;AAAA,IACtD,UAAY,EAAA,iBAAA;AAAA,IACZ,OAAS,EAAA,oBAAA;AAAA,IACT,IAAM,EAAA,eAAA;AAAA,IACN,KAAO,EAAA,eAAA;AAAA,GACR,CAAA,CAAA;AAED,EAAM,MAAA,YAAA,GAAe,CAAC,KAAyC,KAAA;AAC7D,IAAiB,gBAAA,CAAA,CAAC,SAAsB,GAAA,EAAO,KAAA;AAC7C,MAAMC,MAAAA,KAAAA,GAAO,MAAM,MAAO,CAAA,KAAA,CAAA;AAC1B,MAAM,MAAA,UAAA,GAAa,SAAU,CAAA,QAAA,CAASA,KAAI,CAAA,CAAA;AAE1C,MAAO,OAAA,UAAA,GACH,SAAU,CAAA,MAAA,CAAO,CAAC,KAAA,KAAU,UAAUA,KAAI,CAAA,GAC1C,SAAU,CAAA,MAAA,CAAOA,KAAI,CAAA,CAAA;AAAA,KAC1B,CAAA,CAAA;AAED,IAAW,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAA,KAAA,CAAA,CAAA;AAAA,GACb,CAAA;AAEA,EACE,uBAAA,GAAA,CAAC,qBAAqB,QAArB,EAAA;AAAA,IACC,KAAO,EAAA,EAAE,IAAM,EAAA,QAAA,EAAU,cAAc,aAAc,EAAA;AAAA,IAErD,QAAC,kBAAA,GAAA,CAAA,UAAA,EAAA;AAAA,MACC,SAAA,EAAW,KAAK,SAAW,EAAA;AAAA,QACzB,CAAC,GAAG,SAAyB,CAAA,WAAA,CAAA,GAAA,GAAA;AAAA,OAC9B,CAAA;AAAA,MACD,GAAA;AAAA,MAEA,QAAC,kBAAA,GAAA,CAAA,SAAA,EAAA;AAAA,QAAU,WAAW,CAAG,EAAA,SAAA,CAAA,UAAA,CAAA;AAAA,QAAuB,GAAA;AAAA,QAAW,GAAG,KAAA;AAAA,QAC3D,QAAA;AAAA,OACH,CAAA;AAAA,KACF,CAAA;AAAA,GACF,CAAA,CAAA;AAEJ,CAAC;;;;"}
@@ -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 { makePrefixer } from '@salt-ds/core';
4
4
  import { CheckboxUncheckedIcon } from './assets/CheckboxUncheckedIcon.js';
5
5
  import { CheckboxCheckedIcon } from './assets/CheckboxCheckedIcon.js';
@@ -13,13 +13,13 @@ const CheckboxIcon = ({
13
13
  disabled,
14
14
  indeterminate
15
15
  }) => {
16
- const className = cx(withBaseName(), classNameProp, {
16
+ const className = clsx(withBaseName(), classNameProp, {
17
17
  [withBaseName("disabled")]: disabled
18
18
  });
19
19
  return indeterminate ? /* @__PURE__ */ jsx(CheckboxIndeterminateIcon, {
20
- className: cx(className, withBaseName("indeterminate"))
20
+ className: clsx(className, withBaseName("indeterminate"))
21
21
  }) : checked ? /* @__PURE__ */ jsx(CheckboxCheckedIcon, {
22
- className: cx(className, withBaseName("checked"))
22
+ className: clsx(className, withBaseName("checked"))
23
23
  }) : /* @__PURE__ */ jsx(CheckboxUncheckedIcon, {
24
24
  className
25
25
  });
@@ -1 +1 @@
1
- {"version":3,"file":"CheckboxIcon.js","sources":["../src/checkbox/CheckboxIcon.tsx"],"sourcesContent":["import cx from \"classnames\";\nimport { makePrefixer } from \"@salt-ds/core\";\nimport {\n CheckboxUncheckedIcon,\n CheckboxCheckedIcon,\n CheckboxIndeterminateIcon,\n} from \"./assets\";\n\nimport \"./CheckboxIcon.css\";\n\nexport interface CheckboxIconProps {\n checked?: boolean;\n className?: string;\n disabled?: boolean;\n indeterminate?: boolean;\n}\n\nconst withBaseName = makePrefixer(\"saltCheckboxIcon\");\n\nexport const CheckboxIcon = ({\n checked = false,\n className: classNameProp,\n disabled,\n indeterminate,\n}: CheckboxIconProps): JSX.Element => {\n const className = cx(withBaseName(), classNameProp, {\n [withBaseName(\"disabled\")]: disabled,\n });\n return indeterminate ? (\n <CheckboxIndeterminateIcon\n className={cx(className, withBaseName(\"indeterminate\"))}\n />\n ) : checked ? (\n <CheckboxCheckedIcon className={cx(className, withBaseName(\"checked\"))} />\n ) : (\n <CheckboxUncheckedIcon className={className} />\n );\n};\n"],"names":[],"mappings":";;;;;;;;AAiBA,MAAM,YAAA,GAAe,aAAa,kBAAkB,CAAA,CAAA;AAE7C,MAAM,eAAe,CAAC;AAAA,EAC3B,OAAU,GAAA,KAAA;AAAA,EACV,SAAW,EAAA,aAAA;AAAA,EACX,QAAA;AAAA,EACA,aAAA;AACF,CAAsC,KAAA;AACpC,EAAA,MAAM,SAAY,GAAA,EAAA,CAAG,YAAa,EAAA,EAAG,aAAe,EAAA;AAAA,IAClD,CAAC,YAAa,CAAA,UAAU,CAAI,GAAA,QAAA;AAAA,GAC7B,CAAA,CAAA;AACD,EAAA,OAAO,gCACJ,GAAA,CAAA,yBAAA,EAAA;AAAA,IACC,SAAW,EAAA,EAAA,CAAG,SAAW,EAAA,YAAA,CAAa,eAAe,CAAC,CAAA;AAAA,GACxD,CAAA,GACE,0BACD,GAAA,CAAA,mBAAA,EAAA;AAAA,IAAoB,SAAW,EAAA,EAAA,CAAG,SAAW,EAAA,YAAA,CAAa,SAAS,CAAC,CAAA;AAAA,GAAG,oBAEvE,GAAA,CAAA,qBAAA,EAAA;AAAA,IAAsB,SAAA;AAAA,GAAsB,CAAA,CAAA;AAEjD;;;;"}
1
+ {"version":3,"file":"CheckboxIcon.js","sources":["../src/checkbox/CheckboxIcon.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport { makePrefixer } from \"@salt-ds/core\";\nimport {\n CheckboxUncheckedIcon,\n CheckboxCheckedIcon,\n CheckboxIndeterminateIcon,\n} from \"./assets\";\n\nimport \"./CheckboxIcon.css\";\n\nexport interface CheckboxIconProps {\n checked?: boolean;\n className?: string;\n disabled?: boolean;\n indeterminate?: boolean;\n}\n\nconst withBaseName = makePrefixer(\"saltCheckboxIcon\");\n\nexport const CheckboxIcon = ({\n checked = false,\n className: classNameProp,\n disabled,\n indeterminate,\n}: CheckboxIconProps): JSX.Element => {\n const className = clsx(withBaseName(), classNameProp, {\n [withBaseName(\"disabled\")]: disabled,\n });\n return indeterminate ? (\n <CheckboxIndeterminateIcon\n className={clsx(className, withBaseName(\"indeterminate\"))}\n />\n ) : checked ? (\n <CheckboxCheckedIcon className={clsx(className, withBaseName(\"checked\"))} />\n ) : (\n <CheckboxUncheckedIcon className={className} />\n );\n};\n"],"names":[],"mappings":";;;;;;;;AAiBA,MAAM,YAAA,GAAe,aAAa,kBAAkB,CAAA,CAAA;AAE7C,MAAM,eAAe,CAAC;AAAA,EAC3B,OAAU,GAAA,KAAA;AAAA,EACV,SAAW,EAAA,aAAA;AAAA,EACX,QAAA;AAAA,EACA,aAAA;AACF,CAAsC,KAAA;AACpC,EAAA,MAAM,SAAY,GAAA,IAAA,CAAK,YAAa,EAAA,EAAG,aAAe,EAAA;AAAA,IACpD,CAAC,YAAa,CAAA,UAAU,CAAI,GAAA,QAAA;AAAA,GAC7B,CAAA,CAAA;AACD,EAAA,OAAO,gCACJ,GAAA,CAAA,yBAAA,EAAA;AAAA,IACC,SAAW,EAAA,IAAA,CAAK,SAAW,EAAA,YAAA,CAAa,eAAe,CAAC,CAAA;AAAA,GAC1D,CAAA,GACE,0BACD,GAAA,CAAA,mBAAA,EAAA;AAAA,IAAoB,SAAW,EAAA,IAAA,CAAK,SAAW,EAAA,YAAA,CAAa,SAAS,CAAC,CAAA;AAAA,GAAG,oBAEzE,GAAA,CAAA,qBAAA,EAAA;AAAA,IAAsB,SAAA;AAAA,GAAsB,CAAA,CAAA;AAEjD;;;;"}
@@ -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 { useState, useEffect } from 'react';
4
4
  import { makePrefixer } from '@salt-ds/core';
5
5
  import { Input } from '../input/Input.js';
@@ -50,7 +50,7 @@ const AlphaInput = ({
50
50
  inputProps: {
51
51
  "data-testid": "a-input"
52
52
  },
53
- className: cx({
53
+ className: clsx({
54
54
  [withBaseName("rgbaInput")]: !showAsOpacity,
55
55
  [withBaseName("opacityInput")]: showAsOpacity
56
56
  }),
@@ -1 +1 @@
1
- {"version":3,"file":"AlphaInputField.js","sources":["../src/color-chooser/AlphaInputField.tsx"],"sourcesContent":["import cn from \"classnames\";\nimport { useState, useEffect } from \"react\";\nimport { makePrefixer } from \"@salt-ds/core\";\nimport { Input } from \"../input\";\n\nimport \"./RGBAInput.css\";\n\nconst withBaseName = makePrefixer(\"saltColorChooser\");\n\ninterface AlphaInputProps {\n alphaValue: number;\n showAsOpacity?: boolean;\n onSubmit: (alpha: number, e?: React.ChangeEvent) => void;\n}\n\nexport const AlphaInput = ({\n alphaValue,\n onSubmit,\n showAsOpacity = false,\n}: AlphaInputProps): JSX.Element => {\n const [alphaInputValue, setAlphaInputValue] = useState<string>(\n !isNaN(alphaValue) ? alphaValue.toString() : \"\"\n );\n\n useEffect(() => {\n setAlphaInputValue(!isNaN(alphaValue) ? alphaValue.toString() : \"\");\n }, [alphaValue]);\n\n const handleAlphaInputChange = (\n event: React.ChangeEvent<HTMLInputElement>,\n value: string\n ): void => {\n value = value.replace(\"%\", \"\");\n let alpha: string = value;\n\n if (value.trim() === \"\" || Number.isNaN(value)) {\n alpha = \"\";\n }\n\n if (showAsOpacity && Number.parseFloat(value)) {\n alpha = (parseFloat(value) / 100).toString();\n }\n\n if (value.charAt(1) === \".\" || value.charAt(0) === \".\") {\n alpha = value;\n }\n\n setAlphaInputValue(alpha);\n };\n\n const handleKeyDownAlpha = (\n e: React.KeyboardEvent<HTMLInputElement>\n ): void => {\n if (e.key === \"Enter\") {\n const alpha =\n alphaInputValue.trim().replace(\"%\", \"\") !== \"\"\n ? parseFloat(alphaInputValue)\n : 0;\n const validatedAlpha = Math.max(0, Math.min(alpha, 1));\n setAlphaInputValue(validatedAlpha.toString());\n onSubmit(validatedAlpha);\n }\n };\n\n const handleOnBlurAlpha = (e: React.FocusEvent<HTMLInputElement>): void => {\n // Guard against parseFloat('') becoming NaN\n const alpha =\n alphaInputValue.trim() !== \"\" ? parseFloat(alphaInputValue) : 0;\n\n const validatedAlpha = Math.max(0, Math.min(alpha, 1));\n setAlphaInputValue(validatedAlpha.toString());\n onSubmit(validatedAlpha, e);\n };\n\n return (\n <Input\n inputProps={{\n // @ts-ignore\n \"data-testid\": \"a-input\",\n }}\n className={cn({\n [withBaseName(\"rgbaInput\")]: !showAsOpacity,\n [withBaseName(\"opacityInput\")]: showAsOpacity,\n })}\n value={\n showAsOpacity\n ? alphaInputValue\n ? (parseFloat(alphaInputValue) * 100).toString() + \"%\"\n : \"%\"\n : alphaInputValue\n }\n onChange={handleAlphaInputChange}\n onBlur={handleOnBlurAlpha}\n onKeyDown={handleKeyDownAlpha}\n />\n );\n};\n"],"names":["cn"],"mappings":"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"}
1
+ {"version":3,"file":"AlphaInputField.js","sources":["../src/color-chooser/AlphaInputField.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport { useState, useEffect } from \"react\";\nimport { makePrefixer } from \"@salt-ds/core\";\nimport { Input } from \"../input\";\n\nimport \"./RGBAInput.css\";\n\nconst withBaseName = makePrefixer(\"saltColorChooser\");\n\ninterface AlphaInputProps {\n alphaValue: number;\n showAsOpacity?: boolean;\n onSubmit: (alpha: number, e?: React.ChangeEvent) => void;\n}\n\nexport const AlphaInput = ({\n alphaValue,\n onSubmit,\n showAsOpacity = false,\n}: AlphaInputProps): JSX.Element => {\n const [alphaInputValue, setAlphaInputValue] = useState<string>(\n !isNaN(alphaValue) ? alphaValue.toString() : \"\"\n );\n\n useEffect(() => {\n setAlphaInputValue(!isNaN(alphaValue) ? alphaValue.toString() : \"\");\n }, [alphaValue]);\n\n const handleAlphaInputChange = (\n event: React.ChangeEvent<HTMLInputElement>,\n value: string\n ): void => {\n value = value.replace(\"%\", \"\");\n let alpha: string = value;\n\n if (value.trim() === \"\" || Number.isNaN(value)) {\n alpha = \"\";\n }\n\n if (showAsOpacity && Number.parseFloat(value)) {\n alpha = (parseFloat(value) / 100).toString();\n }\n\n if (value.charAt(1) === \".\" || value.charAt(0) === \".\") {\n alpha = value;\n }\n\n setAlphaInputValue(alpha);\n };\n\n const handleKeyDownAlpha = (\n e: React.KeyboardEvent<HTMLInputElement>\n ): void => {\n if (e.key === \"Enter\") {\n const alpha =\n alphaInputValue.trim().replace(\"%\", \"\") !== \"\"\n ? parseFloat(alphaInputValue)\n : 0;\n const validatedAlpha = Math.max(0, Math.min(alpha, 1));\n setAlphaInputValue(validatedAlpha.toString());\n onSubmit(validatedAlpha);\n }\n };\n\n const handleOnBlurAlpha = (e: React.FocusEvent<HTMLInputElement>): void => {\n // Guard against parseFloat('') becoming NaN\n const alpha =\n alphaInputValue.trim() !== \"\" ? parseFloat(alphaInputValue) : 0;\n\n const validatedAlpha = Math.max(0, Math.min(alpha, 1));\n setAlphaInputValue(validatedAlpha.toString());\n onSubmit(validatedAlpha, e);\n };\n\n return (\n <Input\n inputProps={{\n // @ts-ignore\n \"data-testid\": \"a-input\",\n }}\n className={clsx({\n [withBaseName(\"rgbaInput\")]: !showAsOpacity,\n [withBaseName(\"opacityInput\")]: showAsOpacity,\n })}\n value={\n showAsOpacity\n ? alphaInputValue\n ? (parseFloat(alphaInputValue) * 100).toString() + \"%\"\n : \"%\"\n : alphaInputValue\n }\n onChange={handleAlphaInputChange}\n onBlur={handleOnBlurAlpha}\n onKeyDown={handleKeyDownAlpha}\n />\n );\n};\n"],"names":[],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
2
2
  import { useState } from 'react';
3
- import cx from 'classnames';
3
+ import { clsx } from 'clsx';
4
4
  import { Overlay } from '../overlay/Overlay.js';
5
5
  import { useOverlay } from '../overlay/useOverlay.js';
6
6
  import { makePrefixer, Button } from '@salt-ds/core';
@@ -91,7 +91,7 @@ const ColorChooser = ({
91
91
  children: [
92
92
  /* @__PURE__ */ jsxs(Button, {
93
93
  ...getTriggerProps({
94
- className: cx(withBaseName("overlayButton"), {
94
+ className: clsx(withBaseName("overlayButton"), {
95
95
  [withBaseName("overlayButtonHiddenLabel")]: hideLabel
96
96
  }),
97
97
  "data-testid": "color-chooser-overlay-button",
@@ -100,7 +100,7 @@ const ColorChooser = ({
100
100
  }),
101
101
  children: [
102
102
  color && /* @__PURE__ */ jsx("div", {
103
- className: cx(withBaseName("overlayButtonSwatch"), {
103
+ className: clsx(withBaseName("overlayButtonSwatch"), {
104
104
  [withBaseName("overlayButtonSwatchWithBorder")]: color == null ? void 0 : color.hex.startsWith("#ffffff"),
105
105
  [withBaseName("overlayButtonSwatchTransparent")]: isTransparent(
106
106
  color == null ? void 0 : color.hex
@@ -122,20 +122,20 @@ const ColorChooser = ({
122
122
  showClose: false
123
123
  },
124
124
  "data-testid": "color-chooser-overlay",
125
- className: cx(withBaseName("overlayButtonClose"))
125
+ className: clsx(withBaseName("overlayButtonClose"))
126
126
  }),
127
127
  children: /* @__PURE__ */ jsxs("div", {
128
- className: cx(withBaseName("overlayContent")),
128
+ className: clsx(withBaseName("overlayContent")),
129
129
  "data-testid": "overlay-content",
130
130
  children: [
131
131
  /* @__PURE__ */ jsxs(Button, {
132
132
  "data-testid": "default-button",
133
133
  variant: "secondary",
134
- className: cx(withBaseName("defaultButton")),
134
+ className: clsx(withBaseName("defaultButton")),
135
135
  onClick: onDefaultSelected,
136
136
  children: [
137
137
  /* @__PURE__ */ jsx(RefreshIcon, {
138
- className: cx(withBaseName("refreshIcon"))
138
+ className: clsx(withBaseName("refreshIcon"))
139
139
  }),
140
140
  "Default"
141
141
  ]
@@ -1 +1 @@
1
- {"version":3,"file":"ColorChooser.js","sources":["../src/color-chooser/ColorChooser.tsx"],"sourcesContent":["import { useState, ChangeEvent } from \"react\";\nimport cn from \"classnames\";\nimport { Overlay, useOverlay } from \"../overlay\";\nimport { Button, ButtonProps, makePrefixer } from \"@salt-ds/core\";\nimport { RefreshIcon } from \"@salt-ds/icons\";\nimport { Color } from \"./Color\";\nimport { isTransparent } from \"./color-utils\";\n\nimport {\n hexValueWithoutAlpha,\n getColorNameByHexValue,\n convertColorMapValueToHex,\n getHexValue,\n} from \"./ColorHelpers\";\nimport { saltColorMap } from \"./colorMap\";\nimport { ColorChooserTabs, DictTabs } from \"./DictTabs\";\nimport { getColorPalettes } from \"./GetColorPalettes\";\nimport { createTabsMapping } from \"./createTabsMapping\";\n\nimport \"./ColorChooser.css\";\n\nconst withBaseName = makePrefixer(\"saltColorChooser\");\n\nfunction getActiveTab(\n hexValue: string | undefined,\n tabs: ColorChooserTabs,\n saltColorOverrides: Record<string, string> | undefined\n): number {\n if (tabs[\"Swatches\"] && tabs[\"Color Picker\"]) {\n const hexNoAlpha: string | undefined = hexValueWithoutAlpha(hexValue);\n const colors = saltColorOverrides ?? saltColorMap;\n // if hexNoAlpha is a Salt color or null/undefined then set the active tab as Swatches\n if (\n hexNoAlpha &&\n !Object.keys(colors).find(\n (key: string) =>\n convertColorMapValueToHex(colors[key])?.toLowerCase() ===\n hexNoAlpha?.toLowerCase()\n )\n ) {\n return 1;\n }\n }\n return 0;\n}\n\nexport interface ColorChooserProps {\n color: Color | undefined;\n defaultAlpha?: number;\n disableAlphaChooser?: boolean;\n displayHexOnly?: boolean;\n hideLabel?: boolean;\n onClear: () => void; // called when user clicks \"default\" button\n onSelect: (\n color: Color | undefined,\n finalSelection: boolean,\n event?: ChangeEvent\n ) => void;\n placeholder?: string;\n buttonProps?: Partial<ButtonProps>;\n saltColorOverrides?: Record<string, string>;\n showSwatches?: boolean;\n showColorPicker?: boolean;\n readOnly?: boolean;\n}\n\nexport const ColorChooser = ({\n onClear,\n onSelect,\n color,\n showSwatches = true,\n showColorPicker = true,\n defaultAlpha = 1,\n disableAlphaChooser = false,\n hideLabel = false,\n placeholder,\n buttonProps,\n saltColorOverrides,\n readOnly = false,\n displayHexOnly = false,\n}: ColorChooserProps): JSX.Element => {\n const [open, setOpen] = useState(false);\n\n const allColors: string[][] = saltColorOverrides\n ? getColorPalettes(saltColorOverrides)\n : getColorPalettes();\n const displayColorName = displayHexOnly\n ? getHexValue(color?.hex, disableAlphaChooser)\n : getColorNameByHexValue(\n color?.hex,\n disableAlphaChooser,\n saltColorOverrides\n );\n\n const handleOpenChange = (open: boolean) => setOpen(open);\n\n const alphaForTabs = isTransparent(color?.hex)\n ? defaultAlpha\n : color?.rgba?.a ?? defaultAlpha;\n\n const tabsMapping = createTabsMapping({\n swatches: showSwatches,\n colorPicker: showColorPicker,\n disableAlphaChooser,\n allColors,\n color,\n alpha: alphaForTabs,\n handleColorChange: onSelect,\n displayColorName,\n placeholder,\n onDialogClosed: () => {\n setOpen(false);\n },\n });\n\n const [activeTab, setActiveTab] = useState<number>(\n getActiveTab(color?.hex, tabsMapping, saltColorOverrides)\n );\n const onDefaultSelected = (): void => {\n if (activeTab === 0 && showSwatches) {\n onClear();\n handleOpenChange(false);\n } else {\n onClear();\n }\n };\n const onTabClick = (index: number): void => {\n setActiveTab(index);\n };\n\n const { getTriggerProps, getOverlayProps } = useOverlay({\n placement: \"bottom\",\n open,\n onOpenChange: handleOpenChange,\n });\n\n return (\n <>\n <Button\n {...getTriggerProps<typeof Button>({\n className: cn(withBaseName(\"overlayButton\"), {\n [withBaseName(\"overlayButtonHiddenLabel\")]: hideLabel,\n }),\n // @ts-ignore\n \"data-testid\": \"color-chooser-overlay-button\",\n disabled: readOnly,\n ...buttonProps,\n })}\n >\n {color && (\n <div\n className={cn(withBaseName(\"overlayButtonSwatch\"), {\n [withBaseName(\"overlayButtonSwatchWithBorder\")]:\n color?.hex.startsWith(\"#ffffff\"),\n [withBaseName(\"overlayButtonSwatchTransparent\")]: isTransparent(\n color?.hex\n ),\n })}\n style={{\n backgroundColor: color?.hex,\n }}\n />\n )}\n {!hideLabel && (\n <div className={withBaseName(\"overlayButtonText\")}>\n {displayColorName ?? placeholder ?? \"No color selected\"}\n </div>\n )}\n </Button>\n <Overlay\n {...getOverlayProps({\n adaExceptions: {\n showClose: false,\n },\n // @ts-ignore\n \"data-testid\": \"color-chooser-overlay\",\n className: cn(withBaseName(\"overlayButtonClose\")),\n })}\n >\n <div\n className={cn(withBaseName(\"overlayContent\"))}\n data-testid=\"overlay-content\"\n >\n <Button\n data-testid=\"default-button\"\n variant=\"secondary\"\n className={cn(withBaseName(\"defaultButton\"))}\n onClick={onDefaultSelected}\n >\n <RefreshIcon className={cn(withBaseName(\"refreshIcon\"))} />\n Default\n </Button>\n <DictTabs\n tabs={tabsMapping}\n hexValue={color?.hex}\n onTabClick={onTabClick}\n activeTab={activeTab}\n />\n </div>\n </Overlay>\n </>\n );\n};\n"],"names":["open","cn"],"mappings":";;;;;;;;;;;;;;;AAqBA,MAAM,YAAA,GAAe,aAAa,kBAAkB,CAAA,CAAA;AAEpD,SAAS,YAAA,CACP,QACA,EAAA,IAAA,EACA,kBACQ,EAAA;AACR,EAAI,IAAA,IAAA,CAAK,UAAe,CAAA,IAAA,IAAA,CAAK,cAAiB,CAAA,EAAA;AAC5C,IAAM,MAAA,UAAA,GAAiC,qBAAqB,QAAQ,CAAA,CAAA;AACpE,IAAA,MAAM,SAAS,kBAAsB,IAAA,IAAA,GAAA,kBAAA,GAAA,YAAA,CAAA;AAErC,IAAA,IACE,UACA,IAAA,CAAC,MAAO,CAAA,IAAA,CAAK,MAAM,CAAE,CAAA,IAAA;AAAA,MACnB,CAAC,GAAa,KAAA;AAnCtB,QAAA,IAAA,EAAA,CAAA;AAoCU,QAAA,OAAA,CAAA,CAAA,EAAA,GAAA,yBAAA,CAA0B,MAAO,CAAA,GAAA,CAAI,CAArC,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAwC,oBACxC,UAAY,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,UAAA,CAAA,WAAA,EAAA,CAAA,CAAA;AAAA,OAAA;AAAA,KAEhB,EAAA;AACA,MAAO,OAAA,CAAA,CAAA;AAAA,KACT;AAAA,GACF;AACA,EAAO,OAAA,CAAA,CAAA;AACT,CAAA;AAsBO,MAAM,eAAe,CAAC;AAAA,EAC3B,OAAA;AAAA,EACA,QAAA;AAAA,EACA,KAAA;AAAA,EACA,YAAe,GAAA,IAAA;AAAA,EACf,eAAkB,GAAA,IAAA;AAAA,EAClB,YAAe,GAAA,CAAA;AAAA,EACf,mBAAsB,GAAA,KAAA;AAAA,EACtB,SAAY,GAAA,KAAA;AAAA,EACZ,WAAA;AAAA,EACA,WAAA;AAAA,EACA,kBAAA;AAAA,EACA,QAAW,GAAA,KAAA;AAAA,EACX,cAAiB,GAAA,KAAA;AACnB,CAAsC,KAAA;AAhFtC,EAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA,CAAA;AAiFE,EAAA,MAAM,CAAC,IAAA,EAAM,OAAO,CAAA,GAAI,SAAS,KAAK,CAAA,CAAA;AAEtC,EAAA,MAAM,SAAwB,GAAA,kBAAA,GAC1B,gBAAiB,CAAA,kBAAkB,IACnC,gBAAiB,EAAA,CAAA;AACrB,EAAA,MAAM,mBAAmB,cACrB,GAAA,WAAA,CAAY,KAAO,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,EAAK,mBAAmB,CAC3C,GAAA,sBAAA;AAAA,IACE,KAAO,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA;AAAA,IACP,mBAAA;AAAA,IACA,kBAAA;AAAA,GACF,CAAA;AAEJ,EAAA,MAAM,gBAAmB,GAAA,CAACA,KAAkB,KAAA,OAAA,CAAQA,KAAI,CAAA,CAAA;AAExD,EAAM,MAAA,YAAA,GAAe,aAAc,CAAA,KAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,KAAA,CAAO,GAAG,CAAA,GACzC,gBACA,EAAO,GAAA,CAAA,EAAA,GAAA,KAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,KAAA,CAAA,IAAA,KAAP,IAAa,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,CAAA,KAAb,IAAkB,GAAA,EAAA,GAAA,YAAA,CAAA;AAEtB,EAAA,MAAM,cAAc,iBAAkB,CAAA;AAAA,IACpC,QAAU,EAAA,YAAA;AAAA,IACV,WAAa,EAAA,eAAA;AAAA,IACb,mBAAA;AAAA,IACA,SAAA;AAAA,IACA,KAAA;AAAA,IACA,KAAO,EAAA,YAAA;AAAA,IACP,iBAAmB,EAAA,QAAA;AAAA,IACnB,gBAAA;AAAA,IACA,WAAA;AAAA,IACA,gBAAgB,MAAM;AACpB,MAAA,OAAA,CAAQ,KAAK,CAAA,CAAA;AAAA,KACf;AAAA,GACD,CAAA,CAAA;AAED,EAAM,MAAA,CAAC,SAAW,EAAA,YAAY,CAAI,GAAA,QAAA;AAAA,IAChC,YAAa,CAAA,KAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,KAAA,CAAO,GAAK,EAAA,WAAA,EAAa,kBAAkB,CAAA;AAAA,GAC1D,CAAA;AACA,EAAA,MAAM,oBAAoB,MAAY;AACpC,IAAI,IAAA,SAAA,KAAc,KAAK,YAAc,EAAA;AACnC,MAAQ,OAAA,EAAA,CAAA;AACR,MAAA,gBAAA,CAAiB,KAAK,CAAA,CAAA;AAAA,KACjB,MAAA;AACL,MAAQ,OAAA,EAAA,CAAA;AAAA,KACV;AAAA,GACF,CAAA;AACA,EAAM,MAAA,UAAA,GAAa,CAAC,KAAwB,KAAA;AAC1C,IAAA,YAAA,CAAa,KAAK,CAAA,CAAA;AAAA,GACpB,CAAA;AAEA,EAAA,MAAM,EAAE,eAAA,EAAiB,eAAgB,EAAA,GAAI,UAAW,CAAA;AAAA,IACtD,SAAW,EAAA,QAAA;AAAA,IACX,IAAA;AAAA,IACA,YAAc,EAAA,gBAAA;AAAA,GACf,CAAA,CAAA;AAED,EACE,uBAAA,IAAA,CAAA,QAAA,EAAA;AAAA,IACE,QAAA,EAAA;AAAA,sBAAC,IAAA,CAAA,MAAA,EAAA;AAAA,QACE,GAAG,eAA+B,CAAA;AAAA,UACjC,SAAW,EAAAC,EAAA,CAAG,YAAa,CAAA,eAAe,CAAG,EAAA;AAAA,YAC3C,CAAC,YAAa,CAAA,0BAA0B,CAAI,GAAA,SAAA;AAAA,WAC7C,CAAA;AAAA,UAED,aAAe,EAAA,8BAAA;AAAA,UACf,QAAU,EAAA,QAAA;AAAA,UACV,GAAG,WAAA;AAAA,SACJ,CAAA;AAAA,QAEA,QAAA,EAAA;AAAA,UAAA,KAAA,oBACE,GAAA,CAAA,KAAA,EAAA;AAAA,YACC,SAAW,EAAAA,EAAA,CAAG,YAAa,CAAA,qBAAqB,CAAG,EAAA;AAAA,cACjD,CAAC,YAAa,CAAA,+BAA+B,CAC3C,GAAA,KAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,KAAA,CAAO,IAAI,UAAW,CAAA,SAAA,CAAA;AAAA,cACxB,CAAC,YAAa,CAAA,gCAAgC,CAAI,GAAA,aAAA;AAAA,gBAChD,KAAO,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA;AAAA,eACT;AAAA,aACD,CAAA;AAAA,YACD,KAAO,EAAA;AAAA,cACL,iBAAiB,KAAO,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA;AAAA,aAC1B;AAAA,WACF,CAAA;AAAA,UAED,CAAC,6BACC,GAAA,CAAA,KAAA,EAAA;AAAA,YAAI,SAAA,EAAW,aAAa,mBAAmB,CAAA;AAAA,YAC7C,QAAA,EAAA,CAAA,EAAA,GAAA,gBAAA,IAAA,IAAA,GAAA,gBAAA,GAAoB,gBAApB,IAAmC,GAAA,EAAA,GAAA,mBAAA;AAAA,WACtC,CAAA;AAAA,SAAA;AAAA,OAEJ,CAAA;AAAA,sBACC,GAAA,CAAA,OAAA,EAAA;AAAA,QACE,GAAG,eAAgB,CAAA;AAAA,UAClB,aAAe,EAAA;AAAA,YACb,SAAW,EAAA,KAAA;AAAA,WACb;AAAA,UAEA,aAAe,EAAA,uBAAA;AAAA,UACf,SAAW,EAAAA,EAAA,CAAG,YAAa,CAAA,oBAAoB,CAAC,CAAA;AAAA,SACjD,CAAA;AAAA,QAED,QAAC,kBAAA,IAAA,CAAA,KAAA,EAAA;AAAA,UACC,SAAW,EAAAA,EAAA,CAAG,YAAa,CAAA,gBAAgB,CAAC,CAAA;AAAA,UAC5C,aAAY,EAAA,iBAAA;AAAA,UAEZ,QAAA,EAAA;AAAA,4BAAC,IAAA,CAAA,MAAA,EAAA;AAAA,cACC,aAAY,EAAA,gBAAA;AAAA,cACZ,OAAQ,EAAA,WAAA;AAAA,cACR,SAAW,EAAAA,EAAA,CAAG,YAAa,CAAA,eAAe,CAAC,CAAA;AAAA,cAC3C,OAAS,EAAA,iBAAA;AAAA,cAET,QAAA,EAAA;AAAA,gCAAC,GAAA,CAAA,WAAA,EAAA;AAAA,kBAAY,SAAW,EAAAA,EAAA,CAAG,YAAa,CAAA,aAAa,CAAC,CAAA;AAAA,iBAAG,CAAA;AAAA,gBAAE,SAAA;AAAA,eAAA;AAAA,aAE7D,CAAA;AAAA,4BACC,GAAA,CAAA,QAAA,EAAA;AAAA,cACC,IAAM,EAAA,WAAA;AAAA,cACN,UAAU,KAAO,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA;AAAA,cACjB,UAAA;AAAA,cACA,SAAA;AAAA,aACF,CAAA;AAAA,WAAA;AAAA,SACF,CAAA;AAAA,OACF,CAAA;AAAA,KAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
1
+ {"version":3,"file":"ColorChooser.js","sources":["../src/color-chooser/ColorChooser.tsx"],"sourcesContent":["import { useState, ChangeEvent } from \"react\";\nimport { clsx } from \"clsx\";\nimport { Overlay, useOverlay } from \"../overlay\";\nimport { Button, ButtonProps, makePrefixer } from \"@salt-ds/core\";\nimport { RefreshIcon } from \"@salt-ds/icons\";\nimport { Color } from \"./Color\";\nimport { isTransparent } from \"./color-utils\";\n\nimport {\n hexValueWithoutAlpha,\n getColorNameByHexValue,\n convertColorMapValueToHex,\n getHexValue,\n} from \"./ColorHelpers\";\nimport { saltColorMap } from \"./colorMap\";\nimport { ColorChooserTabs, DictTabs } from \"./DictTabs\";\nimport { getColorPalettes } from \"./GetColorPalettes\";\nimport { createTabsMapping } from \"./createTabsMapping\";\n\nimport \"./ColorChooser.css\";\n\nconst withBaseName = makePrefixer(\"saltColorChooser\");\n\nfunction getActiveTab(\n hexValue: string | undefined,\n tabs: ColorChooserTabs,\n saltColorOverrides: Record<string, string> | undefined\n): number {\n if (tabs[\"Swatches\"] && tabs[\"Color Picker\"]) {\n const hexNoAlpha: string | undefined = hexValueWithoutAlpha(hexValue);\n const colors = saltColorOverrides ?? saltColorMap;\n // if hexNoAlpha is a Salt color or null/undefined then set the active tab as Swatches\n if (\n hexNoAlpha &&\n !Object.keys(colors).find(\n (key: string) =>\n convertColorMapValueToHex(colors[key])?.toLowerCase() ===\n hexNoAlpha?.toLowerCase()\n )\n ) {\n return 1;\n }\n }\n return 0;\n}\n\nexport interface ColorChooserProps {\n color: Color | undefined;\n defaultAlpha?: number;\n disableAlphaChooser?: boolean;\n displayHexOnly?: boolean;\n hideLabel?: boolean;\n onClear: () => void; // called when user clicks \"default\" button\n onSelect: (\n color: Color | undefined,\n finalSelection: boolean,\n event?: ChangeEvent\n ) => void;\n placeholder?: string;\n buttonProps?: Partial<ButtonProps>;\n saltColorOverrides?: Record<string, string>;\n showSwatches?: boolean;\n showColorPicker?: boolean;\n readOnly?: boolean;\n}\n\nexport const ColorChooser = ({\n onClear,\n onSelect,\n color,\n showSwatches = true,\n showColorPicker = true,\n defaultAlpha = 1,\n disableAlphaChooser = false,\n hideLabel = false,\n placeholder,\n buttonProps,\n saltColorOverrides,\n readOnly = false,\n displayHexOnly = false,\n}: ColorChooserProps): JSX.Element => {\n const [open, setOpen] = useState(false);\n\n const allColors: string[][] = saltColorOverrides\n ? getColorPalettes(saltColorOverrides)\n : getColorPalettes();\n const displayColorName = displayHexOnly\n ? getHexValue(color?.hex, disableAlphaChooser)\n : getColorNameByHexValue(\n color?.hex,\n disableAlphaChooser,\n saltColorOverrides\n );\n\n const handleOpenChange = (open: boolean) => setOpen(open);\n\n const alphaForTabs = isTransparent(color?.hex)\n ? defaultAlpha\n : color?.rgba?.a ?? defaultAlpha;\n\n const tabsMapping = createTabsMapping({\n swatches: showSwatches,\n colorPicker: showColorPicker,\n disableAlphaChooser,\n allColors,\n color,\n alpha: alphaForTabs,\n handleColorChange: onSelect,\n displayColorName,\n placeholder,\n onDialogClosed: () => {\n setOpen(false);\n },\n });\n\n const [activeTab, setActiveTab] = useState<number>(\n getActiveTab(color?.hex, tabsMapping, saltColorOverrides)\n );\n const onDefaultSelected = (): void => {\n if (activeTab === 0 && showSwatches) {\n onClear();\n handleOpenChange(false);\n } else {\n onClear();\n }\n };\n const onTabClick = (index: number): void => {\n setActiveTab(index);\n };\n\n const { getTriggerProps, getOverlayProps } = useOverlay({\n placement: \"bottom\",\n open,\n onOpenChange: handleOpenChange,\n });\n\n return (\n <>\n <Button\n {...getTriggerProps<typeof Button>({\n className: clsx(withBaseName(\"overlayButton\"), {\n [withBaseName(\"overlayButtonHiddenLabel\")]: hideLabel,\n }),\n // @ts-ignore\n \"data-testid\": \"color-chooser-overlay-button\",\n disabled: readOnly,\n ...buttonProps,\n })}\n >\n {color && (\n <div\n className={clsx(withBaseName(\"overlayButtonSwatch\"), {\n [withBaseName(\"overlayButtonSwatchWithBorder\")]:\n color?.hex.startsWith(\"#ffffff\"),\n [withBaseName(\"overlayButtonSwatchTransparent\")]: isTransparent(\n color?.hex\n ),\n })}\n style={{\n backgroundColor: color?.hex,\n }}\n />\n )}\n {!hideLabel && (\n <div className={withBaseName(\"overlayButtonText\")}>\n {displayColorName ?? placeholder ?? \"No color selected\"}\n </div>\n )}\n </Button>\n <Overlay\n {...getOverlayProps({\n adaExceptions: {\n showClose: false,\n },\n // @ts-ignore\n \"data-testid\": \"color-chooser-overlay\",\n className: clsx(withBaseName(\"overlayButtonClose\")),\n })}\n >\n <div\n className={clsx(withBaseName(\"overlayContent\"))}\n data-testid=\"overlay-content\"\n >\n <Button\n data-testid=\"default-button\"\n variant=\"secondary\"\n className={clsx(withBaseName(\"defaultButton\"))}\n onClick={onDefaultSelected}\n >\n <RefreshIcon className={clsx(withBaseName(\"refreshIcon\"))} />\n Default\n </Button>\n <DictTabs\n tabs={tabsMapping}\n hexValue={color?.hex}\n onTabClick={onTabClick}\n activeTab={activeTab}\n />\n </div>\n </Overlay>\n </>\n );\n};\n"],"names":["open"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { jsxs, jsx } from 'react/jsx-runtime';
2
2
  import { SketchPicker } from 'react-color';
3
- import cx from 'classnames';
3
+ import { clsx } from 'clsx';
4
4
  import { makePrefixer, Button } from '@salt-ds/core';
5
5
  import { Color } from './Color.js';
6
6
  import { hexValueWithoutAlpha } from './ColorHelpers.js';
@@ -52,10 +52,10 @@ const ColorPicker = ({
52
52
  };
53
53
  return /* @__PURE__ */ jsxs("div", {
54
54
  "data-testid": "color-picker",
55
- className: cx(withBaseName()),
55
+ className: clsx(withBaseName()),
56
56
  children: [
57
57
  /* @__PURE__ */ jsx(SketchPicker, {
58
- className: cx(withBaseName("swatchPickerStyles"), {
58
+ className: clsx(withBaseName("swatchPickerStyles"), {
59
59
  ["rootDisabledAlpha"]: disableAlphaChooser,
60
60
  ["root"]: !disableAlphaChooser
61
61
  }),
@@ -65,13 +65,13 @@ const ColorPicker = ({
65
65
  disableAlpha: disableAlphaChooser
66
66
  }),
67
67
  /* @__PURE__ */ jsxs("div", {
68
- className: cx(withBaseName("inputContainer")),
68
+ className: clsx(withBaseName("inputContainer")),
69
69
  children: [
70
70
  /* @__PURE__ */ jsxs("div", {
71
- className: cx(withBaseName("inputDivs")),
71
+ className: clsx(withBaseName("inputDivs")),
72
72
  children: [
73
73
  /* @__PURE__ */ jsx("span", {
74
- className: cx(withBaseName("textDivOverrides")),
74
+ className: clsx(withBaseName("textDivOverrides")),
75
75
  children: "HEX"
76
76
  }),
77
77
  /* @__PURE__ */ jsx(HexInput, {
@@ -89,7 +89,7 @@ const ColorPicker = ({
89
89
  ]
90
90
  }),
91
91
  /* @__PURE__ */ jsx("div", {
92
- className: cx(withBaseName("applyButtonDiv")),
92
+ className: clsx(withBaseName("applyButtonDiv")),
93
93
  children: /* @__PURE__ */ jsx(Button, {
94
94
  "data-testid": "apply-button",
95
95
  variant: "cta",