@salt-ds/core 1.20.0 → 1.22.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 (440) hide show
  1. package/css/salt-core.css +474 -19
  2. package/dist-cjs/accordion/Accordion.js +77 -0
  3. package/dist-cjs/accordion/Accordion.js.map +1 -1
  4. package/dist-cjs/accordion/AccordionContext.js +81 -0
  5. package/dist-cjs/accordion/AccordionContext.js.map +1 -1
  6. package/dist-cjs/accordion/AccordionGroup.js +78 -1
  7. package/dist-cjs/accordion/AccordionGroup.js.map +1 -1
  8. package/dist-cjs/accordion/AccordionHeader.js +75 -0
  9. package/dist-cjs/accordion/AccordionHeader.js.map +1 -1
  10. package/dist-cjs/accordion/AccordionPanel.js +77 -0
  11. package/dist-cjs/accordion/AccordionPanel.js.map +1 -1
  12. package/dist-cjs/aria-announcer/useAriaAnnouncer.js +80 -0
  13. package/dist-cjs/aria-announcer/useAriaAnnouncer.js.map +1 -1
  14. package/dist-cjs/avatar/Avatar.js +76 -0
  15. package/dist-cjs/avatar/Avatar.js.map +1 -1
  16. package/dist-cjs/avatar/useAvatarImage.js +81 -0
  17. package/dist-cjs/avatar/useAvatarImage.js.map +1 -1
  18. package/dist-cjs/badge/Badge.js +77 -0
  19. package/dist-cjs/badge/Badge.js.map +1 -1
  20. package/dist-cjs/banner/Banner.js +78 -2
  21. package/dist-cjs/banner/Banner.js.map +1 -1
  22. package/dist-cjs/banner/BannerActions.js +78 -1
  23. package/dist-cjs/banner/BannerActions.js.map +1 -1
  24. package/dist-cjs/banner/BannerContent.js +78 -1
  25. package/dist-cjs/banner/BannerContent.js.map +1 -1
  26. package/dist-cjs/border-item/BorderItem.js +77 -1
  27. package/dist-cjs/border-item/BorderItem.js.map +1 -1
  28. package/dist-cjs/border-layout/BorderLayout.js +78 -0
  29. package/dist-cjs/border-layout/BorderLayout.js.map +1 -1
  30. package/dist-cjs/button/Button.js +78 -1
  31. package/dist-cjs/button/Button.js.map +1 -1
  32. package/dist-cjs/card/Card.js +77 -0
  33. package/dist-cjs/card/Card.js.map +1 -1
  34. package/dist-cjs/card/InteractableCard.js +77 -0
  35. package/dist-cjs/card/InteractableCard.js.map +1 -1
  36. package/dist-cjs/checkbox/Checkbox.js +75 -0
  37. package/dist-cjs/checkbox/Checkbox.js.map +1 -1
  38. package/dist-cjs/checkbox/CheckboxGroup.js +76 -0
  39. package/dist-cjs/checkbox/CheckboxGroup.js.map +1 -1
  40. package/dist-cjs/checkbox/CheckboxIcon.js +77 -0
  41. package/dist-cjs/checkbox/CheckboxIcon.js.map +1 -1
  42. package/dist-cjs/checkbox/internal/CheckboxGroupContext.js +81 -0
  43. package/dist-cjs/checkbox/internal/CheckboxGroupContext.js.map +1 -1
  44. package/dist-cjs/combo-box/ComboBox.css.js +6 -0
  45. package/dist-cjs/combo-box/ComboBox.css.js.map +1 -0
  46. package/dist-cjs/combo-box/ComboBox.js +445 -0
  47. package/dist-cjs/combo-box/ComboBox.js.map +1 -0
  48. package/dist-cjs/combo-box/useComboBox.js +155 -0
  49. package/dist-cjs/combo-box/useComboBox.js.map +1 -0
  50. package/dist-cjs/dialog/Dialog.js +79 -3
  51. package/dist-cjs/dialog/Dialog.js.map +1 -1
  52. package/dist-cjs/dialog/DialogActions.js +78 -1
  53. package/dist-cjs/dialog/DialogActions.js.map +1 -1
  54. package/dist-cjs/dialog/DialogCloseButton.js +76 -1
  55. package/dist-cjs/dialog/DialogCloseButton.js.map +1 -1
  56. package/dist-cjs/dialog/DialogContent.js +78 -1
  57. package/dist-cjs/dialog/DialogContent.js.map +1 -1
  58. package/dist-cjs/dialog/DialogHeader.css.js +1 -1
  59. package/dist-cjs/dialog/DialogHeader.js +124 -51
  60. package/dist-cjs/dialog/DialogHeader.js.map +1 -1
  61. package/dist-cjs/drawer/Drawer.js +79 -4
  62. package/dist-cjs/drawer/Drawer.js.map +1 -1
  63. package/dist-cjs/drawer/DrawerCloseButton.js +76 -1
  64. package/dist-cjs/drawer/DrawerCloseButton.js.map +1 -1
  65. package/dist-cjs/dropdown/Dropdown.css.js +6 -0
  66. package/dist-cjs/dropdown/Dropdown.css.js.map +1 -0
  67. package/dist-cjs/dropdown/Dropdown.js +414 -0
  68. package/dist-cjs/dropdown/Dropdown.js.map +1 -0
  69. package/dist-cjs/file-drop-zone/FileDropZone.js +77 -0
  70. package/dist-cjs/file-drop-zone/FileDropZone.js.map +1 -1
  71. package/dist-cjs/file-drop-zone/FileDropZoneTrigger.js +78 -0
  72. package/dist-cjs/file-drop-zone/FileDropZoneTrigger.js.map +1 -1
  73. package/dist-cjs/flex-item/FlexItem.js +81 -2
  74. package/dist-cjs/flex-item/FlexItem.js.map +1 -1
  75. package/dist-cjs/flex-layout/FlexLayout.js +81 -2
  76. package/dist-cjs/flex-layout/FlexLayout.js.map +1 -1
  77. package/dist-cjs/form-field/FormField.js +76 -0
  78. package/dist-cjs/form-field/FormField.js.map +1 -1
  79. package/dist-cjs/form-field/FormFieldHelperText.js +73 -3
  80. package/dist-cjs/form-field/FormFieldHelperText.js.map +1 -1
  81. package/dist-cjs/form-field/FormFieldLabel.js +72 -1
  82. package/dist-cjs/form-field/FormFieldLabel.js.map +1 -1
  83. package/dist-cjs/form-field-context/FormFieldContext.js +80 -0
  84. package/dist-cjs/form-field-context/FormFieldContext.js.map +1 -1
  85. package/dist-cjs/grid-item/GridItem.js +81 -2
  86. package/dist-cjs/grid-item/GridItem.js.map +1 -1
  87. package/dist-cjs/grid-layout/GridLayout.js +81 -2
  88. package/dist-cjs/grid-layout/GridLayout.js.map +1 -1
  89. package/dist-cjs/index.js +20 -2
  90. package/dist-cjs/index.js.map +1 -1
  91. package/dist-cjs/input/Input.js +75 -0
  92. package/dist-cjs/input/Input.js.map +1 -1
  93. package/dist-cjs/link/Link.js +73 -3
  94. package/dist-cjs/link/Link.js.map +1 -1
  95. package/dist-cjs/link-card/LinkCard.js +77 -0
  96. package/dist-cjs/link-card/LinkCard.js.map +1 -1
  97. package/dist-cjs/list-control/ListControlContext.js +123 -0
  98. package/dist-cjs/list-control/ListControlContext.js.map +1 -0
  99. package/dist-cjs/list-control/ListControlState.js +278 -0
  100. package/dist-cjs/list-control/ListControlState.js.map +1 -0
  101. package/dist-cjs/multiline-input/MultilineInput.js +75 -0
  102. package/dist-cjs/multiline-input/MultilineInput.js.map +1 -1
  103. package/dist-cjs/navigation-item/NavigationItem.js +79 -2
  104. package/dist-cjs/navigation-item/NavigationItem.js.map +1 -1
  105. package/dist-cjs/option/Option.css.js +6 -0
  106. package/dist-cjs/option/Option.css.js.map +1 -0
  107. package/dist-cjs/option/Option.js +180 -0
  108. package/dist-cjs/option/Option.js.map +1 -0
  109. package/dist-cjs/option/OptionGroup.css.js +6 -0
  110. package/dist-cjs/option/OptionGroup.css.js.map +1 -0
  111. package/dist-cjs/option/OptionGroup.js +125 -0
  112. package/dist-cjs/option/OptionGroup.js.map +1 -0
  113. package/dist-cjs/option/OptionList.css.js +6 -0
  114. package/dist-cjs/option/OptionList.css.js.map +1 -0
  115. package/dist-cjs/option/OptionList.js +120 -0
  116. package/dist-cjs/option/OptionList.js.map +1 -0
  117. package/dist-cjs/option/OptionListBase.js +115 -0
  118. package/dist-cjs/option/OptionListBase.js.map +1 -0
  119. package/dist-cjs/pagination/CompactInput.js +78 -2
  120. package/dist-cjs/pagination/CompactInput.js.map +1 -1
  121. package/dist-cjs/pagination/CompactPaginator.js +72 -3
  122. package/dist-cjs/pagination/CompactPaginator.js.map +1 -1
  123. package/dist-cjs/pagination/GoToInput.js +71 -4
  124. package/dist-cjs/pagination/GoToInput.js.map +1 -1
  125. package/dist-cjs/pagination/PageButton.js +79 -2
  126. package/dist-cjs/pagination/PageButton.js.map +1 -1
  127. package/dist-cjs/pagination/PageRanges.js +80 -2
  128. package/dist-cjs/pagination/PageRanges.js.map +1 -1
  129. package/dist-cjs/pagination/Pagination.js +78 -2
  130. package/dist-cjs/pagination/Pagination.js.map +1 -1
  131. package/dist-cjs/pagination/Paginator.js +77 -2
  132. package/dist-cjs/pagination/Paginator.js.map +1 -1
  133. package/dist-cjs/panel/Panel.js +79 -2
  134. package/dist-cjs/panel/Panel.js.map +1 -1
  135. package/dist-cjs/pill/Pill.js +76 -0
  136. package/dist-cjs/pill/Pill.js.map +1 -1
  137. package/dist-cjs/pill-input/PillInput.css.js +6 -0
  138. package/dist-cjs/pill-input/PillInput.css.js.map +1 -0
  139. package/dist-cjs/pill-input/PillInput.js +340 -0
  140. package/dist-cjs/pill-input/PillInput.js.map +1 -0
  141. package/dist-cjs/pill-input/useTruncatePills.js +83 -0
  142. package/dist-cjs/pill-input/useTruncatePills.js.map +1 -0
  143. package/dist-cjs/progress/CircularProgress/CircularProgress.css.js +1 -1
  144. package/dist-cjs/progress/CircularProgress/CircularProgress.js +141 -15
  145. package/dist-cjs/progress/CircularProgress/CircularProgress.js.map +1 -1
  146. package/dist-cjs/progress/LinearProgress/LinearProgress.css.js +1 -1
  147. package/dist-cjs/progress/LinearProgress/LinearProgress.js +92 -9
  148. package/dist-cjs/progress/LinearProgress/LinearProgress.js.map +1 -1
  149. package/dist-cjs/radio-button/RadioButton.js +80 -4
  150. package/dist-cjs/radio-button/RadioButton.js.map +1 -1
  151. package/dist-cjs/radio-button/RadioButtonGroup.js +79 -3
  152. package/dist-cjs/radio-button/RadioButtonGroup.js.map +1 -1
  153. package/dist-cjs/radio-button/RadioButtonIcon.js +78 -0
  154. package/dist-cjs/radio-button/RadioButtonIcon.js.map +1 -1
  155. package/dist-cjs/radio-button/internal/RadioGroupContext.js +81 -0
  156. package/dist-cjs/radio-button/internal/RadioGroupContext.js.map +1 -1
  157. package/dist-cjs/salt-provider/SaltProvider.js +80 -3
  158. package/dist-cjs/salt-provider/SaltProvider.js.map +1 -1
  159. package/dist-cjs/scrim/Scrim.js +78 -1
  160. package/dist-cjs/scrim/Scrim.js.map +1 -1
  161. package/dist-cjs/spinner/Spinner.js +78 -2
  162. package/dist-cjs/spinner/Spinner.js.map +1 -1
  163. package/dist-cjs/spinner/svgSpinners/SpinnerSVG.js +80 -0
  164. package/dist-cjs/spinner/svgSpinners/SpinnerSVG.js.map +1 -1
  165. package/dist-cjs/split-layout/SplitLayout.js +78 -2
  166. package/dist-cjs/split-layout/SplitLayout.js.map +1 -1
  167. package/dist-cjs/stack-layout/StackLayout.js +80 -2
  168. package/dist-cjs/stack-layout/StackLayout.js.map +1 -1
  169. package/dist-cjs/status-adornment/StatusAdornment.js +77 -0
  170. package/dist-cjs/status-adornment/StatusAdornment.js.map +1 -1
  171. package/dist-cjs/status-indicator/StatusIndicator.js +78 -2
  172. package/dist-cjs/status-indicator/StatusIndicator.js.map +1 -1
  173. package/dist-cjs/switch/Switch.js +77 -2
  174. package/dist-cjs/switch/Switch.js.map +1 -1
  175. package/dist-cjs/text/Code.js +21 -0
  176. package/dist-cjs/text/Code.js.map +1 -0
  177. package/dist-cjs/text/Text.css.js +1 -1
  178. package/dist-cjs/text/Text.js +79 -2
  179. package/dist-cjs/text/Text.js.map +1 -1
  180. package/dist-cjs/toast/Toast.js +76 -0
  181. package/dist-cjs/toast/Toast.js.map +1 -1
  182. package/dist-cjs/toast/ToastContent.js +77 -0
  183. package/dist-cjs/toast/ToastContent.js.map +1 -1
  184. package/dist-cjs/toggle-button/ToggleButton.js +75 -0
  185. package/dist-cjs/toggle-button/ToggleButton.js.map +1 -1
  186. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js +76 -0
  187. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js.map +1 -1
  188. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js +80 -0
  189. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js.map +1 -1
  190. package/dist-cjs/tooltip/Tooltip.js +77 -1
  191. package/dist-cjs/tooltip/Tooltip.js.map +1 -1
  192. package/dist-cjs/tooltip/TooltipBase.js +77 -2
  193. package/dist-cjs/tooltip/TooltipBase.js.map +1 -1
  194. package/dist-cjs/tooltip/useAriaAnnounce.js +79 -0
  195. package/dist-cjs/tooltip/useAriaAnnounce.js.map +1 -1
  196. package/dist-cjs/tooltip/useTooltip.js +80 -0
  197. package/dist-cjs/tooltip/useTooltip.js.map +1 -1
  198. package/dist-cjs/utils/ownerWindow.js.map +1 -1
  199. package/dist-cjs/utils/useEventCallback.js +20 -0
  200. package/dist-cjs/utils/useEventCallback.js.map +1 -0
  201. package/dist-cjs/utils/useResizeObserver.js +29 -0
  202. package/dist-cjs/utils/useResizeObserver.js.map +1 -0
  203. package/dist-cjs/utils/useValueEffect.js +126 -0
  204. package/dist-cjs/utils/useValueEffect.js.map +1 -0
  205. package/dist-cjs/viewport/ViewportProvider.js +80 -0
  206. package/dist-cjs/viewport/ViewportProvider.js.map +1 -1
  207. package/dist-es/accordion/Accordion.js +77 -0
  208. package/dist-es/accordion/Accordion.js.map +1 -1
  209. package/dist-es/accordion/AccordionContext.js +81 -0
  210. package/dist-es/accordion/AccordionContext.js.map +1 -1
  211. package/dist-es/accordion/AccordionGroup.js +78 -1
  212. package/dist-es/accordion/AccordionGroup.js.map +1 -1
  213. package/dist-es/accordion/AccordionHeader.js +75 -0
  214. package/dist-es/accordion/AccordionHeader.js.map +1 -1
  215. package/dist-es/accordion/AccordionPanel.js +77 -0
  216. package/dist-es/accordion/AccordionPanel.js.map +1 -1
  217. package/dist-es/aria-announcer/useAriaAnnouncer.js +80 -0
  218. package/dist-es/aria-announcer/useAriaAnnouncer.js.map +1 -1
  219. package/dist-es/avatar/Avatar.js +76 -0
  220. package/dist-es/avatar/Avatar.js.map +1 -1
  221. package/dist-es/avatar/useAvatarImage.js +81 -0
  222. package/dist-es/avatar/useAvatarImage.js.map +1 -1
  223. package/dist-es/badge/Badge.js +77 -0
  224. package/dist-es/badge/Badge.js.map +1 -1
  225. package/dist-es/banner/Banner.js +78 -2
  226. package/dist-es/banner/Banner.js.map +1 -1
  227. package/dist-es/banner/BannerActions.js +78 -1
  228. package/dist-es/banner/BannerActions.js.map +1 -1
  229. package/dist-es/banner/BannerContent.js +78 -1
  230. package/dist-es/banner/BannerContent.js.map +1 -1
  231. package/dist-es/border-item/BorderItem.js +77 -1
  232. package/dist-es/border-item/BorderItem.js.map +1 -1
  233. package/dist-es/border-layout/BorderLayout.js +78 -0
  234. package/dist-es/border-layout/BorderLayout.js.map +1 -1
  235. package/dist-es/button/Button.js +78 -1
  236. package/dist-es/button/Button.js.map +1 -1
  237. package/dist-es/card/Card.js +77 -0
  238. package/dist-es/card/Card.js.map +1 -1
  239. package/dist-es/card/InteractableCard.js +77 -0
  240. package/dist-es/card/InteractableCard.js.map +1 -1
  241. package/dist-es/checkbox/Checkbox.js +75 -0
  242. package/dist-es/checkbox/Checkbox.js.map +1 -1
  243. package/dist-es/checkbox/CheckboxGroup.js +76 -0
  244. package/dist-es/checkbox/CheckboxGroup.js.map +1 -1
  245. package/dist-es/checkbox/CheckboxIcon.js +77 -0
  246. package/dist-es/checkbox/CheckboxIcon.js.map +1 -1
  247. package/dist-es/checkbox/internal/CheckboxGroupContext.js +81 -0
  248. package/dist-es/checkbox/internal/CheckboxGroupContext.js.map +1 -1
  249. package/dist-es/combo-box/ComboBox.css.js +4 -0
  250. package/dist-es/combo-box/ComboBox.css.js.map +1 -0
  251. package/dist-es/combo-box/ComboBox.js +441 -0
  252. package/dist-es/combo-box/ComboBox.js.map +1 -0
  253. package/dist-es/combo-box/useComboBox.js +151 -0
  254. package/dist-es/combo-box/useComboBox.js.map +1 -0
  255. package/dist-es/dialog/Dialog.js +79 -3
  256. package/dist-es/dialog/Dialog.js.map +1 -1
  257. package/dist-es/dialog/DialogActions.js +78 -1
  258. package/dist-es/dialog/DialogActions.js.map +1 -1
  259. package/dist-es/dialog/DialogCloseButton.js +76 -1
  260. package/dist-es/dialog/DialogCloseButton.js.map +1 -1
  261. package/dist-es/dialog/DialogContent.js +78 -1
  262. package/dist-es/dialog/DialogContent.js.map +1 -1
  263. package/dist-es/dialog/DialogHeader.css.js +1 -1
  264. package/dist-es/dialog/DialogHeader.js +124 -51
  265. package/dist-es/dialog/DialogHeader.js.map +1 -1
  266. package/dist-es/drawer/Drawer.js +79 -4
  267. package/dist-es/drawer/Drawer.js.map +1 -1
  268. package/dist-es/drawer/DrawerCloseButton.js +76 -1
  269. package/dist-es/drawer/DrawerCloseButton.js.map +1 -1
  270. package/dist-es/dropdown/Dropdown.css.js +4 -0
  271. package/dist-es/dropdown/Dropdown.css.js.map +1 -0
  272. package/dist-es/dropdown/Dropdown.js +410 -0
  273. package/dist-es/dropdown/Dropdown.js.map +1 -0
  274. package/dist-es/file-drop-zone/FileDropZone.js +77 -0
  275. package/dist-es/file-drop-zone/FileDropZone.js.map +1 -1
  276. package/dist-es/file-drop-zone/FileDropZoneTrigger.js +78 -0
  277. package/dist-es/file-drop-zone/FileDropZoneTrigger.js.map +1 -1
  278. package/dist-es/flex-item/FlexItem.js +81 -2
  279. package/dist-es/flex-item/FlexItem.js.map +1 -1
  280. package/dist-es/flex-layout/FlexLayout.js +81 -2
  281. package/dist-es/flex-layout/FlexLayout.js.map +1 -1
  282. package/dist-es/form-field/FormField.js +76 -0
  283. package/dist-es/form-field/FormField.js.map +1 -1
  284. package/dist-es/form-field/FormFieldHelperText.js +73 -3
  285. package/dist-es/form-field/FormFieldHelperText.js.map +1 -1
  286. package/dist-es/form-field/FormFieldLabel.js +72 -1
  287. package/dist-es/form-field/FormFieldLabel.js.map +1 -1
  288. package/dist-es/form-field-context/FormFieldContext.js +80 -0
  289. package/dist-es/form-field-context/FormFieldContext.js.map +1 -1
  290. package/dist-es/grid-item/GridItem.js +81 -2
  291. package/dist-es/grid-item/GridItem.js.map +1 -1
  292. package/dist-es/grid-layout/GridLayout.js +81 -2
  293. package/dist-es/grid-layout/GridLayout.js.map +1 -1
  294. package/dist-es/index.js +10 -1
  295. package/dist-es/index.js.map +1 -1
  296. package/dist-es/input/Input.js +75 -0
  297. package/dist-es/input/Input.js.map +1 -1
  298. package/dist-es/link/Link.js +73 -3
  299. package/dist-es/link/Link.js.map +1 -1
  300. package/dist-es/link-card/LinkCard.js +77 -0
  301. package/dist-es/link-card/LinkCard.js.map +1 -1
  302. package/dist-es/list-control/ListControlContext.js +118 -0
  303. package/dist-es/list-control/ListControlContext.js.map +1 -0
  304. package/dist-es/list-control/ListControlState.js +273 -0
  305. package/dist-es/list-control/ListControlState.js.map +1 -0
  306. package/dist-es/multiline-input/MultilineInput.js +75 -0
  307. package/dist-es/multiline-input/MultilineInput.js.map +1 -1
  308. package/dist-es/navigation-item/NavigationItem.js +79 -2
  309. package/dist-es/navigation-item/NavigationItem.js.map +1 -1
  310. package/dist-es/option/Option.css.js +4 -0
  311. package/dist-es/option/Option.css.js.map +1 -0
  312. package/dist-es/option/Option.js +176 -0
  313. package/dist-es/option/Option.js.map +1 -0
  314. package/dist-es/option/OptionGroup.css.js +4 -0
  315. package/dist-es/option/OptionGroup.css.js.map +1 -0
  316. package/dist-es/option/OptionGroup.js +121 -0
  317. package/dist-es/option/OptionGroup.js.map +1 -0
  318. package/dist-es/option/OptionList.css.js +4 -0
  319. package/dist-es/option/OptionList.css.js.map +1 -0
  320. package/dist-es/option/OptionList.js +116 -0
  321. package/dist-es/option/OptionList.js.map +1 -0
  322. package/dist-es/option/OptionListBase.js +111 -0
  323. package/dist-es/option/OptionListBase.js.map +1 -0
  324. package/dist-es/pagination/CompactInput.js +78 -2
  325. package/dist-es/pagination/CompactInput.js.map +1 -1
  326. package/dist-es/pagination/CompactPaginator.js +72 -3
  327. package/dist-es/pagination/CompactPaginator.js.map +1 -1
  328. package/dist-es/pagination/GoToInput.js +71 -4
  329. package/dist-es/pagination/GoToInput.js.map +1 -1
  330. package/dist-es/pagination/PageButton.js +79 -2
  331. package/dist-es/pagination/PageButton.js.map +1 -1
  332. package/dist-es/pagination/PageRanges.js +80 -2
  333. package/dist-es/pagination/PageRanges.js.map +1 -1
  334. package/dist-es/pagination/Pagination.js +78 -2
  335. package/dist-es/pagination/Pagination.js.map +1 -1
  336. package/dist-es/pagination/Paginator.js +77 -2
  337. package/dist-es/pagination/Paginator.js.map +1 -1
  338. package/dist-es/panel/Panel.js +79 -2
  339. package/dist-es/panel/Panel.js.map +1 -1
  340. package/dist-es/pill/Pill.js +76 -0
  341. package/dist-es/pill/Pill.js.map +1 -1
  342. package/dist-es/pill-input/PillInput.css.js +4 -0
  343. package/dist-es/pill-input/PillInput.css.js.map +1 -0
  344. package/dist-es/pill-input/PillInput.js +336 -0
  345. package/dist-es/pill-input/PillInput.js.map +1 -0
  346. package/dist-es/pill-input/useTruncatePills.js +79 -0
  347. package/dist-es/pill-input/useTruncatePills.js.map +1 -0
  348. package/dist-es/progress/CircularProgress/CircularProgress.css.js +1 -1
  349. package/dist-es/progress/CircularProgress/CircularProgress.js +141 -15
  350. package/dist-es/progress/CircularProgress/CircularProgress.js.map +1 -1
  351. package/dist-es/progress/LinearProgress/LinearProgress.css.js +1 -1
  352. package/dist-es/progress/LinearProgress/LinearProgress.js +92 -9
  353. package/dist-es/progress/LinearProgress/LinearProgress.js.map +1 -1
  354. package/dist-es/radio-button/RadioButton.js +80 -4
  355. package/dist-es/radio-button/RadioButton.js.map +1 -1
  356. package/dist-es/radio-button/RadioButtonGroup.js +79 -3
  357. package/dist-es/radio-button/RadioButtonGroup.js.map +1 -1
  358. package/dist-es/radio-button/RadioButtonIcon.js +78 -0
  359. package/dist-es/radio-button/RadioButtonIcon.js.map +1 -1
  360. package/dist-es/radio-button/internal/RadioGroupContext.js +81 -0
  361. package/dist-es/radio-button/internal/RadioGroupContext.js.map +1 -1
  362. package/dist-es/salt-provider/SaltProvider.js +80 -3
  363. package/dist-es/salt-provider/SaltProvider.js.map +1 -1
  364. package/dist-es/scrim/Scrim.js +78 -1
  365. package/dist-es/scrim/Scrim.js.map +1 -1
  366. package/dist-es/spinner/Spinner.js +78 -2
  367. package/dist-es/spinner/Spinner.js.map +1 -1
  368. package/dist-es/spinner/svgSpinners/SpinnerSVG.js +80 -0
  369. package/dist-es/spinner/svgSpinners/SpinnerSVG.js.map +1 -1
  370. package/dist-es/split-layout/SplitLayout.js +78 -2
  371. package/dist-es/split-layout/SplitLayout.js.map +1 -1
  372. package/dist-es/stack-layout/StackLayout.js +80 -2
  373. package/dist-es/stack-layout/StackLayout.js.map +1 -1
  374. package/dist-es/status-adornment/StatusAdornment.js +77 -0
  375. package/dist-es/status-adornment/StatusAdornment.js.map +1 -1
  376. package/dist-es/status-indicator/StatusIndicator.js +78 -2
  377. package/dist-es/status-indicator/StatusIndicator.js.map +1 -1
  378. package/dist-es/switch/Switch.js +77 -2
  379. package/dist-es/switch/Switch.js.map +1 -1
  380. package/dist-es/text/Code.js +17 -0
  381. package/dist-es/text/Code.js.map +1 -0
  382. package/dist-es/text/Text.css.js +1 -1
  383. package/dist-es/text/Text.js +79 -2
  384. package/dist-es/text/Text.js.map +1 -1
  385. package/dist-es/toast/Toast.js +76 -0
  386. package/dist-es/toast/Toast.js.map +1 -1
  387. package/dist-es/toast/ToastContent.js +77 -0
  388. package/dist-es/toast/ToastContent.js.map +1 -1
  389. package/dist-es/toggle-button/ToggleButton.js +75 -0
  390. package/dist-es/toggle-button/ToggleButton.js.map +1 -1
  391. package/dist-es/toggle-button-group/ToggleButtonGroup.js +76 -0
  392. package/dist-es/toggle-button-group/ToggleButtonGroup.js.map +1 -1
  393. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js +80 -0
  394. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js.map +1 -1
  395. package/dist-es/tooltip/Tooltip.js +77 -1
  396. package/dist-es/tooltip/Tooltip.js.map +1 -1
  397. package/dist-es/tooltip/TooltipBase.js +77 -2
  398. package/dist-es/tooltip/TooltipBase.js.map +1 -1
  399. package/dist-es/tooltip/useAriaAnnounce.js +79 -0
  400. package/dist-es/tooltip/useAriaAnnounce.js.map +1 -1
  401. package/dist-es/tooltip/useTooltip.js +80 -0
  402. package/dist-es/tooltip/useTooltip.js.map +1 -1
  403. package/dist-es/utils/ownerWindow.js.map +1 -1
  404. package/dist-es/utils/useEventCallback.js +16 -0
  405. package/dist-es/utils/useEventCallback.js.map +1 -0
  406. package/dist-es/utils/useResizeObserver.js +25 -0
  407. package/dist-es/utils/useResizeObserver.js.map +1 -0
  408. package/dist-es/utils/useValueEffect.js +122 -0
  409. package/dist-es/utils/useValueEffect.js.map +1 -0
  410. package/dist-es/viewport/ViewportProvider.js +80 -0
  411. package/dist-es/viewport/ViewportProvider.js.map +1 -1
  412. package/dist-types/combo-box/ComboBox.d.ts +17 -0
  413. package/dist-types/combo-box/index.d.ts +1 -0
  414. package/dist-types/combo-box/useComboBox.d.ts +30 -0
  415. package/dist-types/dialog/DialogHeader.d.ts +2 -4
  416. package/dist-types/dropdown/Dropdown.d.ts +99 -0
  417. package/dist-types/dropdown/index.d.ts +1 -0
  418. package/dist-types/index.d.ts +4 -0
  419. package/dist-types/list-control/ListControlContext.d.ts +21 -0
  420. package/dist-types/list-control/ListControlState.d.ts +70 -0
  421. package/dist-types/list-control/index.d.ts +1 -0
  422. package/dist-types/option/Option.d.ts +16 -0
  423. package/dist-types/option/OptionGroup.d.ts +12 -0
  424. package/dist-types/option/OptionList.d.ts +5 -0
  425. package/dist-types/option/OptionListBase.d.ts +4 -0
  426. package/dist-types/option/index.d.ts +2 -0
  427. package/dist-types/pill-input/PillInput.d.ts +48 -0
  428. package/dist-types/pill-input/index.d.ts +1 -0
  429. package/dist-types/pill-input/useTruncatePills.d.ts +8 -0
  430. package/dist-types/progress/CircularProgress/CircularProgress.d.ts +5 -0
  431. package/dist-types/progress/LinearProgress/LinearProgress.d.ts +5 -0
  432. package/dist-types/text/Code.d.ts +2 -0
  433. package/dist-types/text/Text.d.ts +1 -1
  434. package/dist-types/text/index.d.ts +2 -1
  435. package/dist-types/utils/index.d.ts +3 -0
  436. package/dist-types/utils/ownerWindow.d.ts +1 -1
  437. package/dist-types/utils/useEventCallback.d.ts +4 -0
  438. package/dist-types/utils/useResizeObserver.d.ts +6 -0
  439. package/dist-types/utils/useValueEffect.d.ts +4 -0
  440. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"Input.js","sources":["../src/input/Input.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport {\n ChangeEvent,\n ComponentPropsWithoutRef,\n FocusEvent,\n forwardRef,\n InputHTMLAttributes,\n ReactNode,\n Ref,\n useState,\n} from \"react\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useFormFieldProps } from \"../form-field-context\";\nimport { makePrefixer, useControlled } from \"../utils\";\nimport { StatusAdornment } from \"../status-adornment\";\n\nimport inputCss from \"./Input.css\";\n\nconst withBaseName = makePrefixer(\"saltInput\");\n\nexport interface InputProps\n extends Omit<ComponentPropsWithoutRef<\"div\">, \"defaultValue\">,\n Pick<\n ComponentPropsWithoutRef<\"input\">,\n \"disabled\" | \"value\" | \"defaultValue\" | \"placeholder\"\n > {\n /**\n * The marker to use in an empty read only Input.\n * Use `''` to disable this feature. Defaults to '—'.\n */\n emptyReadOnlyMarker?: string;\n /**\n * End adornment component\n */\n endAdornment?: ReactNode;\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps?: InputHTMLAttributes<HTMLInputElement>;\n /**\n * Optional ref for the input component\n */\n inputRef?: Ref<HTMLInputElement>;\n /**\n * If `true`, the component is read only.\n */\n readOnly?: boolean;\n /**\n * Start adornment component\n */\n startAdornment?: ReactNode;\n /**\n * Alignment of text within container. Defaults to \"left\"\n */\n textAlign?: \"left\" | \"center\" | \"right\";\n /**\n * Validation status.\n */\n validationStatus?: \"error\" | \"warning\" | \"success\";\n /**\n * Styling variant. Defaults to \"primary\".\n */\n variant?: \"primary\" | \"secondary\";\n}\n\nexport const Input = forwardRef<HTMLDivElement, InputProps>(function Input(\n {\n \"aria-activedescendant\": ariaActiveDescendant,\n \"aria-expanded\": ariaExpanded,\n \"aria-owns\": ariaOwns,\n className: classNameProp,\n disabled,\n emptyReadOnlyMarker = \"—\",\n endAdornment,\n id,\n inputProps = {},\n inputRef,\n placeholder,\n readOnly: readOnlyProp,\n role,\n startAdornment,\n style,\n textAlign = \"left\",\n value: valueProp,\n defaultValue: defaultValueProp = valueProp === undefined ? \"\" : undefined,\n validationStatus: validationStatusProp,\n variant = \"primary\",\n ...other\n },\n ref\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-input\",\n css: inputCss,\n window: targetWindow,\n });\n\n const {\n a11yProps: {\n \"aria-describedby\": formFieldDescribedBy,\n \"aria-labelledby\": formFieldLabelledBy,\n } = {},\n disabled: formFieldDisabled,\n readOnly: formFieldReadOnly,\n necessity: formFieldRequired,\n validationStatus: formFieldValidationStatus,\n } = useFormFieldProps();\n\n const restA11yProps = {\n \"aria-activedescendant\": ariaActiveDescendant,\n \"aria-expanded\": ariaExpanded,\n \"aria-owns\": ariaOwns,\n };\n\n const isDisabled = disabled || formFieldDisabled;\n const isReadOnly = readOnlyProp || formFieldReadOnly;\n const validationStatus = formFieldValidationStatus ?? validationStatusProp;\n\n const [focused, setFocused] = useState(false);\n\n const isEmptyReadOnly = isReadOnly && !defaultValueProp && !valueProp;\n const defaultValue = isEmptyReadOnly ? emptyReadOnlyMarker : defaultValueProp;\n\n const {\n \"aria-describedby\": inputDescribedBy,\n \"aria-labelledby\": inputLabelledBy,\n onBlur,\n onChange,\n onFocus,\n required: inputPropsRequired,\n ...restInputProps\n } = inputProps;\n\n const isRequired = formFieldRequired\n ? [\"required\", \"asterisk\"].includes(formFieldRequired)\n : inputPropsRequired;\n\n const [value, setValue] = useControlled({\n controlled: valueProp,\n default: defaultValue,\n name: \"Input\",\n state: \"value\",\n });\n\n const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n const value = event.target.value;\n setValue(value);\n onChange?.(event);\n };\n\n const handleBlur = (event: FocusEvent<HTMLInputElement>) => {\n onBlur?.(event);\n setFocused(false);\n };\n\n const handleFocus = (event: FocusEvent<HTMLInputElement>) => {\n onFocus?.(event);\n setFocused(true);\n };\n\n const inputStyle = {\n \"--input-textAlign\": textAlign,\n ...style,\n };\n\n return (\n <div\n className={clsx(\n withBaseName(),\n withBaseName(variant),\n {\n [withBaseName(\"focused\")]: !isDisabled && focused,\n [withBaseName(\"disabled\")]: isDisabled,\n [withBaseName(\"readOnly\")]: isReadOnly,\n [withBaseName(validationStatus || \"\")]: validationStatus,\n },\n classNameProp\n )}\n ref={ref}\n style={inputStyle}\n {...other}\n >\n {startAdornment && (\n <div className={withBaseName(\"startAdornmentContainer\")}>\n {startAdornment}\n </div>\n )}\n <input\n aria-describedby={clsx(formFieldDescribedBy, inputDescribedBy)}\n aria-labelledby={clsx(formFieldLabelledBy, inputLabelledBy)}\n className={clsx(withBaseName(\"input\"), inputProps?.className)}\n disabled={isDisabled}\n id={id}\n readOnly={isReadOnly}\n ref={inputRef}\n role={role}\n tabIndex={isDisabled ? -1 : 0}\n onBlur={handleBlur}\n onChange={handleChange}\n onFocus={!isDisabled ? handleFocus : undefined}\n placeholder={placeholder}\n value={value}\n {...restA11yProps}\n {...restInputProps}\n required={isRequired}\n />\n {!isDisabled && !isReadOnly && validationStatus && (\n <StatusAdornment status={validationStatus} />\n )}\n {endAdornment && (\n <div className={withBaseName(\"endAdornmentContainer\")}>\n {endAdornment}\n </div>\n )}\n <div className={withBaseName(\"activationIndicator\")} />\n </div>\n );\n});\n"],"names":["makePrefixer","forwardRef","Input","useWindow","useComponentCssInjection","inputCss","useFormFieldProps","useState","useControlled","value","jsxs","clsx","jsx","StatusAdornment"],"mappings":"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"}
