@salt-ds/core 1.30.0 → 1.32.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 (750) hide show
  1. package/css/salt-core.css +143 -30
  2. package/dist-cjs/accordion/Accordion.js +9 -7
  3. package/dist-cjs/accordion/Accordion.js.map +1 -1
  4. package/dist-cjs/accordion/AccordionContext.js +5 -4
  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.css.js +1 -1
  9. package/dist-cjs/accordion/AccordionHeader.js +26 -12
  10. package/dist-cjs/accordion/AccordionHeader.js.map +1 -1
  11. package/dist-cjs/accordion/AccordionPanel.css.js +1 -1
  12. package/dist-cjs/accordion/AccordionPanel.js +9 -7
  13. package/dist-cjs/accordion/AccordionPanel.js.map +1 -1
  14. package/dist-cjs/aria-announcer/AriaAnnounce.js.map +1 -1
  15. package/dist-cjs/aria-announcer/AriaAnnouncerContext.js.map +1 -1
  16. package/dist-cjs/aria-announcer/AriaAnnouncerProvider.js.map +1 -1
  17. package/dist-cjs/aria-announcer/useAriaAnnouncer.js +5 -5
  18. package/dist-cjs/aria-announcer/useAriaAnnouncer.js.map +1 -1
  19. package/dist-cjs/avatar/Avatar.js +4 -4
  20. package/dist-cjs/avatar/Avatar.js.map +1 -1
  21. package/dist-cjs/avatar/useAvatarImage.js +4 -4
  22. package/dist-cjs/avatar/useAvatarImage.js.map +1 -1
  23. package/dist-cjs/badge/Badge.js +5 -5
  24. package/dist-cjs/badge/Badge.js.map +1 -1
  25. package/dist-cjs/banner/Banner.js +6 -6
  26. package/dist-cjs/banner/Banner.js.map +1 -1
  27. package/dist-cjs/banner/BannerActions.js +5 -5
  28. package/dist-cjs/banner/BannerActions.js.map +1 -1
  29. package/dist-cjs/banner/BannerContent.js +5 -5
  30. package/dist-cjs/banner/BannerContent.js.map +1 -1
  31. package/dist-cjs/border-item/BorderItem.js +7 -7
  32. package/dist-cjs/border-item/BorderItem.js.map +1 -1
  33. package/dist-cjs/border-layout/BorderLayout.js +5 -5
  34. package/dist-cjs/border-layout/BorderLayout.js.map +1 -1
  35. package/dist-cjs/breakpoints/BreakpointProvider.js +5 -5
  36. package/dist-cjs/breakpoints/BreakpointProvider.js.map +1 -1
  37. package/dist-cjs/button/Button.css.js +1 -1
  38. package/dist-cjs/button/Button.js +5 -5
  39. package/dist-cjs/button/Button.js.map +1 -1
  40. package/dist-cjs/button/useButton.js.map +1 -1
  41. package/dist-cjs/card/Card.js +42 -40
  42. package/dist-cjs/card/Card.js.map +1 -1
  43. package/dist-cjs/checkbox/Checkbox.js +6 -6
  44. package/dist-cjs/checkbox/Checkbox.js.map +1 -1
  45. package/dist-cjs/checkbox/CheckboxGroup.js +5 -5
  46. package/dist-cjs/checkbox/CheckboxGroup.js.map +1 -1
  47. package/dist-cjs/checkbox/CheckboxIcon.js +5 -5
  48. package/dist-cjs/checkbox/CheckboxIcon.js.map +1 -1
  49. package/dist-cjs/checkbox/internal/CheckboxGroupContext.js +4 -4
  50. package/dist-cjs/checkbox/internal/CheckboxGroupContext.js.map +1 -1
  51. package/dist-cjs/combo-box/ComboBox.js +22 -20
  52. package/dist-cjs/combo-box/ComboBox.js.map +1 -1
  53. package/dist-cjs/combo-box/useComboBox.js +4 -4
  54. package/dist-cjs/combo-box/useComboBox.js.map +1 -1
  55. package/dist-cjs/dialog/Dialog.js +90 -88
  56. package/dist-cjs/dialog/Dialog.js.map +1 -1
  57. package/dist-cjs/dialog/DialogActions.js +6 -6
  58. package/dist-cjs/dialog/DialogActions.js.map +1 -1
  59. package/dist-cjs/dialog/DialogCloseButton.js +7 -7
  60. package/dist-cjs/dialog/DialogCloseButton.js.map +1 -1
  61. package/dist-cjs/dialog/DialogContent.js +6 -6
  62. package/dist-cjs/dialog/DialogContent.js.map +1 -1
  63. package/dist-cjs/dialog/DialogContext.js.map +1 -1
  64. package/dist-cjs/dialog/DialogHeader.js +5 -5
  65. package/dist-cjs/dialog/DialogHeader.js.map +1 -1
  66. package/dist-cjs/divider/Divider.js +6 -6
  67. package/dist-cjs/divider/Divider.js.map +1 -1
  68. package/dist-cjs/drawer/Drawer.js +76 -74
  69. package/dist-cjs/drawer/Drawer.js.map +1 -1
  70. package/dist-cjs/drawer/DrawerCloseButton.js +7 -7
  71. package/dist-cjs/drawer/DrawerCloseButton.js.map +1 -1
  72. package/dist-cjs/dropdown/Dropdown.css.js +1 -1
  73. package/dist-cjs/dropdown/Dropdown.js +22 -17
  74. package/dist-cjs/dropdown/Dropdown.js.map +1 -1
  75. package/dist-cjs/file-drop-zone/FileDropZone.js +5 -5
  76. package/dist-cjs/file-drop-zone/FileDropZone.js.map +1 -1
  77. package/dist-cjs/file-drop-zone/FileDropZoneIcon.js +1 -1
  78. package/dist-cjs/file-drop-zone/FileDropZoneIcon.js.map +1 -1
  79. package/dist-cjs/file-drop-zone/FileDropZoneTrigger.js +6 -5
  80. package/dist-cjs/file-drop-zone/FileDropZoneTrigger.js.map +1 -1
  81. package/dist-cjs/file-drop-zone/internal/utils.js.map +1 -1
  82. package/dist-cjs/flex-item/FlexItem.js +8 -8
  83. package/dist-cjs/flex-item/FlexItem.js.map +1 -1
  84. package/dist-cjs/flex-layout/FlexLayout.js +5 -5
  85. package/dist-cjs/flex-layout/FlexLayout.js.map +1 -1
  86. package/dist-cjs/flow-layout/FlowLayout.js.map +1 -1
  87. package/dist-cjs/form-field/FormField.js +4 -4
  88. package/dist-cjs/form-field/FormField.js.map +1 -1
  89. package/dist-cjs/form-field/FormFieldHelperText.js +5 -5
  90. package/dist-cjs/form-field/FormFieldHelperText.js.map +1 -1
  91. package/dist-cjs/form-field/FormFieldLabel.js +3 -3
  92. package/dist-cjs/form-field/FormFieldLabel.js.map +1 -1
  93. package/dist-cjs/form-field-context/FormFieldContext.js +3 -3
  94. package/dist-cjs/form-field-context/FormFieldContext.js.map +1 -1
  95. package/dist-cjs/form-field-context/useFormFieldProps.js.map +1 -1
  96. package/dist-cjs/grid-item/GridItem.js +8 -8
  97. package/dist-cjs/grid-item/GridItem.js.map +1 -1
  98. package/dist-cjs/grid-layout/GridLayout.js +5 -5
  99. package/dist-cjs/grid-layout/GridLayout.js.map +1 -1
  100. package/dist-cjs/index.js +7 -0
  101. package/dist-cjs/index.js.map +1 -1
  102. package/dist-cjs/input/Input.js +5 -5
  103. package/dist-cjs/input/Input.js.map +1 -1
  104. package/dist-cjs/interactable-card/InteractableCard.js +9 -9
  105. package/dist-cjs/interactable-card/InteractableCard.js.map +1 -1
  106. package/dist-cjs/interactable-card/InteractableCardGroup.js +18 -14
  107. package/dist-cjs/interactable-card/InteractableCardGroup.js.map +1 -1
  108. package/dist-cjs/interactable-card/InteractableCardGroupContext.js +4 -4
  109. package/dist-cjs/interactable-card/InteractableCardGroupContext.js.map +1 -1
  110. package/dist-cjs/interactable-card/useInteractableCard.js +1 -1
  111. package/dist-cjs/interactable-card/useInteractableCard.js.map +1 -1
  112. package/dist-cjs/link/Link.js +12 -12
  113. package/dist-cjs/link/Link.js.map +1 -1
  114. package/dist-cjs/link-card/LinkCard.js +5 -5
  115. package/dist-cjs/link-card/LinkCard.js.map +1 -1
  116. package/dist-cjs/list-box/ListBox.js +10 -10
  117. package/dist-cjs/list-box/ListBox.js.map +1 -1
  118. package/dist-cjs/list-control/ListControlContext.js +4 -4
  119. package/dist-cjs/list-control/ListControlContext.js.map +1 -1
  120. package/dist-cjs/list-control/ListControlState.js +9 -9
  121. package/dist-cjs/list-control/ListControlState.js.map +1 -1
  122. package/dist-cjs/menu/Menu.js +1 -1
  123. package/dist-cjs/menu/Menu.js.map +1 -1
  124. package/dist-cjs/menu/MenuBase.js +7 -7
  125. package/dist-cjs/menu/MenuBase.js.map +1 -1
  126. package/dist-cjs/menu/MenuContext.js +3 -3
  127. package/dist-cjs/menu/MenuContext.js.map +1 -1
  128. package/dist-cjs/menu/MenuGroup.js +6 -6
  129. package/dist-cjs/menu/MenuGroup.js.map +1 -1
  130. package/dist-cjs/menu/MenuItem.js +8 -8
  131. package/dist-cjs/menu/MenuItem.js.map +1 -1
  132. package/dist-cjs/menu/MenuPanel.css.js +1 -1
  133. package/dist-cjs/menu/MenuPanel.js +7 -7
  134. package/dist-cjs/menu/MenuPanel.js.map +1 -1
  135. package/dist-cjs/menu/MenuPanelBase.js +2 -2
  136. package/dist-cjs/menu/MenuPanelBase.js.map +1 -1
  137. package/dist-cjs/menu/MenuPanelContext.js +3 -3
  138. package/dist-cjs/menu/MenuPanelContext.js.map +1 -1
  139. package/dist-cjs/menu/MenuTrigger.js +8 -7
  140. package/dist-cjs/menu/MenuTrigger.js.map +1 -1
  141. package/dist-cjs/menu/MenuTriggerContext.js +3 -3
  142. package/dist-cjs/menu/MenuTriggerContext.js.map +1 -1
  143. package/dist-cjs/multiline-input/MultilineInput.js +4 -4
  144. package/dist-cjs/multiline-input/MultilineInput.js.map +1 -1
  145. package/dist-cjs/navigation-item/ConditionalWrapper.js +1 -0
  146. package/dist-cjs/navigation-item/ConditionalWrapper.js.map +1 -1
  147. package/dist-cjs/navigation-item/ExpansionIcon.js.map +1 -1
  148. package/dist-cjs/navigation-item/NavigationItem.js +6 -6
  149. package/dist-cjs/navigation-item/NavigationItem.js.map +1 -1
  150. package/dist-cjs/option/Option.js +95 -93
  151. package/dist-cjs/option/Option.js.map +1 -1
  152. package/dist-cjs/option/OptionGroup.js +6 -6
  153. package/dist-cjs/option/OptionGroup.js.map +1 -1
  154. package/dist-cjs/option/OptionList.css.js +1 -1
  155. package/dist-cjs/option/OptionList.js +5 -5
  156. package/dist-cjs/option/OptionList.js.map +1 -1
  157. package/dist-cjs/option/OptionListBase.js +6 -6
  158. package/dist-cjs/option/OptionListBase.js.map +1 -1
  159. package/dist-cjs/overlay/Overlay.js +5 -5
  160. package/dist-cjs/overlay/Overlay.js.map +1 -1
  161. package/dist-cjs/overlay/OverlayContext.js +5 -5
  162. package/dist-cjs/overlay/OverlayContext.js.map +1 -1
  163. package/dist-cjs/overlay/OverlayPanel.js +7 -7
  164. package/dist-cjs/overlay/OverlayPanel.js.map +1 -1
  165. package/dist-cjs/overlay/OverlayPanelCloseButton.js +8 -8
  166. package/dist-cjs/overlay/OverlayPanelCloseButton.js.map +1 -1
  167. package/dist-cjs/overlay/OverlayPanelContent.js +5 -5
  168. package/dist-cjs/overlay/OverlayPanelContent.js.map +1 -1
  169. package/dist-cjs/overlay/OverlayTrigger.js +7 -9
  170. package/dist-cjs/overlay/OverlayTrigger.js.map +1 -1
  171. package/dist-cjs/pagination/CompactInput.js +5 -5
  172. package/dist-cjs/pagination/CompactInput.js.map +1 -1
  173. package/dist-cjs/pagination/CompactPaginator.js +5 -5
  174. package/dist-cjs/pagination/CompactPaginator.js.map +1 -1
  175. package/dist-cjs/pagination/GoToInput.js +5 -5
  176. package/dist-cjs/pagination/GoToInput.js.map +1 -1
  177. package/dist-cjs/pagination/PageButton.js +5 -5
  178. package/dist-cjs/pagination/PageButton.js.map +1 -1
  179. package/dist-cjs/pagination/PageRanges.js +5 -5
  180. package/dist-cjs/pagination/PageRanges.js.map +1 -1
  181. package/dist-cjs/pagination/Pagination.js +7 -7
  182. package/dist-cjs/pagination/Pagination.js.map +1 -1
  183. package/dist-cjs/pagination/PaginationContext.js.map +1 -1
  184. package/dist-cjs/pagination/Paginator.js +4 -4
  185. package/dist-cjs/pagination/Paginator.js.map +1 -1
  186. package/dist-cjs/pagination/usePagination.js.map +1 -1
  187. package/dist-cjs/pagination/usePaginationContext.js +1 -1
  188. package/dist-cjs/pagination/usePaginationContext.js.map +1 -1
  189. package/dist-cjs/panel/Panel.js +4 -4
  190. package/dist-cjs/panel/Panel.js.map +1 -1
  191. package/dist-cjs/parent-child-layout/ParentChildLayout.js +5 -5
  192. package/dist-cjs/parent-child-layout/ParentChildLayout.js.map +1 -1
  193. package/dist-cjs/parent-child-layout/useIsViewportLargerThanBreakpoint.js +4 -4
  194. package/dist-cjs/parent-child-layout/useIsViewportLargerThanBreakpoint.js.map +1 -1
  195. package/dist-cjs/pill/Pill.js +9 -9
  196. package/dist-cjs/pill/Pill.js.map +1 -1
  197. package/dist-cjs/pill-input/PillInput.css.js +1 -1
  198. package/dist-cjs/pill-input/PillInput.js +16 -14
  199. package/dist-cjs/pill-input/PillInput.js.map +1 -1
  200. package/dist-cjs/pill-input/useTruncatePills.js +7 -3
  201. package/dist-cjs/pill-input/useTruncatePills.js.map +1 -1
  202. package/dist-cjs/progress/CircularProgress/CircularProgress.js +13 -13
  203. package/dist-cjs/progress/CircularProgress/CircularProgress.js.map +1 -1
  204. package/dist-cjs/progress/LinearProgress/LinearProgress.css.js +1 -1
  205. package/dist-cjs/progress/LinearProgress/LinearProgress.js +30 -25
  206. package/dist-cjs/progress/LinearProgress/LinearProgress.js.map +1 -1
  207. package/dist-cjs/radio-button/RadioButton.js +7 -7
  208. package/dist-cjs/radio-button/RadioButton.js.map +1 -1
  209. package/dist-cjs/radio-button/RadioButtonGroup.js +5 -5
  210. package/dist-cjs/radio-button/RadioButtonGroup.js.map +1 -1
  211. package/dist-cjs/radio-button/RadioButtonIcon.js +6 -6
  212. package/dist-cjs/radio-button/RadioButtonIcon.js.map +1 -1
  213. package/dist-cjs/radio-button/internal/RadioGroupContext.js +4 -4
  214. package/dist-cjs/radio-button/internal/RadioGroupContext.js.map +1 -1
  215. package/dist-cjs/salt-provider/SaltProvider.js +46 -40
  216. package/dist-cjs/salt-provider/SaltProvider.js.map +1 -1
  217. package/dist-cjs/scrim/Scrim.js +4 -4
  218. package/dist-cjs/scrim/Scrim.js.map +1 -1
  219. package/dist-cjs/segmented-button-group/SegmentedButtonGroup.js +6 -6
  220. package/dist-cjs/segmented-button-group/SegmentedButtonGroup.js.map +1 -1
  221. package/dist-cjs/spinner/Spinner.js +4 -4
  222. package/dist-cjs/spinner/Spinner.js.map +1 -1
  223. package/dist-cjs/spinner/svgSpinners/SpinnerSVG.js +4 -4
  224. package/dist-cjs/spinner/svgSpinners/SpinnerSVG.js.map +1 -1
  225. package/dist-cjs/split-layout/SplitLayout.js +6 -6
  226. package/dist-cjs/split-layout/SplitLayout.js.map +1 -1
  227. package/dist-cjs/stack-layout/StackLayout.js +8 -8
  228. package/dist-cjs/stack-layout/StackLayout.js.map +1 -1
  229. package/dist-cjs/status-adornment/ErrorAdornment.js.map +1 -1
  230. package/dist-cjs/status-adornment/StatusAdornment.js +5 -5
  231. package/dist-cjs/status-adornment/StatusAdornment.js.map +1 -1
  232. package/dist-cjs/status-adornment/SuccessAdornment.js.map +1 -1
  233. package/dist-cjs/status-adornment/WarningAdornment.js.map +1 -1
  234. package/dist-cjs/status-indicator/StatusIndicator.js +3 -3
  235. package/dist-cjs/status-indicator/StatusIndicator.js.map +1 -1
  236. package/dist-cjs/switch/Switch.js +101 -99
  237. package/dist-cjs/switch/Switch.js.map +1 -1
  238. package/dist-cjs/tag/Tag.js +5 -5
  239. package/dist-cjs/tag/Tag.js.map +1 -1
  240. package/dist-cjs/text/Code.js.map +1 -1
  241. package/dist-cjs/text/Display.js.map +1 -1
  242. package/dist-cjs/text/Headings.js.map +1 -1
  243. package/dist-cjs/text/Label.js.map +1 -1
  244. package/dist-cjs/text/Text.js +5 -5
  245. package/dist-cjs/text/Text.js.map +1 -1
  246. package/dist-cjs/text/TextAction.js.map +1 -1
  247. package/dist-cjs/text/TextNotation.js.map +1 -1
  248. package/dist-cjs/theme/Accent.js +3 -1
  249. package/dist-cjs/theme/Accent.js.map +1 -1
  250. package/dist-cjs/theme/ActionFont.js +3 -1
  251. package/dist-cjs/theme/ActionFont.js.map +1 -1
  252. package/dist-cjs/theme/Corner.js +3 -1
  253. package/dist-cjs/theme/Corner.js.map +1 -1
  254. package/dist-cjs/theme/HeadingFont.js +3 -1
  255. package/dist-cjs/theme/HeadingFont.js.map +1 -1
  256. package/dist-cjs/theme/Theme.js.map +1 -1
  257. package/dist-cjs/toast/Toast.js +33 -31
  258. package/dist-cjs/toast/Toast.js.map +1 -1
  259. package/dist-cjs/toast/ToastContent.js +5 -5
  260. package/dist-cjs/toast/ToastContent.js.map +1 -1
  261. package/dist-cjs/toggle-button/ToggleButton.js +6 -6
  262. package/dist-cjs/toggle-button/ToggleButton.js.map +1 -1
  263. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js +10 -10
  264. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js.map +1 -1
  265. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js +4 -4
  266. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js.map +1 -1
  267. package/dist-cjs/tooltip/Tooltip.css.js +1 -1
  268. package/dist-cjs/tooltip/Tooltip.js +8 -10
  269. package/dist-cjs/tooltip/Tooltip.js.map +1 -1
  270. package/dist-cjs/tooltip/TooltipBase.js +5 -5
  271. package/dist-cjs/tooltip/TooltipBase.js.map +1 -1
  272. package/dist-cjs/tooltip/useAriaAnnounce.js +10 -7
  273. package/dist-cjs/tooltip/useAriaAnnounce.js.map +1 -1
  274. package/dist-cjs/tooltip/useTooltip.js +3 -3
  275. package/dist-cjs/tooltip/useTooltip.js.map +1 -1
  276. package/dist-cjs/utils/createChainedFunction.js.map +1 -1
  277. package/dist-cjs/utils/createContext.js.map +1 -1
  278. package/dist-cjs/utils/debounce.js.map +1 -1
  279. package/dist-cjs/utils/getRefFromChildren.js +15 -0
  280. package/dist-cjs/utils/getRefFromChildren.js.map +1 -0
  281. package/dist-cjs/utils/marginMiddleware.js.map +1 -1
  282. package/dist-cjs/utils/mergeProps.js.map +1 -1
  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 +4 -4
  299. package/dist-cjs/utils/useValueEffect.js.map +1 -1
  300. package/dist-cjs/viewport/ViewportProvider.js +4 -4
  301. package/dist-cjs/viewport/ViewportProvider.js.map +1 -1
  302. package/dist-es/accordion/Accordion.js +9 -7
  303. package/dist-es/accordion/Accordion.js.map +1 -1
  304. package/dist-es/accordion/AccordionContext.js +5 -4
  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.css.js +1 -1
  309. package/dist-es/accordion/AccordionHeader.js +26 -12
  310. package/dist-es/accordion/AccordionHeader.js.map +1 -1
  311. package/dist-es/accordion/AccordionPanel.css.js +1 -1
  312. package/dist-es/accordion/AccordionPanel.js +9 -7
  313. package/dist-es/accordion/AccordionPanel.js.map +1 -1
  314. package/dist-es/aria-announcer/AriaAnnounce.js.map +1 -1
  315. package/dist-es/aria-announcer/AriaAnnouncerContext.js.map +1 -1
  316. package/dist-es/aria-announcer/AriaAnnouncerProvider.js.map +1 -1
  317. package/dist-es/aria-announcer/useAriaAnnouncer.js +5 -5
  318. package/dist-es/aria-announcer/useAriaAnnouncer.js.map +1 -1
  319. package/dist-es/avatar/Avatar.js +4 -4
  320. package/dist-es/avatar/Avatar.js.map +1 -1
  321. package/dist-es/avatar/useAvatarImage.js +4 -4
  322. package/dist-es/avatar/useAvatarImage.js.map +1 -1
  323. package/dist-es/badge/Badge.js +5 -5
  324. package/dist-es/badge/Badge.js.map +1 -1
  325. package/dist-es/banner/Banner.js +6 -6
  326. package/dist-es/banner/Banner.js.map +1 -1
  327. package/dist-es/banner/BannerActions.js +5 -5
  328. package/dist-es/banner/BannerActions.js.map +1 -1
  329. package/dist-es/banner/BannerContent.js +5 -5
  330. package/dist-es/banner/BannerContent.js.map +1 -1
  331. package/dist-es/border-item/BorderItem.js +7 -7
  332. package/dist-es/border-item/BorderItem.js.map +1 -1
  333. package/dist-es/border-layout/BorderLayout.js +5 -5
  334. package/dist-es/border-layout/BorderLayout.js.map +1 -1
  335. package/dist-es/breakpoints/BreakpointProvider.js +5 -5
  336. package/dist-es/breakpoints/BreakpointProvider.js.map +1 -1
  337. package/dist-es/button/Button.css.js +1 -1
  338. package/dist-es/button/Button.js +5 -5
  339. package/dist-es/button/Button.js.map +1 -1
  340. package/dist-es/button/useButton.js.map +1 -1
  341. package/dist-es/card/Card.js +42 -40
  342. package/dist-es/card/Card.js.map +1 -1
  343. package/dist-es/checkbox/Checkbox.js +6 -6
  344. package/dist-es/checkbox/Checkbox.js.map +1 -1
  345. package/dist-es/checkbox/CheckboxGroup.js +5 -5
  346. package/dist-es/checkbox/CheckboxGroup.js.map +1 -1
  347. package/dist-es/checkbox/CheckboxIcon.js +5 -5
  348. package/dist-es/checkbox/CheckboxIcon.js.map +1 -1
  349. package/dist-es/checkbox/internal/CheckboxGroupContext.js +4 -4
  350. package/dist-es/checkbox/internal/CheckboxGroupContext.js.map +1 -1
  351. package/dist-es/combo-box/ComboBox.js +22 -20
  352. package/dist-es/combo-box/ComboBox.js.map +1 -1
  353. package/dist-es/combo-box/useComboBox.js +4 -4
  354. package/dist-es/combo-box/useComboBox.js.map +1 -1
  355. package/dist-es/dialog/Dialog.js +90 -88
  356. package/dist-es/dialog/Dialog.js.map +1 -1
  357. package/dist-es/dialog/DialogActions.js +6 -6
  358. package/dist-es/dialog/DialogActions.js.map +1 -1
  359. package/dist-es/dialog/DialogCloseButton.js +7 -7
  360. package/dist-es/dialog/DialogCloseButton.js.map +1 -1
  361. package/dist-es/dialog/DialogContent.js +6 -6
  362. package/dist-es/dialog/DialogContent.js.map +1 -1
  363. package/dist-es/dialog/DialogContext.js.map +1 -1
  364. package/dist-es/dialog/DialogHeader.js +5 -5
  365. package/dist-es/dialog/DialogHeader.js.map +1 -1
  366. package/dist-es/divider/Divider.js +6 -6
  367. package/dist-es/divider/Divider.js.map +1 -1
  368. package/dist-es/drawer/Drawer.js +76 -74
  369. package/dist-es/drawer/Drawer.js.map +1 -1
  370. package/dist-es/drawer/DrawerCloseButton.js +7 -7
  371. package/dist-es/drawer/DrawerCloseButton.js.map +1 -1
  372. package/dist-es/dropdown/Dropdown.css.js +1 -1
  373. package/dist-es/dropdown/Dropdown.js +22 -17
  374. package/dist-es/dropdown/Dropdown.js.map +1 -1
  375. package/dist-es/file-drop-zone/FileDropZone.js +5 -5
  376. package/dist-es/file-drop-zone/FileDropZone.js.map +1 -1
  377. package/dist-es/file-drop-zone/FileDropZoneIcon.js +1 -1
  378. package/dist-es/file-drop-zone/FileDropZoneIcon.js.map +1 -1
  379. package/dist-es/file-drop-zone/FileDropZoneTrigger.js +6 -5
  380. package/dist-es/file-drop-zone/FileDropZoneTrigger.js.map +1 -1
  381. package/dist-es/file-drop-zone/internal/utils.js.map +1 -1
  382. package/dist-es/flex-item/FlexItem.js +8 -8
  383. package/dist-es/flex-item/FlexItem.js.map +1 -1
  384. package/dist-es/flex-layout/FlexLayout.js +5 -5
  385. package/dist-es/flex-layout/FlexLayout.js.map +1 -1
  386. package/dist-es/flow-layout/FlowLayout.js.map +1 -1
  387. package/dist-es/form-field/FormField.js +4 -4
  388. package/dist-es/form-field/FormField.js.map +1 -1
  389. package/dist-es/form-field/FormFieldHelperText.js +5 -5
  390. package/dist-es/form-field/FormFieldHelperText.js.map +1 -1
  391. package/dist-es/form-field/FormFieldLabel.js +3 -3
  392. package/dist-es/form-field/FormFieldLabel.js.map +1 -1
  393. package/dist-es/form-field-context/FormFieldContext.js +3 -3
  394. package/dist-es/form-field-context/FormFieldContext.js.map +1 -1
  395. package/dist-es/form-field-context/useFormFieldProps.js.map +1 -1
  396. package/dist-es/grid-item/GridItem.js +8 -8
  397. package/dist-es/grid-item/GridItem.js.map +1 -1
  398. package/dist-es/grid-layout/GridLayout.js +5 -5
  399. package/dist-es/grid-layout/GridLayout.js.map +1 -1
  400. package/dist-es/index.js +6 -5
  401. package/dist-es/index.js.map +1 -1
  402. package/dist-es/input/Input.js +5 -5
  403. package/dist-es/input/Input.js.map +1 -1
  404. package/dist-es/interactable-card/InteractableCard.js +9 -9
  405. package/dist-es/interactable-card/InteractableCard.js.map +1 -1
  406. package/dist-es/interactable-card/InteractableCardGroup.js +18 -14
  407. package/dist-es/interactable-card/InteractableCardGroup.js.map +1 -1
  408. package/dist-es/interactable-card/InteractableCardGroupContext.js +4 -4
  409. package/dist-es/interactable-card/InteractableCardGroupContext.js.map +1 -1
  410. package/dist-es/interactable-card/useInteractableCard.js +1 -1
  411. package/dist-es/interactable-card/useInteractableCard.js.map +1 -1
  412. package/dist-es/link/Link.js +12 -12
  413. package/dist-es/link/Link.js.map +1 -1
  414. package/dist-es/link-card/LinkCard.js +5 -5
  415. package/dist-es/link-card/LinkCard.js.map +1 -1
  416. package/dist-es/list-box/ListBox.js +10 -10
  417. package/dist-es/list-box/ListBox.js.map +1 -1
  418. package/dist-es/list-control/ListControlContext.js +4 -4
  419. package/dist-es/list-control/ListControlContext.js.map +1 -1
  420. package/dist-es/list-control/ListControlState.js +9 -9
  421. package/dist-es/list-control/ListControlState.js.map +1 -1
  422. package/dist-es/menu/Menu.js +1 -1
  423. package/dist-es/menu/Menu.js.map +1 -1
  424. package/dist-es/menu/MenuBase.js +7 -7
  425. package/dist-es/menu/MenuBase.js.map +1 -1
  426. package/dist-es/menu/MenuContext.js +3 -3
  427. package/dist-es/menu/MenuContext.js.map +1 -1
  428. package/dist-es/menu/MenuGroup.js +6 -6
  429. package/dist-es/menu/MenuGroup.js.map +1 -1
  430. package/dist-es/menu/MenuItem.js +8 -8
  431. package/dist-es/menu/MenuItem.js.map +1 -1
  432. package/dist-es/menu/MenuPanel.css.js +1 -1
  433. package/dist-es/menu/MenuPanel.js +7 -7
  434. package/dist-es/menu/MenuPanel.js.map +1 -1
  435. package/dist-es/menu/MenuPanelBase.js +2 -2
  436. package/dist-es/menu/MenuPanelBase.js.map +1 -1
  437. package/dist-es/menu/MenuPanelContext.js +3 -3
  438. package/dist-es/menu/MenuPanelContext.js.map +1 -1
  439. package/dist-es/menu/MenuTrigger.js +8 -7
  440. package/dist-es/menu/MenuTrigger.js.map +1 -1
  441. package/dist-es/menu/MenuTriggerContext.js +3 -3
  442. package/dist-es/menu/MenuTriggerContext.js.map +1 -1
  443. package/dist-es/multiline-input/MultilineInput.js +4 -4
  444. package/dist-es/multiline-input/MultilineInput.js.map +1 -1
  445. package/dist-es/navigation-item/ConditionalWrapper.js +1 -0
  446. package/dist-es/navigation-item/ConditionalWrapper.js.map +1 -1
  447. package/dist-es/navigation-item/ExpansionIcon.js.map +1 -1
  448. package/dist-es/navigation-item/NavigationItem.js +6 -6
  449. package/dist-es/navigation-item/NavigationItem.js.map +1 -1
  450. package/dist-es/option/Option.js +95 -93
  451. package/dist-es/option/Option.js.map +1 -1
  452. package/dist-es/option/OptionGroup.js +6 -6
  453. package/dist-es/option/OptionGroup.js.map +1 -1
  454. package/dist-es/option/OptionList.css.js +1 -1
  455. package/dist-es/option/OptionList.js +5 -5
  456. package/dist-es/option/OptionList.js.map +1 -1
  457. package/dist-es/option/OptionListBase.js +6 -6
  458. package/dist-es/option/OptionListBase.js.map +1 -1
  459. package/dist-es/overlay/Overlay.js +5 -5
  460. package/dist-es/overlay/Overlay.js.map +1 -1
  461. package/dist-es/overlay/OverlayContext.js +5 -5
  462. package/dist-es/overlay/OverlayContext.js.map +1 -1
  463. package/dist-es/overlay/OverlayPanel.js +7 -7
  464. package/dist-es/overlay/OverlayPanel.js.map +1 -1
  465. package/dist-es/overlay/OverlayPanelCloseButton.js +8 -8
  466. package/dist-es/overlay/OverlayPanelCloseButton.js.map +1 -1
  467. package/dist-es/overlay/OverlayPanelContent.js +5 -5
  468. package/dist-es/overlay/OverlayPanelContent.js.map +1 -1
  469. package/dist-es/overlay/OverlayTrigger.js +7 -9
  470. package/dist-es/overlay/OverlayTrigger.js.map +1 -1
  471. package/dist-es/pagination/CompactInput.js +5 -5
  472. package/dist-es/pagination/CompactInput.js.map +1 -1
  473. package/dist-es/pagination/CompactPaginator.js +5 -5
  474. package/dist-es/pagination/CompactPaginator.js.map +1 -1
  475. package/dist-es/pagination/GoToInput.js +5 -5
  476. package/dist-es/pagination/GoToInput.js.map +1 -1
  477. package/dist-es/pagination/PageButton.js +5 -5
  478. package/dist-es/pagination/PageButton.js.map +1 -1
  479. package/dist-es/pagination/PageRanges.js +5 -5
  480. package/dist-es/pagination/PageRanges.js.map +1 -1
  481. package/dist-es/pagination/Pagination.js +7 -7
  482. package/dist-es/pagination/Pagination.js.map +1 -1
  483. package/dist-es/pagination/PaginationContext.js.map +1 -1
  484. package/dist-es/pagination/Paginator.js +4 -4
  485. package/dist-es/pagination/Paginator.js.map +1 -1
  486. package/dist-es/pagination/usePagination.js.map +1 -1
  487. package/dist-es/pagination/usePaginationContext.js +1 -1
  488. package/dist-es/pagination/usePaginationContext.js.map +1 -1
  489. package/dist-es/panel/Panel.js +4 -4
  490. package/dist-es/panel/Panel.js.map +1 -1
  491. package/dist-es/parent-child-layout/ParentChildLayout.js +5 -5
  492. package/dist-es/parent-child-layout/ParentChildLayout.js.map +1 -1
  493. package/dist-es/parent-child-layout/useIsViewportLargerThanBreakpoint.js +4 -4
  494. package/dist-es/parent-child-layout/useIsViewportLargerThanBreakpoint.js.map +1 -1
  495. package/dist-es/pill/Pill.js +9 -9
  496. package/dist-es/pill/Pill.js.map +1 -1
  497. package/dist-es/pill-input/PillInput.css.js +1 -1
  498. package/dist-es/pill-input/PillInput.js +16 -14
  499. package/dist-es/pill-input/PillInput.js.map +1 -1
  500. package/dist-es/pill-input/useTruncatePills.js +7 -3
  501. package/dist-es/pill-input/useTruncatePills.js.map +1 -1
  502. package/dist-es/progress/CircularProgress/CircularProgress.js +13 -13
  503. package/dist-es/progress/CircularProgress/CircularProgress.js.map +1 -1
  504. package/dist-es/progress/LinearProgress/LinearProgress.css.js +1 -1
  505. package/dist-es/progress/LinearProgress/LinearProgress.js +30 -25
  506. package/dist-es/progress/LinearProgress/LinearProgress.js.map +1 -1
  507. package/dist-es/radio-button/RadioButton.js +7 -7
  508. package/dist-es/radio-button/RadioButton.js.map +1 -1
  509. package/dist-es/radio-button/RadioButtonGroup.js +5 -5
  510. package/dist-es/radio-button/RadioButtonGroup.js.map +1 -1
  511. package/dist-es/radio-button/RadioButtonIcon.js +6 -6
  512. package/dist-es/radio-button/RadioButtonIcon.js.map +1 -1
  513. package/dist-es/radio-button/internal/RadioGroupContext.js +4 -4
  514. package/dist-es/radio-button/internal/RadioGroupContext.js.map +1 -1
  515. package/dist-es/salt-provider/SaltProvider.js +46 -41
  516. package/dist-es/salt-provider/SaltProvider.js.map +1 -1
  517. package/dist-es/scrim/Scrim.js +4 -4
  518. package/dist-es/scrim/Scrim.js.map +1 -1
  519. package/dist-es/segmented-button-group/SegmentedButtonGroup.js +6 -6
  520. package/dist-es/segmented-button-group/SegmentedButtonGroup.js.map +1 -1
  521. package/dist-es/spinner/Spinner.js +4 -4
  522. package/dist-es/spinner/Spinner.js.map +1 -1
  523. package/dist-es/spinner/svgSpinners/SpinnerSVG.js +4 -4
  524. package/dist-es/spinner/svgSpinners/SpinnerSVG.js.map +1 -1
  525. package/dist-es/split-layout/SplitLayout.js +6 -6
  526. package/dist-es/split-layout/SplitLayout.js.map +1 -1
  527. package/dist-es/stack-layout/StackLayout.js +8 -8
  528. package/dist-es/stack-layout/StackLayout.js.map +1 -1
  529. package/dist-es/status-adornment/ErrorAdornment.js.map +1 -1
  530. package/dist-es/status-adornment/StatusAdornment.js +5 -5
  531. package/dist-es/status-adornment/StatusAdornment.js.map +1 -1
  532. package/dist-es/status-adornment/SuccessAdornment.js.map +1 -1
  533. package/dist-es/status-adornment/WarningAdornment.js.map +1 -1
  534. package/dist-es/status-indicator/StatusIndicator.js +3 -3
  535. package/dist-es/status-indicator/StatusIndicator.js.map +1 -1
  536. package/dist-es/switch/Switch.js +101 -99
  537. package/dist-es/switch/Switch.js.map +1 -1
  538. package/dist-es/tag/Tag.js +5 -5
  539. package/dist-es/tag/Tag.js.map +1 -1
  540. package/dist-es/text/Code.js.map +1 -1
  541. package/dist-es/text/Display.js.map +1 -1
  542. package/dist-es/text/Headings.js.map +1 -1
  543. package/dist-es/text/Label.js.map +1 -1
  544. package/dist-es/text/Text.js +5 -5
  545. package/dist-es/text/Text.js.map +1 -1
  546. package/dist-es/text/TextAction.js.map +1 -1
  547. package/dist-es/text/TextNotation.js.map +1 -1
  548. package/dist-es/theme/Accent.js +3 -2
  549. package/dist-es/theme/Accent.js.map +1 -1
  550. package/dist-es/theme/ActionFont.js +3 -2
  551. package/dist-es/theme/ActionFont.js.map +1 -1
  552. package/dist-es/theme/Corner.js +3 -2
  553. package/dist-es/theme/Corner.js.map +1 -1
  554. package/dist-es/theme/HeadingFont.js +3 -2
  555. package/dist-es/theme/HeadingFont.js.map +1 -1
  556. package/dist-es/theme/Theme.js.map +1 -1
  557. package/dist-es/toast/Toast.js +33 -31
  558. package/dist-es/toast/Toast.js.map +1 -1
  559. package/dist-es/toast/ToastContent.js +5 -5
  560. package/dist-es/toast/ToastContent.js.map +1 -1
  561. package/dist-es/toggle-button/ToggleButton.js +6 -6
  562. package/dist-es/toggle-button/ToggleButton.js.map +1 -1
  563. package/dist-es/toggle-button-group/ToggleButtonGroup.js +10 -10
  564. package/dist-es/toggle-button-group/ToggleButtonGroup.js.map +1 -1
  565. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js +4 -4
  566. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js.map +1 -1
  567. package/dist-es/tooltip/Tooltip.css.js +1 -1
  568. package/dist-es/tooltip/Tooltip.js +8 -10
  569. package/dist-es/tooltip/Tooltip.js.map +1 -1
  570. package/dist-es/tooltip/TooltipBase.js +5 -5
  571. package/dist-es/tooltip/TooltipBase.js.map +1 -1
  572. package/dist-es/tooltip/useAriaAnnounce.js +10 -7
  573. package/dist-es/tooltip/useAriaAnnounce.js.map +1 -1
  574. package/dist-es/tooltip/useTooltip.js +3 -3
  575. package/dist-es/tooltip/useTooltip.js.map +1 -1
  576. package/dist-es/utils/createChainedFunction.js.map +1 -1
  577. package/dist-es/utils/createContext.js.map +1 -1
  578. package/dist-es/utils/debounce.js.map +1 -1
  579. package/dist-es/utils/getRefFromChildren.js +11 -0
  580. package/dist-es/utils/getRefFromChildren.js.map +1 -0
  581. package/dist-es/utils/marginMiddleware.js.map +1 -1
  582. package/dist-es/utils/mergeProps.js.map +1 -1
  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 +4 -4
  599. package/dist-es/utils/useValueEffect.js.map +1 -1
  600. package/dist-es/viewport/ViewportProvider.js +4 -4
  601. package/dist-es/viewport/ViewportProvider.js.map +1 -1
  602. package/dist-types/accordion/Accordion.d.ts +6 -2
  603. package/dist-types/accordion/AccordionContext.d.ts +2 -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 +10 -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 +2 -2
  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/ConditionalWrapper.d.ts +3 -3
  671. package/dist-types/navigation-item/ExpansionIcon.d.ts +2 -2
  672. package/dist-types/navigation-item/NavigationItem.d.ts +1 -1
  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 +1 -1
  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 +4 -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 +61 -19
  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 +1 -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/setRef.d.ts +1 -1
  740. package/dist-types/utils/useControlled.d.ts +1 -1
  741. package/dist-types/utils/useFloatingUI/useFloatingUI.d.ts +4 -4
  742. package/dist-types/utils/useForkRef.d.ts +1 -1
  743. package/dist-types/utils/useIsFocusVisible.d.ts +1 -1
  744. package/dist-types/utils/useIsomorphicLayoutEffect.d.ts +2 -2
  745. package/dist-types/utils/usePrevious.d.ts +1 -1
  746. package/dist-types/utils/useResizeObserver.d.ts +1 -1
  747. package/dist-types/utils/useResponsiveProp.d.ts +1 -1
  748. package/dist-types/utils/useValueEffect.d.ts +1 -1
  749. package/dist-types/viewport/ViewportProvider.d.ts +2 -2
  750. package/package.json +2 -2
