@salt-ds/core 1.37.1 → 1.37.3

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 (670) hide show
  1. package/CHANGELOG.md +1760 -0
  2. package/css/salt-core.css +76 -37
  3. package/dist-cjs/accordion/Accordion.js +31 -123
  4. package/dist-cjs/accordion/Accordion.js.map +1 -1
  5. package/dist-cjs/accordion/AccordionContext.js +0 -101
  6. package/dist-cjs/accordion/AccordionContext.js.map +1 -1
  7. package/dist-cjs/accordion/AccordionGroup.js +1 -103
  8. package/dist-cjs/accordion/AccordionGroup.js.map +1 -1
  9. package/dist-cjs/accordion/AccordionHeader.js +33 -136
  10. package/dist-cjs/accordion/AccordionHeader.js.map +1 -1
  11. package/dist-cjs/accordion/AccordionPanel.js +22 -117
  12. package/dist-cjs/accordion/AccordionPanel.js.map +1 -1
  13. package/dist-cjs/aria-announcer/AriaAnnounce.js +0 -2
  14. package/dist-cjs/aria-announcer/AriaAnnounce.js.map +1 -1
  15. package/dist-cjs/aria-announcer/AriaAnnouncerContext.js +0 -2
  16. package/dist-cjs/aria-announcer/AriaAnnouncerContext.js.map +1 -1
  17. package/dist-cjs/aria-announcer/AriaAnnouncerProvider.js +8 -10
  18. package/dist-cjs/aria-announcer/AriaAnnouncerProvider.js.map +1 -1
  19. package/dist-cjs/aria-announcer/useAriaAnnouncer.js +0 -106
  20. package/dist-cjs/aria-announcer/useAriaAnnouncer.js.map +1 -1
  21. package/dist-cjs/avatar/Avatar.js +18 -117
  22. package/dist-cjs/avatar/Avatar.js.map +1 -1
  23. package/dist-cjs/avatar/useAvatarImage.js +0 -101
  24. package/dist-cjs/avatar/useAvatarImage.js.map +1 -1
  25. package/dist-cjs/badge/Badge.js +8 -108
  26. package/dist-cjs/badge/Badge.js.map +1 -1
  27. package/dist-cjs/banner/Banner.js +18 -115
  28. package/dist-cjs/banner/Banner.js.map +1 -1
  29. package/dist-cjs/banner/BannerActions.js +1 -103
  30. package/dist-cjs/banner/BannerActions.js.map +1 -1
  31. package/dist-cjs/banner/BannerContent.js +1 -103
  32. package/dist-cjs/banner/BannerContent.js.map +1 -1
  33. package/dist-cjs/border-item/BorderItem.js +17 -111
  34. package/dist-cjs/border-item/BorderItem.js.map +1 -1
  35. package/dist-cjs/border-layout/BorderLayout.js +12 -108
  36. package/dist-cjs/border-layout/BorderLayout.js.map +1 -1
  37. package/dist-cjs/breakpoints/BreakpointProvider.js +2 -111
  38. package/dist-cjs/breakpoints/BreakpointProvider.js.map +1 -1
  39. package/dist-cjs/breakpoints/Breakpoints.js +0 -2
  40. package/dist-cjs/breakpoints/Breakpoints.js.map +1 -1
  41. package/dist-cjs/button/Button.js +24 -120
  42. package/dist-cjs/button/Button.js.map +1 -1
  43. package/dist-cjs/button/useButton.js +0 -2
  44. package/dist-cjs/button/useButton.js.map +1 -1
  45. package/dist-cjs/card/Card.js +21 -115
  46. package/dist-cjs/card/Card.js.map +1 -1
  47. package/dist-cjs/checkbox/Checkbox.css.js +1 -1
  48. package/dist-cjs/checkbox/Checkbox.js +62 -150
  49. package/dist-cjs/checkbox/Checkbox.js.map +1 -1
  50. package/dist-cjs/checkbox/CheckboxGroup.js +32 -123
  51. package/dist-cjs/checkbox/CheckboxGroup.js.map +1 -1
  52. package/dist-cjs/checkbox/CheckboxIcon.js +24 -131
  53. package/dist-cjs/checkbox/CheckboxIcon.js.map +1 -1
  54. package/dist-cjs/checkbox/internal/CheckboxGroupContext.js +0 -101
  55. package/dist-cjs/checkbox/internal/CheckboxGroupContext.js.map +1 -1
  56. package/dist-cjs/checkbox/internal/useCheckboxGroup.js +0 -2
  57. package/dist-cjs/checkbox/internal/useCheckboxGroup.js.map +1 -1
  58. package/dist-cjs/combo-box/ComboBox.js +33 -127
  59. package/dist-cjs/combo-box/ComboBox.js.map +1 -1
  60. package/dist-cjs/combo-box/useComboBox.js +1 -102
  61. package/dist-cjs/combo-box/useComboBox.js.map +1 -1
  62. package/dist-cjs/dialog/Dialog.js +38 -143
  63. package/dist-cjs/dialog/Dialog.js.map +1 -1
  64. package/dist-cjs/dialog/DialogActions.js +1 -104
  65. package/dist-cjs/dialog/DialogActions.js.map +1 -1
  66. package/dist-cjs/dialog/DialogCloseButton.js +11 -110
  67. package/dist-cjs/dialog/DialogCloseButton.js.map +1 -1
  68. package/dist-cjs/dialog/DialogContent.css.js +1 -1
  69. package/dist-cjs/dialog/DialogContent.js +39 -113
  70. package/dist-cjs/dialog/DialogContent.js.map +1 -1
  71. package/dist-cjs/dialog/DialogContext.js +0 -2
  72. package/dist-cjs/dialog/DialogContext.js.map +1 -1
  73. package/dist-cjs/dialog/DialogHeader.js +24 -125
  74. package/dist-cjs/dialog/DialogHeader.js.map +1 -1
  75. package/dist-cjs/divider/Divider.js +15 -110
  76. package/dist-cjs/divider/Divider.js.map +1 -1
  77. package/dist-cjs/drawer/Drawer.js +13 -114
  78. package/dist-cjs/drawer/Drawer.js.map +1 -1
  79. package/dist-cjs/drawer/DrawerCloseButton.js +8 -110
  80. package/dist-cjs/drawer/DrawerCloseButton.js.map +1 -1
  81. package/dist-cjs/dropdown/Dropdown.js +38 -137
  82. package/dist-cjs/dropdown/Dropdown.js.map +1 -1
  83. package/dist-cjs/file-drop-zone/FileDropZone.js +21 -116
  84. package/dist-cjs/file-drop-zone/FileDropZone.js.map +1 -1
  85. package/dist-cjs/file-drop-zone/FileDropZoneIcon.js +2 -9
  86. package/dist-cjs/file-drop-zone/FileDropZoneIcon.js.map +1 -1
  87. package/dist-cjs/file-drop-zone/FileDropZoneTrigger.js +14 -110
  88. package/dist-cjs/file-drop-zone/FileDropZoneTrigger.js.map +1 -1
  89. package/dist-cjs/file-drop-zone/internal/utils.js +1 -4
  90. package/dist-cjs/file-drop-zone/internal/utils.js.map +1 -1
  91. package/dist-cjs/flex-item/FlexItem.js +10 -106
  92. package/dist-cjs/flex-item/FlexItem.js.map +1 -1
  93. package/dist-cjs/flex-layout/FlexLayout.js +21 -117
  94. package/dist-cjs/flex-layout/FlexLayout.js.map +1 -1
  95. package/dist-cjs/flow-layout/FlowLayout.js +1 -9
  96. package/dist-cjs/flow-layout/FlowLayout.js.map +1 -1
  97. package/dist-cjs/form-field/FormField.css.js +1 -1
  98. package/dist-cjs/form-field/FormField.js +30 -121
  99. package/dist-cjs/form-field/FormField.js.map +1 -1
  100. package/dist-cjs/form-field/FormFieldHelperText.js +24 -114
  101. package/dist-cjs/form-field/FormFieldHelperText.js.map +1 -1
  102. package/dist-cjs/form-field/FormFieldLabel.js +15 -106
  103. package/dist-cjs/form-field/FormFieldLabel.js.map +1 -1
  104. package/dist-cjs/form-field-context/FormFieldContext.js +0 -100
  105. package/dist-cjs/form-field-context/FormFieldContext.js.map +1 -1
  106. package/dist-cjs/form-field-context/useFormFieldProps.js +0 -2
  107. package/dist-cjs/form-field-context/useFormFieldProps.js.map +1 -1
  108. package/dist-cjs/grid-item/GridItem.js +10 -106
  109. package/dist-cjs/grid-item/GridItem.js.map +1 -1
  110. package/dist-cjs/grid-layout/GridLayout.js +13 -109
  111. package/dist-cjs/grid-layout/GridLayout.js.map +1 -1
  112. package/dist-cjs/index.js +0 -2
  113. package/dist-cjs/index.js.map +1 -1
  114. package/dist-cjs/input/Input.js +49 -149
  115. package/dist-cjs/input/Input.js.map +1 -1
  116. package/dist-cjs/interactable-card/InteractableCard.js +28 -122
  117. package/dist-cjs/interactable-card/InteractableCard.js.map +1 -1
  118. package/dist-cjs/interactable-card/InteractableCardGroup.js +9 -106
  119. package/dist-cjs/interactable-card/InteractableCardGroup.js.map +1 -1
  120. package/dist-cjs/interactable-card/InteractableCardGroupContext.js +0 -100
  121. package/dist-cjs/interactable-card/InteractableCardGroupContext.js.map +1 -1
  122. package/dist-cjs/interactable-card/useInteractableCard.js +0 -2
  123. package/dist-cjs/interactable-card/useInteractableCard.js.map +1 -1
  124. package/dist-cjs/link/Link.js +22 -117
  125. package/dist-cjs/link/Link.js.map +1 -1
  126. package/dist-cjs/link-card/LinkCard.js +18 -113
  127. package/dist-cjs/link-card/LinkCard.js.map +1 -1
  128. package/dist-cjs/list-box/ListBox.js +8 -106
  129. package/dist-cjs/list-box/ListBox.js.map +1 -1
  130. package/dist-cjs/list-control/ListControlContext.js +0 -100
  131. package/dist-cjs/list-control/ListControlContext.js.map +1 -1
  132. package/dist-cjs/list-control/ListControlState.js +3 -104
  133. package/dist-cjs/list-control/ListControlState.js.map +1 -1
  134. package/dist-cjs/menu/Menu.js +2 -10
  135. package/dist-cjs/menu/Menu.js.map +1 -1
  136. package/dist-cjs/menu/MenuBase.js +10 -109
  137. package/dist-cjs/menu/MenuBase.js.map +1 -1
  138. package/dist-cjs/menu/MenuContext.js +0 -100
  139. package/dist-cjs/menu/MenuContext.js.map +1 -1
  140. package/dist-cjs/menu/MenuGroup.js +14 -114
  141. package/dist-cjs/menu/MenuGroup.js.map +1 -1
  142. package/dist-cjs/menu/MenuItem.js +51 -143
  143. package/dist-cjs/menu/MenuItem.js.map +1 -1
  144. package/dist-cjs/menu/MenuPanel.js +27 -123
  145. package/dist-cjs/menu/MenuPanel.js.map +1 -1
  146. package/dist-cjs/menu/MenuPanelBase.js +1 -7
  147. package/dist-cjs/menu/MenuPanelBase.js.map +1 -1
  148. package/dist-cjs/menu/MenuPanelContext.js +0 -100
  149. package/dist-cjs/menu/MenuPanelContext.js.map +1 -1
  150. package/dist-cjs/menu/MenuTrigger.js +20 -118
  151. package/dist-cjs/menu/MenuTrigger.js.map +1 -1
  152. package/dist-cjs/menu/MenuTriggerContext.js +0 -100
  153. package/dist-cjs/menu/MenuTriggerContext.js.map +1 -1
  154. package/dist-cjs/multiline-input/MultilineInput.js +54 -161
  155. package/dist-cjs/multiline-input/MultilineInput.js.map +1 -1
  156. package/dist-cjs/navigation-item/ExpansionIcon.js +1 -5
  157. package/dist-cjs/navigation-item/ExpansionIcon.js.map +1 -1
  158. package/dist-cjs/navigation-item/NavigationItem.js +32 -132
  159. package/dist-cjs/navigation-item/NavigationItem.js.map +1 -1
  160. package/dist-cjs/navigation-item/NavigationItemAction.js +0 -102
  161. package/dist-cjs/navigation-item/NavigationItemAction.js.map +1 -1
  162. package/dist-cjs/option/Option.js +32 -120
  163. package/dist-cjs/option/Option.js.map +1 -1
  164. package/dist-cjs/option/OptionGroup.js +14 -114
  165. package/dist-cjs/option/OptionGroup.js.map +1 -1
  166. package/dist-cjs/option/OptionList.js +17 -117
  167. package/dist-cjs/option/OptionList.js.map +1 -1
  168. package/dist-cjs/option/OptionListBase.js +9 -105
  169. package/dist-cjs/option/OptionListBase.js.map +1 -1
  170. package/dist-cjs/overlay/Overlay.js +18 -114
  171. package/dist-cjs/overlay/Overlay.js.map +1 -1
  172. package/dist-cjs/overlay/OverlayContext.js +0 -100
  173. package/dist-cjs/overlay/OverlayContext.js.map +1 -1
  174. package/dist-cjs/overlay/OverlayPanel.js +34 -127
  175. package/dist-cjs/overlay/OverlayPanel.js.map +1 -1
  176. package/dist-cjs/overlay/OverlayPanelCloseButton.js +7 -109
  177. package/dist-cjs/overlay/OverlayPanelCloseButton.js.map +1 -1
  178. package/dist-cjs/overlay/OverlayPanelContent.css.js +1 -1
  179. package/dist-cjs/overlay/OverlayPanelContent.js +41 -107
  180. package/dist-cjs/overlay/OverlayPanelContent.js.map +1 -1
  181. package/dist-cjs/overlay/OverlayTrigger.js +6 -111
  182. package/dist-cjs/overlay/OverlayTrigger.js.map +1 -1
  183. package/dist-cjs/pagination/CompactInput.js +20 -114
  184. package/dist-cjs/pagination/CompactInput.js.map +1 -1
  185. package/dist-cjs/pagination/CompactPaginator.js +21 -123
  186. package/dist-cjs/pagination/CompactPaginator.js.map +1 -1
  187. package/dist-cjs/pagination/GoToInput.js +31 -114
  188. package/dist-cjs/pagination/GoToInput.js.map +1 -1
  189. package/dist-cjs/pagination/PageButton.js +17 -112
  190. package/dist-cjs/pagination/PageButton.js.map +1 -1
  191. package/dist-cjs/pagination/PageRanges.js +15 -126
  192. package/dist-cjs/pagination/PageRanges.js.map +1 -1
  193. package/dist-cjs/pagination/Pagination.js +6 -103
  194. package/dist-cjs/pagination/Pagination.js.map +1 -1
  195. package/dist-cjs/pagination/PaginationContext.js +0 -2
  196. package/dist-cjs/pagination/PaginationContext.js.map +1 -1
  197. package/dist-cjs/pagination/Paginator.js +19 -121
  198. package/dist-cjs/pagination/Paginator.js.map +1 -1
  199. package/dist-cjs/pagination/usePagination.js +0 -2
  200. package/dist-cjs/pagination/usePagination.js.map +1 -1
  201. package/dist-cjs/pagination/usePaginationContext.js +0 -2
  202. package/dist-cjs/pagination/usePaginationContext.js.map +1 -1
  203. package/dist-cjs/panel/Panel.js +9 -104
  204. package/dist-cjs/panel/Panel.js.map +1 -1
  205. package/dist-cjs/parent-child-layout/ParentChildLayout.js +24 -123
  206. package/dist-cjs/parent-child-layout/ParentChildLayout.js.map +1 -1
  207. package/dist-cjs/parent-child-layout/useIsViewportLargerThanBreakpoint.js +0 -103
  208. package/dist-cjs/parent-child-layout/useIsViewportLargerThanBreakpoint.js.map +1 -1
  209. package/dist-cjs/pill/Pill.js +17 -115
  210. package/dist-cjs/pill/Pill.js.map +1 -1
  211. package/dist-cjs/pill-input/PillInput.js +97 -204
  212. package/dist-cjs/pill-input/PillInput.js.map +1 -1
  213. package/dist-cjs/pill-input/useTruncatePills.js +0 -2
  214. package/dist-cjs/pill-input/useTruncatePills.js.map +1 -1
  215. package/dist-cjs/progress/CircularProgress/CircularProgress.js +44 -153
  216. package/dist-cjs/progress/CircularProgress/CircularProgress.js.map +1 -1
  217. package/dist-cjs/progress/LinearProgress/LinearProgress.js +28 -125
  218. package/dist-cjs/progress/LinearProgress/LinearProgress.js.map +1 -1
  219. package/dist-cjs/radio-button/RadioButton.css.js +1 -1
  220. package/dist-cjs/radio-button/RadioButton.js +60 -150
  221. package/dist-cjs/radio-button/RadioButton.js.map +1 -1
  222. package/dist-cjs/radio-button/RadioButtonGroup.js +36 -127
  223. package/dist-cjs/radio-button/RadioButtonGroup.js.map +1 -1
  224. package/dist-cjs/radio-button/RadioButtonIcon.js +45 -134
  225. package/dist-cjs/radio-button/RadioButtonIcon.js.map +1 -1
  226. package/dist-cjs/radio-button/internal/RadioGroupContext.js +0 -101
  227. package/dist-cjs/radio-button/internal/RadioGroupContext.js.map +1 -1
  228. package/dist-cjs/radio-button/internal/useRadioGroup.js +0 -2
  229. package/dist-cjs/radio-button/internal/useRadioGroup.js.map +1 -1
  230. package/dist-cjs/salt-provider/SaltProvider.js +32 -155
  231. package/dist-cjs/salt-provider/SaltProvider.js.map +1 -1
  232. package/dist-cjs/scrim/Scrim.js +16 -111
  233. package/dist-cjs/scrim/Scrim.js.map +1 -1
  234. package/dist-cjs/segmented-button-group/SegmentedButtonGroup.js +1 -104
  235. package/dist-cjs/segmented-button-group/SegmentedButtonGroup.js.map +1 -1
  236. package/dist-cjs/semantic-icon-provider/SemanticIconProvider.js +1 -6
  237. package/dist-cjs/semantic-icon-provider/SemanticIconProvider.js.map +1 -1
  238. package/dist-cjs/spinner/Spinner.js +16 -116
  239. package/dist-cjs/spinner/Spinner.js.map +1 -1
  240. package/dist-cjs/spinner/svgSpinners/SpinnerSVG.js +43 -141
  241. package/dist-cjs/spinner/svgSpinners/SpinnerSVG.js.map +1 -1
  242. package/dist-cjs/split-layout/SplitLayout.js +13 -107
  243. package/dist-cjs/split-layout/SplitLayout.js.map +1 -1
  244. package/dist-cjs/stack-layout/StackLayout.js +21 -116
  245. package/dist-cjs/stack-layout/StackLayout.js.map +1 -1
  246. package/dist-cjs/status-adornment/ErrorAdornment.js +5 -11
  247. package/dist-cjs/status-adornment/ErrorAdornment.js.map +1 -1
  248. package/dist-cjs/status-adornment/StatusAdornment.js +9 -104
  249. package/dist-cjs/status-adornment/StatusAdornment.js.map +1 -1
  250. package/dist-cjs/status-adornment/SuccessAdornment.js +18 -14
  251. package/dist-cjs/status-adornment/SuccessAdornment.js.map +1 -1
  252. package/dist-cjs/status-adornment/WarningAdornment.js +1 -12
  253. package/dist-cjs/status-adornment/WarningAdornment.js.map +1 -1
  254. package/dist-cjs/status-indicator/StatusIndicator.js +10 -103
  255. package/dist-cjs/status-indicator/StatusIndicator.js.map +1 -1
  256. package/dist-cjs/status-indicator/ValidationStatus.js +0 -2
  257. package/dist-cjs/status-indicator/ValidationStatus.js.map +1 -1
  258. package/dist-cjs/switch/Switch.js +44 -150
  259. package/dist-cjs/switch/Switch.js.map +1 -1
  260. package/dist-cjs/tag/Tag.js +17 -112
  261. package/dist-cjs/tag/Tag.js.map +1 -1
  262. package/dist-cjs/text/Code.js +1 -8
  263. package/dist-cjs/text/Code.js.map +1 -1
  264. package/dist-cjs/text/Display.js +4 -30
  265. package/dist-cjs/text/Display.js.map +1 -1
  266. package/dist-cjs/text/Headings.js +4 -26
  267. package/dist-cjs/text/Headings.js.map +1 -1
  268. package/dist-cjs/text/Label.js +1 -8
  269. package/dist-cjs/text/Label.js.map +1 -1
  270. package/dist-cjs/text/Text.js +21 -117
  271. package/dist-cjs/text/Text.js.map +1 -1
  272. package/dist-cjs/text/TextAction.js +1 -9
  273. package/dist-cjs/text/TextAction.js.map +1 -1
  274. package/dist-cjs/text/TextNotation.js +1 -9
  275. package/dist-cjs/text/TextNotation.js.map +1 -1
  276. package/dist-cjs/theme/Accent.js +0 -2
  277. package/dist-cjs/theme/Accent.js.map +1 -1
  278. package/dist-cjs/theme/ActionFont.js +0 -2
  279. package/dist-cjs/theme/ActionFont.js.map +1 -1
  280. package/dist-cjs/theme/Corner.js +0 -2
  281. package/dist-cjs/theme/Corner.js.map +1 -1
  282. package/dist-cjs/theme/Density.js +0 -2
  283. package/dist-cjs/theme/Density.js.map +1 -1
  284. package/dist-cjs/theme/HeadingFont.js +0 -2
  285. package/dist-cjs/theme/HeadingFont.js.map +1 -1
  286. package/dist-cjs/theme/Mode.js +0 -2
  287. package/dist-cjs/theme/Mode.js.map +1 -1
  288. package/dist-cjs/theme/Theme.js +0 -2
  289. package/dist-cjs/theme/Theme.js.map +1 -1
  290. package/dist-cjs/toast/Toast.js +17 -116
  291. package/dist-cjs/toast/Toast.js.map +1 -1
  292. package/dist-cjs/toast/ToastContent.js +1 -104
  293. package/dist-cjs/toast/ToastContent.js.map +1 -1
  294. package/dist-cjs/toggle-button/ToggleButton.css.js +1 -1
  295. package/dist-cjs/toggle-button/ToggleButton.js +18 -111
  296. package/dist-cjs/toggle-button/ToggleButton.js.map +1 -1
  297. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js +10 -107
  298. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js.map +1 -1
  299. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js +0 -100
  300. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js.map +1 -1
  301. package/dist-cjs/tooltip/Tooltip.js +25 -119
  302. package/dist-cjs/tooltip/Tooltip.js.map +1 -1
  303. package/dist-cjs/tooltip/TooltipBase.js +25 -117
  304. package/dist-cjs/tooltip/TooltipBase.js.map +1 -1
  305. package/dist-cjs/tooltip/useAriaAnnounce.js +2 -104
  306. package/dist-cjs/tooltip/useAriaAnnounce.js.map +1 -1
  307. package/dist-cjs/tooltip/useTooltip.js +4 -103
  308. package/dist-cjs/tooltip/useTooltip.js.map +1 -1
  309. package/dist-cjs/utils/capitalize.js +0 -2
  310. package/dist-cjs/utils/capitalize.js.map +1 -1
  311. package/dist-cjs/utils/createChainedFunction.js +0 -2
  312. package/dist-cjs/utils/createChainedFunction.js.map +1 -1
  313. package/dist-cjs/utils/createContext.js +0 -2
  314. package/dist-cjs/utils/createContext.js.map +1 -1
  315. package/dist-cjs/utils/debounce.js +0 -2
  316. package/dist-cjs/utils/debounce.js.map +1 -1
  317. package/dist-cjs/utils/getRefFromChildren.js +4 -3
  318. package/dist-cjs/utils/getRefFromChildren.js.map +1 -1
  319. package/dist-cjs/utils/makePrefixer.js +0 -2
  320. package/dist-cjs/utils/makePrefixer.js.map +1 -1
  321. package/dist-cjs/utils/marginMiddleware.js +0 -2
  322. package/dist-cjs/utils/marginMiddleware.js.map +1 -1
  323. package/dist-cjs/utils/mergeProps.js +0 -2
  324. package/dist-cjs/utils/mergeProps.js.map +1 -1
  325. package/dist-cjs/utils/ownerDocument.js +0 -2
  326. package/dist-cjs/utils/ownerDocument.js.map +1 -1
  327. package/dist-cjs/utils/ownerWindow.js +0 -2
  328. package/dist-cjs/utils/ownerWindow.js.map +1 -1
  329. package/dist-cjs/utils/renderProps.js +1 -5
  330. package/dist-cjs/utils/renderProps.js.map +1 -1
  331. package/dist-cjs/utils/setRef.js +0 -2
  332. package/dist-cjs/utils/setRef.js.map +1 -1
  333. package/dist-cjs/utils/useControlled.js +0 -2
  334. package/dist-cjs/utils/useControlled.js.map +1 -1
  335. package/dist-cjs/utils/useEventCallback.js +4 -3
  336. package/dist-cjs/utils/useEventCallback.js.map +1 -1
  337. package/dist-cjs/utils/useFloatingUI/useFloatingUI.js +6 -33
  338. package/dist-cjs/utils/useFloatingUI/useFloatingUI.js.map +1 -1
  339. package/dist-cjs/utils/useForkRef.js +0 -2
  340. package/dist-cjs/utils/useForkRef.js.map +1 -1
  341. package/dist-cjs/utils/useId.js +5 -8
  342. package/dist-cjs/utils/useId.js.map +1 -1
  343. package/dist-cjs/utils/useIsFocusVisible.js +0 -2
  344. package/dist-cjs/utils/useIsFocusVisible.js.map +1 -1
  345. package/dist-cjs/utils/useIsomorphicLayoutEffect.js +0 -2
  346. package/dist-cjs/utils/useIsomorphicLayoutEffect.js.map +1 -1
  347. package/dist-cjs/utils/usePrevious.js +0 -2
  348. package/dist-cjs/utils/usePrevious.js.map +1 -1
  349. package/dist-cjs/utils/useResizeObserver.js +5 -7
  350. package/dist-cjs/utils/useResizeObserver.js.map +1 -1
  351. package/dist-cjs/utils/useResponsiveProp.js +2 -5
  352. package/dist-cjs/utils/useResponsiveProp.js.map +1 -1
  353. package/dist-cjs/utils/useValueEffect.js +1 -108
  354. package/dist-cjs/utils/useValueEffect.js.map +1 -1
  355. package/dist-cjs/viewport/ViewportProvider.js +1 -109
  356. package/dist-cjs/viewport/ViewportProvider.js.map +1 -1
  357. package/dist-es/accordion/Accordion.js +31 -121
  358. package/dist-es/accordion/Accordion.js.map +1 -1
  359. package/dist-es/accordion/AccordionContext.js +0 -99
  360. package/dist-es/accordion/AccordionContext.js.map +1 -1
  361. package/dist-es/accordion/AccordionGroup.js +1 -101
  362. package/dist-es/accordion/AccordionGroup.js.map +1 -1
  363. package/dist-es/accordion/AccordionHeader.js +33 -134
  364. package/dist-es/accordion/AccordionHeader.js.map +1 -1
  365. package/dist-es/accordion/AccordionPanel.js +22 -115
  366. package/dist-es/accordion/AccordionPanel.js.map +1 -1
  367. package/dist-es/aria-announcer/AriaAnnounce.js.map +1 -1
  368. package/dist-es/aria-announcer/AriaAnnouncerContext.js.map +1 -1
  369. package/dist-es/aria-announcer/AriaAnnouncerProvider.js +8 -8
  370. package/dist-es/aria-announcer/AriaAnnouncerProvider.js.map +1 -1
  371. package/dist-es/aria-announcer/useAriaAnnouncer.js +0 -104
  372. package/dist-es/aria-announcer/useAriaAnnouncer.js.map +1 -1
  373. package/dist-es/avatar/Avatar.js +18 -115
  374. package/dist-es/avatar/Avatar.js.map +1 -1
  375. package/dist-es/avatar/useAvatarImage.js +0 -99
  376. package/dist-es/avatar/useAvatarImage.js.map +1 -1
  377. package/dist-es/badge/Badge.js +8 -106
  378. package/dist-es/badge/Badge.js.map +1 -1
  379. package/dist-es/banner/Banner.js +18 -113
  380. package/dist-es/banner/Banner.js.map +1 -1
  381. package/dist-es/banner/BannerActions.js +1 -101
  382. package/dist-es/banner/BannerActions.js.map +1 -1
  383. package/dist-es/banner/BannerContent.js +1 -101
  384. package/dist-es/banner/BannerContent.js.map +1 -1
  385. package/dist-es/border-item/BorderItem.js +17 -109
  386. package/dist-es/border-item/BorderItem.js.map +1 -1
  387. package/dist-es/border-layout/BorderLayout.js +12 -106
  388. package/dist-es/border-layout/BorderLayout.js.map +1 -1
  389. package/dist-es/breakpoints/BreakpointProvider.js +2 -109
  390. package/dist-es/breakpoints/BreakpointProvider.js.map +1 -1
  391. package/dist-es/breakpoints/Breakpoints.js.map +1 -1
  392. package/dist-es/button/Button.js +24 -118
  393. package/dist-es/button/Button.js.map +1 -1
  394. package/dist-es/button/useButton.js.map +1 -1
  395. package/dist-es/card/Card.js +21 -113
  396. package/dist-es/card/Card.js.map +1 -1
  397. package/dist-es/checkbox/Checkbox.css.js +1 -1
  398. package/dist-es/checkbox/Checkbox.js +62 -148
  399. package/dist-es/checkbox/Checkbox.js.map +1 -1
  400. package/dist-es/checkbox/CheckboxGroup.js +32 -121
  401. package/dist-es/checkbox/CheckboxGroup.js.map +1 -1
  402. package/dist-es/checkbox/CheckboxIcon.js +24 -129
  403. package/dist-es/checkbox/CheckboxIcon.js.map +1 -1
  404. package/dist-es/checkbox/internal/CheckboxGroupContext.js +0 -99
  405. package/dist-es/checkbox/internal/CheckboxGroupContext.js.map +1 -1
  406. package/dist-es/checkbox/internal/useCheckboxGroup.js.map +1 -1
  407. package/dist-es/combo-box/ComboBox.js +33 -125
  408. package/dist-es/combo-box/ComboBox.js.map +1 -1
  409. package/dist-es/combo-box/useComboBox.js +1 -100
  410. package/dist-es/combo-box/useComboBox.js.map +1 -1
  411. package/dist-es/dialog/Dialog.js +38 -141
  412. package/dist-es/dialog/Dialog.js.map +1 -1
  413. package/dist-es/dialog/DialogActions.js +1 -102
  414. package/dist-es/dialog/DialogActions.js.map +1 -1
  415. package/dist-es/dialog/DialogCloseButton.js +11 -104
  416. package/dist-es/dialog/DialogCloseButton.js.map +1 -1
  417. package/dist-es/dialog/DialogContent.css.js +1 -1
  418. package/dist-es/dialog/DialogContent.js +40 -112
  419. package/dist-es/dialog/DialogContent.js.map +1 -1
  420. package/dist-es/dialog/DialogContext.js.map +1 -1
  421. package/dist-es/dialog/DialogHeader.js +24 -119
  422. package/dist-es/dialog/DialogHeader.js.map +1 -1
  423. package/dist-es/divider/Divider.js +15 -108
  424. package/dist-es/divider/Divider.js.map +1 -1
  425. package/dist-es/drawer/Drawer.js +13 -112
  426. package/dist-es/drawer/Drawer.js.map +1 -1
  427. package/dist-es/drawer/DrawerCloseButton.js +7 -103
  428. package/dist-es/drawer/DrawerCloseButton.js.map +1 -1
  429. package/dist-es/dropdown/Dropdown.js +38 -135
  430. package/dist-es/dropdown/Dropdown.js.map +1 -1
  431. package/dist-es/file-drop-zone/FileDropZone.js +21 -114
  432. package/dist-es/file-drop-zone/FileDropZone.js.map +1 -1
  433. package/dist-es/file-drop-zone/FileDropZoneIcon.js +2 -7
  434. package/dist-es/file-drop-zone/FileDropZoneIcon.js.map +1 -1
  435. package/dist-es/file-drop-zone/FileDropZoneTrigger.js +14 -108
  436. package/dist-es/file-drop-zone/FileDropZoneTrigger.js.map +1 -1
  437. package/dist-es/file-drop-zone/internal/utils.js +1 -2
  438. package/dist-es/file-drop-zone/internal/utils.js.map +1 -1
  439. package/dist-es/flex-item/FlexItem.js +10 -104
  440. package/dist-es/flex-item/FlexItem.js.map +1 -1
  441. package/dist-es/flex-layout/FlexLayout.js +21 -115
  442. package/dist-es/flex-layout/FlexLayout.js.map +1 -1
  443. package/dist-es/flow-layout/FlowLayout.js +1 -7
  444. package/dist-es/flow-layout/FlowLayout.js.map +1 -1
  445. package/dist-es/form-field/FormField.css.js +1 -1
  446. package/dist-es/form-field/FormField.js +30 -119
  447. package/dist-es/form-field/FormField.js.map +1 -1
  448. package/dist-es/form-field/FormFieldHelperText.js +24 -108
  449. package/dist-es/form-field/FormFieldHelperText.js.map +1 -1
  450. package/dist-es/form-field/FormFieldLabel.js +15 -104
  451. package/dist-es/form-field/FormFieldLabel.js.map +1 -1
  452. package/dist-es/form-field-context/FormFieldContext.js +0 -98
  453. package/dist-es/form-field-context/FormFieldContext.js.map +1 -1
  454. package/dist-es/form-field-context/useFormFieldProps.js.map +1 -1
  455. package/dist-es/grid-item/GridItem.js +10 -104
  456. package/dist-es/grid-item/GridItem.js.map +1 -1
  457. package/dist-es/grid-layout/GridLayout.js +13 -107
  458. package/dist-es/grid-layout/GridLayout.js.map +1 -1
  459. package/dist-es/input/Input.js +49 -147
  460. package/dist-es/input/Input.js.map +1 -1
  461. package/dist-es/interactable-card/InteractableCard.js +28 -120
  462. package/dist-es/interactable-card/InteractableCard.js.map +1 -1
  463. package/dist-es/interactable-card/InteractableCardGroup.js +9 -104
  464. package/dist-es/interactable-card/InteractableCardGroup.js.map +1 -1
  465. package/dist-es/interactable-card/InteractableCardGroupContext.js +0 -98
  466. package/dist-es/interactable-card/InteractableCardGroupContext.js.map +1 -1
  467. package/dist-es/interactable-card/useInteractableCard.js.map +1 -1
  468. package/dist-es/link/Link.js +22 -115
  469. package/dist-es/link/Link.js.map +1 -1
  470. package/dist-es/link-card/LinkCard.js +18 -111
  471. package/dist-es/link-card/LinkCard.js.map +1 -1
  472. package/dist-es/list-box/ListBox.js +8 -104
  473. package/dist-es/list-box/ListBox.js.map +1 -1
  474. package/dist-es/list-control/ListControlContext.js +0 -98
  475. package/dist-es/list-control/ListControlContext.js.map +1 -1
  476. package/dist-es/list-control/ListControlState.js +3 -102
  477. package/dist-es/list-control/ListControlState.js.map +1 -1
  478. package/dist-es/menu/Menu.js +2 -8
  479. package/dist-es/menu/Menu.js.map +1 -1
  480. package/dist-es/menu/MenuBase.js +10 -107
  481. package/dist-es/menu/MenuBase.js.map +1 -1
  482. package/dist-es/menu/MenuContext.js +0 -98
  483. package/dist-es/menu/MenuContext.js.map +1 -1
  484. package/dist-es/menu/MenuGroup.js +14 -112
  485. package/dist-es/menu/MenuGroup.js.map +1 -1
  486. package/dist-es/menu/MenuItem.js +51 -141
  487. package/dist-es/menu/MenuItem.js.map +1 -1
  488. package/dist-es/menu/MenuPanel.js +27 -121
  489. package/dist-es/menu/MenuPanel.js.map +1 -1
  490. package/dist-es/menu/MenuPanelBase.js +1 -5
  491. package/dist-es/menu/MenuPanelBase.js.map +1 -1
  492. package/dist-es/menu/MenuPanelContext.js +0 -98
  493. package/dist-es/menu/MenuPanelContext.js.map +1 -1
  494. package/dist-es/menu/MenuTrigger.js +20 -116
  495. package/dist-es/menu/MenuTrigger.js.map +1 -1
  496. package/dist-es/menu/MenuTriggerContext.js +0 -98
  497. package/dist-es/menu/MenuTriggerContext.js.map +1 -1
  498. package/dist-es/multiline-input/MultilineInput.js +54 -159
  499. package/dist-es/multiline-input/MultilineInput.js.map +1 -1
  500. package/dist-es/navigation-item/ExpansionIcon.js +1 -3
  501. package/dist-es/navigation-item/ExpansionIcon.js.map +1 -1
  502. package/dist-es/navigation-item/NavigationItem.js +32 -130
  503. package/dist-es/navigation-item/NavigationItem.js.map +1 -1
  504. package/dist-es/navigation-item/NavigationItemAction.js +0 -100
  505. package/dist-es/navigation-item/NavigationItemAction.js.map +1 -1
  506. package/dist-es/option/Option.js +32 -118
  507. package/dist-es/option/Option.js.map +1 -1
  508. package/dist-es/option/OptionGroup.js +14 -112
  509. package/dist-es/option/OptionGroup.js.map +1 -1
  510. package/dist-es/option/OptionList.js +17 -115
  511. package/dist-es/option/OptionList.js.map +1 -1
  512. package/dist-es/option/OptionListBase.js +9 -103
  513. package/dist-es/option/OptionListBase.js.map +1 -1
  514. package/dist-es/overlay/Overlay.js +18 -112
  515. package/dist-es/overlay/Overlay.js.map +1 -1
  516. package/dist-es/overlay/OverlayContext.js +0 -98
  517. package/dist-es/overlay/OverlayContext.js.map +1 -1
  518. package/dist-es/overlay/OverlayPanel.js +34 -125
  519. package/dist-es/overlay/OverlayPanel.js.map +1 -1
  520. package/dist-es/overlay/OverlayPanelCloseButton.js +7 -103
  521. package/dist-es/overlay/OverlayPanelCloseButton.js.map +1 -1
  522. package/dist-es/overlay/OverlayPanelContent.css.js +1 -1
  523. package/dist-es/overlay/OverlayPanelContent.js +43 -103
  524. package/dist-es/overlay/OverlayPanelContent.js.map +1 -1
  525. package/dist-es/overlay/OverlayTrigger.js +6 -109
  526. package/dist-es/overlay/OverlayTrigger.js.map +1 -1
  527. package/dist-es/pagination/CompactInput.js +20 -112
  528. package/dist-es/pagination/CompactInput.js.map +1 -1
  529. package/dist-es/pagination/CompactPaginator.js +21 -121
  530. package/dist-es/pagination/CompactPaginator.js.map +1 -1
  531. package/dist-es/pagination/GoToInput.js +31 -112
  532. package/dist-es/pagination/GoToInput.js.map +1 -1
  533. package/dist-es/pagination/PageButton.js +17 -110
  534. package/dist-es/pagination/PageButton.js.map +1 -1
  535. package/dist-es/pagination/PageRanges.js +15 -124
  536. package/dist-es/pagination/PageRanges.js.map +1 -1
  537. package/dist-es/pagination/Pagination.js +6 -101
  538. package/dist-es/pagination/Pagination.js.map +1 -1
  539. package/dist-es/pagination/PaginationContext.js.map +1 -1
  540. package/dist-es/pagination/Paginator.js +19 -119
  541. package/dist-es/pagination/Paginator.js.map +1 -1
  542. package/dist-es/pagination/usePagination.js.map +1 -1
  543. package/dist-es/pagination/usePaginationContext.js.map +1 -1
  544. package/dist-es/panel/Panel.js +9 -102
  545. package/dist-es/panel/Panel.js.map +1 -1
  546. package/dist-es/parent-child-layout/ParentChildLayout.js +24 -121
  547. package/dist-es/parent-child-layout/ParentChildLayout.js.map +1 -1
  548. package/dist-es/parent-child-layout/useIsViewportLargerThanBreakpoint.js +0 -101
  549. package/dist-es/parent-child-layout/useIsViewportLargerThanBreakpoint.js.map +1 -1
  550. package/dist-es/pill/Pill.js +17 -109
  551. package/dist-es/pill/Pill.js.map +1 -1
  552. package/dist-es/pill-input/PillInput.js +97 -202
  553. package/dist-es/pill-input/PillInput.js.map +1 -1
  554. package/dist-es/pill-input/useTruncatePills.js.map +1 -1
  555. package/dist-es/progress/CircularProgress/CircularProgress.js +44 -151
  556. package/dist-es/progress/CircularProgress/CircularProgress.js.map +1 -1
  557. package/dist-es/progress/LinearProgress/LinearProgress.js +28 -123
  558. package/dist-es/progress/LinearProgress/LinearProgress.js.map +1 -1
  559. package/dist-es/radio-button/RadioButton.css.js +1 -1
  560. package/dist-es/radio-button/RadioButton.js +60 -148
  561. package/dist-es/radio-button/RadioButton.js.map +1 -1
  562. package/dist-es/radio-button/RadioButtonGroup.js +36 -125
  563. package/dist-es/radio-button/RadioButtonGroup.js.map +1 -1
  564. package/dist-es/radio-button/RadioButtonIcon.js +45 -132
  565. package/dist-es/radio-button/RadioButtonIcon.js.map +1 -1
  566. package/dist-es/radio-button/internal/RadioGroupContext.js +0 -99
  567. package/dist-es/radio-button/internal/RadioGroupContext.js.map +1 -1
  568. package/dist-es/radio-button/internal/useRadioGroup.js.map +1 -1
  569. package/dist-es/salt-provider/SaltProvider.js +32 -153
  570. package/dist-es/salt-provider/SaltProvider.js.map +1 -1
  571. package/dist-es/scrim/Scrim.js +16 -109
  572. package/dist-es/scrim/Scrim.js.map +1 -1
  573. package/dist-es/segmented-button-group/SegmentedButtonGroup.js +1 -102
  574. package/dist-es/segmented-button-group/SegmentedButtonGroup.js.map +1 -1
  575. package/dist-es/semantic-icon-provider/SemanticIconProvider.js +1 -4
  576. package/dist-es/semantic-icon-provider/SemanticIconProvider.js.map +1 -1
  577. package/dist-es/spinner/Spinner.js +16 -114
  578. package/dist-es/spinner/Spinner.js.map +1 -1
  579. package/dist-es/spinner/svgSpinners/SpinnerSVG.js +43 -139
  580. package/dist-es/spinner/svgSpinners/SpinnerSVG.js.map +1 -1
  581. package/dist-es/split-layout/SplitLayout.js +13 -105
  582. package/dist-es/split-layout/SplitLayout.js.map +1 -1
  583. package/dist-es/stack-layout/StackLayout.js +21 -114
  584. package/dist-es/stack-layout/StackLayout.js.map +1 -1
  585. package/dist-es/status-adornment/ErrorAdornment.js +5 -9
  586. package/dist-es/status-adornment/ErrorAdornment.js.map +1 -1
  587. package/dist-es/status-adornment/StatusAdornment.js +9 -102
  588. package/dist-es/status-adornment/StatusAdornment.js.map +1 -1
  589. package/dist-es/status-adornment/SuccessAdornment.js +18 -12
  590. package/dist-es/status-adornment/SuccessAdornment.js.map +1 -1
  591. package/dist-es/status-adornment/WarningAdornment.js +1 -10
  592. package/dist-es/status-adornment/WarningAdornment.js.map +1 -1
  593. package/dist-es/status-indicator/StatusIndicator.js +10 -101
  594. package/dist-es/status-indicator/StatusIndicator.js.map +1 -1
  595. package/dist-es/status-indicator/ValidationStatus.js.map +1 -1
  596. package/dist-es/switch/Switch.js +44 -148
  597. package/dist-es/switch/Switch.js.map +1 -1
  598. package/dist-es/tag/Tag.js +17 -110
  599. package/dist-es/tag/Tag.js.map +1 -1
  600. package/dist-es/text/Code.js +1 -6
  601. package/dist-es/text/Code.js.map +1 -1
  602. package/dist-es/text/Display.js +4 -28
  603. package/dist-es/text/Display.js.map +1 -1
  604. package/dist-es/text/Headings.js +4 -24
  605. package/dist-es/text/Headings.js.map +1 -1
  606. package/dist-es/text/Label.js +1 -6
  607. package/dist-es/text/Label.js.map +1 -1
  608. package/dist-es/text/Text.js +21 -115
  609. package/dist-es/text/Text.js.map +1 -1
  610. package/dist-es/text/TextAction.js +1 -7
  611. package/dist-es/text/TextAction.js.map +1 -1
  612. package/dist-es/text/TextNotation.js +1 -7
  613. package/dist-es/text/TextNotation.js.map +1 -1
  614. package/dist-es/theme/Accent.js.map +1 -1
  615. package/dist-es/theme/ActionFont.js.map +1 -1
  616. package/dist-es/theme/Corner.js.map +1 -1
  617. package/dist-es/theme/HeadingFont.js.map +1 -1
  618. package/dist-es/theme/Theme.js.map +1 -1
  619. package/dist-es/toast/Toast.js +17 -114
  620. package/dist-es/toast/Toast.js.map +1 -1
  621. package/dist-es/toast/ToastContent.js +1 -102
  622. package/dist-es/toast/ToastContent.js.map +1 -1
  623. package/dist-es/toggle-button/ToggleButton.css.js +1 -1
  624. package/dist-es/toggle-button/ToggleButton.js +18 -109
  625. package/dist-es/toggle-button/ToggleButton.js.map +1 -1
  626. package/dist-es/toggle-button-group/ToggleButtonGroup.js +10 -105
  627. package/dist-es/toggle-button-group/ToggleButtonGroup.js.map +1 -1
  628. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js +0 -98
  629. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js.map +1 -1
  630. package/dist-es/tooltip/Tooltip.js +25 -117
  631. package/dist-es/tooltip/Tooltip.js.map +1 -1
  632. package/dist-es/tooltip/TooltipBase.js +25 -115
  633. package/dist-es/tooltip/TooltipBase.js.map +1 -1
  634. package/dist-es/tooltip/useAriaAnnounce.js +2 -102
  635. package/dist-es/tooltip/useAriaAnnounce.js.map +1 -1
  636. package/dist-es/tooltip/useTooltip.js +4 -101
  637. package/dist-es/tooltip/useTooltip.js.map +1 -1
  638. package/dist-es/utils/capitalize.js.map +1 -1
  639. package/dist-es/utils/createChainedFunction.js.map +1 -1
  640. package/dist-es/utils/createContext.js.map +1 -1
  641. package/dist-es/utils/debounce.js.map +1 -1
  642. package/dist-es/utils/getRefFromChildren.js +4 -1
  643. package/dist-es/utils/getRefFromChildren.js.map +1 -1
  644. package/dist-es/utils/marginMiddleware.js.map +1 -1
  645. package/dist-es/utils/mergeProps.js.map +1 -1
  646. package/dist-es/utils/ownerDocument.js.map +1 -1
  647. package/dist-es/utils/ownerWindow.js.map +1 -1
  648. package/dist-es/utils/renderProps.js +1 -3
  649. package/dist-es/utils/renderProps.js.map +1 -1
  650. package/dist-es/utils/setRef.js.map +1 -1
  651. package/dist-es/utils/useControlled.js.map +1 -1
  652. package/dist-es/utils/useEventCallback.js +4 -1
  653. package/dist-es/utils/useEventCallback.js.map +1 -1
  654. package/dist-es/utils/useFloatingUI/useFloatingUI.js +6 -31
  655. package/dist-es/utils/useFloatingUI/useFloatingUI.js.map +1 -1
  656. package/dist-es/utils/useForkRef.js.map +1 -1
  657. package/dist-es/utils/useId.js +2 -2
  658. package/dist-es/utils/useId.js.map +1 -1
  659. package/dist-es/utils/useIsFocusVisible.js.map +1 -1
  660. package/dist-es/utils/usePrevious.js.map +1 -1
  661. package/dist-es/utils/useResizeObserver.js +5 -5
  662. package/dist-es/utils/useResizeObserver.js.map +1 -1
  663. package/dist-es/utils/useResponsiveProp.js +2 -3
  664. package/dist-es/utils/useResponsiveProp.js.map +1 -1
  665. package/dist-es/utils/useValueEffect.js +1 -106
  666. package/dist-es/utils/useValueEffect.js.map +1 -1
  667. package/dist-es/viewport/ViewportProvider.js +1 -107
  668. package/dist-es/viewport/ViewportProvider.js.map +1 -1
  669. package/dist-types/file-drop-zone/FileDropZoneIcon.d.ts +1 -1
  670. package/package.json +8 -7
