@salt-ds/core 1.28.1 → 1.30.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (516) hide show
  1. package/css/salt-core.css +332 -31
  2. package/dist-cjs/accordion/Accordion.js +3 -0
  3. package/dist-cjs/accordion/Accordion.js.map +1 -1
  4. package/dist-cjs/accordion/AccordionContext.js +3 -0
  5. package/dist-cjs/accordion/AccordionContext.js.map +1 -1
  6. package/dist-cjs/accordion/AccordionGroup.js +3 -0
  7. package/dist-cjs/accordion/AccordionGroup.js.map +1 -1
  8. package/dist-cjs/accordion/AccordionHeader.js +3 -0
  9. package/dist-cjs/accordion/AccordionHeader.js.map +1 -1
  10. package/dist-cjs/accordion/AccordionPanel.js +3 -0
  11. package/dist-cjs/accordion/AccordionPanel.js.map +1 -1
  12. package/dist-cjs/aria-announcer/useAriaAnnouncer.js +3 -0
  13. package/dist-cjs/aria-announcer/useAriaAnnouncer.js.map +1 -1
  14. package/dist-cjs/avatar/Avatar.js +3 -0
  15. package/dist-cjs/avatar/Avatar.js.map +1 -1
  16. package/dist-cjs/avatar/useAvatarImage.js +3 -0
  17. package/dist-cjs/avatar/useAvatarImage.js.map +1 -1
  18. package/dist-cjs/badge/Badge.js +3 -0
  19. package/dist-cjs/badge/Badge.js.map +1 -1
  20. package/dist-cjs/banner/Banner.js +3 -0
  21. package/dist-cjs/banner/Banner.js.map +1 -1
  22. package/dist-cjs/banner/BannerActions.js +3 -0
  23. package/dist-cjs/banner/BannerActions.js.map +1 -1
  24. package/dist-cjs/banner/BannerContent.js +3 -0
  25. package/dist-cjs/banner/BannerContent.js.map +1 -1
  26. package/dist-cjs/border-item/BorderItem.js +3 -0
  27. package/dist-cjs/border-item/BorderItem.js.map +1 -1
  28. package/dist-cjs/border-layout/BorderLayout.js +3 -0
  29. package/dist-cjs/border-layout/BorderLayout.js.map +1 -1
  30. package/dist-cjs/breakpoints/BreakpointProvider.js +3 -0
  31. package/dist-cjs/breakpoints/BreakpointProvider.js.map +1 -1
  32. package/dist-cjs/button/Button.css.js +1 -1
  33. package/dist-cjs/button/Button.js +3 -0
  34. package/dist-cjs/button/Button.js.map +1 -1
  35. package/dist-cjs/card/Card.js +3 -0
  36. package/dist-cjs/card/Card.js.map +1 -1
  37. package/dist-cjs/checkbox/Checkbox.js +3 -0
  38. package/dist-cjs/checkbox/Checkbox.js.map +1 -1
  39. package/dist-cjs/checkbox/CheckboxGroup.js +3 -0
  40. package/dist-cjs/checkbox/CheckboxGroup.js.map +1 -1
  41. package/dist-cjs/checkbox/CheckboxIcon.js +3 -0
  42. package/dist-cjs/checkbox/CheckboxIcon.js.map +1 -1
  43. package/dist-cjs/checkbox/internal/CheckboxGroupContext.js +3 -0
  44. package/dist-cjs/checkbox/internal/CheckboxGroupContext.js.map +1 -1
  45. package/dist-cjs/combo-box/ComboBox.js +28 -20
  46. package/dist-cjs/combo-box/ComboBox.js.map +1 -1
  47. package/dist-cjs/combo-box/useComboBox.js +5 -2
  48. package/dist-cjs/combo-box/useComboBox.js.map +1 -1
  49. package/dist-cjs/dialog/Dialog.js +3 -0
  50. package/dist-cjs/dialog/Dialog.js.map +1 -1
  51. package/dist-cjs/dialog/DialogActions.js +3 -0
  52. package/dist-cjs/dialog/DialogActions.js.map +1 -1
  53. package/dist-cjs/dialog/DialogCloseButton.js +3 -0
  54. package/dist-cjs/dialog/DialogCloseButton.js.map +1 -1
  55. package/dist-cjs/dialog/DialogContent.js +3 -0
  56. package/dist-cjs/dialog/DialogContent.js.map +1 -1
  57. package/dist-cjs/dialog/DialogHeader.js +3 -0
  58. package/dist-cjs/dialog/DialogHeader.js.map +1 -1
  59. package/dist-cjs/divider/Divider.css.js +6 -0
  60. package/dist-cjs/divider/Divider.css.js.map +1 -0
  61. package/dist-cjs/divider/Divider.js +143 -0
  62. package/dist-cjs/divider/Divider.js.map +1 -0
  63. package/dist-cjs/drawer/Drawer.js +3 -0
  64. package/dist-cjs/drawer/Drawer.js.map +1 -1
  65. package/dist-cjs/drawer/DrawerCloseButton.js +3 -0
  66. package/dist-cjs/drawer/DrawerCloseButton.js.map +1 -1
  67. package/dist-cjs/dropdown/Dropdown.css.js +1 -1
  68. package/dist-cjs/dropdown/Dropdown.js +23 -17
  69. package/dist-cjs/dropdown/Dropdown.js.map +1 -1
  70. package/dist-cjs/file-drop-zone/FileDropZone.js +3 -0
  71. package/dist-cjs/file-drop-zone/FileDropZone.js.map +1 -1
  72. package/dist-cjs/file-drop-zone/FileDropZoneTrigger.js +3 -0
  73. package/dist-cjs/file-drop-zone/FileDropZoneTrigger.js.map +1 -1
  74. package/dist-cjs/flex-item/FlexItem.js +3 -0
  75. package/dist-cjs/flex-item/FlexItem.js.map +1 -1
  76. package/dist-cjs/flex-layout/FlexLayout.js +3 -0
  77. package/dist-cjs/flex-layout/FlexLayout.js.map +1 -1
  78. package/dist-cjs/form-field/FormField.js +3 -0
  79. package/dist-cjs/form-field/FormField.js.map +1 -1
  80. package/dist-cjs/form-field/FormFieldHelperText.js +3 -0
  81. package/dist-cjs/form-field/FormFieldHelperText.js.map +1 -1
  82. package/dist-cjs/form-field/FormFieldLabel.js +3 -0
  83. package/dist-cjs/form-field/FormFieldLabel.js.map +1 -1
  84. package/dist-cjs/form-field-context/FormFieldContext.js +3 -0
  85. package/dist-cjs/form-field-context/FormFieldContext.js.map +1 -1
  86. package/dist-cjs/grid-item/GridItem.js +3 -0
  87. package/dist-cjs/grid-item/GridItem.js.map +1 -1
  88. package/dist-cjs/grid-layout/GridLayout.js +3 -0
  89. package/dist-cjs/grid-layout/GridLayout.js.map +1 -1
  90. package/dist-cjs/index.js +9 -0
  91. package/dist-cjs/index.js.map +1 -1
  92. package/dist-cjs/input/Input.css.js +1 -1
  93. package/dist-cjs/input/Input.js +7 -2
  94. package/dist-cjs/input/Input.js.map +1 -1
  95. package/dist-cjs/interactable-card/InteractableCard.js +3 -0
  96. package/dist-cjs/interactable-card/InteractableCard.js.map +1 -1
  97. package/dist-cjs/interactable-card/InteractableCardGroup.js +3 -0
  98. package/dist-cjs/interactable-card/InteractableCardGroup.js.map +1 -1
  99. package/dist-cjs/interactable-card/InteractableCardGroupContext.js +3 -0
  100. package/dist-cjs/interactable-card/InteractableCardGroupContext.js.map +1 -1
  101. package/dist-cjs/link/Link.js +3 -0
  102. package/dist-cjs/link/Link.js.map +1 -1
  103. package/dist-cjs/link-card/LinkCard.js +3 -0
  104. package/dist-cjs/link-card/LinkCard.js.map +1 -1
  105. package/dist-cjs/list-box/ListBox.css.js +6 -0
  106. package/dist-cjs/list-box/ListBox.css.js.map +1 -0
  107. package/dist-cjs/list-box/ListBox.js +295 -0
  108. package/dist-cjs/list-box/ListBox.js.map +1 -0
  109. package/dist-cjs/list-control/ListControlContext.js +5 -1
  110. package/dist-cjs/list-control/ListControlContext.js.map +1 -1
  111. package/dist-cjs/list-control/ListControlState.js +78 -11
  112. package/dist-cjs/list-control/ListControlState.js.map +1 -1
  113. package/dist-cjs/menu/MenuBase.js +3 -0
  114. package/dist-cjs/menu/MenuBase.js.map +1 -1
  115. package/dist-cjs/menu/MenuContext.js +3 -0
  116. package/dist-cjs/menu/MenuContext.js.map +1 -1
  117. package/dist-cjs/menu/MenuGroup.css.js +1 -1
  118. package/dist-cjs/menu/MenuGroup.js +3 -0
  119. package/dist-cjs/menu/MenuGroup.js.map +1 -1
  120. package/dist-cjs/menu/MenuItem.css.js +1 -1
  121. package/dist-cjs/menu/MenuItem.js +3 -0
  122. package/dist-cjs/menu/MenuItem.js.map +1 -1
  123. package/dist-cjs/menu/MenuPanel.js +3 -0
  124. package/dist-cjs/menu/MenuPanel.js.map +1 -1
  125. package/dist-cjs/menu/MenuPanelContext.js +3 -0
  126. package/dist-cjs/menu/MenuPanelContext.js.map +1 -1
  127. package/dist-cjs/menu/MenuTrigger.js +3 -0
  128. package/dist-cjs/menu/MenuTrigger.js.map +1 -1
  129. package/dist-cjs/menu/MenuTriggerContext.js +3 -0
  130. package/dist-cjs/menu/MenuTriggerContext.js.map +1 -1
  131. package/dist-cjs/multiline-input/MultilineInput.css.js +1 -1
  132. package/dist-cjs/multiline-input/MultilineInput.js +4 -1
  133. package/dist-cjs/multiline-input/MultilineInput.js.map +1 -1
  134. package/dist-cjs/navigation-item/NavigationItem.js +3 -0
  135. package/dist-cjs/navigation-item/NavigationItem.js.map +1 -1
  136. package/dist-cjs/option/Option.css.js +1 -1
  137. package/dist-cjs/option/Option.js +7 -2
  138. package/dist-cjs/option/Option.js.map +1 -1
  139. package/dist-cjs/option/OptionGroup.css.js +1 -1
  140. package/dist-cjs/option/OptionGroup.js +3 -0
  141. package/dist-cjs/option/OptionGroup.js.map +1 -1
  142. package/dist-cjs/option/OptionList.js +3 -0
  143. package/dist-cjs/option/OptionList.js.map +1 -1
  144. package/dist-cjs/option/OptionListBase.js +3 -0
  145. package/dist-cjs/option/OptionListBase.js.map +1 -1
  146. package/dist-cjs/overlay/Overlay.js +3 -0
  147. package/dist-cjs/overlay/Overlay.js.map +1 -1
  148. package/dist-cjs/overlay/OverlayContext.js +3 -0
  149. package/dist-cjs/overlay/OverlayContext.js.map +1 -1
  150. package/dist-cjs/overlay/OverlayPanel.js +3 -0
  151. package/dist-cjs/overlay/OverlayPanel.js.map +1 -1
  152. package/dist-cjs/overlay/OverlayPanelCloseButton.js +3 -0
  153. package/dist-cjs/overlay/OverlayPanelCloseButton.js.map +1 -1
  154. package/dist-cjs/overlay/OverlayPanelContent.js +3 -0
  155. package/dist-cjs/overlay/OverlayPanelContent.js.map +1 -1
  156. package/dist-cjs/overlay/OverlayTrigger.js +3 -0
  157. package/dist-cjs/overlay/OverlayTrigger.js.map +1 -1
  158. package/dist-cjs/pagination/CompactInput.js +3 -0
  159. package/dist-cjs/pagination/CompactInput.js.map +1 -1
  160. package/dist-cjs/pagination/CompactPaginator.js +3 -0
  161. package/dist-cjs/pagination/CompactPaginator.js.map +1 -1
  162. package/dist-cjs/pagination/GoToInput.js +3 -0
  163. package/dist-cjs/pagination/GoToInput.js.map +1 -1
  164. package/dist-cjs/pagination/PageButton.js +3 -0
  165. package/dist-cjs/pagination/PageButton.js.map +1 -1
  166. package/dist-cjs/pagination/PageRanges.js +3 -0
  167. package/dist-cjs/pagination/PageRanges.js.map +1 -1
  168. package/dist-cjs/pagination/Pagination.js +3 -0
  169. package/dist-cjs/pagination/Pagination.js.map +1 -1
  170. package/dist-cjs/pagination/Paginator.js +3 -0
  171. package/dist-cjs/pagination/Paginator.js.map +1 -1
  172. package/dist-cjs/panel/Panel.js +3 -0
  173. package/dist-cjs/panel/Panel.js.map +1 -1
  174. package/dist-cjs/parent-child-layout/ParentChildLayout.js +3 -0
  175. package/dist-cjs/parent-child-layout/ParentChildLayout.js.map +1 -1
  176. package/dist-cjs/parent-child-layout/useIsViewportLargerThanBreakpoint.js +3 -0
  177. package/dist-cjs/parent-child-layout/useIsViewportLargerThanBreakpoint.js.map +1 -1
  178. package/dist-cjs/pill/Pill.js +3 -0
  179. package/dist-cjs/pill/Pill.js.map +1 -1
  180. package/dist-cjs/pill-input/PillInput.js +3 -0
  181. package/dist-cjs/pill-input/PillInput.js.map +1 -1
  182. package/dist-cjs/progress/CircularProgress/CircularProgress.js +3 -0
  183. package/dist-cjs/progress/CircularProgress/CircularProgress.js.map +1 -1
  184. package/dist-cjs/progress/LinearProgress/LinearProgress.js +3 -0
  185. package/dist-cjs/progress/LinearProgress/LinearProgress.js.map +1 -1
  186. package/dist-cjs/radio-button/RadioButton.js +3 -0
  187. package/dist-cjs/radio-button/RadioButton.js.map +1 -1
  188. package/dist-cjs/radio-button/RadioButtonGroup.js +3 -0
  189. package/dist-cjs/radio-button/RadioButtonGroup.js.map +1 -1
  190. package/dist-cjs/radio-button/RadioButtonIcon.js +3 -0
  191. package/dist-cjs/radio-button/RadioButtonIcon.js.map +1 -1
  192. package/dist-cjs/radio-button/internal/RadioGroupContext.js +3 -0
  193. package/dist-cjs/radio-button/internal/RadioGroupContext.js.map +1 -1
  194. package/dist-cjs/salt-provider/SaltProvider.js +34 -10
  195. package/dist-cjs/salt-provider/SaltProvider.js.map +1 -1
  196. package/dist-cjs/scrim/Scrim.js +3 -0
  197. package/dist-cjs/scrim/Scrim.js.map +1 -1
  198. package/dist-cjs/segmented-button-group/SegmentedButtonGroup.css.js +1 -1
  199. package/dist-cjs/segmented-button-group/SegmentedButtonGroup.js +3 -0
  200. package/dist-cjs/segmented-button-group/SegmentedButtonGroup.js.map +1 -1
  201. package/dist-cjs/spinner/Spinner.js +3 -0
  202. package/dist-cjs/spinner/Spinner.js.map +1 -1
  203. package/dist-cjs/spinner/svgSpinners/SpinnerSVG.js +3 -0
  204. package/dist-cjs/spinner/svgSpinners/SpinnerSVG.js.map +1 -1
  205. package/dist-cjs/split-layout/SplitLayout.js +3 -0
  206. package/dist-cjs/split-layout/SplitLayout.js.map +1 -1
  207. package/dist-cjs/stack-layout/StackLayout.js +3 -0
  208. package/dist-cjs/stack-layout/StackLayout.js.map +1 -1
  209. package/dist-cjs/status-adornment/StatusAdornment.js +3 -0
  210. package/dist-cjs/status-adornment/StatusAdornment.js.map +1 -1
  211. package/dist-cjs/status-indicator/StatusIndicator.js +3 -0
  212. package/dist-cjs/status-indicator/StatusIndicator.js.map +1 -1
  213. package/dist-cjs/switch/Switch.js +4 -1
  214. package/dist-cjs/switch/Switch.js.map +1 -1
  215. package/dist-cjs/tag/Tag.css.js +6 -0
  216. package/dist-cjs/tag/Tag.css.js.map +1 -0
  217. package/dist-cjs/tag/Tag.js +137 -0
  218. package/dist-cjs/tag/Tag.js.map +1 -0
  219. package/dist-cjs/text/Display.js +10 -0
  220. package/dist-cjs/text/Display.js.map +1 -1
  221. package/dist-cjs/text/Text.css.js +1 -1
  222. package/dist-cjs/text/Text.js +3 -0
  223. package/dist-cjs/text/Text.js.map +1 -1
  224. package/dist-cjs/theme/ActionFont.js +8 -0
  225. package/dist-cjs/theme/ActionFont.js.map +1 -0
  226. package/dist-cjs/toast/Toast.css.js +1 -1
  227. package/dist-cjs/toast/Toast.js +9 -4
  228. package/dist-cjs/toast/Toast.js.map +1 -1
  229. package/dist-cjs/toast/ToastContent.js +3 -0
  230. package/dist-cjs/toast/ToastContent.js.map +1 -1
  231. package/dist-cjs/toggle-button/ToggleButton.css.js +1 -1
  232. package/dist-cjs/toggle-button/ToggleButton.js +3 -0
  233. package/dist-cjs/toggle-button/ToggleButton.js.map +1 -1
  234. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js +3 -0
  235. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js.map +1 -1
  236. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js +3 -0
  237. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js.map +1 -1
  238. package/dist-cjs/tooltip/Tooltip.js +3 -0
  239. package/dist-cjs/tooltip/Tooltip.js.map +1 -1
  240. package/dist-cjs/tooltip/TooltipBase.js +3 -0
  241. package/dist-cjs/tooltip/TooltipBase.js.map +1 -1
  242. package/dist-cjs/tooltip/useAriaAnnounce.js +3 -0
  243. package/dist-cjs/tooltip/useAriaAnnounce.js.map +1 -1
  244. package/dist-cjs/tooltip/useTooltip.js +3 -0
  245. package/dist-cjs/tooltip/useTooltip.js.map +1 -1
  246. package/dist-cjs/utils/useValueEffect.js +3 -0
  247. package/dist-cjs/utils/useValueEffect.js.map +1 -1
  248. package/dist-cjs/viewport/ViewportProvider.js +3 -0
  249. package/dist-cjs/viewport/ViewportProvider.js.map +1 -1
  250. package/dist-es/accordion/Accordion.js +3 -0
  251. package/dist-es/accordion/Accordion.js.map +1 -1
  252. package/dist-es/accordion/AccordionContext.js +3 -0
  253. package/dist-es/accordion/AccordionContext.js.map +1 -1
  254. package/dist-es/accordion/AccordionGroup.js +3 -0
  255. package/dist-es/accordion/AccordionGroup.js.map +1 -1
  256. package/dist-es/accordion/AccordionHeader.js +3 -0
  257. package/dist-es/accordion/AccordionHeader.js.map +1 -1
  258. package/dist-es/accordion/AccordionPanel.js +3 -0
  259. package/dist-es/accordion/AccordionPanel.js.map +1 -1
  260. package/dist-es/aria-announcer/useAriaAnnouncer.js +3 -0
  261. package/dist-es/aria-announcer/useAriaAnnouncer.js.map +1 -1
  262. package/dist-es/avatar/Avatar.js +3 -0
  263. package/dist-es/avatar/Avatar.js.map +1 -1
  264. package/dist-es/avatar/useAvatarImage.js +3 -0
  265. package/dist-es/avatar/useAvatarImage.js.map +1 -1
  266. package/dist-es/badge/Badge.js +3 -0
  267. package/dist-es/badge/Badge.js.map +1 -1
  268. package/dist-es/banner/Banner.js +3 -0
  269. package/dist-es/banner/Banner.js.map +1 -1
  270. package/dist-es/banner/BannerActions.js +3 -0
  271. package/dist-es/banner/BannerActions.js.map +1 -1
  272. package/dist-es/banner/BannerContent.js +3 -0
  273. package/dist-es/banner/BannerContent.js.map +1 -1
  274. package/dist-es/border-item/BorderItem.js +3 -0
  275. package/dist-es/border-item/BorderItem.js.map +1 -1
  276. package/dist-es/border-layout/BorderLayout.js +3 -0
  277. package/dist-es/border-layout/BorderLayout.js.map +1 -1
  278. package/dist-es/breakpoints/BreakpointProvider.js +3 -0
  279. package/dist-es/breakpoints/BreakpointProvider.js.map +1 -1
  280. package/dist-es/button/Button.css.js +1 -1
  281. package/dist-es/button/Button.js +3 -0
  282. package/dist-es/button/Button.js.map +1 -1
  283. package/dist-es/card/Card.js +3 -0
  284. package/dist-es/card/Card.js.map +1 -1
  285. package/dist-es/checkbox/Checkbox.js +3 -0
  286. package/dist-es/checkbox/Checkbox.js.map +1 -1
  287. package/dist-es/checkbox/CheckboxGroup.js +3 -0
  288. package/dist-es/checkbox/CheckboxGroup.js.map +1 -1
  289. package/dist-es/checkbox/CheckboxIcon.js +3 -0
  290. package/dist-es/checkbox/CheckboxIcon.js.map +1 -1
  291. package/dist-es/checkbox/internal/CheckboxGroupContext.js +3 -0
  292. package/dist-es/checkbox/internal/CheckboxGroupContext.js.map +1 -1
  293. package/dist-es/combo-box/ComboBox.js +28 -20
  294. package/dist-es/combo-box/ComboBox.js.map +1 -1
  295. package/dist-es/combo-box/useComboBox.js +5 -2
  296. package/dist-es/combo-box/useComboBox.js.map +1 -1
  297. package/dist-es/dialog/Dialog.js +3 -0
  298. package/dist-es/dialog/Dialog.js.map +1 -1
  299. package/dist-es/dialog/DialogActions.js +3 -0
  300. package/dist-es/dialog/DialogActions.js.map +1 -1
  301. package/dist-es/dialog/DialogCloseButton.js +3 -0
  302. package/dist-es/dialog/DialogCloseButton.js.map +1 -1
  303. package/dist-es/dialog/DialogContent.js +3 -0
  304. package/dist-es/dialog/DialogContent.js.map +1 -1
  305. package/dist-es/dialog/DialogHeader.js +3 -0
  306. package/dist-es/dialog/DialogHeader.js.map +1 -1
  307. package/dist-es/divider/Divider.css.js +4 -0
  308. package/dist-es/divider/Divider.css.js.map +1 -0
  309. package/dist-es/divider/Divider.js +139 -0
  310. package/dist-es/divider/Divider.js.map +1 -0
  311. package/dist-es/drawer/Drawer.js +3 -0
  312. package/dist-es/drawer/Drawer.js.map +1 -1
  313. package/dist-es/drawer/DrawerCloseButton.js +3 -0
  314. package/dist-es/drawer/DrawerCloseButton.js.map +1 -1
  315. package/dist-es/dropdown/Dropdown.css.js +1 -1
  316. package/dist-es/dropdown/Dropdown.js +24 -18
  317. package/dist-es/dropdown/Dropdown.js.map +1 -1
  318. package/dist-es/file-drop-zone/FileDropZone.js +3 -0
  319. package/dist-es/file-drop-zone/FileDropZone.js.map +1 -1
  320. package/dist-es/file-drop-zone/FileDropZoneTrigger.js +3 -0
  321. package/dist-es/file-drop-zone/FileDropZoneTrigger.js.map +1 -1
  322. package/dist-es/flex-item/FlexItem.js +3 -0
  323. package/dist-es/flex-item/FlexItem.js.map +1 -1
  324. package/dist-es/flex-layout/FlexLayout.js +3 -0
  325. package/dist-es/flex-layout/FlexLayout.js.map +1 -1
  326. package/dist-es/form-field/FormField.js +3 -0
  327. package/dist-es/form-field/FormField.js.map +1 -1
  328. package/dist-es/form-field/FormFieldHelperText.js +3 -0
  329. package/dist-es/form-field/FormFieldHelperText.js.map +1 -1
  330. package/dist-es/form-field/FormFieldLabel.js +3 -0
  331. package/dist-es/form-field/FormFieldLabel.js.map +1 -1
  332. package/dist-es/form-field-context/FormFieldContext.js +3 -0
  333. package/dist-es/form-field-context/FormFieldContext.js.map +1 -1
  334. package/dist-es/grid-item/GridItem.js +3 -0
  335. package/dist-es/grid-item/GridItem.js.map +1 -1
  336. package/dist-es/grid-layout/GridLayout.js +3 -0
  337. package/dist-es/grid-layout/GridLayout.js.map +1 -1
  338. package/dist-es/index.js +5 -1
  339. package/dist-es/index.js.map +1 -1
  340. package/dist-es/input/Input.css.js +1 -1
  341. package/dist-es/input/Input.js +7 -2
  342. package/dist-es/input/Input.js.map +1 -1
  343. package/dist-es/interactable-card/InteractableCard.js +3 -0
  344. package/dist-es/interactable-card/InteractableCard.js.map +1 -1
  345. package/dist-es/interactable-card/InteractableCardGroup.js +3 -0
  346. package/dist-es/interactable-card/InteractableCardGroup.js.map +1 -1
  347. package/dist-es/interactable-card/InteractableCardGroupContext.js +3 -0
  348. package/dist-es/interactable-card/InteractableCardGroupContext.js.map +1 -1
  349. package/dist-es/link/Link.js +3 -0
  350. package/dist-es/link/Link.js.map +1 -1
  351. package/dist-es/link-card/LinkCard.js +3 -0
  352. package/dist-es/link-card/LinkCard.js.map +1 -1
  353. package/dist-es/list-box/ListBox.css.js +4 -0
  354. package/dist-es/list-box/ListBox.css.js.map +1 -0
  355. package/dist-es/list-box/ListBox.js +291 -0
  356. package/dist-es/list-box/ListBox.js.map +1 -0
  357. package/dist-es/list-control/ListControlContext.js +5 -1
  358. package/dist-es/list-control/ListControlContext.js.map +1 -1
  359. package/dist-es/list-control/ListControlState.js +79 -12
  360. package/dist-es/list-control/ListControlState.js.map +1 -1
  361. package/dist-es/menu/MenuBase.js +3 -0
  362. package/dist-es/menu/MenuBase.js.map +1 -1
  363. package/dist-es/menu/MenuContext.js +3 -0
  364. package/dist-es/menu/MenuContext.js.map +1 -1
  365. package/dist-es/menu/MenuGroup.css.js +1 -1
  366. package/dist-es/menu/MenuGroup.js +3 -0
  367. package/dist-es/menu/MenuGroup.js.map +1 -1
  368. package/dist-es/menu/MenuItem.css.js +1 -1
  369. package/dist-es/menu/MenuItem.js +3 -0
  370. package/dist-es/menu/MenuItem.js.map +1 -1
  371. package/dist-es/menu/MenuPanel.js +3 -0
  372. package/dist-es/menu/MenuPanel.js.map +1 -1
  373. package/dist-es/menu/MenuPanelContext.js +3 -0
  374. package/dist-es/menu/MenuPanelContext.js.map +1 -1
  375. package/dist-es/menu/MenuTrigger.js +3 -0
  376. package/dist-es/menu/MenuTrigger.js.map +1 -1
  377. package/dist-es/menu/MenuTriggerContext.js +3 -0
  378. package/dist-es/menu/MenuTriggerContext.js.map +1 -1
  379. package/dist-es/multiline-input/MultilineInput.css.js +1 -1
  380. package/dist-es/multiline-input/MultilineInput.js +4 -1
  381. package/dist-es/multiline-input/MultilineInput.js.map +1 -1
  382. package/dist-es/navigation-item/NavigationItem.js +3 -0
  383. package/dist-es/navigation-item/NavigationItem.js.map +1 -1
  384. package/dist-es/option/Option.css.js +1 -1
  385. package/dist-es/option/Option.js +7 -2
  386. package/dist-es/option/Option.js.map +1 -1
  387. package/dist-es/option/OptionGroup.css.js +1 -1
  388. package/dist-es/option/OptionGroup.js +3 -0
  389. package/dist-es/option/OptionGroup.js.map +1 -1
  390. package/dist-es/option/OptionList.js +3 -0
  391. package/dist-es/option/OptionList.js.map +1 -1
  392. package/dist-es/option/OptionListBase.js +3 -0
  393. package/dist-es/option/OptionListBase.js.map +1 -1
  394. package/dist-es/overlay/Overlay.js +3 -0
  395. package/dist-es/overlay/Overlay.js.map +1 -1
  396. package/dist-es/overlay/OverlayContext.js +3 -0
  397. package/dist-es/overlay/OverlayContext.js.map +1 -1
  398. package/dist-es/overlay/OverlayPanel.js +3 -0
  399. package/dist-es/overlay/OverlayPanel.js.map +1 -1
  400. package/dist-es/overlay/OverlayPanelCloseButton.js +3 -0
  401. package/dist-es/overlay/OverlayPanelCloseButton.js.map +1 -1
  402. package/dist-es/overlay/OverlayPanelContent.js +3 -0
  403. package/dist-es/overlay/OverlayPanelContent.js.map +1 -1
  404. package/dist-es/overlay/OverlayTrigger.js +3 -0
  405. package/dist-es/overlay/OverlayTrigger.js.map +1 -1
  406. package/dist-es/pagination/CompactInput.js +3 -0
  407. package/dist-es/pagination/CompactInput.js.map +1 -1
  408. package/dist-es/pagination/CompactPaginator.js +3 -0
  409. package/dist-es/pagination/CompactPaginator.js.map +1 -1
  410. package/dist-es/pagination/GoToInput.js +3 -0
  411. package/dist-es/pagination/GoToInput.js.map +1 -1
  412. package/dist-es/pagination/PageButton.js +3 -0
  413. package/dist-es/pagination/PageButton.js.map +1 -1
  414. package/dist-es/pagination/PageRanges.js +3 -0
  415. package/dist-es/pagination/PageRanges.js.map +1 -1
  416. package/dist-es/pagination/Pagination.js +3 -0
  417. package/dist-es/pagination/Pagination.js.map +1 -1
  418. package/dist-es/pagination/Paginator.js +3 -0
  419. package/dist-es/pagination/Paginator.js.map +1 -1
  420. package/dist-es/panel/Panel.js +3 -0
  421. package/dist-es/panel/Panel.js.map +1 -1
  422. package/dist-es/parent-child-layout/ParentChildLayout.js +3 -0
  423. package/dist-es/parent-child-layout/ParentChildLayout.js.map +1 -1
  424. package/dist-es/parent-child-layout/useIsViewportLargerThanBreakpoint.js +3 -0
  425. package/dist-es/parent-child-layout/useIsViewportLargerThanBreakpoint.js.map +1 -1
  426. package/dist-es/pill/Pill.js +3 -0
  427. package/dist-es/pill/Pill.js.map +1 -1
  428. package/dist-es/pill-input/PillInput.js +3 -0
  429. package/dist-es/pill-input/PillInput.js.map +1 -1
  430. package/dist-es/progress/CircularProgress/CircularProgress.js +3 -0
  431. package/dist-es/progress/CircularProgress/CircularProgress.js.map +1 -1
  432. package/dist-es/progress/LinearProgress/LinearProgress.js +3 -0
  433. package/dist-es/progress/LinearProgress/LinearProgress.js.map +1 -1
  434. package/dist-es/radio-button/RadioButton.js +3 -0
  435. package/dist-es/radio-button/RadioButton.js.map +1 -1
  436. package/dist-es/radio-button/RadioButtonGroup.js +3 -0
  437. package/dist-es/radio-button/RadioButtonGroup.js.map +1 -1
  438. package/dist-es/radio-button/RadioButtonIcon.js +3 -0
  439. package/dist-es/radio-button/RadioButtonIcon.js.map +1 -1
  440. package/dist-es/radio-button/internal/RadioGroupContext.js +3 -0
  441. package/dist-es/radio-button/internal/RadioGroupContext.js.map +1 -1
  442. package/dist-es/salt-provider/SaltProvider.js +34 -10
  443. package/dist-es/salt-provider/SaltProvider.js.map +1 -1
  444. package/dist-es/scrim/Scrim.js +3 -0
  445. package/dist-es/scrim/Scrim.js.map +1 -1
  446. package/dist-es/segmented-button-group/SegmentedButtonGroup.css.js +1 -1
  447. package/dist-es/segmented-button-group/SegmentedButtonGroup.js +3 -0
  448. package/dist-es/segmented-button-group/SegmentedButtonGroup.js.map +1 -1
  449. package/dist-es/spinner/Spinner.js +3 -0
  450. package/dist-es/spinner/Spinner.js.map +1 -1
  451. package/dist-es/spinner/svgSpinners/SpinnerSVG.js +3 -0
  452. package/dist-es/spinner/svgSpinners/SpinnerSVG.js.map +1 -1
  453. package/dist-es/split-layout/SplitLayout.js +3 -0
  454. package/dist-es/split-layout/SplitLayout.js.map +1 -1
  455. package/dist-es/stack-layout/StackLayout.js +3 -0
  456. package/dist-es/stack-layout/StackLayout.js.map +1 -1
  457. package/dist-es/status-adornment/StatusAdornment.js +3 -0
  458. package/dist-es/status-adornment/StatusAdornment.js.map +1 -1
  459. package/dist-es/status-indicator/StatusIndicator.js +3 -0
  460. package/dist-es/status-indicator/StatusIndicator.js.map +1 -1
  461. package/dist-es/switch/Switch.js +4 -1
  462. package/dist-es/switch/Switch.js.map +1 -1
  463. package/dist-es/tag/Tag.css.js +4 -0
  464. package/dist-es/tag/Tag.css.js.map +1 -0
  465. package/dist-es/tag/Tag.js +133 -0
  466. package/dist-es/tag/Tag.js.map +1 -0
  467. package/dist-es/text/Display.js +10 -1
  468. package/dist-es/text/Display.js.map +1 -1
  469. package/dist-es/text/Text.css.js +1 -1
  470. package/dist-es/text/Text.js +3 -0
  471. package/dist-es/text/Text.js.map +1 -1
  472. package/dist-es/theme/ActionFont.js +4 -0
  473. package/dist-es/theme/ActionFont.js.map +1 -0
  474. package/dist-es/toast/Toast.css.js +1 -1
  475. package/dist-es/toast/Toast.js +9 -4
  476. package/dist-es/toast/Toast.js.map +1 -1
  477. package/dist-es/toast/ToastContent.js +3 -0
  478. package/dist-es/toast/ToastContent.js.map +1 -1
  479. package/dist-es/toggle-button/ToggleButton.css.js +1 -1
  480. package/dist-es/toggle-button/ToggleButton.js +3 -0
  481. package/dist-es/toggle-button/ToggleButton.js.map +1 -1
  482. package/dist-es/toggle-button-group/ToggleButtonGroup.js +3 -0
  483. package/dist-es/toggle-button-group/ToggleButtonGroup.js.map +1 -1
  484. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js +3 -0
  485. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js.map +1 -1
  486. package/dist-es/tooltip/Tooltip.js +3 -0
  487. package/dist-es/tooltip/Tooltip.js.map +1 -1
  488. package/dist-es/tooltip/TooltipBase.js +3 -0
  489. package/dist-es/tooltip/TooltipBase.js.map +1 -1
  490. package/dist-es/tooltip/useAriaAnnounce.js +3 -0
  491. package/dist-es/tooltip/useAriaAnnounce.js.map +1 -1
  492. package/dist-es/tooltip/useTooltip.js +3 -0
  493. package/dist-es/tooltip/useTooltip.js.map +1 -1
  494. package/dist-es/utils/useValueEffect.js +3 -0
  495. package/dist-es/utils/useValueEffect.js.map +1 -1
  496. package/dist-es/viewport/ViewportProvider.js +3 -0
  497. package/dist-es/viewport/ViewportProvider.js.map +1 -1
  498. package/dist-types/combo-box/ComboBox.d.ts +8 -0
  499. package/dist-types/combo-box/useComboBox.d.ts +33 -2
  500. package/dist-types/divider/Divider.d.ts +12 -0
  501. package/dist-types/divider/index.d.ts +1 -0
  502. package/dist-types/index.d.ts +4 -1
  503. package/dist-types/input/Input.d.ts +3 -0
  504. package/dist-types/list-box/ListBox.d.ts +40 -0
  505. package/dist-types/list-box/index.d.ts +1 -0
  506. package/dist-types/list-control/ListControlContext.d.ts +1 -0
  507. package/dist-types/list-control/ListControlState.d.ts +33 -2
  508. package/dist-types/salt-provider/SaltProvider.d.ts +3 -1
  509. package/dist-types/tag/Tag.d.ts +16 -0
  510. package/dist-types/tag/index.d.ts +1 -0
  511. package/dist-types/text/Display.d.ts +1 -0
  512. package/dist-types/text/Text.d.ts +1 -1
  513. package/dist-types/theme/ActionFont.d.ts +2 -0
  514. package/dist-types/theme/index.d.ts +1 -0
  515. package/dist-types/toast/Toast.d.ts +6 -1
  516. package/package.json +2 -2
