@salt-ds/core 1.37.0 → 1.37.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (668) hide show
  1. package/CHANGELOG.md +1753 -0
  2. package/css/salt-core.css +75 -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 +30 -124
  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 +35 -134
  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.js +30 -121
  98. package/dist-cjs/form-field/FormField.js.map +1 -1
  99. package/dist-cjs/form-field/FormFieldHelperText.js +24 -114
  100. package/dist-cjs/form-field/FormFieldHelperText.js.map +1 -1
  101. package/dist-cjs/form-field/FormFieldLabel.js +15 -106
  102. package/dist-cjs/form-field/FormFieldLabel.js.map +1 -1
  103. package/dist-cjs/form-field-context/FormFieldContext.js +0 -100
  104. package/dist-cjs/form-field-context/FormFieldContext.js.map +1 -1
  105. package/dist-cjs/form-field-context/useFormFieldProps.js +0 -2
  106. package/dist-cjs/form-field-context/useFormFieldProps.js.map +1 -1
  107. package/dist-cjs/grid-item/GridItem.js +10 -106
  108. package/dist-cjs/grid-item/GridItem.js.map +1 -1
  109. package/dist-cjs/grid-layout/GridLayout.js +13 -109
  110. package/dist-cjs/grid-layout/GridLayout.js.map +1 -1
  111. package/dist-cjs/index.js +0 -2
  112. package/dist-cjs/index.js.map +1 -1
  113. package/dist-cjs/input/Input.js +49 -149
  114. package/dist-cjs/input/Input.js.map +1 -1
  115. package/dist-cjs/interactable-card/InteractableCard.js +28 -122
  116. package/dist-cjs/interactable-card/InteractableCard.js.map +1 -1
  117. package/dist-cjs/interactable-card/InteractableCardGroup.js +9 -106
  118. package/dist-cjs/interactable-card/InteractableCardGroup.js.map +1 -1
  119. package/dist-cjs/interactable-card/InteractableCardGroupContext.js +0 -100
  120. package/dist-cjs/interactable-card/InteractableCardGroupContext.js.map +1 -1
  121. package/dist-cjs/interactable-card/useInteractableCard.js +0 -2
  122. package/dist-cjs/interactable-card/useInteractableCard.js.map +1 -1
  123. package/dist-cjs/link/Link.js +22 -117
  124. package/dist-cjs/link/Link.js.map +1 -1
  125. package/dist-cjs/link-card/LinkCard.js +18 -113
  126. package/dist-cjs/link-card/LinkCard.js.map +1 -1
  127. package/dist-cjs/list-box/ListBox.js +8 -106
  128. package/dist-cjs/list-box/ListBox.js.map +1 -1
  129. package/dist-cjs/list-control/ListControlContext.js +0 -100
  130. package/dist-cjs/list-control/ListControlContext.js.map +1 -1
  131. package/dist-cjs/list-control/ListControlState.js +3 -104
  132. package/dist-cjs/list-control/ListControlState.js.map +1 -1
  133. package/dist-cjs/menu/Menu.js +2 -10
  134. package/dist-cjs/menu/Menu.js.map +1 -1
  135. package/dist-cjs/menu/MenuBase.js +10 -109
  136. package/dist-cjs/menu/MenuBase.js.map +1 -1
  137. package/dist-cjs/menu/MenuContext.js +0 -100
  138. package/dist-cjs/menu/MenuContext.js.map +1 -1
  139. package/dist-cjs/menu/MenuGroup.js +14 -114
  140. package/dist-cjs/menu/MenuGroup.js.map +1 -1
  141. package/dist-cjs/menu/MenuItem.js +51 -143
  142. package/dist-cjs/menu/MenuItem.js.map +1 -1
  143. package/dist-cjs/menu/MenuPanel.js +27 -123
  144. package/dist-cjs/menu/MenuPanel.js.map +1 -1
  145. package/dist-cjs/menu/MenuPanelBase.js +1 -7
  146. package/dist-cjs/menu/MenuPanelBase.js.map +1 -1
  147. package/dist-cjs/menu/MenuPanelContext.js +0 -100
  148. package/dist-cjs/menu/MenuPanelContext.js.map +1 -1
  149. package/dist-cjs/menu/MenuTrigger.js +20 -118
  150. package/dist-cjs/menu/MenuTrigger.js.map +1 -1
  151. package/dist-cjs/menu/MenuTriggerContext.js +0 -100
  152. package/dist-cjs/menu/MenuTriggerContext.js.map +1 -1
  153. package/dist-cjs/multiline-input/MultilineInput.js +54 -161
  154. package/dist-cjs/multiline-input/MultilineInput.js.map +1 -1
  155. package/dist-cjs/navigation-item/ExpansionIcon.js +1 -5
  156. package/dist-cjs/navigation-item/ExpansionIcon.js.map +1 -1
  157. package/dist-cjs/navigation-item/NavigationItem.js +32 -132
  158. package/dist-cjs/navigation-item/NavigationItem.js.map +1 -1
  159. package/dist-cjs/navigation-item/NavigationItemAction.js +0 -102
  160. package/dist-cjs/navigation-item/NavigationItemAction.js.map +1 -1
  161. package/dist-cjs/option/Option.js +32 -120
  162. package/dist-cjs/option/Option.js.map +1 -1
  163. package/dist-cjs/option/OptionGroup.js +14 -114
  164. package/dist-cjs/option/OptionGroup.js.map +1 -1
  165. package/dist-cjs/option/OptionList.js +17 -117
  166. package/dist-cjs/option/OptionList.js.map +1 -1
  167. package/dist-cjs/option/OptionListBase.js +9 -105
  168. package/dist-cjs/option/OptionListBase.js.map +1 -1
  169. package/dist-cjs/overlay/Overlay.js +18 -114
  170. package/dist-cjs/overlay/Overlay.js.map +1 -1
  171. package/dist-cjs/overlay/OverlayContext.js +0 -100
  172. package/dist-cjs/overlay/OverlayContext.js.map +1 -1
  173. package/dist-cjs/overlay/OverlayPanel.js +34 -127
  174. package/dist-cjs/overlay/OverlayPanel.js.map +1 -1
  175. package/dist-cjs/overlay/OverlayPanelCloseButton.js +7 -109
  176. package/dist-cjs/overlay/OverlayPanelCloseButton.js.map +1 -1
  177. package/dist-cjs/overlay/OverlayPanelContent.css.js +1 -1
  178. package/dist-cjs/overlay/OverlayPanelContent.js +41 -107
  179. package/dist-cjs/overlay/OverlayPanelContent.js.map +1 -1
  180. package/dist-cjs/overlay/OverlayTrigger.js +6 -111
  181. package/dist-cjs/overlay/OverlayTrigger.js.map +1 -1
  182. package/dist-cjs/pagination/CompactInput.js +20 -114
  183. package/dist-cjs/pagination/CompactInput.js.map +1 -1
  184. package/dist-cjs/pagination/CompactPaginator.js +21 -123
  185. package/dist-cjs/pagination/CompactPaginator.js.map +1 -1
  186. package/dist-cjs/pagination/GoToInput.js +31 -114
  187. package/dist-cjs/pagination/GoToInput.js.map +1 -1
  188. package/dist-cjs/pagination/PageButton.js +17 -112
  189. package/dist-cjs/pagination/PageButton.js.map +1 -1
  190. package/dist-cjs/pagination/PageRanges.js +15 -126
  191. package/dist-cjs/pagination/PageRanges.js.map +1 -1
  192. package/dist-cjs/pagination/Pagination.js +6 -103
  193. package/dist-cjs/pagination/Pagination.js.map +1 -1
  194. package/dist-cjs/pagination/PaginationContext.js +0 -2
  195. package/dist-cjs/pagination/PaginationContext.js.map +1 -1
  196. package/dist-cjs/pagination/Paginator.js +19 -121
  197. package/dist-cjs/pagination/Paginator.js.map +1 -1
  198. package/dist-cjs/pagination/usePagination.js +0 -2
  199. package/dist-cjs/pagination/usePagination.js.map +1 -1
  200. package/dist-cjs/pagination/usePaginationContext.js +0 -2
  201. package/dist-cjs/pagination/usePaginationContext.js.map +1 -1
  202. package/dist-cjs/panel/Panel.js +9 -104
  203. package/dist-cjs/panel/Panel.js.map +1 -1
  204. package/dist-cjs/parent-child-layout/ParentChildLayout.js +24 -123
  205. package/dist-cjs/parent-child-layout/ParentChildLayout.js.map +1 -1
  206. package/dist-cjs/parent-child-layout/useIsViewportLargerThanBreakpoint.js +0 -103
  207. package/dist-cjs/parent-child-layout/useIsViewportLargerThanBreakpoint.js.map +1 -1
  208. package/dist-cjs/pill/Pill.js +17 -115
  209. package/dist-cjs/pill/Pill.js.map +1 -1
  210. package/dist-cjs/pill-input/PillInput.js +97 -204
  211. package/dist-cjs/pill-input/PillInput.js.map +1 -1
  212. package/dist-cjs/pill-input/useTruncatePills.js +0 -2
  213. package/dist-cjs/pill-input/useTruncatePills.js.map +1 -1
  214. package/dist-cjs/progress/CircularProgress/CircularProgress.js +44 -153
  215. package/dist-cjs/progress/CircularProgress/CircularProgress.js.map +1 -1
  216. package/dist-cjs/progress/LinearProgress/LinearProgress.js +28 -125
  217. package/dist-cjs/progress/LinearProgress/LinearProgress.js.map +1 -1
  218. package/dist-cjs/radio-button/RadioButton.css.js +1 -1
  219. package/dist-cjs/radio-button/RadioButton.js +60 -150
  220. package/dist-cjs/radio-button/RadioButton.js.map +1 -1
  221. package/dist-cjs/radio-button/RadioButtonGroup.js +36 -127
  222. package/dist-cjs/radio-button/RadioButtonGroup.js.map +1 -1
  223. package/dist-cjs/radio-button/RadioButtonIcon.js +45 -134
  224. package/dist-cjs/radio-button/RadioButtonIcon.js.map +1 -1
  225. package/dist-cjs/radio-button/internal/RadioGroupContext.js +0 -101
  226. package/dist-cjs/radio-button/internal/RadioGroupContext.js.map +1 -1
  227. package/dist-cjs/radio-button/internal/useRadioGroup.js +0 -2
  228. package/dist-cjs/radio-button/internal/useRadioGroup.js.map +1 -1
  229. package/dist-cjs/salt-provider/SaltProvider.js +32 -155
  230. package/dist-cjs/salt-provider/SaltProvider.js.map +1 -1
  231. package/dist-cjs/scrim/Scrim.js +16 -111
  232. package/dist-cjs/scrim/Scrim.js.map +1 -1
  233. package/dist-cjs/segmented-button-group/SegmentedButtonGroup.js +1 -104
  234. package/dist-cjs/segmented-button-group/SegmentedButtonGroup.js.map +1 -1
  235. package/dist-cjs/semantic-icon-provider/SemanticIconProvider.js +1 -6
  236. package/dist-cjs/semantic-icon-provider/SemanticIconProvider.js.map +1 -1
  237. package/dist-cjs/spinner/Spinner.js +16 -116
  238. package/dist-cjs/spinner/Spinner.js.map +1 -1
  239. package/dist-cjs/spinner/svgSpinners/SpinnerSVG.js +43 -141
  240. package/dist-cjs/spinner/svgSpinners/SpinnerSVG.js.map +1 -1
  241. package/dist-cjs/split-layout/SplitLayout.js +13 -107
  242. package/dist-cjs/split-layout/SplitLayout.js.map +1 -1
  243. package/dist-cjs/stack-layout/StackLayout.js +21 -116
  244. package/dist-cjs/stack-layout/StackLayout.js.map +1 -1
  245. package/dist-cjs/status-adornment/ErrorAdornment.js +5 -11
  246. package/dist-cjs/status-adornment/ErrorAdornment.js.map +1 -1
  247. package/dist-cjs/status-adornment/StatusAdornment.js +9 -104
  248. package/dist-cjs/status-adornment/StatusAdornment.js.map +1 -1
  249. package/dist-cjs/status-adornment/SuccessAdornment.js +18 -14
  250. package/dist-cjs/status-adornment/SuccessAdornment.js.map +1 -1
  251. package/dist-cjs/status-adornment/WarningAdornment.js +1 -12
  252. package/dist-cjs/status-adornment/WarningAdornment.js.map +1 -1
  253. package/dist-cjs/status-indicator/StatusIndicator.js +10 -103
  254. package/dist-cjs/status-indicator/StatusIndicator.js.map +1 -1
  255. package/dist-cjs/status-indicator/ValidationStatus.js +0 -2
  256. package/dist-cjs/status-indicator/ValidationStatus.js.map +1 -1
  257. package/dist-cjs/switch/Switch.js +44 -150
  258. package/dist-cjs/switch/Switch.js.map +1 -1
  259. package/dist-cjs/tag/Tag.js +17 -112
  260. package/dist-cjs/tag/Tag.js.map +1 -1
  261. package/dist-cjs/text/Code.js +1 -8
  262. package/dist-cjs/text/Code.js.map +1 -1
  263. package/dist-cjs/text/Display.js +4 -30
  264. package/dist-cjs/text/Display.js.map +1 -1
  265. package/dist-cjs/text/Headings.js +4 -26
  266. package/dist-cjs/text/Headings.js.map +1 -1
  267. package/dist-cjs/text/Label.js +1 -8
  268. package/dist-cjs/text/Label.js.map +1 -1
  269. package/dist-cjs/text/Text.js +21 -117
  270. package/dist-cjs/text/Text.js.map +1 -1
  271. package/dist-cjs/text/TextAction.js +1 -9
  272. package/dist-cjs/text/TextAction.js.map +1 -1
  273. package/dist-cjs/text/TextNotation.js +1 -9
  274. package/dist-cjs/text/TextNotation.js.map +1 -1
  275. package/dist-cjs/theme/Accent.js +0 -2
  276. package/dist-cjs/theme/Accent.js.map +1 -1
  277. package/dist-cjs/theme/ActionFont.js +0 -2
  278. package/dist-cjs/theme/ActionFont.js.map +1 -1
  279. package/dist-cjs/theme/Corner.js +0 -2
  280. package/dist-cjs/theme/Corner.js.map +1 -1
  281. package/dist-cjs/theme/Density.js +0 -2
  282. package/dist-cjs/theme/Density.js.map +1 -1
  283. package/dist-cjs/theme/HeadingFont.js +0 -2
  284. package/dist-cjs/theme/HeadingFont.js.map +1 -1
  285. package/dist-cjs/theme/Mode.js +0 -2
  286. package/dist-cjs/theme/Mode.js.map +1 -1
  287. package/dist-cjs/theme/Theme.js +0 -2
  288. package/dist-cjs/theme/Theme.js.map +1 -1
  289. package/dist-cjs/toast/Toast.js +17 -116
  290. package/dist-cjs/toast/Toast.js.map +1 -1
  291. package/dist-cjs/toast/ToastContent.js +1 -104
  292. package/dist-cjs/toast/ToastContent.js.map +1 -1
  293. package/dist-cjs/toggle-button/ToggleButton.css.js +1 -1
  294. package/dist-cjs/toggle-button/ToggleButton.js +18 -111
  295. package/dist-cjs/toggle-button/ToggleButton.js.map +1 -1
  296. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js +10 -107
  297. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js.map +1 -1
  298. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js +0 -100
  299. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js.map +1 -1
  300. package/dist-cjs/tooltip/Tooltip.js +25 -119
  301. package/dist-cjs/tooltip/Tooltip.js.map +1 -1
  302. package/dist-cjs/tooltip/TooltipBase.js +25 -117
  303. package/dist-cjs/tooltip/TooltipBase.js.map +1 -1
  304. package/dist-cjs/tooltip/useAriaAnnounce.js +2 -104
  305. package/dist-cjs/tooltip/useAriaAnnounce.js.map +1 -1
  306. package/dist-cjs/tooltip/useTooltip.js +4 -103
  307. package/dist-cjs/tooltip/useTooltip.js.map +1 -1
  308. package/dist-cjs/utils/capitalize.js +0 -2
  309. package/dist-cjs/utils/capitalize.js.map +1 -1
  310. package/dist-cjs/utils/createChainedFunction.js +0 -2
  311. package/dist-cjs/utils/createChainedFunction.js.map +1 -1
  312. package/dist-cjs/utils/createContext.js +0 -2
  313. package/dist-cjs/utils/createContext.js.map +1 -1
  314. package/dist-cjs/utils/debounce.js +0 -2
  315. package/dist-cjs/utils/debounce.js.map +1 -1
  316. package/dist-cjs/utils/getRefFromChildren.js +4 -3
  317. package/dist-cjs/utils/getRefFromChildren.js.map +1 -1
  318. package/dist-cjs/utils/makePrefixer.js +0 -2
  319. package/dist-cjs/utils/makePrefixer.js.map +1 -1
  320. package/dist-cjs/utils/marginMiddleware.js +0 -2
  321. package/dist-cjs/utils/marginMiddleware.js.map +1 -1
  322. package/dist-cjs/utils/mergeProps.js +0 -2
  323. package/dist-cjs/utils/mergeProps.js.map +1 -1
  324. package/dist-cjs/utils/ownerDocument.js +0 -2
  325. package/dist-cjs/utils/ownerDocument.js.map +1 -1
  326. package/dist-cjs/utils/ownerWindow.js +0 -2
  327. package/dist-cjs/utils/ownerWindow.js.map +1 -1
  328. package/dist-cjs/utils/renderProps.js +1 -5
  329. package/dist-cjs/utils/renderProps.js.map +1 -1
  330. package/dist-cjs/utils/setRef.js +0 -2
  331. package/dist-cjs/utils/setRef.js.map +1 -1
  332. package/dist-cjs/utils/useControlled.js +0 -2
  333. package/dist-cjs/utils/useControlled.js.map +1 -1
  334. package/dist-cjs/utils/useEventCallback.js +4 -3
  335. package/dist-cjs/utils/useEventCallback.js.map +1 -1
  336. package/dist-cjs/utils/useFloatingUI/useFloatingUI.js +6 -33
  337. package/dist-cjs/utils/useFloatingUI/useFloatingUI.js.map +1 -1
  338. package/dist-cjs/utils/useForkRef.js +0 -2
  339. package/dist-cjs/utils/useForkRef.js.map +1 -1
  340. package/dist-cjs/utils/useId.js +5 -8
  341. package/dist-cjs/utils/useId.js.map +1 -1
  342. package/dist-cjs/utils/useIsFocusVisible.js +0 -2
  343. package/dist-cjs/utils/useIsFocusVisible.js.map +1 -1
  344. package/dist-cjs/utils/useIsomorphicLayoutEffect.js +0 -2
  345. package/dist-cjs/utils/useIsomorphicLayoutEffect.js.map +1 -1
  346. package/dist-cjs/utils/usePrevious.js +0 -2
  347. package/dist-cjs/utils/usePrevious.js.map +1 -1
  348. package/dist-cjs/utils/useResizeObserver.js +5 -7
  349. package/dist-cjs/utils/useResizeObserver.js.map +1 -1
  350. package/dist-cjs/utils/useResponsiveProp.js +2 -5
  351. package/dist-cjs/utils/useResponsiveProp.js.map +1 -1
  352. package/dist-cjs/utils/useValueEffect.js +1 -108
  353. package/dist-cjs/utils/useValueEffect.js.map +1 -1
  354. package/dist-cjs/viewport/ViewportProvider.js +1 -109
  355. package/dist-cjs/viewport/ViewportProvider.js.map +1 -1
  356. package/dist-es/accordion/Accordion.js +31 -121
  357. package/dist-es/accordion/Accordion.js.map +1 -1
  358. package/dist-es/accordion/AccordionContext.js +0 -99
  359. package/dist-es/accordion/AccordionContext.js.map +1 -1
  360. package/dist-es/accordion/AccordionGroup.js +1 -101
  361. package/dist-es/accordion/AccordionGroup.js.map +1 -1
  362. package/dist-es/accordion/AccordionHeader.js +33 -134
  363. package/dist-es/accordion/AccordionHeader.js.map +1 -1
  364. package/dist-es/accordion/AccordionPanel.js +22 -115
  365. package/dist-es/accordion/AccordionPanel.js.map +1 -1
  366. package/dist-es/aria-announcer/AriaAnnounce.js.map +1 -1
  367. package/dist-es/aria-announcer/AriaAnnouncerContext.js.map +1 -1
  368. package/dist-es/aria-announcer/AriaAnnouncerProvider.js +8 -8
  369. package/dist-es/aria-announcer/AriaAnnouncerProvider.js.map +1 -1
  370. package/dist-es/aria-announcer/useAriaAnnouncer.js +0 -104
  371. package/dist-es/aria-announcer/useAriaAnnouncer.js.map +1 -1
  372. package/dist-es/avatar/Avatar.js +18 -115
  373. package/dist-es/avatar/Avatar.js.map +1 -1
  374. package/dist-es/avatar/useAvatarImage.js +0 -99
  375. package/dist-es/avatar/useAvatarImage.js.map +1 -1
  376. package/dist-es/badge/Badge.js +8 -106
  377. package/dist-es/badge/Badge.js.map +1 -1
  378. package/dist-es/banner/Banner.js +18 -113
  379. package/dist-es/banner/Banner.js.map +1 -1
  380. package/dist-es/banner/BannerActions.js +1 -101
  381. package/dist-es/banner/BannerActions.js.map +1 -1
  382. package/dist-es/banner/BannerContent.js +1 -101
  383. package/dist-es/banner/BannerContent.js.map +1 -1
  384. package/dist-es/border-item/BorderItem.js +17 -109
  385. package/dist-es/border-item/BorderItem.js.map +1 -1
  386. package/dist-es/border-layout/BorderLayout.js +12 -106
  387. package/dist-es/border-layout/BorderLayout.js.map +1 -1
  388. package/dist-es/breakpoints/BreakpointProvider.js +2 -109
  389. package/dist-es/breakpoints/BreakpointProvider.js.map +1 -1
  390. package/dist-es/breakpoints/Breakpoints.js.map +1 -1
  391. package/dist-es/button/Button.js +24 -118
  392. package/dist-es/button/Button.js.map +1 -1
  393. package/dist-es/button/useButton.js.map +1 -1
  394. package/dist-es/card/Card.js +21 -113
  395. package/dist-es/card/Card.js.map +1 -1
  396. package/dist-es/checkbox/Checkbox.css.js +1 -1
  397. package/dist-es/checkbox/Checkbox.js +62 -148
  398. package/dist-es/checkbox/Checkbox.js.map +1 -1
  399. package/dist-es/checkbox/CheckboxGroup.js +32 -121
  400. package/dist-es/checkbox/CheckboxGroup.js.map +1 -1
  401. package/dist-es/checkbox/CheckboxIcon.js +24 -129
  402. package/dist-es/checkbox/CheckboxIcon.js.map +1 -1
  403. package/dist-es/checkbox/internal/CheckboxGroupContext.js +0 -99
  404. package/dist-es/checkbox/internal/CheckboxGroupContext.js.map +1 -1
  405. package/dist-es/checkbox/internal/useCheckboxGroup.js.map +1 -1
  406. package/dist-es/combo-box/ComboBox.js +30 -122
  407. package/dist-es/combo-box/ComboBox.js.map +1 -1
  408. package/dist-es/combo-box/useComboBox.js +1 -100
  409. package/dist-es/combo-box/useComboBox.js.map +1 -1
  410. package/dist-es/dialog/Dialog.js +38 -141
  411. package/dist-es/dialog/Dialog.js.map +1 -1
  412. package/dist-es/dialog/DialogActions.js +1 -102
  413. package/dist-es/dialog/DialogActions.js.map +1 -1
  414. package/dist-es/dialog/DialogCloseButton.js +11 -104
  415. package/dist-es/dialog/DialogCloseButton.js.map +1 -1
  416. package/dist-es/dialog/DialogContent.css.js +1 -1
  417. package/dist-es/dialog/DialogContent.js +40 -112
  418. package/dist-es/dialog/DialogContent.js.map +1 -1
  419. package/dist-es/dialog/DialogContext.js.map +1 -1
  420. package/dist-es/dialog/DialogHeader.js +24 -119
  421. package/dist-es/dialog/DialogHeader.js.map +1 -1
  422. package/dist-es/divider/Divider.js +15 -108
  423. package/dist-es/divider/Divider.js.map +1 -1
  424. package/dist-es/drawer/Drawer.js +13 -112
  425. package/dist-es/drawer/Drawer.js.map +1 -1
  426. package/dist-es/drawer/DrawerCloseButton.js +7 -103
  427. package/dist-es/drawer/DrawerCloseButton.js.map +1 -1
  428. package/dist-es/dropdown/Dropdown.js +35 -132
  429. package/dist-es/dropdown/Dropdown.js.map +1 -1
  430. package/dist-es/file-drop-zone/FileDropZone.js +21 -114
  431. package/dist-es/file-drop-zone/FileDropZone.js.map +1 -1
  432. package/dist-es/file-drop-zone/FileDropZoneIcon.js +2 -7
  433. package/dist-es/file-drop-zone/FileDropZoneIcon.js.map +1 -1
  434. package/dist-es/file-drop-zone/FileDropZoneTrigger.js +14 -108
  435. package/dist-es/file-drop-zone/FileDropZoneTrigger.js.map +1 -1
  436. package/dist-es/file-drop-zone/internal/utils.js +1 -2
  437. package/dist-es/file-drop-zone/internal/utils.js.map +1 -1
  438. package/dist-es/flex-item/FlexItem.js +10 -104
  439. package/dist-es/flex-item/FlexItem.js.map +1 -1
  440. package/dist-es/flex-layout/FlexLayout.js +21 -115
  441. package/dist-es/flex-layout/FlexLayout.js.map +1 -1
  442. package/dist-es/flow-layout/FlowLayout.js +1 -7
  443. package/dist-es/flow-layout/FlowLayout.js.map +1 -1
  444. package/dist-es/form-field/FormField.js +30 -119
  445. package/dist-es/form-field/FormField.js.map +1 -1
  446. package/dist-es/form-field/FormFieldHelperText.js +24 -108
  447. package/dist-es/form-field/FormFieldHelperText.js.map +1 -1
  448. package/dist-es/form-field/FormFieldLabel.js +15 -104
  449. package/dist-es/form-field/FormFieldLabel.js.map +1 -1
  450. package/dist-es/form-field-context/FormFieldContext.js +0 -98
  451. package/dist-es/form-field-context/FormFieldContext.js.map +1 -1
  452. package/dist-es/form-field-context/useFormFieldProps.js.map +1 -1
  453. package/dist-es/grid-item/GridItem.js +10 -104
  454. package/dist-es/grid-item/GridItem.js.map +1 -1
  455. package/dist-es/grid-layout/GridLayout.js +13 -107
  456. package/dist-es/grid-layout/GridLayout.js.map +1 -1
  457. package/dist-es/input/Input.js +49 -147
  458. package/dist-es/input/Input.js.map +1 -1
  459. package/dist-es/interactable-card/InteractableCard.js +28 -120
  460. package/dist-es/interactable-card/InteractableCard.js.map +1 -1
  461. package/dist-es/interactable-card/InteractableCardGroup.js +9 -104
  462. package/dist-es/interactable-card/InteractableCardGroup.js.map +1 -1
  463. package/dist-es/interactable-card/InteractableCardGroupContext.js +0 -98
  464. package/dist-es/interactable-card/InteractableCardGroupContext.js.map +1 -1
  465. package/dist-es/interactable-card/useInteractableCard.js.map +1 -1
  466. package/dist-es/link/Link.js +22 -115
  467. package/dist-es/link/Link.js.map +1 -1
  468. package/dist-es/link-card/LinkCard.js +18 -111
  469. package/dist-es/link-card/LinkCard.js.map +1 -1
  470. package/dist-es/list-box/ListBox.js +8 -104
  471. package/dist-es/list-box/ListBox.js.map +1 -1
  472. package/dist-es/list-control/ListControlContext.js +0 -98
  473. package/dist-es/list-control/ListControlContext.js.map +1 -1
  474. package/dist-es/list-control/ListControlState.js +3 -102
  475. package/dist-es/list-control/ListControlState.js.map +1 -1
  476. package/dist-es/menu/Menu.js +2 -8
  477. package/dist-es/menu/Menu.js.map +1 -1
  478. package/dist-es/menu/MenuBase.js +10 -107
  479. package/dist-es/menu/MenuBase.js.map +1 -1
  480. package/dist-es/menu/MenuContext.js +0 -98
  481. package/dist-es/menu/MenuContext.js.map +1 -1
  482. package/dist-es/menu/MenuGroup.js +14 -112
  483. package/dist-es/menu/MenuGroup.js.map +1 -1
  484. package/dist-es/menu/MenuItem.js +51 -141
  485. package/dist-es/menu/MenuItem.js.map +1 -1
  486. package/dist-es/menu/MenuPanel.js +27 -121
  487. package/dist-es/menu/MenuPanel.js.map +1 -1
  488. package/dist-es/menu/MenuPanelBase.js +1 -5
  489. package/dist-es/menu/MenuPanelBase.js.map +1 -1
  490. package/dist-es/menu/MenuPanelContext.js +0 -98
  491. package/dist-es/menu/MenuPanelContext.js.map +1 -1
  492. package/dist-es/menu/MenuTrigger.js +20 -116
  493. package/dist-es/menu/MenuTrigger.js.map +1 -1
  494. package/dist-es/menu/MenuTriggerContext.js +0 -98
  495. package/dist-es/menu/MenuTriggerContext.js.map +1 -1
  496. package/dist-es/multiline-input/MultilineInput.js +54 -159
  497. package/dist-es/multiline-input/MultilineInput.js.map +1 -1
  498. package/dist-es/navigation-item/ExpansionIcon.js +1 -3
  499. package/dist-es/navigation-item/ExpansionIcon.js.map +1 -1
  500. package/dist-es/navigation-item/NavigationItem.js +32 -130
  501. package/dist-es/navigation-item/NavigationItem.js.map +1 -1
  502. package/dist-es/navigation-item/NavigationItemAction.js +0 -100
  503. package/dist-es/navigation-item/NavigationItemAction.js.map +1 -1
  504. package/dist-es/option/Option.js +32 -118
  505. package/dist-es/option/Option.js.map +1 -1
  506. package/dist-es/option/OptionGroup.js +14 -112
  507. package/dist-es/option/OptionGroup.js.map +1 -1
  508. package/dist-es/option/OptionList.js +17 -115
  509. package/dist-es/option/OptionList.js.map +1 -1
  510. package/dist-es/option/OptionListBase.js +9 -103
  511. package/dist-es/option/OptionListBase.js.map +1 -1
  512. package/dist-es/overlay/Overlay.js +18 -112
  513. package/dist-es/overlay/Overlay.js.map +1 -1
  514. package/dist-es/overlay/OverlayContext.js +0 -98
  515. package/dist-es/overlay/OverlayContext.js.map +1 -1
  516. package/dist-es/overlay/OverlayPanel.js +34 -125
  517. package/dist-es/overlay/OverlayPanel.js.map +1 -1
  518. package/dist-es/overlay/OverlayPanelCloseButton.js +7 -103
  519. package/dist-es/overlay/OverlayPanelCloseButton.js.map +1 -1
  520. package/dist-es/overlay/OverlayPanelContent.css.js +1 -1
  521. package/dist-es/overlay/OverlayPanelContent.js +43 -103
  522. package/dist-es/overlay/OverlayPanelContent.js.map +1 -1
  523. package/dist-es/overlay/OverlayTrigger.js +6 -109
  524. package/dist-es/overlay/OverlayTrigger.js.map +1 -1
  525. package/dist-es/pagination/CompactInput.js +20 -112
  526. package/dist-es/pagination/CompactInput.js.map +1 -1
  527. package/dist-es/pagination/CompactPaginator.js +21 -121
  528. package/dist-es/pagination/CompactPaginator.js.map +1 -1
  529. package/dist-es/pagination/GoToInput.js +31 -112
  530. package/dist-es/pagination/GoToInput.js.map +1 -1
  531. package/dist-es/pagination/PageButton.js +17 -110
  532. package/dist-es/pagination/PageButton.js.map +1 -1
  533. package/dist-es/pagination/PageRanges.js +15 -124
  534. package/dist-es/pagination/PageRanges.js.map +1 -1
  535. package/dist-es/pagination/Pagination.js +6 -101
  536. package/dist-es/pagination/Pagination.js.map +1 -1
  537. package/dist-es/pagination/PaginationContext.js.map +1 -1
  538. package/dist-es/pagination/Paginator.js +19 -119
  539. package/dist-es/pagination/Paginator.js.map +1 -1
  540. package/dist-es/pagination/usePagination.js.map +1 -1
  541. package/dist-es/pagination/usePaginationContext.js.map +1 -1
  542. package/dist-es/panel/Panel.js +9 -102
  543. package/dist-es/panel/Panel.js.map +1 -1
  544. package/dist-es/parent-child-layout/ParentChildLayout.js +24 -121
  545. package/dist-es/parent-child-layout/ParentChildLayout.js.map +1 -1
  546. package/dist-es/parent-child-layout/useIsViewportLargerThanBreakpoint.js +0 -101
  547. package/dist-es/parent-child-layout/useIsViewportLargerThanBreakpoint.js.map +1 -1
  548. package/dist-es/pill/Pill.js +17 -109
  549. package/dist-es/pill/Pill.js.map +1 -1
  550. package/dist-es/pill-input/PillInput.js +97 -202
  551. package/dist-es/pill-input/PillInput.js.map +1 -1
  552. package/dist-es/pill-input/useTruncatePills.js.map +1 -1
  553. package/dist-es/progress/CircularProgress/CircularProgress.js +44 -151
  554. package/dist-es/progress/CircularProgress/CircularProgress.js.map +1 -1
  555. package/dist-es/progress/LinearProgress/LinearProgress.js +28 -123
  556. package/dist-es/progress/LinearProgress/LinearProgress.js.map +1 -1
  557. package/dist-es/radio-button/RadioButton.css.js +1 -1
  558. package/dist-es/radio-button/RadioButton.js +60 -148
  559. package/dist-es/radio-button/RadioButton.js.map +1 -1
  560. package/dist-es/radio-button/RadioButtonGroup.js +36 -125
  561. package/dist-es/radio-button/RadioButtonGroup.js.map +1 -1
  562. package/dist-es/radio-button/RadioButtonIcon.js +45 -132
  563. package/dist-es/radio-button/RadioButtonIcon.js.map +1 -1
  564. package/dist-es/radio-button/internal/RadioGroupContext.js +0 -99
  565. package/dist-es/radio-button/internal/RadioGroupContext.js.map +1 -1
  566. package/dist-es/radio-button/internal/useRadioGroup.js.map +1 -1
  567. package/dist-es/salt-provider/SaltProvider.js +32 -153
  568. package/dist-es/salt-provider/SaltProvider.js.map +1 -1
  569. package/dist-es/scrim/Scrim.js +16 -109
  570. package/dist-es/scrim/Scrim.js.map +1 -1
  571. package/dist-es/segmented-button-group/SegmentedButtonGroup.js +1 -102
  572. package/dist-es/segmented-button-group/SegmentedButtonGroup.js.map +1 -1
  573. package/dist-es/semantic-icon-provider/SemanticIconProvider.js +1 -4
  574. package/dist-es/semantic-icon-provider/SemanticIconProvider.js.map +1 -1
  575. package/dist-es/spinner/Spinner.js +16 -114
  576. package/dist-es/spinner/Spinner.js.map +1 -1
  577. package/dist-es/spinner/svgSpinners/SpinnerSVG.js +43 -139
  578. package/dist-es/spinner/svgSpinners/SpinnerSVG.js.map +1 -1
  579. package/dist-es/split-layout/SplitLayout.js +13 -105
  580. package/dist-es/split-layout/SplitLayout.js.map +1 -1
  581. package/dist-es/stack-layout/StackLayout.js +21 -114
  582. package/dist-es/stack-layout/StackLayout.js.map +1 -1
  583. package/dist-es/status-adornment/ErrorAdornment.js +5 -9
  584. package/dist-es/status-adornment/ErrorAdornment.js.map +1 -1
  585. package/dist-es/status-adornment/StatusAdornment.js +9 -102
  586. package/dist-es/status-adornment/StatusAdornment.js.map +1 -1
  587. package/dist-es/status-adornment/SuccessAdornment.js +18 -12
  588. package/dist-es/status-adornment/SuccessAdornment.js.map +1 -1
  589. package/dist-es/status-adornment/WarningAdornment.js +1 -10
  590. package/dist-es/status-adornment/WarningAdornment.js.map +1 -1
  591. package/dist-es/status-indicator/StatusIndicator.js +10 -101
  592. package/dist-es/status-indicator/StatusIndicator.js.map +1 -1
  593. package/dist-es/status-indicator/ValidationStatus.js.map +1 -1
  594. package/dist-es/switch/Switch.js +44 -148
  595. package/dist-es/switch/Switch.js.map +1 -1
  596. package/dist-es/tag/Tag.js +17 -110
  597. package/dist-es/tag/Tag.js.map +1 -1
  598. package/dist-es/text/Code.js +1 -6
  599. package/dist-es/text/Code.js.map +1 -1
  600. package/dist-es/text/Display.js +4 -28
  601. package/dist-es/text/Display.js.map +1 -1
  602. package/dist-es/text/Headings.js +4 -24
  603. package/dist-es/text/Headings.js.map +1 -1
  604. package/dist-es/text/Label.js +1 -6
  605. package/dist-es/text/Label.js.map +1 -1
  606. package/dist-es/text/Text.js +21 -115
  607. package/dist-es/text/Text.js.map +1 -1
  608. package/dist-es/text/TextAction.js +1 -7
  609. package/dist-es/text/TextAction.js.map +1 -1
  610. package/dist-es/text/TextNotation.js +1 -7
  611. package/dist-es/text/TextNotation.js.map +1 -1
  612. package/dist-es/theme/Accent.js.map +1 -1
  613. package/dist-es/theme/ActionFont.js.map +1 -1
  614. package/dist-es/theme/Corner.js.map +1 -1
  615. package/dist-es/theme/HeadingFont.js.map +1 -1
  616. package/dist-es/theme/Theme.js.map +1 -1
  617. package/dist-es/toast/Toast.js +17 -114
  618. package/dist-es/toast/Toast.js.map +1 -1
  619. package/dist-es/toast/ToastContent.js +1 -102
  620. package/dist-es/toast/ToastContent.js.map +1 -1
  621. package/dist-es/toggle-button/ToggleButton.css.js +1 -1
  622. package/dist-es/toggle-button/ToggleButton.js +18 -109
  623. package/dist-es/toggle-button/ToggleButton.js.map +1 -1
  624. package/dist-es/toggle-button-group/ToggleButtonGroup.js +10 -105
  625. package/dist-es/toggle-button-group/ToggleButtonGroup.js.map +1 -1
  626. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js +0 -98
  627. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js.map +1 -1
  628. package/dist-es/tooltip/Tooltip.js +25 -117
  629. package/dist-es/tooltip/Tooltip.js.map +1 -1
  630. package/dist-es/tooltip/TooltipBase.js +25 -115
  631. package/dist-es/tooltip/TooltipBase.js.map +1 -1
  632. package/dist-es/tooltip/useAriaAnnounce.js +2 -102
  633. package/dist-es/tooltip/useAriaAnnounce.js.map +1 -1
  634. package/dist-es/tooltip/useTooltip.js +4 -101
  635. package/dist-es/tooltip/useTooltip.js.map +1 -1
  636. package/dist-es/utils/capitalize.js.map +1 -1
  637. package/dist-es/utils/createChainedFunction.js.map +1 -1
  638. package/dist-es/utils/createContext.js.map +1 -1
  639. package/dist-es/utils/debounce.js.map +1 -1
  640. package/dist-es/utils/getRefFromChildren.js +4 -1
  641. package/dist-es/utils/getRefFromChildren.js.map +1 -1
  642. package/dist-es/utils/marginMiddleware.js.map +1 -1
  643. package/dist-es/utils/mergeProps.js.map +1 -1
  644. package/dist-es/utils/ownerDocument.js.map +1 -1
  645. package/dist-es/utils/ownerWindow.js.map +1 -1
  646. package/dist-es/utils/renderProps.js +1 -3
  647. package/dist-es/utils/renderProps.js.map +1 -1
  648. package/dist-es/utils/setRef.js.map +1 -1
  649. package/dist-es/utils/useControlled.js.map +1 -1
  650. package/dist-es/utils/useEventCallback.js +4 -1
  651. package/dist-es/utils/useEventCallback.js.map +1 -1
  652. package/dist-es/utils/useFloatingUI/useFloatingUI.js +6 -31
  653. package/dist-es/utils/useFloatingUI/useFloatingUI.js.map +1 -1
  654. package/dist-es/utils/useForkRef.js.map +1 -1
  655. package/dist-es/utils/useId.js +2 -2
  656. package/dist-es/utils/useId.js.map +1 -1
  657. package/dist-es/utils/useIsFocusVisible.js.map +1 -1
  658. package/dist-es/utils/usePrevious.js.map +1 -1
  659. package/dist-es/utils/useResizeObserver.js +5 -5
  660. package/dist-es/utils/useResizeObserver.js.map +1 -1
  661. package/dist-es/utils/useResponsiveProp.js +2 -3
  662. package/dist-es/utils/useResponsiveProp.js.map +1 -1
  663. package/dist-es/utils/useValueEffect.js +1 -106
  664. package/dist-es/utils/useValueEffect.js.map +1 -1
  665. package/dist-es/viewport/ViewportProvider.js +1 -107
  666. package/dist-es/viewport/ViewportProvider.js.map +1 -1
  667. package/dist-types/file-drop-zone/FileDropZoneIcon.d.ts +1 -1
  668. package/package.json +8 -7