@@ -1 +1 @@
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\" | \"tertiary\";\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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkBA,MAAM,YAAA,GAAeA,0BAAa,sBAAsB,CAAA,CAAA;AA8BjD,MAAM,gBAAmB,GAAAC,gBAAA,CAG9B,SAASC,iBAAAA,CAAiB,OAAO,GAAK,EAAA;AACtC,EAAM,MAAA;AAAA,IACJ,MAAA;AAAA,IACA,eAAA;AAAA,IACA,QAAA;AAAA,IACA,SAAA;AAAA,IACA,QAAU,EAAA,YAAA;AAAA,IACV,OAAU,GAAA,SAAA;AAAA,IACV,KAAA;AAAA,IACA,MAAA;AAAA,IACA,QAAA;AAAA,IACA,OAAA;AAAA,IACA,OAAA;AAAA,IACA,SAAA;AAAA,IACG,GAAA,IAAA;AAAA,GACD,GAAA,KAAA,CAAA;AAEJ,EAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,wBAAA;AAAA,IACR,GAAK,EAAAC,kBAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,MAAM,wBAAwBC,qDAAyB,EAAA,CAAA;AAEvD,EAAM,MAAA,6BAAA,GACJ,+DAAuB,UAAW,CAAA,KAAA,CAAA,CAAA;AAEpC,EAAM,MAAA,QAAA,GAAA,CAAW,+DAAuB,QAAY,KAAA,YAAA,CAAA;AAEpD,EAAA,MAAM,CAAC,QAAA,EAAU,WAAW,CAAA,GAAIC,2BAAc,CAAA;AAAA,IAC5C,UAAY,EAAA,6BAAA;AAAA,IACZ,OAAA,EAAS,QAAQ,KAAK,CAAA;AAAA,IACtB,IAAM,EAAA,kBAAA;AAAA,IACN,KAAO,EAAA,UAAA;AAAA,GACR,CAAA,CAAA;AAED,EAAA,MAAM,IAAO,GAAA,qBAAA,GACT,qBAAsB,CAAA,WAAA,GACpB,aACA,OACF,GAAA,QAAA,CAAA;AAEJ,EAAA,MAAM,gBAAgB,qBAAuB,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,qBAAA,CAAA,WAAA,CAAA;AAE7C,EAAM,MAAA,YAAA,GAAe,+DAAuB,YAAa,CAAA,KAAA,CAAA,CAAA;AAEzD,EAAA,MAAM,WACJ,GAAA,IAAA,KAAS,OAAW,IAAA,IAAA,KAAS,aAAa,QAAW,GAAA,KAAA,CAAA,CAAA;AAEvD,EAAA,MAAM,cAAc,MAAU,IAAA,eAAA,CAAA;AAE9B,EAAM,MAAA,WAAA,GAAc,CAAC,KAAsC,KAAA;AACzD,IAAI,IAAA,qBAAA,IAAyB,CAAC,QAAU,EAAA;AACtC,MAAsB,qBAAA,CAAA,MAAA,CAAO,OAAO,KAAK,CAAA,CAAA;AACzC,MAAA,WAAA,CAAY,CAAC,QAAQ,CAAA,CAAA;AAAA,KACvB;AACA,IAAW,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAA,KAAA,CAAA,CAAA;AACX,IAAU,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,CAAA,KAAA,CAAA,CAAA;AAAA,GACZ,CAAA;AAEA,EAAI,IAAA,QAAA,CAAA;AAEJ,EAAA,IAAI,qBAAuB,EAAA;AACzB,IAAA,IAAI,QAAU,EAAA;AACZ,MAAW,QAAA,GAAA,CAAA,CAAA,CAAA;AAAA,eACF,aAAe,EAAA;AACxB,MAAW,QAAA,GAAA,CAAA,CAAA;AAAA,KACN,MAAA;AAEL,MAAA,QAAA,GAAW,WAAW,CAAI,GAAA,CAAA,CAAA,CAAA;AAC1B,MAAI,IAAA,CAAC,qBAAsB,CAAA,KAAA,IAAS,YAAc,EAAA;AAChD,QAAW,QAAA,GAAA,CAAA,CAAA;AAAA,OACb;AAAA,KACF;AAAA,GACK,MAAA;AACL,IAAA,QAAA,GAAW,WAAW,CAAK,CAAA,GAAA,CAAA,CAAA;AAAA,GAC7B;AAEA,EAAM,MAAA,OAAA,GAAUC,aAAuB,IAAI,CAAA,CAAA;AAC3C,EAAM,MAAA,SAAA,GAAYC,qBAAW,CAAA,GAAA,EAAK,OAAO,CAAA,CAAA;AAEzC,EAAA,MAAM,EAAE,MAAA,EAAQ,SAAU,EAAA,GAAIC,uCAAoB,CAAA;AAAA,IAChD,QAAA;AAAA,IACA,OAAA;AAAA,IACA,SAAA;AAAA,IACA,MAAA;AAAA,IACA,OAAA;AAAA,GACD,CAAA,CAAA;AAED,EAAA,uBACGC,cAAA,CAAA,KAAA,EAAA;AAAA,IACE,GAAG,SAAA;AAAA,IACJ,IAAA;AAAA,IACA,cAAc,EAAA,WAAA;AAAA,IACd,eAAe,EAAA,QAAA;AAAA,IACf,YAAY,EAAA,KAAA;AAAA,IACZ,SAAW,EAAAC,SAAA;AAAA,MACT,YAAa,EAAA;AAAA,MACb,aAAa,OAAO,CAAA;AAAA,MACpB;AAAA,QACE,CAAC,YAAa,CAAA,QAAQ,CAAI,GAAA,WAAA;AAAA,QAC1B,CAAC,YAAa,CAAA,CAAA,MAAA,EAASC,sBAAW,WAAe,IAAA,IAAA,GAAA,WAAA,GAAA,EAAE,GAAG,CAAI,GAAA,WAAA;AAAA,QAC1D,CAAC,YAAA,CAAa,QAAQ,CAAA,GAAI,SAAS,QAAY,IAAA,MAAA;AAAA,QAC/C,CAAC,YAAa,CAAA,UAAU,CAAI,GAAA,QAAA;AAAA,QAC5B,CAAC,YAAa,CAAA,UAAU,CAAI,GAAA,QAAA;AAAA,OAC9B;AAAA,MACA,SAAA;AAAA,KACF;AAAA,IACC,GAAG,IAAA;AAAA,IACJ,OAAS,EAAA,WAAA;AAAA,IACT,GAAK,EAAA,SAAA;AAAA,IACL,QAAA;AAAA,IAEC,QAAA;AAAA,GACH,CAAA,CAAA;AAEJ,CAAC;;;;"}
1
+ {"version":3,"file":"InteractableCard.js","sources":["../src/interactable-card/InteractableCard.tsx"],"sourcesContent":["import { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport {\n type ComponentPropsWithoutRef,\n type MouseEvent,\n type SyntheticEvent,\n forwardRef,\n useRef,\n} from \"react\";\nimport { capitalize, makePrefixer, useControlled, useForkRef } from \"../utils\";\nimport interactableCardCss from \"./InteractableCard.css\";\nimport {\n type InteractableCardValue,\n useInteractableCardGroup,\n} from \"./InteractableCardGroupContext\";\nimport { useInteractableCard } from \"./useInteractableCard\";\n\nconst withBaseName = makePrefixer(\"saltInteractableCard\");\n\nexport interface InteractableCardProps extends ComponentPropsWithoutRef<\"div\"> {\n /**\n * Accent border position: defaults to \"bottom\"\n */\n accent?: \"bottom\" | \"top\" | \"left\" | \"right\";\n /**\n * @deprecated Use the `accent` prop instead\n */\n accentPlacement?: \"bottom\" | \"top\" | \"left\" | \"right\";\n /**\n * If `true`, the card will be disabled.\n */\n disabled?: boolean;\n /**\n * Callback fired when the selection changes.\n * @param event\n */\n onChange?: (event: SyntheticEvent<HTMLDivElement>) => void;\n /**\n * Styling variant; defaults to \"primary\".\n */\n variant?: \"primary\" | \"secondary\" | \"tertiary\";\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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"}
@@ -1,7 +1,5 @@
1
1
  'use strict';
2
2
 
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
3
  var jsxRuntime = require('react/jsx-runtime');
6
4
  var styles = require('@salt-ds/styles');
7
5
  var window = require('@salt-ds/window');
@@ -14,103 +12,8 @@ var useForkRef = require('../utils/useForkRef.js');
14
12
  require('../utils/useId.js');
15
13
  require('../salt-provider/SaltProvider.js');
16
14
  require('../viewport/ViewportProvider.js');
17
- require('../accordion/AccordionGroup.js');
18
- require('../accordion/AccordionPanel.js');
19
- require('../accordion/Accordion.js');
20
- require('../accordion/AccordionHeader.js');
21
- require('../aria-announcer/AriaAnnouncerContext.js');
22
- require('../avatar/Avatar.js');
23
- require('../badge/Badge.js');
24
- require('../banner/Banner.js');
25
- require('../banner/BannerActions.js');
26
- require('../banner/BannerContent.js');
27
- require('../border-item/BorderItem.js');
28
- require('../border-layout/BorderLayout.js');
29
- require('../breakpoints/BreakpointProvider.js');
30
- require('../button/Button.js');
31
- require('../card/Card.js');
32
- require('../checkbox/Checkbox.js');
33
- require('../checkbox/CheckboxGroup.js');
34
- require('@salt-ds/icons');
35
- require('../combo-box/ComboBox.js');
36
- require('../dialog/Dialog.js');
37
- require('../dialog/DialogHeader.js');
38
- require('../dialog/DialogActions.js');
39
- require('../dialog/DialogContent.js');
40
- require('../dialog/DialogContext.js');
41
- require('../dialog/DialogCloseButton.js');
42
- require('../divider/Divider.js');
43
- require('../drawer/Drawer.js');
44
- require('../drawer/DrawerCloseButton.js');
45
- require('../dropdown/Dropdown.js');
46
- require('../file-drop-zone/FileDropZone.js');
47
- require('../file-drop-zone/FileDropZoneIcon.js');
48
- require('../file-drop-zone/FileDropZoneTrigger.js');
49
- require('../flex-item/FlexItem.js');
50
- require('../flex-layout/FlexLayout.js');
51
- require('../flow-layout/FlowLayout.js');
52
- require('../form-field/FormField.js');
53
- require('../form-field-context/FormFieldContext.js');
54
- require('../status-indicator/StatusIndicator.js');
55
- require('../text/Text.js');
56
- require('../text/Code.js');
57
- require('../text/Display.js');
58
- require('../text/Headings.js');
59
- require('../text/Label.js');
60
- require('../text/TextAction.js');
61
- require('../text/TextNotation.js');
62
- require('../grid-item/GridItem.js');
63
- require('../grid-layout/GridLayout.js');
64
- require('../input/Input.js');
65
- require('./InteractableCard.js');
66
- var InteractableCardGroupContext = require('./InteractableCardGroupContext.js');
67
- require('../link/Link.js');
68
- require('../link-card/LinkCard.js');
69
- require('../list-box/ListBox.js');
70
- require('../list-control/ListControlContext.js');
71
- require('@floating-ui/react');
72
- require('../menu/MenuContext.js');
73
- require('../menu/MenuItem.js');
74
- require('../menu/MenuPanel.js');
75
- require('../menu/MenuPanelContext.js');
76
- require('../menu/MenuTriggerContext.js');
77
- require('../menu/MenuGroup.js');
78
- require('../multiline-input/MultilineInput.js');
79
- require('../navigation-item/NavigationItem.js');
80
- require('../option/Option.js');
81
- require('../option/OptionGroup.js');
82
- require('../overlay/OverlayContext.js');
83
- require('../overlay/OverlayPanel.js');
84
- require('../overlay/OverlayPanelCloseButton.js');
85
- require('../overlay/OverlayPanelContent.js');
86
- require('../pagination/Pagination.js');
87
- require('../pagination/Paginator.js');
88
- require('../pagination/CompactInput.js');
89
- require('../pagination/CompactPaginator.js');
90
- require('../pagination/GoToInput.js');
91
- require('../panel/Panel.js');
92
- require('../parent-child-layout/ParentChildLayout.js');
93
- require('../pill/Pill.js');
94
- require('../progress/CircularProgress/CircularProgress.js');
95
- require('../progress/LinearProgress/LinearProgress.js');
96
- require('../radio-button/RadioButton.js');
97
- require('../radio-button/RadioButtonGroup.js');
98
- require('../scrim/Scrim.js');
99
- require('../segmented-button-group/SegmentedButtonGroup.js');
100
- require('../spinner/Spinner.js');
101
- require('../stack-layout/StackLayout.js');
102
- require('../status-adornment/StatusAdornment.js');
103
- require('../toast/Toast.js');
104
- require('../toast/ToastContent.js');
105
- require('../split-layout/SplitLayout.js');
106
- require('../switch/Switch.js');
107
- require('../tag/Tag.js');
108
- require('../toggle-button/ToggleButton.js');
109
- require('../toggle-button-group/ToggleButtonGroup.js');
110
- require('../toggle-button-group/ToggleButtonGroupContext.js');
111
- require('../tooltip/Tooltip.js');
112
- require('../semantic-icon-provider/SemanticIconProvider.js');
113
15
  var InteractableCardGroup$1 = require('./InteractableCardGroup.css.js');
16
+ var InteractableCardGroupContext = require('./InteractableCardGroupContext.js');
114
17
 
115
18
  const withBaseName = makePrefixer.makePrefixer("saltInteractableCardGroup");
116
19
  const InteractableCardGroup = React.forwardRef(function InteractableCardGroup2(props, ref) {
@@ -141,11 +44,11 @@ const InteractableCardGroup = React.forwardRef(function InteractableCardGroup2(p
141
44
  });
142
45
  const [elements, setElements] = React.useState([]);
143
46
  React.useEffect(() => {
144
- var _a, _b;
47
+ var _a;
145
48
  const childElements = Array.from(
146
- (_b = (_a = groupRef.current) == null ? void 0 : _a.querySelectorAll(
49
+ ((_a = groupRef.current) == null ? void 0 : _a.querySelectorAll(
147
50
  ".saltInteractableCard:not([disabled])"
148
- )) != null ? _b : []
51
+ )) ?? []
149
52
  );
150
53
  setElements(childElements);
151
54
  }, [children]);
@@ -231,17 +134,17 @@ const InteractableCardGroup = React.forwardRef(function InteractableCardGroup2(p
231
134
  }
232
135
  onKeyDown == null ? void 0 : onKeyDown(event);
233
136
  };
234
- return /* @__PURE__ */ jsxRuntime.jsx(InteractableCardGroupContext.InteractableCardGroupContext.Provider, {
235
- value: contextValue,
236
- children: /* @__PURE__ */ jsxRuntime.jsx("div", {
137
+ return /* @__PURE__ */ jsxRuntime.jsx(InteractableCardGroupContext.InteractableCardGroupContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsxRuntime.jsx(
138
+ "div",
139
+ {
237
140
  className: clsx.clsx(withBaseName(), className),
238
141
  role: multiSelect ? "group" : "radiogroup",
239
142
  onKeyDown: handleKeyDown,
240
143
  ref: handleRef,
241
144
  ...rest,
242
145
  children
243
- })
244
- });
146
+ }
147
+ ) });
245
148
  });
