@salt-ds/core 1.21.0 → 1.23.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (421) hide show
  1. package/css/salt-core.css +158 -94
  2. package/dist-cjs/accordion/Accordion.js +14 -9
  3. package/dist-cjs/accordion/Accordion.js.map +1 -1
  4. package/dist-cjs/accordion/AccordionContext.js +14 -9
  5. package/dist-cjs/accordion/AccordionContext.js.map +1 -1
  6. package/dist-cjs/accordion/AccordionGroup.js +14 -9
  7. package/dist-cjs/accordion/AccordionGroup.js.map +1 -1
  8. package/dist-cjs/accordion/AccordionHeader.js +13 -8
  9. package/dist-cjs/accordion/AccordionHeader.js.map +1 -1
  10. package/dist-cjs/accordion/AccordionPanel.js +14 -9
  11. package/dist-cjs/accordion/AccordionPanel.js.map +1 -1
  12. package/dist-cjs/aria-announcer/useAriaAnnouncer.js +14 -9
  13. package/dist-cjs/aria-announcer/useAriaAnnouncer.js.map +1 -1
  14. package/dist-cjs/avatar/Avatar.js +14 -9
  15. package/dist-cjs/avatar/Avatar.js.map +1 -1
  16. package/dist-cjs/avatar/useAvatarImage.js +14 -9
  17. package/dist-cjs/avatar/useAvatarImage.js.map +1 -1
  18. package/dist-cjs/badge/Badge.js +14 -9
  19. package/dist-cjs/badge/Badge.js.map +1 -1
  20. package/dist-cjs/banner/Banner.js +14 -9
  21. package/dist-cjs/banner/Banner.js.map +1 -1
  22. package/dist-cjs/banner/BannerActions.js +14 -9
  23. package/dist-cjs/banner/BannerActions.js.map +1 -1
  24. package/dist-cjs/banner/BannerContent.js +14 -9
  25. package/dist-cjs/banner/BannerContent.js.map +1 -1
  26. package/dist-cjs/border-item/BorderItem.js +14 -9
  27. package/dist-cjs/border-item/BorderItem.js.map +1 -1
  28. package/dist-cjs/border-layout/BorderLayout.js +14 -9
  29. package/dist-cjs/border-layout/BorderLayout.js.map +1 -1
  30. package/dist-cjs/button/Button.js +14 -9
  31. package/dist-cjs/button/Button.js.map +1 -1
  32. package/dist-cjs/card/Card.css.js +1 -1
  33. package/dist-cjs/card/Card.js +14 -9
  34. package/dist-cjs/card/Card.js.map +1 -1
  35. package/dist-cjs/checkbox/Checkbox.js +14 -9
  36. package/dist-cjs/checkbox/Checkbox.js.map +1 -1
  37. package/dist-cjs/checkbox/CheckboxGroup.js +14 -9
  38. package/dist-cjs/checkbox/CheckboxGroup.js.map +1 -1
  39. package/dist-cjs/checkbox/CheckboxIcon.js +14 -9
  40. package/dist-cjs/checkbox/CheckboxIcon.js.map +1 -1
  41. package/dist-cjs/checkbox/internal/CheckboxGroupContext.js +14 -9
  42. package/dist-cjs/checkbox/internal/CheckboxGroupContext.js.map +1 -1
  43. package/dist-cjs/combo-box/ComboBox.js +14 -9
  44. package/dist-cjs/combo-box/ComboBox.js.map +1 -1
  45. package/dist-cjs/combo-box/useComboBox.js +14 -9
  46. package/dist-cjs/combo-box/useComboBox.js.map +1 -1
  47. package/dist-cjs/dialog/Dialog.js +16 -11
  48. package/dist-cjs/dialog/Dialog.js.map +1 -1
  49. package/dist-cjs/dialog/DialogActions.js +14 -9
  50. package/dist-cjs/dialog/DialogActions.js.map +1 -1
  51. package/dist-cjs/dialog/DialogCloseButton.js +17 -10
  52. package/dist-cjs/dialog/DialogCloseButton.js.map +1 -1
  53. package/dist-cjs/dialog/DialogContent.js +14 -9
  54. package/dist-cjs/dialog/DialogContent.js.map +1 -1
  55. package/dist-cjs/dialog/DialogHeader.css.js +1 -1
  56. package/dist-cjs/dialog/DialogHeader.js +60 -52
  57. package/dist-cjs/dialog/DialogHeader.js.map +1 -1
  58. package/dist-cjs/drawer/Drawer.js +16 -11
  59. package/dist-cjs/drawer/Drawer.js.map +1 -1
  60. package/dist-cjs/drawer/DrawerCloseButton.js +14 -9
  61. package/dist-cjs/drawer/DrawerCloseButton.js.map +1 -1
  62. package/dist-cjs/dropdown/Dropdown.js +14 -9
  63. package/dist-cjs/dropdown/Dropdown.js.map +1 -1
  64. package/dist-cjs/file-drop-zone/FileDropZone.js +14 -9
  65. package/dist-cjs/file-drop-zone/FileDropZone.js.map +1 -1
  66. package/dist-cjs/file-drop-zone/FileDropZoneTrigger.js +14 -9
  67. package/dist-cjs/file-drop-zone/FileDropZoneTrigger.js.map +1 -1
  68. package/dist-cjs/flex-item/FlexItem.js +14 -9
  69. package/dist-cjs/flex-item/FlexItem.js.map +1 -1
  70. package/dist-cjs/flex-layout/FlexLayout.js +14 -9
  71. package/dist-cjs/flex-layout/FlexLayout.js.map +1 -1
  72. package/dist-cjs/form-field/FormField.js +14 -9
  73. package/dist-cjs/form-field/FormField.js.map +1 -1
  74. package/dist-cjs/form-field/FormFieldHelperText.js +8 -3
  75. package/dist-cjs/form-field/FormFieldHelperText.js.map +1 -1
  76. package/dist-cjs/form-field/FormFieldLabel.js +9 -4
  77. package/dist-cjs/form-field/FormFieldLabel.js.map +1 -1
  78. package/dist-cjs/form-field-context/FormFieldContext.js +14 -9
  79. package/dist-cjs/form-field-context/FormFieldContext.js.map +1 -1
  80. package/dist-cjs/grid-item/GridItem.js +14 -9
  81. package/dist-cjs/grid-item/GridItem.js.map +1 -1
  82. package/dist-cjs/grid-layout/GridLayout.js +14 -9
  83. package/dist-cjs/grid-layout/GridLayout.js.map +1 -1
  84. package/dist-cjs/index.js +13 -4
  85. package/dist-cjs/index.js.map +1 -1
  86. package/dist-cjs/input/Input.js +14 -9
  87. package/dist-cjs/input/Input.js.map +1 -1
  88. package/dist-cjs/interactable-card/InteractableCard.css.js +6 -0
  89. package/dist-cjs/interactable-card/InteractableCard.js +197 -0
  90. package/dist-cjs/interactable-card/InteractableCard.js.map +1 -0
  91. package/dist-cjs/interactable-card/InteractableCardGroup.css.js +6 -0
  92. package/dist-cjs/interactable-card/InteractableCardGroup.css.js.map +1 -0
  93. package/dist-cjs/interactable-card/InteractableCardGroup.js +228 -0
  94. package/dist-cjs/interactable-card/InteractableCardGroup.js.map +1 -0
  95. package/dist-cjs/interactable-card/InteractableCardGroupContext.js +103 -0
  96. package/dist-cjs/interactable-card/InteractableCardGroupContext.js.map +1 -0
  97. package/dist-cjs/{card → interactable-card}/useInteractableCard.js +5 -2
  98. package/dist-cjs/interactable-card/useInteractableCard.js.map +1 -0
  99. package/dist-cjs/link/Link.js +14 -9
  100. package/dist-cjs/link/Link.js.map +1 -1
  101. package/dist-cjs/link-card/LinkCard.css.js +1 -1
  102. package/dist-cjs/link-card/LinkCard.js +14 -9
  103. package/dist-cjs/link-card/LinkCard.js.map +1 -1
  104. package/dist-cjs/list-control/ListControlContext.js +14 -9
  105. package/dist-cjs/list-control/ListControlContext.js.map +1 -1
  106. package/dist-cjs/list-control/ListControlState.js +14 -9
  107. package/dist-cjs/list-control/ListControlState.js.map +1 -1
  108. package/dist-cjs/multiline-input/MultilineInput.js +14 -9
  109. package/dist-cjs/multiline-input/MultilineInput.js.map +1 -1
  110. package/dist-cjs/navigation-item/NavigationItem.js +14 -9
  111. package/dist-cjs/navigation-item/NavigationItem.js.map +1 -1
  112. package/dist-cjs/option/Option.js +14 -9
  113. package/dist-cjs/option/Option.js.map +1 -1
  114. package/dist-cjs/option/OptionGroup.js +14 -9
  115. package/dist-cjs/option/OptionGroup.js.map +1 -1
  116. package/dist-cjs/option/OptionList.js +14 -9
  117. package/dist-cjs/option/OptionList.js.map +1 -1
  118. package/dist-cjs/option/OptionListBase.js +14 -9
  119. package/dist-cjs/option/OptionListBase.js.map +1 -1
  120. package/dist-cjs/pagination/CompactInput.js +14 -9
  121. package/dist-cjs/pagination/CompactInput.js.map +1 -1
  122. package/dist-cjs/pagination/CompactPaginator.js +9 -4
  123. package/dist-cjs/pagination/CompactPaginator.js.map +1 -1
  124. package/dist-cjs/pagination/GoToInput.js +8 -3
  125. package/dist-cjs/pagination/GoToInput.js.map +1 -1
  126. package/dist-cjs/pagination/PageButton.js +14 -9
  127. package/dist-cjs/pagination/PageButton.js.map +1 -1
  128. package/dist-cjs/pagination/PageRanges.js +14 -9
  129. package/dist-cjs/pagination/PageRanges.js.map +1 -1
  130. package/dist-cjs/pagination/Pagination.js +14 -9
  131. package/dist-cjs/pagination/Pagination.js.map +1 -1
  132. package/dist-cjs/pagination/Paginator.js +14 -9
  133. package/dist-cjs/pagination/Paginator.js.map +1 -1
  134. package/dist-cjs/panel/Panel.js +14 -9
  135. package/dist-cjs/panel/Panel.js.map +1 -1
  136. package/dist-cjs/pill/Pill.js +14 -9
  137. package/dist-cjs/pill/Pill.js.map +1 -1
  138. package/dist-cjs/pill-input/PillInput.js +14 -9
  139. package/dist-cjs/pill-input/PillInput.js.map +1 -1
  140. package/dist-cjs/progress/CircularProgress/CircularProgress.js +14 -9
  141. package/dist-cjs/progress/CircularProgress/CircularProgress.js.map +1 -1
  142. package/dist-cjs/progress/LinearProgress/LinearProgress.js +14 -9
  143. package/dist-cjs/progress/LinearProgress/LinearProgress.js.map +1 -1
  144. package/dist-cjs/radio-button/RadioButton.js +14 -9
  145. package/dist-cjs/radio-button/RadioButton.js.map +1 -1
  146. package/dist-cjs/radio-button/RadioButtonGroup.js +14 -9
  147. package/dist-cjs/radio-button/RadioButtonGroup.js.map +1 -1
  148. package/dist-cjs/radio-button/RadioButtonIcon.js +14 -9
  149. package/dist-cjs/radio-button/RadioButtonIcon.js.map +1 -1
  150. package/dist-cjs/radio-button/internal/RadioGroupContext.js +14 -9
  151. package/dist-cjs/radio-button/internal/RadioGroupContext.js.map +1 -1
  152. package/dist-cjs/salt-provider/SaltProvider.js +14 -9
  153. package/dist-cjs/salt-provider/SaltProvider.js.map +1 -1
  154. package/dist-cjs/scrim/Scrim.js +14 -9
  155. package/dist-cjs/scrim/Scrim.js.map +1 -1
  156. package/dist-cjs/segmented-button-group/SegmentedButtonGroup.css.js +6 -0
  157. package/dist-cjs/segmented-button-group/SegmentedButtonGroup.css.js.map +1 -0
  158. package/dist-cjs/{card/InteractableCard.js → segmented-button-group/SegmentedButtonGroup.js} +26 -53
  159. package/dist-cjs/segmented-button-group/SegmentedButtonGroup.js.map +1 -0
  160. package/dist-cjs/spinner/Spinner.js +14 -9
  161. package/dist-cjs/spinner/Spinner.js.map +1 -1
  162. package/dist-cjs/spinner/svgSpinners/SpinnerSVG.js +14 -9
  163. package/dist-cjs/spinner/svgSpinners/SpinnerSVG.js.map +1 -1
  164. package/dist-cjs/split-layout/SplitLayout.js +14 -9
  165. package/dist-cjs/split-layout/SplitLayout.js.map +1 -1
  166. package/dist-cjs/stack-layout/StackLayout.js +14 -9
  167. package/dist-cjs/stack-layout/StackLayout.js.map +1 -1
  168. package/dist-cjs/status-adornment/StatusAdornment.js +14 -9
  169. package/dist-cjs/status-adornment/StatusAdornment.js.map +1 -1
  170. package/dist-cjs/status-indicator/StatusIndicator.js +13 -8
  171. package/dist-cjs/status-indicator/StatusIndicator.js.map +1 -1
  172. package/dist-cjs/switch/Switch.js +15 -9
  173. package/dist-cjs/switch/Switch.js.map +1 -1
  174. package/dist-cjs/text/Code.js +21 -0
  175. package/dist-cjs/text/Code.js.map +1 -0
  176. package/dist-cjs/text/Text.css.js +1 -1
  177. package/dist-cjs/text/Text.js +13 -8
  178. package/dist-cjs/text/Text.js.map +1 -1
  179. package/dist-cjs/toast/Toast.js +13 -8
  180. package/dist-cjs/toast/Toast.js.map +1 -1
  181. package/dist-cjs/toast/ToastContent.js +14 -9
  182. package/dist-cjs/toast/ToastContent.js.map +1 -1
  183. package/dist-cjs/toggle-button/ToggleButton.js +14 -9
  184. package/dist-cjs/toggle-button/ToggleButton.js.map +1 -1
  185. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js +14 -9
  186. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js.map +1 -1
  187. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js +14 -9
  188. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js.map +1 -1
  189. package/dist-cjs/tooltip/Tooltip.js +13 -8
  190. package/dist-cjs/tooltip/Tooltip.js.map +1 -1
  191. package/dist-cjs/tooltip/TooltipBase.js +13 -8
  192. package/dist-cjs/tooltip/TooltipBase.js.map +1 -1
  193. package/dist-cjs/tooltip/useAriaAnnounce.js +14 -9
  194. package/dist-cjs/tooltip/useAriaAnnounce.js.map +1 -1
  195. package/dist-cjs/tooltip/useTooltip.js +14 -9
  196. package/dist-cjs/tooltip/useTooltip.js.map +1 -1
  197. package/dist-cjs/utils/useValueEffect.js +14 -9
  198. package/dist-cjs/utils/useValueEffect.js.map +1 -1
  199. package/dist-cjs/viewport/ViewportProvider.js +14 -9
  200. package/dist-cjs/viewport/ViewportProvider.js.map +1 -1
  201. package/dist-es/accordion/Accordion.js +14 -9
  202. package/dist-es/accordion/Accordion.js.map +1 -1
  203. package/dist-es/accordion/AccordionContext.js +14 -9
  204. package/dist-es/accordion/AccordionContext.js.map +1 -1
  205. package/dist-es/accordion/AccordionGroup.js +14 -9
  206. package/dist-es/accordion/AccordionGroup.js.map +1 -1
  207. package/dist-es/accordion/AccordionHeader.js +13 -8
  208. package/dist-es/accordion/AccordionHeader.js.map +1 -1
  209. package/dist-es/accordion/AccordionPanel.js +14 -9
  210. package/dist-es/accordion/AccordionPanel.js.map +1 -1
  211. package/dist-es/aria-announcer/useAriaAnnouncer.js +14 -9
  212. package/dist-es/aria-announcer/useAriaAnnouncer.js.map +1 -1
  213. package/dist-es/avatar/Avatar.js +14 -9
  214. package/dist-es/avatar/Avatar.js.map +1 -1
  215. package/dist-es/avatar/useAvatarImage.js +14 -9
  216. package/dist-es/avatar/useAvatarImage.js.map +1 -1
  217. package/dist-es/badge/Badge.js +14 -9
  218. package/dist-es/badge/Badge.js.map +1 -1
  219. package/dist-es/banner/Banner.js +14 -9
  220. package/dist-es/banner/Banner.js.map +1 -1
  221. package/dist-es/banner/BannerActions.js +14 -9
  222. package/dist-es/banner/BannerActions.js.map +1 -1
  223. package/dist-es/banner/BannerContent.js +14 -9
  224. package/dist-es/banner/BannerContent.js.map +1 -1
  225. package/dist-es/border-item/BorderItem.js +14 -9
  226. package/dist-es/border-item/BorderItem.js.map +1 -1
  227. package/dist-es/border-layout/BorderLayout.js +14 -9
  228. package/dist-es/border-layout/BorderLayout.js.map +1 -1
  229. package/dist-es/button/Button.js +14 -9
  230. package/dist-es/button/Button.js.map +1 -1
  231. package/dist-es/card/Card.css.js +1 -1
  232. package/dist-es/card/Card.js +14 -9
  233. package/dist-es/card/Card.js.map +1 -1
  234. package/dist-es/checkbox/Checkbox.js +14 -9
  235. package/dist-es/checkbox/Checkbox.js.map +1 -1
  236. package/dist-es/checkbox/CheckboxGroup.js +14 -9
  237. package/dist-es/checkbox/CheckboxGroup.js.map +1 -1
  238. package/dist-es/checkbox/CheckboxIcon.js +14 -9
  239. package/dist-es/checkbox/CheckboxIcon.js.map +1 -1
  240. package/dist-es/checkbox/internal/CheckboxGroupContext.js +14 -9
  241. package/dist-es/checkbox/internal/CheckboxGroupContext.js.map +1 -1
  242. package/dist-es/combo-box/ComboBox.js +14 -9
  243. package/dist-es/combo-box/ComboBox.js.map +1 -1
  244. package/dist-es/combo-box/useComboBox.js +14 -9
  245. package/dist-es/combo-box/useComboBox.js.map +1 -1
  246. package/dist-es/dialog/Dialog.js +16 -11
  247. package/dist-es/dialog/Dialog.js.map +1 -1
  248. package/dist-es/dialog/DialogActions.js +14 -9
  249. package/dist-es/dialog/DialogActions.js.map +1 -1
  250. package/dist-es/dialog/DialogCloseButton.js +17 -10
  251. package/dist-es/dialog/DialogCloseButton.js.map +1 -1
  252. package/dist-es/dialog/DialogContent.js +14 -9
  253. package/dist-es/dialog/DialogContent.js.map +1 -1
  254. package/dist-es/dialog/DialogHeader.css.js +1 -1
  255. package/dist-es/dialog/DialogHeader.js +60 -52
  256. package/dist-es/dialog/DialogHeader.js.map +1 -1
  257. package/dist-es/drawer/Drawer.js +16 -11
  258. package/dist-es/drawer/Drawer.js.map +1 -1
  259. package/dist-es/drawer/DrawerCloseButton.js +14 -9
  260. package/dist-es/drawer/DrawerCloseButton.js.map +1 -1
  261. package/dist-es/dropdown/Dropdown.js +14 -9
  262. package/dist-es/dropdown/Dropdown.js.map +1 -1
  263. package/dist-es/file-drop-zone/FileDropZone.js +14 -9
  264. package/dist-es/file-drop-zone/FileDropZone.js.map +1 -1
  265. package/dist-es/file-drop-zone/FileDropZoneTrigger.js +14 -9
  266. package/dist-es/file-drop-zone/FileDropZoneTrigger.js.map +1 -1
  267. package/dist-es/flex-item/FlexItem.js +14 -9
  268. package/dist-es/flex-item/FlexItem.js.map +1 -1
  269. package/dist-es/flex-layout/FlexLayout.js +14 -9
  270. package/dist-es/flex-layout/FlexLayout.js.map +1 -1
  271. package/dist-es/form-field/FormField.js +14 -9
  272. package/dist-es/form-field/FormField.js.map +1 -1
  273. package/dist-es/form-field/FormFieldHelperText.js +8 -3
  274. package/dist-es/form-field/FormFieldHelperText.js.map +1 -1
  275. package/dist-es/form-field/FormFieldLabel.js +9 -4
  276. package/dist-es/form-field/FormFieldLabel.js.map +1 -1
  277. package/dist-es/form-field-context/FormFieldContext.js +14 -9
  278. package/dist-es/form-field-context/FormFieldContext.js.map +1 -1
  279. package/dist-es/grid-item/GridItem.js +14 -9
  280. package/dist-es/grid-item/GridItem.js.map +1 -1
  281. package/dist-es/grid-layout/GridLayout.js +14 -9
  282. package/dist-es/grid-layout/GridLayout.js.map +1 -1
  283. package/dist-es/index.js +6 -2
  284. package/dist-es/index.js.map +1 -1
  285. package/dist-es/input/Input.js +14 -9
  286. package/dist-es/input/Input.js.map +1 -1
  287. package/dist-es/interactable-card/InteractableCard.css.js +4 -0
  288. package/dist-es/interactable-card/InteractableCard.js +193 -0
  289. package/dist-es/interactable-card/InteractableCard.js.map +1 -0
  290. package/dist-es/interactable-card/InteractableCardGroup.css.js +4 -0
  291. package/dist-es/interactable-card/InteractableCardGroup.css.js.map +1 -0
  292. package/dist-es/interactable-card/InteractableCardGroup.js +224 -0
  293. package/dist-es/interactable-card/InteractableCardGroup.js.map +1 -0
  294. package/dist-es/interactable-card/InteractableCardGroupContext.js +98 -0
  295. package/dist-es/interactable-card/InteractableCardGroupContext.js.map +1 -0
  296. package/dist-es/{card → interactable-card}/useInteractableCard.js +5 -2
  297. package/dist-es/interactable-card/useInteractableCard.js.map +1 -0
  298. package/dist-es/link/Link.js +14 -9
  299. package/dist-es/link/Link.js.map +1 -1
  300. package/dist-es/link-card/LinkCard.css.js +1 -1
  301. package/dist-es/link-card/LinkCard.js +14 -9
  302. package/dist-es/link-card/LinkCard.js.map +1 -1
  303. package/dist-es/list-control/ListControlContext.js +14 -9
  304. package/dist-es/list-control/ListControlContext.js.map +1 -1
  305. package/dist-es/list-control/ListControlState.js +14 -9
  306. package/dist-es/list-control/ListControlState.js.map +1 -1
  307. package/dist-es/multiline-input/MultilineInput.js +14 -9
  308. package/dist-es/multiline-input/MultilineInput.js.map +1 -1
  309. package/dist-es/navigation-item/NavigationItem.js +14 -9
  310. package/dist-es/navigation-item/NavigationItem.js.map +1 -1
  311. package/dist-es/option/Option.js +14 -9
  312. package/dist-es/option/Option.js.map +1 -1
  313. package/dist-es/option/OptionGroup.js +14 -9
  314. package/dist-es/option/OptionGroup.js.map +1 -1
  315. package/dist-es/option/OptionList.js +14 -9
  316. package/dist-es/option/OptionList.js.map +1 -1
  317. package/dist-es/option/OptionListBase.js +14 -9
  318. package/dist-es/option/OptionListBase.js.map +1 -1
  319. package/dist-es/pagination/CompactInput.js +14 -9
  320. package/dist-es/pagination/CompactInput.js.map +1 -1
  321. package/dist-es/pagination/CompactPaginator.js +9 -4
  322. package/dist-es/pagination/CompactPaginator.js.map +1 -1
  323. package/dist-es/pagination/GoToInput.js +8 -3
  324. package/dist-es/pagination/GoToInput.js.map +1 -1
  325. package/dist-es/pagination/PageButton.js +14 -9
  326. package/dist-es/pagination/PageButton.js.map +1 -1
  327. package/dist-es/pagination/PageRanges.js +14 -9
  328. package/dist-es/pagination/PageRanges.js.map +1 -1
  329. package/dist-es/pagination/Pagination.js +14 -9
  330. package/dist-es/pagination/Pagination.js.map +1 -1
  331. package/dist-es/pagination/Paginator.js +14 -9
  332. package/dist-es/pagination/Paginator.js.map +1 -1
  333. package/dist-es/panel/Panel.js +14 -9
  334. package/dist-es/panel/Panel.js.map +1 -1
  335. package/dist-es/pill/Pill.js +14 -9
  336. package/dist-es/pill/Pill.js.map +1 -1
  337. package/dist-es/pill-input/PillInput.js +14 -9
  338. package/dist-es/pill-input/PillInput.js.map +1 -1
  339. package/dist-es/progress/CircularProgress/CircularProgress.js +14 -9
  340. package/dist-es/progress/CircularProgress/CircularProgress.js.map +1 -1
  341. package/dist-es/progress/LinearProgress/LinearProgress.js +14 -9
  342. package/dist-es/progress/LinearProgress/LinearProgress.js.map +1 -1
  343. package/dist-es/radio-button/RadioButton.js +14 -9
  344. package/dist-es/radio-button/RadioButton.js.map +1 -1
  345. package/dist-es/radio-button/RadioButtonGroup.js +14 -9
  346. package/dist-es/radio-button/RadioButtonGroup.js.map +1 -1
  347. package/dist-es/radio-button/RadioButtonIcon.js +14 -9
  348. package/dist-es/radio-button/RadioButtonIcon.js.map +1 -1
  349. package/dist-es/radio-button/internal/RadioGroupContext.js +14 -9
  350. package/dist-es/radio-button/internal/RadioGroupContext.js.map +1 -1
  351. package/dist-es/salt-provider/SaltProvider.js +14 -9
  352. package/dist-es/salt-provider/SaltProvider.js.map +1 -1
  353. package/dist-es/scrim/Scrim.js +14 -9
  354. package/dist-es/scrim/Scrim.js.map +1 -1
  355. package/dist-es/segmented-button-group/SegmentedButtonGroup.css.js +4 -0
  356. package/dist-es/segmented-button-group/SegmentedButtonGroup.css.js.map +1 -0
  357. package/dist-es/{card/InteractableCard.js → segmented-button-group/SegmentedButtonGroup.js} +25 -52
  358. package/dist-es/segmented-button-group/SegmentedButtonGroup.js.map +1 -0
  359. package/dist-es/spinner/Spinner.js +14 -9
  360. package/dist-es/spinner/Spinner.js.map +1 -1
  361. package/dist-es/spinner/svgSpinners/SpinnerSVG.js +14 -9
  362. package/dist-es/spinner/svgSpinners/SpinnerSVG.js.map +1 -1
  363. package/dist-es/split-layout/SplitLayout.js +14 -9
  364. package/dist-es/split-layout/SplitLayout.js.map +1 -1
  365. package/dist-es/stack-layout/StackLayout.js +14 -9
  366. package/dist-es/stack-layout/StackLayout.js.map +1 -1
  367. package/dist-es/status-adornment/StatusAdornment.js +14 -9
  368. package/dist-es/status-adornment/StatusAdornment.js.map +1 -1
  369. package/dist-es/status-indicator/StatusIndicator.js +13 -8
  370. package/dist-es/status-indicator/StatusIndicator.js.map +1 -1
  371. package/dist-es/switch/Switch.js +15 -9
  372. package/dist-es/switch/Switch.js.map +1 -1
  373. package/dist-es/text/Code.js +17 -0
  374. package/dist-es/text/Code.js.map +1 -0
  375. package/dist-es/text/Text.css.js +1 -1
  376. package/dist-es/text/Text.js +13 -8
  377. package/dist-es/text/Text.js.map +1 -1
  378. package/dist-es/toast/Toast.js +13 -8
  379. package/dist-es/toast/Toast.js.map +1 -1
  380. package/dist-es/toast/ToastContent.js +14 -9
  381. package/dist-es/toast/ToastContent.js.map +1 -1
  382. package/dist-es/toggle-button/ToggleButton.js +14 -9
  383. package/dist-es/toggle-button/ToggleButton.js.map +1 -1
  384. package/dist-es/toggle-button-group/ToggleButtonGroup.js +14 -9
  385. package/dist-es/toggle-button-group/ToggleButtonGroup.js.map +1 -1
  386. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js +14 -9
  387. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js.map +1 -1
  388. package/dist-es/tooltip/Tooltip.js +13 -8
  389. package/dist-es/tooltip/Tooltip.js.map +1 -1
  390. package/dist-es/tooltip/TooltipBase.js +13 -8
  391. package/dist-es/tooltip/TooltipBase.js.map +1 -1
  392. package/dist-es/tooltip/useAriaAnnounce.js +14 -9
  393. package/dist-es/tooltip/useAriaAnnounce.js.map +1 -1
  394. package/dist-es/tooltip/useTooltip.js +14 -9
  395. package/dist-es/tooltip/useTooltip.js.map +1 -1
  396. package/dist-es/utils/useValueEffect.js +14 -9
  397. package/dist-es/utils/useValueEffect.js.map +1 -1
  398. package/dist-es/viewport/ViewportProvider.js +14 -9
  399. package/dist-es/viewport/ViewportProvider.js.map +1 -1
  400. package/dist-types/card/index.d.ts +0 -1
  401. package/dist-types/dialog/DialogHeader.d.ts +1 -1
  402. package/dist-types/index.d.ts +2 -0
  403. package/dist-types/{card → interactable-card}/InteractableCard.d.ts +15 -1
  404. package/dist-types/interactable-card/InteractableCardGroup.d.ts +27 -0
  405. package/dist-types/interactable-card/InteractableCardGroupContext.d.ts +12 -0
  406. package/dist-types/interactable-card/index.d.ts +3 -0
  407. package/dist-types/segmented-button-group/SegmentedButtonGroup.d.ts +4 -0
  408. package/dist-types/segmented-button-group/index.d.ts +1 -0
  409. package/dist-types/text/Code.d.ts +2 -0
  410. package/dist-types/text/Text.d.ts +1 -1
  411. package/dist-types/text/index.d.ts +2 -1
  412. package/package.json +2 -2
  413. package/dist-cjs/card/InteractableCard.css.js +0 -6
  414. package/dist-cjs/card/InteractableCard.js.map +0 -1
  415. package/dist-cjs/card/useInteractableCard.js.map +0 -1
  416. package/dist-es/card/InteractableCard.css.js +0 -4
  417. package/dist-es/card/InteractableCard.js.map +0 -1
  418. package/dist-es/card/useInteractableCard.js.map +0 -1
  419. /package/dist-cjs/{card → interactable-card}/InteractableCard.css.js.map +0 -0
  420. /package/dist-es/{card → interactable-card}/InteractableCard.css.js.map +0 -0
  421. /package/dist-types/{card → interactable-card}/useInteractableCard.d.ts +0 -0