@@ -11,103 +11,8 @@ import { useForkRef } from '../utils/useForkRef.js';
11
11
  import '../utils/useId.js';
12
12
  import '../salt-provider/SaltProvider.js';
13
13
  import '../viewport/ViewportProvider.js';
14
- import '../accordion/AccordionGroup.js';
15
- import '../accordion/AccordionPanel.js';
16
- import '../accordion/Accordion.js';
17
- import '../accordion/AccordionHeader.js';
18
- import '../aria-announcer/AriaAnnouncerContext.js';
19
- import '../avatar/Avatar.js';
20
- import '../badge/Badge.js';
21
- import '../banner/Banner.js';
22
- import '../banner/BannerActions.js';
23
- import '../banner/BannerContent.js';
24
- import '../border-item/BorderItem.js';
25
- import '../border-layout/BorderLayout.js';
26
- import '../breakpoints/BreakpointProvider.js';
27
- import '../button/Button.js';
28
- import '../card/Card.js';
29
- import '../checkbox/Checkbox.js';
30
- import '../checkbox/CheckboxGroup.js';
31
- import '@salt-ds/icons';
32
- import '../combo-box/ComboBox.js';
33
- import '../dialog/Dialog.js';
34
- import '../dialog/DialogHeader.js';
35
- import '../dialog/DialogActions.js';
36
- import '../dialog/DialogContent.js';
37
- import '../dialog/DialogContext.js';
38
- import '../dialog/DialogCloseButton.js';
39
- import '../divider/Divider.js';
40
- import '../drawer/Drawer.js';
41
- import '../drawer/DrawerCloseButton.js';
42
- import '../dropdown/Dropdown.js';
43
- import '../file-drop-zone/FileDropZone.js';
44
- import '../file-drop-zone/FileDropZoneIcon.js';
45
- import '../file-drop-zone/FileDropZoneTrigger.js';
46
- import '../flex-item/FlexItem.js';
47
- import '../flex-layout/FlexLayout.js';
48
- import '../flow-layout/FlowLayout.js';
49
- import '../form-field/FormField.js';
50
- import '../form-field-context/FormFieldContext.js';
51
- import '../status-indicator/StatusIndicator.js';
52
- import '../text/Text.js';
53
- import '../text/Code.js';
54
- import '../text/Display.js';
55
- import '../text/Headings.js';
56
- import '../text/Label.js';
57
- import '../text/TextAction.js';
58
- import '../text/TextNotation.js';
59
- import '../grid-item/GridItem.js';
60
- import '../grid-layout/GridLayout.js';
61
- import '../input/Input.js';
62
- import './InteractableCardGroup.js';
63
- import { useInteractableCardGroup } from './InteractableCardGroupContext.js';
64
- import '../link/Link.js';
65
- import '../link-card/LinkCard.js';
66
- import '../list-box/ListBox.js';
67
- import '../list-control/ListControlContext.js';
68
- import '@floating-ui/react';
69
- import '../menu/MenuContext.js';
70
- import '../menu/MenuItem.js';
71
- import '../menu/MenuPanel.js';
72
- import '../menu/MenuPanelContext.js';
73
- import '../menu/MenuTriggerContext.js';
74
- import '../menu/MenuGroup.js';
75
- import '../multiline-input/MultilineInput.js';
76
- import '../navigation-item/NavigationItem.js';
77
- import '../option/Option.js';
78
- import '../option/OptionGroup.js';
79
- import '../overlay/OverlayContext.js';
80
- import '../overlay/OverlayPanel.js';
81
- import '../overlay/OverlayPanelCloseButton.js';
82
- import '../overlay/OverlayPanelContent.js';
83
- import '../pagination/Pagination.js';
84
- import '../pagination/Paginator.js';
85
- import '../pagination/CompactInput.js';
86
- import '../pagination/CompactPaginator.js';
87
- import '../pagination/GoToInput.js';
88
- import '../panel/Panel.js';
89
- import '../parent-child-layout/ParentChildLayout.js';
90
- import '../pill/Pill.js';
91
- import '../progress/CircularProgress/CircularProgress.js';
92
- import '../progress/LinearProgress/LinearProgress.js';
93
- import '../radio-button/RadioButton.js';
94
- import '../radio-button/RadioButtonGroup.js';
95
- import '../scrim/Scrim.js';
96
- import '../segmented-button-group/SegmentedButtonGroup.js';
97
- import '../spinner/Spinner.js';
98
- import '../stack-layout/StackLayout.js';
99
- import '../status-adornment/StatusAdornment.js';
100
- import '../toast/Toast.js';
101
- import '../toast/ToastContent.js';
102
- import '../split-layout/SplitLayout.js';
103
- import '../switch/Switch.js';
104
- import '../tag/Tag.js';
105
- import '../toggle-button/ToggleButton.js';
106
- import '../toggle-button-group/ToggleButtonGroup.js';
107
- import '../toggle-button-group/ToggleButtonGroupContext.js';
108
- import '../tooltip/Tooltip.js';
109
- import '../semantic-icon-provider/SemanticIconProvider.js';
110
14
  import css_248z from './InteractableCard.css.js';
