@salt-ds/core 1.31.0 → 1.33.0

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 (756) hide show
  1. package/css/salt-core.css +28 -5
  2. package/dist-cjs/accordion/Accordion.js +7 -7
  3. package/dist-cjs/accordion/Accordion.js.map +1 -1
  4. package/dist-cjs/accordion/AccordionContext.js +6 -6
  5. package/dist-cjs/accordion/AccordionContext.js.map +1 -1
  6. package/dist-cjs/accordion/AccordionGroup.js +6 -6
  7. package/dist-cjs/accordion/AccordionGroup.js.map +1 -1
  8. package/dist-cjs/accordion/AccordionHeader.js +7 -7
  9. package/dist-cjs/accordion/AccordionHeader.js.map +1 -1
  10. package/dist-cjs/accordion/AccordionPanel.js +5 -5
  11. package/dist-cjs/accordion/AccordionPanel.js.map +1 -1
  12. package/dist-cjs/aria-announcer/AriaAnnounce.js.map +1 -1
  13. package/dist-cjs/aria-announcer/AriaAnnouncerContext.js.map +1 -1
  14. package/dist-cjs/aria-announcer/AriaAnnouncerProvider.js.map +1 -1
  15. package/dist-cjs/aria-announcer/useAriaAnnouncer.js +7 -7
  16. package/dist-cjs/aria-announcer/useAriaAnnouncer.js.map +1 -1
  17. package/dist-cjs/avatar/Avatar.js +4 -4
  18. package/dist-cjs/avatar/Avatar.js.map +1 -1
  19. package/dist-cjs/avatar/useAvatarImage.js +6 -6
  20. package/dist-cjs/avatar/useAvatarImage.js.map +1 -1
  21. package/dist-cjs/badge/Badge.js +5 -5
  22. package/dist-cjs/badge/Badge.js.map +1 -1
  23. package/dist-cjs/banner/Banner.js +6 -6
  24. package/dist-cjs/banner/Banner.js.map +1 -1
  25. package/dist-cjs/banner/BannerActions.js +5 -5
  26. package/dist-cjs/banner/BannerActions.js.map +1 -1
  27. package/dist-cjs/banner/BannerContent.js +5 -5
  28. package/dist-cjs/banner/BannerContent.js.map +1 -1
  29. package/dist-cjs/border-item/BorderItem.js +7 -7
  30. package/dist-cjs/border-item/BorderItem.js.map +1 -1
  31. package/dist-cjs/border-layout/BorderLayout.js +5 -5
  32. package/dist-cjs/border-layout/BorderLayout.js.map +1 -1
  33. package/dist-cjs/breakpoints/BreakpointProvider.js +6 -6
  34. package/dist-cjs/breakpoints/BreakpointProvider.js.map +1 -1
  35. package/dist-cjs/button/Button.css.js +1 -1
  36. package/dist-cjs/button/Button.js +5 -5
  37. package/dist-cjs/button/Button.js.map +1 -1
  38. package/dist-cjs/button/useButton.js.map +1 -1
  39. package/dist-cjs/card/Card.js +42 -40
  40. package/dist-cjs/card/Card.js.map +1 -1
  41. package/dist-cjs/checkbox/Checkbox.js +6 -6
  42. package/dist-cjs/checkbox/Checkbox.js.map +1 -1
  43. package/dist-cjs/checkbox/CheckboxGroup.js +5 -5
  44. package/dist-cjs/checkbox/CheckboxGroup.js.map +1 -1
  45. package/dist-cjs/checkbox/CheckboxIcon.js +5 -5
  46. package/dist-cjs/checkbox/CheckboxIcon.js.map +1 -1
  47. package/dist-cjs/checkbox/internal/CheckboxGroupContext.js +6 -6
  48. package/dist-cjs/checkbox/internal/CheckboxGroupContext.js.map +1 -1
  49. package/dist-cjs/combo-box/ComboBox.js +21 -20
  50. package/dist-cjs/combo-box/ComboBox.js.map +1 -1
  51. package/dist-cjs/combo-box/useComboBox.js +6 -6
  52. package/dist-cjs/combo-box/useComboBox.js.map +1 -1
  53. package/dist-cjs/dialog/Dialog.js +92 -88
  54. package/dist-cjs/dialog/Dialog.js.map +1 -1
  55. package/dist-cjs/dialog/DialogActions.js +6 -6
  56. package/dist-cjs/dialog/DialogActions.js.map +1 -1
  57. package/dist-cjs/dialog/DialogCloseButton.js +7 -7
  58. package/dist-cjs/dialog/DialogCloseButton.js.map +1 -1
  59. package/dist-cjs/dialog/DialogContent.js +6 -6
  60. package/dist-cjs/dialog/DialogContent.js.map +1 -1
  61. package/dist-cjs/dialog/DialogContext.js.map +1 -1
  62. package/dist-cjs/dialog/DialogHeader.js +5 -5
  63. package/dist-cjs/dialog/DialogHeader.js.map +1 -1
  64. package/dist-cjs/divider/Divider.js +6 -6
  65. package/dist-cjs/divider/Divider.js.map +1 -1
  66. package/dist-cjs/drawer/Drawer.js +76 -74
  67. package/dist-cjs/drawer/Drawer.js.map +1 -1
  68. package/dist-cjs/drawer/DrawerCloseButton.js +7 -7
  69. package/dist-cjs/drawer/DrawerCloseButton.js.map +1 -1
  70. package/dist-cjs/dropdown/Dropdown.js +17 -16
  71. package/dist-cjs/dropdown/Dropdown.js.map +1 -1
  72. package/dist-cjs/file-drop-zone/FileDropZone.js +5 -5
  73. package/dist-cjs/file-drop-zone/FileDropZone.js.map +1 -1
  74. package/dist-cjs/file-drop-zone/FileDropZoneIcon.js +1 -1
  75. package/dist-cjs/file-drop-zone/FileDropZoneIcon.js.map +1 -1
  76. package/dist-cjs/file-drop-zone/FileDropZoneTrigger.js +6 -6
  77. package/dist-cjs/file-drop-zone/FileDropZoneTrigger.js.map +1 -1
  78. package/dist-cjs/file-drop-zone/internal/utils.js.map +1 -1
  79. package/dist-cjs/flex-item/FlexItem.js +8 -8
  80. package/dist-cjs/flex-item/FlexItem.js.map +1 -1
  81. package/dist-cjs/flex-layout/FlexLayout.js +5 -5
  82. package/dist-cjs/flex-layout/FlexLayout.js.map +1 -1
  83. package/dist-cjs/flow-layout/FlowLayout.js.map +1 -1
  84. package/dist-cjs/form-field/FormField.js +4 -4
  85. package/dist-cjs/form-field/FormField.js.map +1 -1
  86. package/dist-cjs/form-field/FormFieldHelperText.js +5 -5
  87. package/dist-cjs/form-field/FormFieldHelperText.js.map +1 -1
  88. package/dist-cjs/form-field/FormFieldLabel.js +3 -3
  89. package/dist-cjs/form-field/FormFieldLabel.js.map +1 -1
  90. package/dist-cjs/form-field-context/FormFieldContext.js +5 -5
  91. package/dist-cjs/form-field-context/FormFieldContext.js.map +1 -1
  92. package/dist-cjs/form-field-context/useFormFieldProps.js.map +1 -1
  93. package/dist-cjs/grid-item/GridItem.js +8 -8
  94. package/dist-cjs/grid-item/GridItem.js.map +1 -1
  95. package/dist-cjs/grid-layout/GridLayout.js +5 -5
  96. package/dist-cjs/grid-layout/GridLayout.js.map +1 -1
  97. package/dist-cjs/index.js +9 -0
  98. package/dist-cjs/index.js.map +1 -1
  99. package/dist-cjs/input/Input.js +5 -5
  100. package/dist-cjs/input/Input.js.map +1 -1
  101. package/dist-cjs/interactable-card/InteractableCard.js +9 -9
  102. package/dist-cjs/interactable-card/InteractableCard.js.map +1 -1
  103. package/dist-cjs/interactable-card/InteractableCardGroup.js +18 -14
  104. package/dist-cjs/interactable-card/InteractableCardGroup.js.map +1 -1
  105. package/dist-cjs/interactable-card/InteractableCardGroupContext.js +6 -6
  106. package/dist-cjs/interactable-card/InteractableCardGroupContext.js.map +1 -1
  107. package/dist-cjs/interactable-card/useInteractableCard.js +1 -1
  108. package/dist-cjs/interactable-card/useInteractableCard.js.map +1 -1
  109. package/dist-cjs/link/Link.js +12 -12
  110. package/dist-cjs/link/Link.js.map +1 -1
  111. package/dist-cjs/link-card/LinkCard.js +5 -5
  112. package/dist-cjs/link-card/LinkCard.js.map +1 -1
  113. package/dist-cjs/list-box/ListBox.css.js +1 -1
  114. package/dist-cjs/list-box/ListBox.js +10 -10
  115. package/dist-cjs/list-box/ListBox.js.map +1 -1
  116. package/dist-cjs/list-control/ListControlContext.js +6 -6
  117. package/dist-cjs/list-control/ListControlContext.js.map +1 -1
  118. package/dist-cjs/list-control/ListControlState.js +12 -12
  119. package/dist-cjs/list-control/ListControlState.js.map +1 -1
  120. package/dist-cjs/menu/Menu.js +1 -1
  121. package/dist-cjs/menu/Menu.js.map +1 -1
  122. package/dist-cjs/menu/MenuBase.js +11 -9
  123. package/dist-cjs/menu/MenuBase.js.map +1 -1
  124. package/dist-cjs/menu/MenuContext.js +5 -5
  125. package/dist-cjs/menu/MenuContext.js.map +1 -1
  126. package/dist-cjs/menu/MenuGroup.js +6 -6
  127. package/dist-cjs/menu/MenuGroup.js.map +1 -1
  128. package/dist-cjs/menu/MenuItem.js +8 -8
  129. package/dist-cjs/menu/MenuItem.js.map +1 -1
  130. package/dist-cjs/menu/MenuPanel.css.js +1 -1
  131. package/dist-cjs/menu/MenuPanel.js +7 -7
  132. package/dist-cjs/menu/MenuPanel.js.map +1 -1
  133. package/dist-cjs/menu/MenuPanelBase.js +2 -2
  134. package/dist-cjs/menu/MenuPanelBase.js.map +1 -1
  135. package/dist-cjs/menu/MenuPanelContext.js +5 -5
  136. package/dist-cjs/menu/MenuPanelContext.js.map +1 -1
  137. package/dist-cjs/menu/MenuTrigger.js +9 -8
  138. package/dist-cjs/menu/MenuTrigger.js.map +1 -1
  139. package/dist-cjs/menu/MenuTriggerContext.js +5 -5
  140. package/dist-cjs/menu/MenuTriggerContext.js.map +1 -1
  141. package/dist-cjs/multiline-input/MultilineInput.js +4 -4
  142. package/dist-cjs/multiline-input/MultilineInput.js.map +1 -1
  143. package/dist-cjs/navigation-item/ExpansionIcon.js +3 -3
  144. package/dist-cjs/navigation-item/ExpansionIcon.js.map +1 -1
  145. package/dist-cjs/navigation-item/NavigationItem.js +22 -14
  146. package/dist-cjs/navigation-item/NavigationItem.js.map +1 -1
  147. package/dist-cjs/navigation-item/NavigationItemAction.js +117 -0
  148. package/dist-cjs/navigation-item/NavigationItemAction.js.map +1 -0
  149. package/dist-cjs/option/Option.js +95 -93
  150. package/dist-cjs/option/Option.js.map +1 -1
  151. package/dist-cjs/option/OptionGroup.js +6 -6
  152. package/dist-cjs/option/OptionGroup.js.map +1 -1
  153. package/dist-cjs/option/OptionList.css.js +1 -1
  154. package/dist-cjs/option/OptionList.js +5 -5
  155. package/dist-cjs/option/OptionList.js.map +1 -1
  156. package/dist-cjs/option/OptionListBase.js +6 -6
  157. package/dist-cjs/option/OptionListBase.js.map +1 -1
  158. package/dist-cjs/overlay/Overlay.js +6 -6
  159. package/dist-cjs/overlay/Overlay.js.map +1 -1
  160. package/dist-cjs/overlay/OverlayContext.js +7 -7
  161. package/dist-cjs/overlay/OverlayContext.js.map +1 -1
  162. package/dist-cjs/overlay/OverlayPanel.js +7 -7
  163. package/dist-cjs/overlay/OverlayPanel.js.map +1 -1
  164. package/dist-cjs/overlay/OverlayPanelCloseButton.js +8 -8
  165. package/dist-cjs/overlay/OverlayPanelCloseButton.js.map +1 -1
  166. package/dist-cjs/overlay/OverlayPanelContent.js +5 -5
  167. package/dist-cjs/overlay/OverlayPanelContent.js.map +1 -1
  168. package/dist-cjs/overlay/OverlayTrigger.js +8 -10
  169. package/dist-cjs/overlay/OverlayTrigger.js.map +1 -1
  170. package/dist-cjs/pagination/CompactInput.js +5 -5
  171. package/dist-cjs/pagination/CompactInput.js.map +1 -1
  172. package/dist-cjs/pagination/CompactPaginator.js +5 -5
  173. package/dist-cjs/pagination/CompactPaginator.js.map +1 -1
  174. package/dist-cjs/pagination/GoToInput.js +5 -5
  175. package/dist-cjs/pagination/GoToInput.js.map +1 -1
  176. package/dist-cjs/pagination/PageButton.js +5 -5
  177. package/dist-cjs/pagination/PageButton.js.map +1 -1
  178. package/dist-cjs/pagination/PageRanges.js +6 -6
  179. package/dist-cjs/pagination/PageRanges.js.map +1 -1
  180. package/dist-cjs/pagination/Pagination.js +7 -7
  181. package/dist-cjs/pagination/Pagination.js.map +1 -1
  182. package/dist-cjs/pagination/PaginationContext.js.map +1 -1
  183. package/dist-cjs/pagination/Paginator.js +4 -4
  184. package/dist-cjs/pagination/Paginator.js.map +1 -1
  185. package/dist-cjs/pagination/usePagination.js.map +1 -1
  186. package/dist-cjs/pagination/usePaginationContext.js +1 -1
  187. package/dist-cjs/pagination/usePaginationContext.js.map +1 -1
  188. package/dist-cjs/panel/Panel.js +4 -4
  189. package/dist-cjs/panel/Panel.js.map +1 -1
  190. package/dist-cjs/parent-child-layout/ParentChildLayout.js +5 -5
  191. package/dist-cjs/parent-child-layout/ParentChildLayout.js.map +1 -1
  192. package/dist-cjs/parent-child-layout/useIsViewportLargerThanBreakpoint.js +6 -6
  193. package/dist-cjs/parent-child-layout/useIsViewportLargerThanBreakpoint.js.map +1 -1
  194. package/dist-cjs/pill/Pill.js +9 -9
  195. package/dist-cjs/pill/Pill.js.map +1 -1
  196. package/dist-cjs/pill-input/PillInput.js +12 -12
  197. package/dist-cjs/pill-input/PillInput.js.map +1 -1
  198. package/dist-cjs/pill-input/useTruncatePills.js +9 -4
  199. package/dist-cjs/pill-input/useTruncatePills.js.map +1 -1
  200. package/dist-cjs/progress/CircularProgress/CircularProgress.js +13 -13
  201. package/dist-cjs/progress/CircularProgress/CircularProgress.js.map +1 -1
  202. package/dist-cjs/progress/LinearProgress/LinearProgress.css.js +1 -1
  203. package/dist-cjs/progress/LinearProgress/LinearProgress.js +30 -25
  204. package/dist-cjs/progress/LinearProgress/LinearProgress.js.map +1 -1
  205. package/dist-cjs/radio-button/RadioButton.js +7 -7
  206. package/dist-cjs/radio-button/RadioButton.js.map +1 -1
  207. package/dist-cjs/radio-button/RadioButtonGroup.js +5 -5
  208. package/dist-cjs/radio-button/RadioButtonGroup.js.map +1 -1
  209. package/dist-cjs/radio-button/RadioButtonIcon.js +6 -6
  210. package/dist-cjs/radio-button/RadioButtonIcon.js.map +1 -1
  211. package/dist-cjs/radio-button/internal/RadioGroupContext.js +6 -6
  212. package/dist-cjs/radio-button/internal/RadioGroupContext.js.map +1 -1
  213. package/dist-cjs/salt-provider/SaltProvider.js +48 -46
  214. package/dist-cjs/salt-provider/SaltProvider.js.map +1 -1
  215. package/dist-cjs/scrim/Scrim.js +4 -4
  216. package/dist-cjs/scrim/Scrim.js.map +1 -1
  217. package/dist-cjs/segmented-button-group/SegmentedButtonGroup.js +6 -6
  218. package/dist-cjs/segmented-button-group/SegmentedButtonGroup.js.map +1 -1
  219. package/dist-cjs/spinner/Spinner.js +4 -4
  220. package/dist-cjs/spinner/Spinner.js.map +1 -1
  221. package/dist-cjs/spinner/svgSpinners/SpinnerSVG.js +5 -5
  222. package/dist-cjs/spinner/svgSpinners/SpinnerSVG.js.map +1 -1
  223. package/dist-cjs/split-layout/SplitLayout.js +6 -6
  224. package/dist-cjs/split-layout/SplitLayout.js.map +1 -1
  225. package/dist-cjs/stack-layout/StackLayout.js +8 -8
  226. package/dist-cjs/stack-layout/StackLayout.js.map +1 -1
  227. package/dist-cjs/status-adornment/ErrorAdornment.js.map +1 -1
  228. package/dist-cjs/status-adornment/StatusAdornment.js +5 -5
  229. package/dist-cjs/status-adornment/StatusAdornment.js.map +1 -1
  230. package/dist-cjs/status-adornment/SuccessAdornment.js.map +1 -1
  231. package/dist-cjs/status-adornment/WarningAdornment.js.map +1 -1
  232. package/dist-cjs/status-indicator/StatusIndicator.js +3 -3
  233. package/dist-cjs/status-indicator/StatusIndicator.js.map +1 -1
  234. package/dist-cjs/switch/Switch.js +101 -99
  235. package/dist-cjs/switch/Switch.js.map +1 -1
  236. package/dist-cjs/tag/Tag.js +6 -6
  237. package/dist-cjs/tag/Tag.js.map +1 -1
  238. package/dist-cjs/text/Code.js.map +1 -1
  239. package/dist-cjs/text/Display.js.map +1 -1
  240. package/dist-cjs/text/Headings.js.map +1 -1
  241. package/dist-cjs/text/Label.js.map +1 -1
  242. package/dist-cjs/text/Text.js +5 -5
  243. package/dist-cjs/text/Text.js.map +1 -1
  244. package/dist-cjs/text/TextAction.js.map +1 -1
  245. package/dist-cjs/text/TextNotation.js.map +1 -1
  246. package/dist-cjs/theme/Accent.js +3 -1
  247. package/dist-cjs/theme/Accent.js.map +1 -1
  248. package/dist-cjs/theme/ActionFont.js +3 -1
  249. package/dist-cjs/theme/ActionFont.js.map +1 -1
  250. package/dist-cjs/theme/Corner.js +3 -1
  251. package/dist-cjs/theme/Corner.js.map +1 -1
  252. package/dist-cjs/theme/HeadingFont.js +3 -1
  253. package/dist-cjs/theme/HeadingFont.js.map +1 -1
  254. package/dist-cjs/theme/Theme.js.map +1 -1
  255. package/dist-cjs/toast/Toast.js +33 -31
  256. package/dist-cjs/toast/Toast.js.map +1 -1
  257. package/dist-cjs/toast/ToastContent.js +5 -5
  258. package/dist-cjs/toast/ToastContent.js.map +1 -1
  259. package/dist-cjs/toggle-button/ToggleButton.js +6 -6
  260. package/dist-cjs/toggle-button/ToggleButton.js.map +1 -1
  261. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js +10 -10
  262. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js.map +1 -1
  263. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js +6 -6
  264. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js.map +1 -1
  265. package/dist-cjs/tooltip/Tooltip.css.js +1 -1
  266. package/dist-cjs/tooltip/Tooltip.js +9 -11
  267. package/dist-cjs/tooltip/Tooltip.js.map +1 -1
  268. package/dist-cjs/tooltip/TooltipBase.js +6 -6
  269. package/dist-cjs/tooltip/TooltipBase.js.map +1 -1
  270. package/dist-cjs/tooltip/useAriaAnnounce.js +11 -8
  271. package/dist-cjs/tooltip/useAriaAnnounce.js.map +1 -1
  272. package/dist-cjs/tooltip/useTooltip.js +5 -5
  273. package/dist-cjs/tooltip/useTooltip.js.map +1 -1
  274. package/dist-cjs/utils/createChainedFunction.js.map +1 -1
  275. package/dist-cjs/utils/createContext.js.map +1 -1
  276. package/dist-cjs/utils/debounce.js.map +1 -1
  277. package/dist-cjs/utils/getRefFromChildren.js +15 -0
  278. package/dist-cjs/utils/getRefFromChildren.js.map +1 -0
  279. package/dist-cjs/utils/marginMiddleware.js.map +1 -1
  280. package/dist-cjs/utils/mergeProps.js.map +1 -1
  281. package/dist-cjs/utils/renderProps.js +32 -0
  282. package/dist-cjs/utils/renderProps.js.map +1 -0
  283. package/dist-cjs/utils/setRef.js.map +1 -1
  284. package/dist-cjs/utils/useControlled.js +1 -1
  285. package/dist-cjs/utils/useControlled.js.map +1 -1
  286. package/dist-cjs/utils/useEventCallback.js.map +1 -1
  287. package/dist-cjs/utils/useFloatingUI/useFloatingUI.js +1 -1
  288. package/dist-cjs/utils/useFloatingUI/useFloatingUI.js.map +1 -1
  289. package/dist-cjs/utils/useForkRef.js.map +1 -1
  290. package/dist-cjs/utils/useId.js +1 -2
  291. package/dist-cjs/utils/useId.js.map +1 -1
  292. package/dist-cjs/utils/useIsFocusVisible.js.map +1 -1
  293. package/dist-cjs/utils/useIsomorphicLayoutEffect.js.map +1 -1
  294. package/dist-cjs/utils/usePrevious.js.map +1 -1
  295. package/dist-cjs/utils/useResizeObserver.js.map +1 -1
  296. package/dist-cjs/utils/useResponsiveProp.js +11 -8
  297. package/dist-cjs/utils/useResponsiveProp.js.map +1 -1
  298. package/dist-cjs/utils/useValueEffect.js +5 -5
  299. package/dist-cjs/utils/useValueEffect.js.map +1 -1
  300. package/dist-cjs/viewport/ViewportProvider.js +5 -5
  301. package/dist-cjs/viewport/ViewportProvider.js.map +1 -1
  302. package/dist-es/accordion/Accordion.js +7 -7
  303. package/dist-es/accordion/Accordion.js.map +1 -1
  304. package/dist-es/accordion/AccordionContext.js +6 -6
  305. package/dist-es/accordion/AccordionContext.js.map +1 -1
  306. package/dist-es/accordion/AccordionGroup.js +6 -6
  307. package/dist-es/accordion/AccordionGroup.js.map +1 -1
  308. package/dist-es/accordion/AccordionHeader.js +7 -7
  309. package/dist-es/accordion/AccordionHeader.js.map +1 -1
  310. package/dist-es/accordion/AccordionPanel.js +5 -5
  311. package/dist-es/accordion/AccordionPanel.js.map +1 -1
  312. package/dist-es/aria-announcer/AriaAnnounce.js.map +1 -1
  313. package/dist-es/aria-announcer/AriaAnnouncerContext.js.map +1 -1
  314. package/dist-es/aria-announcer/AriaAnnouncerProvider.js.map +1 -1
  315. package/dist-es/aria-announcer/useAriaAnnouncer.js +7 -7
  316. package/dist-es/aria-announcer/useAriaAnnouncer.js.map +1 -1
  317. package/dist-es/avatar/Avatar.js +4 -4
  318. package/dist-es/avatar/Avatar.js.map +1 -1
  319. package/dist-es/avatar/useAvatarImage.js +6 -6
  320. package/dist-es/avatar/useAvatarImage.js.map +1 -1
  321. package/dist-es/badge/Badge.js +5 -5
  322. package/dist-es/badge/Badge.js.map +1 -1
  323. package/dist-es/banner/Banner.js +6 -6
  324. package/dist-es/banner/Banner.js.map +1 -1
  325. package/dist-es/banner/BannerActions.js +5 -5
  326. package/dist-es/banner/BannerActions.js.map +1 -1
  327. package/dist-es/banner/BannerContent.js +5 -5
  328. package/dist-es/banner/BannerContent.js.map +1 -1
  329. package/dist-es/border-item/BorderItem.js +7 -7
  330. package/dist-es/border-item/BorderItem.js.map +1 -1
  331. package/dist-es/border-layout/BorderLayout.js +5 -5
  332. package/dist-es/border-layout/BorderLayout.js.map +1 -1
  333. package/dist-es/breakpoints/BreakpointProvider.js +6 -6
  334. package/dist-es/breakpoints/BreakpointProvider.js.map +1 -1
  335. package/dist-es/button/Button.css.js +1 -1
  336. package/dist-es/button/Button.js +5 -5
  337. package/dist-es/button/Button.js.map +1 -1
  338. package/dist-es/button/useButton.js.map +1 -1
  339. package/dist-es/card/Card.js +42 -40
  340. package/dist-es/card/Card.js.map +1 -1
  341. package/dist-es/checkbox/Checkbox.js +6 -6
  342. package/dist-es/checkbox/Checkbox.js.map +1 -1
  343. package/dist-es/checkbox/CheckboxGroup.js +5 -5
  344. package/dist-es/checkbox/CheckboxGroup.js.map +1 -1
  345. package/dist-es/checkbox/CheckboxIcon.js +5 -5
  346. package/dist-es/checkbox/CheckboxIcon.js.map +1 -1
  347. package/dist-es/checkbox/internal/CheckboxGroupContext.js +6 -6
  348. package/dist-es/checkbox/internal/CheckboxGroupContext.js.map +1 -1
  349. package/dist-es/combo-box/ComboBox.js +22 -21
  350. package/dist-es/combo-box/ComboBox.js.map +1 -1
  351. package/dist-es/combo-box/useComboBox.js +6 -6
  352. package/dist-es/combo-box/useComboBox.js.map +1 -1
  353. package/dist-es/dialog/Dialog.js +92 -88
  354. package/dist-es/dialog/Dialog.js.map +1 -1
  355. package/dist-es/dialog/DialogActions.js +6 -6
  356. package/dist-es/dialog/DialogActions.js.map +1 -1
  357. package/dist-es/dialog/DialogCloseButton.js +7 -7
  358. package/dist-es/dialog/DialogCloseButton.js.map +1 -1
  359. package/dist-es/dialog/DialogContent.js +6 -6
  360. package/dist-es/dialog/DialogContent.js.map +1 -1
  361. package/dist-es/dialog/DialogContext.js.map +1 -1
  362. package/dist-es/dialog/DialogHeader.js +5 -5
  363. package/dist-es/dialog/DialogHeader.js.map +1 -1
  364. package/dist-es/divider/Divider.js +6 -6
  365. package/dist-es/divider/Divider.js.map +1 -1
  366. package/dist-es/drawer/Drawer.js +76 -74
  367. package/dist-es/drawer/Drawer.js.map +1 -1
  368. package/dist-es/drawer/DrawerCloseButton.js +7 -7
  369. package/dist-es/drawer/DrawerCloseButton.js.map +1 -1
  370. package/dist-es/dropdown/Dropdown.js +17 -16
  371. package/dist-es/dropdown/Dropdown.js.map +1 -1
  372. package/dist-es/file-drop-zone/FileDropZone.js +5 -5
  373. package/dist-es/file-drop-zone/FileDropZone.js.map +1 -1
  374. package/dist-es/file-drop-zone/FileDropZoneIcon.js +1 -1
  375. package/dist-es/file-drop-zone/FileDropZoneIcon.js.map +1 -1
  376. package/dist-es/file-drop-zone/FileDropZoneTrigger.js +6 -6
  377. package/dist-es/file-drop-zone/FileDropZoneTrigger.js.map +1 -1
  378. package/dist-es/file-drop-zone/internal/utils.js.map +1 -1
  379. package/dist-es/flex-item/FlexItem.js +8 -8
  380. package/dist-es/flex-item/FlexItem.js.map +1 -1
  381. package/dist-es/flex-layout/FlexLayout.js +5 -5
  382. package/dist-es/flex-layout/FlexLayout.js.map +1 -1
  383. package/dist-es/flow-layout/FlowLayout.js.map +1 -1
  384. package/dist-es/form-field/FormField.js +4 -4
  385. package/dist-es/form-field/FormField.js.map +1 -1
  386. package/dist-es/form-field/FormFieldHelperText.js +5 -5
  387. package/dist-es/form-field/FormFieldHelperText.js.map +1 -1
  388. package/dist-es/form-field/FormFieldLabel.js +3 -3
  389. package/dist-es/form-field/FormFieldLabel.js.map +1 -1
  390. package/dist-es/form-field-context/FormFieldContext.js +5 -5
  391. package/dist-es/form-field-context/FormFieldContext.js.map +1 -1
  392. package/dist-es/form-field-context/useFormFieldProps.js.map +1 -1
  393. package/dist-es/grid-item/GridItem.js +8 -8
  394. package/dist-es/grid-item/GridItem.js.map +1 -1
  395. package/dist-es/grid-layout/GridLayout.js +5 -5
  396. package/dist-es/grid-layout/GridLayout.js.map +1 -1
  397. package/dist-es/index.js +7 -5
  398. package/dist-es/index.js.map +1 -1
  399. package/dist-es/input/Input.js +5 -5
  400. package/dist-es/input/Input.js.map +1 -1
  401. package/dist-es/interactable-card/InteractableCard.js +9 -9
  402. package/dist-es/interactable-card/InteractableCard.js.map +1 -1
  403. package/dist-es/interactable-card/InteractableCardGroup.js +18 -14
  404. package/dist-es/interactable-card/InteractableCardGroup.js.map +1 -1
  405. package/dist-es/interactable-card/InteractableCardGroupContext.js +6 -6
  406. package/dist-es/interactable-card/InteractableCardGroupContext.js.map +1 -1
  407. package/dist-es/interactable-card/useInteractableCard.js +1 -1
  408. package/dist-es/interactable-card/useInteractableCard.js.map +1 -1
  409. package/dist-es/link/Link.js +12 -12
  410. package/dist-es/link/Link.js.map +1 -1
  411. package/dist-es/link-card/LinkCard.js +5 -5
  412. package/dist-es/link-card/LinkCard.js.map +1 -1
  413. package/dist-es/list-box/ListBox.css.js +1 -1
  414. package/dist-es/list-box/ListBox.js +10 -10
  415. package/dist-es/list-box/ListBox.js.map +1 -1
  416. package/dist-es/list-control/ListControlContext.js +6 -6
  417. package/dist-es/list-control/ListControlContext.js.map +1 -1
  418. package/dist-es/list-control/ListControlState.js +12 -12
  419. package/dist-es/list-control/ListControlState.js.map +1 -1
  420. package/dist-es/menu/Menu.js +1 -1
  421. package/dist-es/menu/Menu.js.map +1 -1
  422. package/dist-es/menu/MenuBase.js +11 -9
  423. package/dist-es/menu/MenuBase.js.map +1 -1
  424. package/dist-es/menu/MenuContext.js +5 -5
  425. package/dist-es/menu/MenuContext.js.map +1 -1
  426. package/dist-es/menu/MenuGroup.js +6 -6
  427. package/dist-es/menu/MenuGroup.js.map +1 -1
  428. package/dist-es/menu/MenuItem.js +8 -8
  429. package/dist-es/menu/MenuItem.js.map +1 -1
  430. package/dist-es/menu/MenuPanel.css.js +1 -1
  431. package/dist-es/menu/MenuPanel.js +7 -7
  432. package/dist-es/menu/MenuPanel.js.map +1 -1
  433. package/dist-es/menu/MenuPanelBase.js +2 -2
  434. package/dist-es/menu/MenuPanelBase.js.map +1 -1
  435. package/dist-es/menu/MenuPanelContext.js +5 -5
  436. package/dist-es/menu/MenuPanelContext.js.map +1 -1
  437. package/dist-es/menu/MenuTrigger.js +9 -8
  438. package/dist-es/menu/MenuTrigger.js.map +1 -1
  439. package/dist-es/menu/MenuTriggerContext.js +5 -5
  440. package/dist-es/menu/MenuTriggerContext.js.map +1 -1
  441. package/dist-es/multiline-input/MultilineInput.js +4 -4
  442. package/dist-es/multiline-input/MultilineInput.js.map +1 -1
  443. package/dist-es/navigation-item/ExpansionIcon.js +3 -3
  444. package/dist-es/navigation-item/ExpansionIcon.js.map +1 -1
  445. package/dist-es/navigation-item/NavigationItem.js +22 -14
  446. package/dist-es/navigation-item/NavigationItem.js.map +1 -1
  447. package/dist-es/navigation-item/NavigationItemAction.js +113 -0
  448. package/dist-es/navigation-item/NavigationItemAction.js.map +1 -0
  449. package/dist-es/option/Option.js +95 -93
  450. package/dist-es/option/Option.js.map +1 -1
  451. package/dist-es/option/OptionGroup.js +6 -6
  452. package/dist-es/option/OptionGroup.js.map +1 -1
  453. package/dist-es/option/OptionList.css.js +1 -1
  454. package/dist-es/option/OptionList.js +5 -5
  455. package/dist-es/option/OptionList.js.map +1 -1
  456. package/dist-es/option/OptionListBase.js +6 -6
  457. package/dist-es/option/OptionListBase.js.map +1 -1
  458. package/dist-es/overlay/Overlay.js +6 -6
  459. package/dist-es/overlay/Overlay.js.map +1 -1
  460. package/dist-es/overlay/OverlayContext.js +7 -7
  461. package/dist-es/overlay/OverlayContext.js.map +1 -1
  462. package/dist-es/overlay/OverlayPanel.js +7 -7
  463. package/dist-es/overlay/OverlayPanel.js.map +1 -1
  464. package/dist-es/overlay/OverlayPanelCloseButton.js +8 -8
  465. package/dist-es/overlay/OverlayPanelCloseButton.js.map +1 -1
  466. package/dist-es/overlay/OverlayPanelContent.js +5 -5
  467. package/dist-es/overlay/OverlayPanelContent.js.map +1 -1
  468. package/dist-es/overlay/OverlayTrigger.js +8 -10
  469. package/dist-es/overlay/OverlayTrigger.js.map +1 -1
  470. package/dist-es/pagination/CompactInput.js +5 -5
  471. package/dist-es/pagination/CompactInput.js.map +1 -1
  472. package/dist-es/pagination/CompactPaginator.js +5 -5
  473. package/dist-es/pagination/CompactPaginator.js.map +1 -1
  474. package/dist-es/pagination/GoToInput.js +5 -5
  475. package/dist-es/pagination/GoToInput.js.map +1 -1
  476. package/dist-es/pagination/PageButton.js +5 -5
  477. package/dist-es/pagination/PageButton.js.map +1 -1
  478. package/dist-es/pagination/PageRanges.js +6 -6
  479. package/dist-es/pagination/PageRanges.js.map +1 -1
  480. package/dist-es/pagination/Pagination.js +7 -7
  481. package/dist-es/pagination/Pagination.js.map +1 -1
  482. package/dist-es/pagination/PaginationContext.js.map +1 -1
  483. package/dist-es/pagination/Paginator.js +4 -4
  484. package/dist-es/pagination/Paginator.js.map +1 -1
  485. package/dist-es/pagination/usePagination.js.map +1 -1
  486. package/dist-es/pagination/usePaginationContext.js +1 -1
  487. package/dist-es/pagination/usePaginationContext.js.map +1 -1
  488. package/dist-es/panel/Panel.js +4 -4
  489. package/dist-es/panel/Panel.js.map +1 -1
  490. package/dist-es/parent-child-layout/ParentChildLayout.js +5 -5
  491. package/dist-es/parent-child-layout/ParentChildLayout.js.map +1 -1
  492. package/dist-es/parent-child-layout/useIsViewportLargerThanBreakpoint.js +6 -6
  493. package/dist-es/parent-child-layout/useIsViewportLargerThanBreakpoint.js.map +1 -1
  494. package/dist-es/pill/Pill.js +9 -9
  495. package/dist-es/pill/Pill.js.map +1 -1
  496. package/dist-es/pill-input/PillInput.js +12 -12
  497. package/dist-es/pill-input/PillInput.js.map +1 -1
  498. package/dist-es/pill-input/useTruncatePills.js +9 -4
  499. package/dist-es/pill-input/useTruncatePills.js.map +1 -1
  500. package/dist-es/progress/CircularProgress/CircularProgress.js +13 -13
  501. package/dist-es/progress/CircularProgress/CircularProgress.js.map +1 -1
  502. package/dist-es/progress/LinearProgress/LinearProgress.css.js +1 -1
  503. package/dist-es/progress/LinearProgress/LinearProgress.js +30 -25
  504. package/dist-es/progress/LinearProgress/LinearProgress.js.map +1 -1
  505. package/dist-es/radio-button/RadioButton.js +7 -7
  506. package/dist-es/radio-button/RadioButton.js.map +1 -1
  507. package/dist-es/radio-button/RadioButtonGroup.js +5 -5
  508. package/dist-es/radio-button/RadioButtonGroup.js.map +1 -1
  509. package/dist-es/radio-button/RadioButtonIcon.js +6 -6
  510. package/dist-es/radio-button/RadioButtonIcon.js.map +1 -1
  511. package/dist-es/radio-button/internal/RadioGroupContext.js +6 -6
  512. package/dist-es/radio-button/internal/RadioGroupContext.js.map +1 -1
  513. package/dist-es/salt-provider/SaltProvider.js +49 -44
  514. package/dist-es/salt-provider/SaltProvider.js.map +1 -1
  515. package/dist-es/scrim/Scrim.js +4 -4
  516. package/dist-es/scrim/Scrim.js.map +1 -1
  517. package/dist-es/segmented-button-group/SegmentedButtonGroup.js +6 -6
  518. package/dist-es/segmented-button-group/SegmentedButtonGroup.js.map +1 -1
  519. package/dist-es/spinner/Spinner.js +4 -4
  520. package/dist-es/spinner/Spinner.js.map +1 -1
  521. package/dist-es/spinner/svgSpinners/SpinnerSVG.js +5 -5
  522. package/dist-es/spinner/svgSpinners/SpinnerSVG.js.map +1 -1
  523. package/dist-es/split-layout/SplitLayout.js +6 -6
  524. package/dist-es/split-layout/SplitLayout.js.map +1 -1
  525. package/dist-es/stack-layout/StackLayout.js +8 -8
  526. package/dist-es/stack-layout/StackLayout.js.map +1 -1
  527. package/dist-es/status-adornment/ErrorAdornment.js.map +1 -1
  528. package/dist-es/status-adornment/StatusAdornment.js +5 -5
  529. package/dist-es/status-adornment/StatusAdornment.js.map +1 -1
  530. package/dist-es/status-adornment/SuccessAdornment.js.map +1 -1
  531. package/dist-es/status-adornment/WarningAdornment.js.map +1 -1
  532. package/dist-es/status-indicator/StatusIndicator.js +3 -3
  533. package/dist-es/status-indicator/StatusIndicator.js.map +1 -1
  534. package/dist-es/switch/Switch.js +101 -99
  535. package/dist-es/switch/Switch.js.map +1 -1
  536. package/dist-es/tag/Tag.js +6 -6
  537. package/dist-es/tag/Tag.js.map +1 -1
  538. package/dist-es/text/Code.js.map +1 -1
  539. package/dist-es/text/Display.js.map +1 -1
  540. package/dist-es/text/Headings.js.map +1 -1
  541. package/dist-es/text/Label.js.map +1 -1
  542. package/dist-es/text/Text.js +5 -5
  543. package/dist-es/text/Text.js.map +1 -1
  544. package/dist-es/text/TextAction.js.map +1 -1
  545. package/dist-es/text/TextNotation.js.map +1 -1
  546. package/dist-es/theme/Accent.js +3 -2
  547. package/dist-es/theme/Accent.js.map +1 -1
  548. package/dist-es/theme/ActionFont.js +3 -2
  549. package/dist-es/theme/ActionFont.js.map +1 -1
  550. package/dist-es/theme/Corner.js +3 -2
  551. package/dist-es/theme/Corner.js.map +1 -1
  552. package/dist-es/theme/HeadingFont.js +3 -2
  553. package/dist-es/theme/HeadingFont.js.map +1 -1
  554. package/dist-es/theme/Theme.js.map +1 -1
  555. package/dist-es/toast/Toast.js +33 -31
  556. package/dist-es/toast/Toast.js.map +1 -1
  557. package/dist-es/toast/ToastContent.js +5 -5
  558. package/dist-es/toast/ToastContent.js.map +1 -1
  559. package/dist-es/toggle-button/ToggleButton.js +6 -6
  560. package/dist-es/toggle-button/ToggleButton.js.map +1 -1
  561. package/dist-es/toggle-button-group/ToggleButtonGroup.js +10 -10
  562. package/dist-es/toggle-button-group/ToggleButtonGroup.js.map +1 -1
  563. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js +6 -6
  564. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js.map +1 -1
  565. package/dist-es/tooltip/Tooltip.css.js +1 -1
  566. package/dist-es/tooltip/Tooltip.js +9 -11
  567. package/dist-es/tooltip/Tooltip.js.map +1 -1
  568. package/dist-es/tooltip/TooltipBase.js +6 -6
  569. package/dist-es/tooltip/TooltipBase.js.map +1 -1
  570. package/dist-es/tooltip/useAriaAnnounce.js +11 -8
  571. package/dist-es/tooltip/useAriaAnnounce.js.map +1 -1
  572. package/dist-es/tooltip/useTooltip.js +5 -5
  573. package/dist-es/tooltip/useTooltip.js.map +1 -1
  574. package/dist-es/utils/createChainedFunction.js.map +1 -1
  575. package/dist-es/utils/createContext.js.map +1 -1
  576. package/dist-es/utils/debounce.js.map +1 -1
  577. package/dist-es/utils/getRefFromChildren.js +11 -0
  578. package/dist-es/utils/getRefFromChildren.js.map +1 -0
  579. package/dist-es/utils/marginMiddleware.js.map +1 -1
  580. package/dist-es/utils/mergeProps.js.map +1 -1
  581. package/dist-es/utils/renderProps.js +28 -0
  582. package/dist-es/utils/renderProps.js.map +1 -0
  583. package/dist-es/utils/setRef.js.map +1 -1
  584. package/dist-es/utils/useControlled.js +1 -1
  585. package/dist-es/utils/useControlled.js.map +1 -1
  586. package/dist-es/utils/useEventCallback.js.map +1 -1
  587. package/dist-es/utils/useFloatingUI/useFloatingUI.js +2 -2
  588. package/dist-es/utils/useFloatingUI/useFloatingUI.js.map +1 -1
  589. package/dist-es/utils/useForkRef.js.map +1 -1
  590. package/dist-es/utils/useId.js +1 -2
  591. package/dist-es/utils/useId.js.map +1 -1
  592. package/dist-es/utils/useIsFocusVisible.js.map +1 -1
  593. package/dist-es/utils/useIsomorphicLayoutEffect.js.map +1 -1
  594. package/dist-es/utils/usePrevious.js.map +1 -1
  595. package/dist-es/utils/useResizeObserver.js.map +1 -1
  596. package/dist-es/utils/useResponsiveProp.js +11 -8
  597. package/dist-es/utils/useResponsiveProp.js.map +1 -1
  598. package/dist-es/utils/useValueEffect.js +5 -5
  599. package/dist-es/utils/useValueEffect.js.map +1 -1
  600. package/dist-es/viewport/ViewportProvider.js +5 -5
  601. package/dist-es/viewport/ViewportProvider.js.map +1 -1
  602. package/dist-types/accordion/Accordion.d.ts +2 -2
  603. package/dist-types/accordion/AccordionContext.d.ts +1 -1
  604. package/dist-types/accordion/AccordionGroup.d.ts +1 -1
  605. package/dist-types/accordion/AccordionHeader.d.ts +1 -1
  606. package/dist-types/accordion/AccordionPanel.d.ts +1 -1
  607. package/dist-types/aria-announcer/AriaAnnounce.d.ts +1 -1
  608. package/dist-types/aria-announcer/AriaAnnouncerProvider.d.ts +2 -2
  609. package/dist-types/aria-announcer/useAriaAnnouncer.d.ts +1 -1
  610. package/dist-types/avatar/Avatar.d.ts +1 -1
  611. package/dist-types/avatar/useAvatarImage.d.ts +1 -1
  612. package/dist-types/badge/Badge.d.ts +1 -1
  613. package/dist-types/banner/Banner.d.ts +2 -2
  614. package/dist-types/banner/BannerActions.d.ts +1 -1
  615. package/dist-types/banner/BannerContent.d.ts +1 -1
  616. package/dist-types/border-item/BorderItem.d.ts +3 -3
  617. package/dist-types/border-layout/BorderLayout.d.ts +4 -4
  618. package/dist-types/breakpoints/BreakpointProvider.d.ts +3 -3
  619. package/dist-types/button/Button.d.ts +1 -1
  620. package/dist-types/button/useButton.d.ts +1 -1
  621. package/dist-types/card/Card.d.ts +1 -1
  622. package/dist-types/checkbox/Checkbox.d.ts +2 -2
  623. package/dist-types/checkbox/CheckboxGroup.d.ts +2 -2
  624. package/dist-types/checkbox/CheckboxIcon.d.ts +1 -1
  625. package/dist-types/checkbox/internal/CheckboxGroupContext.d.ts +2 -2
  626. package/dist-types/combo-box/ComboBox.d.ts +4 -4
  627. package/dist-types/combo-box/useComboBox.d.ts +3 -3
  628. package/dist-types/dialog/Dialog.d.ts +4 -4
  629. package/dist-types/dialog/DialogActions.d.ts +1 -1
  630. package/dist-types/dialog/DialogCloseButton.d.ts +1 -1
  631. package/dist-types/dialog/DialogContent.d.ts +1 -1
  632. package/dist-types/dialog/DialogHeader.d.ts +2 -2
  633. package/dist-types/divider/Divider.d.ts +1 -1
  634. package/dist-types/drawer/Drawer.d.ts +1 -1
  635. package/dist-types/drawer/DrawerCloseButton.d.ts +1 -1
  636. package/dist-types/dropdown/Dropdown.d.ts +4 -4
  637. package/dist-types/file-drop-zone/FileDropZone.d.ts +2 -2
  638. package/dist-types/file-drop-zone/FileDropZoneIcon.d.ts +2 -2
  639. package/dist-types/file-drop-zone/FileDropZoneTrigger.d.ts +1 -1
  640. package/dist-types/file-drop-zone/internal/utils.d.ts +1 -1
  641. package/dist-types/flex-item/FlexItem.d.ts +2 -2
  642. package/dist-types/flex-layout/FlexLayout.d.ts +2 -2
  643. package/dist-types/flow-layout/FlowLayout.d.ts +3 -3
  644. package/dist-types/form-field/FormField.d.ts +2 -2
  645. package/dist-types/form-field/FormFieldHelperText.d.ts +2 -2
  646. package/dist-types/form-field/FormFieldLabel.d.ts +2 -2
  647. package/dist-types/form-field-context/useFormFieldProps.d.ts +1 -1
  648. package/dist-types/grid-item/GridItem.d.ts +2 -2
  649. package/dist-types/grid-layout/GridLayout.d.ts +2 -2
  650. package/dist-types/input/Input.d.ts +1 -1
  651. package/dist-types/interactable-card/InteractableCard.d.ts +2 -2
  652. package/dist-types/interactable-card/InteractableCardGroup.d.ts +2 -2
  653. package/dist-types/interactable-card/InteractableCardGroupContext.d.ts +1 -1
  654. package/dist-types/interactable-card/useInteractableCard.d.ts +1 -1
  655. package/dist-types/link/Link.d.ts +3 -3
  656. package/dist-types/link-card/LinkCard.d.ts +1 -1
  657. package/dist-types/list-box/ListBox.d.ts +2 -2
  658. package/dist-types/list-control/ListControlContext.d.ts +1 -1
  659. package/dist-types/list-control/ListControlState.d.ts +2 -2
  660. package/dist-types/menu/Menu.d.ts +2 -2
  661. package/dist-types/menu/MenuBase.d.ts +4 -4
  662. package/dist-types/menu/MenuContext.d.ts +3 -3
  663. package/dist-types/menu/MenuGroup.d.ts +1 -1
  664. package/dist-types/menu/MenuItem.d.ts +1 -1
  665. package/dist-types/menu/MenuPanel.d.ts +1 -1
  666. package/dist-types/menu/MenuPanelBase.d.ts +1 -1
  667. package/dist-types/menu/MenuPanelContext.d.ts +1 -1
  668. package/dist-types/menu/MenuTrigger.d.ts +2 -2
  669. package/dist-types/multiline-input/MultilineInput.d.ts +1 -1
  670. package/dist-types/navigation-item/ExpansionIcon.d.ts +12 -2
  671. package/dist-types/navigation-item/NavigationItem.d.ts +6 -1
  672. package/dist-types/navigation-item/NavigationItemAction.d.ts +5 -0
  673. package/dist-types/option/Option.d.ts +1 -1
  674. package/dist-types/option/OptionGroup.d.ts +1 -1
  675. package/dist-types/option/OptionList.d.ts +1 -1
  676. package/dist-types/option/OptionListBase.d.ts +1 -1
  677. package/dist-types/overlay/Overlay.d.ts +2 -2
  678. package/dist-types/overlay/OverlayContext.d.ts +4 -3
  679. package/dist-types/overlay/OverlayPanel.d.ts +1 -1
  680. package/dist-types/overlay/OverlayPanelCloseButton.d.ts +1 -1
  681. package/dist-types/overlay/OverlayPanelContent.d.ts +1 -1
  682. package/dist-types/overlay/OverlayTrigger.d.ts +2 -2
  683. package/dist-types/pagination/CompactInput.d.ts +1 -1
  684. package/dist-types/pagination/GoToInput.d.ts +1 -1
  685. package/dist-types/pagination/PageRanges.d.ts +1 -1
  686. package/dist-types/pagination/Pagination.d.ts +1 -1
  687. package/dist-types/pagination/PaginationContext.d.ts +1 -1
  688. package/dist-types/pagination/Paginator.d.ts +1 -1
  689. package/dist-types/panel/Panel.d.ts +1 -1
  690. package/dist-types/parent-child-layout/ParentChildLayout.d.ts +2 -2
  691. package/dist-types/parent-child-layout/useIsViewportLargerThanBreakpoint.d.ts +1 -1
  692. package/dist-types/pill/Pill.d.ts +1 -1
  693. package/dist-types/pill-input/PillInput.d.ts +1 -1
  694. package/dist-types/progress/CircularProgress/CircularProgress.d.ts +1 -1
  695. package/dist-types/progress/LinearProgress/LinearProgress.d.ts +5 -3
  696. package/dist-types/radio-button/RadioButton.d.ts +2 -2
  697. package/dist-types/radio-button/RadioButtonGroup.d.ts +1 -1
  698. package/dist-types/radio-button/RadioButtonIcon.d.ts +3 -3
  699. package/dist-types/radio-button/internal/RadioGroupContext.d.ts +2 -2
  700. package/dist-types/salt-provider/SaltProvider.d.ts +84 -22
  701. package/dist-types/scrim/Scrim.d.ts +1 -1
  702. package/dist-types/segmented-button-group/SegmentedButtonGroup.d.ts +1 -1
  703. package/dist-types/spinner/Spinner.d.ts +1 -1
  704. package/dist-types/spinner/svgSpinners/SpinnerSVG.d.ts +4 -4
  705. package/dist-types/split-layout/SplitLayout.d.ts +3 -3
  706. package/dist-types/stack-layout/StackLayout.d.ts +3 -3
  707. package/dist-types/status-adornment/ErrorAdornment.d.ts +1 -1
  708. package/dist-types/status-adornment/StatusAdornment.d.ts +2 -2
  709. package/dist-types/status-adornment/SuccessAdornment.d.ts +1 -1
  710. package/dist-types/status-adornment/WarningAdornment.d.ts +1 -1
  711. package/dist-types/status-indicator/StatusIndicator.d.ts +2 -2
  712. package/dist-types/switch/Switch.d.ts +1 -1
  713. package/dist-types/tag/Tag.d.ts +1 -1
  714. package/dist-types/text/Code.d.ts +1 -1
  715. package/dist-types/text/Display.d.ts +1 -1
  716. package/dist-types/text/Headings.d.ts +1 -1
  717. package/dist-types/text/Label.d.ts +1 -1
  718. package/dist-types/text/Text.d.ts +3 -3
  719. package/dist-types/text/TextAction.d.ts +1 -1
  720. package/dist-types/text/TextNotation.d.ts +1 -1
  721. package/dist-types/theme/Accent.d.ts +5 -1
  722. package/dist-types/theme/ActionFont.d.ts +5 -1
  723. package/dist-types/theme/Corner.d.ts +5 -1
  724. package/dist-types/theme/HeadingFont.d.ts +5 -1
  725. package/dist-types/toast/Toast.d.ts +3 -3
  726. package/dist-types/toast/ToastContent.d.ts +1 -1
  727. package/dist-types/toggle-button/ToggleButton.d.ts +1 -1
  728. package/dist-types/toggle-button-group/ToggleButtonGroup.d.ts +2 -2
  729. package/dist-types/toggle-button-group/ToggleButtonGroupContext.d.ts +1 -1
  730. package/dist-types/tooltip/Tooltip.d.ts +3 -3
  731. package/dist-types/tooltip/TooltipBase.d.ts +4 -4
  732. package/dist-types/tooltip/useTooltip.d.ts +2 -2
  733. package/dist-types/utils/createContext.d.ts +1 -1
  734. package/dist-types/utils/getRefFromChildren.d.ts +2 -0
  735. package/dist-types/utils/index.d.ts +2 -0
  736. package/dist-types/utils/inferElementType.d.ts +1 -1
  737. package/dist-types/utils/marginMiddleware.d.ts +1 -1
  738. package/dist-types/utils/polymorphicTypes.d.ts +1 -1
  739. package/dist-types/utils/renderProps.d.ts +5 -0
  740. package/dist-types/utils/setRef.d.ts +1 -1
  741. package/dist-types/utils/useControlled.d.ts +1 -1
  742. package/dist-types/utils/useFloatingUI/useFloatingUI.d.ts +4 -4
  743. package/dist-types/utils/useForkRef.d.ts +1 -1
  744. package/dist-types/utils/useIsFocusVisible.d.ts +1 -1
  745. package/dist-types/utils/useIsomorphicLayoutEffect.d.ts +2 -2
  746. package/dist-types/utils/usePrevious.d.ts +1 -1
  747. package/dist-types/utils/useResizeObserver.d.ts +1 -1
  748. package/dist-types/utils/useResponsiveProp.d.ts +1 -1
  749. package/dist-types/utils/useValueEffect.d.ts +1 -1
  750. package/dist-types/viewport/ViewportProvider.d.ts +2 -2
  751. package/package.json +2 -2
  752. package/dist-cjs/navigation-item/ConditionalWrapper.js +0 -35
  753. package/dist-cjs/navigation-item/ConditionalWrapper.js.map +0 -1
  754. package/dist-es/navigation-item/ConditionalWrapper.js +0 -31
  755. package/dist-es/navigation-item/ConditionalWrapper.js.map +0 -1
  756. package/dist-types/navigation-item/ConditionalWrapper.d.ts +0 -8