@@ -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":"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"}
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":"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"}
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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;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;AAG1D,EAAAC,eAAA,CAAU,MAAM;AAzFlB,IAAA,IAAA,EAAA,EAAA,EAAA,CAAA;AA0FI,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,QAAU,EAAA,KAAA,EAAO,WAAW,CAAA;AAAA,GAC/B,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;AAzJlE,IAAA,IAAA,EAAA,EAAA,EAAA,CAAA;AA0JI,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,QAAQ,GAAK,EAAA;AACrB,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,UAAA,MAAA;AAAA,YACE,KAAA;AAAA,YACA,SAAS,SAAW,CAAA,CAAA,YAAA;AAAA,cAClB,YAAA;AAAA,aACF;AAAA,WACF,CAAA;AACA,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,UAAA,MAAA;AAAA,YACE,KAAA;AAAA,YACA,SAAS,SAAW,CAAA,CAAA,YAAA;AAAA,cAClB,YAAA;AAAA,aACF;AAAA,WACF,CAAA;AACA,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;;;;"}
@@ -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;;;;"}
@@ -3,10 +3,10 @@
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
+ var styles = require('@salt-ds/styles');
7
+ var window = require('@salt-ds/window');
6
8
  var clsx = require('clsx');
7
9
  var React = require('react');