@@ -1 +1 @@
1
- {"version":3,"file":"InteractableCardGroup.js","sources":["../src/interactable-card/InteractableCardGroup.tsx"],"sourcesContent":["import {\n ComponentPropsWithoutRef,\n forwardRef,\n KeyboardEvent,\n SyntheticEvent,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { clsx } from \"clsx\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport { makePrefixer, useControlled, useForkRef } from \"../utils\";\nimport {\n InteractableCardGroupContext,\n InteractableCardValue,\n} from \"./InteractableCardGroupContext\";\nimport interactableCardGroupCss from \"./InteractableCardGroup.css\";\n\nexport interface InteractableCardGroupProps\n extends Omit<ComponentPropsWithoutRef<\"div\">, \"onChange\"> {\n /**\n * The default value. Use when the component is not controlled. Should be an array when `multiSelect` is true.\n */\n defaultValue?: InteractableCardValue;\n /**\n * If `true`, the Interactable Card Group will be disabled.\n */\n disabled?: boolean;\n /**\n * The value. Use when the component is controlled. Should be an array when `multiSelect` is true.\n */\n value?: InteractableCardValue;\n /**\n * If `true` the Interactable Card Group will allow multiple selection functionality, with keyboard interactions matching those of a checkbox.\n * By default the group allows mutually exclusive selection with keyboard interactions matching radio buttons.\n */\n multiSelect?: boolean;\n /**\n * Callback fired when the selection changes.\n * @param event\n */\n onChange?: (\n event: SyntheticEvent<HTMLDivElement>,\n value: InteractableCardValue\n ) => void;\n}\n\nconst withBaseName = makePrefixer(\"saltInteractableCardGroup\");\n\nexport const InteractableCardGroup = forwardRef<\n HTMLDivElement,\n InteractableCardGroupProps\n>(function InteractableCardGroup(props, ref) {\n const {\n children,\n className,\n value: valueProp,\n defaultValue,\n disabled,\n onChange,\n onKeyDown,\n multiSelect,\n ...rest\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-interactable-card-group\",\n css: interactableCardGroupCss,\n window: targetWindow,\n });\n\n const groupRef = useRef<HTMLDivElement>(null);\n const handleRef = useForkRef(ref, groupRef);\n\n const [value, setValue] = useControlled({\n default: defaultValue,\n controlled: valueProp,\n name: \"InteractableCardGroup\",\n state: \"value\",\n });\n\n const [elements, setElements] = useState<HTMLElement[]>([]);\n\n useEffect(() => {\n const childElements: HTMLElement[] = Array.from(\n groupRef.current?.querySelectorAll(\n \".saltInteractableCard:not([disabled])\"\n ) ?? []\n );\n setElements(childElements);\n }, [children]);\n\n const select = useCallback(\n (\n event: SyntheticEvent<HTMLDivElement>,\n newValue: InteractableCardValue\n ) => {\n if (multiSelect) {\n const currentValues = Array.isArray(value) ? value : [];\n const isSelected = currentValues.includes(newValue);\n\n const nextValues = isSelected\n ? currentValues.filter((val) => val !== newValue)\n : [...currentValues, newValue];\n setValue(nextValues);\n onChange?.(event, nextValues);\n } else {\n setValue(newValue);\n if (value !== newValue) {\n onChange?.(event, newValue);\n }\n }\n },\n [onChange, value, setValue, multiSelect]\n );\n\n const isSelected = useCallback(\n (cardValue: InteractableCardValue) =>\n multiSelect\n ? Array.isArray(value) && value.includes(cardValue)\n : cardValue !== undefined && value === cardValue,\n [value, multiSelect]\n );\n\n const isFirstChild = useCallback(\n (cardValue: InteractableCardValue) => {\n return (\n elements.findIndex(\n (element) => element.getAttribute(\"data-value\") === cardValue\n ) === 0\n );\n },\n [elements]\n );\n\n const contextValue = useMemo(\n () => ({\n select,\n isSelected,\n isFirstChild,\n disabled,\n multiSelect,\n value,\n }),\n [select, isSelected, disabled, multiSelect, isFirstChild, value]\n );\n\n const handleKeyDown = (event: KeyboardEvent<HTMLDivElement>) => {\n const currentIndex = elements.findIndex(\n (element) => element === document.activeElement\n );\n const nextIndex = (currentIndex + 1) % elements.length;\n const prevIndex = (currentIndex - 1 + elements.length) % elements.length;\n\n if (event.key == \" \") {\n event.preventDefault();\n select(\n event,\n elements[currentIndex].getAttribute(\n \"data-value\"\n ) as InteractableCardValue\n );\n }\n\n if (!multiSelect) {\n switch (event.key) {\n case \"ArrowDown\":\n case \"ArrowRight\":\n const nextValue = elements[nextIndex].getAttribute(\n \"data-value\"\n ) as InteractableCardValue;\n select(event, nextValue);\n elements[nextIndex]?.focus();\n break;\n case \"ArrowUp\":\n case \"ArrowLeft\":\n const prevValue = elements[prevIndex].getAttribute(\n \"data-value\"\n ) as InteractableCardValue;\n select(event, prevValue);\n elements[prevIndex]?.focus();\n break;\n }\n }\n onKeyDown?.(event);\n };\n\n return (\n <InteractableCardGroupContext.Provider value={contextValue}>\n <div\n className={clsx(withBaseName(), className)}\n role={multiSelect ? \"group\" : \"radiogroup\"}\n onKeyDown={handleKeyDown}\n ref={handleRef}\n {...rest}\n >\n {children}\n </div>\n </InteractableCardGroupContext.Provider>\n );\n});\n"],"names":["makePrefixer","forwardRef","InteractableCardGroup","useWindow","useComponentCssInjection","interactableCardGroupCss","useRef","useForkRef","useControlled","useState","useEffect","useCallback","isSelected","useMemo","jsx","InteractableCardGroupContext","clsx"],"mappings":"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"}
1
+ {"version":3,"file":"InteractableCardGroup.js","sources":["../src/interactable-card/InteractableCardGroup.tsx"],"sourcesContent":["import {\n ComponentPropsWithoutRef,\n forwardRef,\n KeyboardEvent,\n SyntheticEvent,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { clsx } from \"clsx\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport { makePrefixer, useControlled, useForkRef } from \"../utils\";\nimport {\n InteractableCardGroupContext,\n InteractableCardValue,\n} from \"./InteractableCardGroupContext\";\nimport interactableCardGroupCss from \"./InteractableCardGroup.css\";\n\nexport interface InteractableCardGroupProps\n extends Omit<ComponentPropsWithoutRef<\"div\">, \"onChange\"> {\n /**\n * The default value. Use when the component is not controlled. Should be an array when `multiSelect` is true.\n */\n defaultValue?: InteractableCardValue;\n /**\n * If `true`, the Interactable Card Group will be disabled.\n */\n disabled?: boolean;\n /**\n * The value. Use when the component is controlled. Should be an array when `multiSelect` is true.\n */\n value?: InteractableCardValue;\n /**\n * If `true` the Interactable Card Group will allow multiple selection functionality, with keyboard interactions matching those of a checkbox.\n * By default the group allows mutually exclusive selection with keyboard interactions matching radio buttons.\n */\n multiSelect?: boolean;\n /**\n * Callback fired when the selection changes.\n * @param event\n */\n onChange?: (\n event: SyntheticEvent<HTMLDivElement>,\n value: InteractableCardValue\n ) => void;\n}\n\nconst withBaseName = makePrefixer(\"saltInteractableCardGroup\");\n\nexport const InteractableCardGroup = forwardRef<\n HTMLDivElement,\n InteractableCardGroupProps\n>(function InteractableCardGroup(props, ref) {\n const {\n children,\n className,\n value: valueProp,\n defaultValue,\n disabled,\n onChange,\n onKeyDown,\n multiSelect,\n ...rest\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-interactable-card-group\",\n css: interactableCardGroupCss,\n window: targetWindow,\n });\n\n const groupRef = useRef<HTMLDivElement>(null);\n const handleRef = useForkRef(ref, groupRef);\n\n const [value, setValue] = useControlled({\n default: defaultValue,\n controlled: valueProp,\n name: \"InteractableCardGroup\",\n state: \"value\",\n });\n\n const [elements, setElements] = useState<HTMLElement[]>([]);\n\n useEffect(() => {\n const childElements: HTMLElement[] = Array.from(\n groupRef.current?.querySelectorAll(\n \".saltInteractableCard:not([disabled])\"\n ) ?? []\n );\n setElements(childElements);\n }, [children]);\n\n const select = useCallback(\n (\n event: SyntheticEvent<HTMLDivElement>,\n newValue: InteractableCardValue\n ) => {\n if (multiSelect) {\n const currentValues = Array.isArray(value) ? value : [];\n const isSelected = currentValues.includes(newValue);\n\n const nextValues = isSelected\n ? currentValues.filter((val) => val !== newValue)\n : [...currentValues, newValue];\n setValue(nextValues);\n onChange?.(event, nextValues);\n } else {\n setValue(newValue);\n if (value !== newValue) {\n onChange?.(event, newValue);\n }\n }\n },\n [onChange, value, setValue, multiSelect]\n );\n\n const isSelected = useCallback(\n (cardValue: InteractableCardValue) =>\n multiSelect\n ? Array.isArray(value) && value.includes(cardValue)\n : cardValue !== undefined && value === cardValue,\n [value, multiSelect]\n );\n\n const isFirstChild = useCallback(\n (cardValue: InteractableCardValue) => {\n return (\n elements.findIndex(\n (element) => element.getAttribute(\"data-value\") === cardValue\n ) === 0\n );\n },\n [elements]\n );\n\n const contextValue = useMemo(\n () => ({\n select,\n isSelected,\n isFirstChild,\n disabled,\n multiSelect,\n value,\n }),\n [select, isSelected, disabled, multiSelect, isFirstChild, value]\n );\n\n const handleKeyDown = (event: KeyboardEvent<HTMLDivElement>) => {\n const currentIndex = elements.findIndex(\n (element) => element === document.activeElement\n );\n const nextIndex = (currentIndex + 1) % elements.length;\n const prevIndex = (currentIndex - 1 + elements.length) % elements.length;\n\n if (event.key == \" \") {\n event.preventDefault();\n select(\n event,\n elements[currentIndex].getAttribute(\n \"data-value\"\n ) as InteractableCardValue\n );\n }\n\n if (!multiSelect) {\n switch (event.key) {\n case \"ArrowDown\":\n case \"ArrowRight\":\n const nextValue = elements[nextIndex].getAttribute(\n \"data-value\"\n ) as InteractableCardValue;\n select(event, nextValue);\n elements[nextIndex]?.focus();\n break;\n case \"ArrowUp\":\n case \"ArrowLeft\":\n const prevValue = elements[prevIndex].getAttribute(\n \"data-value\"\n ) as InteractableCardValue;\n select(event, prevValue);\n elements[prevIndex]?.focus();\n break;\n }\n }\n onKeyDown?.(event);\n };\n\n return (\n <InteractableCardGroupContext.Provider value={contextValue}>\n <div\n className={clsx(withBaseName(), className)}\n role={multiSelect ? \"group\" : \"radiogroup\"}\n onKeyDown={handleKeyDown}\n ref={handleRef}\n {...rest}\n >\n {children}\n </div>\n </InteractableCardGroupContext.Provider>\n );\n});\n"],"names":["makePrefixer","forwardRef","InteractableCardGroup","useWindow","useComponentCssInjection","interactableCardGroupCss","useRef","useForkRef","useControlled","useState","useEffect","useCallback","isSelected","useMemo","jsx","InteractableCardGroupContext","clsx"],"mappings":"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"}
@@ -37,6 +37,7 @@ require('../dialog/DialogActions.js');
37
37
  require('../dialog/DialogContent.js');