15
+ import { useInteractableCardGroup } from './InteractableCardGroupContext.js';
111
16
  import { useInteractableCard } from './useInteractableCard.js';
112
17
 
113
18
  const withBaseName = makePrefixer("saltInteractableCard");
@@ -179,30 +84,33 @@ const InteractableCard = forwardRef(function InteractableCard2(props, ref) {
179
84
  onBlur,
180
85
  onClick
181
86
  });
182
- return /* @__PURE__ */ jsx("div", {
183
- ...cardProps,
184
- role,
185
- "aria-checked": ariaChecked,
186
- "aria-disabled": disabled,
187
- "data-value": value,
188
- className: clsx(
189
- withBaseName(),
190
- withBaseName(variant),
191
- {
192
- [withBaseName("accent")]: accentValue,
193
- [withBaseName(`accent${capitalize(accentValue != null ? accentValue : "")}`)]: accentValue,
194
- [withBaseName("active")]: role === "button" && active,
195
- [withBaseName("disabled")]: disabled,
196
- [withBaseName("selected")]: selected
197
- },
198
- className
199
- ),
200
- ...rest,
201
- onClick: handleClick,
202
- ref: handleRef,
203
- tabIndex,
204
- children
205
- });
87
+ return /* @__PURE__ */ jsx(
88
+ "div",
89
+ {
90
+ ...cardProps,
91
+ role,
92
+ "aria-checked": ariaChecked,
93
+ "aria-disabled": disabled,
94
+ "data-value": value,
95
+ className: clsx(
96
+ withBaseName(),
97
+ withBaseName(variant),
98
+ {
99
+ [withBaseName("accent")]: accentValue,
100
+ [withBaseName(`accent${capitalize(accentValue ?? "")}`)]: accentValue,
101
+ [withBaseName("active")]: role === "button" && active,
102
+ [withBaseName("disabled")]: disabled,
103
+ [withBaseName("selected")]: selected
104
+ },
105
+ className
106
+ ),
107
+ ...rest,
108
+ onClick: handleClick,
109
+ ref: handleRef,
110
+ tabIndex,
111
+ children
112
+ }
113
+ );
206
114
  });