246
149
 
247
150
  exports.InteractableCardGroup = InteractableCardGroup;
@@ -1 +1 @@
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;;;;"}
1
+ {"version":3,"file":"InteractableCardGroup.js","sources":["../src/interactable-card/InteractableCardGroup.tsx"],"sourcesContent":["import { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport {\n type ComponentPropsWithoutRef,\n type KeyboardEvent,\n type SyntheticEvent,\n forwardRef,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\n\nimport { makePrefixer, useControlled, useForkRef } from \"../utils\";\nimport interactableCardGroupCss from \"./InteractableCardGroup.css\";\nimport {\n InteractableCardGroupContext,\n type InteractableCardValue,\n} from \"./InteractableCardGroupContext\";\n\nexport interface InteractableCardGroupProps\n extends Omit<ComponentPropsWithoutRef<\"div\">, \"onChange\"> {\n /**\n * The default value. Use when the component is not controlled. Should be an array when `multiSelect` is true.\n */\n defaultValue?: InteractableCardValue;\n /**\n * If `true`, the Interactable Card Group will be disabled.\n */\n disabled?: boolean;\n /**\n * The value. Use when the component is controlled. Should be an array when `multiSelect` is true.\n */\n value?: InteractableCardValue;\n /**\n * If `true` the Interactable Card Group will allow multiple selection functionality, with keyboard interactions matching those of a checkbox.\n * By default the group allows mutually exclusive selection with keyboard interactions matching radio buttons.\n */\n multiSelect?: boolean;\n /**\n * Callback fired when the selection changes.\n * @param event\n */\n onChange?: (\n event: SyntheticEvent<HTMLDivElement>,\n value: InteractableCardValue,\n ) => void;\n}\n\nconst withBaseName = makePrefixer(\"saltInteractableCardGroup\");\n\nexport const InteractableCardGroup = forwardRef<\n HTMLDivElement,\n InteractableCardGroupProps\n>(function InteractableCardGroup(props, ref) {\n const {\n children,\n className,\n value: valueProp,\n defaultValue,\n disabled,\n onChange,\n onKeyDown,\n multiSelect,\n ...rest\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-interactable-card-group\",\n css: interactableCardGroupCss,\n window: targetWindow,\n });\n\n const groupRef = useRef<HTMLDivElement>(null);\n const handleRef = useForkRef(ref, groupRef);\n\n const [value, setValue] = useControlled({\n default: defaultValue,\n controlled: valueProp,\n name: \"InteractableCardGroup\",\n state: \"value\",\n });\n\n const [elements, setElements] = useState<HTMLElement[]>([]);\n\n // biome-ignore lint/correctness/useExhaustiveDependencies: queries the dom when children changes.\n useEffect(() => {\n const childElements: HTMLElement[] = Array.from(\n groupRef.current?.querySelectorAll(\n \".saltInteractableCard:not([disabled])\",\n ) ?? [],\n );\n setElements(childElements);\n }, [children]);\n\n const select = useCallback(\n (\n event: SyntheticEvent<HTMLDivElement>,\n newValue: InteractableCardValue,\n ) => {\n if (multiSelect) {\n const currentValues = Array.isArray(value) ? value : [];\n const isSelected = currentValues.includes(newValue);\n\n const nextValues = isSelected\n ? currentValues.filter((val) => val !== newValue)\n : [...currentValues, newValue];\n setValue(nextValues);\n onChange?.(event, nextValues);\n } else {\n setValue(newValue);\n if (value !== newValue) {\n onChange?.(event, newValue);\n }\n }\n },\n [onChange, value, multiSelect],\n );\n\n const isSelected = useCallback(\n (cardValue: InteractableCardValue) =>\n multiSelect\n ? Array.isArray(value) && value.includes(cardValue)\n : cardValue !== undefined && value === cardValue,\n [value, multiSelect],\n );\n\n const isFirstChild = useCallback(\n (cardValue: InteractableCardValue) => {\n return (\n elements.findIndex(\n (element) => element.getAttribute(\"data-value\") === cardValue,\n ) === 0\n );\n },\n [elements],\n );\n\n const contextValue = useMemo(\n () => ({\n select,\n isSelected,\n isFirstChild,\n disabled,\n multiSelect,\n value,\n }),\n [select, isSelected, disabled, multiSelect, isFirstChild, value],\n );\n\n const handleKeyDown = (event: KeyboardEvent<HTMLDivElement>) => {\n const currentIndex = elements.findIndex(\n (element) => element === document.activeElement,\n );\n const nextIndex = (currentIndex + 1) % elements.length;\n const prevIndex = (currentIndex - 1 + elements.length) % elements.length;\n\n if (event.key === \" \") {\n event.preventDefault();\n select(\n event,\n elements[currentIndex].getAttribute(\n \"data-value\",\n ) as InteractableCardValue,\n );\n }\n\n if (!multiSelect) {\n switch (event.key) {\n case \"ArrowDown\":\n case \"ArrowRight\":\n select(\n event,\n elements[nextIndex].getAttribute(\n \"data-value\",\n ) as InteractableCardValue,\n );\n elements[nextIndex]?.focus();\n break;\n case \"ArrowUp\":\n case \"ArrowLeft\":\n select(\n event,\n elements[prevIndex].getAttribute(\n \"data-value\",\n ) as InteractableCardValue,\n );\n elements[prevIndex]?.focus();\n break;\n }\n }\n onKeyDown?.(event);\n };\n\n return (\n <InteractableCardGroupContext.Provider value={contextValue}>\n <div\n className={clsx(withBaseName(), className)}\n role={multiSelect ? \"group\" : \"radiogroup\"}\n onKeyDown={handleKeyDown}\n ref={handleRef}\n {...rest}\n >\n {children}\n </div>\n </InteractableCardGroupContext.Provider>\n );\n});\n"],"names":["makePrefixer","forwardRef","InteractableCardGroup","useWindow","useComponentCssInjection","interactableCardGroupCss","useRef","useForkRef","useControlled","useState","useEffect","useCallback","isSelected","useMemo","jsx","InteractableCardGroupContext","clsx"],"mappings":"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"}
@@ -1,7 +1,5 @@
1
1
  'use strict';