8
- var window = require('@salt-ds/window');
9
- var styles = require('@salt-ds/styles');
10
10
  var capitalize = require('../utils/capitalize.js');
11
11
  var makePrefixer = require('../utils/makePrefixer.js');
12
12
  require('../utils/useFloatingUI/useFloatingUI.js');
@@ -49,6 +49,7 @@ require('../flex-item/FlexItem.js');
49
49
  require('../flex-layout/FlexLayout.js');
50
50
  require('../flow-layout/FlowLayout.js');
51
51
  require('../form-field/FormField.js');
52
+ require('../form-field-context/FormFieldContext.js');
52
53
  require('../status-indicator/StatusIndicator.js');
53
54
  require('../text/Text.js');
54
55
  require('../text/Code.js');
@@ -57,7 +58,6 @@ require('../text/Headings.js');
57
58
  require('../text/Label.js');
58
59
  require('../text/TextAction.js');
59
60
  require('../text/TextNotation.js');
60
- require('../form-field-context/FormFieldContext.js');
61
61
  require('../grid-item/GridItem.js');
62
62
  require('../grid-layout/GridLayout.js');
63
63
  require('../input/Input.js');
@@ -67,12 +67,12 @@ require('../interactable-card/InteractableCardGroupContext.js');
67
67
  require('../link/Link.js');