1
+ {"version":3,"file":"Input.js","sources":["../src/input/Input.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport {\n ChangeEvent,\n ComponentPropsWithoutRef,\n FocusEvent,\n forwardRef,\n InputHTMLAttributes,\n ReactNode,\n Ref,\n useState,\n} from \"react\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useFormFieldProps } from \"../form-field-context\";\nimport { makePrefixer, useControlled } from \"../utils\";\nimport { StatusAdornment } from \"../status-adornment\";\n\nimport inputCss from \"./Input.css\";\n\nconst withBaseName = makePrefixer(\"saltInput\");\n\nexport interface InputProps\n extends Omit<ComponentPropsWithoutRef<\"div\">, \"defaultValue\">,\n Pick<\n ComponentPropsWithoutRef<\"input\">,\n \"disabled\" | \"value\" | \"defaultValue\" | \"placeholder\"\n > {\n /**\n * The marker to use in an empty read only Input.\n * Use `''` to disable this feature. Defaults to '—'.\n */\n emptyReadOnlyMarker?: string;\n /**\n * End adornment component\n */\n endAdornment?: ReactNode;\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps?: InputHTMLAttributes<HTMLInputElement>;\n /**\n * Optional ref for the input component\n */\n inputRef?: Ref<HTMLInputElement>;\n /**\n * If `true`, the component is read only.\n */\n readOnly?: boolean;\n /**\n * Start adornment component\n */\n startAdornment?: ReactNode;\n /**\n * Alignment of text within container. Defaults to \"left\"\n */\n textAlign?: \"left\" | \"center\" | \"right\";\n /**\n * Validation status.\n */\n validationStatus?: \"error\" | \"warning\" | \"success\";\n /**\n * Styling variant. Defaults to \"primary\".\n */\n variant?: \"primary\" | \"secondary\";\n}\n\nexport const Input = forwardRef<HTMLDivElement, InputProps>(function Input(\n {\n \"aria-activedescendant\": ariaActiveDescendant,\n \"aria-expanded\": ariaExpanded,\n \"aria-owns\": ariaOwns,\n className: classNameProp,\n disabled,\n emptyReadOnlyMarker = \"—\",\n endAdornment,\n id,\n inputProps = {},\n inputRef,\n placeholder,\n readOnly: readOnlyProp,\n role,\n startAdornment,\n style,\n textAlign = \"left\",\n value: valueProp,\n defaultValue: defaultValueProp = valueProp === undefined ? \"\" : undefined,\n validationStatus: validationStatusProp,\n variant = \"primary\",\n ...other\n },\n ref\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-input\",\n css: inputCss,\n window: targetWindow,\n });\n\n const {\n a11yProps: {\n \"aria-describedby\": formFieldDescribedBy,\n \"aria-labelledby\": formFieldLabelledBy,\n } = {},\n disabled: formFieldDisabled,\n readOnly: formFieldReadOnly,\n necessity: formFieldRequired,\n validationStatus: formFieldValidationStatus,\n } = useFormFieldProps();\n\n const restA11yProps = {\n \"aria-activedescendant\": ariaActiveDescendant,\n \"aria-expanded\": ariaExpanded,\n \"aria-owns\": ariaOwns,\n };\n\n const isDisabled = disabled || formFieldDisabled;\n const isReadOnly = readOnlyProp || formFieldReadOnly;\n const validationStatus = formFieldValidationStatus ?? validationStatusProp;\n\n const [focused, setFocused] = useState(false);\n\n const isEmptyReadOnly = isReadOnly && !defaultValueProp && !valueProp;\n const defaultValue = isEmptyReadOnly ? emptyReadOnlyMarker : defaultValueProp;\n\n const {\n \"aria-describedby\": inputDescribedBy,\n \"aria-labelledby\": inputLabelledBy,\n onBlur,\n onChange,\n onFocus,\n required: inputPropsRequired,\n ...restInputProps\n } = inputProps;\n\n const isRequired = formFieldRequired\n ? [\"required\", \"asterisk\"].includes(formFieldRequired)\n : inputPropsRequired;\n\n const [value, setValue] = useControlled({\n controlled: valueProp,\n default: defaultValue,\n name: \"Input\",\n state: \"value\",\n });\n\n const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n const value = event.target.value;\n setValue(value);\n onChange?.(event);\n };\n\n const handleBlur = (event: FocusEvent<HTMLInputElement>) => {\n onBlur?.(event);\n setFocused(false);\n };\n\n const handleFocus = (event: FocusEvent<HTMLInputElement>) => {\n onFocus?.(event);\n setFocused(true);\n };\n\n const inputStyle = {\n \"--input-textAlign\": textAlign,\n ...style,\n };\n\n return (\n <div\n className={clsx(\n withBaseName(),\n withBaseName(variant),\n {\n [withBaseName(\"focused\")]: !isDisabled && focused,\n [withBaseName(\"disabled\")]: isDisabled,\n [withBaseName(\"readOnly\")]: isReadOnly,\n [withBaseName(validationStatus || \"\")]: validationStatus,\n },\n classNameProp\n )}\n ref={ref}\n style={inputStyle}\n {...other}\n >\n {startAdornment && (\n <div className={withBaseName(\"startAdornmentContainer\")}>\n {startAdornment}\n </div>\n )}\n <input\n aria-describedby={clsx(formFieldDescribedBy, inputDescribedBy)}\n aria-labelledby={clsx(formFieldLabelledBy, inputLabelledBy)}\n className={clsx(withBaseName(\"input\"), inputProps?.className)}\n disabled={isDisabled}\n id={id}\n readOnly={isReadOnly}\n ref={inputRef}\n role={role}\n tabIndex={isDisabled ? -1 : 0}\n onBlur={handleBlur}\n onChange={handleChange}\n onFocus={!isDisabled ? handleFocus : undefined}\n placeholder={placeholder}\n value={value}\n {...restA11yProps}\n {...restInputProps}\n required={isRequired}\n />\n {!isDisabled && !isReadOnly && validationStatus && (\n <StatusAdornment status={validationStatus} />\n )}\n {endAdornment && (\n <div className={withBaseName(\"endAdornmentContainer\")}>\n {endAdornment}\n </div>\n )}\n <div className={withBaseName(\"activationIndicator\")} />\n </div>\n );\n});\n"],"names":["makePrefixer","forwardRef","Input","useWindow","useComponentCssInjection","inputCss","useFormFieldProps","useState","useControlled","value","jsxs","clsx","jsx","StatusAdornment"],"mappings":"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"}
@@ -11,15 +11,85 @@ require('../utils/useFloatingUI/useFloatingUI.js');
11
11
  require('../utils/useId.js');