2
2
 
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
3
  var React = require('react');
6
4
  var createContext = require('../utils/createContext.js');
7
5
  require('react/jsx-runtime');
@@ -10,104 +8,6 @@ require('../utils/useFloatingUI/useFloatingUI.js');
10
8
  require('../utils/useId.js');
11
9
  require('../salt-provider/SaltProvider.js');
12
10
  require('../viewport/ViewportProvider.js');
13
- require('../accordion/AccordionGroup.js');
14
- require('../accordion/AccordionPanel.js');
15
- require('../accordion/Accordion.js');
16
- require('../accordion/AccordionHeader.js');
17
- require('../aria-announcer/AriaAnnouncerContext.js');
18
- require('../avatar/Avatar.js');
19
- require('../badge/Badge.js');
20
- require('../banner/Banner.js');
21
- require('../banner/BannerActions.js');
22
- require('../banner/BannerContent.js');
23
- require('../border-item/BorderItem.js');
24
- require('../border-layout/BorderLayout.js');
25
- require('../breakpoints/BreakpointProvider.js');
26
- require('../button/Button.js');
27
- require('../card/Card.js');
28
- require('../checkbox/Checkbox.js');
29
- require('../checkbox/CheckboxGroup.js');
30
- require('@salt-ds/icons');
31
- require('@salt-ds/styles');
32
- require('@salt-ds/window');
33
- require('../combo-box/ComboBox.js');
34
- require('../dialog/Dialog.js');
35
- require('../dialog/DialogHeader.js');
36
- require('../dialog/DialogActions.js');
37
- require('../dialog/DialogContent.js');
38
- require('../dialog/DialogContext.js');
39
- require('../dialog/DialogCloseButton.js');
40
- require('../divider/Divider.js');
41
- require('../drawer/Drawer.js');
42
- require('../drawer/DrawerCloseButton.js');
43
- require('../dropdown/Dropdown.js');
44
- require('../file-drop-zone/FileDropZone.js');
45
- require('../file-drop-zone/FileDropZoneIcon.js');
46
- require('../file-drop-zone/FileDropZoneTrigger.js');
47
- require('../flex-item/FlexItem.js');
48
- require('../flex-layout/FlexLayout.js');
49
- require('../flow-layout/FlowLayout.js');
50
- require('../form-field/FormField.js');
51
- require('../form-field-context/FormFieldContext.js');
52
- require('../status-indicator/StatusIndicator.js');
53
- require('../text/Text.js');
54
- require('../text/Code.js');
55
- require('../text/Display.js');
56
- require('../text/Headings.js');
57
- require('../text/Label.js');
58
- require('../text/TextAction.js');
59
- require('../text/TextNotation.js');
60
- require('../grid-item/GridItem.js');
61
- require('../grid-layout/GridLayout.js');
62
- require('../input/Input.js');
63
- require('./InteractableCard.js');
64
- require('./InteractableCardGroup.js');
65
- require('../link/Link.js');
66
- require('../link-card/LinkCard.js');
67
- require('../list-box/ListBox.js');
68
- require('../list-control/ListControlContext.js');
69
- require('@floating-ui/react');
70
- require('../menu/MenuContext.js');
71
- require('../menu/MenuItem.js');
72
- require('../menu/MenuPanel.js');
73
- require('../menu/MenuPanelContext.js');
74
- require('../menu/MenuTriggerContext.js');
75
- require('../menu/MenuGroup.js');
76
- require('../multiline-input/MultilineInput.js');
77
- require('../navigation-item/NavigationItem.js');
78
- require('../option/Option.js');
79
- require('../option/OptionGroup.js');
80
- require('../overlay/OverlayContext.js');
81
- require('../overlay/OverlayPanel.js');
82
- require('../overlay/OverlayPanelCloseButton.js');
83
- require('../overlay/OverlayPanelContent.js');
84
- require('../pagination/Pagination.js');
85
- require('../pagination/Paginator.js');
86
- require('../pagination/CompactInput.js');
87
- require('../pagination/CompactPaginator.js');
88
- require('../pagination/GoToInput.js');
89
- require('../panel/Panel.js');
90
- require('../parent-child-layout/ParentChildLayout.js');
91
- require('../pill/Pill.js');
92
- require('../progress/CircularProgress/CircularProgress.js');
93
- require('../progress/LinearProgress/LinearProgress.js');
94
- require('../radio-button/RadioButton.js');
95
- require('../radio-button/RadioButtonGroup.js');
96
- require('../scrim/Scrim.js');
97
- require('../segmented-button-group/SegmentedButtonGroup.js');
98
- require('../spinner/Spinner.js');
99
- require('../stack-layout/StackLayout.js');
100
- require('../status-adornment/StatusAdornment.js');
101
- require('../toast/Toast.js');
102
- require('../toast/ToastContent.js');
103
- require('../split-layout/SplitLayout.js');
104
- require('../switch/Switch.js');
105
- require('../tag/Tag.js');
106
- require('../toggle-button/ToggleButton.js');
107
- require('../toggle-button-group/ToggleButtonGroup.js');
108
- require('../toggle-button-group/ToggleButtonGroupContext.js');
109
- require('../tooltip/Tooltip.js');
110
- require('../semantic-icon-provider/SemanticIconProvider.js');
111
11
 