package/dist-cjs/index.js CHANGED
@@ -125,6 +125,7 @@ var makePrefixer = require('./utils/makePrefixer.js');
125
125
  var marginMiddleware = require('./utils/marginMiddleware.js');
126
126
  var ownerDocument = require('./utils/ownerDocument.js');
127
127
  var ownerWindow = require('./utils/ownerWindow.js');
128
+ var renderProps = require('./utils/renderProps.js');
128
129
  var setRef = require('./utils/setRef.js');
129
130
  var useControlled = require('./utils/useControlled.js');
130
131
  var useFloatingUI = require('./utils/useFloatingUI/useFloatingUI.js');
@@ -138,6 +139,7 @@ var mergeProps = require('./utils/mergeProps.js');
138
139
  var useValueEffect = require('./utils/useValueEffect.js');
139
140
  var useResizeObserver = require('./utils/useResizeObserver.js');
140
141
  var useEventCallback = require('./utils/useEventCallback.js');
142
+ var getRefFromChildren = require('./utils/getRefFromChildren.js');
141
143
  var ViewportProvider = require('./viewport/ViewportProvider.js');
142
144
 
143
145
 
@@ -256,12 +258,16 @@ exports.H4 = Headings.H4;
256
258
  exports.Label = Label.Label;
257
259
  exports.TextAction = TextAction.TextAction;