@@ -0,0 +1,27 @@
1
+ import { ComponentPropsWithoutRef, SyntheticEvent } from "react";
2
+ import { InteractableCardValue } from "./InteractableCardGroupContext";
3
+ export interface InteractableCardGroupProps extends Omit<ComponentPropsWithoutRef<"div">, "onChange"> {
4
+ /**
5
+ * The default value. Use when the component is not controlled. Should be an array when `multiSelect` is true.
6
+ */
7
+ defaultValue?: InteractableCardValue;
8
+ /**
9
+ * If `true`, the Interactable Card Group will be disabled.
10
+ */
11
+ disabled?: boolean;
12
+ /**
13
+ * The value. Use when the component is controlled. Should be an array when `multiSelect` is true.
14
+ */
15
+ value?: InteractableCardValue;
16
+ /**
17
+ * If `true` the Interactable Card Group will allow multiple selection functionality, with keyboard interactions matching those of a checkbox.
18
+ * By default the group allows mutually exclusive selection with keyboard interactions matching radio buttons.
19
+ */
20
+ multiSelect?: boolean;
21
+ /**
22
+ * Callback fired when the selection changes.
23
+ * @param event
24
+ */
25
+ onChange?: (event: SyntheticEvent<HTMLDivElement>, value: InteractableCardValue) => void;
26
+ }
27
+ export declare const InteractableCardGroup: import("react").ForwardRefExoticComponent<InteractableCardGroupProps & import("react").RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,12 @@
1
+ import { SyntheticEvent } from "react";
2
+ export declare type InteractableCardValue = string | readonly string[] | undefined;
3
+ export interface InteractableCardGroupContextValue {
4
+ disabled?: boolean;
5
+ select: (event: SyntheticEvent<HTMLDivElement>, value: InteractableCardValue) => void;
6
+ isSelected: (id: InteractableCardValue) => boolean;
7
+ isFirstChild: (value: InteractableCardValue) => boolean;
8
+ multiSelect?: boolean;
9
+ value: InteractableCardValue;
10
+ }
11
+ export declare const InteractableCardGroupContext: import("react").Context<InteractableCardGroupContextValue | undefined>;
12
+ export declare function useInteractableCardGroup(): InteractableCardGroupContextValue | undefined;
@@ -0,0 +1,3 @@
1
+ export * from "./InteractableCard";
2
+ export * from "./InteractableCardGroup";
3
+ export * from "./InteractableCardGroupContext";
@@ -0,0 +1,4 @@
1
+ import { ComponentPropsWithoutRef } from "react";
2
+ export interface SegmentedButtonGroupProps extends ComponentPropsWithoutRef<"div"> {
3
+ }
4
+ export declare const SegmentedButtonGroup: import("react").ForwardRefExoticComponent<SegmentedButtonGroupProps & import("react").RefAttributes<HTMLDivElement>>;
@@ -0,0 +1 @@
1
+ export * from "./SegmentedButtonGroup";
@@ -0,0 +1,2 @@
1
+ import { TextProps } from "./Text";
2
+ export declare const Code: import("react").ForwardRefExoticComponent<Omit<Omit<TextProps<"code">, "as">, "ref"> & import("react").RefAttributes<HTMLSpanElement>>;
@@ -12,7 +12,7 @@ export declare type TextProps<T extends ElementType> = PolymorphicComponentPropW
12
12
  /**
13
13
  * Match styling to another text component's style
14
14
  */