112
12
  const InteractableCardGroupContext = createContext.createContext("InteractableCardGroupContext", void 0);
113
13
  function useInteractableCardGroup() {
@@ -1 +1 @@
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;;;;;"}
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;AAEpC,SAAS,wBAA2B,GAAA;AACzC,EAAA,OAAOC,iBAAW,4BAA4B,CAAA;AAChD;;;;;"}
@@ -1,7 +1,5 @@
1
1
  'use strict';
2
2
 
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
3
  var React = require('react');
6
4
 
7
5
  const useInteractableCard = ({
@@ -1 +1 @@
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;;;;"}
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;AACF,CAA2C,KAAA;AACzC,EAAA,MAAM,CAAC,SAAA,EAAW,YAAY,CAAA,GAAIA,eAAS,EAAE,CAAA;AAC7C,EAAA,MAAM,CAAC,MAAA,EAAQ,SAAS,CAAA,GAAIA,eAAS,KAAK,CAAA;AAE1C,EAAA,MAAM,KAAQ,GAAA,OAAA;AACd,EAAA,MAAM,KAAQ,GAAA,GAAA;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;AAAA;AACjB,OACC,CAAC,CAAA;AAEJ,IAAA,OAAO,MAAM;AACX,MAAA,YAAA,CAAa,CAAC,CAAA;AAAA,KAChB;AAAA,GACC,EAAA,CAAC,MAAQ,EAAA,SAAS,CAAC,CAAA;AAEtB,EAAM,MAAA,WAAA,GAAc,CAAC,KAA4B,KAAA;AAC/C,IAAA,YAAA,CAAa,EAAE,CAAA;AACf,IAAA,SAAA,CAAU,KAAK,CAAA;AACf,IAAU,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,CAAA,KAAA,CAAA;AAAA,GACZ;AAEA,EAAM,MAAA,WAAA,GAAc,CAAC,KAAyB,KAAA;AAC5C,IAAA,SAAA,CAAU,IAAI,CAAA;AACd,IAAU,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,CAAA,KAAA,CAAA;AAAA,GACZ;AAEA,EAAM,MAAA,UAAA,GAAa,CAAC,KAAyB,KAAA;AAC3C,IAAA,SAAA,CAAU,KAAK,CAAA;AACf,IAAS,MAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,MAAA,CAAA,KAAA,CAAA;AAAA,GACX;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;AACtB,MAAA,KAAA,CAAM,cAAe,EAAA;AACrB,MAAA,SAAA,CAAU,IAAI,CAAA;AACd,MAAU,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,CAAA,KAAA,CAAA;AAAA;AAEZ,IAAY,SAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,SAAA,CAAA,KAAA,CAAA;AAAA,GACd;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;AAAA,GACX;AAEA,EAAO,OAAA;AAAA,IACL,MAAA;AAAA,IACA;AAAA,GACF;AACF;;;;"}
@@ -1,7 +1,5 @@
1
1
  'use strict';
2
2
 
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
3
  var jsxRuntime = require('react/jsx-runtime');
6
4
  var styles = require('@salt-ds/styles');
7
5
  var window = require('@salt-ds/window');
@@ -20,94 +18,6 @@ require('../utils/useFloatingUI/useFloatingUI.js');
20
18
  require('../utils/useId.js');
21
19
  require('../salt-provider/SaltProvider.js');
22
20
  require('../viewport/ViewportProvider.js');
23
- require('../accordion/AccordionGroup.js');
24
- require('../accordion/AccordionPanel.js');
25
- require('../accordion/Accordion.js');
26
- require('../accordion/AccordionHeader.js');
27
- require('../aria-announcer/AriaAnnouncerContext.js');
28
- require('../avatar/Avatar.js');
29
- require('../badge/Badge.js');
30
- require('../banner/Banner.js');
31
- require('../banner/BannerActions.js');
32
- require('../banner/BannerContent.js');
33
- require('../border-item/BorderItem.js');
34
- require('../border-layout/BorderLayout.js');
35
- require('../breakpoints/BreakpointProvider.js');
36
- require('../button/Button.js');
37
- require('../card/Card.js');
38
- require('../checkbox/Checkbox.js');
39
- require('../checkbox/CheckboxGroup.js');
40
- require('@salt-ds/icons');
41
- require('../combo-box/ComboBox.js');
42
- require('../dialog/Dialog.js');
43
- require('../dialog/DialogHeader.js');
44
- require('../dialog/DialogActions.js');
45
- require('../dialog/DialogContent.js');
46
- require('../dialog/DialogContext.js');
47
- require('../dialog/DialogCloseButton.js');
48
- require('../divider/Divider.js');
49
- require('../drawer/Drawer.js');
50
- require('../drawer/DrawerCloseButton.js');
51
- require('../dropdown/Dropdown.js');
52
- require('../file-drop-zone/FileDropZone.js');
53
- require('../file-drop-zone/FileDropZoneIcon.js');
54
- require('../file-drop-zone/FileDropZoneTrigger.js');
55
- require('../flex-item/FlexItem.js');
56
- require('../flex-layout/FlexLayout.js');
57
- require('../flow-layout/FlowLayout.js');
58
- require('../form-field/FormField.js');
59
- require('../form-field-context/FormFieldContext.js');
60
- require('../status-indicator/StatusIndicator.js');
61
- require('../grid-item/GridItem.js');
62
- require('../grid-layout/GridLayout.js');
63
- require('../input/Input.js');
64
- require('../interactable-card/InteractableCard.js');
65
- require('../interactable-card/InteractableCardGroup.js');
66
- require('../interactable-card/InteractableCardGroupContext.js');
67
- require('../link-card/LinkCard.js');
68
- require('../list-box/ListBox.js');
69
- require('../list-control/ListControlContext.js');
70
- require('@floating-ui/react');
71
- require('../menu/MenuContext.js');
72
- require('../menu/MenuItem.js');
73
- require('../menu/MenuPanel.js');
74
- require('../menu/MenuPanelContext.js');
75
- require('../menu/MenuTriggerContext.js');
76
- require('../menu/MenuGroup.js');
77
- require('../multiline-input/MultilineInput.js');
78
- require('../navigation-item/NavigationItem.js');
79
- require('../option/Option.js');
80
- require('../option/OptionGroup.js');
81
- require('../overlay/OverlayContext.js');
82
- require('../overlay/OverlayPanel.js');
83
- require('../overlay/OverlayPanelCloseButton.js');
84
- require('../overlay/OverlayPanelContent.js');
85
- require('../pagination/Pagination.js');
86
- require('../pagination/Paginator.js');
87
- require('../pagination/CompactInput.js');
88
- require('../pagination/CompactPaginator.js');
89
- require('../pagination/GoToInput.js');
90
- require('../panel/Panel.js');
91
- require('../parent-child-layout/ParentChildLayout.js');
92
- require('../pill/Pill.js');
93
- require('../progress/CircularProgress/CircularProgress.js');
94
- require('../progress/LinearProgress/LinearProgress.js');
95
- require('../radio-button/RadioButton.js');
96
- require('../radio-button/RadioButtonGroup.js');
97
- require('../scrim/Scrim.js');
98
- require('../segmented-button-group/SegmentedButtonGroup.js');
99
- require('../spinner/Spinner.js');
100
- require('../stack-layout/StackLayout.js');
101
- require('../status-adornment/StatusAdornment.js');
102
- require('../toast/Toast.js');
103
- require('../toast/ToastContent.js');
104
- require('../split-layout/SplitLayout.js');
105
- require('../switch/Switch.js');
106
- require('../tag/Tag.js');
107
- require('../toggle-button/ToggleButton.js');
108
- require('../toggle-button-group/ToggleButtonGroup.js');
109
- require('../toggle-button-group/ToggleButtonGroupContext.js');
110
- require('../tooltip/Tooltip.js');
111
21
  var Link$1 = require('./Link.css.js');
112
22
 
113
23
  const withBaseName = makePrefixer.makePrefixer("saltLink");
@@ -116,8 +26,8 @@ const Link = React.forwardRef(function Link2({
116
26
  href,
117
27
  className,
118
28
  children,
119
- variant = "primary",
120
- color = "primary",
29
+ color: colorProp,
30
+ variant,
121
31
  target = "_self",
122
32
  ...rest
123
33
  }, ref) {
@@ -128,32 +38,27 @@ const Link = React.forwardRef(function Link2({
128
38
  window: targetWindow
129
39
  });
130
40
  const { ExternalIcon } = SemanticIconProvider.useIcon();
41
+ const color = variant ?? colorProp ?? "primary";
131
42
  const LinkIconComponent = IconComponent === void 0 ? ExternalIcon : IconComponent;
132
- return /* @__PURE__ */ jsxRuntime.jsxs(Text.Text, {
133
- as: "a",
134
- className: clsx.clsx(withBaseName(), className),
135
- href,
136
- ref,
137
- target,
138
- variant,
139
- color,
140
- ...rest,
141
- children: [
142
- children,
143
- target === "_blank" && /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, {
144
- children: [
145
- LinkIconComponent && /* @__PURE__ */ jsxRuntime.jsx(LinkIconComponent, {
146
- className: withBaseName("icon"),
147
- "aria-hidden": true
148
- }),
149
- /* @__PURE__ */ jsxRuntime.jsx("span", {
150
- className: withBaseName("externalLinkADA"),
151
- children: "External"
152
- })
153
- ]
154
- })
155
- ]
156
- });
43
+ return /* @__PURE__ */ jsxRuntime.jsxs(
44
+ Text.Text,
45
+ {
46
+ as: "a",
47
+ className: clsx.clsx(withBaseName(), className),
48
+ href,
49
+ ref,
50
+ target,
51
+ color,
52
+ ...rest,
53
+ children: [
54
+ children,
55
+ target === "_blank" && /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
56
+ LinkIconComponent && /* @__PURE__ */ jsxRuntime.jsx(LinkIconComponent, { className: withBaseName("icon"), "aria-hidden": true }),
57
+ /* @__PURE__ */ jsxRuntime.jsx("span", { className: withBaseName("externalLinkADA"), children: "External" })
58
+ ] })
59
+ ]
60
+ }
61
+ );
157
62
  });