12
12
  require('../salt-provider/SaltProvider.js');
13
13
  require('../viewport/ViewportProvider.js');
14
+ require('../accordion/AccordionGroup.js');
15
+ require('../accordion/AccordionPanel.js');
16
+ require('../accordion/Accordion.js');
17
+ require('../accordion/AccordionHeader.js');
18
+ require('../aria-announcer/AriaAnnouncerContext.js');
19
+ require('../avatar/Avatar.js');
20
+ require('../badge/Badge.js');
21
+ require('../banner/Banner.js');
22
+ require('../banner/BannerActions.js');
23
+ require('../banner/BannerContent.js');
24
+ require('../border-item/BorderItem.js');
25
+ require('../border-layout/BorderLayout.js');
26
+ require('../button/Button.js');
27
+ require('../card/Card.js');
28
+ require('../card/InteractableCard.js');
29
+ require('../checkbox/Checkbox.js');
30
+ require('../checkbox/CheckboxGroup.js');
31
+ var styles = require('@salt-ds/styles');
32
+ var window = require('@salt-ds/window');
33
+ require('../combo-box/ComboBox.js');
34
+ require('../dialog/Dialog.js');
35
+ require('../dialog/DialogHeader.js');
36
+ require('../dialog/DialogActions.js');
37
+ require('../dialog/DialogContent.js');
38
+ require('../dialog/DialogContext.js');
39
+ require('../dialog/DialogCloseButton.js');
40
+ require('../drawer/Drawer.js');
41
+ require('../drawer/DrawerCloseButton.js');
42
+ require('../dropdown/Dropdown.js');
43
+ require('../file-drop-zone/FileDropZone.js');
44
+ require('../file-drop-zone/FileDropZoneIcon.js');
45
+ require('../file-drop-zone/FileDropZoneTrigger.js');
46
+ require('../flex-item/FlexItem.js');
47
+ require('../flex-layout/FlexLayout.js');
48
+ require('../flow-layout/FlowLayout.js');
49
+ require('../form-field/FormField.js');
50
+ require('../status-indicator/StatusIndicator.js');
14
51
  var Text = require('../text/Text.js');