68
68
  require('../list-box/ListBox.js');
69
69
  require('../list-control/ListControlContext.js');
70
- require('../menu/MenuContext.js');
71
70
  require('@floating-ui/react');
71
+ require('../menu/MenuContext.js');
72
72
  require('../menu/MenuItem.js');
73
73
  require('../menu/MenuPanel.js');
74
- require('../menu/MenuTriggerContext.js');
75
74
  require('../menu/MenuPanelContext.js');
75
+ require('../menu/MenuTriggerContext.js');
76
76
  require('../menu/MenuGroup.js');
77
77
  require('../multiline-input/MultilineInput.js');
78
78
  require('../navigation-item/NavigationItem.js');
@@ -1 +1 @@
1
- {"version":3,"file":"LinkCard.js","sources":["../src/link-card/LinkCard.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport { ComponentPropsWithoutRef, forwardRef } from \"react\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport { capitalize, makePrefixer } from \"../utils\";\n\nimport linkCardCss from \"./LinkCard.css\";\n\nconst withBaseName = makePrefixer(\"saltLinkCard\");\n\nexport interface LinkCardProps extends ComponentPropsWithoutRef<\"a\"> {\n /**\n * If provided an accent is shown in the specified position.\n */\n accent?: \"bottom\" | \"top\" | \"left\" | \"right\";\n /**\n * Styling variant; defaults to \"primary\".\n */\n variant?: \"primary\" | \"secondary\";\n}\n\nexport const LinkCard = forwardRef<HTMLAnchorElement, LinkCardProps>(\n function LinkCard(props, ref) {\n const {\n accent,\n children,\n className,\n href,\n variant = \"primary\",\n ...rest\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-link-card\",\n css: linkCardCss,\n window: targetWindow,\n });\n\n return (\n <a\n className={clsx(\n withBaseName(),\n withBaseName(variant),\n {\n [withBaseName(\"accent\")]: accent,\n [withBaseName(`accent${capitalize(accent ?? \"\")}`)]: accent,\n },\n className\n )}\n href={href}\n {...rest}\n ref={ref}\n >\n {children}\n </a>\n );\n }\n);\n"],"names":["makePrefixer","forwardRef","LinkCard","useWindow","useComponentCssInjection","linkCardCss","jsx","clsx","capitalize"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AASA,MAAM,YAAA,GAAeA,0BAAa,cAAc,CAAA,CAAA;AAazC,MAAM,QAAW,GAAAC,gBAAA;AAAA,EACtB,SAASC,SAAS,CAAA,KAAA,EAAO,GAAK,EAAA;AAC5B,IAAM,MAAA;AAAA,MACJ,MAAA;AAAA,MACA,QAAA;AAAA,MACA,SAAA;AAAA,MACA,IAAA;AAAA,MACA,OAAU,GAAA,SAAA;AAAA,MACP,GAAA,IAAA;AAAA,KACD,GAAA,KAAA,CAAA;AAEJ,IAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,gBAAA;AAAA,MACR,GAAK,EAAAC,UAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAA,uBACGC,cAAA,CAAA,GAAA,EAAA;AAAA,MACC,SAAW,EAAAC,SAAA;AAAA,QACT,YAAa,EAAA;AAAA,QACb,aAAa,OAAO,CAAA;AAAA,QACpB;AAAA,UACE,CAAC,YAAa,CAAA,QAAQ,CAAI,GAAA,MAAA;AAAA,UAC1B,CAAC,YAAa,CAAA,CAAA,MAAA,EAASC,sBAAW,MAAU,IAAA,IAAA,GAAA,MAAA,GAAA,EAAE,GAAG,CAAI,GAAA,MAAA;AAAA,SACvD;AAAA,QACA,SAAA;AAAA,OACF;AAAA,MACA,IAAA;AAAA,MACC,GAAG,IAAA;AAAA,MACJ,GAAA;AAAA,MAEC,QAAA;AAAA,KACH,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
1
+ {"version":3,"file":"LinkCard.js","sources":["../src/link-card/LinkCard.tsx"],"sourcesContent":["import { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport { type ComponentPropsWithoutRef, forwardRef } from \"react\";\n\nimport { capitalize, makePrefixer } from \"../utils\";\n\nimport linkCardCss from \"./LinkCard.css\";\n\nconst withBaseName = makePrefixer(\"saltLinkCard\");\n\nexport interface LinkCardProps extends ComponentPropsWithoutRef<\"a\"> {\n /**\n * If provided an accent is shown in the specified position.\n */\n accent?: \"bottom\" | \"top\" | \"left\" | \"right\";\n /**\n * Styling variant; defaults to \"primary\".\n */\n variant?: \"primary\" | \"secondary\";\n}\n\nexport const LinkCard = forwardRef<HTMLAnchorElement, LinkCardProps>(\n function LinkCard(props, ref) {\n const {\n accent,\n children,\n className,\n href,\n variant = \"primary\",\n ...rest\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-link-card\",\n css: linkCardCss,\n window: targetWindow,\n });\n\n return (\n <a\n className={clsx(\n withBaseName(),\n withBaseName(variant),\n {\n [withBaseName(\"accent\")]: accent,\n [withBaseName(`accent${capitalize(accent ?? \"\")}`)]: accent,\n },\n className,\n )}\n href={href}\n {...rest}\n ref={ref}\n >\n {children}\n </a>\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","LinkCard","useWindow","useComponentCssInjection","linkCardCss","jsx","clsx","capitalize"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AASA,MAAM,YAAA,GAAeA,0BAAa,cAAc,CAAA,CAAA;AAazC,MAAM,QAAW,GAAAC,gBAAA;AAAA,EACtB,SAASC,SAAS,CAAA,KAAA,EAAO,GAAK,EAAA;AAC5B,IAAM,MAAA;AAAA,MACJ,MAAA;AAAA,MACA,QAAA;AAAA,MACA,SAAA;AAAA,MACA,IAAA;AAAA,MACA,OAAU,GAAA,SAAA;AAAA,MACP,GAAA,IAAA;AAAA,KACD,GAAA,KAAA,CAAA;AAEJ,IAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,gBAAA;AAAA,MACR,GAAK,EAAAC,UAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAA,uBACGC,cAAA,CAAA,GAAA,EAAA;AAAA,MACC,SAAW,EAAAC,SAAA;AAAA,QACT,YAAa,EAAA;AAAA,QACb,aAAa,OAAO,CAAA;AAAA,QACpB;AAAA,UACE,CAAC,YAAa,CAAA,QAAQ,CAAI,GAAA,MAAA;AAAA,UAC1B,CAAC,YAAa,CAAA,CAAA,MAAA,EAASC,sBAAW,MAAU,IAAA,IAAA,GAAA,MAAA,GAAA,EAAE,GAAG,CAAI,GAAA,MAAA;AAAA,SACvD;AAAA,QACA,SAAA;AAAA,OACF;AAAA,MACA,IAAA;AAAA,MACC,GAAG,IAAA;AAAA,MACJ,GAAA;AAAA,MAEC,QAAA;AAAA,KACH,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
@@ -3,10 +3,12 @@
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 window$1 = require('@salt-ds/window');
8
6
  var styles = require('@salt-ds/styles');
7
+ var window$1 = require('@salt-ds/window');
9
8
  var clsx = require('clsx');
9
+ var React = require('react');
10
+ var ListControlContext = require('../list-control/ListControlContext.js');
11
+ var ListControlState = require('../list-control/ListControlState.js');
10
12
  var makePrefixer = require('../utils/makePrefixer.js');
11
13
  require('../utils/useFloatingUI/useFloatingUI.js');
12
14
  var useForkRef = require('../utils/useForkRef.js');
@@ -49,6 +51,7 @@ require('../flex-item/FlexItem.js');
49
51
  require('../flex-layout/FlexLayout.js');
50
52
  require('../flow-layout/FlowLayout.js');
51
53
  require('../form-field/FormField.js');
54
+ require('../form-field-context/FormFieldContext.js');
52
55
  require('../status-indicator/StatusIndicator.js');
53
56
  require('../text/Text.js');
54
57
  require('../text/Code.js');
@@ -57,7 +60,6 @@ require('../text/Headings.js');
57
60
  require('../text/Label.js');
58
61
  require('../text/TextAction.js');
59
62
  require('../text/TextNotation.js');
60
- require('../form-field-context/FormFieldContext.js');
61
63
  require('../grid-item/GridItem.js');
62
64
  require('../grid-layout/GridLayout.js');
63
65
  require('../input/Input.js');
@@ -66,13 +68,12 @@ require('../interactable-card/InteractableCardGroup.js');
66
68
  require('../interactable-card/InteractableCardGroupContext.js');
67
69
  require('../link/Link.js');
68
70
  require('../link-card/LinkCard.js');
69
- var ListControlContext = require('../list-control/ListControlContext.js');
70
- require('../menu/MenuContext.js');
71
71
  require('@floating-ui/react');
72
+ require('../menu/MenuContext.js');
72
73
  require('../menu/MenuItem.js');
73
74
  require('../menu/MenuPanel.js');
74
- require('../menu/MenuTriggerContext.js');
75
75
  require('../menu/MenuPanelContext.js');
76
+ require('../menu/MenuTriggerContext.js');
76
77
  require('../menu/MenuGroup.js');
77
78
  require('../multiline-input/MultilineInput.js');
78
79
  require('../navigation-item/NavigationItem.js');
@@ -108,7 +109,6 @@ require('../toggle-button/ToggleButton.js');
108
109
  require('../toggle-button-group/ToggleButtonGroup.js');
109
110
  require('../toggle-button-group/ToggleButtonGroupContext.js');
110
111
  require('../tooltip/Tooltip.js');
111
- var ListControlState = require('../list-control/ListControlState.js');
112
112
  var ListBox$1 = require('./ListBox.css.js');
113
113
 
114
114
  const withBaseName = makePrefixer.makePrefixer("saltListBox");
@@ -182,13 +182,14 @@ const ListBox = React.forwardRef(function ListBox2(props, ref) {
182
182
  };
183
183
  const handleKeyDown = (event) => {
184
184
  var _a, _b;
185
+ onKeyDown == null ? void 0 : onKeyDown(event);
185
186
  if (event.key.length === 1 && !event.ctrlKey && !event.metaKey && !event.altKey) {
186
187
  event.preventDefault();
187
188
  event.stopPropagation();
188
189
  handleTypeahead(event);
189
190
  }
190
191
  const activeOption = activeState != null ? activeState : getFirstOption().data;
191
- let newActive;
192
+ let newActive = null;
192
193
  switch (event.key) {
193
194
  case "ArrowDown":
194
195
  newActive = (_a = getOptionAfter(activeOption)) != null ? _a : getLastOption();
@@ -221,12 +222,11 @@ const ListBox = React.forwardRef(function ListBox2(props, ref) {
221
222
  select(event, activeState);
222
223
  break;
223
224
  }
224
- if (newActive && newActive.data.id != (activeState == null ? void 0 : activeState.id)) {
225
+ if (newActive && newActive.data.id !== (activeState == null ? void 0 : activeState.id)) {
225
226
  event.preventDefault();
226
227
  setActive(newActive.data);
227
228
  setFocusVisibleState(true);
228
229
  }
229
- onKeyDown == null ? void 0 : onKeyDown(event);
230
230
  };
231
231
  const wasMouseDown = React.useRef(false);
232
232
  const handleMouseDown = () => {
@@ -1 +1 @@
1
- {"version":3,"file":"ListBox.js","sources":["../src/list-box/ListBox.tsx"],"sourcesContent":["import {\n ComponentPropsWithoutRef,\n FocusEvent,\n ForwardedRef,\n forwardRef,\n KeyboardEvent,\n ReactNode,\n Ref,\n useRef,\n} from \"react\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { clsx } from \"clsx\";\nimport { makePrefixer, useForkRef } from \"../utils\";\nimport { ListControlContext } from \"../list-control/ListControlContext\";\nimport {\n defaultValueToString,\n useListControl,\n ListControlProps,\n} from \"../list-control/ListControlState\";\n\nimport listBoxCss from \"./ListBox.css\";\n\nexport type ListBoxProps<Item = string> = {\n /**\n * If `true`, the list box will be disabled.\n */\n disabled?: boolean;\n /**\n * If `false`, the list box will have not a border.\n */\n bordered?: boolean;\n /**\n * The options to display in the list box.\n */\n children?: ReactNode;\n /**\n * If `true`, the list box will be multiselect.\n */\n multiselect?: boolean;\n} & ComponentPropsWithoutRef<\"div\"> &\n Omit<ListControlProps<Item>, \"onOpenChange\">;\n\nconst withBaseName = makePrefixer(\"saltListBox\");\n\nexport const ListBox = forwardRef(function ListBox<Item>(\n props: ListBoxProps<Item>,\n ref: ForwardedRef<HTMLDivElement>\n) {\n const {\n bordered,\n className,\n children,\n defaultSelected,\n disabled,\n selected,\n onSelectionChange,\n multiselect,\n valueToString = defaultValueToString,\n onKeyDown,\n onFocus,\n onBlur,\n ...rest\n } = props;\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-list-box\",\n css: listBoxCss,\n window: targetWindow,\n });\n\n const listControl = useListControl<Item>({\n multiselect,\n defaultSelected,\n selected,\n onSelectionChange,\n valueToString,\n disabled,\n });\n\n const {\n activeState,\n setActive,\n getOptionAtIndex,\n getIndexOfOption,\n getOptionsMatching,\n getOptionFromSearch,\n getFirstOption,\n getLastOption,\n getOptionAfter,\n getOptionBefore,\n getOptionPageAbove,\n getOptionPageBelow,\n selectedState,\n select,\n setFocusVisibleState,\n setFocusedState,\n listRef,\n } = listControl;\n\n const typeaheadString = useRef(\"\");\n const typeaheadTimeout = useRef<number | undefined>();\n\n const handleTypeahead = (event: KeyboardEvent<HTMLDivElement>) => {\n if (typeaheadTimeout.current) {\n clearTimeout(typeaheadTimeout.current);\n }\n typeaheadString.current += event.key;\n typeaheadTimeout.current = window.setTimeout(() => {\n typeaheadString.current = \"\";\n }, 500);\n\n let newOption = getOptionFromSearch(typeaheadString.current, activeState);\n\n if (!newOption) {\n newOption = getOptionFromSearch(typeaheadString.current);\n }\n\n if (newOption) {\n setActive(newOption);\n setFocusVisibleState(true);\n }\n };\n\n const handleKeyDown = (event: KeyboardEvent<HTMLDivElement>) => {\n if (\n event.key.length === 1 &&\n !event.ctrlKey &&\n !event.metaKey &&\n !event.altKey\n ) {\n event.preventDefault();\n event.stopPropagation();\n handleTypeahead(event);\n }\n\n const activeOption = activeState ?? getFirstOption().data;\n\n let newActive;\n switch (event.key) {\n case \"ArrowDown\":\n newActive = getOptionAfter(activeOption) ?? getLastOption();\n break;\n case \"ArrowUp\":\n newActive = getOptionBefore(activeOption) ?? getFirstOption();\n break;\n case \"Home\":\n newActive = getFirstOption();\n break;\n case \"End\":\n newActive = getLastOption();\n break;\n case \"PageUp\":\n newActive = getOptionPageAbove(activeOption);\n break;\n case \"PageDown\":\n newActive = getOptionPageBelow(activeOption);\n break;\n case \"Enter\":\n case \" \":\n if (\n Boolean(activeState?.disabled) ||\n (typeaheadString.current.trim().length > 0 && event.key === \" \")\n ) {\n event.preventDefault();\n return;\n }\n\n if (!activeState) {\n return;\n }\n\n event.preventDefault();\n select(event, activeState);\n\n break;\n }\n\n if (newActive && newActive.data.id != activeState?.id) {\n event.preventDefault();\n setActive(newActive.data);\n setFocusVisibleState(true);\n }\n\n onKeyDown?.(event);\n };\n\n const wasMouseDown = useRef(false);\n\n const handleMouseDown = () => {\n wasMouseDown.current = true;\n };\n\n const handleFocus = (event: FocusEvent<HTMLDivElement>) => {\n if (wasMouseDown.current) {\n wasMouseDown.current = false;\n return;\n }\n\n setFocusVisibleState(true);\n wasMouseDown.current = false;\n\n // We check the active index because the active item may have been removed\n const activeIndex = activeState ? getIndexOfOption(activeState) : -1;\n let newActive = undefined;\n\n // If the active item is still in the list, we don't need to do anything\n if (activeIndex > 0) {\n return;\n }\n\n // If we have selected an item, we should make that the active item\n if (selectedState.length > 0) {\n newActive = getOptionsMatching(\n (option) => option.value === selectedState[0]\n ).pop();\n }\n\n // If we still don't have an active item, we should just select the first item\n if (!newActive) {\n newActive = getOptionAtIndex(0);\n }\n\n setActive(newActive?.data);\n setFocusedState(true);\n onFocus?.(event);\n };\n\n const handleBlur = (event: FocusEvent<HTMLDivElement>) => {\n setFocusedState(false);\n setActive(undefined);\n onBlur?.(event);\n };\n\n const handleListMouseOver = () => {\n setFocusVisibleState(false);\n setActive(undefined);\n };\n\n const handleRef = useForkRef(listRef, ref);\n\n return (\n <ListControlContext.Provider value={listControl}>\n <div\n className={clsx(\n withBaseName(),\n { [withBaseName(\"bordered\")]: bordered },\n className\n )}\n role=\"listbox\"\n aria-activedescendant={activeState?.id}\n aria-disabled={disabled || undefined}\n aria-multiselectable={multiselect}\n tabIndex={disabled ? -1 : 0}\n onKeyDown={handleKeyDown}\n onBlur={handleBlur}\n onFocus={handleFocus}\n onMouseOver={handleListMouseOver}\n onMouseDown={handleMouseDown}\n ref={handleRef}\n {...rest}\n >\n {children}\n </div>\n </ListControlContext.Provider>\n );\n}) as <Item = string>(\n props: ListBoxProps<Item> & { ref?: Ref<HTMLDivElement> }\n) => JSX.Element;\n"],"names":["makePrefixer","forwardRef","ListBox","defaultValueToString","useWindow","useComponentCssInjection","listBoxCss","useListControl","useRef","useForkRef","jsx","ListControlContext","clsx"],"mappings":"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"}
1
+ {"version":3,"file":"ListBox.js","sources":["../src/list-box/ListBox.tsx"],"sourcesContent":["import { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport {\n type ComponentPropsWithoutRef,\n type FocusEvent,\n type ForwardedRef,\n type KeyboardEvent,\n type ReactNode,\n type Ref,\n forwardRef,\n useRef,\n} from \"react\";\nimport {\n ListControlContext,\n type OptionValue,\n} from \"../list-control/ListControlContext\";\nimport {\n type ListControlProps,\n defaultValueToString,\n useListControl,\n} from \"../list-control/ListControlState\";\nimport { makePrefixer, useForkRef } from \"../utils\";\n\nimport listBoxCss from \"./ListBox.css\";\n\nexport type ListBoxProps<Item = string> = {\n /**\n * If `true`, the list box will be disabled.\n */\n disabled?: boolean;\n /**\n * If `false`, the list box will have not a border.\n */\n bordered?: boolean;\n /**\n * The options to display in the list box.\n */\n children?: ReactNode;\n /**\n * If `true`, the list box will be multiselect.\n */\n multiselect?: boolean;\n} & ComponentPropsWithoutRef<\"div\"> &\n Omit<ListControlProps<Item>, \"onOpenChange\">;\n\nconst withBaseName = makePrefixer(\"saltListBox\");\n\nexport const ListBox = forwardRef(function ListBox<Item>(\n props: ListBoxProps<Item>,\n ref: ForwardedRef<HTMLDivElement>,\n) {\n const {\n bordered,\n className,\n children,\n defaultSelected,\n disabled,\n selected,\n onSelectionChange,\n multiselect,\n valueToString = defaultValueToString,\n onKeyDown,\n onFocus,\n onBlur,\n ...rest\n } = props;\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-list-box\",\n css: listBoxCss,\n window: targetWindow,\n });\n\n const listControl = useListControl<Item>({\n multiselect,\n defaultSelected,\n selected,\n onSelectionChange,\n valueToString,\n disabled,\n });\n\n const {\n activeState,\n setActive,\n getOptionAtIndex,\n getIndexOfOption,\n getOptionsMatching,\n getOptionFromSearch,\n getFirstOption,\n getLastOption,\n getOptionAfter,\n getOptionBefore,\n getOptionPageAbove,\n getOptionPageBelow,\n selectedState,\n select,\n setFocusVisibleState,\n setFocusedState,\n listRef,\n } = listControl;\n\n const typeaheadString = useRef(\"\");\n const typeaheadTimeout = useRef<number | undefined>();\n\n const handleTypeahead = (event: KeyboardEvent<HTMLDivElement>) => {\n if (typeaheadTimeout.current) {\n clearTimeout(typeaheadTimeout.current);\n }\n typeaheadString.current += event.key;\n typeaheadTimeout.current = window.setTimeout(() => {\n typeaheadString.current = \"\";\n }, 500);\n\n let newOption = getOptionFromSearch(typeaheadString.current, activeState);\n\n if (!newOption) {\n newOption = getOptionFromSearch(typeaheadString.current);\n }\n\n if (newOption) {\n setActive(newOption);\n setFocusVisibleState(true);\n }\n };\n\n const handleKeyDown = (event: KeyboardEvent<HTMLDivElement>) => {\n onKeyDown?.(event);\n\n if (\n event.key.length === 1 &&\n !event.ctrlKey &&\n !event.metaKey &&\n !event.altKey\n ) {\n event.preventDefault();\n event.stopPropagation();\n handleTypeahead(event);\n }\n\n const activeOption = activeState ?? getFirstOption().data;\n\n let newActive: { data: OptionValue<Item>; element: HTMLElement } | null =\n null;\n switch (event.key) {\n case \"ArrowDown\":\n newActive = getOptionAfter(activeOption) ?? getLastOption();\n break;\n case \"ArrowUp\":\n newActive = getOptionBefore(activeOption) ?? getFirstOption();\n break;\n case \"Home\":\n newActive = getFirstOption();\n break;\n case \"End\":\n newActive = getLastOption();\n break;\n case \"PageUp\":\n newActive = getOptionPageAbove(activeOption);\n break;\n case \"PageDown\":\n newActive = getOptionPageBelow(activeOption);\n break;\n case \"Enter\":\n case \" \":\n if (\n Boolean(activeState?.disabled) ||\n (typeaheadString.current.trim().length > 0 && event.key === \" \")\n ) {\n event.preventDefault();\n return;\n }\n\n if (!activeState) {\n return;\n }\n\n event.preventDefault();\n select(event, activeState);\n\n break;\n }\n\n if (newActive && newActive.data.id !== activeState?.id) {\n event.preventDefault();\n setActive(newActive.data);\n setFocusVisibleState(true);\n }\n };\n\n const wasMouseDown = useRef(false);\n\n const handleMouseDown = () => {\n wasMouseDown.current = true;\n };\n\n const handleFocus = (event: FocusEvent<HTMLDivElement>) => {\n if (wasMouseDown.current) {\n wasMouseDown.current = false;\n return;\n }\n\n setFocusVisibleState(true);\n wasMouseDown.current = false;\n\n // We check the active index because the active item may have been removed\n const activeIndex = activeState ? getIndexOfOption(activeState) : -1;\n let newActive = undefined;\n\n // If the active item is still in the list, we don't need to do anything\n if (activeIndex > 0) {\n return;\n }\n\n // If we have selected an item, we should make that the active item\n if (selectedState.length > 0) {\n newActive = getOptionsMatching(\n (option) => option.value === selectedState[0],\n ).pop();\n }\n\n // If we still don't have an active item, we should just select the first item\n if (!newActive) {\n newActive = getOptionAtIndex(0);\n }\n\n setActive(newActive?.data);\n setFocusedState(true);\n onFocus?.(event);\n };\n\n const handleBlur = (event: FocusEvent<HTMLDivElement>) => {\n setFocusedState(false);\n setActive(undefined);\n onBlur?.(event);\n };\n\n const handleListMouseOver = () => {\n setFocusVisibleState(false);\n setActive(undefined);\n };\n\n const handleRef = useForkRef(listRef, ref);\n\n return (\n <ListControlContext.Provider value={listControl}>\n <div\n className={clsx(\n withBaseName(),\n { [withBaseName(\"bordered\")]: bordered },\n className,\n )}\n role=\"listbox\"\n aria-activedescendant={activeState?.id}\n aria-disabled={disabled || undefined}\n aria-multiselectable={multiselect}\n tabIndex={disabled ? -1 : 0}\n onKeyDown={handleKeyDown}\n onBlur={handleBlur}\n onFocus={handleFocus}\n onMouseOver={handleListMouseOver}\n onMouseDown={handleMouseDown}\n ref={handleRef}\n {...rest}\n >\n {children}\n </div>\n </ListControlContext.Provider>\n );\n}) as <Item = string>(\n props: ListBoxProps<Item> & { ref?: Ref<HTMLDivElement> },\n) => JSX.Element;\n"],"names":["makePrefixer","forwardRef","ListBox","defaultValueToString","useWindow","useComponentCssInjection","listBoxCss","useListControl","useRef","useForkRef","jsx","ListControlContext","clsx"],"mappings":"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"}