15
- styleAs?: "h1" | "h2" | "h3" | "h4" | "label" | "display1" | "display2" | "display3" | "notation" | "action";
15
+ styleAs?: "h1" | "h2" | "h3" | "h4" | "label" | "display1" | "display2" | "display3" | "notation" | "action" | "code";
16
16
  /**
17
17
  * Change text color palette
18
18
  */
@@ -1,6 +1,7 @@
1
1
  export * from "./Text";
2
+ export * from "./Code";
2
3
  export * from "./Display";
3
4
  export * from "./Headings";
4
5
  export * from "./Label";
5
- export * from "./TextNotation";
6
6
  export * from "./TextAction";
7
+ export * from "./TextNotation";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@salt-ds/core",
3
- "version": "1.21.0",
3
+ "version": "1.23.0",
4
4
  "license": "Apache-2.0",
5
5
  "repository": {
6
6
  "type": "git",
@@ -15,7 +15,7 @@
15
15
  "clsx": "^2.0.0",
16
16
  "@salt-ds/window": "^0.1.1",
17
17
  "@salt-ds/styles": "^0.2.1",
18
- "@salt-ds/icons": "^1.9.1"
18
+ "@salt-ds/icons": "^1.10.0"
19
19
  },
20
20
  "peerDependencies": {
21
21
  "@types/react": ">=16.14.0",
@@ -1,6 +0,0 @@
1
- 'use strict';
2
-
3
- var css_248z = "/* Styles applied to InteractableCard */\n.saltInteractableCard {\n box-shadow: var(--saltCard-boxShadow, var(--salt-overlayable-shadow));\n border-width: var(--saltCard-borderWidth, var(--card-borderWidth));\n border-style: var(--saltCard-borderStyle, var(--salt-container-borderStyle));\n border-color: var(--saltCard-borderColor, var(--salt-accent-borderColor));\n border-radius: var(--saltCard-borderRadius, var(--salt-palette-corner, 0));\n display: block;\n transition: box-shadow var(--salt-duration-instant) cubic-bezier(0.4, 0, 0.2, 1);\n padding: var(--saltCard-padding, var(--salt-spacing-300));\n}\n\n/* Styles applied to InteractableCard when variant=\"primary\" */\n.saltInteractableCard-primary {\n background: var(--saltCard-background, var(--salt-container-primary-background));\n}\n\n/* Styles applied to InteractableCard when variant=\"secondary\" */\n.saltInteractableCard-secondary {\n background: var(--saltCard-background, var(--salt-container-secondary-background));\n}\n\n/* Styles applied to InteractableCard if `accentPlacement=\"bottom\"` (default) */\n.saltInteractableCard-accentBottom {\n --card-borderWidth: 0 0 var(--salt-size-accent) 0;\n}\n\n/* Styles applied to InteractableCard if `accentPlacement=\"left\"` */\n.saltInteractableCard-accentLeft {\n --card-borderWidth: 0 0 0 var(--salt-size-accent);\n}\n\n/* Styles applied to InteractableCard if `accentPlacement=\"top\"` */\n.saltInteractableCard-accentTop {\n --card-borderWidth: var(--salt-size-accent) 0 0 0;\n}\n\n/* Styles applied to InteractableCard if `accentPlacement=\"right\"` */\n.saltInteractableCard-accentRight {\n --card-borderWidth: 0 var(--salt-size-accent) 0 0;\n}\n\n/* Styles applied to InteractableCard on focus */\na:focus-visible .saltInteractableCard,\n.saltInteractableCard:focus-visible {\n cursor: var(--saltCard-interactable-cursor-focus, var(--salt-selectable-cursor-hover));\n box-shadow: var(--saltCard-interactable-shadow-focus, var(--salt-overlayable-shadow-hover));\n color: var(--saltCard-color-focus, var(--salt-content-primary-foreground));\n outline-color: var(--salt-focused-outlineColor);\n outline-style: var(--salt-focused-outlineStyle);\n outline-width: var(--salt-focused-outlineWidth);\n outline-offset: var(--salt-focused-outlineOffset);\n}\n\na:link .saltInteractableCard * {\n text-decoration: none;\n}\n\n/* Styles applied on active state to InteractableCard */\n.saltInteractableCard:active {\n cursor: var(--saltCard-interactable-cursor-active, var(--salt-selectable-cursor-active));\n box-shadow: var(--saltCard-interactable-shadow-active, var(--salt-overlayable-shadow-hover));\n}\n\n/* Styles applied on hover state to InteractableCard */\n.saltInteractableCard:hover {\n cursor: var(--saltCard-interactable-cursor-hover, var(--salt-selectable-cursor-hover));\n box-shadow: var(--saltCard-interactable-shadow-hover, var(--salt-overlayable-shadow-hover));\n}\n\n/* Styles applied to InteractableCard if `disabled={true}` */\n.saltInteractableCard-disabled,\n.saltInteractableCard-disabled:focus,\n.saltInteractableCard-disabled:hover,\n.saltInteractableCard-disabled:active {\n box-shadow: var(--saltCard-interactable-shadow, var(--salt-overlayable-shadow));\n color: var(--saltCard-color-disabled, var(--salt-content-primary-foreground-disabled));\n cursor: var(--saltCard-interactable-cursor-disabled, var(--salt-selectable-cursor-disabled));\n outline: none;\n}\n\n/* Styles applied to InteractableCard primary variant if `disabled={true}` */\n.saltInteractableCard-primary.saltInteractableCard-disabled,\n.saltInteractableCard-primary.saltInteractableCard-disabled:focus,\n.saltInteractableCard-primary.saltInteractableCard-disabled:hover,\n.saltInteractableCard-primary.saltInteractableCard-disabled:active {\n border-color: var(--saltCard-borderColor-disabled, var(--salt-container-primary-borderColor-disabled));\n background: var(--saltCard-background-disabled, var(--salt-container-primary-background-disabled));\n}\n\n/* Styles applied to InteractableCard secondary variant if `disabled={true}` */\n.saltInteractableCard-secondary.saltInteractableCard-disabled,\n.saltInteractableCard-secondary.saltInteractableCard-disabled:focus,\n.saltInteractableCard-secondary.saltInteractableCard-disabled:hover,\n.saltInteractableCard-secondary.saltInteractableCard-disabled:active {\n border-color: var(--saltCard-borderColor-disabled, var(--salt-container-secondary-borderColor-disabled));\n background: var(--saltCard-background-disabled, var(--salt-container-secondary-background));\n}\n\n/* Styles applied to nested divs in InteractableCard if `disabled={true}` */\n.saltInteractableCard-disabled div {\n pointer-events: none;\n}\n\n/* Class that can be used for anchor tags wrapping InteractableCard */\n.saltInteractableCard-link {\n color: var(--saltCard-link-color, var(--salt-content-primary-foreground));\n inset: var(--salt-focused-outlineInset);\n outline-color: var(--salt-focused-outlineColor);\n outline-offset: var(--salt-focused-outlineOffset);\n outline-style: var(--salt-focused-outlineStyle);\n outline-width: var(--salt-focused-outlineWidth);\n}\n";
4
-
5
- module.exports = css_248z;
6
- //# sourceMappingURL=InteractableCard.css.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"InteractableCard.js","sources":["../src/card/InteractableCard.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport { ComponentPropsWithoutRef, forwardRef } from \"react\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport { capitalize, makePrefixer } from \"../utils\";\nimport { useInteractableCard } from \"./useInteractableCard\";\n\nimport interactableCardCss from \"./InteractableCard.css\";\n\nconst withBaseName = makePrefixer(\"saltInteractableCard\");\n\n// TODO: Remove omissions when Card props deprecated\nexport interface InteractableCardProps extends ComponentPropsWithoutRef<\"div\"> {\n /**\n * Accent border position: defaults to \"bottom\"\n */\n accentPlacement?: \"bottom\" | \"top\" | \"left\" | \"right\";\n /**\n * If `true`, the card will be disabled.\n */\n disabled?: boolean;\n /**\n * Styling variant; defaults to \"primary\".\n */\n variant?: \"primary\" | \"secondary\";\n}\n\nexport const InteractableCard = forwardRef<\n HTMLDivElement,\n InteractableCardProps\n>(function InteractableCard(props, ref) {\n const {\n accentPlacement = \"bottom\",\n children,\n className,\n variant = \"primary\",\n disabled,\n onBlur,\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 { active, cardProps } = useInteractableCard({\n disabled,\n onKeyUp,\n onKeyDown,\n onBlur,\n onClick,\n });\n // for now, we do not want to spread tab index here as users may be wrapping in a link\n const { tabIndex, ...restCardProps } = cardProps;\n\n return (\n <div\n {...restCardProps}\n className={clsx(\n withBaseName(),\n withBaseName(variant),\n withBaseName(`accent${capitalize(accentPlacement)}`),\n {\n [withBaseName(\"disabled\")]: disabled,\n [withBaseName(\"active\")]: active,\n },\n className\n )}\n {...rest}\n ref={ref}\n >\n {children}\n </div>\n );\n});\n"],"names":["makePrefixer","forwardRef","InteractableCard","useWindow","useComponentCssInjection","interactableCardCss","useInteractableCard","jsx","clsx","capitalize"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAUA,MAAM,YAAA,GAAeA,0BAAa,sBAAsB,CAAA,CAAA;AAkBjD,MAAM,gBAAmB,GAAAC,gBAAA,CAG9B,SAASC,iBAAAA,CAAiB,OAAO,GAAK,EAAA;AACtC,EAAM,MAAA;AAAA,IACJ,eAAkB,GAAA,QAAA;AAAA,IAClB,QAAA;AAAA,IACA,SAAA;AAAA,IACA,OAAU,GAAA,SAAA;AAAA,IACV,QAAA;AAAA,IACA,MAAA;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,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,EAAM,MAAA,EAAE,QAAa,EAAA,GAAA,aAAA,EAAkB,GAAA,SAAA,CAAA;AAEvC,EAAA,uBACGC,cAAA,CAAA,KAAA,EAAA;AAAA,IACE,GAAG,aAAA;AAAA,IACJ,SAAW,EAAAC,SAAA;AAAA,MACT,YAAa,EAAA;AAAA,MACb,aAAa,OAAO,CAAA;AAAA,MACpB,YAAa,CAAA,CAAA,MAAA,EAASC,qBAAW,CAAA,eAAe,CAAG,CAAA,CAAA,CAAA;AAAA,MACnD;AAAA,QACE,CAAC,YAAa,CAAA,UAAU,CAAI,GAAA,QAAA;AAAA,QAC5B,CAAC,YAAa,CAAA,QAAQ,CAAI,GAAA,MAAA;AAAA,OAC5B;AAAA,MACA,SAAA;AAAA,KACF;AAAA,IACC,GAAG,IAAA;AAAA,IACJ,GAAA;AAAA,IAEC,QAAA;AAAA,GACH,CAAA,CAAA;AAEJ,CAAC;;;;"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"useInteractableCard.js","sources":["../src/card/useInteractableCard.ts"],"sourcesContent":["import {\n FocusEvent,\n KeyboardEvent,\n MouseEvent,\n useEffect,\n useState,\n} from \"react\";\n\nexport interface CardHookProps<T extends Element> {\n disabled?: boolean;\n onKeyUp?: (event: KeyboardEvent<T>) => void;\n onKeyDown?: (event: KeyboardEvent<T>) => void;\n onClick?: (event: MouseEvent<T>) => void;\n onBlur?: (event: FocusEvent<T>) => void;\n}\n\nexport interface CardHookResult<T extends Element> {\n active: boolean;\n cardProps: {\n \"aria-disabled\"?: boolean;\n disabled?: boolean;\n tabIndex: number;\n onBlur: (event: FocusEvent<T>) => void;\n onClick?: (event: MouseEvent<T>) => void;\n onKeyDown: (event: KeyboardEvent<T>) => void;\n onKeyUp: (event: KeyboardEvent<T>) => void;\n };\n}\n\nexport const useInteractableCard = <T extends Element>({\n disabled,\n onKeyUp,\n onKeyDown,\n onClick,\n onBlur,\n}: CardHookProps<T>): CardHookResult<T> => {\n const [keyIsDown, setkeyIsDown] = useState(\"\");\n const [active, setActive] = useState(false);\n\n const enter = \"Enter\";\n\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) {\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) {\n setkeyIsDown(event.key);\n setActive(true);\n }\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;AAEd,EAAAC,eAAA,CAAU,MAAM;AACd,IAAM,MAAA,CAAA,GAAI,WAAW,MAAM;AAGzB,MAAA,IAAI,cAAc,KAAO,EAAA;AACvB,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,IAAI,IAAA,KAAA,CAAM,QAAQ,KAAO,EAAA;AACvB,MAAA,YAAA,CAAa,MAAM,GAAG,CAAA,CAAA;AACtB,MAAA,SAAA,CAAU,IAAI,CAAA,CAAA;AAAA,KAChB;AAEA,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,4 +0,0 @@
1
- var css_248z = "/* Styles applied to InteractableCard */\n.saltInteractableCard {\n box-shadow: var(--saltCard-boxShadow, var(--salt-overlayable-shadow));\n border-width: var(--saltCard-borderWidth, var(--card-borderWidth));\n border-style: var(--saltCard-borderStyle, var(--salt-container-borderStyle));\n border-color: var(--saltCard-borderColor, var(--salt-accent-borderColor));\n border-radius: var(--saltCard-borderRadius, var(--salt-palette-corner, 0));\n display: block;\n transition: box-shadow var(--salt-duration-instant) cubic-bezier(0.4, 0, 0.2, 1);\n padding: var(--saltCard-padding, var(--salt-spacing-300));\n}\n\n/* Styles applied to InteractableCard when variant=\"primary\" */\n.saltInteractableCard-primary {\n background: var(--saltCard-background, var(--salt-container-primary-background));\n}\n\n/* Styles applied to InteractableCard when variant=\"secondary\" */\n.saltInteractableCard-secondary {\n background: var(--saltCard-background, var(--salt-container-secondary-background));\n}\n\n/* Styles applied to InteractableCard if `accentPlacement=\"bottom\"` (default) */\n.saltInteractableCard-accentBottom {\n --card-borderWidth: 0 0 var(--salt-size-accent) 0;\n}\n\n/* Styles applied to InteractableCard if `accentPlacement=\"left\"` */\n.saltInteractableCard-accentLeft {\n --card-borderWidth: 0 0 0 var(--salt-size-accent);\n}\n\n/* Styles applied to InteractableCard if `accentPlacement=\"top\"` */\n.saltInteractableCard-accentTop {\n --card-borderWidth: var(--salt-size-accent) 0 0 0;\n}\n\n/* Styles applied to InteractableCard if `accentPlacement=\"right\"` */\n.saltInteractableCard-accentRight {\n --card-borderWidth: 0 var(--salt-size-accent) 0 0;\n}\n\n/* Styles applied to InteractableCard on focus */\na:focus-visible .saltInteractableCard,\n.saltInteractableCard:focus-visible {\n cursor: var(--saltCard-interactable-cursor-focus, var(--salt-selectable-cursor-hover));\n box-shadow: var(--saltCard-interactable-shadow-focus, var(--salt-overlayable-shadow-hover));\n color: var(--saltCard-color-focus, var(--salt-content-primary-foreground));\n outline-color: var(--salt-focused-outlineColor);\n outline-style: var(--salt-focused-outlineStyle);\n outline-width: var(--salt-focused-outlineWidth);\n outline-offset: var(--salt-focused-outlineOffset);\n}\n\na:link .saltInteractableCard * {\n text-decoration: none;\n}\n\n/* Styles applied on active state to InteractableCard */\n.saltInteractableCard:active {\n cursor: var(--saltCard-interactable-cursor-active, var(--salt-selectable-cursor-active));\n box-shadow: var(--saltCard-interactable-shadow-active, var(--salt-overlayable-shadow-hover));\n}\n\n/* Styles applied on hover state to InteractableCard */\n.saltInteractableCard:hover {\n cursor: var(--saltCard-interactable-cursor-hover, var(--salt-selectable-cursor-hover));\n box-shadow: var(--saltCard-interactable-shadow-hover, var(--salt-overlayable-shadow-hover));\n}\n\n/* Styles applied to InteractableCard if `disabled={true}` */\n.saltInteractableCard-disabled,\n.saltInteractableCard-disabled:focus,\n.saltInteractableCard-disabled:hover,\n.saltInteractableCard-disabled:active {\n box-shadow: var(--saltCard-interactable-shadow, var(--salt-overlayable-shadow));\n color: var(--saltCard-color-disabled, var(--salt-content-primary-foreground-disabled));\n cursor: var(--saltCard-interactable-cursor-disabled, var(--salt-selectable-cursor-disabled));\n outline: none;\n}\n\n/* Styles applied to InteractableCard primary variant if `disabled={true}` */\n.saltInteractableCard-primary.saltInteractableCard-disabled,\n.saltInteractableCard-primary.saltInteractableCard-disabled:focus,\n.saltInteractableCard-primary.saltInteractableCard-disabled:hover,\n.saltInteractableCard-primary.saltInteractableCard-disabled:active {\n border-color: var(--saltCard-borderColor-disabled, var(--salt-container-primary-borderColor-disabled));\n background: var(--saltCard-background-disabled, var(--salt-container-primary-background-disabled));\n}\n\n/* Styles applied to InteractableCard secondary variant if `disabled={true}` */\n.saltInteractableCard-secondary.saltInteractableCard-disabled,\n.saltInteractableCard-secondary.saltInteractableCard-disabled:focus,\n.saltInteractableCard-secondary.saltInteractableCard-disabled:hover,\n.saltInteractableCard-secondary.saltInteractableCard-disabled:active {\n border-color: var(--saltCard-borderColor-disabled, var(--salt-container-secondary-borderColor-disabled));\n background: var(--saltCard-background-disabled, var(--salt-container-secondary-background));\n}\n\n/* Styles applied to nested divs in InteractableCard if `disabled={true}` */\n.saltInteractableCard-disabled div {\n pointer-events: none;\n}\n\n/* Class that can be used for anchor tags wrapping InteractableCard */\n.saltInteractableCard-link {\n color: var(--saltCard-link-color, var(--salt-content-primary-foreground));\n inset: var(--salt-focused-outlineInset);\n outline-color: var(--salt-focused-outlineColor);\n outline-offset: var(--salt-focused-outlineOffset);\n outline-style: var(--salt-focused-outlineStyle);\n outline-width: var(--salt-focused-outlineWidth);\n}\n";
2
-
3
- export { css_248z as default };
4
- //# sourceMappingURL=InteractableCard.css.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"InteractableCard.js","sources":["../src/card/InteractableCard.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport { ComponentPropsWithoutRef, forwardRef } from \"react\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport { capitalize, makePrefixer } from \"../utils\";\nimport { useInteractableCard } from \"./useInteractableCard\";\n\nimport interactableCardCss from \"./InteractableCard.css\";\n\nconst withBaseName = makePrefixer(\"saltInteractableCard\");\n\n// TODO: Remove omissions when Card props deprecated\nexport interface InteractableCardProps extends ComponentPropsWithoutRef<\"div\"> {\n /**\n * Accent border position: defaults to \"bottom\"\n */\n accentPlacement?: \"bottom\" | \"top\" | \"left\" | \"right\";\n /**\n * If `true`, the card will be disabled.\n */\n disabled?: boolean;\n /**\n * Styling variant; defaults to \"primary\".\n */\n variant?: \"primary\" | \"secondary\";\n}\n\nexport const InteractableCard = forwardRef<\n HTMLDivElement,\n InteractableCardProps\n>(function InteractableCard(props, ref) {\n const {\n accentPlacement = \"bottom\",\n children,\n className,\n variant = \"primary\",\n disabled,\n onBlur,\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 { active, cardProps } = useInteractableCard({\n disabled,\n onKeyUp,\n onKeyDown,\n onBlur,\n onClick,\n });\n // for now, we do not want to spread tab index here as users may be wrapping in a link\n const { tabIndex, ...restCardProps } = cardProps;\n\n return (\n <div\n {...restCardProps}\n className={clsx(\n withBaseName(),\n withBaseName(variant),\n withBaseName(`accent${capitalize(accentPlacement)}`),\n {\n [withBaseName(\"disabled\")]: disabled,\n [withBaseName(\"active\")]: active,\n },\n className\n )}\n {...rest}\n ref={ref}\n >\n {children}\n </div>\n );\n});\n"],"names":["InteractableCard","interactableCardCss"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAUA,MAAM,YAAA,GAAe,aAAa,sBAAsB,CAAA,CAAA;AAkBjD,MAAM,gBAAmB,GAAA,UAAA,CAG9B,SAASA,iBAAAA,CAAiB,OAAO,GAAK,EAAA;AACtC,EAAM,MAAA;AAAA,IACJ,eAAkB,GAAA,QAAA;AAAA,IAClB,QAAA;AAAA,IACA,SAAA;AAAA,IACA,OAAU,GAAA,SAAA;AAAA,IACV,QAAA;AAAA,IACA,MAAA;AAAA,IACA,OAAA;AAAA,IACA,OAAA;AAAA,IACA,SAAA;AAAA,IACG,GAAA,IAAA;AAAA,GACD,GAAA,KAAA,CAAA;AAEJ,EAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,wBAAA;AAAA,IACR,GAAK,EAAAC,QAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,MAAM,EAAE,MAAA,EAAQ,SAAU,EAAA,GAAI,mBAAoB,CAAA;AAAA,IAChD,QAAA;AAAA,IACA,OAAA;AAAA,IACA,SAAA;AAAA,IACA,MAAA;AAAA,IACA,OAAA;AAAA,GACD,CAAA,CAAA;AAED,EAAM,MAAA,EAAE,QAAa,EAAA,GAAA,aAAA,EAAkB,GAAA,SAAA,CAAA;AAEvC,EAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,IACE,GAAG,aAAA;AAAA,IACJ,SAAW,EAAA,IAAA;AAAA,MACT,YAAa,EAAA;AAAA,MACb,aAAa,OAAO,CAAA;AAAA,MACpB,YAAa,CAAA,CAAA,MAAA,EAAS,UAAW,CAAA,eAAe,CAAG,CAAA,CAAA,CAAA;AAAA,MACnD;AAAA,QACE,CAAC,YAAa,CAAA,UAAU,CAAI,GAAA,QAAA;AAAA,QAC5B,CAAC,YAAa,CAAA,QAAQ,CAAI,GAAA,MAAA;AAAA,OAC5B;AAAA,MACA,SAAA;AAAA,KACF;AAAA,IACC,GAAG,IAAA;AAAA,IACJ,GAAA;AAAA,IAEC,QAAA;AAAA,GACH,CAAA,CAAA;AAEJ,CAAC;;;;"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"useInteractableCard.js","sources":["../src/card/useInteractableCard.ts"],"sourcesContent":["import {\n FocusEvent,\n KeyboardEvent,\n MouseEvent,\n useEffect,\n useState,\n} from \"react\";\n\nexport interface CardHookProps<T extends Element> {\n disabled?: boolean;\n onKeyUp?: (event: KeyboardEvent<T>) => void;\n onKeyDown?: (event: KeyboardEvent<T>) => void;\n onClick?: (event: MouseEvent<T>) => void;\n onBlur?: (event: FocusEvent<T>) => void;\n}\n\nexport interface CardHookResult<T extends Element> {\n active: boolean;\n cardProps: {\n \"aria-disabled\"?: boolean;\n disabled?: boolean;\n tabIndex: number;\n onBlur: (event: FocusEvent<T>) => void;\n onClick?: (event: MouseEvent<T>) => void;\n onKeyDown: (event: KeyboardEvent<T>) => void;\n onKeyUp: (event: KeyboardEvent<T>) => void;\n };\n}\n\nexport const useInteractableCard = <T extends Element>({\n disabled,\n onKeyUp,\n onKeyDown,\n onClick,\n onBlur,\n}: CardHookProps<T>): CardHookResult<T> => {\n const [keyIsDown, setkeyIsDown] = useState(\"\");\n const [active, setActive] = useState(false);\n\n const enter = \"Enter\";\n\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) {\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) {\n setkeyIsDown(event.key);\n setActive(true);\n }\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":[],"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,GAAI,SAAS,EAAE,CAAA,CAAA;AAC7C,EAAA,MAAM,CAAC,MAAA,EAAQ,SAAS,CAAA,GAAI,SAAS,KAAK,CAAA,CAAA;AAE1C,EAAA,MAAM,KAAQ,GAAA,OAAA,CAAA;AAEd,EAAA,SAAA,CAAU,MAAM;AACd,IAAM,MAAA,CAAA,GAAI,WAAW,MAAM;AAGzB,MAAA,IAAI,cAAc,KAAO,EAAA;AACvB,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,IAAI,IAAA,KAAA,CAAM,QAAQ,KAAO,EAAA;AACvB,MAAA,YAAA,CAAa,MAAM,GAAG,CAAA,CAAA;AACtB,MAAA,SAAA,CAAU,IAAI,CAAA,CAAA;AAAA,KAChB;AAEA,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;;;;"}