258
260
  exports.TextNotation = TextNotation.TextNotation;
261
+ exports.AccentValues = Accent.AccentValues;
259
262
  exports.UNSTABLE_AccentValues = Accent.UNSTABLE_AccentValues;
263
+ exports.ActionFontValues = ActionFont.ActionFontValues;
260
264
  exports.UNSTABLE_ActionFontValues = ActionFont.UNSTABLE_ActionFontValues;
261
265
  exports.DensityValues = Density.DensityValues;
266
+ exports.HeadingFontValues = HeadingFont.HeadingFontValues;
262
267
  exports.UNSTABLE_HeadingFontValues = HeadingFont.UNSTABLE_HeadingFontValues;
263
268
  exports.getCharacteristicValue = Theme.getCharacteristicValue;
264
269
  exports.ModeValues = Mode.ModeValues;
270
+ exports.CornerValues = Corner.CornerValues;
265
271
  exports.UNSTABLE_CornerValues = Corner.UNSTABLE_CornerValues;
266
272
  exports.Toast = Toast.Toast;
267
273
  exports.ToastContent = ToastContent.ToastContent;
@@ -269,6 +275,7 @@ exports.BreakpointContext = SaltProvider.BreakpointContext;
269
275
  exports.DEFAULT_DENSITY = SaltProvider.DEFAULT_DENSITY;