52
+ require('../text/Code.js');
15
53
  require('../text/Display.js');
16
54
  require('../text/Headings.js');
17
55
  require('../text/Label.js');
18
- require('../text/TextNotation.js');
19
56
  require('../text/TextAction.js');
57
+ require('../text/TextNotation.js');
58
+ require('../form-field-context/FormFieldContext.js');
59
+ require('../grid-item/GridItem.js');
60
+ require('../grid-layout/GridLayout.js');
61
+ require('../input/Input.js');
62
+ require('../link-card/LinkCard.js');
63
+ require('../list-control/ListControlContext.js');
64
+ require('../multiline-input/MultilineInput.js');
65
+ require('../navigation-item/NavigationItem.js');
66
+ require('../option/Option.js');
67
+ require('../option/OptionGroup.js');
68
+ require('../pagination/Pagination.js');
69
+ require('../pagination/Paginator.js');
70
+ require('../pagination/CompactInput.js');
71
+ require('../pagination/CompactPaginator.js');
72
+ require('../pagination/GoToInput.js');
73
+ require('../panel/Panel.js');
74
+ require('../pill/Pill.js');
75
+ require('../progress/CircularProgress/CircularProgress.js');
76
+ require('../progress/LinearProgress/LinearProgress.js');
77
+ require('../radio-button/RadioButton.js');
78
+ require('../radio-button/RadioButtonGroup.js');
79
+ require('../scrim/Scrim.js');
80
+ require('../spinner/Spinner.js');
81
+ require('../stack-layout/StackLayout.js');
82
+ require('../status-adornment/StatusAdornment.js');
83
+ require('../toast/Toast.js');
84
+ require('../toast/ToastContent.js');
85
+ require('../split-layout/SplitLayout.js');
86
+ require('../switch/Switch.js');
87
+ require('../toggle-button/ToggleButton.js');
88
+ require('../toggle-button-group/ToggleButtonGroup.js');
89
+ require('../toggle-button-group/ToggleButtonGroupContext.js');
90
+ require('../tooltip/Tooltip.js');
91
+ require('@floating-ui/react');
20
92
  var Link$1 = require('./Link.css.js');