207
115
 
208
116
  export { InteractableCard };
@@ -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":["InteractableCard","interactableCardCss"],"mappings":"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"}
1
+ {"version":3,"file":"InteractableCard.js","sources":["../src/interactable-card/InteractableCard.tsx"],"sourcesContent":["import { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport {\n type ComponentPropsWithoutRef,\n type MouseEvent,\n type SyntheticEvent,\n forwardRef,\n useRef,\n} from \"react\";\nimport { capitalize, makePrefixer, useControlled, useForkRef } from \"../utils\";\nimport interactableCardCss from \"./InteractableCard.css\";\nimport {\n type InteractableCardValue,\n useInteractableCardGroup,\n} from \"./InteractableCardGroupContext\";\nimport { useInteractableCard } from \"./useInteractableCard\";\n\nconst withBaseName = makePrefixer(\"saltInteractableCard\");\n\nexport interface InteractableCardProps extends ComponentPropsWithoutRef<\"div\"> {\n /**\n * Accent border position: defaults to \"bottom\"\n */\n accent?: \"bottom\" | \"top\" | \"left\" | \"right\";\n /**\n * @deprecated Use the `accent` prop instead\n */\n accentPlacement?: \"bottom\" | \"top\" | \"left\" | \"right\";\n /**\n * If `true`, the card will be disabled.\n */\n disabled?: boolean;\n /**\n * Callback fired when the selection changes.\n * @param event\n */\n onChange?: (event: SyntheticEvent<HTMLDivElement>) => void;\n /**\n * Styling variant; defaults to \"primary\".\n */\n variant?: \"primary\" | \"secondary\" | \"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":["InteractableCard","interactableCardCss"],"mappings":";;;;;;;;;;;;;;;;;AAkBA,MAAM,YAAA,GAAe,aAAa,sBAAsB,CAAA;AA8BjD,MAAM,gBAAmB,GAAA,UAAA,CAG9B,SAASA,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,IACA,GAAG;AAAA,GACD,GAAA,KAAA;AAEJ,EAAA,MAAM,eAAe,SAAU,EAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,wBAAA;AAAA,IACR,GAAK,EAAAC,QAAA;AAAA,IACL,MAAQ,EAAA;AAAA,GACT,CAAA;AAED,EAAA,MAAM,wBAAwB,wBAAyB,EAAA;AAEvD,EAAM,MAAA,6BAAA,GACJ,+DAAuB,UAAW,CAAA,KAAA,CAAA;AAEpC,EAAM,MAAA,QAAA,GAAA,CAAW,+DAAuB,QAAY,KAAA,YAAA;AAEpD,EAAA,MAAM,CAAC,QAAA,EAAU,WAAW,CAAA,GAAI,aAAc,CAAA;AAAA,IAC5C,UAAY,EAAA,6BAAA;AAAA,IACZ,OAAA,EAAS,QAAQ,KAAK,CAAA;AAAA,IACtB,IAAM,EAAA,kBAAA;AAAA,IACN,KAAO,EAAA;AAAA,GACR,CAAA;AAED,EAAA,MAAM,IAAO,GAAA,qBAAA,GACT,qBAAsB,CAAA,WAAA,GACpB,aACA,OACF,GAAA,QAAA;AAEJ,EAAA,MAAM,gBAAgB,qBAAuB,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,qBAAA,CAAA,WAAA;AAE7C,EAAM,MAAA,YAAA,GAAe,+DAAuB,YAAa,CAAA,KAAA,CAAA;AAEzD,EAAA,MAAM,WACJ,GAAA,IAAA,KAAS,OAAW,IAAA,IAAA,KAAS,aAAa,QAAW,GAAA,KAAA,CAAA;AAEvD,EAAA,MAAM,cAAc,MAAU,IAAA,eAAA;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;AACzC,MAAA,WAAA,CAAY,CAAC,QAAQ,CAAA;AAAA;AAEvB,IAAW,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAA,KAAA,CAAA;AACX,IAAU,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,CAAA,KAAA,CAAA;AAAA,GACZ;AAEA,EAAI,IAAA,QAAA;AAEJ,EAAA,IAAI,qBAAuB,EAAA;AACzB,IAAA,IAAI,QAAU,EAAA;AACZ,MAAW,QAAA,GAAA,CAAA,CAAA;AAAA,eACF,aAAe,EAAA;AACxB,MAAW,QAAA,GAAA,CAAA;AAAA,KACN,MAAA;AAEL,MAAA,QAAA,GAAW,WAAW,CAAI,GAAA,CAAA,CAAA;AAC1B,MAAI,IAAA,CAAC,qBAAsB,CAAA,KAAA,IAAS,YAAc,EAAA;AAChD,QAAW,QAAA,GAAA,CAAA;AAAA;AACb;AACF,GACK,MAAA;AACL,IAAA,QAAA,GAAW,WAAW,CAAK,CAAA,GAAA,CAAA;AAAA;AAG7B,EAAM,MAAA,OAAA,GAAU,OAAuB,IAAI,CAAA;AAC3C,EAAM,MAAA,SAAA,GAAY,UAAW,CAAA,GAAA,EAAK,OAAO,CAAA;AAEzC,EAAA,MAAM,EAAE,MAAA,EAAQ,SAAU,EAAA,GAAI,mBAAoB,CAAA;AAAA,IAChD,QAAA;AAAA,IACA,OAAA;AAAA,IACA,SAAA;AAAA,IACA,MAAA;AAAA,IACA;AAAA,GACD,CAAA;AAED,EACE,uBAAA,GAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACE,GAAG,SAAA;AAAA,MACJ,IAAA;AAAA,MACA,cAAc,EAAA,WAAA;AAAA,MACd,eAAe,EAAA,QAAA;AAAA,MACf,YAAY,EAAA,KAAA;AAAA,MACZ,SAAW,EAAA,IAAA;AAAA,QACT,YAAa,EAAA;AAAA,QACb,aAAa,OAAO,CAAA;AAAA,QACpB;AAAA,UACE,CAAC,YAAA,CAAa,QAAQ,CAAC,GAAG,WAAA;AAAA,UAC1B,CAAC,aAAa,CAAS,MAAA,EAAA,UAAA,CAAW,eAAe,EAAE,CAAC,CAAE,CAAA,CAAC,GAAG,WAAA;AAAA,UAC1D,CAAC,YAAa,CAAA,QAAQ,CAAC,GAAG,SAAS,QAAY,IAAA,MAAA;AAAA,UAC/C,CAAC,YAAA,CAAa,UAAU,CAAC,GAAG,QAAA;AAAA,UAC5B,CAAC,YAAA,CAAa,UAAU,CAAC,GAAG;AAAA,SAC9B;AAAA,QACA;AAAA,OACF;AAAA,MACC,GAAG,IAAA;AAAA,MACJ,OAAS,EAAA,WAAA;AAAA,MACT,GAAK,EAAA,SAAA;AAAA,MACL,QAAA;AAAA,MAEC;AAAA;AAAA,GACH;AAEJ,CAAC;;;;"}
@@ -10,103 +10,8 @@ import { useForkRef } from '../utils/useForkRef.js';
10
10
  import '../utils/useId.js';
11
11
  import '../salt-provider/SaltProvider.js';
12
12
  import '../viewport/ViewportProvider.js';
13
- import '../accordion/AccordionGroup.js';
14
- import '../accordion/AccordionPanel.js';
15
- import '../accordion/Accordion.js';
16
- import '../accordion/AccordionHeader.js';
17
- import '../aria-announcer/AriaAnnouncerContext.js';
18
- import '../avatar/Avatar.js';
19
- import '../badge/Badge.js';
20
- import '../banner/Banner.js';
21
- import '../banner/BannerActions.js';
22
- import '../banner/BannerContent.js';
23
- import '../border-item/BorderItem.js';
24
- import '../border-layout/BorderLayout.js';
25
- import '../breakpoints/BreakpointProvider.js';
26
- import '../button/Button.js';
27
- import '../card/Card.js';
28
- import '../checkbox/Checkbox.js';
29
- import '../checkbox/CheckboxGroup.js';
30
- import '@salt-ds/icons';
31
- import '../combo-box/ComboBox.js';
32
- import '../dialog/Dialog.js';
33
- import '../dialog/DialogHeader.js';
34
- import '../dialog/DialogActions.js';
35
- import '../dialog/DialogContent.js';
36
- import '../dialog/DialogContext.js';
37
- import '../dialog/DialogCloseButton.js';
38
- import '../divider/Divider.js';
39
- import '../drawer/Drawer.js';
40
- import '../drawer/DrawerCloseButton.js';
41
- import '../dropdown/Dropdown.js';
42
- import '../file-drop-zone/FileDropZone.js';
43
- import '../file-drop-zone/FileDropZoneIcon.js';
44
- import '../file-drop-zone/FileDropZoneTrigger.js';
45
- import '../flex-item/FlexItem.js';
46
- import '../flex-layout/FlexLayout.js';
47
- import '../flow-layout/FlowLayout.js';
48
- import '../form-field/FormField.js';
49
- import '../form-field-context/FormFieldContext.js';
50
- import '../status-indicator/StatusIndicator.js';
51
- import '../text/Text.js';
52
- import '../text/Code.js';
53
- import '../text/Display.js';
54
- import '../text/Headings.js';
55
- import '../text/Label.js';
56
- import '../text/TextAction.js';
57
- import '../text/TextNotation.js';
58
- import '../grid-item/GridItem.js';
59
- import '../grid-layout/GridLayout.js';
60
- import '../input/Input.js';
61
- import './InteractableCard.js';
62
- import { InteractableCardGroupContext } from './InteractableCardGroupContext.js';
63
- import '../link/Link.js';
64
- import '../link-card/LinkCard.js';
65
- import '../list-box/ListBox.js';
66
- import '../list-control/ListControlContext.js';
67
- import '@floating-ui/react';
68
- import '../menu/MenuContext.js';
69
- import '../menu/MenuItem.js';
70
- import '../menu/MenuPanel.js';
71
- import '../menu/MenuPanelContext.js';
72
- import '../menu/MenuTriggerContext.js';
73
- import '../menu/MenuGroup.js';
74
- import '../multiline-input/MultilineInput.js';
75
- import '../navigation-item/NavigationItem.js';
76
- import '../option/Option.js';
77
- import '../option/OptionGroup.js';
78
- import '../overlay/OverlayContext.js';
79
- import '../overlay/OverlayPanel.js';
80
- import '../overlay/OverlayPanelCloseButton.js';
81
- import '../overlay/OverlayPanelContent.js';
82
- import '../pagination/Pagination.js';
83
- import '../pagination/Paginator.js';
84
- import '../pagination/CompactInput.js';
85
- import '../pagination/CompactPaginator.js';
86
- import '../pagination/GoToInput.js';
87
- import '../panel/Panel.js';
88
- import '../parent-child-layout/ParentChildLayout.js';
89
- import '../pill/Pill.js';
90
- import '../progress/CircularProgress/CircularProgress.js';
91
- import '../progress/LinearProgress/LinearProgress.js';
92
- import '../radio-button/RadioButton.js';
93
- import '../radio-button/RadioButtonGroup.js';
94
- import '../scrim/Scrim.js';
95
- import '../segmented-button-group/SegmentedButtonGroup.js';
96
- import '../spinner/Spinner.js';
97
- import '../stack-layout/StackLayout.js';
98
- import '../status-adornment/StatusAdornment.js';
99
- import '../toast/Toast.js';
100
- import '../toast/ToastContent.js';
101
- import '../split-layout/SplitLayout.js';
102
- import '../switch/Switch.js';
103
- import '../tag/Tag.js';
104
- import '../toggle-button/ToggleButton.js';
105
- import '../toggle-button-group/ToggleButtonGroup.js';
106
- import '../toggle-button-group/ToggleButtonGroupContext.js';
107
- import '../tooltip/Tooltip.js';
108
- import '../semantic-icon-provider/SemanticIconProvider.js';
109
13
  import css_248z from './InteractableCardGroup.css.js';
14
+ import { InteractableCardGroupContext } from './InteractableCardGroupContext.js';
110
15
 
111
16
  const withBaseName = makePrefixer("saltInteractableCardGroup");
112
17
  const InteractableCardGroup = forwardRef(function InteractableCardGroup2(props, ref) {
@@ -137,11 +42,11 @@ const InteractableCardGroup = forwardRef(function InteractableCardGroup2(props,
137
42
  });
138
43
  const [elements, setElements] = useState([]);
139
44
  useEffect(() => {
140
- var _a, _b;
45
+ var _a;
141
46
  const childElements = Array.from(
142
- (_b = (_a = groupRef.current) == null ? void 0 : _a.querySelectorAll(
47
+ ((_a = groupRef.current) == null ? void 0 : _a.querySelectorAll(
143
48
  ".saltInteractableCard:not([disabled])"
144
- )) != null ? _b : []
49
+ )) ?? []
145
50
  );
146
51
  setElements(childElements);
147
52
  }, [children]);
@@ -227,17 +132,17 @@ const InteractableCardGroup = forwardRef(function InteractableCardGroup2(props,
227
132
  }
228
133
  onKeyDown == null ? void 0 : onKeyDown(event);
229
134
  };
230
- return /* @__PURE__ */ jsx(InteractableCardGroupContext.Provider, {
231
- value: contextValue,
232
- children: /* @__PURE__ */ jsx("div", {
135
+ return /* @__PURE__ */ jsx(InteractableCardGroupContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsx(
136
+ "div",
137
+ {
233
138
  className: clsx(withBaseName(), className),
234
139
  role: multiSelect ? "group" : "radiogroup",
235
140
  onKeyDown: handleKeyDown,
236
141
  ref: handleRef,
237
142
  ...rest,
238
143
  children
239
- })
240
- });
144
+ }
145
+ ) });
241
146
  });