270
276
  exports.DensityContext = SaltProvider.DensityContext;
271
277
  exports.SaltProvider = SaltProvider.SaltProvider;
278
+ exports.SaltProviderNext = SaltProvider.SaltProviderNext;
272
279
  exports.ThemeContext = SaltProvider.ThemeContext;
273
280
  exports.UNSTABLE_SaltProviderNext = SaltProvider.UNSTABLE_SaltProviderNext;
274
281
  exports.useBreakpoints = SaltProvider.useBreakpoints;
@@ -290,6 +297,7 @@ exports.makePrefixer = makePrefixer.makePrefixer;
290
297
  exports.margin = marginMiddleware.margin;
291
298
  exports.ownerDocument = ownerDocument.ownerDocument;
292
299
  exports.ownerWindow = ownerWindow.ownerWindow;
300
+ exports.renderProps = renderProps.renderProps;
293
301
  exports.setRef = setRef.setRef;
294
302
  exports.useControlled = useControlled.useControlled;
295
303
  exports.DEFAULT_FLOATING_UI_MIDDLEWARE = useFloatingUI.DEFAULT_FLOATING_UI_MIDDLEWARE;
@@ -314,6 +322,7 @@ exports.mergeProps = mergeProps.mergeProps;
314
322
  exports.useValueEffect = useValueEffect.useValueEffect;
315
323
  exports.useResizeObserver = useResizeObserver.useResizeObserver;
316
324
  exports.useEventCallback = useEventCallback.useEventCallback;
325
+ exports.getRefFromChildren = getRefFromChildren.getRefFromChildren;
317
326
  exports.ViewportContext = ViewportProvider.ViewportContext;
318
327
  exports.ViewportProvider = ViewportProvider.ViewportProvider;
319
328
  exports.useViewport = ViewportProvider.useViewport;
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -3,12 +3,13 @@
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
- var clsx = require('clsx');
7
- var React = require('react');
8
6
  var styles = require('@salt-ds/styles');
9
7
  var window = require('@salt-ds/window');
8
+ var clsx = require('clsx');
9
+ var React = require('react');
10
10
  require('../form-field-context/FormFieldContext.js');
11
11
  var useFormFieldProps = require('../form-field-context/useFormFieldProps.js');
12
+ var StatusAdornment = require('../status-adornment/StatusAdornment.js');
12
13
  var makePrefixer = require('../utils/makePrefixer.js');
13
14
  var useControlled = require('../utils/useControlled.js');
14
15
  require('../utils/useFloatingUI/useFloatingUI.js');
@@ -68,12 +69,12 @@ require('../link/Link.js');
68
69
  require('../link-card/LinkCard.js');
69
70
  require('../list-box/ListBox.js');
70
71
  require('../list-control/ListControlContext.js');
71
- require('../menu/MenuContext.js');
72
72
  require('@floating-ui/react');
73
+ require('../menu/MenuContext.js');
73
74
  require('../menu/MenuItem.js');
74
75
  require('../menu/MenuPanel.js');
75
- require('../menu/MenuTriggerContext.js');
76
76
  require('../menu/MenuPanelContext.js');
77
+ require('../menu/MenuTriggerContext.js');
77
78
  require('../menu/MenuGroup.js');
78
79
  require('../multiline-input/MultilineInput.js');
79
80
  require('../navigation-item/NavigationItem.js');
@@ -99,7 +100,6 @@ require('../scrim/Scrim.js');
99
100
  require('../segmented-button-group/SegmentedButtonGroup.js');
100
101
  require('../spinner/Spinner.js');
101
102
  require('../stack-layout/StackLayout.js');
102
- var StatusAdornment = require('../status-adornment/StatusAdornment.js');
103
103
  require('../toast/Toast.js');
104
104
  require('../toast/ToastContent.js');
105
105
  require('../split-layout/SplitLayout.js');
@@ -1 +1 @@
1
- {"version":3,"file":"Input.js","sources":["../src/input/Input.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport {\n ChangeEvent,\n ComponentPropsWithoutRef,\n FocusEvent,\n forwardRef,\n InputHTMLAttributes,\n ReactNode,\n Ref,\n useState,\n} from \"react\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useFormFieldProps } from \"../form-field-context\";\nimport { makePrefixer, useControlled } from \"../utils\";\nimport { StatusAdornment } from \"../status-adornment\";\n\nimport inputCss from \"./Input.css\";\n\nconst withBaseName = makePrefixer(\"saltInput\");\n\nexport interface InputProps\n extends Omit<ComponentPropsWithoutRef<\"div\">, \"defaultValue\">,\n Pick<\n ComponentPropsWithoutRef<\"input\">,\n \"disabled\" | \"value\" | \"defaultValue\" | \"placeholder\"\n > {\n /**\n * The marker to use in an empty read only Input.\n * Use `''` to disable this feature. Defaults to '—'.\n */\n emptyReadOnlyMarker?: string;\n /**\n * End adornment component\n */\n endAdornment?: ReactNode;\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps?: InputHTMLAttributes<HTMLInputElement>;\n /**\n * Optional ref for the input component\n */\n inputRef?: Ref<HTMLInputElement>;\n /**\n * If `true`, the component is read only.\n */\n readOnly?: boolean;\n /**\n * Start adornment component\n */\n startAdornment?: ReactNode;\n /**\n * Alignment of text within container. Defaults to \"left\"\n */\n textAlign?: \"left\" | \"center\" | \"right\";\n /**\n * Validation status.\n */\n validationStatus?: \"error\" | \"warning\" | \"success\";\n /**\n * Styling variant. Defaults to \"primary\".\n */\n variant?: \"primary\" | \"secondary\";\n /** Styling variant with full border. Defaults to false\n */\n bordered?: boolean;\n}\n\nexport const Input = forwardRef<HTMLDivElement, InputProps>(function Input(\n {\n \"aria-activedescendant\": ariaActiveDescendant,\n \"aria-expanded\": ariaExpanded,\n \"aria-owns\": ariaOwns,\n className: classNameProp,\n disabled,\n emptyReadOnlyMarker = \"—\",\n endAdornment,\n id,\n inputProps = {},\n inputRef,\n placeholder,\n readOnly: readOnlyProp,\n role,\n startAdornment,\n style,\n textAlign = \"left\",\n value: valueProp,\n defaultValue: defaultValueProp = valueProp === undefined ? \"\" : undefined,\n validationStatus: validationStatusProp,\n variant = \"primary\",\n bordered = false,\n ...other\n },\n ref\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-input\",\n css: inputCss,\n window: targetWindow,\n });\n\n const {\n a11yProps: {\n \"aria-describedby\": formFieldDescribedBy,\n \"aria-labelledby\": formFieldLabelledBy,\n } = {},\n disabled: formFieldDisabled,\n readOnly: formFieldReadOnly,\n necessity: formFieldRequired,\n validationStatus: formFieldValidationStatus,\n } = useFormFieldProps();\n\n const restA11yProps = {\n \"aria-activedescendant\": ariaActiveDescendant,\n \"aria-expanded\": ariaExpanded,\n \"aria-owns\": ariaOwns,\n };\n\n const isDisabled = disabled || formFieldDisabled;\n const isReadOnly = readOnlyProp || formFieldReadOnly;\n const validationStatus = formFieldValidationStatus ?? validationStatusProp;\n\n const [focused, setFocused] = useState(false);\n\n const isEmptyReadOnly = isReadOnly && !defaultValueProp && !valueProp;\n const defaultValue = isEmptyReadOnly ? emptyReadOnlyMarker : defaultValueProp;\n\n const {\n \"aria-describedby\": inputDescribedBy,\n \"aria-labelledby\": inputLabelledBy,\n onBlur,\n onChange,\n onFocus,\n required: inputPropsRequired,\n ...restInputProps\n } = inputProps;\n\n const isRequired = formFieldRequired\n ? [\"required\", \"asterisk\"].includes(formFieldRequired)\n : inputPropsRequired;\n\n const [value, setValue] = useControlled({\n controlled: valueProp,\n default: defaultValue,\n name: \"Input\",\n state: \"value\",\n });\n\n const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n const value = event.target.value;\n setValue(value);\n onChange?.(event);\n };\n\n const handleBlur = (event: FocusEvent<HTMLInputElement>) => {\n onBlur?.(event);\n setFocused(false);\n };\n\n const handleFocus = (event: FocusEvent<HTMLInputElement>) => {\n onFocus?.(event);\n setFocused(true);\n };\n\n const inputStyle = {\n \"--input-textAlign\": textAlign,\n ...style,\n };\n\n return (\n <div\n className={clsx(\n withBaseName(),\n withBaseName(variant),\n {\n [withBaseName(\"focused\")]: !isDisabled && focused,\n [withBaseName(\"disabled\")]: isDisabled,\n [withBaseName(\"readOnly\")]: isReadOnly,\n [withBaseName(validationStatus || \"\")]: validationStatus,\n [withBaseName(\"bordered\")]: bordered,\n },\n classNameProp\n )}\n ref={ref}\n style={inputStyle}\n {...other}\n >\n {startAdornment && (\n <div className={withBaseName(\"startAdornmentContainer\")}>\n {startAdornment}\n </div>\n )}\n <input\n aria-describedby={clsx(formFieldDescribedBy, inputDescribedBy)}\n aria-labelledby={clsx(formFieldLabelledBy, inputLabelledBy)}\n className={clsx(withBaseName(\"input\"), inputProps?.className)}\n disabled={isDisabled}\n id={id}\n readOnly={isReadOnly}\n ref={inputRef}\n role={role}\n tabIndex={isDisabled ? -1 : 0}\n onBlur={handleBlur}\n onChange={handleChange}\n onFocus={!isDisabled ? handleFocus : undefined}\n placeholder={placeholder}\n value={value}\n {...restA11yProps}\n {...restInputProps}\n required={isRequired}\n />\n {!isDisabled && validationStatus && (\n <StatusAdornment status={validationStatus} />\n )}\n {endAdornment && (\n <div className={withBaseName(\"endAdornmentContainer\")}>\n {endAdornment}\n </div>\n )}\n <div className={withBaseName(\"activationIndicator\")} />\n </div>\n );\n});\n"],"names":["makePrefixer","forwardRef","Input","useWindow","useComponentCssInjection","inputCss","useFormFieldProps","useState","useControlled","value","jsxs","clsx","jsx","StatusAdornment"],"mappings":"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"}
1
+ {"version":3,"file":"Input.js","sources":["../src/input/Input.tsx"],"sourcesContent":["import { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport {\n type ChangeEvent,\n type ComponentPropsWithoutRef,\n type FocusEvent,\n type InputHTMLAttributes,\n type ReactNode,\n type Ref,\n forwardRef,\n useState,\n} from \"react\";\nimport { useFormFieldProps } from \"../form-field-context\";\nimport { StatusAdornment } from \"../status-adornment\";\nimport { makePrefixer, useControlled } from \"../utils\";\n\nimport inputCss from \"./Input.css\";\n\nconst withBaseName = makePrefixer(\"saltInput\");\n\nexport interface InputProps\n extends Omit<ComponentPropsWithoutRef<\"div\">, \"defaultValue\">,\n Pick<\n ComponentPropsWithoutRef<\"input\">,\n \"disabled\" | \"value\" | \"defaultValue\" | \"placeholder\"\n > {\n /**\n * The marker to use in an empty read only Input.\n * Use `''` to disable this feature. Defaults to '—'.\n */\n emptyReadOnlyMarker?: string;\n /**\n * End adornment component\n */\n endAdornment?: ReactNode;\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps?: InputHTMLAttributes<HTMLInputElement>;\n /**\n * Optional ref for the input component\n */\n inputRef?: Ref<HTMLInputElement>;\n /**\n * If `true`, the component is read only.\n */\n readOnly?: boolean;\n /**\n * Start adornment component\n */\n startAdornment?: ReactNode;\n /**\n * Alignment of text within container. Defaults to \"left\"\n */\n textAlign?: \"left\" | \"center\" | \"right\";\n /**\n * Validation status.\n */\n validationStatus?: \"error\" | \"warning\" | \"success\";\n /**\n * Styling variant. Defaults to \"primary\".\n */\n variant?: \"primary\" | \"secondary\";\n /** Styling variant with full border. Defaults to false\n */\n bordered?: boolean;\n}\n\nexport const Input = forwardRef<HTMLDivElement, InputProps>(function Input(\n {\n \"aria-activedescendant\": ariaActiveDescendant,\n \"aria-expanded\": ariaExpanded,\n \"aria-owns\": ariaOwns,\n className: classNameProp,\n disabled,\n emptyReadOnlyMarker = \"—\",\n endAdornment,\n id,\n inputProps = {},\n inputRef,\n placeholder,\n readOnly: readOnlyProp,\n role,\n startAdornment,\n style,\n textAlign = \"left\",\n value: valueProp,\n defaultValue: defaultValueProp = valueProp === undefined ? \"\" : undefined,\n validationStatus: validationStatusProp,\n variant = \"primary\",\n bordered = false,\n ...other\n },\n ref,\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-input\",\n css: inputCss,\n window: targetWindow,\n });\n\n const {\n a11yProps: {\n \"aria-describedby\": formFieldDescribedBy,\n \"aria-labelledby\": formFieldLabelledBy,\n } = {},\n disabled: formFieldDisabled,\n readOnly: formFieldReadOnly,\n necessity: formFieldRequired,\n validationStatus: formFieldValidationStatus,\n } = useFormFieldProps();\n\n const restA11yProps = {\n \"aria-activedescendant\": ariaActiveDescendant,\n \"aria-expanded\": ariaExpanded,\n \"aria-owns\": ariaOwns,\n };\n\n const isDisabled = disabled || formFieldDisabled;\n const isReadOnly = readOnlyProp || formFieldReadOnly;\n const validationStatus = formFieldValidationStatus ?? validationStatusProp;\n\n const [focused, setFocused] = useState(false);\n\n const isEmptyReadOnly = isReadOnly && !defaultValueProp && !valueProp;\n const defaultValue = isEmptyReadOnly ? emptyReadOnlyMarker : defaultValueProp;\n\n const {\n \"aria-describedby\": inputDescribedBy,\n \"aria-labelledby\": inputLabelledBy,\n onBlur,\n onChange,\n onFocus,\n required: inputPropsRequired,\n ...restInputProps\n } = inputProps;\n\n const isRequired = formFieldRequired\n ? [\"required\", \"asterisk\"].includes(formFieldRequired)\n : inputPropsRequired;\n\n const [value, setValue] = useControlled({\n controlled: valueProp,\n default: defaultValue,\n name: \"Input\",\n state: \"value\",\n });\n\n const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n const value = event.target.value;\n setValue(value);\n onChange?.(event);\n };\n\n const handleBlur = (event: FocusEvent<HTMLInputElement>) => {\n onBlur?.(event);\n setFocused(false);\n };\n\n const handleFocus = (event: FocusEvent<HTMLInputElement>) => {\n onFocus?.(event);\n setFocused(true);\n };\n\n const inputStyle = {\n \"--input-textAlign\": textAlign,\n ...style,\n };\n\n return (\n <div\n className={clsx(\n withBaseName(),\n withBaseName(variant),\n {\n [withBaseName(\"focused\")]: !isDisabled && focused,\n [withBaseName(\"disabled\")]: isDisabled,\n [withBaseName(\"readOnly\")]: isReadOnly,\n [withBaseName(validationStatus || \"\")]: validationStatus,\n [withBaseName(\"bordered\")]: bordered,\n },\n classNameProp,\n )}\n ref={ref}\n style={inputStyle}\n {...other}\n >\n {startAdornment && (\n <div className={withBaseName(\"startAdornmentContainer\")}>\n {startAdornment}\n </div>\n )}\n <input\n aria-describedby={clsx(formFieldDescribedBy, inputDescribedBy)}\n aria-labelledby={clsx(formFieldLabelledBy, inputLabelledBy)}\n className={clsx(withBaseName(\"input\"), inputProps?.className)}\n disabled={isDisabled}\n id={id}\n readOnly={isReadOnly}\n ref={inputRef}\n role={role}\n tabIndex={isDisabled ? -1 : 0}\n onBlur={handleBlur}\n onChange={handleChange}\n onFocus={!isDisabled ? handleFocus : undefined}\n placeholder={placeholder}\n value={value}\n {...restA11yProps}\n {...restInputProps}\n required={isRequired}\n />\n {!isDisabled && validationStatus && (\n <StatusAdornment status={validationStatus} />\n )}\n {endAdornment && (\n <div className={withBaseName(\"endAdornmentContainer\")}>\n {endAdornment}\n </div>\n )}\n <div className={withBaseName(\"activationIndicator\")} />\n </div>\n );\n});\n"],"names":["makePrefixer","forwardRef","Input","useWindow","useComponentCssInjection","inputCss","useFormFieldProps","useState","useControlled","value","jsxs","clsx","jsx","StatusAdornment"],"mappings":"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"}
@@ -3,10 +3,10 @@
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
- var React = require('react');
7
- var clsx = require('clsx');
8
- var window = require('@salt-ds/window');
9
6
  var styles = require('@salt-ds/styles');