21
- var window = require('@salt-ds/window');
22
- var styles = require('@salt-ds/styles');
23
93
 
24
94
  const withBaseName = makePrefixer.makePrefixer("saltLink");
25
95
  const Link = React.forwardRef(function Link2({
@@ -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 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 {...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,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,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 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 {...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,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,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;;;;"}
@@ -13,6 +13,83 @@ require('../utils/useFloatingUI/useFloatingUI.js');
13
13
  require('../utils/useId.js');
14
14
  require('../salt-provider/SaltProvider.js');
15
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('../button/Button.js');
29
+ require('../card/Card.js');
30
+ require('../card/InteractableCard.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('../drawer/Drawer.js');
42
+ require('../drawer/DrawerCloseButton.js');
43
+ require('../dropdown/Dropdown.js');
44
+ require('../file-drop-zone/FileDropZone.js');
45
+ require('../file-drop-zone/FileDropZoneIcon.js');
46
+ require('../file-drop-zone/FileDropZoneTrigger.js');
47
+ require('../flex-item/FlexItem.js');
48
+ require('../flex-layout/FlexLayout.js');
49
+ require('../flow-layout/FlowLayout.js');
50
+ require('../form-field/FormField.js');
51
+ require('../status-indicator/StatusIndicator.js');
52
+ require('../text/Text.js');
53
+ require('../text/Code.js');
54
+ require('../text/Display.js');
55
+ require('../text/Headings.js');
56
+ require('../text/Label.js');
57
+ require('../text/TextAction.js');
58
+ require('../text/TextNotation.js');
59
+ require('../form-field-context/FormFieldContext.js');
60
+ require('../grid-item/GridItem.js');
61
+ require('../grid-layout/GridLayout.js');
62
+ require('../input/Input.js');
63
+ require('../link/Link.js');
64
+ require('../list-control/ListControlContext.js');
65
+ require('../multiline-input/MultilineInput.js');
66
+ require('../navigation-item/NavigationItem.js');
67
+ require('../option/Option.js');
68
+ require('../option/OptionGroup.js');
69
+ require('../pagination/Pagination.js');
70
+ require('../pagination/Paginator.js');
71
+ require('../pagination/CompactInput.js');
72
+ require('../pagination/CompactPaginator.js');
73
+ require('../pagination/GoToInput.js');
74
+ require('../panel/Panel.js');
75
+ require('../pill/Pill.js');
76
+ require('../progress/CircularProgress/CircularProgress.js');
77
+ require('../progress/LinearProgress/LinearProgress.js');
78
+ require('../radio-button/RadioButton.js');
79
+ require('../radio-button/RadioButtonGroup.js');
80
+ require('../scrim/Scrim.js');
81
+ require('../spinner/Spinner.js');
82
+ require('../stack-layout/StackLayout.js');
83
+ require('../status-adornment/StatusAdornment.js');
84
+ require('../toast/Toast.js');
85
+ require('../toast/ToastContent.js');
86
+ require('../split-layout/SplitLayout.js');
87
+ require('../switch/Switch.js');
88
+ require('../toggle-button/ToggleButton.js');
89
+ require('../toggle-button-group/ToggleButtonGroup.js');
90
+ require('../toggle-button-group/ToggleButtonGroupContext.js');
91
+ require('../tooltip/Tooltip.js');
92
+ require('@floating-ui/react');
16
93
  var LinkCard$1 = require('./LinkCard.css.js');
17
94
 
18
95
  const withBaseName = makePrefixer.makePrefixer("saltLinkCard");
@@ -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,123 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var React = require('react');
6
+ var createContext = require('../utils/createContext.js');
7
+ require('../utils/useFloatingUI/useFloatingUI.js');
8
+ require('../utils/useId.js');
9
+ require('../salt-provider/SaltProvider.js');
10
+ require('../viewport/ViewportProvider.js');
11
+ require('clsx');
12
+ require('../accordion/AccordionGroup.js');
13
+ require('../accordion/AccordionPanel.js');
14
+ require('../accordion/Accordion.js');
15
+ require('../accordion/AccordionHeader.js');
16
+ require('../aria-announcer/AriaAnnouncerContext.js');
17
+ require('react/jsx-runtime');
18
+ require('../avatar/Avatar.js');
19
+ require('../badge/Badge.js');
20
+ require('../banner/Banner.js');
21
+ require('../banner/BannerActions.js');
22
+ require('../banner/BannerContent.js');
23
+ require('../border-item/BorderItem.js');
24
+ require('../border-layout/BorderLayout.js');
25
+ require('../button/Button.js');
26
+ require('../card/Card.js');
27
+ require('../card/InteractableCard.js');
28
+ require('../checkbox/Checkbox.js');
29
+ require('../checkbox/CheckboxGroup.js');
30
+ require('@salt-ds/styles');
31
+ require('@salt-ds/window');
32
+ require('@salt-ds/icons');
33
+ require('../combo-box/ComboBox.js');
34
+ require('../dialog/Dialog.js');
35
+ require('../dialog/DialogHeader.js');
36
+ require('../dialog/DialogActions.js');
37
+ require('../dialog/DialogContent.js');
38
+ require('../dialog/DialogContext.js');
39
+ require('../dialog/DialogCloseButton.js');
40
+ require('../drawer/Drawer.js');
41
+ require('../drawer/DrawerCloseButton.js');
42
+ require('../dropdown/Dropdown.js');
43
+ require('../file-drop-zone/FileDropZone.js');
44
+ require('../file-drop-zone/FileDropZoneIcon.js');
45
+ require('../file-drop-zone/FileDropZoneTrigger.js');
46
+ require('../flex-item/FlexItem.js');
47
+ require('../flex-layout/FlexLayout.js');
48
+ require('../flow-layout/FlowLayout.js');
49
+ require('../form-field/FormField.js');
50
+ require('../status-indicator/StatusIndicator.js');
51
+ require('../text/Text.js');
52
+ require('../text/Code.js');
53
+ require('../text/Display.js');
54
+ require('../text/Headings.js');
55
+ require('../text/Label.js');
56
+ require('../text/TextAction.js');
57
+ require('../text/TextNotation.js');
58
+ require('../form-field-context/FormFieldContext.js');
59
+ require('../grid-item/GridItem.js');
60
+ require('../grid-layout/GridLayout.js');
61
+ require('../input/Input.js');
62
+ require('../link/Link.js');
63
+ require('../link-card/LinkCard.js');
64
+ require('../multiline-input/MultilineInput.js');
65
+ require('../navigation-item/NavigationItem.js');
66
+ require('../option/Option.js');
67
+ require('../option/OptionGroup.js');
68
+ require('../pagination/Pagination.js');
69
+ require('../pagination/Paginator.js');
70
+ require('../pagination/CompactInput.js');
71
+ require('../pagination/CompactPaginator.js');
72
+ require('../pagination/GoToInput.js');
73
+ require('../panel/Panel.js');
74
+ require('../pill/Pill.js');
75
+ require('../progress/CircularProgress/CircularProgress.js');
76
+ require('../progress/LinearProgress/LinearProgress.js');
77
+ require('../radio-button/RadioButton.js');
78
+ require('../radio-button/RadioButtonGroup.js');
79
+ require('../scrim/Scrim.js');
80
+ require('../spinner/Spinner.js');
81
+ require('../stack-layout/StackLayout.js');
82
+ require('../status-adornment/StatusAdornment.js');
83
+ require('../toast/Toast.js');
84
+ require('../toast/ToastContent.js');
85
+ require('../split-layout/SplitLayout.js');
86
+ require('../switch/Switch.js');
87
+ require('../toggle-button/ToggleButton.js');
88
+ require('../toggle-button-group/ToggleButtonGroup.js');
89
+ require('../toggle-button-group/ToggleButtonGroupContext.js');
90
+ require('../tooltip/Tooltip.js');
91
+ require('@floating-ui/react');
92
+ var ListControlState = require('./ListControlState.js');
93
+
94
+ const ListControlContext = createContext.createContext(
95
+ "ListControlContext",
96
+ {
97
+ openState: false,
98
+ setOpen() {
99
+ return void 0;
100
+ },
101
+ register() {
102
+ return () => void 0;
103
+ },
104
+ selectedState: [],
105
+ select() {
106
+ return void 0;
107
+ },
108
+ activeState: void 0,
109
+ setActive() {
110
+ return void 0;
111
+ },
112
+ multiselect: false,
113
+ focusVisibleState: false,
114
+ valueToString: ListControlState.defaultValueToString
115
+ }
116
+ );
117
+ function useListControlContext() {
118
+ return React.useContext(ListControlContext);
119
+ }
120
+
121
+ exports.ListControlContext = ListControlContext;
122
+ exports.useListControlContext = useListControlContext;
123
+ //# sourceMappingURL=ListControlContext.js.map
@@ -0,0 +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;;;;;"}