242
147
 
243
148
  export { 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":["InteractableCardGroup","interactableCardGroupCss","isSelected"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmDA,MAAM,YAAA,GAAe,aAAa,2BAA2B,CAAA,CAAA;AAEtD,MAAM,qBAAwB,GAAA,UAAA,CAGnC,SAASA,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,eAAe,SAAU,EAAA,CAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,8BAAA;AAAA,IACR,GAAK,EAAAC,QAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAM,MAAA,QAAA,GAAW,OAAuB,IAAI,CAAA,CAAA;AAC5C,EAAM,MAAA,SAAA,GAAY,UAAW,CAAA,GAAA,EAAK,QAAQ,CAAA,CAAA;AAE1C,EAAA,MAAM,CAAC,KAAA,EAAO,QAAQ,CAAA,GAAI,aAAc,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,GAAA,QAAA,CAAwB,EAAE,CAAA,CAAA;AAG1D,EAAA,SAAA,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,GAAA,WAAA;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,GAAA,WAAA;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,GAAA,WAAA;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,GAAA,OAAA;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,uBAAA,GAAA,CAAC,6BAA6B,QAA7B,EAAA;AAAA,IAAsC,KAAO,EAAA,YAAA;AAAA,IAC5C,QAAC,kBAAA,GAAA,CAAA,KAAA,EAAA;AAAA,MACC,SAAW,EAAA,IAAA,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":["InteractableCardGroup","interactableCardGroupCss","isSelected"],"mappings":";;;;;;;;;;;;;;;AAmDA,MAAM,YAAA,GAAe,aAAa,2BAA2B,CAAA;AAEtD,MAAM,qBAAwB,GAAA,UAAA,CAGnC,SAASA,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,IACA,GAAG;AAAA,GACD,GAAA,KAAA;AAEJ,EAAA,MAAM,eAAe,SAAU,EAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,8BAAA;AAAA,IACR,GAAK,EAAAC,QAAA;AAAA,IACL,MAAQ,EAAA;AAAA,GACT,CAAA;AAED,EAAM,MAAA,QAAA,GAAW,OAAuB,IAAI,CAAA;AAC5C,EAAM,MAAA,SAAA,GAAY,UAAW,CAAA,GAAA,EAAK,QAAQ,CAAA;AAE1C,EAAA,MAAM,CAAC,KAAA,EAAO,QAAQ,CAAA,GAAI,aAAc,CAAA;AAAA,IACtC,OAAS,EAAA,YAAA;AAAA,IACT,UAAY,EAAA,SAAA;AAAA,IACZ,IAAM,EAAA,uBAAA;AAAA,IACN,KAAO,EAAA;AAAA,GACR,CAAA;AAED,EAAA,MAAM,CAAC,QAAU,EAAA,WAAW,CAAI,GAAA,QAAA,CAAwB,EAAE,CAAA;AAG1D,EAAA,SAAA,CAAU,MAAM;AAzFlB,IAAA,IAAA,EAAA;AA0FI,IAAA,MAAM,gBAA+B,KAAM,CAAA,IAAA;AAAA,MACzC,CAAA,CAAA,EAAA,GAAA,QAAA,CAAS,YAAT,IAAkB,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,gBAAA;AAAA,QAChB;AAAA,OAAA,KACG;AAAC,KACR;AACA,IAAA,WAAA,CAAY,aAAa,CAAA;AAAA,GAC3B,EAAG,CAAC,QAAQ,CAAC,CAAA;AAEb,EAAA,MAAM,MAAS,GAAA,WAAA;AAAA,IACb,CACE,OACA,QACG,KAAA;AACH,MAAA,IAAI,WAAa,EAAA;AACf,QAAA,MAAM,gBAAgB,KAAM,CAAA,OAAA,CAAQ,KAAK,CAAA,GAAI,QAAQ,EAAC;AACtD,QAAMC,MAAAA,WAAAA,GAAa,aAAc,CAAA,QAAA,CAAS,QAAQ,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;AAC/B,QAAA,QAAA,CAAS,UAAU,CAAA;AACnB,QAAA,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAW,KAAO,EAAA,UAAA,CAAA;AAAA,OACb,MAAA;AACL,QAAA,QAAA,CAAS,QAAQ,CAAA;AACjB,QAAA,IAAI,UAAU,QAAU,EAAA;AACtB,UAAA,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAW,KAAO,EAAA,QAAA,CAAA;AAAA;AACpB;AACF,KACF;AAAA,IACA,CAAC,QAAU,EAAA,KAAA,EAAO,WAAW;AAAA,GAC/B;AAEA,EAAA,MAAM,UAAa,GAAA,WAAA;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;AAAA,GACrB;AAEA,EAAA,MAAM,YAAe,GAAA,WAAA;AAAA,IACnB,CAAC,SAAqC,KAAA;AACpC,MAAA,OACE,QAAS,CAAA,SAAA;AAAA,QACP,CAAC,OAAA,KAAY,OAAQ,CAAA,YAAA,CAAa,YAAY,CAAM,KAAA;AAAA,OAChD,KAAA,CAAA;AAAA,KAEV;AAAA,IACA,CAAC,QAAQ;AAAA,GACX;AAEA,EAAA,MAAM,YAAe,GAAA,OAAA;AAAA,IACnB,OAAO;AAAA,MACL,MAAA;AAAA,MACA,UAAA;AAAA,MACA,YAAA;AAAA,MACA,QAAA;AAAA,MACA,WAAA;AAAA,MACA;AAAA,KACF,CAAA;AAAA,IACA,CAAC,MAAQ,EAAA,UAAA,EAAY,QAAU,EAAA,WAAA,EAAa,cAAc,KAAK;AAAA,GACjE;AAEA,EAAM,MAAA,aAAA,GAAgB,CAAC,KAAyC,KAAA;AAzJlE,IAAA,IAAA,EAAA,EAAA,EAAA;AA0JI,IAAA,MAAM,eAAe,QAAS,CAAA,SAAA;AAAA,MAC5B,CAAC,OAAY,KAAA,OAAA,KAAY,QAAS,CAAA;AAAA,KACpC;AACA,IAAM,MAAA,SAAA,GAAA,CAAa,YAAe,GAAA,CAAA,IAAK,QAAS,CAAA,MAAA;AAChD,IAAA,MAAM,SAAa,GAAA,CAAA,YAAA,GAAe,CAAI,GAAA,QAAA,CAAS,UAAU,QAAS,CAAA,MAAA;AAElE,IAAI,IAAA,KAAA,CAAM,QAAQ,GAAK,EAAA;AACrB,MAAA,KAAA,CAAM,cAAe,EAAA;AACrB,MAAA,MAAA;AAAA,QACE,KAAA;AAAA,QACA,QAAA,CAAS,YAAY,CAAE,CAAA,YAAA;AAAA,UACrB;AAAA;AACF,OACF;AAAA;AAGF,IAAA,IAAI,CAAC,WAAa,EAAA;AAChB,MAAA,QAAQ,MAAM,GAAK;AAAA,QACjB,KAAK,WAAA;AAAA,QACL,KAAK,YAAA;AACH,UAAA,MAAA;AAAA,YACE,KAAA;AAAA,YACA,QAAA,CAAS,SAAS,CAAE,CAAA,YAAA;AAAA,cAClB;AAAA;AACF,WACF;AACA,UAAS,CAAA,EAAA,GAAA,QAAA,CAAA,SAAS,MAAlB,IAAqB,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,KAAA,EAAA;AACrB,UAAA;AAAA,QACF,KAAK,SAAA;AAAA,QACL,KAAK,WAAA;AACH,UAAA,MAAA;AAAA,YACE,KAAA;AAAA,YACA,QAAA,CAAS,SAAS,CAAE,CAAA,YAAA;AAAA,cAClB;AAAA;AACF,WACF;AACA,UAAS,CAAA,EAAA,GAAA,QAAA,CAAA,SAAS,MAAlB,IAAqB,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,KAAA,EAAA;AACrB,UAAA;AAAA;AACJ;AAEF,IAAY,SAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,SAAA,CAAA,KAAA,CAAA;AAAA,GACd;AAEA,EAAA,uBACG,GAAA,CAAA,4BAAA,CAA6B,QAA7B,EAAA,EAAsC,OAAO,YAC5C,EAAA,QAAA,kBAAA,GAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACC,SAAW,EAAA,IAAA,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;AAAA;AAAA,GAEL,EAAA,CAAA;AAEJ,CAAC;;;;"}