7
+ var window = require('@salt-ds/window');
8
+ var clsx = require('clsx');
9
+ var React = require('react');
10
10
  var capitalize = require('../utils/capitalize.js');
11
11
  var makePrefixer = require('../utils/makePrefixer.js');
12
12
  var useControlled = require('../utils/useControlled.js');
@@ -51,6 +51,7 @@ require('../flex-item/FlexItem.js');
51
51
  require('../flex-layout/FlexLayout.js');
52
52
  require('../flow-layout/FlowLayout.js');
53
53
  require('../form-field/FormField.js');
54
+ require('../form-field-context/FormFieldContext.js');
54
55
  require('../status-indicator/StatusIndicator.js');
55
56
  require('../text/Text.js');
56
57
  require('../text/Code.js');
@@ -59,7 +60,6 @@ require('../text/Headings.js');
59
60
  require('../text/Label.js');
60
61
  require('../text/TextAction.js');
61
62
  require('../text/TextNotation.js');
62
- require('../form-field-context/FormFieldContext.js');
63
63
  require('../grid-item/GridItem.js');
64
64
  require('../grid-layout/GridLayout.js');
65
65
  require('../input/Input.js');
@@ -69,12 +69,12 @@ require('../link/Link.js');
69
69
  require('../link-card/LinkCard.js');
70
70
  require('../list-box/ListBox.js');
71
71
  require('../list-control/ListControlContext.js');
72
- require('../menu/MenuContext.js');
73
72
  require('@floating-ui/react');
73
+ require('../menu/MenuContext.js');
74
74
  require('../menu/MenuItem.js');
75
75
  require('../menu/MenuPanel.js');
76
- require('../menu/MenuTriggerContext.js');
77
76
  require('../menu/MenuPanelContext.js');
77
+ require('../menu/MenuTriggerContext.js');
78
78
  require('../menu/MenuGroup.js');
79
79
  require('../multiline-input/MultilineInput.js');
80
80
  require('../navigation-item/NavigationItem.js');
@@ -110,8 +110,8 @@ require('../toggle-button/ToggleButton.js');
110
110
  require('../toggle-button-group/ToggleButtonGroup.js');
111
111
  require('../toggle-button-group/ToggleButtonGroupContext.js');
112
112
  require('../tooltip/Tooltip.js');
113
- var useInteractableCard = require('./useInteractableCard.js');
114
113
  var InteractableCard$1 = require('./InteractableCard.css.js');
114
+ var useInteractableCard = require('./useInteractableCard.js');
115
115
 
116
116
  const withBaseName = makePrefixer.makePrefixer("saltInteractableCard");