158
63
 
159
64
  exports.Link = Link;
@@ -1 +1 @@
1
- {"version":3,"file":"Link.js","sources":["../src/link/Link.tsx"],"sourcesContent":["import type { IconProps } from \"@salt-ds/icons\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport { type ComponentType, type ReactElement, forwardRef } from \"react\";\nimport { useIcon } from \"../semantic-icon-provider\";\nimport { Text, type TextProps } from \"../text\";\nimport { makePrefixer } from \"../utils\";\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,\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 const { ExternalIcon } = useIcon();\n\n const LinkIconComponent =\n IconComponent === undefined ? ExternalIcon : IconComponent;\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 {LinkIconComponent && (\n <LinkIconComponent className={withBaseName(\"icon\")} aria-hidden />\n )}\n <span className={withBaseName(\"externalLinkADA\")}>External</span>\n </>\n )}\n </Text>\n );\n});\n"],"names":["makePrefixer","forwardRef","Link","useWindow","useComponentCssInjection","linkCss","useIcon","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,aAAA;AAAA,EACA,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;AACD,EAAM,MAAA,EAAE,YAAa,EAAA,GAAIC,4BAAQ,EAAA,CAAA;AAEjC,EAAM,MAAA,iBAAA,GACJ,aAAkB,KAAA,KAAA,CAAA,GAAY,YAAe,GAAA,aAAA,CAAA;AAE/C,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,iBAAA,oBACEC,cAAA,CAAA,iBAAA,EAAA;AAAA,YAAkB,SAAA,EAAW,aAAa,MAAM,CAAA;AAAA,YAAG,aAAW,EAAA,IAAA;AAAA,WAAC,CAAA;AAAA,0BAEjEA,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 } from \"@salt-ds/icons\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport { type ComponentType, type ReactElement, forwardRef } from \"react\";\nimport { useIcon } from \"../semantic-icon-provider\";\nimport { Text, type TextProps } from \"../text\";\nimport { makePrefixer } from \"../utils\";\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,\n href,\n className,\n children,\n color: colorProp,\n variant,\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 const { ExternalIcon } = useIcon();\n\n const color = variant ?? colorProp ?? \"primary\";\n const LinkIconComponent =\n IconComponent === undefined ? ExternalIcon : IconComponent;\n\n return (\n <Text\n as=\"a\"\n className={clsx(withBaseName(), className)}\n href={href}\n ref={ref}\n target={target}\n color={color}\n {...rest}\n >\n {children}\n {target === \"_blank\" && (\n <>\n {LinkIconComponent && (\n <LinkIconComponent className={withBaseName(\"icon\")} aria-hidden />\n )}\n <span className={withBaseName(\"externalLinkADA\")}>External</span>\n </>\n )}\n </Text>\n );\n});\n"],"names":["makePrefixer","forwardRef","Link","useWindow","useComponentCssInjection","linkCss","useIcon","jsxs","Text","clsx","Fragment"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAUA,MAAM,YAAA,GAAeA,0BAAa,UAAU,CAAA;AAY/B,MAAA,IAAA,GAAOC,gBAAyC,CAAA,SAASC,KACpE,CAAA;AAAA,EACE,aAAA;AAAA,EACA,IAAA;AAAA,EACA,SAAA;AAAA,EACA,QAAA;AAAA,EACA,KAAO,EAAA,SAAA;AAAA,EACP,OAAA;AAAA,EACA,MAAS,GAAA,OAAA;AAAA,EACT,GAAG;AACL,CAAA,EACA,GACyB,EAAA;AACzB,EAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,WAAA;AAAA,IACR,GAAK,EAAAC,MAAA;AAAA,IACL,MAAQ,EAAA;AAAA,GACT,CAAA;AACD,EAAM,MAAA,EAAE,YAAa,EAAA,GAAIC,4BAAQ,EAAA;AAEjC,EAAM,MAAA,KAAA,GAAQ,WAAW,SAAa,IAAA,SAAA;AACtC,EAAM,MAAA,iBAAA,GACJ,aAAkB,KAAA,KAAA,CAAA,GAAY,YAAe,GAAA,aAAA;AAE/C,EACE,uBAAAC,eAAA;AAAA,IAACC,SAAA;AAAA,IAAA;AAAA,MACC,EAAG,EAAA,GAAA;AAAA,MACH,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,MACzC,IAAA;AAAA,MACA,GAAA;AAAA,MACA,MAAA;AAAA,MACA,KAAA;AAAA,MACC,GAAG,IAAA;AAAA,MAEH,QAAA,EAAA;AAAA,QAAA,QAAA;AAAA,QACA,MAAA,KAAW,4BAEPF,eAAA,CAAAG,mBAAA,EAAA,EAAA,QAAA,EAAA;AAAA,UAAA,iBAAA,mCACE,iBAAkB,EAAA,EAAA,SAAA,EAAW,aAAa,MAAM,CAAA,EAAG,eAAW,IAAC,EAAA,CAAA;AAAA,yCAEjE,MAAK,EAAA,EAAA,SAAA,EAAW,YAAa,CAAA,iBAAiB,GAAG,QAAQ,EAAA,UAAA,EAAA;AAAA,SAC5D,EAAA;AAAA;AAAA;AAAA,GAEJ;AAEJ,CAAC;;;;"}