@@ -6,104 +6,6 @@ import '../utils/useFloatingUI/useFloatingUI.js';
6
6
  import '../utils/useId.js';
7
7
  import '../salt-provider/SaltProvider.js';
8
8
  import '../viewport/ViewportProvider.js';
9
- import '../accordion/AccordionGroup.js';
10
- import '../accordion/AccordionPanel.js';
11
- import '../accordion/Accordion.js';
12
- import '../accordion/AccordionHeader.js';
13
- import '../aria-announcer/AriaAnnouncerContext.js';
14
- import '../avatar/Avatar.js';
15
- import '../badge/Badge.js';
16
- import '../banner/Banner.js';
17
- import '../banner/BannerActions.js';
18
- import '../banner/BannerContent.js';
19
- import '../border-item/BorderItem.js';
20
- import '../border-layout/BorderLayout.js';
21
- import '../breakpoints/BreakpointProvider.js';
22
- import '../button/Button.js';
23
- import '../card/Card.js';
24
- import '../checkbox/Checkbox.js';
25
- import '../checkbox/CheckboxGroup.js';
26
- import '@salt-ds/icons';
27
- import '@salt-ds/styles';
28
- import '@salt-ds/window';
29
- import '../combo-box/ComboBox.js';
30
- import '../dialog/Dialog.js';
31
- import '../dialog/DialogHeader.js';
32
- import '../dialog/DialogActions.js';
33
- import '../dialog/DialogContent.js';
34
- import '../dialog/DialogContext.js';
35
- import '../dialog/DialogCloseButton.js';
36
- import '../divider/Divider.js';
37
- import '../drawer/Drawer.js';
38
- import '../drawer/DrawerCloseButton.js';
39
- import '../dropdown/Dropdown.js';
40
- import '../file-drop-zone/FileDropZone.js';
41
- import '../file-drop-zone/FileDropZoneIcon.js';
42
- import '../file-drop-zone/FileDropZoneTrigger.js';
43
- import '../flex-item/FlexItem.js';
44
- import '../flex-layout/FlexLayout.js';
45
- import '../flow-layout/FlowLayout.js';
46
- import '../form-field/FormField.js';
47
- import '../form-field-context/FormFieldContext.js';
48
- import '../status-indicator/StatusIndicator.js';
49
- import '../text/Text.js';
50
- import '../text/Code.js';
51
- import '../text/Display.js';
52
- import '../text/Headings.js';
53
- import '../text/Label.js';
54
- import '../text/TextAction.js';
55
- import '../text/TextNotation.js';
56
- import '../grid-item/GridItem.js';
57
- import '../grid-layout/GridLayout.js';
58
- import '../input/Input.js';
59
- import './InteractableCard.js';
60
- import './InteractableCardGroup.js';
61
- import '../link/Link.js';
62
- import '../link-card/LinkCard.js';
63
- import '../list-box/ListBox.js';
64
- import '../list-control/ListControlContext.js';
65
- import '@floating-ui/react';
66
- import '../menu/MenuContext.js';
67
- import '../menu/MenuItem.js';
68
- import '../menu/MenuPanel.js';
69
- import '../menu/MenuPanelContext.js';
70
- import '../menu/MenuTriggerContext.js';
71
- import '../menu/MenuGroup.js';
72
- import '../multiline-input/MultilineInput.js';
73
- import '../navigation-item/NavigationItem.js';
74
- import '../option/Option.js';
75
- import '../option/OptionGroup.js';
76
- import '../overlay/OverlayContext.js';
77
- import '../overlay/OverlayPanel.js';
78
- import '../overlay/OverlayPanelCloseButton.js';
79
- import '../overlay/OverlayPanelContent.js';
80
- import '../pagination/Pagination.js';
81
- import '../pagination/Paginator.js';
82
- import '../pagination/CompactInput.js';
83
- import '../pagination/CompactPaginator.js';
84
- import '../pagination/GoToInput.js';
85
- import '../panel/Panel.js';
86
- import '../parent-child-layout/ParentChildLayout.js';
87
- import '../pill/Pill.js';
88
- import '../progress/CircularProgress/CircularProgress.js';
89
- import '../progress/LinearProgress/LinearProgress.js';
90
- import '../radio-button/RadioButton.js';
91
- import '../radio-button/RadioButtonGroup.js';
92
- import '../scrim/Scrim.js';
93
- import '../segmented-button-group/SegmentedButtonGroup.js';
94
- import '../spinner/Spinner.js';
95
- import '../stack-layout/StackLayout.js';
96
- import '../status-adornment/StatusAdornment.js';
97
- import '../toast/Toast.js';
98
- import '../toast/ToastContent.js';
99
- import '../split-layout/SplitLayout.js';
100
- import '../switch/Switch.js';
101
- import '../tag/Tag.js';
102
- import '../toggle-button/ToggleButton.js';
103
- import '../toggle-button-group/ToggleButtonGroup.js';
104
- import '../toggle-button-group/ToggleButtonGroupContext.js';
105
- import '../tooltip/Tooltip.js';
106
- import '../semantic-icon-provider/SemanticIconProvider.js';
107
9
 