117
117
  const InteractableCard = React.forwardRef(function InteractableCard2(props, ref) {
@@ -146,8 +146,8 @@ const InteractableCard = React.forwardRef(function InteractableCard2(props, ref)
146
146
  state: "selected"
147
147
  });
148
148
  const role = interactableCardGroup ? interactableCardGroup.multiSelect ? "checkbox" : "radio" : "button";
149
- const isMultiselect = interactableCardGroup && interactableCardGroup.multiSelect;
150
- const isFirstChild = interactableCardGroup && interactableCardGroup.isFirstChild(value);
149
+ const isMultiselect = interactableCardGroup == null ? void 0 : interactableCardGroup.multiSelect;
150
+ const isFirstChild = interactableCardGroup == null ? void 0 : interactableCardGroup.isFirstChild(value);
151
151
  const ariaChecked = role === "radio" || role === "checkbox" ? selected : void 0;
152
152
  const accentValue = accent || accentPlacement;
153
153
  const handleClick = (event) => {
@@ -1 +1 @@
1
- {"version":3,"file":"InteractableCard.js","sources":["../src/interactable-card/InteractableCard.tsx"],"sourcesContent":["import {\n forwardRef,\n MouseEvent,\n ComponentPropsWithoutRef,\n SyntheticEvent,\n useRef,\n} from \"react\";\nimport { clsx } from \"clsx\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { capitalize, makePrefixer, useControlled, useForkRef } from \"../utils\";\nimport { useInteractableCard } from \"./useInteractableCard\";\nimport interactableCardCss from \"./InteractableCard.css\";\nimport {\n InteractableCardValue,\n useInteractableCardGroup,\n} from \"./InteractableCardGroupContext\";\n\nconst withBaseName = makePrefixer(\"saltInteractableCard\");\n\nexport interface InteractableCardProps extends ComponentPropsWithoutRef<\"div\"> {\n /**\n * Accent border position: defaults to \"bottom\"\n */\n accent?: \"bottom\" | \"top\" | \"left\" | \"right\";\n /**\n * @deprecated Use the `accent` prop instead\n */\n accentPlacement?: \"bottom\" | \"top\" | \"left\" | \"right\";\n /**\n * If `true`, the card will be disabled.\n */\n disabled?: boolean;\n /**\n * Callback fired when the selection changes.\n * @param event\n */\n onChange?: (event: SyntheticEvent<HTMLDivElement>) => void;\n /**\n * Styling variant; defaults to \"primary\".\n */\n variant?: \"primary\" | \"secondary\";\n /**\n * Value of card (for selectable use case).\n */\n value?: InteractableCardValue;\n}\n\nexport const InteractableCard = forwardRef<\n HTMLDivElement,\n InteractableCardProps\n>(function InteractableCard(props, ref) {\n const {\n accent,\n accentPlacement,\n children,\n className,\n disabled: disabledProp,\n variant = \"primary\",\n value,\n onBlur,\n onChange,\n onClick,\n onKeyUp,\n onKeyDown,\n ...rest\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-interactable-card\",\n css: interactableCardCss,\n window: targetWindow,\n });\n\n const interactableCardGroup = useInteractableCardGroup();\n\n const interactableCardGroupSelected =\n interactableCardGroup?.isSelected(value);\n\n const disabled = interactableCardGroup?.disabled || disabledProp;\n\n const [selected, setSelected] = useControlled({\n controlled: interactableCardGroupSelected,\n default: Boolean(false),\n name: \"InteractableCard\",\n state: \"selected\",\n });\n\n const role = interactableCardGroup\n ? interactableCardGroup.multiSelect\n ? \"checkbox\"\n : \"radio\"\n : \"button\";\n\n const isMultiselect =\n interactableCardGroup && interactableCardGroup.multiSelect;\n\n const isFirstChild =\n interactableCardGroup && interactableCardGroup.isFirstChild(value);\n\n const ariaChecked =\n role === \"radio\" || role === \"checkbox\" ? selected : undefined;\n\n const accentValue = accent || accentPlacement;\n\n const handleClick = (event: MouseEvent<HTMLDivElement>) => {\n if (interactableCardGroup && !disabled) {\n interactableCardGroup.select(event, value);\n setSelected(!selected);\n }\n onChange?.(event);\n onClick?.(event);\n };\n\n let tabIndex;\n\n if (interactableCardGroup) {\n if (disabled) {\n tabIndex = -1;\n } else if (isMultiselect) {\n tabIndex = 0; // All items focusable in multi-select\n } else {\n // Single select: Only selected or first item (if none are selected) is focusable\n tabIndex = selected ? 0 : -1;\n if (!interactableCardGroup.value && isFirstChild) {\n tabIndex = 0;\n }\n }\n } else {\n tabIndex = disabled ? -1 : 0;\n }\n\n const cardRef = useRef<HTMLDivElement>(null);\n const handleRef = useForkRef(ref, cardRef);\n\n const { active, cardProps } = useInteractableCard({\n disabled,\n onKeyUp,\n onKeyDown,\n onBlur,\n onClick,\n });\n\n return (\n <div\n {...cardProps}\n role={role}\n aria-checked={ariaChecked}\n aria-disabled={disabled}\n data-value={value}\n className={clsx(\n withBaseName(),\n withBaseName(variant),\n {\n [withBaseName(\"accent\")]: accentValue,\n [withBaseName(`accent${capitalize(accentValue ?? \"\")}`)]: accentValue,\n [withBaseName(\"active\")]: role === \"button\" && active,\n [withBaseName(\"disabled\")]: disabled,\n [withBaseName(\"selected\")]: selected,\n },\n className\n )}\n {...rest}\n onClick={handleClick}\n ref={handleRef}\n tabIndex={tabIndex}\n >\n {children}\n </div>\n );\n});\n"],"names":["makePrefixer","forwardRef","InteractableCard","useWindow","useComponentCssInjection","interactableCardCss","useInteractableCardGroup","useControlled","useRef","useForkRef","useInteractableCard","jsx","clsx","capitalize"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkBA,MAAM,YAAA,GAAeA,0BAAa,sBAAsB,CAAA,CAAA;AA8BjD,MAAM,gBAAmB,GAAAC,gBAAA,CAG9B,SAASC,iBAAAA,CAAiB,OAAO,GAAK,EAAA;AACtC,EAAM,MAAA;AAAA,IACJ,MAAA;AAAA,IACA,eAAA;AAAA,IACA,QAAA;AAAA,IACA,SAAA;AAAA,IACA,QAAU,EAAA,YAAA;AAAA,IACV,OAAU,GAAA,SAAA;AAAA,IACV,KAAA;AAAA,IACA,MAAA;AAAA,IACA,QAAA;AAAA,IACA,OAAA;AAAA,IACA,OAAA;AAAA,IACA,SAAA;AAAA,IACG,GAAA,IAAA;AAAA,GACD,GAAA,KAAA,CAAA;AAEJ,EAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,wBAAA;AAAA,IACR,GAAK,EAAAC,kBAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,MAAM,wBAAwBC,qDAAyB,EAAA,CAAA;AAEvD,EAAM,MAAA,6BAAA,GACJ,+DAAuB,UAAW,CAAA,KAAA,CAAA,CAAA;AAEpC,EAAM,MAAA,QAAA,GAAA,CAAW,+DAAuB,QAAY,KAAA,YAAA,CAAA;AAEpD,EAAA,MAAM,CAAC,QAAA,EAAU,WAAW,CAAA,GAAIC,2BAAc,CAAA;AAAA,IAC5C,UAAY,EAAA,6BAAA;AAAA,IACZ,OAAA,EAAS,QAAQ,KAAK,CAAA;AAAA,IACtB,IAAM,EAAA,kBAAA;AAAA,IACN,KAAO,EAAA,UAAA;AAAA,GACR,CAAA,CAAA;AAED,EAAA,MAAM,IAAO,GAAA,qBAAA,GACT,qBAAsB,CAAA,WAAA,GACpB,aACA,OACF,GAAA,QAAA,CAAA;AAEJ,EAAM,MAAA,aAAA,GACJ,yBAAyB,qBAAsB,CAAA,WAAA,CAAA;AAEjD,EAAA,MAAM,YACJ,GAAA,qBAAA,IAAyB,qBAAsB,CAAA,YAAA,CAAa,KAAK,CAAA,CAAA;AAEnE,EAAA,MAAM,WACJ,GAAA,IAAA,KAAS,OAAW,IAAA,IAAA,KAAS,aAAa,QAAW,GAAA,KAAA,CAAA,CAAA;AAEvD,EAAA,MAAM,cAAc,MAAU,IAAA,eAAA,CAAA;AAE9B,EAAM,MAAA,WAAA,GAAc,CAAC,KAAsC,KAAA;AACzD,IAAI,IAAA,qBAAA,IAAyB,CAAC,QAAU,EAAA;AACtC,MAAsB,qBAAA,CAAA,MAAA,CAAO,OAAO,KAAK,CAAA,CAAA;AACzC,MAAA,WAAA,CAAY,CAAC,QAAQ,CAAA,CAAA;AAAA,KACvB;AACA,IAAW,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAA,KAAA,CAAA,CAAA;AACX,IAAU,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,CAAA,KAAA,CAAA,CAAA;AAAA,GACZ,CAAA;AAEA,EAAI,IAAA,QAAA,CAAA;AAEJ,EAAA,IAAI,qBAAuB,EAAA;AACzB,IAAA,IAAI,QAAU,EAAA;AACZ,MAAW,QAAA,GAAA,CAAA,CAAA,CAAA;AAAA,eACF,aAAe,EAAA;AACxB,MAAW,QAAA,GAAA,CAAA,CAAA;AAAA,KACN,MAAA;AAEL,MAAA,QAAA,GAAW,WAAW,CAAI,GAAA,CAAA,CAAA,CAAA;AAC1B,MAAI,IAAA,CAAC,qBAAsB,CAAA,KAAA,IAAS,YAAc,EAAA;AAChD,QAAW,QAAA,GAAA,CAAA,CAAA;AAAA,OACb;AAAA,KACF;AAAA,GACK,MAAA;AACL,IAAA,QAAA,GAAW,WAAW,CAAK,CAAA,GAAA,CAAA,CAAA;AAAA,GAC7B;AAEA,EAAM,MAAA,OAAA,GAAUC,aAAuB,IAAI,CAAA,CAAA;AAC3C,EAAM,MAAA,SAAA,GAAYC,qBAAW,CAAA,GAAA,EAAK,OAAO,CAAA,CAAA;AAEzC,EAAA,MAAM,EAAE,MAAA,EAAQ,SAAU,EAAA,GAAIC,uCAAoB,CAAA;AAAA,IAChD,QAAA;AAAA,IACA,OAAA;AAAA,IACA,SAAA;AAAA,IACA,MAAA;AAAA,IACA,OAAA;AAAA,GACD,CAAA,CAAA;AAED,EAAA,uBACGC,cAAA,CAAA,KAAA,EAAA;AAAA,IACE,GAAG,SAAA;AAAA,IACJ,IAAA;AAAA,IACA,cAAc,EAAA,WAAA;AAAA,IACd,eAAe,EAAA,QAAA;AAAA,IACf,YAAY,EAAA,KAAA;AAAA,IACZ,SAAW,EAAAC,SAAA;AAAA,MACT,YAAa,EAAA;AAAA,MACb,aAAa,OAAO,CAAA;AAAA,MACpB;AAAA,QACE,CAAC,YAAa,CAAA,QAAQ,CAAI,GAAA,WAAA;AAAA,QAC1B,CAAC,YAAa,CAAA,CAAA,MAAA,EAASC,sBAAW,WAAe,IAAA,IAAA,GAAA,WAAA,GAAA,EAAE,GAAG,CAAI,GAAA,WAAA;AAAA,QAC1D,CAAC,YAAA,CAAa,QAAQ,CAAA,GAAI,SAAS,QAAY,IAAA,MAAA;AAAA,QAC/C,CAAC,YAAa,CAAA,UAAU,CAAI,GAAA,QAAA;AAAA,QAC5B,CAAC,YAAa,CAAA,UAAU,CAAI,GAAA,QAAA;AAAA,OAC9B;AAAA,MACA,SAAA;AAAA,KACF;AAAA,IACC,GAAG,IAAA;AAAA,IACJ,OAAS,EAAA,WAAA;AAAA,IACT,GAAK,EAAA,SAAA;AAAA,IACL,QAAA;AAAA,IAEC,QAAA;AAAA,GACH,CAAA,CAAA;AAEJ,CAAC;;;;"}
1
+ {"version":3,"file":"InteractableCard.js","sources":["../src/interactable-card/InteractableCard.tsx"],"sourcesContent":["import { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport {\n type ComponentPropsWithoutRef,\n type MouseEvent,\n type SyntheticEvent,\n forwardRef,\n useRef,\n} from \"react\";\nimport { capitalize, makePrefixer, useControlled, useForkRef } from \"../utils\";\nimport interactableCardCss from \"./InteractableCard.css\";\nimport {\n type InteractableCardValue,\n useInteractableCardGroup,\n} from \"./InteractableCardGroupContext\";\nimport { useInteractableCard } from \"./useInteractableCard\";\n\nconst withBaseName = makePrefixer(\"saltInteractableCard\");\n\nexport interface InteractableCardProps extends ComponentPropsWithoutRef<\"div\"> {\n /**\n * Accent border position: defaults to \"bottom\"\n */\n accent?: \"bottom\" | \"top\" | \"left\" | \"right\";\n /**\n * @deprecated Use the `accent` prop instead\n */\n accentPlacement?: \"bottom\" | \"top\" | \"left\" | \"right\";\n /**\n * If `true`, the card will be disabled.\n */\n disabled?: boolean;\n /**\n * Callback fired when the selection changes.\n * @param event\n */\n onChange?: (event: SyntheticEvent<HTMLDivElement>) => void;\n /**\n * Styling variant; defaults to \"primary\".\n */\n variant?: \"primary\" | \"secondary\";\n /**\n * Value of card (for selectable use case).\n */\n value?: InteractableCardValue;\n}\n\nexport const InteractableCard = forwardRef<\n HTMLDivElement,\n InteractableCardProps\n>(function InteractableCard(props, ref) {\n const {\n accent,\n accentPlacement,\n children,\n className,\n disabled: disabledProp,\n variant = \"primary\",\n value,\n onBlur,\n onChange,\n onClick,\n onKeyUp,\n onKeyDown,\n ...rest\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-interactable-card\",\n css: interactableCardCss,\n window: targetWindow,\n });\n\n const interactableCardGroup = useInteractableCardGroup();\n\n const interactableCardGroupSelected =\n interactableCardGroup?.isSelected(value);\n\n const disabled = interactableCardGroup?.disabled || disabledProp;\n\n const [selected, setSelected] = useControlled({\n controlled: interactableCardGroupSelected,\n default: Boolean(false),\n name: \"InteractableCard\",\n state: \"selected\",\n });\n\n const role = interactableCardGroup\n ? interactableCardGroup.multiSelect\n ? \"checkbox\"\n : \"radio\"\n : \"button\";\n\n const isMultiselect = interactableCardGroup?.multiSelect;\n\n const isFirstChild = interactableCardGroup?.isFirstChild(value);\n\n const ariaChecked =\n role === \"radio\" || role === \"checkbox\" ? selected : undefined;\n\n const accentValue = accent || accentPlacement;\n\n const handleClick = (event: MouseEvent<HTMLDivElement>) => {\n if (interactableCardGroup && !disabled) {\n interactableCardGroup.select(event, value);\n setSelected(!selected);\n }\n onChange?.(event);\n onClick?.(event);\n };\n\n let tabIndex: number;\n\n if (interactableCardGroup) {\n if (disabled) {\n tabIndex = -1;\n } else if (isMultiselect) {\n tabIndex = 0; // All items focusable in multi-select\n } else {\n // Single select: Only selected or first item (if none are selected) is focusable\n tabIndex = selected ? 0 : -1;\n if (!interactableCardGroup.value && isFirstChild) {\n tabIndex = 0;\n }\n }\n } else {\n tabIndex = disabled ? -1 : 0;\n }\n\n const cardRef = useRef<HTMLDivElement>(null);\n const handleRef = useForkRef(ref, cardRef);\n\n const { active, cardProps } = useInteractableCard({\n disabled,\n onKeyUp,\n onKeyDown,\n onBlur,\n onClick,\n });\n\n return (\n <div\n {...cardProps}\n role={role}\n aria-checked={ariaChecked}\n aria-disabled={disabled}\n data-value={value}\n className={clsx(\n withBaseName(),\n withBaseName(variant),\n {\n [withBaseName(\"accent\")]: accentValue,\n [withBaseName(`accent${capitalize(accentValue ?? \"\")}`)]: accentValue,\n [withBaseName(\"active\")]: role === \"button\" && active,\n [withBaseName(\"disabled\")]: disabled,\n [withBaseName(\"selected\")]: selected,\n },\n className,\n )}\n {...rest}\n onClick={handleClick}\n ref={handleRef}\n tabIndex={tabIndex}\n >\n {children}\n </div>\n );\n});\n"],"names":["makePrefixer","forwardRef","InteractableCard","useWindow","useComponentCssInjection","interactableCardCss","useInteractableCardGroup","useControlled","useRef","useForkRef","useInteractableCard","jsx","clsx","capitalize"],"mappings":"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"}
@@ -3,10 +3,10 @@
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
- var React = require('react');
7
- var clsx = require('clsx');
8
- var window = require('@salt-ds/window');
9
6
  var styles = require('@salt-ds/styles');
7
+ var window = require('@salt-ds/window');
8
+ var clsx = require('clsx');
9
+ var React = require('react');
10
10
  var makePrefixer = require('../utils/makePrefixer.js');
11
11
  var useControlled = require('../utils/useControlled.js');
12
12
  require('../utils/useFloatingUI/useFloatingUI.js');
@@ -50,6 +50,7 @@ require('../flex-item/FlexItem.js');
50
50
  require('../flex-layout/FlexLayout.js');
51
51
  require('../flow-layout/FlowLayout.js');
52
52
  require('../form-field/FormField.js');
53
+ require('../form-field-context/FormFieldContext.js');
53
54
  require('../status-indicator/StatusIndicator.js');
54
55
  require('../text/Text.js');
55
56
  require('../text/Code.js');
@@ -58,7 +59,6 @@ require('../text/Headings.js');
58
59
  require('../text/Label.js');
59
60
  require('../text/TextAction.js');
60
61
  require('../text/TextNotation.js');
61
- require('../form-field-context/FormFieldContext.js');
62
62
  require('../grid-item/GridItem.js');
63
63
  require('../grid-layout/GridLayout.js');
64
64
  require('../input/Input.js');
@@ -68,12 +68,12 @@ require('../link/Link.js');
68
68
  require('../link-card/LinkCard.js');
69
69
  require('../list-box/ListBox.js');
70
70
  require('../list-control/ListControlContext.js');
71
- require('../menu/MenuContext.js');
72
71
  require('@floating-ui/react');
72
+ require('../menu/MenuContext.js');
73
73
  require('../menu/MenuItem.js');
74
74
  require('../menu/MenuPanel.js');
75
- require('../menu/MenuTriggerContext.js');
76
75
  require('../menu/MenuPanelContext.js');
76
+ require('../menu/MenuTriggerContext.js');
77
77
  require('../menu/MenuGroup.js');
78
78
  require('../multiline-input/MultilineInput.js');
79
79
  require('../navigation-item/NavigationItem.js');
@@ -163,7 +163,7 @@ const InteractableCardGroup = React.forwardRef(function InteractableCardGroup2(p
163
163
  }
164
164
  }
165
165
  },
166
- [onChange, value, setValue, multiSelect]
166
+ [onChange, value, multiSelect]
167
167
  );
168
168
  const isSelected = React.useCallback(
169
169
  (cardValue) => multiSelect ? Array.isArray(value) && value.includes(cardValue) : cardValue !== void 0 && value === cardValue,
@@ -195,7 +195,7 @@ const InteractableCardGroup = React.forwardRef(function InteractableCardGroup2(p
195
195
  );
196
196
  const nextIndex = (currentIndex + 1) % elements.length;
197
197
  const prevIndex = (currentIndex - 1 + elements.length) % elements.length;
198
- if (event.key == " ") {
198
+ if (event.key === " ") {
199
199
  event.preventDefault();
200
200
  select(
201
201
  event,
@@ -208,18 +208,22 @@ const InteractableCardGroup = React.forwardRef(function InteractableCardGroup2(p
208
208
  switch (event.key) {
209
209
  case "ArrowDown":
210
210
  case "ArrowRight":
211
- const nextValue = elements[nextIndex].getAttribute(
212
- "data-value"
211
+ select(
212
+ event,
213
+ elements[nextIndex].getAttribute(
214
+ "data-value"
215
+ )
213
216
  );
214
- select(event, nextValue);
215
217
  (_a = elements[nextIndex]) == null ? void 0 : _a.focus();
216
218
  break;
217
219
  case "ArrowUp":
218
220
  case "ArrowLeft":
219
- const prevValue = elements[prevIndex].getAttribute(
220
- "data-value"
221
+ select(
222
+ event,
223
+ elements[prevIndex].getAttribute(
224
+ "data-value"
225
+ )
221
226
  );
222
- select(event, prevValue);
223
227
  (_b = elements[prevIndex]) == null ? void 0 : _b.focus();
224
228
  break;
225
229
  }
@@ -1 +1 @@
1
- {"version":3,"file":"InteractableCardGroup.js","sources":["../src/interactable-card/InteractableCardGroup.tsx"],"sourcesContent":["import {\n ComponentPropsWithoutRef,\n forwardRef,\n KeyboardEvent,\n SyntheticEvent,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { clsx } from \"clsx\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport { makePrefixer, useControlled, useForkRef } from \"../utils\";\nimport {\n InteractableCardGroupContext,\n InteractableCardValue,\n} from \"./InteractableCardGroupContext\";\nimport interactableCardGroupCss from \"./InteractableCardGroup.css\";\n\nexport interface InteractableCardGroupProps\n extends Omit<ComponentPropsWithoutRef<\"div\">, \"onChange\"> {\n /**\n * The default value. Use when the component is not controlled. Should be an array when `multiSelect` is true.\n */\n defaultValue?: InteractableCardValue;\n /**\n * If `true`, the Interactable Card Group will be disabled.\n */\n disabled?: boolean;\n /**\n * The value. Use when the component is controlled. Should be an array when `multiSelect` is true.\n */\n value?: InteractableCardValue;\n /**\n * If `true` the Interactable Card Group will allow multiple selection functionality, with keyboard interactions matching those of a checkbox.\n * By default the group allows mutually exclusive selection with keyboard interactions matching radio buttons.\n */\n multiSelect?: boolean;\n /**\n * Callback fired when the selection changes.\n * @param event\n */\n onChange?: (\n event: SyntheticEvent<HTMLDivElement>,\n value: InteractableCardValue\n ) => void;\n}\n\nconst withBaseName = makePrefixer(\"saltInteractableCardGroup\");\n\nexport const InteractableCardGroup = forwardRef<\n HTMLDivElement,\n InteractableCardGroupProps\n>(function InteractableCardGroup(props, ref) {\n const {\n children,\n className,\n value: valueProp,\n defaultValue,\n disabled,\n onChange,\n onKeyDown,\n multiSelect,\n ...rest\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-interactable-card-group\",\n css: interactableCardGroupCss,\n window: targetWindow,\n });\n\n const groupRef = useRef<HTMLDivElement>(null);\n const handleRef = useForkRef(ref, groupRef);\n\n const [value, setValue] = useControlled({\n default: defaultValue,\n controlled: valueProp,\n name: \"InteractableCardGroup\",\n state: \"value\",\n });\n\n const [elements, setElements] = useState<HTMLElement[]>([]);\n\n useEffect(() => {\n const childElements: HTMLElement[] = Array.from(\n groupRef.current?.querySelectorAll(\n \".saltInteractableCard:not([disabled])\"\n ) ?? []\n );\n setElements(childElements);\n }, [children]);\n\n const select = useCallback(\n (\n event: SyntheticEvent<HTMLDivElement>,\n newValue: InteractableCardValue\n ) => {\n if (multiSelect) {\n const currentValues = Array.isArray(value) ? value : [];\n const isSelected = currentValues.includes(newValue);\n\n const nextValues = isSelected\n ? currentValues.filter((val) => val !== newValue)\n : [...currentValues, newValue];\n setValue(nextValues);\n onChange?.(event, nextValues);\n } else {\n setValue(newValue);\n if (value !== newValue) {\n onChange?.(event, newValue);\n }\n }\n },\n [onChange, value, setValue, multiSelect]\n );\n\n const isSelected = useCallback(\n (cardValue: InteractableCardValue) =>\n multiSelect\n ? Array.isArray(value) && value.includes(cardValue)\n : cardValue !== undefined && value === cardValue,\n [value, multiSelect]\n );\n\n const isFirstChild = useCallback(\n (cardValue: InteractableCardValue) => {\n return (\n elements.findIndex(\n (element) => element.getAttribute(\"data-value\") === cardValue\n ) === 0\n );\n },\n [elements]\n );\n\n const contextValue = useMemo(\n () => ({\n select,\n isSelected,\n isFirstChild,\n disabled,\n multiSelect,\n value,\n }),\n [select, isSelected, disabled, multiSelect, isFirstChild, value]\n );\n\n const handleKeyDown = (event: KeyboardEvent<HTMLDivElement>) => {\n const currentIndex = elements.findIndex(\n (element) => element === document.activeElement\n );\n const nextIndex = (currentIndex + 1) % elements.length;\n const prevIndex = (currentIndex - 1 + elements.length) % elements.length;\n\n if (event.key == \" \") {\n event.preventDefault();\n select(\n event,\n elements[currentIndex].getAttribute(\n \"data-value\"\n ) as InteractableCardValue\n );\n }\n\n if (!multiSelect) {\n switch (event.key) {\n case \"ArrowDown\":\n case \"ArrowRight\":\n const nextValue = elements[nextIndex].getAttribute(\n \"data-value\"\n ) as InteractableCardValue;\n select(event, nextValue);\n elements[nextIndex]?.focus();\n break;\n case \"ArrowUp\":\n case \"ArrowLeft\":\n const prevValue = elements[prevIndex].getAttribute(\n \"data-value\"\n ) as InteractableCardValue;\n select(event, prevValue);\n elements[prevIndex]?.focus();\n break;\n }\n }\n onKeyDown?.(event);\n };\n\n return (\n <InteractableCardGroupContext.Provider value={contextValue}>\n <div\n className={clsx(withBaseName(), className)}\n role={multiSelect ? \"group\" : \"radiogroup\"}\n onKeyDown={handleKeyDown}\n ref={handleRef}\n {...rest}\n >\n {children}\n </div>\n </InteractableCardGroupContext.Provider>\n );\n});\n"],"names":["makePrefixer","forwardRef","InteractableCardGroup","useWindow","useComponentCssInjection","interactableCardGroupCss","useRef","useForkRef","useControlled","useState","useEffect","useCallback","isSelected","useMemo","jsx","InteractableCardGroupContext","clsx"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmDA,MAAM,YAAA,GAAeA,0BAAa,2BAA2B,CAAA,CAAA;AAEtD,MAAM,qBAAwB,GAAAC,gBAAA,CAGnC,SAASC,sBAAAA,CAAsB,OAAO,GAAK,EAAA;AAC3C,EAAM,MAAA;AAAA,IACJ,QAAA;AAAA,IACA,SAAA;AAAA,IACA,KAAO,EAAA,SAAA;AAAA,IACP,YAAA;AAAA,IACA,QAAA;AAAA,IACA,QAAA;AAAA,IACA,SAAA;AAAA,IACA,WAAA;AAAA,IACG,GAAA,IAAA;AAAA,GACD,GAAA,KAAA,CAAA;AAEJ,EAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,8BAAA;AAAA,IACR,GAAK,EAAAC,uBAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAM,MAAA,QAAA,GAAWC,aAAuB,IAAI,CAAA,CAAA;AAC5C,EAAM,MAAA,SAAA,GAAYC,qBAAW,CAAA,GAAA,EAAK,QAAQ,CAAA,CAAA;AAE1C,EAAA,MAAM,CAAC,KAAA,EAAO,QAAQ,CAAA,GAAIC,2BAAc,CAAA;AAAA,IACtC,OAAS,EAAA,YAAA;AAAA,IACT,UAAY,EAAA,SAAA;AAAA,IACZ,IAAM,EAAA,uBAAA;AAAA,IACN,KAAO,EAAA,OAAA;AAAA,GACR,CAAA,CAAA;AAED,EAAA,MAAM,CAAC,QAAU,EAAA,WAAW,CAAI,GAAAC,cAAA,CAAwB,EAAE,CAAA,CAAA;AAE1D,EAAAC,eAAA,CAAU,MAAM;AAxFlB,IAAA,IAAA,EAAA,EAAA,EAAA,CAAA;AAyFI,IAAA,MAAM,gBAA+B,KAAM,CAAA,IAAA;AAAA,MACzC,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,QAAA,CAAS,YAAT,IAAkB,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,gBAAA;AAAA,QAChB,uCAAA;AAAA,OAAA,KADF,YAEK,EAAC;AAAA,KACR,CAAA;AACA,IAAA,WAAA,CAAY,aAAa,CAAA,CAAA;AAAA,GAC3B,EAAG,CAAC,QAAQ,CAAC,CAAA,CAAA;AAEb,EAAA,MAAM,MAAS,GAAAC,iBAAA;AAAA,IACb,CACE,OACA,QACG,KAAA;AACH,MAAA,IAAI,WAAa,EAAA;AACf,QAAA,MAAM,gBAAgB,KAAM,CAAA,OAAA,CAAQ,KAAK,CAAA,GAAI,QAAQ,EAAC,CAAA;AACtD,QAAMC,MAAAA,WAAAA,GAAa,aAAc,CAAA,QAAA,CAAS,QAAQ,CAAA,CAAA;AAElD,QAAA,MAAM,UAAaA,GAAAA,WAAAA,GACf,aAAc,CAAA,MAAA,CAAO,CAAC,GAAA,KAAQ,GAAQ,KAAA,QAAQ,CAC9C,GAAA,CAAC,GAAG,aAAA,EAAe,QAAQ,CAAA,CAAA;AAC/B,QAAA,QAAA,CAAS,UAAU,CAAA,CAAA;AACnB,QAAA,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAW,KAAO,EAAA,UAAA,CAAA,CAAA;AAAA,OACb,MAAA;AACL,QAAA,QAAA,CAAS,QAAQ,CAAA,CAAA;AACjB,QAAA,IAAI,UAAU,QAAU,EAAA;AACtB,UAAA,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAW,KAAO,EAAA,QAAA,CAAA,CAAA;AAAA,SACpB;AAAA,OACF;AAAA,KACF;AAAA,IACA,CAAC,QAAA,EAAU,KAAO,EAAA,QAAA,EAAU,WAAW,CAAA;AAAA,GACzC,CAAA;AAEA,EAAA,MAAM,UAAa,GAAAD,iBAAA;AAAA,IACjB,CAAC,SAAA,KACC,WACI,GAAA,KAAA,CAAM,OAAQ,CAAA,KAAK,CAAK,IAAA,KAAA,CAAM,QAAS,CAAA,SAAS,CAChD,GAAA,SAAA,KAAc,UAAa,KAAU,KAAA,SAAA;AAAA,IAC3C,CAAC,OAAO,WAAW,CAAA;AAAA,GACrB,CAAA;AAEA,EAAA,MAAM,YAAe,GAAAA,iBAAA;AAAA,IACnB,CAAC,SAAqC,KAAA;AACpC,MAAA,OACE,QAAS,CAAA,SAAA;AAAA,QACP,CAAC,OAAA,KAAY,OAAQ,CAAA,YAAA,CAAa,YAAY,CAAM,KAAA,SAAA;AAAA,OAChD,KAAA,CAAA,CAAA;AAAA,KAEV;AAAA,IACA,CAAC,QAAQ,CAAA;AAAA,GACX,CAAA;AAEA,EAAA,MAAM,YAAe,GAAAE,aAAA;AAAA,IACnB,OAAO;AAAA,MACL,MAAA;AAAA,MACA,UAAA;AAAA,MACA,YAAA;AAAA,MACA,QAAA;AAAA,MACA,WAAA;AAAA,MACA,KAAA;AAAA,KACF,CAAA;AAAA,IACA,CAAC,MAAQ,EAAA,UAAA,EAAY,QAAU,EAAA,WAAA,EAAa,cAAc,KAAK,CAAA;AAAA,GACjE,CAAA;AAEA,EAAM,MAAA,aAAA,GAAgB,CAAC,KAAyC,KAAA;AAxJlE,IAAA,IAAA,EAAA,EAAA,EAAA,CAAA;AAyJI,IAAA,MAAM,eAAe,QAAS,CAAA,SAAA;AAAA,MAC5B,CAAC,OAAY,KAAA,OAAA,KAAY,QAAS,CAAA,aAAA;AAAA,KACpC,CAAA;AACA,IAAM,MAAA,SAAA,GAAA,CAAa,YAAe,GAAA,CAAA,IAAK,QAAS,CAAA,MAAA,CAAA;AAChD,IAAA,MAAM,SAAa,GAAA,CAAA,YAAA,GAAe,CAAI,GAAA,QAAA,CAAS,UAAU,QAAS,CAAA,MAAA,CAAA;AAElE,IAAI,IAAA,KAAA,CAAM,OAAO,GAAK,EAAA;AACpB,MAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,MAAA,MAAA;AAAA,QACE,KAAA;AAAA,QACA,SAAS,YAAc,CAAA,CAAA,YAAA;AAAA,UACrB,YAAA;AAAA,SACF;AAAA,OACF,CAAA;AAAA,KACF;AAEA,IAAA,IAAI,CAAC,WAAa,EAAA;AAChB,MAAA,QAAQ,KAAM,CAAA,GAAA;AAAA,QACP,KAAA,WAAA,CAAA;AAAA,QACA,KAAA,YAAA;AACH,UAAM,MAAA,SAAA,GAAY,SAAS,SAAW,CAAA,CAAA,YAAA;AAAA,YACpC,YAAA;AAAA,WACF,CAAA;AACA,UAAA,MAAA,CAAO,OAAO,SAAS,CAAA,CAAA;AACvB,UAAA,CAAA,EAAA,GAAA,QAAA,CAAS,eAAT,IAAqB,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,KAAA,EAAA,CAAA;AACrB,UAAA,MAAA;AAAA,QACG,KAAA,SAAA,CAAA;AAAA,QACA,KAAA,WAAA;AACH,UAAM,MAAA,SAAA,GAAY,SAAS,SAAW,CAAA,CAAA,YAAA;AAAA,YACpC,YAAA;AAAA,WACF,CAAA;AACA,UAAA,MAAA,CAAO,OAAO,SAAS,CAAA,CAAA;AACvB,UAAA,CAAA,EAAA,GAAA,QAAA,CAAS,eAAT,IAAqB,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,KAAA,EAAA,CAAA;AACrB,UAAA,MAAA;AAAA,OAAA;AAAA,KAEN;AACA,IAAY,SAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,SAAA,CAAA,KAAA,CAAA,CAAA;AAAA,GACd,CAAA;AAEA,EACE,uBAAAC,cAAA,CAACC,0DAA6B,QAA7B,EAAA;AAAA,IAAsC,KAAO,EAAA,YAAA;AAAA,IAC5C,QAAC,kBAAAD,cAAA,CAAA,KAAA,EAAA;AAAA,MACC,SAAW,EAAAE,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,MACzC,IAAA,EAAM,cAAc,OAAU,GAAA,YAAA;AAAA,MAC9B,SAAW,EAAA,aAAA;AAAA,MACX,GAAK,EAAA,SAAA;AAAA,MACJ,GAAG,IAAA;AAAA,MAEH,QAAA;AAAA,KACH,CAAA;AAAA,GACF,CAAA,CAAA;AAEJ,CAAC;;;;"}
1
+ {"version":3,"file":"InteractableCardGroup.js","sources":["../src/interactable-card/InteractableCardGroup.tsx"],"sourcesContent":["import { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport {\n type ComponentPropsWithoutRef,\n type KeyboardEvent,\n type SyntheticEvent,\n forwardRef,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\n\nimport { makePrefixer, useControlled, useForkRef } from \"../utils\";\nimport interactableCardGroupCss from \"./InteractableCardGroup.css\";\nimport {\n InteractableCardGroupContext,\n type InteractableCardValue,\n} from \"./InteractableCardGroupContext\";\n\nexport interface InteractableCardGroupProps\n extends Omit<ComponentPropsWithoutRef<\"div\">, \"onChange\"> {\n /**\n * The default value. Use when the component is not controlled. Should be an array when `multiSelect` is true.\n */\n defaultValue?: InteractableCardValue;\n /**\n * If `true`, the Interactable Card Group will be disabled.\n */\n disabled?: boolean;\n /**\n * The value. Use when the component is controlled. Should be an array when `multiSelect` is true.\n */\n value?: InteractableCardValue;\n /**\n * If `true` the Interactable Card Group will allow multiple selection functionality, with keyboard interactions matching those of a checkbox.\n * By default the group allows mutually exclusive selection with keyboard interactions matching radio buttons.\n */\n multiSelect?: boolean;\n /**\n * Callback fired when the selection changes.\n * @param event\n */\n onChange?: (\n event: SyntheticEvent<HTMLDivElement>,\n value: InteractableCardValue,\n ) => void;\n}\n\nconst withBaseName = makePrefixer(\"saltInteractableCardGroup\");\n\nexport const InteractableCardGroup = forwardRef<\n HTMLDivElement,\n InteractableCardGroupProps\n>(function InteractableCardGroup(props, ref) {\n const {\n children,\n className,\n value: valueProp,\n defaultValue,\n disabled,\n onChange,\n onKeyDown,\n multiSelect,\n ...rest\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-interactable-card-group\",\n css: interactableCardGroupCss,\n window: targetWindow,\n });\n\n const groupRef = useRef<HTMLDivElement>(null);\n const handleRef = useForkRef(ref, groupRef);\n\n const [value, setValue] = useControlled({\n default: defaultValue,\n controlled: valueProp,\n name: \"InteractableCardGroup\",\n state: \"value\",\n });\n\n const [elements, setElements] = useState<HTMLElement[]>([]);\n\n // biome-ignore lint/correctness/useExhaustiveDependencies: queries the dom when children changes.\n useEffect(() => {\n const childElements: HTMLElement[] = Array.from(\n groupRef.current?.querySelectorAll(\n \".saltInteractableCard:not([disabled])\",\n ) ?? [],\n );\n setElements(childElements);\n }, [children]);\n\n const select = useCallback(\n (\n event: SyntheticEvent<HTMLDivElement>,\n newValue: InteractableCardValue,\n ) => {\n if (multiSelect) {\n const currentValues = Array.isArray(value) ? value : [];\n const isSelected = currentValues.includes(newValue);\n\n const nextValues = isSelected\n ? currentValues.filter((val) => val !== newValue)\n : [...currentValues, newValue];\n setValue(nextValues);\n onChange?.(event, nextValues);\n } else {\n setValue(newValue);\n if (value !== newValue) {\n onChange?.(event, newValue);\n }\n }\n },\n [onChange, value, multiSelect],\n );\n\n const isSelected = useCallback(\n (cardValue: InteractableCardValue) =>\n multiSelect\n ? Array.isArray(value) && value.includes(cardValue)\n : cardValue !== undefined && value === cardValue,\n [value, multiSelect],\n );\n\n const isFirstChild = useCallback(\n (cardValue: InteractableCardValue) => {\n return (\n elements.findIndex(\n (element) => element.getAttribute(\"data-value\") === cardValue,\n ) === 0\n );\n },\n [elements],\n );\n\n const contextValue = useMemo(\n () => ({\n select,\n isSelected,\n isFirstChild,\n disabled,\n multiSelect,\n value,\n }),\n [select, isSelected, disabled, multiSelect, isFirstChild, value],\n );\n\n const handleKeyDown = (event: KeyboardEvent<HTMLDivElement>) => {\n const currentIndex = elements.findIndex(\n (element) => element === document.activeElement,\n );\n const nextIndex = (currentIndex + 1) % elements.length;\n const prevIndex = (currentIndex - 1 + elements.length) % elements.length;\n\n if (event.key === \" \") {\n event.preventDefault();\n select(\n event,\n elements[currentIndex].getAttribute(\n \"data-value\",\n ) as InteractableCardValue,\n );\n }\n\n if (!multiSelect) {\n switch (event.key) {\n case \"ArrowDown\":\n case \"ArrowRight\":\n select(\n event,\n elements[nextIndex].getAttribute(\n \"data-value\",\n ) as InteractableCardValue,\n );\n elements[nextIndex]?.focus();\n break;\n case \"ArrowUp\":\n case \"ArrowLeft\":\n select(\n event,\n elements[prevIndex].getAttribute(\n \"data-value\",\n ) as InteractableCardValue,\n );\n elements[prevIndex]?.focus();\n break;\n }\n }\n onKeyDown?.(event);\n };\n\n return (\n <InteractableCardGroupContext.Provider value={contextValue}>\n <div\n className={clsx(withBaseName(), className)}\n role={multiSelect ? \"group\" : \"radiogroup\"}\n onKeyDown={handleKeyDown}\n ref={handleRef}\n {...rest}\n >\n {children}\n </div>\n </InteractableCardGroupContext.Provider>\n );\n});\n"],"names":["makePrefixer","forwardRef","InteractableCardGroup","useWindow","useComponentCssInjection","interactableCardGroupCss","useRef","useForkRef","useControlled","useState","useEffect","useCallback","isSelected","useMemo","jsx","InteractableCardGroupContext","clsx"],"mappings":"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"}
@@ -4,17 +4,17 @@ Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var React = require('react');
6
6
  var createContext = require('../utils/createContext.js');
7
+ require('react/jsx-runtime');
8
+ require('clsx');
7
9
  require('../utils/useFloatingUI/useFloatingUI.js');
8
10
  require('../utils/useId.js');
9
11
  require('../salt-provider/SaltProvider.js');
10
12
  require('../viewport/ViewportProvider.js');
11
- require('clsx');
12
13
  require('../accordion/AccordionGroup.js');
13
14
  require('../accordion/AccordionPanel.js');
14
15
  require('../accordion/Accordion.js');
15
16
  require('../accordion/AccordionHeader.js');
16
17
  require('../aria-announcer/AriaAnnouncerContext.js');
17
- require('react/jsx-runtime');
18
18
  require('../avatar/Avatar.js');
19
19
  require('../badge/Badge.js');
20
20
  require('../banner/Banner.js');
@@ -27,9 +27,9 @@ require('../button/Button.js');
27
27
  require('../card/Card.js');
28
28
  require('../checkbox/Checkbox.js');
29
29
  require('../checkbox/CheckboxGroup.js');
30
+ require('@salt-ds/icons');
30
31
  require('@salt-ds/styles');
31
32
  require('@salt-ds/window');
32
- require('@salt-ds/icons');
33
33
  require('../combo-box/ComboBox.js');
34
34
  require('../dialog/Dialog.js');
35
35
  require('../dialog/DialogHeader.js');
@@ -48,6 +48,7 @@ require('../flex-item/FlexItem.js');
48
48
  require('../flex-layout/FlexLayout.js');
49
49
  require('../flow-layout/FlowLayout.js');
50
50
  require('../form-field/FormField.js');
51
+ require('../form-field-context/FormFieldContext.js');
51
52
  require('../status-indicator/StatusIndicator.js');
52
53
  require('../text/Text.js');
53
54
  require('../text/Code.js');
@@ -56,7 +57,6 @@ require('../text/Headings.js');
56
57
  require('../text/Label.js');
57
58
  require('../text/TextAction.js');
58
59
  require('../text/TextNotation.js');
59
- require('../form-field-context/FormFieldContext.js');
60
60
  require('../grid-item/GridItem.js');
61
61
  require('../grid-layout/GridLayout.js');
62
62
  require('../input/Input.js');
@@ -66,12 +66,12 @@ require('../link/Link.js');
66
66
  require('../link-card/LinkCard.js');
67
67
  require('../list-box/ListBox.js');
68
68
  require('../list-control/ListControlContext.js');
69
- require('../menu/MenuContext.js');
70
69
  require('@floating-ui/react');
70
+ require('../menu/MenuContext.js');
71
71
  require('../menu/MenuItem.js');
72
72
  require('../menu/MenuPanel.js');
73
- require('../menu/MenuTriggerContext.js');
74
73
  require('../menu/MenuPanelContext.js');
74
+ require('../menu/MenuTriggerContext.js');
75
75
  require('../menu/MenuGroup.js');
76
76
  require('../multiline-input/MultilineInput.js');
77
77
  require('../navigation-item/NavigationItem.js');
@@ -1 +1 @@
1
- {"version":3,"file":"InteractableCardGroupContext.js","sources":["../src/interactable-card/InteractableCardGroupContext.tsx"],"sourcesContent":["import { SyntheticEvent, useContext } from \"react\";\nimport { createContext } from \"../utils\";\n\nexport type InteractableCardValue = string | readonly string[] | undefined;\n\nexport interface InteractableCardGroupContextValue {\n disabled?: boolean;\n select: (\n event: SyntheticEvent<HTMLDivElement>,\n value: InteractableCardValue\n ) => void;\n isSelected: (id: InteractableCardValue) => boolean;\n isFirstChild: (value: InteractableCardValue) => boolean;\n multiSelect?: boolean;\n value: InteractableCardValue;\n}\n\nexport const InteractableCardGroupContext = createContext<\n InteractableCardGroupContextValue | undefined\n>(\"InteractableCardGroupContext\", undefined);\n\nexport function useInteractableCardGroup() {\n return useContext(InteractableCardGroupContext);\n}\n"],"names":["createContext","useContext"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiBa,MAAA,4BAAA,GAA+BA,2BAE1C,CAAA,8BAAA,EAAgC,KAAS,CAAA,EAAA;AAEpC,SAAS,wBAA2B,GAAA;AACzC,EAAA,OAAOC,iBAAW,4BAA4B,CAAA,CAAA;AAChD;;;;;"}
1
+ {"version":3,"file":"InteractableCardGroupContext.js","sources":["../src/interactable-card/InteractableCardGroupContext.tsx"],"sourcesContent":["import { type SyntheticEvent, useContext } from \"react\";\nimport { createContext } from \"../utils\";\n\nexport type InteractableCardValue = string | readonly string[] | undefined;\n\nexport interface InteractableCardGroupContextValue {\n disabled?: boolean;\n select: (\n event: SyntheticEvent<HTMLDivElement>,\n value: InteractableCardValue,\n ) => void;\n isSelected: (id: InteractableCardValue) => boolean;\n isFirstChild: (value: InteractableCardValue) => boolean;\n multiSelect?: boolean;\n value: InteractableCardValue;\n}\n\nexport const InteractableCardGroupContext = createContext<\n InteractableCardGroupContextValue | undefined\n>(\"InteractableCardGroupContext\", undefined);\n\nexport function useInteractableCardGroup() {\n return useContext(InteractableCardGroupContext);\n}\n"],"names":["createContext","useContext"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiBa,MAAA,4BAAA,GAA+BA,2BAE1C,CAAA,8BAAA,EAAgC,KAAS,CAAA,EAAA;AAEpC,SAAS,wBAA2B,GAAA;AACzC,EAAA,OAAOC,iBAAW,4BAA4B,CAAA,CAAA;AAChD;;;;;"}
@@ -17,7 +17,7 @@ const useInteractableCard = ({
17
17
  const space = " ";
18
18
  React.useEffect(() => {
19
19
  const t = setTimeout(() => {
20
- if (keyIsDown !== enter && keyIsDown !== space) {
20
+ if (keyIsDown !== enter && keyIsDown !== space && active) {
21
21
  setActive(false);
22
22
  }
23
23
  }, 0);
@@ -1 +1 @@
1
- {"version":3,"file":"useInteractableCard.js","sources":["../src/interactable-card/useInteractableCard.ts"],"sourcesContent":["import {\n FocusEvent,\n KeyboardEvent,\n MouseEvent,\n useEffect,\n useState,\n} from \"react\";\n\nexport interface CardHookProps<T extends Element> {\n disabled?: boolean;\n onKeyUp?: (event: KeyboardEvent<T>) => void;\n onKeyDown?: (event: KeyboardEvent<T>) => void;\n onClick?: (event: MouseEvent<T>) => void;\n onBlur?: (event: FocusEvent<T>) => void;\n}\n\nexport interface CardHookResult<T extends Element> {\n active: boolean;\n cardProps: {\n \"aria-disabled\"?: boolean;\n disabled?: boolean;\n tabIndex: number;\n onBlur: (event: FocusEvent<T>) => void;\n onClick?: (event: MouseEvent<T>) => void;\n onKeyDown: (event: KeyboardEvent<T>) => void;\n onKeyUp: (event: KeyboardEvent<T>) => void;\n };\n}\n\nexport const useInteractableCard = <T extends Element>({\n disabled,\n onKeyUp,\n onKeyDown,\n onClick,\n onBlur,\n}: CardHookProps<T>): CardHookResult<T> => {\n const [keyIsDown, setkeyIsDown] = useState(\"\");\n const [active, setActive] = useState(false);\n\n const enter = \"Enter\";\n const space = \" \";\n\n useEffect(() => {\n const t = setTimeout(() => {\n // This key state check is to stop continual visual state change when using Enter Key, which the browser treats as both key and click events on a Button-like component\n // This key state check also fixes Firefox Button where Space key is pressed but button fails to be in active state\n if (keyIsDown !== enter && keyIsDown !== space) {\n setActive(false);\n }\n }, 0);\n\n return () => {\n clearTimeout(t);\n };\n }, [active, keyIsDown]);\n\n const handleKeyUp = (event: KeyboardEvent<T>) => {\n setkeyIsDown(\"\");\n setActive(false);\n onKeyUp?.(event);\n };\n\n const handleClick = (event: MouseEvent<T>) => {\n setActive(true);\n onClick?.(event);\n };\n\n const handleBlur = (event: FocusEvent<T>) => {\n setActive(false);\n onBlur?.(event);\n };\n\n const handleKeyDown = (event: KeyboardEvent<T>) => {\n if (event.key === enter || event.key === space) {\n setkeyIsDown(event.key);\n event.preventDefault();\n setActive(true);\n onClick?.(event as unknown as MouseEvent<T>);\n }\n onKeyDown?.(event);\n };\n\n const cardProps = {\n \"aria-disabled\": disabled ? true : undefined,\n disabled: disabled,\n tabIndex: disabled ? -1 : 0,\n onBlur: handleBlur,\n onClick: !disabled ? handleClick : undefined,\n onKeyDown: handleKeyDown,\n onKeyUp: handleKeyUp,\n };\n\n return {\n active,\n cardProps,\n };\n};\n"],"names":["useState","useEffect"],"mappings":";;;;;;AA6BO,MAAM,sBAAsB,CAAoB;AAAA,EACrD,QAAA;AAAA,EACA,OAAA;AAAA,EACA,SAAA;AAAA,EACA,OAAA;AAAA,EACA,MAAA;AACF,CAA2C,KAAA;AACzC,EAAA,MAAM,CAAC,SAAA,EAAW,YAAY,CAAA,GAAIA,eAAS,EAAE,CAAA,CAAA;AAC7C,EAAA,MAAM,CAAC,MAAA,EAAQ,SAAS,CAAA,GAAIA,eAAS,KAAK,CAAA,CAAA;AAE1C,EAAA,MAAM,KAAQ,GAAA,OAAA,CAAA;AACd,EAAA,MAAM,KAAQ,GAAA,GAAA,CAAA;AAEd,EAAAC,eAAA,CAAU,MAAM;AACd,IAAM,MAAA,CAAA,GAAI,WAAW,MAAM;AAGzB,MAAI,IAAA,SAAA,KAAc,KAAS,IAAA,SAAA,KAAc,KAAO,EAAA;AAC9C,QAAA,SAAA,CAAU,KAAK,CAAA,CAAA;AAAA,OACjB;AAAA,OACC,CAAC,CAAA,CAAA;AAEJ,IAAA,OAAO,MAAM;AACX,MAAA,YAAA,CAAa,CAAC,CAAA,CAAA;AAAA,KAChB,CAAA;AAAA,GACC,EAAA,CAAC,MAAQ,EAAA,SAAS,CAAC,CAAA,CAAA;AAEtB,EAAM,MAAA,WAAA,GAAc,CAAC,KAA4B,KAAA;AAC/C,IAAA,YAAA,CAAa,EAAE,CAAA,CAAA;AACf,IAAA,SAAA,CAAU,KAAK,CAAA,CAAA;AACf,IAAU,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,CAAA,KAAA,CAAA,CAAA;AAAA,GACZ,CAAA;AAEA,EAAM,MAAA,WAAA,GAAc,CAAC,KAAyB,KAAA;AAC5C,IAAA,SAAA,CAAU,IAAI,CAAA,CAAA;AACd,IAAU,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,CAAA,KAAA,CAAA,CAAA;AAAA,GACZ,CAAA;AAEA,EAAM,MAAA,UAAA,GAAa,CAAC,KAAyB,KAAA;AAC3C,IAAA,SAAA,CAAU,KAAK,CAAA,CAAA;AACf,IAAS,MAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,MAAA,CAAA,KAAA,CAAA,CAAA;AAAA,GACX,CAAA;AAEA,EAAM,MAAA,aAAA,GAAgB,CAAC,KAA4B,KAAA;AACjD,IAAA,IAAI,KAAM,CAAA,GAAA,KAAQ,KAAS,IAAA,KAAA,CAAM,QAAQ,KAAO,EAAA;AAC9C,MAAA,YAAA,CAAa,MAAM,GAAG,CAAA,CAAA;AACtB,MAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,MAAA,SAAA,CAAU,IAAI,CAAA,CAAA;AACd,MAAU,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,CAAA,KAAA,CAAA,CAAA;AAAA,KACZ;AACA,IAAY,SAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,SAAA,CAAA,KAAA,CAAA,CAAA;AAAA,GACd,CAAA;AAEA,EAAA,MAAM,SAAY,GAAA;AAAA,IAChB,eAAA,EAAiB,WAAW,IAAO,GAAA,KAAA,CAAA;AAAA,IACnC,QAAA;AAAA,IACA,QAAA,EAAU,WAAW,CAAK,CAAA,GAAA,CAAA;AAAA,IAC1B,MAAQ,EAAA,UAAA;AAAA,IACR,OAAA,EAAS,CAAC,QAAA,GAAW,WAAc,GAAA,KAAA,CAAA;AAAA,IACnC,SAAW,EAAA,aAAA;AAAA,IACX,OAAS,EAAA,WAAA;AAAA,GACX,CAAA;AAEA,EAAO,OAAA;AAAA,IACL,MAAA;AAAA,IACA,SAAA;AAAA,GACF,CAAA;AACF;;;;"}
1
+ {"version":3,"file":"useInteractableCard.js","sources":["../src/interactable-card/useInteractableCard.ts"],"sourcesContent":["import {\n type FocusEvent,\n type KeyboardEvent,\n type MouseEvent,\n useEffect,\n useState,\n} from \"react\";\n\nexport interface CardHookProps<T extends Element> {\n disabled?: boolean;\n onKeyUp?: (event: KeyboardEvent<T>) => void;\n onKeyDown?: (event: KeyboardEvent<T>) => void;\n onClick?: (event: MouseEvent<T>) => void;\n onBlur?: (event: FocusEvent<T>) => void;\n}\n\nexport interface CardHookResult<T extends Element> {\n active: boolean;\n cardProps: {\n \"aria-disabled\"?: boolean;\n disabled?: boolean;\n tabIndex: number;\n onBlur: (event: FocusEvent<T>) => void;\n onClick?: (event: MouseEvent<T>) => void;\n onKeyDown: (event: KeyboardEvent<T>) => void;\n onKeyUp: (event: KeyboardEvent<T>) => void;\n };\n}\n\nexport const useInteractableCard = <T extends Element>({\n disabled,\n onKeyUp,\n onKeyDown,\n onClick,\n onBlur,\n}: CardHookProps<T>): CardHookResult<T> => {\n const [keyIsDown, setkeyIsDown] = useState(\"\");\n const [active, setActive] = useState(false);\n\n const enter = \"Enter\";\n const space = \" \";\n\n useEffect(() => {\n const t = setTimeout(() => {\n // This key state check is to stop continual visual state change when using Enter Key, which the browser treats as both key and click events on a Button-like component\n // This key state check also fixes Firefox Button where Space key is pressed but button fails to be in active state\n if (keyIsDown !== enter && keyIsDown !== space && active) {\n setActive(false);\n }\n }, 0);\n\n return () => {\n clearTimeout(t);\n };\n }, [active, keyIsDown]);\n\n const handleKeyUp = (event: KeyboardEvent<T>) => {\n setkeyIsDown(\"\");\n setActive(false);\n onKeyUp?.(event);\n };\n\n const handleClick = (event: MouseEvent<T>) => {\n setActive(true);\n onClick?.(event);\n };\n\n const handleBlur = (event: FocusEvent<T>) => {\n setActive(false);\n onBlur?.(event);\n };\n\n const handleKeyDown = (event: KeyboardEvent<T>) => {\n if (event.key === enter || event.key === space) {\n setkeyIsDown(event.key);\n event.preventDefault();\n setActive(true);\n onClick?.(event as unknown as MouseEvent<T>);\n }\n onKeyDown?.(event);\n };\n\n const cardProps = {\n \"aria-disabled\": disabled ? true : undefined,\n disabled: disabled,\n tabIndex: disabled ? -1 : 0,\n onBlur: handleBlur,\n onClick: !disabled ? handleClick : undefined,\n onKeyDown: handleKeyDown,\n onKeyUp: handleKeyUp,\n };\n\n return {\n active,\n cardProps,\n };\n};\n"],"names":["useState","useEffect"],"mappings":";;;;;;AA6BO,MAAM,sBAAsB,CAAoB;AAAA,EACrD,QAAA;AAAA,EACA,OAAA;AAAA,EACA,SAAA;AAAA,EACA,OAAA;AAAA,EACA,MAAA;AACF,CAA2C,KAAA;AACzC,EAAA,MAAM,CAAC,SAAA,EAAW,YAAY,CAAA,GAAIA,eAAS,EAAE,CAAA,CAAA;AAC7C,EAAA,MAAM,CAAC,MAAA,EAAQ,SAAS,CAAA,GAAIA,eAAS,KAAK,CAAA,CAAA;AAE1C,EAAA,MAAM,KAAQ,GAAA,OAAA,CAAA;AACd,EAAA,MAAM,KAAQ,GAAA,GAAA,CAAA;AAEd,EAAAC,eAAA,CAAU,MAAM;AACd,IAAM,MAAA,CAAA,GAAI,WAAW,MAAM;AAGzB,MAAA,IAAI,SAAc,KAAA,KAAA,IAAS,SAAc,KAAA,KAAA,IAAS,MAAQ,EAAA;AACxD,QAAA,SAAA,CAAU,KAAK,CAAA,CAAA;AAAA,OACjB;AAAA,OACC,CAAC,CAAA,CAAA;AAEJ,IAAA,OAAO,MAAM;AACX,MAAA,YAAA,CAAa,CAAC,CAAA,CAAA;AAAA,KAChB,CAAA;AAAA,GACC,EAAA,CAAC,MAAQ,EAAA,SAAS,CAAC,CAAA,CAAA;AAEtB,EAAM,MAAA,WAAA,GAAc,CAAC,KAA4B,KAAA;AAC/C,IAAA,YAAA,CAAa,EAAE,CAAA,CAAA;AACf,IAAA,SAAA,CAAU,KAAK,CAAA,CAAA;AACf,IAAU,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,CAAA,KAAA,CAAA,CAAA;AAAA,GACZ,CAAA;AAEA,EAAM,MAAA,WAAA,GAAc,CAAC,KAAyB,KAAA;AAC5C,IAAA,SAAA,CAAU,IAAI,CAAA,CAAA;AACd,IAAU,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,CAAA,KAAA,CAAA,CAAA;AAAA,GACZ,CAAA;AAEA,EAAM,MAAA,UAAA,GAAa,CAAC,KAAyB,KAAA;AAC3C,IAAA,SAAA,CAAU,KAAK,CAAA,CAAA;AACf,IAAS,MAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,MAAA,CAAA,KAAA,CAAA,CAAA;AAAA,GACX,CAAA;AAEA,EAAM,MAAA,aAAA,GAAgB,CAAC,KAA4B,KAAA;AACjD,IAAA,IAAI,KAAM,CAAA,GAAA,KAAQ,KAAS,IAAA,KAAA,CAAM,QAAQ,KAAO,EAAA;AAC9C,MAAA,YAAA,CAAa,MAAM,GAAG,CAAA,CAAA;AACtB,MAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,MAAA,SAAA,CAAU,IAAI,CAAA,CAAA;AACd,MAAU,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,CAAA,KAAA,CAAA,CAAA;AAAA,KACZ;AACA,IAAY,SAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,SAAA,CAAA,KAAA,CAAA,CAAA;AAAA,GACd,CAAA;AAEA,EAAA,MAAM,SAAY,GAAA;AAAA,IAChB,eAAA,EAAiB,WAAW,IAAO,GAAA,KAAA,CAAA;AAAA,IACnC,QAAA;AAAA,IACA,QAAA,EAAU,WAAW,CAAK,CAAA,GAAA,CAAA;AAAA,IAC1B,MAAQ,EAAA,UAAA;AAAA,IACR,OAAA,EAAS,CAAC,QAAA,GAAW,WAAc,GAAA,KAAA,CAAA;AAAA,IACnC,SAAW,EAAA,aAAA;AAAA,IACX,OAAS,EAAA,WAAA;AAAA,GACX,CAAA;AAEA,EAAO,OAAA;AAAA,IACL,MAAA;AAAA,IACA,SAAA;AAAA,GACF,CAAA;AACF;;;;"}
@@ -3,9 +3,16 @@
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
- var React = require('react');
7
- var clsx = require('clsx');
8
6
  var icons = require('@salt-ds/icons');
7
+ var clsx = require('clsx');
8
+ var React = require('react');
9
+ var Text = require('../text/Text.js');
10
+ require('../text/Code.js');
11
+ require('../text/Display.js');
12
+ require('../text/Headings.js');
13
+ require('../text/Label.js');
14
+ require('../text/TextAction.js');
15
+ require('../text/TextNotation.js');
9
16
  var makePrefixer = require('../utils/makePrefixer.js');
10
17
  require('../utils/useFloatingUI/useFloatingUI.js');
11
18
  require('../utils/useId.js');
@@ -48,15 +55,8 @@ require('../flex-item/FlexItem.js');
48
55
  require('../flex-layout/FlexLayout.js');
49
56
  require('../flow-layout/FlowLayout.js');
50
57
  require('../form-field/FormField.js');
51
- require('../status-indicator/StatusIndicator.js');
52
- var Text = require('../text/Text.js');
53
- require('../text/Code.js');
54
- require('../text/Display.js');
55
- require('../text/Headings.js');
56
- require('../text/Label.js');
57
- require('../text/TextAction.js');
58
- require('../text/TextNotation.js');
59
58
  require('../form-field-context/FormFieldContext.js');
59
+ require('../status-indicator/StatusIndicator.js');
60
60
  require('../grid-item/GridItem.js');
61
61
  require('../grid-layout/GridLayout.js');
62
62
  require('../input/Input.js');
@@ -66,12 +66,12 @@ require('../interactable-card/InteractableCardGroupContext.js');
66
66
  require('../link-card/LinkCard.js');
67
67
  require('../list-box/ListBox.js');
68
68
  require('../list-control/ListControlContext.js');
69
- require('../menu/MenuContext.js');
70
69
  require('@floating-ui/react');
70
+ require('../menu/MenuContext.js');
71
71
  require('../menu/MenuItem.js');
72
72
  require('../menu/MenuPanel.js');
73
- require('../menu/MenuTriggerContext.js');
74
73
  require('../menu/MenuPanelContext.js');
74
+ require('../menu/MenuTriggerContext.js');
75
75
  require('../menu/MenuGroup.js');
76
76
  require('../multiline-input/MultilineInput.js');
77
77
  require('../navigation-item/NavigationItem.js');
@@ -1 +1 @@
1
- {"version":3,"file":"Link.js","sources":["../src/link/Link.tsx"],"sourcesContent":["import { ComponentType, forwardRef, ReactElement } from \"react\";\nimport { clsx } from \"clsx\";\nimport { IconProps, TearOutIcon } from \"@salt-ds/icons\";\nimport { makePrefixer } from \"../utils\";\nimport { Text, TextProps } from \"../text\";\n\nimport linkCss from \"./Link.css\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nconst withBaseName = makePrefixer(\"saltLink\");\n\n/**\n * Links are a fundamental navigation element. When clicked, they take the user to an entirely different page.\n *\n * @example\n * <LinkExample to=\"#link\">Action</LinkExample>\n */\nexport interface LinkProps extends Omit<TextProps<\"a\">, \"as\" | \"disabled\"> {\n IconComponent?: ComponentType<IconProps> | null;\n}\n\nexport const Link = forwardRef<HTMLAnchorElement, LinkProps>(function Link(\n {\n IconComponent = TearOutIcon,\n href,\n className,\n children,\n variant = \"primary\",\n color = \"primary\",\n target = \"_self\",\n ...rest\n },\n ref\n): ReactElement<LinkProps> {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-link\",\n css: linkCss,\n window: targetWindow,\n });\n\n return (\n <Text\n as=\"a\"\n className={clsx(withBaseName(), className)}\n href={href}\n ref={ref}\n target={target}\n variant={variant}\n color={color}\n {...rest}\n >\n {children}\n {target === \"_blank\" && (\n <>\n {IconComponent && (\n <IconComponent className={withBaseName(\"icon\")} aria-hidden />\n )}\n <span className={withBaseName(\"externalLinkADA\")}>External</span>\n </>\n )}\n </Text>\n );\n});\n"],"names":["makePrefixer","forwardRef","Link","TearOutIcon","useWindow","useComponentCssInjection","linkCss","jsxs","Text","clsx","Fragment","jsx"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAUA,MAAM,YAAA,GAAeA,0BAAa,UAAU,CAAA,CAAA;AAY/B,MAAA,IAAA,GAAOC,gBAAyC,CAAA,SAASC,KACpE,CAAA;AAAA,EACE,aAAgB,GAAAC,iBAAA;AAAA,EAChB,IAAA;AAAA,EACA,SAAA;AAAA,EACA,QAAA;AAAA,EACA,OAAU,GAAA,SAAA;AAAA,EACV,KAAQ,GAAA,SAAA;AAAA,EACR,MAAS,GAAA,OAAA;AAAA,EACN,GAAA,IAAA;AACL,CAAA,EACA,GACyB,EAAA;AACzB,EAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,WAAA;AAAA,IACR,GAAK,EAAAC,MAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,uBACGC,eAAA,CAAAC,SAAA,EAAA;AAAA,IACC,EAAG,EAAA,GAAA;AAAA,IACH,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,IACzC,IAAA;AAAA,IACA,GAAA;AAAA,IACA,MAAA;AAAA,IACA,OAAA;AAAA,IACA,KAAA;AAAA,IACC,GAAG,IAAA;AAAA,IAEH,QAAA,EAAA;AAAA,MAAA,QAAA;AAAA,MACA,WAAW,QACV,oBAAAF,eAAA,CAAAG,mBAAA,EAAA;AAAA,QACG,QAAA,EAAA;AAAA,UAAA,aAAA,oBACEC,cAAA,CAAA,aAAA,EAAA;AAAA,YAAc,SAAA,EAAW,aAAa,MAAM,CAAA;AAAA,YAAG,aAAW,EAAA,IAAA;AAAA,WAAC,CAAA;AAAA,0BAE7DA,cAAA,CAAA,MAAA,EAAA;AAAA,YAAK,SAAA,EAAW,aAAa,iBAAiB,CAAA;AAAA,YAAG,QAAA,EAAA,UAAA;AAAA,WAAQ,CAAA;AAAA,SAAA;AAAA,OAC5D,CAAA;AAAA,KAAA;AAAA,GAEJ,CAAA,CAAA;AAEJ,CAAC;;;;"}
1
+ {"version":3,"file":"Link.js","sources":["../src/link/Link.tsx"],"sourcesContent":["import { type IconProps, TearOutIcon } from \"@salt-ds/icons\";\nimport { clsx } from \"clsx\";\nimport { type ComponentType, type ReactElement, forwardRef } from \"react\";\nimport { Text, type TextProps } from \"../text\";\nimport { makePrefixer } from \"../utils\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport linkCss from \"./Link.css\";\n\nconst withBaseName = makePrefixer(\"saltLink\");\n\n/**\n * Links are a fundamental navigation element. When clicked, they take the user to an entirely different page.\n *\n * @example\n * <LinkExample to=\"#link\">Action</LinkExample>\n */\nexport interface LinkProps extends Omit<TextProps<\"a\">, \"as\" | \"disabled\"> {\n IconComponent?: ComponentType<IconProps> | null;\n}\n\nexport const Link = forwardRef<HTMLAnchorElement, LinkProps>(function Link(\n {\n IconComponent = TearOutIcon,\n href,\n className,\n children,\n variant = \"primary\",\n color = \"primary\",\n target = \"_self\",\n ...rest\n },\n ref,\n): ReactElement<LinkProps> {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-link\",\n css: linkCss,\n window: targetWindow,\n });\n\n return (\n <Text\n as=\"a\"\n className={clsx(withBaseName(), className)}\n href={href}\n ref={ref}\n target={target}\n variant={variant}\n color={color}\n {...rest}\n >\n {children}\n {target === \"_blank\" && (\n <>\n {IconComponent && (\n <IconComponent className={withBaseName(\"icon\")} aria-hidden />\n )}\n <span className={withBaseName(\"externalLinkADA\")}>External</span>\n </>\n )}\n </Text>\n );\n});\n"],"names":["makePrefixer","forwardRef","Link","TearOutIcon","useWindow","useComponentCssInjection","linkCss","jsxs","Text","clsx","Fragment","jsx"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAUA,MAAM,YAAA,GAAeA,0BAAa,UAAU,CAAA,CAAA;AAY/B,MAAA,IAAA,GAAOC,gBAAyC,CAAA,SAASC,KACpE,CAAA;AAAA,EACE,aAAgB,GAAAC,iBAAA;AAAA,EAChB,IAAA;AAAA,EACA,SAAA;AAAA,EACA,QAAA;AAAA,EACA,OAAU,GAAA,SAAA;AAAA,EACV,KAAQ,GAAA,SAAA;AAAA,EACR,MAAS,GAAA,OAAA;AAAA,EACN,GAAA,IAAA;AACL,CAAA,EACA,GACyB,EAAA;AACzB,EAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,WAAA;AAAA,IACR,GAAK,EAAAC,MAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,uBACGC,eAAA,CAAAC,SAAA,EAAA;AAAA,IACC,EAAG,EAAA,GAAA;AAAA,IACH,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,IACzC,IAAA;AAAA,IACA,GAAA;AAAA,IACA,MAAA;AAAA,IACA,OAAA;AAAA,IACA,KAAA;AAAA,IACC,GAAG,IAAA;AAAA,IAEH,QAAA,EAAA;AAAA,MAAA,QAAA;AAAA,MACA,WAAW,QACV,oBAAAF,eAAA,CAAAG,mBAAA,EAAA;AAAA,QACG,QAAA,EAAA;AAAA,UAAA,aAAA,oBACEC,cAAA,CAAA,aAAA,EAAA;AAAA,YAAc,SAAA,EAAW,aAAa,MAAM,CAAA;AAAA,YAAG,aAAW,EAAA,IAAA;AAAA,WAAC,CAAA;AAAA,0BAE7DA,cAAA,CAAA,MAAA,EAAA;AAAA,YAAK,SAAA,EAAW,aAAa,iBAAiB,CAAA;AAAA,YAAG,QAAA,EAAA,UAAA;AAAA,WAAQ,CAAA;AAAA,SAAA;AAAA,OAC5D,CAAA;AAAA,KAAA;AAAA,GAEJ,CAAA,CAAA;AAEJ,CAAC;;;;"}