38
38
  require('../dialog/DialogContext.js');
39
39
  require('../dialog/DialogCloseButton.js');
40
+ require('../divider/Divider.js');
40
41
  require('../drawer/Drawer.js');
41
42
  require('../drawer/DrawerCloseButton.js');
42
43
  require('../dropdown/Dropdown.js');
@@ -63,6 +64,7 @@ require('./InteractableCard.js');
63
64
  require('./InteractableCardGroup.js');
64
65
  require('../link/Link.js');
65
66
  require('../link-card/LinkCard.js');
67
+ require('../list-box/ListBox.js');
66
68
  require('../list-control/ListControlContext.js');
67
69
  require('../menu/MenuContext.js');
68
70
  require('@floating-ui/react');
@@ -100,6 +102,7 @@ require('../toast/Toast.js');
100
102
  require('../toast/ToastContent.js');
101
103
  require('../split-layout/SplitLayout.js');
102
104
  require('../switch/Switch.js');
105
+ require('../tag/Tag.js');
103
106
  require('../toggle-button/ToggleButton.js');
104
107
  require('../toggle-button-group/ToggleButtonGroup.js');
105
108
  require('../toggle-button-group/ToggleButtonGroupContext.js');
@@ -1 +1 @@
1
- {"version":3,"file":"InteractableCardGroupContext.js","sources":["../src/interactable-card/InteractableCardGroupContext.tsx"],"sourcesContent":["import { SyntheticEvent, useContext } from \"react\";\nimport { createContext } from \"../utils\";\n\nexport type InteractableCardValue = string | readonly string[] | undefined;\n\nexport interface InteractableCardGroupContextValue {\n disabled?: boolean;\n select: (\n event: SyntheticEvent<HTMLDivElement>,\n value: InteractableCardValue\n ) => void;\n isSelected: (id: InteractableCardValue) => boolean;\n isFirstChild: (value: InteractableCardValue) => boolean;\n multiSelect?: boolean;\n value: InteractableCardValue;\n}\n\nexport const InteractableCardGroupContext = createContext<\n InteractableCardGroupContextValue | undefined\n>(\"InteractableCardGroupContext\", undefined);\n\nexport function useInteractableCardGroup() {\n return useContext(InteractableCardGroupContext);\n}\n"],"names":["createContext","useContext"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiBa,MAAA,4BAAA,GAA+BA,2BAE1C,CAAA,8BAAA,EAAgC,KAAS,CAAA,EAAA;AAEpC,SAAS,wBAA2B,GAAA;AACzC,EAAA,OAAOC,iBAAW,4BAA4B,CAAA,CAAA;AAChD;;;;;"}
1
+ {"version":3,"file":"InteractableCardGroupContext.js","sources":["../src/interactable-card/InteractableCardGroupContext.tsx"],"sourcesContent":["import { SyntheticEvent, useContext } from \"react\";\nimport { createContext } from \"../utils\";\n\nexport type InteractableCardValue = string | readonly string[] | undefined;\n\nexport interface InteractableCardGroupContextValue {\n disabled?: boolean;\n select: (\n event: SyntheticEvent<HTMLDivElement>,\n value: InteractableCardValue\n ) => void;\n isSelected: (id: InteractableCardValue) => boolean;\n isFirstChild: (value: InteractableCardValue) => boolean;\n multiSelect?: boolean;\n value: InteractableCardValue;\n}\n\nexport const InteractableCardGroupContext = createContext<\n InteractableCardGroupContextValue | undefined\n>(\"InteractableCardGroupContext\", undefined);\n\nexport function useInteractableCardGroup() {\n return useContext(InteractableCardGroupContext);\n}\n"],"names":["createContext","useContext"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiBa,MAAA,4BAAA,GAA+BA,2BAE1C,CAAA,8BAAA,EAAgC,KAAS,CAAA,EAAA;AAEpC,SAAS,wBAA2B,GAAA;AACzC,EAAA,OAAOC,iBAAW,4BAA4B,CAAA,CAAA;AAChD;;;;;"}
@@ -37,6 +37,7 @@ require('../dialog/DialogActions.js');
37
37
  require('../dialog/DialogContent.js');
38
38
  require('../dialog/DialogContext.js');
39
39
  require('../dialog/DialogCloseButton.js');
40
+ require('../divider/Divider.js');
40
41
  require('../drawer/Drawer.js');
41
42
  require('../drawer/DrawerCloseButton.js');
42
43
  require('../dropdown/Dropdown.js');
@@ -63,6 +64,7 @@ require('../interactable-card/InteractableCard.js');
63
64
  require('../interactable-card/InteractableCardGroup.js');
64
65
  require('../interactable-card/InteractableCardGroupContext.js');
65
66
  require('../link-card/LinkCard.js');
67
+ require('../list-box/ListBox.js');
66
68
  require('../list-control/ListControlContext.js');
67
69
  require('../menu/MenuContext.js');
68
70
  require('@floating-ui/react');
@@ -100,6 +102,7 @@ require('../toast/Toast.js');
100
102
  require('../toast/ToastContent.js');
101
103
  require('../split-layout/SplitLayout.js');
102
104
  require('../switch/Switch.js');
105
+ require('../tag/Tag.js');
103
106
  require('../toggle-button/ToggleButton.js');
104
107
  require('../toggle-button-group/ToggleButtonGroup.js');
105
108
  require('../toggle-button-group/ToggleButtonGroupContext.js');
@@ -1 +1 @@
1
- {"version":3,"file":"Link.js","sources":["../src/link/Link.tsx"],"sourcesContent":["import { ComponentType, forwardRef, ReactElement } from \"react\";\nimport { clsx } from \"clsx\";\nimport { IconProps, TearOutIcon } from \"@salt-ds/icons\";\nimport { makePrefixer } from \"../utils\";\nimport { Text, TextProps } from \"../text\";\n\nimport linkCss from \"./Link.css\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nconst withBaseName = makePrefixer(\"saltLink\");\n\n/**\n * Links are a fundamental navigation element. When clicked, they take the user to an entirely different page.\n *\n * @example\n * <LinkExample to=\"#link\">Action</LinkExample>\n */\nexport interface LinkProps extends Omit<TextProps<\"a\">, \"as\" | \"disabled\"> {\n IconComponent?: ComponentType<IconProps> | null;\n}\n\nexport const Link = forwardRef<HTMLAnchorElement, LinkProps>(function Link(\n {\n IconComponent = TearOutIcon,\n href,\n className,\n children,\n variant = \"primary\",\n color = \"primary\",\n target = \"_self\",\n ...rest\n },\n ref\n): ReactElement<LinkProps> {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-link\",\n css: linkCss,\n window: targetWindow,\n });\n\n return (\n <Text\n as=\"a\"\n className={clsx(withBaseName(), className)}\n href={href}\n ref={ref}\n target={target}\n variant={variant}\n color={color}\n {...rest}\n >\n {children}\n {target === \"_blank\" && (\n <>\n {IconComponent && (\n <IconComponent className={withBaseName(\"icon\")} aria-hidden />\n )}\n <span className={withBaseName(\"externalLinkADA\")}>External</span>\n </>\n )}\n </Text>\n );\n});\n"],"names":["makePrefixer","forwardRef","Link","TearOutIcon","useWindow","useComponentCssInjection","linkCss","jsxs","Text","clsx","Fragment","jsx"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAUA,MAAM,YAAA,GAAeA,0BAAa,UAAU,CAAA,CAAA;AAY/B,MAAA,IAAA,GAAOC,gBAAyC,CAAA,SAASC,KACpE,CAAA;AAAA,EACE,aAAgB,GAAAC,iBAAA;AAAA,EAChB,IAAA;AAAA,EACA,SAAA;AAAA,EACA,QAAA;AAAA,EACA,OAAU,GAAA,SAAA;AAAA,EACV,KAAQ,GAAA,SAAA;AAAA,EACR,MAAS,GAAA,OAAA;AAAA,EACN,GAAA,IAAA;AACL,CAAA,EACA,GACyB,EAAA;AACzB,EAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,WAAA;AAAA,IACR,GAAK,EAAAC,MAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,uBACGC,eAAA,CAAAC,SAAA,EAAA;AAAA,IACC,EAAG,EAAA,GAAA;AAAA,IACH,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,IACzC,IAAA;AAAA,IACA,GAAA;AAAA,IACA,MAAA;AAAA,IACA,OAAA;AAAA,IACA,KAAA;AAAA,IACC,GAAG,IAAA;AAAA,IAEH,QAAA,EAAA;AAAA,MAAA,QAAA;AAAA,MACA,WAAW,QACV,oBAAAF,eAAA,CAAAG,mBAAA,EAAA;AAAA,QACG,QAAA,EAAA;AAAA,UAAA,aAAA,oBACEC,cAAA,CAAA,aAAA,EAAA;AAAA,YAAc,SAAA,EAAW,aAAa,MAAM,CAAA;AAAA,YAAG,aAAW,EAAA,IAAA;AAAA,WAAC,CAAA;AAAA,0BAE7DA,cAAA,CAAA,MAAA,EAAA;AAAA,YAAK,SAAA,EAAW,aAAa,iBAAiB,CAAA;AAAA,YAAG,QAAA,EAAA,UAAA;AAAA,WAAQ,CAAA;AAAA,SAAA;AAAA,OAC5D,CAAA;AAAA,KAAA;AAAA,GAEJ,CAAA,CAAA;AAEJ,CAAC;;;;"}
1
+ {"version":3,"file":"Link.js","sources":["../src/link/Link.tsx"],"sourcesContent":["import { ComponentType, forwardRef, ReactElement } from \"react\";\nimport { clsx } from \"clsx\";\nimport { IconProps, TearOutIcon } from \"@salt-ds/icons\";\nimport { makePrefixer } from \"../utils\";\nimport { Text, TextProps } from \"../text\";\n\nimport linkCss from \"./Link.css\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nconst withBaseName = makePrefixer(\"saltLink\");\n\n/**\n * Links are a fundamental navigation element. When clicked, they take the user to an entirely different page.\n *\n * @example\n * <LinkExample to=\"#link\">Action</LinkExample>\n */\nexport interface LinkProps extends Omit<TextProps<\"a\">, \"as\" | \"disabled\"> {\n IconComponent?: ComponentType<IconProps> | null;\n}\n\nexport const Link = forwardRef<HTMLAnchorElement, LinkProps>(function Link(\n {\n IconComponent = TearOutIcon,\n href,\n className,\n children,\n variant = \"primary\",\n color = \"primary\",\n target = \"_self\",\n ...rest\n },\n ref\n): ReactElement<LinkProps> {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-link\",\n css: linkCss,\n window: targetWindow,\n });\n\n return (\n <Text\n as=\"a\"\n className={clsx(withBaseName(), className)}\n href={href}\n ref={ref}\n target={target}\n variant={variant}\n color={color}\n {...rest}\n >\n {children}\n {target === \"_blank\" && (\n <>\n {IconComponent && (\n <IconComponent className={withBaseName(\"icon\")} aria-hidden />\n )}\n <span className={withBaseName(\"externalLinkADA\")}>External</span>\n </>\n )}\n </Text>\n );\n});\n"],"names":["makePrefixer","forwardRef","Link","TearOutIcon","useWindow","useComponentCssInjection","linkCss","jsxs","Text","clsx","Fragment","jsx"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAUA,MAAM,YAAA,GAAeA,0BAAa,UAAU,CAAA,CAAA;AAY/B,MAAA,IAAA,GAAOC,gBAAyC,CAAA,SAASC,KACpE,CAAA;AAAA,EACE,aAAgB,GAAAC,iBAAA;AAAA,EAChB,IAAA;AAAA,EACA,SAAA;AAAA,EACA,QAAA;AAAA,EACA,OAAU,GAAA,SAAA;AAAA,EACV,KAAQ,GAAA,SAAA;AAAA,EACR,MAAS,GAAA,OAAA;AAAA,EACN,GAAA,IAAA;AACL,CAAA,EACA,GACyB,EAAA;AACzB,EAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,WAAA;AAAA,IACR,GAAK,EAAAC,MAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,uBACGC,eAAA,CAAAC,SAAA,EAAA;AAAA,IACC,EAAG,EAAA,GAAA;AAAA,IACH,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,IACzC,IAAA;AAAA,IACA,GAAA;AAAA,IACA,MAAA;AAAA,IACA,OAAA;AAAA,IACA,KAAA;AAAA,IACC,GAAG,IAAA;AAAA,IAEH,QAAA,EAAA;AAAA,MAAA,QAAA;AAAA,MACA,WAAW,QACV,oBAAAF,eAAA,CAAAG,mBAAA,EAAA;AAAA,QACG,QAAA,EAAA;AAAA,UAAA,aAAA,oBACEC,cAAA,CAAA,aAAA,EAAA;AAAA,YAAc,SAAA,EAAW,aAAa,MAAM,CAAA;AAAA,YAAG,aAAW,EAAA,IAAA;AAAA,WAAC,CAAA;AAAA,0BAE7DA,cAAA,CAAA,MAAA,EAAA;AAAA,YAAK,SAAA,EAAW,aAAa,iBAAiB,CAAA;AAAA,YAAG,QAAA,EAAA,UAAA;AAAA,WAAQ,CAAA;AAAA,SAAA;AAAA,OAC5D,CAAA;AAAA,KAAA;AAAA,GAEJ,CAAA,CAAA;AAEJ,CAAC;;;;"}
@@ -38,6 +38,7 @@ require('../dialog/DialogActions.js');
38
38
  require('../dialog/DialogContent.js');
39
39
  require('../dialog/DialogContext.js');
40
40
  require('../dialog/DialogCloseButton.js');
41
+ require('../divider/Divider.js');
41
42
  require('../drawer/Drawer.js');
42
43
  require('../drawer/DrawerCloseButton.js');
43
44
  require('../dropdown/Dropdown.js');
@@ -64,6 +65,7 @@ require('../interactable-card/InteractableCard.js');
64
65
  require('../interactable-card/InteractableCardGroup.js');
65
66
  require('../interactable-card/InteractableCardGroupContext.js');
66
67
  require('../link/Link.js');
68
+ require('../list-box/ListBox.js');
67
69
  require('../list-control/ListControlContext.js');
68
70
  require('../menu/MenuContext.js');
69
71
  require('@floating-ui/react');
@@ -101,6 +103,7 @@ require('../toast/Toast.js');
101
103
  require('../toast/ToastContent.js');
102
104
  require('../split-layout/SplitLayout.js');
103
105
  require('../switch/Switch.js');
106
+ require('../tag/Tag.js');
104
107
  require('../toggle-button/ToggleButton.js');
105
108
  require('../toggle-button-group/ToggleButtonGroup.js');
106
109
  require('../toggle-button-group/ToggleButtonGroupContext.js');
@@ -1 +1 @@
1
- {"version":3,"file":"LinkCard.js","sources":["../src/link-card/LinkCard.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport { ComponentPropsWithoutRef, forwardRef } from \"react\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport { capitalize, makePrefixer } from \"../utils\";\n\nimport linkCardCss from \"./LinkCard.css\";\n\nconst withBaseName = makePrefixer(\"saltLinkCard\");\n\nexport interface LinkCardProps extends ComponentPropsWithoutRef<\"a\"> {\n /**\n * If provided an accent is shown in the specified position.\n */\n accent?: \"bottom\" | \"top\" | \"left\" | \"right\";\n /**\n * Styling variant; defaults to \"primary\".\n */\n variant?: \"primary\" | \"secondary\";\n}\n\nexport const LinkCard = forwardRef<HTMLAnchorElement, LinkCardProps>(\n function LinkCard(props, ref) {\n const {\n accent,\n children,\n className,\n href,\n variant = \"primary\",\n ...rest\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-link-card\",\n css: linkCardCss,\n window: targetWindow,\n });\n\n return (\n <a\n className={clsx(\n withBaseName(),\n withBaseName(variant),\n {\n [withBaseName(\"accent\")]: accent,\n [withBaseName(`accent${capitalize(accent ?? \"\")}`)]: accent,\n },\n className\n )}\n href={href}\n {...rest}\n ref={ref}\n >\n {children}\n </a>\n );\n }\n);\n"],"names":["makePrefixer","forwardRef","LinkCard","useWindow","useComponentCssInjection","linkCardCss","jsx","clsx","capitalize"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AASA,MAAM,YAAA,GAAeA,0BAAa,cAAc,CAAA,CAAA;AAazC,MAAM,QAAW,GAAAC,gBAAA;AAAA,EACtB,SAASC,SAAS,CAAA,KAAA,EAAO,GAAK,EAAA;AAC5B,IAAM,MAAA;AAAA,MACJ,MAAA;AAAA,MACA,QAAA;AAAA,MACA,SAAA;AAAA,MACA,IAAA;AAAA,MACA,OAAU,GAAA,SAAA;AAAA,MACP,GAAA,IAAA;AAAA,KACD,GAAA,KAAA,CAAA;AAEJ,IAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,gBAAA;AAAA,MACR,GAAK,EAAAC,UAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAA,uBACGC,cAAA,CAAA,GAAA,EAAA;AAAA,MACC,SAAW,EAAAC,SAAA;AAAA,QACT,YAAa,EAAA;AAAA,QACb,aAAa,OAAO,CAAA;AAAA,QACpB;AAAA,UACE,CAAC,YAAa,CAAA,QAAQ,CAAI,GAAA,MAAA;AAAA,UAC1B,CAAC,YAAa,CAAA,CAAA,MAAA,EAASC,sBAAW,MAAU,IAAA,IAAA,GAAA,MAAA,GAAA,EAAE,GAAG,CAAI,GAAA,MAAA;AAAA,SACvD;AAAA,QACA,SAAA;AAAA,OACF;AAAA,MACA,IAAA;AAAA,MACC,GAAG,IAAA;AAAA,MACJ,GAAA;AAAA,MAEC,QAAA;AAAA,KACH,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
1
+ {"version":3,"file":"LinkCard.js","sources":["../src/link-card/LinkCard.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport { ComponentPropsWithoutRef, forwardRef } from \"react\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport { capitalize, makePrefixer } from \"../utils\";\n\nimport linkCardCss from \"./LinkCard.css\";\n\nconst withBaseName = makePrefixer(\"saltLinkCard\");\n\nexport interface LinkCardProps extends ComponentPropsWithoutRef<\"a\"> {\n /**\n * If provided an accent is shown in the specified position.\n */\n accent?: \"bottom\" | \"top\" | \"left\" | \"right\";\n /**\n * Styling variant; defaults to \"primary\".\n */\n variant?: \"primary\" | \"secondary\";\n}\n\nexport const LinkCard = forwardRef<HTMLAnchorElement, LinkCardProps>(\n function LinkCard(props, ref) {\n const {\n accent,\n children,\n className,\n href,\n variant = \"primary\",\n ...rest\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-link-card\",\n css: linkCardCss,\n window: targetWindow,\n });\n\n return (\n <a\n className={clsx(\n withBaseName(),\n withBaseName(variant),\n {\n [withBaseName(\"accent\")]: accent,\n [withBaseName(`accent${capitalize(accent ?? \"\")}`)]: accent,\n },\n className\n )}\n href={href}\n {...rest}\n ref={ref}\n >\n {children}\n </a>\n );\n }\n);\n"],"names":["makePrefixer","forwardRef","LinkCard","useWindow","useComponentCssInjection","linkCardCss","jsx","clsx","capitalize"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AASA,MAAM,YAAA,GAAeA,0BAAa,cAAc,CAAA,CAAA;AAazC,MAAM,QAAW,GAAAC,gBAAA;AAAA,EACtB,SAASC,SAAS,CAAA,KAAA,EAAO,GAAK,EAAA;AAC5B,IAAM,MAAA;AAAA,MACJ,MAAA;AAAA,MACA,QAAA;AAAA,MACA,SAAA;AAAA,MACA,IAAA;AAAA,MACA,OAAU,GAAA,SAAA;AAAA,MACP,GAAA,IAAA;AAAA,KACD,GAAA,KAAA,CAAA;AAEJ,IAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,gBAAA;AAAA,MACR,GAAK,EAAAC,UAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAA,uBACGC,cAAA,CAAA,GAAA,EAAA;AAAA,MACC,SAAW,EAAAC,SAAA;AAAA,QACT,YAAa,EAAA;AAAA,QACb,aAAa,OAAO,CAAA;AAAA,QACpB;AAAA,UACE,CAAC,YAAa,CAAA,QAAQ,CAAI,GAAA,MAAA;AAAA,UAC1B,CAAC,YAAa,CAAA,CAAA,MAAA,EAASC,sBAAW,MAAU,IAAA,IAAA,GAAA,MAAA,GAAA,EAAE,GAAG,CAAI,GAAA,MAAA;AAAA,SACvD;AAAA,QACA,SAAA;AAAA,OACF;AAAA,MACA,IAAA;AAAA,MACC,GAAG,IAAA;AAAA,MACJ,GAAA;AAAA,MAEC,QAAA;AAAA,KACH,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
@@ -0,0 +1,6 @@
1
+ 'use strict';
2
+
3
+ var css_248z = ".saltListBox {\n display: flex;\n flex-direction: column;\n gap: var(--salt-size-border);\n background: var(--salt-container-primary-background);\n overflow: auto;\n padding-top: 1px;\n padding-bottom: 1px;\n box-sizing: border-box;\n isolation: isolate;\n position: relative;\n max-height: inherit;\n border-radius: var(--salt-palette-corner-weak, 0);\n}\n\n.saltListBox-bordered {\n border: var(--salt-size-border) var(--salt-container-borderStyle) var(--salt-container-primary-borderColor);\n}\n\n.saltListBox:focus-visible {\n outline: none;\n}\n";
4
+
5
+ module.exports = css_248z;
6
+ //# sourceMappingURL=ListBox.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ListBox.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
@@ -0,0 +1,295 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var React = require('react');
7
+ var window$1 = require('@salt-ds/window');
8
+ var styles = require('@salt-ds/styles');
9
+ var clsx = require('clsx');
10
+ var makePrefixer = require('../utils/makePrefixer.js');
11
+ require('../utils/useFloatingUI/useFloatingUI.js');
12
+ var useForkRef = require('../utils/useForkRef.js');
13
+ require('../utils/useId.js');
14
+ require('../salt-provider/SaltProvider.js');
15
+ require('../viewport/ViewportProvider.js');
16
+ require('../accordion/AccordionGroup.js');
17
+ require('../accordion/AccordionPanel.js');
18
+ require('../accordion/Accordion.js');
19
+ require('../accordion/AccordionHeader.js');
20
+ require('../aria-announcer/AriaAnnouncerContext.js');
21
+ require('../avatar/Avatar.js');
22
+ require('../badge/Badge.js');
23
+ require('../banner/Banner.js');
24
+ require('../banner/BannerActions.js');
25
+ require('../banner/BannerContent.js');
26
+ require('../border-item/BorderItem.js');
27
+ require('../border-layout/BorderLayout.js');
28
+ require('../breakpoints/BreakpointProvider.js');
29
+ require('../button/Button.js');
30
+ require('../card/Card.js');
31
+ require('../checkbox/Checkbox.js');
32
+ require('../checkbox/CheckboxGroup.js');
33
+ require('@salt-ds/icons');
34
+ require('../combo-box/ComboBox.js');
35
+ require('../dialog/Dialog.js');
36
+ require('../dialog/DialogHeader.js');
37
+ require('../dialog/DialogActions.js');
38
+ require('../dialog/DialogContent.js');
39
+ require('../dialog/DialogContext.js');
40
+ require('../dialog/DialogCloseButton.js');
41
+ require('../divider/Divider.js');
42
+ require('../drawer/Drawer.js');
43
+ require('../drawer/DrawerCloseButton.js');
44
+ require('../dropdown/Dropdown.js');
45
+ require('../file-drop-zone/FileDropZone.js');
46
+ require('../file-drop-zone/FileDropZoneIcon.js');
47
+ require('../file-drop-zone/FileDropZoneTrigger.js');
48
+ require('../flex-item/FlexItem.js');
49
+ require('../flex-layout/FlexLayout.js');
50
+ require('../flow-layout/FlowLayout.js');
51
+ require('../form-field/FormField.js');
52
+ require('../status-indicator/StatusIndicator.js');
53
+ require('../text/Text.js');
54
+ require('../text/Code.js');
55
+ require('../text/Display.js');
56
+ require('../text/Headings.js');
57
+ require('../text/Label.js');
58
+ require('../text/TextAction.js');
59
+ require('../text/TextNotation.js');
60
+ require('../form-field-context/FormFieldContext.js');
61
+ require('../grid-item/GridItem.js');
62
+ require('../grid-layout/GridLayout.js');
63
+ require('../input/Input.js');
64
+ require('../interactable-card/InteractableCard.js');
65
+ require('../interactable-card/InteractableCardGroup.js');
66
+ require('../interactable-card/InteractableCardGroupContext.js');
67
+ require('../link/Link.js');
68
+ require('../link-card/LinkCard.js');
69
+ var ListControlContext = require('../list-control/ListControlContext.js');
70
+ require('../menu/MenuContext.js');
71
+ require('@floating-ui/react');
72
+ require('../menu/MenuItem.js');
73
+ require('../menu/MenuPanel.js');
74
+ require('../menu/MenuTriggerContext.js');
75
+ require('../menu/MenuPanelContext.js');
76
+ require('../menu/MenuGroup.js');
77
+ require('../multiline-input/MultilineInput.js');
78
+ require('../navigation-item/NavigationItem.js');
79
+ require('../option/Option.js');
80
+ require('../option/OptionGroup.js');
81
+ require('../overlay/OverlayContext.js');
82
+ require('../overlay/OverlayPanel.js');
83
+ require('../overlay/OverlayPanelCloseButton.js');
84
+ require('../overlay/OverlayPanelContent.js');
85
+ require('../pagination/Pagination.js');
86
+ require('../pagination/Paginator.js');
87
+ require('../pagination/CompactInput.js');
88
+ require('../pagination/CompactPaginator.js');
89
+ require('../pagination/GoToInput.js');
90
+ require('../panel/Panel.js');
91
+ require('../parent-child-layout/ParentChildLayout.js');
92
+ require('../pill/Pill.js');
93
+ require('../progress/CircularProgress/CircularProgress.js');
94
+ require('../progress/LinearProgress/LinearProgress.js');
95
+ require('../radio-button/RadioButton.js');
96
+ require('../radio-button/RadioButtonGroup.js');
97
+ require('../scrim/Scrim.js');
98
+ require('../segmented-button-group/SegmentedButtonGroup.js');
99
+ require('../spinner/Spinner.js');
100
+ require('../stack-layout/StackLayout.js');
101
+ require('../status-adornment/StatusAdornment.js');
102
+ require('../toast/Toast.js');
103
+ require('../toast/ToastContent.js');
104
+ require('../split-layout/SplitLayout.js');
105
+ require('../switch/Switch.js');
106
+ require('../tag/Tag.js');
107
+ require('../toggle-button/ToggleButton.js');
108
+ require('../toggle-button-group/ToggleButtonGroup.js');
109
+ require('../toggle-button-group/ToggleButtonGroupContext.js');
110
+ require('../tooltip/Tooltip.js');
111
+ var ListControlState = require('../list-control/ListControlState.js');
112
+ var ListBox$1 = require('./ListBox.css.js');
113
+
114
+ const withBaseName = makePrefixer.makePrefixer("saltListBox");
115
+ const ListBox = React.forwardRef(function ListBox2(props, ref) {
116
+ const {
117
+ bordered,
118
+ className,
119
+ children,
120
+ defaultSelected,
121
+ disabled,
122
+ selected,
123
+ onSelectionChange,
124
+ multiselect,
125
+ valueToString = ListControlState.defaultValueToString,
126
+ onKeyDown,
127
+ onFocus,
128
+ onBlur,
129
+ ...rest
130
+ } = props;
131
+ const targetWindow = window$1.useWindow();
132
+ styles.useComponentCssInjection({
133
+ testId: "salt-list-box",
134
+ css: ListBox$1,
135
+ window: targetWindow
136
+ });
137
+ const listControl = ListControlState.useListControl({
138
+ multiselect,
139
+ defaultSelected,
140
+ selected,
141
+ onSelectionChange,
142
+ valueToString,
143
+ disabled
144
+ });
145
+ const {
146
+ activeState,
147
+ setActive,
148
+ getOptionAtIndex,
149
+ getIndexOfOption,
150
+ getOptionsMatching,
151
+ getOptionFromSearch,
152
+ getFirstOption,
153
+ getLastOption,
154
+ getOptionAfter,
155
+ getOptionBefore,
156
+ getOptionPageAbove,
157
+ getOptionPageBelow,
158
+ selectedState,
159
+ select,
160
+ setFocusVisibleState,
161
+ setFocusedState,
162
+ listRef
163
+ } = listControl;
164
+ const typeaheadString = React.useRef("");
165
+ const typeaheadTimeout = React.useRef();
166
+ const handleTypeahead = (event) => {
167
+ if (typeaheadTimeout.current) {
168
+ clearTimeout(typeaheadTimeout.current);
169
+ }
170
+ typeaheadString.current += event.key;
171
+ typeaheadTimeout.current = window.setTimeout(() => {
172
+ typeaheadString.current = "";
173
+ }, 500);
174
+ let newOption = getOptionFromSearch(typeaheadString.current, activeState);
175
+ if (!newOption) {
176
+ newOption = getOptionFromSearch(typeaheadString.current);
177
+ }
178
+ if (newOption) {
179
+ setActive(newOption);
180
+ setFocusVisibleState(true);
181
+ }
182
+ };
183
+ const handleKeyDown = (event) => {
184
+ var _a, _b;
185
+ if (event.key.length === 1 && !event.ctrlKey && !event.metaKey && !event.altKey) {
186
+ event.preventDefault();
187
+ event.stopPropagation();
188
+ handleTypeahead(event);
189
+ }
190
+ const activeOption = activeState != null ? activeState : getFirstOption().data;
191
+ let newActive;
192
+ switch (event.key) {
193
+ case "ArrowDown":
194
+ newActive = (_a = getOptionAfter(activeOption)) != null ? _a : getLastOption();
195
+ break;
196
+ case "ArrowUp":
197
+ newActive = (_b = getOptionBefore(activeOption)) != null ? _b : getFirstOption();
198
+ break;
199
+ case "Home":
200
+ newActive = getFirstOption();
201
+ break;
202
+ case "End":
203
+ newActive = getLastOption();
204
+ break;
205
+ case "PageUp":
206
+ newActive = getOptionPageAbove(activeOption);
207
+ break;
208
+ case "PageDown":
209
+ newActive = getOptionPageBelow(activeOption);
210
+ break;
211
+ case "Enter":
212
+ case " ":
213
+ if (Boolean(activeState == null ? void 0 : activeState.disabled) || typeaheadString.current.trim().length > 0 && event.key === " ") {
214
+ event.preventDefault();
215
+ return;
216
+ }
217
+ if (!activeState) {
218
+ return;
219
+ }
220
+ event.preventDefault();
221
+ select(event, activeState);
222
+ break;
223
+ }
224
+ if (newActive && newActive.data.id != (activeState == null ? void 0 : activeState.id)) {
225
+ event.preventDefault();
226
+ setActive(newActive.data);
227
+ setFocusVisibleState(true);
228
+ }
229
+ onKeyDown == null ? void 0 : onKeyDown(event);
230
+ };
231
+ const wasMouseDown = React.useRef(false);
232
+ const handleMouseDown = () => {
233
+ wasMouseDown.current = true;
234
+ };
235
+ const handleFocus = (event) => {
236
+ if (wasMouseDown.current) {
237
+ wasMouseDown.current = false;
238
+ return;
239
+ }
240
+ setFocusVisibleState(true);
241
+ wasMouseDown.current = false;
242
+ const activeIndex = activeState ? getIndexOfOption(activeState) : -1;
243
+ let newActive = void 0;
244
+ if (activeIndex > 0) {
245
+ return;
246
+ }
247
+ if (selectedState.length > 0) {
248
+ newActive = getOptionsMatching(
249
+ (option) => option.value === selectedState[0]
250
+ ).pop();
251
+ }
252
+ if (!newActive) {
253
+ newActive = getOptionAtIndex(0);
254
+ }
255
+ setActive(newActive == null ? void 0 : newActive.data);
256
+ setFocusedState(true);
257
+ onFocus == null ? void 0 : onFocus(event);
258
+ };
259
+ const handleBlur = (event) => {
260
+ setFocusedState(false);
261
+ setActive(void 0);
262
+ onBlur == null ? void 0 : onBlur(event);
263
+ };
264
+ const handleListMouseOver = () => {
265
+ setFocusVisibleState(false);
266
+ setActive(void 0);
267
+ };
268
+ const handleRef = useForkRef.useForkRef(listRef, ref);
269
+ return /* @__PURE__ */ jsxRuntime.jsx(ListControlContext.ListControlContext.Provider, {
270
+ value: listControl,
271
+ children: /* @__PURE__ */ jsxRuntime.jsx("div", {
272
+ className: clsx.clsx(
273
+ withBaseName(),
274
+ { [withBaseName("bordered")]: bordered },
275
+ className
276
+ ),
277
+ role: "listbox",
278
+ "aria-activedescendant": activeState == null ? void 0 : activeState.id,
279
+ "aria-disabled": disabled || void 0,
280
+ "aria-multiselectable": multiselect,
281
+ tabIndex: disabled ? -1 : 0,
282
+ onKeyDown: handleKeyDown,
283
+ onBlur: handleBlur,
284
+ onFocus: handleFocus,
285
+ onMouseOver: handleListMouseOver,
286
+ onMouseDown: handleMouseDown,
287
+ ref: handleRef,
288
+ ...rest,
289
+ children
290
+ })
291
+ });
292
+ });
293
+
294
+ exports.ListBox = ListBox;
295
+ //# sourceMappingURL=ListBox.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ListBox.js","sources":["../src/list-box/ListBox.tsx"],"sourcesContent":["import {\n ComponentPropsWithoutRef,\n FocusEvent,\n ForwardedRef,\n forwardRef,\n KeyboardEvent,\n ReactNode,\n Ref,\n useRef,\n} from \"react\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { clsx } from \"clsx\";\nimport { makePrefixer, useForkRef } from \"../utils\";\nimport { ListControlContext } from \"../list-control/ListControlContext\";\nimport {\n defaultValueToString,\n useListControl,\n ListControlProps,\n} from \"../list-control/ListControlState\";\n\nimport listBoxCss from \"./ListBox.css\";\n\nexport type ListBoxProps<Item = string> = {\n /**\n * If `true`, the list box will be disabled.\n */\n disabled?: boolean;\n /**\n * If `false`, the list box will have not a border.\n */\n bordered?: boolean;\n /**\n * The options to display in the list box.\n */\n children?: ReactNode;\n /**\n * If `true`, the list box will be multiselect.\n */\n multiselect?: boolean;\n} & ComponentPropsWithoutRef<\"div\"> &\n Omit<ListControlProps<Item>, \"onOpenChange\">;\n\nconst withBaseName = makePrefixer(\"saltListBox\");\n\nexport const ListBox = forwardRef(function ListBox<Item>(\n props: ListBoxProps<Item>,\n ref: ForwardedRef<HTMLDivElement>\n) {\n const {\n bordered,\n className,\n children,\n defaultSelected,\n disabled,\n selected,\n onSelectionChange,\n multiselect,\n valueToString = defaultValueToString,\n onKeyDown,\n onFocus,\n onBlur,\n ...rest\n } = props;\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-list-box\",\n css: listBoxCss,\n window: targetWindow,\n });\n\n const listControl = useListControl<Item>({\n multiselect,\n defaultSelected,\n selected,\n onSelectionChange,\n valueToString,\n disabled,\n });\n\n const {\n activeState,\n setActive,\n getOptionAtIndex,\n getIndexOfOption,\n getOptionsMatching,\n getOptionFromSearch,\n getFirstOption,\n getLastOption,\n getOptionAfter,\n getOptionBefore,\n getOptionPageAbove,\n getOptionPageBelow,\n selectedState,\n select,\n setFocusVisibleState,\n setFocusedState,\n listRef,\n } = listControl;\n\n const typeaheadString = useRef(\"\");\n const typeaheadTimeout = useRef<number | undefined>();\n\n const handleTypeahead = (event: KeyboardEvent<HTMLDivElement>) => {\n if (typeaheadTimeout.current) {\n clearTimeout(typeaheadTimeout.current);\n }\n typeaheadString.current += event.key;\n typeaheadTimeout.current = window.setTimeout(() => {\n typeaheadString.current = \"\";\n }, 500);\n\n let newOption = getOptionFromSearch(typeaheadString.current, activeState);\n\n if (!newOption) {\n newOption = getOptionFromSearch(typeaheadString.current);\n }\n\n if (newOption) {\n setActive(newOption);\n setFocusVisibleState(true);\n }\n };\n\n const handleKeyDown = (event: KeyboardEvent<HTMLDivElement>) => {\n if (\n event.key.length === 1 &&\n !event.ctrlKey &&\n !event.metaKey &&\n !event.altKey\n ) {\n event.preventDefault();\n event.stopPropagation();\n handleTypeahead(event);\n }\n\n const activeOption = activeState ?? getFirstOption().data;\n\n let newActive;\n switch (event.key) {\n case \"ArrowDown\":\n newActive = getOptionAfter(activeOption) ?? getLastOption();\n break;\n case \"ArrowUp\":\n newActive = getOptionBefore(activeOption) ?? getFirstOption();\n break;\n case \"Home\":\n newActive = getFirstOption();\n break;\n case \"End\":\n newActive = getLastOption();\n break;\n case \"PageUp\":\n newActive = getOptionPageAbove(activeOption);\n break;\n case \"PageDown\":\n newActive = getOptionPageBelow(activeOption);\n break;\n case \"Enter\":\n case \" \":\n if (\n Boolean(activeState?.disabled) ||\n (typeaheadString.current.trim().length > 0 && event.key === \" \")\n ) {\n event.preventDefault();\n return;\n }\n\n if (!activeState) {\n return;\n }\n\n event.preventDefault();\n select(event, activeState);\n\n break;\n }\n\n if (newActive && newActive.data.id != activeState?.id) {\n event.preventDefault();\n setActive(newActive.data);\n setFocusVisibleState(true);\n }\n\n onKeyDown?.(event);\n };\n\n const wasMouseDown = useRef(false);\n\n const handleMouseDown = () => {\n wasMouseDown.current = true;\n };\n\n const handleFocus = (event: FocusEvent<HTMLDivElement>) => {\n if (wasMouseDown.current) {\n wasMouseDown.current = false;\n return;\n }\n\n setFocusVisibleState(true);\n wasMouseDown.current = false;\n\n // We check the active index because the active item may have been removed\n const activeIndex = activeState ? getIndexOfOption(activeState) : -1;\n let newActive = undefined;\n\n // If the active item is still in the list, we don't need to do anything\n if (activeIndex > 0) {\n return;\n }\n\n // If we have selected an item, we should make that the active item\n if (selectedState.length > 0) {\n newActive = getOptionsMatching(\n (option) => option.value === selectedState[0]\n ).pop();\n }\n\n // If we still don't have an active item, we should just select the first item\n if (!newActive) {\n newActive = getOptionAtIndex(0);\n }\n\n setActive(newActive?.data);\n setFocusedState(true);\n onFocus?.(event);\n };\n\n const handleBlur = (event: FocusEvent<HTMLDivElement>) => {\n setFocusedState(false);\n setActive(undefined);\n onBlur?.(event);\n };\n\n const handleListMouseOver = () => {\n setFocusVisibleState(false);\n setActive(undefined);\n };\n\n const handleRef = useForkRef(listRef, ref);\n\n return (\n <ListControlContext.Provider value={listControl}>\n <div\n className={clsx(\n withBaseName(),\n { [withBaseName(\"bordered\")]: bordered },\n className\n )}\n role=\"listbox\"\n aria-activedescendant={activeState?.id}\n aria-disabled={disabled || undefined}\n aria-multiselectable={multiselect}\n tabIndex={disabled ? -1 : 0}\n onKeyDown={handleKeyDown}\n onBlur={handleBlur}\n onFocus={handleFocus}\n onMouseOver={handleListMouseOver}\n onMouseDown={handleMouseDown}\n ref={handleRef}\n {...rest}\n >\n {children}\n </div>\n </ListControlContext.Provider>\n );\n}) as <Item = string>(\n props: ListBoxProps<Item> & { ref?: Ref<HTMLDivElement> }\n) => JSX.Element;\n"],"names":["makePrefixer","forwardRef","ListBox","defaultValueToString","useWindow","useComponentCssInjection","listBoxCss","useListControl","useRef","useForkRef","jsx","ListControlContext","clsx"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA2CA,MAAM,YAAA,GAAeA,0BAAa,aAAa,CAAA,CAAA;AAExC,MAAM,OAAU,GAAAC,gBAAA,CAAW,SAASC,QAAAA,CACzC,OACA,GACA,EAAA;AACA,EAAM,MAAA;AAAA,IACJ,QAAA;AAAA,IACA,SAAA;AAAA,IACA,QAAA;AAAA,IACA,eAAA;AAAA,IACA,QAAA;AAAA,IACA,QAAA;AAAA,IACA,iBAAA;AAAA,IACA,WAAA;AAAA,IACA,aAAgB,GAAAC,qCAAA;AAAA,IAChB,SAAA;AAAA,IACA,OAAA;AAAA,IACA,MAAA;AAAA,IACG,GAAA,IAAA;AAAA,GACD,GAAA,KAAA,CAAA;AACJ,EAAA,MAAM,eAAeC,kBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,eAAA;AAAA,IACR,GAAK,EAAAC,SAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,MAAM,cAAcC,+BAAqB,CAAA;AAAA,IACvC,WAAA;AAAA,IACA,eAAA;AAAA,IACA,QAAA;AAAA,IACA,iBAAA;AAAA,IACA,aAAA;AAAA,IACA,QAAA;AAAA,GACD,CAAA,CAAA;AAED,EAAM,MAAA;AAAA,IACJ,WAAA;AAAA,IACA,SAAA;AAAA,IACA,gBAAA;AAAA,IACA,gBAAA;AAAA,IACA,kBAAA;AAAA,IACA,mBAAA;AAAA,IACA,cAAA;AAAA,IACA,aAAA;AAAA,IACA,cAAA;AAAA,IACA,eAAA;AAAA,IACA,kBAAA;AAAA,IACA,kBAAA;AAAA,IACA,aAAA;AAAA,IACA,MAAA;AAAA,IACA,oBAAA;AAAA,IACA,eAAA;AAAA,IACA,OAAA;AAAA,GACE,GAAA,WAAA,CAAA;AAEJ,EAAM,MAAA,eAAA,GAAkBC,aAAO,EAAE,CAAA,CAAA;AACjC,EAAA,MAAM,mBAAmBA,YAA2B,EAAA,CAAA;AAEpD,EAAM,MAAA,eAAA,GAAkB,CAAC,KAAyC,KAAA;AAChE,IAAA,IAAI,iBAAiB,OAAS,EAAA;AAC5B,MAAA,YAAA,CAAa,iBAAiB,OAAO,CAAA,CAAA;AAAA,KACvC;AACA,IAAA,eAAA,CAAgB,WAAW,KAAM,CAAA,GAAA,CAAA;AACjC,IAAiB,gBAAA,CAAA,OAAA,GAAU,MAAO,CAAA,UAAA,CAAW,MAAM;AACjD,MAAA,eAAA,CAAgB,OAAU,GAAA,EAAA,CAAA;AAAA,OACzB,GAAG,CAAA,CAAA;AAEN,IAAA,IAAI,SAAY,GAAA,mBAAA,CAAoB,eAAgB,CAAA,OAAA,EAAS,WAAW,CAAA,CAAA;AAExE,IAAA,IAAI,CAAC,SAAW,EAAA;AACd,MAAY,SAAA,GAAA,mBAAA,CAAoB,gBAAgB,OAAO,CAAA,CAAA;AAAA,KACzD;AAEA,IAAA,IAAI,SAAW,EAAA;AACb,MAAA,SAAA,CAAU,SAAS,CAAA,CAAA;AACnB,MAAA,oBAAA,CAAqB,IAAI,CAAA,CAAA;AAAA,KAC3B;AAAA,GACF,CAAA;AAEA,EAAM,MAAA,aAAA,GAAgB,CAAC,KAAyC,KAAA;AA5HlE,IAAA,IAAA,EAAA,EAAA,EAAA,CAAA;AA6HI,IAAA,IACE,KAAM,CAAA,GAAA,CAAI,MAAW,KAAA,CAAA,IACrB,CAAC,KAAA,CAAM,OACP,IAAA,CAAC,KAAM,CAAA,OAAA,IACP,CAAC,KAAA,CAAM,MACP,EAAA;AACA,MAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,MAAA,KAAA,CAAM,eAAgB,EAAA,CAAA;AACtB,MAAA,eAAA,CAAgB,KAAK,CAAA,CAAA;AAAA,KACvB;AAEA,IAAM,MAAA,YAAA,GAAe,WAAe,IAAA,IAAA,GAAA,WAAA,GAAA,cAAA,EAAiB,CAAA,IAAA,CAAA;AAErD,IAAI,IAAA,SAAA,CAAA;AACJ,IAAA,QAAQ,KAAM,CAAA,GAAA;AAAA,MACP,KAAA,WAAA;AACH,QAAA,SAAA,GAAA,CAAY,EAAe,GAAA,cAAA,CAAA,YAAY,CAA3B,KAAA,IAAA,GAAA,EAAA,GAAgC,aAAc,EAAA,CAAA;AAC1D,QAAA,MAAA;AAAA,MACG,KAAA,SAAA;AACH,QAAA,SAAA,GAAA,CAAY,EAAgB,GAAA,eAAA,CAAA,YAAY,CAA5B,KAAA,IAAA,GAAA,EAAA,GAAiC,cAAe,EAAA,CAAA;AAC5D,QAAA,MAAA;AAAA,MACG,KAAA,MAAA;AACH,QAAA,SAAA,GAAY,cAAe,EAAA,CAAA;AAC3B,QAAA,MAAA;AAAA,MACG,KAAA,KAAA;AACH,QAAA,SAAA,GAAY,aAAc,EAAA,CAAA;AAC1B,QAAA,MAAA;AAAA,MACG,KAAA,QAAA;AACH,QAAA,SAAA,GAAY,mBAAmB,YAAY,CAAA,CAAA;AAC3C,QAAA,MAAA;AAAA,MACG,KAAA,UAAA;AACH,QAAA,SAAA,GAAY,mBAAmB,YAAY,CAAA,CAAA;AAC3C,QAAA,MAAA;AAAA,MACG,KAAA,OAAA,CAAA;AAAA,MACA,KAAA,GAAA;AACH,QAAA,IACE,OAAQ,CAAA,WAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,WAAA,CAAa,QAAQ,CAAA,IAC5B,eAAgB,CAAA,OAAA,CAAQ,IAAK,EAAA,CAAE,MAAS,GAAA,CAAA,IAAK,KAAM,CAAA,GAAA,KAAQ,GAC5D,EAAA;AACA,UAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,UAAA,OAAA;AAAA,SACF;AAEA,QAAA,IAAI,CAAC,WAAa,EAAA;AAChB,UAAA,OAAA;AAAA,SACF;AAEA,QAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,QAAA,MAAA,CAAO,OAAO,WAAW,CAAA,CAAA;AAEzB,QAAA,MAAA;AAAA,KAAA;AAGJ,IAAA,IAAI,SAAa,IAAA,SAAA,CAAU,IAAK,CAAA,EAAA,KAAM,2CAAa,EAAI,CAAA,EAAA;AACrD,MAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AACrB,MAAA,SAAA,CAAU,UAAU,IAAI,CAAA,CAAA;AACxB,MAAA,oBAAA,CAAqB,IAAI,CAAA,CAAA;AAAA,KAC3B;AAEA,IAAY,SAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,SAAA,CAAA,KAAA,CAAA,CAAA;AAAA,GACd,CAAA;AAEA,EAAM,MAAA,YAAA,GAAeA,aAAO,KAAK,CAAA,CAAA;AAEjC,EAAA,MAAM,kBAAkB,MAAM;AAC5B,IAAA,YAAA,CAAa,OAAU,GAAA,IAAA,CAAA;AAAA,GACzB,CAAA;AAEA,EAAM,MAAA,WAAA,GAAc,CAAC,KAAsC,KAAA;AACzD,IAAA,IAAI,aAAa,OAAS,EAAA;AACxB,MAAA,YAAA,CAAa,OAAU,GAAA,KAAA,CAAA;AACvB,MAAA,OAAA;AAAA,KACF;AAEA,IAAA,oBAAA,CAAqB,IAAI,CAAA,CAAA;AACzB,IAAA,YAAA,CAAa,OAAU,GAAA,KAAA,CAAA;AAGvB,IAAA,MAAM,WAAc,GAAA,WAAA,GAAc,gBAAiB,CAAA,WAAW,CAAI,GAAA,CAAA,CAAA,CAAA;AAClE,IAAA,IAAI,SAAY,GAAA,KAAA,CAAA,CAAA;AAGhB,IAAA,IAAI,cAAc,CAAG,EAAA;AACnB,MAAA,OAAA;AAAA,KACF;AAGA,IAAI,IAAA,aAAA,CAAc,SAAS,CAAG,EAAA;AAC5B,MAAY,SAAA,GAAA,kBAAA;AAAA,QACV,CAAC,MAAA,KAAW,MAAO,CAAA,KAAA,KAAU,aAAc,CAAA,CAAA,CAAA;AAAA,QAC3C,GAAI,EAAA,CAAA;AAAA,KACR;AAGA,IAAA,IAAI,CAAC,SAAW,EAAA;AACd,MAAA,SAAA,GAAY,iBAAiB,CAAC,CAAA,CAAA;AAAA,KAChC;AAEA,IAAA,SAAA,CAAU,uCAAW,IAAI,CAAA,CAAA;AACzB,IAAA,eAAA,CAAgB,IAAI,CAAA,CAAA;AACpB,IAAU,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,CAAA,KAAA,CAAA,CAAA;AAAA,GACZ,CAAA;AAEA,EAAM,MAAA,UAAA,GAAa,CAAC,KAAsC,KAAA;AACxD,IAAA,eAAA,CAAgB,KAAK,CAAA,CAAA;AACrB,IAAA,SAAA,CAAU,KAAS,CAAA,CAAA,CAAA;AACnB,IAAS,MAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,MAAA,CAAA,KAAA,CAAA,CAAA;AAAA,GACX,CAAA;AAEA,EAAA,MAAM,sBAAsB,MAAM;AAChC,IAAA,oBAAA,CAAqB,KAAK,CAAA,CAAA;AAC1B,IAAA,SAAA,CAAU,KAAS,CAAA,CAAA,CAAA;AAAA,GACrB,CAAA;AAEA,EAAM,MAAA,SAAA,GAAYC,qBAAW,CAAA,OAAA,EAAS,GAAG,CAAA,CAAA;AAEzC,EACE,uBAAAC,cAAA,CAACC,sCAAmB,QAAnB,EAAA;AAAA,IAA4B,KAAO,EAAA,WAAA;AAAA,IAClC,QAAC,kBAAAD,cAAA,CAAA,KAAA,EAAA;AAAA,MACC,SAAW,EAAAE,SAAA;AAAA,QACT,YAAa,EAAA;AAAA,QACb,EAAE,CAAC,YAAa,CAAA,UAAU,IAAI,QAAS,EAAA;AAAA,QACvC,SAAA;AAAA,OACF;AAAA,MACA,IAAK,EAAA,SAAA;AAAA,MACL,yBAAuB,WAAa,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,WAAA,CAAA,EAAA;AAAA,MACpC,iBAAe,QAAY,IAAA,KAAA,CAAA;AAAA,MAC3B,sBAAsB,EAAA,WAAA;AAAA,MACtB,QAAA,EAAU,WAAW,CAAK,CAAA,GAAA,CAAA;AAAA,MAC1B,SAAW,EAAA,aAAA;AAAA,MACX,MAAQ,EAAA,UAAA;AAAA,MACR,OAAS,EAAA,WAAA;AAAA,MACT,WAAa,EAAA,mBAAA;AAAA,MACb,WAAa,EAAA,eAAA;AAAA,MACb,GAAK,EAAA,SAAA;AAAA,MACJ,GAAG,IAAA;AAAA,MAEH,QAAA;AAAA,KACH,CAAA;AAAA,GACF,CAAA,CAAA;AAEJ,CAAC;;;;"}
@@ -37,6 +37,7 @@ require('../dialog/DialogActions.js');
37
37
  require('../dialog/DialogContent.js');
38
38
  require('../dialog/DialogContext.js');
39
39
  require('../dialog/DialogCloseButton.js');
40
+ require('../divider/Divider.js');
40
41
  require('../drawer/Drawer.js');
41
42
  require('../drawer/DrawerCloseButton.js');
42
43
  require('../dropdown/Dropdown.js');
@@ -64,6 +65,7 @@ require('../interactable-card/InteractableCardGroup.js');
64
65
  require('../interactable-card/InteractableCardGroupContext.js');
65
66
  require('../link/Link.js');
66
67
  require('../link-card/LinkCard.js');
68
+ require('../list-box/ListBox.js');
67
69
  require('../menu/MenuContext.js');
68
70
  require('@floating-ui/react');
69
71
  require('../menu/MenuItem.js');
@@ -100,6 +102,7 @@ require('../toast/Toast.js');
100
102
  require('../toast/ToastContent.js');
101
103
  require('../split-layout/SplitLayout.js');
102
104
  require('../switch/Switch.js');
105
+ require('../tag/Tag.js');
103
106
  require('../toggle-button/ToggleButton.js');
104
107
  require('../toggle-button-group/ToggleButtonGroup.js');
105
108
  require('../toggle-button-group/ToggleButtonGroupContext.js');
@@ -126,7 +129,8 @@ const ListControlContext = createContext.createContext(
126
129
  },
127
130
  multiselect: false,
128
131
  focusVisibleState: false,
129
- valueToString: ListControlState.defaultValueToString
132
+ valueToString: ListControlState.defaultValueToString,
133
+ disabled: false
130
134
  }
131
135
  );
132
136
  function useListControlContext() {
@@ -1 +1 @@
1
- {"version":3,"file":"ListControlContext.js","sources":["../src/list-control/ListControlContext.tsx"],"sourcesContent":["import { SyntheticEvent, useContext } from \"react\";\nimport { createContext } from \"../utils\";\nimport { defaultValueToString } from \"./ListControlState\";\n\nexport interface OptionValue<Item> {\n id: string;\n disabled: boolean;\n value: Item;\n}\n\nexport type OpenChangeReason = \"input\" | \"manual\";\n\nexport interface ListControlContextValue<Item> {\n openState: boolean;\n setOpen: (newOpen: boolean, openChangeReason?: OpenChangeReason) => void;\n register: (\n optionValue: OptionValue<Item>,\n element: HTMLElement\n ) => () => void;\n selectedState: unknown[];\n select: (event: SyntheticEvent, option: OptionValue<Item>) => void;\n activeState?: OptionValue<Item>;\n setActive: (option: OptionValue<Item>) => void;\n multiselect: boolean;\n focusVisibleState: boolean;\n valueToString: (item: Item) => string;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Need to use any here as a winder type but it gets narrowed when using the useListControl hook.\nexport const ListControlContext = createContext<ListControlContextValue<any>>(\n \"ListControlContext\",\n {\n openState: false,\n setOpen() {\n return undefined;\n },\n register() {\n return () => undefined;\n },\n selectedState: [],\n select() {\n return undefined;\n },\n activeState: undefined,\n setActive() {\n return undefined;\n },\n multiselect: false,\n focusVisibleState: false,\n valueToString: defaultValueToString,\n }\n);\n\nexport function useListControlContext<Item>() {\n return useContext(ListControlContext) as ListControlContextValue<Item>;\n}\n"],"names":["createContext","defaultValueToString","useContext"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA6BO,MAAM,kBAAqB,GAAAA,2BAAA;AAAA,EAChC,oBAAA;AAAA,EACA;AAAA,IACE,SAAW,EAAA,KAAA;AAAA,IACX,OAAU,GAAA;AACR,MAAO,OAAA,KAAA,CAAA,CAAA;AAAA,KACT;AAAA,IACA,QAAW,GAAA;AACT,MAAA,OAAO,MAAM,KAAA,CAAA,CAAA;AAAA,KACf;AAAA,IACA,eAAe,EAAC;AAAA,IAChB,MAAS,GAAA;AACP,MAAO,OAAA,KAAA,CAAA,CAAA;AAAA,KACT;AAAA,IACA,WAAa,EAAA,KAAA,CAAA;AAAA,IACb,SAAY,GAAA;AACV,MAAO,OAAA,KAAA,CAAA,CAAA;AAAA,KACT;AAAA,IACA,WAAa,EAAA,KAAA;AAAA,IACb,iBAAmB,EAAA,KAAA;AAAA,IACnB,aAAe,EAAAC,qCAAA;AAAA,GACjB;AACF,EAAA;AAEO,SAAS,qBAA8B,GAAA;AAC5C,EAAA,OAAOC,iBAAW,kBAAkB,CAAA,CAAA;AACtC;;;;;"}
1
+ {"version":3,"file":"ListControlContext.js","sources":["../src/list-control/ListControlContext.tsx"],"sourcesContent":["import { SyntheticEvent, useContext } from \"react\";\nimport { createContext } from \"../utils\";\nimport { defaultValueToString } from \"./ListControlState\";\n\nexport interface OptionValue<Item> {\n id: string;\n disabled: boolean;\n value: Item;\n}\n\nexport type OpenChangeReason = \"input\" | \"manual\";\n\nexport interface ListControlContextValue<Item> {\n openState: boolean;\n setOpen: (newOpen: boolean, openChangeReason?: OpenChangeReason) => void;\n register: (\n optionValue: OptionValue<Item>,\n element: HTMLElement\n ) => () => void;\n selectedState: unknown[];\n select: (event: SyntheticEvent, option: OptionValue<Item>) => void;\n activeState?: OptionValue<Item>;\n setActive: (option: OptionValue<Item>) => void;\n multiselect: boolean;\n focusVisibleState: boolean;\n valueToString: (item: Item) => string;\n disabled?: boolean;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Need to use any here as a winder type but it gets narrowed when using the useListControl hook.\nexport const ListControlContext = createContext<ListControlContextValue<any>>(\n \"ListControlContext\",\n {\n openState: false,\n setOpen() {\n return undefined;\n },\n register() {\n return () => undefined;\n },\n selectedState: [],\n select() {\n return undefined;\n },\n activeState: undefined,\n setActive() {\n return undefined;\n },\n multiselect: false,\n focusVisibleState: false,\n valueToString: defaultValueToString,\n disabled: false,\n }\n);\n\nexport function useListControlContext<Item>() {\n return useContext(ListControlContext) as ListControlContextValue<Item>;\n}\n"],"names":["createContext","defaultValueToString","useContext"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA8BO,MAAM,kBAAqB,GAAAA,2BAAA;AAAA,EAChC,oBAAA;AAAA,EACA;AAAA,IACE,SAAW,EAAA,KAAA;AAAA,IACX,OAAU,GAAA;AACR,MAAO,OAAA,KAAA,CAAA,CAAA;AAAA,KACT;AAAA,IACA,QAAW,GAAA;AACT,MAAA,OAAO,MAAM,KAAA,CAAA,CAAA;AAAA,KACf;AAAA,IACA,eAAe,EAAC;AAAA,IAChB,MAAS,GAAA;AACP,MAAO,OAAA,KAAA,CAAA,CAAA;AAAA,KACT;AAAA,IACA,WAAa,EAAA,KAAA,CAAA;AAAA,IACb,SAAY,GAAA;AACV,MAAO,OAAA,KAAA,CAAA,CAAA;AAAA,KACT;AAAA,IACA,WAAa,EAAA,KAAA;AAAA,IACb,iBAAmB,EAAA,KAAA;AAAA,IACnB,aAAe,EAAAC,qCAAA;AAAA,IACf,QAAU,EAAA,KAAA;AAAA,GACZ;AACF,EAAA;AAEO,SAAS,qBAA8B,GAAA;AAC5C,EAAA,OAAOC,iBAAW,kBAAkB,CAAA,CAAA;AACtC;;;;;"}