108
10
  const InteractableCardGroupContext = createContext("InteractableCardGroupContext", void 0);
109
11
  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":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiBa,MAAA,4BAAA,GAA+B,aAE1C,CAAA,8BAAA,EAAgC,KAAS,CAAA,EAAA;AAEpC,SAAS,wBAA2B,GAAA;AACzC,EAAA,OAAO,WAAW,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":[],"mappings":";;;;;;;;;AAiBa,MAAA,4BAAA,GAA+B,aAE1C,CAAA,8BAAA,EAAgC,KAAS,CAAA;AAEpC,SAAS,wBAA2B,GAAA;AACzC,EAAA,OAAO,WAAW,4BAA4B,CAAA;AAChD;;;;"}
@@ -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":[],"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;AACd,EAAA,MAAM,KAAQ,GAAA,GAAA,CAAA;AAEd,EAAA,SAAA,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":[],"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,GAAI,SAAS,EAAE,CAAA;AAC7C,EAAA,MAAM,CAAC,MAAA,EAAQ,SAAS,CAAA,GAAI,SAAS,KAAK,CAAA;AAE1C,EAAA,MAAM,KAAQ,GAAA,OAAA;AACd,EAAA,MAAM,KAAQ,GAAA,GAAA;AAEd,EAAA,SAAA,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;;;;"}