@salt-ds/core 1.23.0 → 1.25.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 (448) hide show
  1. package/css/salt-core.css +83 -10
  2. package/dist-cjs/accordion/Accordion.js +6 -1
  3. package/dist-cjs/accordion/Accordion.js.map +1 -1
  4. package/dist-cjs/accordion/AccordionContext.js +6 -1
  5. package/dist-cjs/accordion/AccordionContext.js.map +1 -1
  6. package/dist-cjs/accordion/AccordionGroup.js +6 -1
  7. package/dist-cjs/accordion/AccordionGroup.js.map +1 -1
  8. package/dist-cjs/accordion/AccordionHeader.js +7 -1
  9. package/dist-cjs/accordion/AccordionHeader.js.map +1 -1
  10. package/dist-cjs/accordion/AccordionPanel.js +6 -1
  11. package/dist-cjs/accordion/AccordionPanel.js.map +1 -1
  12. package/dist-cjs/aria-announcer/useAriaAnnouncer.js +6 -1
  13. package/dist-cjs/aria-announcer/useAriaAnnouncer.js.map +1 -1
  14. package/dist-cjs/avatar/Avatar.js +6 -1
  15. package/dist-cjs/avatar/Avatar.js.map +1 -1
  16. package/dist-cjs/avatar/useAvatarImage.js +6 -1
  17. package/dist-cjs/avatar/useAvatarImage.js.map +1 -1
  18. package/dist-cjs/badge/Badge.js +6 -1
  19. package/dist-cjs/badge/Badge.js.map +1 -1
  20. package/dist-cjs/banner/Banner.js +6 -1
  21. package/dist-cjs/banner/Banner.js.map +1 -1
  22. package/dist-cjs/banner/BannerActions.js +6 -1
  23. package/dist-cjs/banner/BannerActions.js.map +1 -1
  24. package/dist-cjs/banner/BannerContent.js +6 -1
  25. package/dist-cjs/banner/BannerContent.js.map +1 -1
  26. package/dist-cjs/border-item/BorderItem.js +6 -1
  27. package/dist-cjs/border-item/BorderItem.js.map +1 -1
  28. package/dist-cjs/border-layout/BorderLayout.js +6 -1
  29. package/dist-cjs/border-layout/BorderLayout.js.map +1 -1
  30. package/dist-cjs/button/Button.css.js +1 -1
  31. package/dist-cjs/button/Button.js +6 -1
  32. package/dist-cjs/button/Button.js.map +1 -1
  33. package/dist-cjs/card/Card.js +6 -1
  34. package/dist-cjs/card/Card.js.map +1 -1
  35. package/dist-cjs/checkbox/Checkbox.js +7 -2
  36. package/dist-cjs/checkbox/Checkbox.js.map +1 -1
  37. package/dist-cjs/checkbox/CheckboxGroup.js +6 -1
  38. package/dist-cjs/checkbox/CheckboxGroup.js.map +1 -1
  39. package/dist-cjs/checkbox/CheckboxIcon.js +6 -1
  40. package/dist-cjs/checkbox/CheckboxIcon.js.map +1 -1
  41. package/dist-cjs/checkbox/internal/CheckboxGroupContext.js +6 -1
  42. package/dist-cjs/checkbox/internal/CheckboxGroupContext.js.map +1 -1
  43. package/dist-cjs/combo-box/ComboBox.js +5 -0
  44. package/dist-cjs/combo-box/ComboBox.js.map +1 -1
  45. package/dist-cjs/combo-box/useComboBox.js +6 -1
  46. package/dist-cjs/combo-box/useComboBox.js.map +1 -1
  47. package/dist-cjs/dialog/Dialog.js +5 -0
  48. package/dist-cjs/dialog/Dialog.js.map +1 -1
  49. package/dist-cjs/dialog/DialogActions.js +6 -1
  50. package/dist-cjs/dialog/DialogActions.js.map +1 -1
  51. package/dist-cjs/dialog/DialogCloseButton.js +6 -1
  52. package/dist-cjs/dialog/DialogCloseButton.js.map +1 -1
  53. package/dist-cjs/dialog/DialogContent.js +6 -1
  54. package/dist-cjs/dialog/DialogContent.js.map +1 -1
  55. package/dist-cjs/dialog/DialogHeader.js +6 -1
  56. package/dist-cjs/dialog/DialogHeader.js.map +1 -1
  57. package/dist-cjs/drawer/Drawer.js +5 -0
  58. package/dist-cjs/drawer/Drawer.js.map +1 -1
  59. package/dist-cjs/drawer/DrawerCloseButton.js +6 -1
  60. package/dist-cjs/drawer/DrawerCloseButton.js.map +1 -1
  61. package/dist-cjs/dropdown/Dropdown.js +6 -1
  62. package/dist-cjs/dropdown/Dropdown.js.map +1 -1
  63. package/dist-cjs/file-drop-zone/FileDropZone.js +6 -1
  64. package/dist-cjs/file-drop-zone/FileDropZone.js.map +1 -1
  65. package/dist-cjs/file-drop-zone/FileDropZoneTrigger.js +6 -1
  66. package/dist-cjs/file-drop-zone/FileDropZoneTrigger.js.map +1 -1
  67. package/dist-cjs/flex-item/FlexItem.js +6 -1
  68. package/dist-cjs/flex-item/FlexItem.js.map +1 -1
  69. package/dist-cjs/flex-layout/FlexLayout.js +6 -1
  70. package/dist-cjs/flex-layout/FlexLayout.js.map +1 -1
  71. package/dist-cjs/form-field/FormField.js +6 -1
  72. package/dist-cjs/form-field/FormField.js.map +1 -1
  73. package/dist-cjs/form-field/FormFieldHelperText.js +6 -1
  74. package/dist-cjs/form-field/FormFieldHelperText.js.map +1 -1
  75. package/dist-cjs/form-field/FormFieldLabel.js +6 -1
  76. package/dist-cjs/form-field/FormFieldLabel.js.map +1 -1
  77. package/dist-cjs/form-field-context/FormFieldContext.js +6 -1
  78. package/dist-cjs/form-field-context/FormFieldContext.js.map +1 -1
  79. package/dist-cjs/grid-item/GridItem.js +6 -1
  80. package/dist-cjs/grid-item/GridItem.js.map +1 -1
  81. package/dist-cjs/grid-layout/GridLayout.js +6 -1
  82. package/dist-cjs/grid-layout/GridLayout.js.map +1 -1
  83. package/dist-cjs/index.js +12 -0
  84. package/dist-cjs/index.js.map +1 -1
  85. package/dist-cjs/input/Input.js +6 -1
  86. package/dist-cjs/input/Input.js.map +1 -1
  87. package/dist-cjs/interactable-card/InteractableCard.css.js +1 -1
  88. package/dist-cjs/interactable-card/InteractableCard.js +6 -1
  89. package/dist-cjs/interactable-card/InteractableCard.js.map +1 -1
  90. package/dist-cjs/interactable-card/InteractableCardGroup.js +6 -1
  91. package/dist-cjs/interactable-card/InteractableCardGroup.js.map +1 -1
  92. package/dist-cjs/interactable-card/InteractableCardGroupContext.js +6 -1
  93. package/dist-cjs/interactable-card/InteractableCardGroupContext.js.map +1 -1
  94. package/dist-cjs/link/Link.js +6 -1
  95. package/dist-cjs/link/Link.js.map +1 -1
  96. package/dist-cjs/link-card/LinkCard.css.js +1 -1
  97. package/dist-cjs/link-card/LinkCard.js +6 -1
  98. package/dist-cjs/link-card/LinkCard.js.map +1 -1
  99. package/dist-cjs/list-control/ListControlContext.js +6 -1
  100. package/dist-cjs/list-control/ListControlContext.js.map +1 -1
  101. package/dist-cjs/list-control/ListControlState.js +6 -1
  102. package/dist-cjs/list-control/ListControlState.js.map +1 -1
  103. package/dist-cjs/multiline-input/MultilineInput.js +6 -1
  104. package/dist-cjs/multiline-input/MultilineInput.js.map +1 -1
  105. package/dist-cjs/navigation-item/NavigationItem.js +6 -1
  106. package/dist-cjs/navigation-item/NavigationItem.js.map +1 -1
  107. package/dist-cjs/option/Option.js +6 -1
  108. package/dist-cjs/option/Option.js.map +1 -1
  109. package/dist-cjs/option/OptionGroup.js +6 -1
  110. package/dist-cjs/option/OptionGroup.js.map +1 -1
  111. package/dist-cjs/option/OptionList.js +6 -1
  112. package/dist-cjs/option/OptionList.js.map +1 -1
  113. package/dist-cjs/option/OptionListBase.js +6 -1
  114. package/dist-cjs/option/OptionListBase.js.map +1 -1
  115. package/dist-cjs/overlay/Overlay.js +165 -0
  116. package/dist-cjs/overlay/Overlay.js.map +1 -0
  117. package/dist-cjs/overlay/OverlayContext.js +128 -0
  118. package/dist-cjs/overlay/OverlayContext.js.map +1 -0
  119. package/dist-cjs/overlay/OverlayPanel.css.js +6 -0
  120. package/dist-cjs/overlay/OverlayPanel.css.js.map +1 -0
  121. package/dist-cjs/overlay/OverlayPanel.js +167 -0
  122. package/dist-cjs/overlay/OverlayPanel.js.map +1 -0
  123. package/dist-cjs/overlay/OverlayPanelCloseButton.css.js +6 -0
  124. package/dist-cjs/overlay/OverlayPanelCloseButton.css.js.map +1 -0
  125. package/dist-cjs/overlay/OverlayPanelCloseButton.js +130 -0
  126. package/dist-cjs/overlay/OverlayPanelCloseButton.js.map +1 -0
  127. package/dist-cjs/overlay/OverlayPanelContent.css.js +6 -0
  128. package/dist-cjs/overlay/OverlayPanelContent.css.js.map +1 -0
  129. package/dist-cjs/overlay/OverlayPanelContent.js +124 -0
  130. package/dist-cjs/overlay/OverlayPanelContent.js.map +1 -0
  131. package/dist-cjs/overlay/OverlayTrigger.js +124 -0
  132. package/dist-cjs/overlay/OverlayTrigger.js.map +1 -0
  133. package/dist-cjs/pagination/CompactInput.js +6 -1
  134. package/dist-cjs/pagination/CompactInput.js.map +1 -1
  135. package/dist-cjs/pagination/CompactPaginator.js +6 -1
  136. package/dist-cjs/pagination/CompactPaginator.js.map +1 -1
  137. package/dist-cjs/pagination/GoToInput.js +6 -1
  138. package/dist-cjs/pagination/GoToInput.js.map +1 -1
  139. package/dist-cjs/pagination/PageButton.js +6 -1
  140. package/dist-cjs/pagination/PageButton.js.map +1 -1
  141. package/dist-cjs/pagination/PageRanges.js +6 -1
  142. package/dist-cjs/pagination/PageRanges.js.map +1 -1
  143. package/dist-cjs/pagination/Pagination.js +6 -1
  144. package/dist-cjs/pagination/Pagination.js.map +1 -1
  145. package/dist-cjs/pagination/Paginator.js +6 -1
  146. package/dist-cjs/pagination/Paginator.js.map +1 -1
  147. package/dist-cjs/panel/Panel.js +6 -1
  148. package/dist-cjs/panel/Panel.js.map +1 -1
  149. package/dist-cjs/parent-child-layout/ParentChildLayout.css.js +6 -0
  150. package/dist-cjs/parent-child-layout/ParentChildLayout.css.js.map +1 -0
  151. package/dist-cjs/parent-child-layout/ParentChildLayout.js +157 -0
  152. package/dist-cjs/parent-child-layout/ParentChildLayout.js.map +1 -0
  153. package/dist-cjs/parent-child-layout/useIsViewportLargerThanBreakpoint.js +111 -0
  154. package/dist-cjs/parent-child-layout/useIsViewportLargerThanBreakpoint.js.map +1 -0
  155. package/dist-cjs/pill/Pill.js +7 -1
  156. package/dist-cjs/pill/Pill.js.map +1 -1
  157. package/dist-cjs/pill-input/PillInput.js +6 -1
  158. package/dist-cjs/pill-input/PillInput.js.map +1 -1
  159. package/dist-cjs/progress/CircularProgress/CircularProgress.js +6 -1
  160. package/dist-cjs/progress/CircularProgress/CircularProgress.js.map +1 -1
  161. package/dist-cjs/progress/LinearProgress/LinearProgress.js +8 -3
  162. package/dist-cjs/progress/LinearProgress/LinearProgress.js.map +1 -1
  163. package/dist-cjs/radio-button/RadioButton.js +7 -2
  164. package/dist-cjs/radio-button/RadioButton.js.map +1 -1
  165. package/dist-cjs/radio-button/RadioButtonGroup.js +6 -1
  166. package/dist-cjs/radio-button/RadioButtonGroup.js.map +1 -1
  167. package/dist-cjs/radio-button/RadioButtonIcon.js +6 -1
  168. package/dist-cjs/radio-button/RadioButtonIcon.js.map +1 -1
  169. package/dist-cjs/radio-button/internal/RadioGroupContext.js +6 -1
  170. package/dist-cjs/radio-button/internal/RadioGroupContext.js.map +1 -1
  171. package/dist-cjs/salt-provider/SaltProvider.js +6 -1
  172. package/dist-cjs/salt-provider/SaltProvider.js.map +1 -1
  173. package/dist-cjs/scrim/Scrim.js +6 -1
  174. package/dist-cjs/scrim/Scrim.js.map +1 -1
  175. package/dist-cjs/segmented-button-group/SegmentedButtonGroup.js +6 -1
  176. package/dist-cjs/segmented-button-group/SegmentedButtonGroup.js.map +1 -1
  177. package/dist-cjs/spinner/Spinner.js +6 -1
  178. package/dist-cjs/spinner/Spinner.js.map +1 -1
  179. package/dist-cjs/spinner/svgSpinners/SpinnerSVG.js +6 -1
  180. package/dist-cjs/spinner/svgSpinners/SpinnerSVG.js.map +1 -1
  181. package/dist-cjs/split-layout/SplitLayout.js +6 -1
  182. package/dist-cjs/split-layout/SplitLayout.js.map +1 -1
  183. package/dist-cjs/stack-layout/StackLayout.js +6 -1
  184. package/dist-cjs/stack-layout/StackLayout.js.map +1 -1
  185. package/dist-cjs/status-adornment/StatusAdornment.js +6 -1
  186. package/dist-cjs/status-adornment/StatusAdornment.js.map +1 -1
  187. package/dist-cjs/status-indicator/StatusIndicator.js +6 -1
  188. package/dist-cjs/status-indicator/StatusIndicator.js.map +1 -1
  189. package/dist-cjs/switch/Switch.js +6 -1
  190. package/dist-cjs/switch/Switch.js.map +1 -1
  191. package/dist-cjs/text/Text.js +6 -1
  192. package/dist-cjs/text/Text.js.map +1 -1
  193. package/dist-cjs/toast/Toast.js +6 -1
  194. package/dist-cjs/toast/Toast.js.map +1 -1
  195. package/dist-cjs/toast/ToastContent.js +6 -1
  196. package/dist-cjs/toast/ToastContent.js.map +1 -1
  197. package/dist-cjs/toggle-button/ToggleButton.js +7 -1
  198. package/dist-cjs/toggle-button/ToggleButton.js.map +1 -1
  199. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js +6 -1
  200. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js.map +1 -1
  201. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js +6 -1
  202. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js.map +1 -1
  203. package/dist-cjs/tooltip/Tooltip.css.js +1 -1
  204. package/dist-cjs/tooltip/Tooltip.js +12 -2
  205. package/dist-cjs/tooltip/Tooltip.js.map +1 -1
  206. package/dist-cjs/tooltip/TooltipBase.js +6 -1
  207. package/dist-cjs/tooltip/TooltipBase.js.map +1 -1
  208. package/dist-cjs/tooltip/useAriaAnnounce.js +6 -1
  209. package/dist-cjs/tooltip/useAriaAnnounce.js.map +1 -1
  210. package/dist-cjs/tooltip/useTooltip.js +5 -0
  211. package/dist-cjs/tooltip/useTooltip.js.map +1 -1
  212. package/dist-cjs/utils/useFloatingUI/useFloatingUI.js +3 -5
  213. package/dist-cjs/utils/useFloatingUI/useFloatingUI.js.map +1 -1
  214. package/dist-cjs/utils/useValueEffect.js +6 -1
  215. package/dist-cjs/utils/useValueEffect.js.map +1 -1
  216. package/dist-cjs/viewport/ViewportProvider.js +6 -1
  217. package/dist-cjs/viewport/ViewportProvider.js.map +1 -1
  218. package/dist-es/accordion/Accordion.js +6 -1
  219. package/dist-es/accordion/Accordion.js.map +1 -1
  220. package/dist-es/accordion/AccordionContext.js +6 -1
  221. package/dist-es/accordion/AccordionContext.js.map +1 -1
  222. package/dist-es/accordion/AccordionGroup.js +6 -1
  223. package/dist-es/accordion/AccordionGroup.js.map +1 -1
  224. package/dist-es/accordion/AccordionHeader.js +7 -1
  225. package/dist-es/accordion/AccordionHeader.js.map +1 -1
  226. package/dist-es/accordion/AccordionPanel.js +6 -1
  227. package/dist-es/accordion/AccordionPanel.js.map +1 -1
  228. package/dist-es/aria-announcer/useAriaAnnouncer.js +6 -1
  229. package/dist-es/aria-announcer/useAriaAnnouncer.js.map +1 -1
  230. package/dist-es/avatar/Avatar.js +6 -1
  231. package/dist-es/avatar/Avatar.js.map +1 -1
  232. package/dist-es/avatar/useAvatarImage.js +6 -1
  233. package/dist-es/avatar/useAvatarImage.js.map +1 -1
  234. package/dist-es/badge/Badge.js +6 -1
  235. package/dist-es/badge/Badge.js.map +1 -1
  236. package/dist-es/banner/Banner.js +6 -1
  237. package/dist-es/banner/Banner.js.map +1 -1
  238. package/dist-es/banner/BannerActions.js +6 -1
  239. package/dist-es/banner/BannerActions.js.map +1 -1
  240. package/dist-es/banner/BannerContent.js +6 -1
  241. package/dist-es/banner/BannerContent.js.map +1 -1
  242. package/dist-es/border-item/BorderItem.js +6 -1
  243. package/dist-es/border-item/BorderItem.js.map +1 -1
  244. package/dist-es/border-layout/BorderLayout.js +6 -1
  245. package/dist-es/border-layout/BorderLayout.js.map +1 -1
  246. package/dist-es/button/Button.css.js +1 -1
  247. package/dist-es/button/Button.js +6 -1
  248. package/dist-es/button/Button.js.map +1 -1
  249. package/dist-es/card/Card.js +6 -1
  250. package/dist-es/card/Card.js.map +1 -1
  251. package/dist-es/checkbox/Checkbox.js +7 -2
  252. package/dist-es/checkbox/Checkbox.js.map +1 -1
  253. package/dist-es/checkbox/CheckboxGroup.js +6 -1
  254. package/dist-es/checkbox/CheckboxGroup.js.map +1 -1
  255. package/dist-es/checkbox/CheckboxIcon.js +6 -1
  256. package/dist-es/checkbox/CheckboxIcon.js.map +1 -1
  257. package/dist-es/checkbox/internal/CheckboxGroupContext.js +6 -1
  258. package/dist-es/checkbox/internal/CheckboxGroupContext.js.map +1 -1
  259. package/dist-es/combo-box/ComboBox.js +5 -0
  260. package/dist-es/combo-box/ComboBox.js.map +1 -1
  261. package/dist-es/combo-box/useComboBox.js +6 -1
  262. package/dist-es/combo-box/useComboBox.js.map +1 -1
  263. package/dist-es/dialog/Dialog.js +5 -0
  264. package/dist-es/dialog/Dialog.js.map +1 -1
  265. package/dist-es/dialog/DialogActions.js +6 -1
  266. package/dist-es/dialog/DialogActions.js.map +1 -1
  267. package/dist-es/dialog/DialogCloseButton.js +6 -1
  268. package/dist-es/dialog/DialogCloseButton.js.map +1 -1
  269. package/dist-es/dialog/DialogContent.js +6 -1
  270. package/dist-es/dialog/DialogContent.js.map +1 -1
  271. package/dist-es/dialog/DialogHeader.js +6 -1
  272. package/dist-es/dialog/DialogHeader.js.map +1 -1
  273. package/dist-es/drawer/Drawer.js +5 -0
  274. package/dist-es/drawer/Drawer.js.map +1 -1
  275. package/dist-es/drawer/DrawerCloseButton.js +6 -1
  276. package/dist-es/drawer/DrawerCloseButton.js.map +1 -1
  277. package/dist-es/dropdown/Dropdown.js +6 -1
  278. package/dist-es/dropdown/Dropdown.js.map +1 -1
  279. package/dist-es/file-drop-zone/FileDropZone.js +6 -1
  280. package/dist-es/file-drop-zone/FileDropZone.js.map +1 -1
  281. package/dist-es/file-drop-zone/FileDropZoneTrigger.js +6 -1
  282. package/dist-es/file-drop-zone/FileDropZoneTrigger.js.map +1 -1
  283. package/dist-es/flex-item/FlexItem.js +6 -1
  284. package/dist-es/flex-item/FlexItem.js.map +1 -1
  285. package/dist-es/flex-layout/FlexLayout.js +6 -1
  286. package/dist-es/flex-layout/FlexLayout.js.map +1 -1
  287. package/dist-es/form-field/FormField.js +6 -1
  288. package/dist-es/form-field/FormField.js.map +1 -1
  289. package/dist-es/form-field/FormFieldHelperText.js +6 -1
  290. package/dist-es/form-field/FormFieldHelperText.js.map +1 -1
  291. package/dist-es/form-field/FormFieldLabel.js +6 -1
  292. package/dist-es/form-field/FormFieldLabel.js.map +1 -1
  293. package/dist-es/form-field-context/FormFieldContext.js +6 -1
  294. package/dist-es/form-field-context/FormFieldContext.js.map +1 -1
  295. package/dist-es/grid-item/GridItem.js +6 -1
  296. package/dist-es/grid-item/GridItem.js.map +1 -1
  297. package/dist-es/grid-layout/GridLayout.js +6 -1
  298. package/dist-es/grid-layout/GridLayout.js.map +1 -1
  299. package/dist-es/index.js +6 -0
  300. package/dist-es/index.js.map +1 -1
  301. package/dist-es/input/Input.js +6 -1
  302. package/dist-es/input/Input.js.map +1 -1
  303. package/dist-es/interactable-card/InteractableCard.css.js +1 -1
  304. package/dist-es/interactable-card/InteractableCard.js +6 -1
  305. package/dist-es/interactable-card/InteractableCard.js.map +1 -1
  306. package/dist-es/interactable-card/InteractableCardGroup.js +6 -1
  307. package/dist-es/interactable-card/InteractableCardGroup.js.map +1 -1
  308. package/dist-es/interactable-card/InteractableCardGroupContext.js +6 -1
  309. package/dist-es/interactable-card/InteractableCardGroupContext.js.map +1 -1
  310. package/dist-es/link/Link.js +6 -1
  311. package/dist-es/link/Link.js.map +1 -1
  312. package/dist-es/link-card/LinkCard.css.js +1 -1
  313. package/dist-es/link-card/LinkCard.js +6 -1
  314. package/dist-es/link-card/LinkCard.js.map +1 -1
  315. package/dist-es/list-control/ListControlContext.js +6 -1
  316. package/dist-es/list-control/ListControlContext.js.map +1 -1
  317. package/dist-es/list-control/ListControlState.js +6 -1
  318. package/dist-es/list-control/ListControlState.js.map +1 -1
  319. package/dist-es/multiline-input/MultilineInput.js +6 -1
  320. package/dist-es/multiline-input/MultilineInput.js.map +1 -1
  321. package/dist-es/navigation-item/NavigationItem.js +6 -1
  322. package/dist-es/navigation-item/NavigationItem.js.map +1 -1
  323. package/dist-es/option/Option.js +6 -1
  324. package/dist-es/option/Option.js.map +1 -1
  325. package/dist-es/option/OptionGroup.js +6 -1
  326. package/dist-es/option/OptionGroup.js.map +1 -1
  327. package/dist-es/option/OptionList.js +6 -1
  328. package/dist-es/option/OptionList.js.map +1 -1
  329. package/dist-es/option/OptionListBase.js +6 -1
  330. package/dist-es/option/OptionListBase.js.map +1 -1
  331. package/dist-es/overlay/Overlay.js +161 -0
  332. package/dist-es/overlay/Overlay.js.map +1 -0
  333. package/dist-es/overlay/OverlayContext.js +123 -0
  334. package/dist-es/overlay/OverlayContext.js.map +1 -0
  335. package/dist-es/overlay/OverlayPanel.css.js +4 -0
  336. package/dist-es/overlay/OverlayPanel.css.js.map +1 -0
  337. package/dist-es/overlay/OverlayPanel.js +163 -0
  338. package/dist-es/overlay/OverlayPanel.js.map +1 -0
  339. package/dist-es/overlay/OverlayPanelCloseButton.css.js +4 -0
  340. package/dist-es/overlay/OverlayPanelCloseButton.css.js.map +1 -0
  341. package/dist-es/overlay/OverlayPanelCloseButton.js +122 -0
  342. package/dist-es/overlay/OverlayPanelCloseButton.js.map +1 -0
  343. package/dist-es/overlay/OverlayPanelContent.css.js +4 -0
  344. package/dist-es/overlay/OverlayPanelContent.css.js.map +1 -0
  345. package/dist-es/overlay/OverlayPanelContent.js +116 -0
  346. package/dist-es/overlay/OverlayPanelContent.js.map +1 -0
  347. package/dist-es/overlay/OverlayTrigger.js +120 -0
  348. package/dist-es/overlay/OverlayTrigger.js.map +1 -0
  349. package/dist-es/pagination/CompactInput.js +6 -1
  350. package/dist-es/pagination/CompactInput.js.map +1 -1
  351. package/dist-es/pagination/CompactPaginator.js +6 -1
  352. package/dist-es/pagination/CompactPaginator.js.map +1 -1
  353. package/dist-es/pagination/GoToInput.js +6 -1
  354. package/dist-es/pagination/GoToInput.js.map +1 -1
  355. package/dist-es/pagination/PageButton.js +6 -1
  356. package/dist-es/pagination/PageButton.js.map +1 -1
  357. package/dist-es/pagination/PageRanges.js +6 -1
  358. package/dist-es/pagination/PageRanges.js.map +1 -1
  359. package/dist-es/pagination/Pagination.js +6 -1
  360. package/dist-es/pagination/Pagination.js.map +1 -1
  361. package/dist-es/pagination/Paginator.js +6 -1
  362. package/dist-es/pagination/Paginator.js.map +1 -1
  363. package/dist-es/panel/Panel.js +6 -1
  364. package/dist-es/panel/Panel.js.map +1 -1
  365. package/dist-es/parent-child-layout/ParentChildLayout.css.js +4 -0
  366. package/dist-es/parent-child-layout/ParentChildLayout.css.js.map +1 -0
  367. package/dist-es/parent-child-layout/ParentChildLayout.js +153 -0
  368. package/dist-es/parent-child-layout/ParentChildLayout.js.map +1 -0
  369. package/dist-es/parent-child-layout/useIsViewportLargerThanBreakpoint.js +107 -0
  370. package/dist-es/parent-child-layout/useIsViewportLargerThanBreakpoint.js.map +1 -0
  371. package/dist-es/pill/Pill.js +7 -1
  372. package/dist-es/pill/Pill.js.map +1 -1
  373. package/dist-es/pill-input/PillInput.js +6 -1
  374. package/dist-es/pill-input/PillInput.js.map +1 -1
  375. package/dist-es/progress/CircularProgress/CircularProgress.js +6 -1
  376. package/dist-es/progress/CircularProgress/CircularProgress.js.map +1 -1
  377. package/dist-es/progress/LinearProgress/LinearProgress.js +8 -3
  378. package/dist-es/progress/LinearProgress/LinearProgress.js.map +1 -1
  379. package/dist-es/radio-button/RadioButton.js +7 -2
  380. package/dist-es/radio-button/RadioButton.js.map +1 -1
  381. package/dist-es/radio-button/RadioButtonGroup.js +6 -1
  382. package/dist-es/radio-button/RadioButtonGroup.js.map +1 -1
  383. package/dist-es/radio-button/RadioButtonIcon.js +6 -1
  384. package/dist-es/radio-button/RadioButtonIcon.js.map +1 -1
  385. package/dist-es/radio-button/internal/RadioGroupContext.js +6 -1
  386. package/dist-es/radio-button/internal/RadioGroupContext.js.map +1 -1
  387. package/dist-es/salt-provider/SaltProvider.js +6 -1
  388. package/dist-es/salt-provider/SaltProvider.js.map +1 -1
  389. package/dist-es/scrim/Scrim.js +6 -1
  390. package/dist-es/scrim/Scrim.js.map +1 -1
  391. package/dist-es/segmented-button-group/SegmentedButtonGroup.js +6 -1
  392. package/dist-es/segmented-button-group/SegmentedButtonGroup.js.map +1 -1
  393. package/dist-es/spinner/Spinner.js +6 -1
  394. package/dist-es/spinner/Spinner.js.map +1 -1
  395. package/dist-es/spinner/svgSpinners/SpinnerSVG.js +6 -1
  396. package/dist-es/spinner/svgSpinners/SpinnerSVG.js.map +1 -1
  397. package/dist-es/split-layout/SplitLayout.js +6 -1
  398. package/dist-es/split-layout/SplitLayout.js.map +1 -1
  399. package/dist-es/stack-layout/StackLayout.js +6 -1
  400. package/dist-es/stack-layout/StackLayout.js.map +1 -1
  401. package/dist-es/status-adornment/StatusAdornment.js +6 -1
  402. package/dist-es/status-adornment/StatusAdornment.js.map +1 -1
  403. package/dist-es/status-indicator/StatusIndicator.js +6 -1
  404. package/dist-es/status-indicator/StatusIndicator.js.map +1 -1
  405. package/dist-es/switch/Switch.js +6 -1
  406. package/dist-es/switch/Switch.js.map +1 -1
  407. package/dist-es/text/Text.js +6 -1
  408. package/dist-es/text/Text.js.map +1 -1
  409. package/dist-es/toast/Toast.js +6 -1
  410. package/dist-es/toast/Toast.js.map +1 -1
  411. package/dist-es/toast/ToastContent.js +6 -1
  412. package/dist-es/toast/ToastContent.js.map +1 -1
  413. package/dist-es/toggle-button/ToggleButton.js +7 -1
  414. package/dist-es/toggle-button/ToggleButton.js.map +1 -1
  415. package/dist-es/toggle-button-group/ToggleButtonGroup.js +6 -1
  416. package/dist-es/toggle-button-group/ToggleButtonGroup.js.map +1 -1
  417. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js +6 -1
  418. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js.map +1 -1
  419. package/dist-es/tooltip/Tooltip.css.js +1 -1
  420. package/dist-es/tooltip/Tooltip.js +12 -2
  421. package/dist-es/tooltip/Tooltip.js.map +1 -1
  422. package/dist-es/tooltip/TooltipBase.js +6 -1
  423. package/dist-es/tooltip/TooltipBase.js.map +1 -1
  424. package/dist-es/tooltip/useAriaAnnounce.js +6 -1
  425. package/dist-es/tooltip/useAriaAnnounce.js.map +1 -1
  426. package/dist-es/tooltip/useTooltip.js +5 -0
  427. package/dist-es/tooltip/useTooltip.js.map +1 -1
  428. package/dist-es/utils/useFloatingUI/useFloatingUI.js +3 -5
  429. package/dist-es/utils/useFloatingUI/useFloatingUI.js.map +1 -1
  430. package/dist-es/utils/useValueEffect.js +6 -1
  431. package/dist-es/utils/useValueEffect.js.map +1 -1
  432. package/dist-es/viewport/ViewportProvider.js +6 -1
  433. package/dist-es/viewport/ViewportProvider.js.map +1 -1
  434. package/dist-types/index.d.ts +2 -0
  435. package/dist-types/overlay/Overlay.d.ts +13 -0
  436. package/dist-types/overlay/OverlayContext.d.ts +21 -0
  437. package/dist-types/overlay/OverlayPanel.d.ts +8 -0
  438. package/dist-types/overlay/OverlayPanelCloseButton.d.ts +2 -0
  439. package/dist-types/overlay/OverlayPanelContent.d.ts +8 -0
  440. package/dist-types/overlay/OverlayTrigger.d.ts +5 -0
  441. package/dist-types/overlay/index.d.ts +5 -0
  442. package/dist-types/parent-child-layout/ParentChildLayout.d.ts +29 -0
  443. package/dist-types/parent-child-layout/index.d.ts +1 -0
  444. package/dist-types/parent-child-layout/useIsViewportLargerThanBreakpoint.d.ts +2 -0
  445. package/dist-types/tooltip/Tooltip.d.ts +2 -1
  446. package/dist-types/tooltip/TooltipBase.d.ts +2 -2
  447. package/dist-types/utils/useFloatingUI/useFloatingUI.d.ts +1 -1
  448. package/package.json +2 -2
@@ -64,11 +64,17 @@ import '../multiline-input/MultilineInput.js';
64
64
  import '../navigation-item/NavigationItem.js';
65
65
  import '../option/Option.js';
66
66
  import '../option/OptionGroup.js';
67
+ import '../overlay/OverlayContext.js';
68
+ import '@floating-ui/react';
69
+ import '../overlay/OverlayPanel.js';
70
+ import '../overlay/OverlayPanelCloseButton.js';
71
+ import '../overlay/OverlayPanelContent.js';
67
72
  import '../pagination/Pagination.js';
68
73
  import '../pagination/Paginator.js';
69
74
  import '../pagination/CompactInput.js';
70
75
  import '../pagination/CompactPaginator.js';
71
76
  import '../pagination/GoToInput.js';
77
+ import '../parent-child-layout/ParentChildLayout.js';
72
78
  import '../pill/Pill.js';
73
79
  import '../progress/CircularProgress/CircularProgress.js';
74
80
  import '../progress/LinearProgress/LinearProgress.js';
@@ -87,7 +93,6 @@ import '../toggle-button/ToggleButton.js';
87
93
  import '../toggle-button-group/ToggleButtonGroup.js';
88
94
  import '../toggle-button-group/ToggleButtonGroupContext.js';
89
95
  import '../tooltip/Tooltip.js';
90
- import '@floating-ui/react';
91
96
  import css_248z from './Panel.css.js';
92
97
 
93
98
  const withBaseName = makePrefixer("saltPanel");
@@ -1 +1 @@
1
- {"version":3,"file":"Panel.js","sources":["../src/panel/Panel.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport { forwardRef, HTMLAttributes } from \"react\";\nimport { makePrefixer } from \"../utils\";\n\nimport panelCss from \"./Panel.css\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\n/**\n * Panel component that acts as wrapper around a node\n *\n * @example\n * const PanelExample = () => (\n * <Panel>\n * <p>This is a panel around some text.</p>\n * </Panel>\n * );\n *\n */\n\nexport interface PanelProps extends HTMLAttributes<HTMLDivElement> {\n /**\n * Styling variant; defaults to \"primary\".\n */\n variant?: \"primary\" | \"secondary\";\n}\n\nconst withBaseName = makePrefixer(\"saltPanel\");\n\nexport const Panel = forwardRef<HTMLDivElement, PanelProps>(function Panel(\n { className, children, variant = \"primary\", ...restProps },\n ref\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-panel\",\n css: panelCss,\n window: targetWindow,\n });\n\n return (\n <div\n className={clsx(withBaseName(), withBaseName(variant), className)}\n ref={ref}\n {...restProps}\n >\n {children}\n </div>\n );\n});\n"],"names":["Panel","panelCss"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA2BA,MAAM,YAAA,GAAe,aAAa,WAAW,CAAA,CAAA;AAEhC,MAAA,KAAA,GAAQ,UAAuC,CAAA,SAASA,MACnE,CAAA,EAAE,SAAW,EAAA,QAAA,EAAU,OAAU,GAAA,SAAA,EAAA,GAAc,SAAU,EAAA,EACzD,GACA,EAAA;AACA,EAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,YAAA;AAAA,IACR,GAAK,EAAAC,QAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,IACC,WAAW,IAAK,CAAA,YAAA,IAAgB,YAAa,CAAA,OAAO,GAAG,SAAS,CAAA;AAAA,IAChE,GAAA;AAAA,IACC,GAAG,SAAA;AAAA,IAEH,QAAA;AAAA,GACH,CAAA,CAAA;AAEJ,CAAC;;;;"}
1
+ {"version":3,"file":"Panel.js","sources":["../src/panel/Panel.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport { forwardRef, HTMLAttributes } from \"react\";\nimport { makePrefixer } from \"../utils\";\n\nimport panelCss from \"./Panel.css\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\n/**\n * Panel component that acts as wrapper around a node\n *\n * @example\n * const PanelExample = () => (\n * <Panel>\n * <p>This is a panel around some text.</p>\n * </Panel>\n * );\n *\n */\n\nexport interface PanelProps extends HTMLAttributes<HTMLDivElement> {\n /**\n * Styling variant; defaults to \"primary\".\n */\n variant?: \"primary\" | \"secondary\";\n}\n\nconst withBaseName = makePrefixer(\"saltPanel\");\n\nexport const Panel = forwardRef<HTMLDivElement, PanelProps>(function Panel(\n { className, children, variant = \"primary\", ...restProps },\n ref\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-panel\",\n css: panelCss,\n window: targetWindow,\n });\n\n return (\n <div\n className={clsx(withBaseName(), withBaseName(variant), className)}\n ref={ref}\n {...restProps}\n >\n {children}\n </div>\n );\n});\n"],"names":["Panel","panelCss"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA2BA,MAAM,YAAA,GAAe,aAAa,WAAW,CAAA,CAAA;AAEhC,MAAA,KAAA,GAAQ,UAAuC,CAAA,SAASA,MACnE,CAAA,EAAE,SAAW,EAAA,QAAA,EAAU,OAAU,GAAA,SAAA,EAAA,GAAc,SAAU,EAAA,EACzD,GACA,EAAA;AACA,EAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,YAAA;AAAA,IACR,GAAK,EAAAC,QAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,IACC,WAAW,IAAK,CAAA,YAAA,IAAgB,YAAa,CAAA,OAAO,GAAG,SAAS,CAAA;AAAA,IAChE,GAAA;AAAA,IACC,GAAG,SAAA;AAAA,IAEH,QAAA;AAAA,GACH,CAAA,CAAA;AAEJ,CAAC;;;;"}
@@ -0,0 +1,4 @@
1
+ var css_248z = ".saltParentChildLayout {\n display: flex;\n gap: var(--parentChildLayout-gap);\n}\n\n.saltParentChildLayout-child {\n flex-grow: 1;\n}\n\n.saltParentChildLayout-collapsed {\n width: 100%;\n}\n\n.saltParentChildLayout-childAnimation {\n animation: var(--salt-animation-slide-in-right);\n}\n\n.saltParentChildLayout-parentAnimation {\n animation: var(--salt-animation-slide-in-left);\n}\n\n@media (prefers-reduced-motion) {\n .saltParentChildLayout-parentAnimation {\n animation: var(--salt-animation-fade-in-center);\n }\n\n .saltParentChildLayout-childAnimation {\n animation: var(--salt-animation-fade-in-center);\n }\n}\n";
2
+
3
+ export { css_248z as default };
4
+ //# sourceMappingURL=ParentChildLayout.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ParentChildLayout.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
@@ -0,0 +1,153 @@
1
+ import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
2
+ import { clsx } from 'clsx';
3
+ import { forwardRef, useEffect } from 'react';
4
+ import { makePrefixer } from '../utils/makePrefixer.js';
5
+ import '../utils/useFloatingUI/useFloatingUI.js';
6
+ import '../utils/useId.js';
7
+ import '../salt-provider/SaltProvider.js';
8
+ import '../viewport/ViewportProvider.js';
9
+ import '../accordion/AccordionGroup.js';
10
+ import '../accordion/AccordionPanel.js';
11
+ import '../accordion/Accordion.js';
12
+ import '../accordion/AccordionHeader.js';
13
+ import '../aria-announcer/AriaAnnouncerContext.js';
14
+ import '../avatar/Avatar.js';
15
+ import '../badge/Badge.js';
16
+ import '../banner/Banner.js';
17
+ import '../banner/BannerActions.js';
18
+ import '../banner/BannerContent.js';
19
+ import '../border-item/BorderItem.js';
20
+ import '../border-layout/BorderLayout.js';
21
+ import '../button/Button.js';
22
+ import '../card/Card.js';
23
+ import '../checkbox/Checkbox.js';
24
+ import '../checkbox/CheckboxGroup.js';
25
+ import { useComponentCssInjection } from '@salt-ds/styles';
26
+ import { useWindow } from '@salt-ds/window';
27
+ import '@salt-ds/icons';
28
+ import '../combo-box/ComboBox.js';
29
+ import '../dialog/Dialog.js';
30
+ import '../dialog/DialogHeader.js';
31
+ import '../dialog/DialogActions.js';
32
+ import '../dialog/DialogContent.js';
33
+ import '../dialog/DialogContext.js';
34
+ import '../dialog/DialogCloseButton.js';
35
+ import '../drawer/Drawer.js';
36
+ import '../drawer/DrawerCloseButton.js';
37
+ import '../dropdown/Dropdown.js';
38
+ import '../file-drop-zone/FileDropZone.js';
39
+ import '../file-drop-zone/FileDropZoneIcon.js';
40
+ import '../file-drop-zone/FileDropZoneTrigger.js';
41
+ import '../flex-item/FlexItem.js';
42
+ import '../flex-layout/FlexLayout.js';
43
+ import '../flow-layout/FlowLayout.js';
44
+ import '../form-field/FormField.js';
45
+ import '../status-indicator/StatusIndicator.js';
46
+ import '../text/Text.js';
47
+ import '../text/Code.js';
48
+ import '../text/Display.js';
49
+ import '../text/Headings.js';
50
+ import '../text/Label.js';
51
+ import '../text/TextAction.js';
52
+ import '../text/TextNotation.js';
53
+ import '../form-field-context/FormFieldContext.js';
54
+ import '../grid-item/GridItem.js';
55
+ import '../grid-layout/GridLayout.js';
56
+ import '../input/Input.js';
57
+ import '../interactable-card/InteractableCard.js';
58
+ import '../interactable-card/InteractableCardGroup.js';
59
+ import '../interactable-card/InteractableCardGroupContext.js';
60
+ import '../link/Link.js';
61
+ import '../link-card/LinkCard.js';
62
+ import '../list-control/ListControlContext.js';
63
+ import '../multiline-input/MultilineInput.js';
64
+ import '../navigation-item/NavigationItem.js';
65
+ import '../option/Option.js';
66
+ import '../option/OptionGroup.js';
67
+ import '../overlay/OverlayContext.js';
68
+ import '@floating-ui/react';
69
+ import '../overlay/OverlayPanel.js';
70
+ import '../overlay/OverlayPanelCloseButton.js';
71
+ import '../overlay/OverlayPanelContent.js';
72
+ import '../pagination/Pagination.js';
73
+ import '../pagination/Paginator.js';
74
+ import '../pagination/CompactInput.js';
75
+ import '../pagination/CompactPaginator.js';
76
+ import '../pagination/GoToInput.js';
77
+ import '../panel/Panel.js';
78
+ import '../pill/Pill.js';
79
+ import '../progress/CircularProgress/CircularProgress.js';
80
+ import '../progress/LinearProgress/LinearProgress.js';
81
+ import '../radio-button/RadioButton.js';
82
+ import '../radio-button/RadioButtonGroup.js';
83
+ import '../scrim/Scrim.js';
84
+ import '../segmented-button-group/SegmentedButtonGroup.js';
85
+ import '../spinner/Spinner.js';
86
+ import '../stack-layout/StackLayout.js';
87
+ import '../status-adornment/StatusAdornment.js';
88
+ import '../toast/Toast.js';
89
+ import '../toast/ToastContent.js';
90
+ import '../split-layout/SplitLayout.js';
91
+ import '../switch/Switch.js';
92
+ import '../toggle-button/ToggleButton.js';
93
+ import '../toggle-button-group/ToggleButtonGroup.js';
94
+ import '../toggle-button-group/ToggleButtonGroupContext.js';
95
+ import '../tooltip/Tooltip.js';
96
+ import { useIsViewportLargerThanBreakpoint } from './useIsViewportLargerThanBreakpoint.js';
97
+ import css_248z from './ParentChildLayout.css.js';
98
+
99
+ const withBaseName = makePrefixer("saltParentChildLayout");
100
+ const ParentChildLayout = forwardRef(function ParentChildLayout2({
101
+ collapseAtBreakpoint = "sm",
102
+ visibleView = "child",
103
+ parent,
104
+ child,
105
+ className,
106
+ gap = 0,
107
+ onCollapseChange,
108
+ style,
109
+ ...rest
110
+ }, ref) {
111
+ const targetWindow = useWindow();
112
+ useComponentCssInjection({
113
+ testId: "salt-parent-child-layout",
114
+ css: css_248z,
115
+ window: targetWindow
116
+ });
117
+ const isCollapsed = useIsViewportLargerThanBreakpoint(collapseAtBreakpoint);
118
+ useEffect(() => {
119
+ onCollapseChange == null ? void 0 : onCollapseChange(isCollapsed);
120
+ }, [isCollapsed, onCollapseChange]);
121
+ const parentChildLayoutStyles = {
122
+ ...style,
123
+ "--parentChildLayout-gap": `calc(var(--salt-spacing-100) * ${gap})`
124
+ };
125
+ return /* @__PURE__ */ jsx("div", {
126
+ ref,
127
+ className: clsx(withBaseName(), className),
128
+ style: parentChildLayoutStyles,
129
+ ...rest,
130
+ children: isCollapsed ? /* @__PURE__ */ jsx("div", {
131
+ className: clsx({
132
+ [withBaseName("collapsed")]: isCollapsed,
133
+ [withBaseName("childAnimation")]: visibleView === "child",
134
+ [withBaseName("parentAnimation")]: visibleView === "parent"
135
+ }),
136
+ children: isCollapsed && visibleView === "child" ? child : parent
137
+ }, visibleView) : /* @__PURE__ */ jsxs(Fragment, {
138
+ children: [
139
+ /* @__PURE__ */ jsx("div", {
140
+ className: withBaseName("parent"),
141
+ children: parent
142
+ }),
143
+ /* @__PURE__ */ jsx("div", {
144
+ className: withBaseName("child"),
145
+ children: child
146
+ })
147
+ ]
148
+ })
149
+ });
150
+ });
151
+
152
+ export { ParentChildLayout };
153
+ //# sourceMappingURL=ParentChildLayout.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ParentChildLayout.js","sources":["../src/parent-child-layout/ParentChildLayout.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport {\n ComponentPropsWithoutRef,\n forwardRef,\n ReactNode,\n useEffect,\n} from \"react\";\nimport { Breakpoints } from \"../breakpoints\";\nimport { makePrefixer } from \"../utils\";\nimport { useIsViewportLargerThanBreakpoint } from \"./useIsViewportLargerThanBreakpoint\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport parentChildLayoutCss from \"./ParentChildLayout.css\";\nexport interface ParentChildLayoutProps\n extends ComponentPropsWithoutRef<\"div\"> {\n /**\n * Breakpoint at which the parent and child will stack.\n */\n collapseAtBreakpoint?: keyof Breakpoints;\n /**\n * View that is displayed when in a collapsed state.\n */\n visibleView?: \"child\" | \"parent\";\n /**\n * Controls the space between parent and child components, default is 0.\n */\n gap?: number;\n /**\n * Parent component to be rendered\n */\n parent: ReactNode;\n /**\n * Child component to be rendered\n */\n child: ReactNode;\n /**\n * Function called when the viewport size equal to or less than the collapseAtBreakpoint variable\n */\n onCollapseChange?: (isCollapsed: boolean) => void;\n}\n\nconst withBaseName = makePrefixer(\"saltParentChildLayout\");\n\nexport const ParentChildLayout = forwardRef<\n HTMLDivElement,\n ParentChildLayoutProps\n>(function ParentChildLayout(\n {\n collapseAtBreakpoint = \"sm\",\n visibleView = \"child\",\n parent,\n child,\n className,\n gap = 0,\n onCollapseChange,\n style,\n ...rest\n },\n ref\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-parent-child-layout\",\n css: parentChildLayoutCss,\n window: targetWindow,\n });\n\n const isCollapsed = useIsViewportLargerThanBreakpoint(collapseAtBreakpoint);\n\n useEffect(() => {\n onCollapseChange?.(isCollapsed);\n }, [isCollapsed, onCollapseChange]);\n\n const parentChildLayoutStyles = {\n ...style,\n \"--parentChildLayout-gap\": `calc(var(--salt-spacing-100) * ${gap})`,\n };\n\n return (\n <div\n ref={ref}\n className={clsx(withBaseName(), className)}\n style={parentChildLayoutStyles}\n {...rest}\n >\n {isCollapsed ? (\n <div\n key={visibleView}\n className={clsx({\n [withBaseName(\"collapsed\")]: isCollapsed,\n [withBaseName(\"childAnimation\")]: visibleView === \"child\",\n [withBaseName(\"parentAnimation\")]: visibleView === \"parent\",\n })}\n >\n {isCollapsed && visibleView === \"child\" ? child : parent}\n </div>\n ) : (\n <>\n <div className={withBaseName(\"parent\")}>{parent}</div>\n <div className={withBaseName(\"child\")}>{child}</div>\n </>\n )}\n </div>\n );\n});\n"],"names":["ParentChildLayout","parentChildLayoutCss"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA0CA,MAAM,YAAA,GAAe,aAAa,uBAAuB,CAAA,CAAA;AAE5C,MAAA,iBAAA,GAAoB,UAG/B,CAAA,SAASA,kBACT,CAAA;AAAA,EACE,oBAAuB,GAAA,IAAA;AAAA,EACvB,WAAc,GAAA,OAAA;AAAA,EACd,MAAA;AAAA,EACA,KAAA;AAAA,EACA,SAAA;AAAA,EACA,GAAM,GAAA,CAAA;AAAA,EACN,gBAAA;AAAA,EACA,KAAA;AAAA,EACG,GAAA,IAAA;AACL,CAAA,EACA,GACA,EAAA;AACA,EAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,0BAAA;AAAA,IACR,GAAK,EAAAC,QAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAM,MAAA,WAAA,GAAc,kCAAkC,oBAAoB,CAAA,CAAA;AAE1E,EAAA,SAAA,CAAU,MAAM;AACd,IAAmB,gBAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,gBAAA,CAAA,WAAA,CAAA,CAAA;AAAA,GAClB,EAAA,CAAC,WAAa,EAAA,gBAAgB,CAAC,CAAA,CAAA;AAElC,EAAA,MAAM,uBAA0B,GAAA;AAAA,IAC9B,GAAG,KAAA;AAAA,IACH,2BAA2B,CAAkC,+BAAA,EAAA,GAAA,CAAA,CAAA,CAAA;AAAA,GAC/D,CAAA;AAEA,EAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,IACC,GAAA;AAAA,IACA,SAAW,EAAA,IAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,IACzC,KAAO,EAAA,uBAAA;AAAA,IACN,GAAG,IAAA;AAAA,IAEH,wCACE,GAAA,CAAA,KAAA,EAAA;AAAA,MAEC,WAAW,IAAK,CAAA;AAAA,QACd,CAAC,YAAa,CAAA,WAAW,CAAI,GAAA,WAAA;AAAA,QAC7B,CAAC,YAAA,CAAa,gBAAgB,CAAA,GAAI,WAAgB,KAAA,OAAA;AAAA,QAClD,CAAC,YAAA,CAAa,iBAAiB,CAAA,GAAI,WAAgB,KAAA,QAAA;AAAA,OACpD,CAAA;AAAA,MAEA,QAAA,EAAA,WAAA,IAAe,WAAgB,KAAA,OAAA,GAAU,KAAQ,GAAA,MAAA;AAAA,KAAA,EAP7C,WAQP,CAEA,mBAAA,IAAA,CAAA,QAAA,EAAA;AAAA,MACE,QAAA,EAAA;AAAA,wBAAC,GAAA,CAAA,KAAA,EAAA;AAAA,UAAI,SAAA,EAAW,aAAa,QAAQ,CAAA;AAAA,UAAI,QAAA,EAAA,MAAA;AAAA,SAAO,CAAA;AAAA,wBAC/C,GAAA,CAAA,KAAA,EAAA;AAAA,UAAI,SAAA,EAAW,aAAa,OAAO,CAAA;AAAA,UAAI,QAAA,EAAA,KAAA;AAAA,SAAM,CAAA;AAAA,OAAA;AAAA,KAChD,CAAA;AAAA,GAEJ,CAAA,CAAA;AAEJ,CAAC;;;;"}
@@ -0,0 +1,107 @@
1
+ import 'react';
2
+ import '../utils/useFloatingUI/useFloatingUI.js';
3
+ import '../utils/useId.js';
4
+ import { useOrderedBreakpoints, useCurrentBreakpoint } from '../utils/useResponsiveProp.js';
5
+ import 'clsx';
6
+ import '../accordion/AccordionGroup.js';
7
+ import '../accordion/AccordionPanel.js';
8
+ import '../accordion/Accordion.js';
9
+ import '../accordion/AccordionHeader.js';
10
+ import '../aria-announcer/AriaAnnouncerContext.js';
11
+ import 'react/jsx-runtime';
12
+ import '../avatar/Avatar.js';
13
+ import '../badge/Badge.js';
14
+ import '../banner/Banner.js';
15
+ import '../banner/BannerActions.js';
16
+ import '../banner/BannerContent.js';
17
+ import '../border-item/BorderItem.js';
18
+ import '../border-layout/BorderLayout.js';
19
+ import '../button/Button.js';
20
+ import '../card/Card.js';
21
+ import '../checkbox/Checkbox.js';
22
+ import '../checkbox/CheckboxGroup.js';
23
+ import '@salt-ds/styles';
24
+ import '@salt-ds/window';
25
+ import '../salt-provider/SaltProvider.js';
26
+ import '@salt-ds/icons';
27
+ import '../combo-box/ComboBox.js';
28
+ import '../dialog/Dialog.js';
29
+ import '../dialog/DialogHeader.js';
30
+ import '../dialog/DialogActions.js';
31
+ import '../dialog/DialogContent.js';
32
+ import '../dialog/DialogContext.js';
33
+ import '../dialog/DialogCloseButton.js';
34
+ import '../drawer/Drawer.js';
35
+ import '../drawer/DrawerCloseButton.js';
36
+ import '../dropdown/Dropdown.js';
37
+ import '../file-drop-zone/FileDropZone.js';
38
+ import '../file-drop-zone/FileDropZoneIcon.js';
39
+ import '../file-drop-zone/FileDropZoneTrigger.js';
40
+ import '../flex-item/FlexItem.js';
41
+ import '../flex-layout/FlexLayout.js';
42
+ import '../flow-layout/FlowLayout.js';
43
+ import '../form-field/FormField.js';
44
+ import '../status-indicator/StatusIndicator.js';
45
+ import '../text/Text.js';
46
+ import '../text/Code.js';
47
+ import '../text/Display.js';
48
+ import '../text/Headings.js';
49
+ import '../text/Label.js';
50
+ import '../text/TextAction.js';
51
+ import '../text/TextNotation.js';
52
+ import '../form-field-context/FormFieldContext.js';
53
+ import '../grid-item/GridItem.js';
54
+ import '../grid-layout/GridLayout.js';
55
+ import '../input/Input.js';
56
+ import '../interactable-card/InteractableCard.js';
57
+ import '../interactable-card/InteractableCardGroup.js';
58
+ import '../interactable-card/InteractableCardGroupContext.js';
59
+ import '../link/Link.js';
60
+ import '../link-card/LinkCard.js';
61
+ import '../list-control/ListControlContext.js';
62
+ import '../multiline-input/MultilineInput.js';
63
+ import '../navigation-item/NavigationItem.js';
64
+ import '../option/Option.js';
65
+ import '../option/OptionGroup.js';
66
+ import '../overlay/OverlayContext.js';
67
+ import '@floating-ui/react';
68
+ import '../overlay/OverlayPanel.js';
69
+ import '../overlay/OverlayPanelCloseButton.js';
70
+ import '../overlay/OverlayPanelContent.js';
71
+ import '../pagination/Pagination.js';
72
+ import '../pagination/Paginator.js';
73
+ import '../pagination/CompactInput.js';
74
+ import '../pagination/CompactPaginator.js';
75
+ import '../pagination/GoToInput.js';
76
+ import '../panel/Panel.js';
77
+ import './ParentChildLayout.js';
78
+ import '../pill/Pill.js';
79
+ import '../progress/CircularProgress/CircularProgress.js';
80
+ import '../progress/LinearProgress/LinearProgress.js';
81
+ import '../radio-button/RadioButton.js';
82
+ import '../radio-button/RadioButtonGroup.js';
83
+ import '../scrim/Scrim.js';
84
+ import '../segmented-button-group/SegmentedButtonGroup.js';
85
+ import '../spinner/Spinner.js';
86
+ import '../stack-layout/StackLayout.js';
87
+ import '../status-adornment/StatusAdornment.js';
88
+ import '../toast/Toast.js';
89
+ import '../toast/ToastContent.js';
90
+ import '../split-layout/SplitLayout.js';
91
+ import '../switch/Switch.js';
92
+ import '../toggle-button/ToggleButton.js';
93
+ import '../toggle-button-group/ToggleButtonGroup.js';
94
+ import '../toggle-button-group/ToggleButtonGroupContext.js';
95
+ import '../tooltip/Tooltip.js';
96
+ import '../viewport/ViewportProvider.js';
97
+
98
+ const useIsViewportLargerThanBreakpoint = (targetedBreakpoint) => {
99
+ const orderedBreakpoints = useOrderedBreakpoints();
100
+ const index = orderedBreakpoints.indexOf(targetedBreakpoint);
101
+ const currentBreakpoint = useCurrentBreakpoint();
102
+ const currentBreakpointIndex = orderedBreakpoints.indexOf(currentBreakpoint);
103
+ return index >= currentBreakpointIndex;
104
+ };
105
+
106
+ export { useIsViewportLargerThanBreakpoint };
107
+ //# sourceMappingURL=useIsViewportLargerThanBreakpoint.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useIsViewportLargerThanBreakpoint.js","sources":["../src/parent-child-layout/useIsViewportLargerThanBreakpoint.ts"],"sourcesContent":["import { Breakpoints } from \"../breakpoints\";\nimport { useCurrentBreakpoint, useOrderedBreakpoints } from \"../utils\";\n\nexport const useIsViewportLargerThanBreakpoint = (\n targetedBreakpoint: keyof Breakpoints\n): boolean => {\n const orderedBreakpoints = useOrderedBreakpoints();\n const index = orderedBreakpoints.indexOf(targetedBreakpoint);\n const currentBreakpoint = useCurrentBreakpoint();\n const currentBreakpointIndex = orderedBreakpoints.indexOf(currentBreakpoint);\n return index >= currentBreakpointIndex;\n};\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAGa,MAAA,iCAAA,GAAoC,CAC/C,kBACY,KAAA;AACZ,EAAA,MAAM,qBAAqB,qBAAsB,EAAA,CAAA;AACjD,EAAM,MAAA,KAAA,GAAQ,kBAAmB,CAAA,OAAA,CAAQ,kBAAkB,CAAA,CAAA;AAC3D,EAAA,MAAM,oBAAoB,oBAAqB,EAAA,CAAA;AAC/C,EAAM,MAAA,sBAAA,GAAyB,kBAAmB,CAAA,OAAA,CAAQ,iBAAiB,CAAA,CAAA;AAC3E,EAAA,OAAO,KAAS,IAAA,sBAAA,CAAA;AAClB;;;;"}
@@ -66,12 +66,18 @@ import '../multiline-input/MultilineInput.js';
66
66
  import '../navigation-item/NavigationItem.js';
67
67
  import '../option/Option.js';
68
68
  import '../option/OptionGroup.js';
69
+ import '../overlay/OverlayContext.js';
70
+ import '@floating-ui/react';
71
+ import '../overlay/OverlayPanel.js';
72
+ import '../overlay/OverlayPanelCloseButton.js';
73
+ import '../overlay/OverlayPanelContent.js';
69
74
  import '../pagination/Pagination.js';
70
75
  import '../pagination/Paginator.js';
71
76
  import '../pagination/CompactInput.js';
72
77
  import '../pagination/CompactPaginator.js';
73
78
  import '../pagination/GoToInput.js';
74
79
  import '../panel/Panel.js';
80
+ import '../parent-child-layout/ParentChildLayout.js';
75
81
  import '../progress/CircularProgress/CircularProgress.js';
76
82
  import '../progress/LinearProgress/LinearProgress.js';
77
83
  import '../radio-button/RadioButton.js';
@@ -89,7 +95,6 @@ import '../toggle-button/ToggleButton.js';
89
95
  import '../toggle-button-group/ToggleButtonGroup.js';
90
96
  import '../toggle-button-group/ToggleButtonGroupContext.js';
91
97
  import '../tooltip/Tooltip.js';
92
- import '@floating-ui/react';
93
98
 
94
99
  const withBaseName = makePrefixer("saltPill");
95
100
  const Pill = forwardRef(function Pill2({
@@ -125,6 +130,7 @@ const Pill = forwardRef(function Pill2({
125
130
  { [withBaseName("active")]: active },
126
131
  className
127
132
  ),
133
+ type: "button",
128
134
  ...restButtonProps,
129
135
  ...rest,
130
136
  children
@@ -1 +1 @@
1
- {"version":3,"file":"Pill.js","sources":["../src/pill/Pill.tsx"],"sourcesContent":["import { forwardRef, ComponentPropsWithoutRef } from \"react\";\nimport clsx from \"clsx\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport pillCss from \"./Pill.css\";\nimport { makePrefixer } from \"../utils\";\nimport { useButton } from \"../button\";\n\nconst withBaseName = makePrefixer(\"saltPill\");\n\n/* eslint-disable @typescript-eslint/no-empty-interface */\nexport interface PillProps extends ComponentPropsWithoutRef<\"button\"> {}\n\nexport const Pill = forwardRef<HTMLButtonElement, PillProps>(function Pill(\n {\n children,\n className,\n disabled,\n onKeyUp,\n onKeyDown,\n onClick,\n onBlur,\n ...rest\n },\n ref\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-pill\",\n css: pillCss,\n window: targetWindow,\n });\n const { buttonProps, active } = useButton<HTMLButtonElement>({\n disabled,\n onKeyUp,\n onKeyDown,\n onClick,\n onBlur,\n });\n // we do not want to spread tab index in this case because the button element\n // does not require tabindex=\"0\" attribute\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { tabIndex, ...restButtonProps } = buttonProps;\n return (\n <button\n data-testid=\"pill\"\n ref={ref}\n className={clsx(\n withBaseName(),\n withBaseName(\"clickable\"),\n { [withBaseName(\"active\")]: active },\n className\n )}\n {...restButtonProps}\n {...rest}\n >\n {children}\n </button>\n );\n});\n"],"names":["Pill","pillCss"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAQA,MAAM,YAAA,GAAe,aAAa,UAAU,CAAA,CAAA;AAK/B,MAAA,IAAA,GAAO,UAAyC,CAAA,SAASA,KACpE,CAAA;AAAA,EACE,QAAA;AAAA,EACA,SAAA;AAAA,EACA,QAAA;AAAA,EACA,OAAA;AAAA,EACA,SAAA;AAAA,EACA,OAAA;AAAA,EACA,MAAA;AAAA,EACG,GAAA,IAAA;AACL,CAAA,EACA,GACA,EAAA;AACA,EAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,WAAA;AAAA,IACR,GAAK,EAAAC,QAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AACD,EAAA,MAAM,EAAE,WAAA,EAAa,MAAO,EAAA,GAAI,SAA6B,CAAA;AAAA,IAC3D,QAAA;AAAA,IACA,OAAA;AAAA,IACA,SAAA;AAAA,IACA,OAAA;AAAA,IACA,MAAA;AAAA,GACD,CAAA,CAAA;AAID,EAAM,MAAA,EAAE,QAAa,EAAA,GAAA,eAAA,EAAoB,GAAA,WAAA,CAAA;AACzC,EAAA,uBACG,GAAA,CAAA,QAAA,EAAA;AAAA,IACC,aAAY,EAAA,MAAA;AAAA,IACZ,GAAA;AAAA,IACA,SAAW,EAAA,IAAA;AAAA,MACT,YAAa,EAAA;AAAA,MACb,aAAa,WAAW,CAAA;AAAA,MACxB,EAAE,CAAC,YAAa,CAAA,QAAQ,IAAI,MAAO,EAAA;AAAA,MACnC,SAAA;AAAA,KACF;AAAA,IACC,GAAG,eAAA;AAAA,IACH,GAAG,IAAA;AAAA,IAEH,QAAA;AAAA,GACH,CAAA,CAAA;AAEJ,CAAC;;;;"}
1
+ {"version":3,"file":"Pill.js","sources":["../src/pill/Pill.tsx"],"sourcesContent":["import { forwardRef, ComponentPropsWithoutRef } from \"react\";\nimport clsx from \"clsx\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport pillCss from \"./Pill.css\";\nimport { makePrefixer } from \"../utils\";\nimport { useButton } from \"../button\";\n\nconst withBaseName = makePrefixer(\"saltPill\");\n\n/* eslint-disable @typescript-eslint/no-empty-interface */\nexport interface PillProps extends ComponentPropsWithoutRef<\"button\"> {}\n\nexport const Pill = forwardRef<HTMLButtonElement, PillProps>(function Pill(\n {\n children,\n className,\n disabled,\n onKeyUp,\n onKeyDown,\n onClick,\n onBlur,\n ...rest\n },\n ref\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-pill\",\n css: pillCss,\n window: targetWindow,\n });\n const { buttonProps, active } = useButton<HTMLButtonElement>({\n disabled,\n onKeyUp,\n onKeyDown,\n onClick,\n onBlur,\n });\n // we do not want to spread tab index in this case because the button element\n // does not require tabindex=\"0\" attribute\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { tabIndex, ...restButtonProps } = buttonProps;\n return (\n <button\n data-testid=\"pill\"\n ref={ref}\n className={clsx(\n withBaseName(),\n withBaseName(\"clickable\"),\n { [withBaseName(\"active\")]: active },\n className\n )}\n type=\"button\"\n {...restButtonProps}\n {...rest}\n >\n {children}\n </button>\n );\n});\n"],"names":["Pill","pillCss"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAQA,MAAM,YAAA,GAAe,aAAa,UAAU,CAAA,CAAA;AAK/B,MAAA,IAAA,GAAO,UAAyC,CAAA,SAASA,KACpE,CAAA;AAAA,EACE,QAAA;AAAA,EACA,SAAA;AAAA,EACA,QAAA;AAAA,EACA,OAAA;AAAA,EACA,SAAA;AAAA,EACA,OAAA;AAAA,EACA,MAAA;AAAA,EACG,GAAA,IAAA;AACL,CAAA,EACA,GACA,EAAA;AACA,EAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,WAAA;AAAA,IACR,GAAK,EAAAC,QAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AACD,EAAA,MAAM,EAAE,WAAA,EAAa,MAAO,EAAA,GAAI,SAA6B,CAAA;AAAA,IAC3D,QAAA;AAAA,IACA,OAAA;AAAA,IACA,SAAA;AAAA,IACA,OAAA;AAAA,IACA,MAAA;AAAA,GACD,CAAA,CAAA;AAID,EAAM,MAAA,EAAE,QAAa,EAAA,GAAA,eAAA,EAAoB,GAAA,WAAA,CAAA;AACzC,EAAA,uBACG,GAAA,CAAA,QAAA,EAAA;AAAA,IACC,aAAY,EAAA,MAAA;AAAA,IACZ,GAAA;AAAA,IACA,SAAW,EAAA,IAAA;AAAA,MACT,YAAa,EAAA;AAAA,MACb,aAAa,WAAW,CAAA;AAAA,MACxB,EAAE,CAAC,YAAa,CAAA,QAAQ,IAAI,MAAO,EAAA;AAAA,MACnC,SAAA;AAAA,KACF;AAAA,IACA,IAAK,EAAA,QAAA;AAAA,IACJ,GAAG,eAAA;AAAA,IACH,GAAG,IAAA;AAAA,IAEH,QAAA;AAAA,GACH,CAAA,CAAA;AAEJ,CAAC;;;;"}
@@ -67,12 +67,18 @@ import '../multiline-input/MultilineInput.js';
67
67
  import '../navigation-item/NavigationItem.js';
68
68
  import '../option/Option.js';
69
69
  import '../option/OptionGroup.js';
70
+ import '../overlay/OverlayContext.js';
71
+ import '@floating-ui/react';
72
+ import '../overlay/OverlayPanel.js';
73
+ import '../overlay/OverlayPanelCloseButton.js';
74
+ import '../overlay/OverlayPanelContent.js';
70
75
  import '../pagination/Pagination.js';
71
76
  import '../pagination/Paginator.js';
72
77
  import '../pagination/CompactInput.js';
73
78
  import '../pagination/CompactPaginator.js';
74
79
  import '../pagination/GoToInput.js';
75
80
  import '../panel/Panel.js';
81
+ import '../parent-child-layout/ParentChildLayout.js';
76
82
  import { Pill } from '../pill/Pill.js';
77
83
  import '../progress/CircularProgress/CircularProgress.js';
78
84
  import '../progress/LinearProgress/LinearProgress.js';
@@ -91,7 +97,6 @@ import '../toggle-button/ToggleButton.js';
91
97
  import '../toggle-button-group/ToggleButtonGroup.js';
92
98
  import '../toggle-button-group/ToggleButtonGroupContext.js';
93
99
  import '../tooltip/Tooltip.js';
94
- import '@floating-ui/react';
95
100
  import { useTruncatePills } from './useTruncatePills.js';
96
101
  import css_248z from './PillInput.css.js';
97
102
 
@@ -1 +1 @@
1
- {"version":3,"file":"PillInput.js","sources":["../src/pill-input/PillInput.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport {\n ChangeEvent,\n KeyboardEvent,\n SyntheticEvent,\n ComponentPropsWithoutRef,\n MouseEvent,\n ForwardedRef,\n forwardRef,\n InputHTMLAttributes,\n ReactNode,\n Ref,\n useState,\n useRef,\n} from \"react\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { CloseIcon, OverflowMenuIcon } from \"@salt-ds/icons\";\nimport { makePrefixer, useControlled, useId, useForkRef } from \"../utils\";\nimport { useFormFieldProps } from \"../form-field-context\";\nimport { StatusAdornment } from \"../status-adornment\";\nimport { Pill } from \"../pill\";\nimport { useTruncatePills } from \"./useTruncatePills\";\n\nimport pillInputCss from \"./PillInput.css\";\n\nconst withBaseName = makePrefixer(\"saltPillInput\");\n\nexport interface PillInputProps\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 * The tokens to display in the input.\n */\n pills?: string[];\n onPillRemove?: (event: SyntheticEvent, index: number) => void;\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 hidePillClose?: boolean;\n truncate?: boolean;\n}\n\nexport const PillInput = forwardRef(function PillInput(\n {\n \"aria-activedescendant\": ariaActiveDescendant,\n \"aria-expanded\": ariaExpanded,\n \"aria-owns\": ariaOwns,\n className: classNameProp,\n disabled,\n emptyReadOnlyMarker = \"—\",\n endAdornment,\n hidePillClose,\n id: idProp,\n inputProps = {},\n inputRef: inputRefProp,\n placeholder,\n pills = [],\n onPillRemove,\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 truncate,\n ...other\n }: PillInputProps,\n ref: ForwardedRef<HTMLDivElement>\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-pill-input\",\n css: pillInputCss,\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 [focusedPillIndex, setFocusedPillIndex] = useState(-1);\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 onChange,\n required: inputPropsRequired,\n onKeyDown: inputOnKeyDown,\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 { visiblePills, pillListRef } = useTruncatePills({\n pills,\n enable: truncate && pills.length > 0,\n });\n\n const id = useId(idProp);\n const pillListId = `${id}-optionsList`;\n\n const pillElementsRef = useRef<HTMLElement[]>([]);\n const inputRef = useRef<HTMLInputElement>(null);\n\n const handleInputRef = useForkRef(inputRef, inputRefProp);\n\n const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n const value = event.target.value;\n setValue(value);\n onChange?.(event);\n };\n\n const handleKeyDown = (event: KeyboardEvent<HTMLInputElement>) => {\n const target = event.currentTarget;\n if (target.selectionStart === 0 && target.selectionEnd == 0) {\n const lastPillIndex = pills.length - 1;\n const lastPill = pills[lastPillIndex];\n if (event.key === \"Backspace\" && lastPill) {\n event.preventDefault();\n onPillRemove?.(event, lastPillIndex);\n } else if (event.key === \"ArrowLeft\") {\n event.preventDefault();\n // Move focus to last pill\n pillElementsRef.current[lastPillIndex]?.focus();\n }\n }\n\n inputOnKeyDown?.(event);\n };\n\n const handlePillKeyDown = (event: KeyboardEvent<HTMLButtonElement>) => {\n const target = event.currentTarget;\n const index = Number(target.dataset.index);\n if (event.key === \"ArrowLeft\") {\n event.preventDefault();\n // Move focus to previous pill\n pillElementsRef.current[index - 1]?.focus();\n } else if (event.key === \"ArrowRight\") {\n event.preventDefault();\n // Move focus to next pill or input\n if (index === pills.length - 1) {\n inputRef?.current?.focus();\n } else {\n pillElementsRef.current[index + 1]?.focus();\n }\n } else if (event.key == \"Delete\" || event.key === \"Backspace\") {\n event.preventDefault();\n onPillRemove?.(event, index);\n\n if (pills.length === 1) {\n inputRef.current?.focus();\n } else if (index === pills.length - 1) {\n pillElementsRef.current[pills.length - 2]?.focus();\n } else {\n pillElementsRef.current[index]?.focus();\n }\n }\n };\n\n const handlePillClick = (event: MouseEvent<HTMLButtonElement>) => {\n const target = event.currentTarget;\n const index = Number(target.dataset.index);\n onPillRemove?.(event, index);\n inputRef.current?.focus();\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(\"disabled\")]: isDisabled,\n [withBaseName(\"readOnly\")]: isReadOnly,\n [withBaseName(\"truncate\")]: truncate,\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 <div className={withBaseName(\"inputWrapper\")} ref={pillListRef}>\n <div\n role=\"list\"\n className={withBaseName(\"pillList\")}\n aria-labelledby={clsx(formFieldLabelledBy, pillListId)}\n aria-label=\"Selected Options\"\n id={pillListId}\n >\n {visiblePills?.map((pill, index) => (\n <div role=\"listitem\" key={index}>\n <Pill\n data-index={index}\n disabled={disabled}\n ref={(element) => {\n if (element) {\n pillElementsRef.current[index] = element;\n } else {\n pillElementsRef.current = pillElementsRef.current.filter(\n (pillEl) => pillEl !== element\n );\n }\n }}\n onFocus={() => setFocusedPillIndex(index)}\n onKeyDown={handlePillKeyDown}\n onClick={handlePillClick}\n tabIndex={\n focusedPillIndex === -1 || focusedPillIndex === index ? 0 : -1\n }\n >\n {pill}\n {!hidePillClose && <CloseIcon aria-label=\"click to close\" />}\n </Pill>\n </div>\n ))}\n {visiblePills.length < pills.length && (\n <div role=\"listitem\">\n <div\n data-overflowindicator\n className={withBaseName(\"overflowIndicator\")}\n >\n <OverflowMenuIcon aria-hidden />\n </div>\n </div>\n )}\n </div>\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={handleInputRef}\n role={role}\n tabIndex={isDisabled ? -1 : 0}\n onChange={handleChange}\n onKeyDown={handleKeyDown}\n placeholder={placeholder}\n value={value}\n {...restA11yProps}\n {...restInputProps}\n required={isRequired}\n />\n </div>\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":["PillInput","pillInputCss","value"],"mappings":"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"}
1
+ {"version":3,"file":"PillInput.js","sources":["../src/pill-input/PillInput.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport {\n ChangeEvent,\n KeyboardEvent,\n SyntheticEvent,\n ComponentPropsWithoutRef,\n MouseEvent,\n ForwardedRef,\n forwardRef,\n InputHTMLAttributes,\n ReactNode,\n Ref,\n useState,\n useRef,\n} from \"react\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { CloseIcon, OverflowMenuIcon } from \"@salt-ds/icons\";\nimport { makePrefixer, useControlled, useId, useForkRef } from \"../utils\";\nimport { useFormFieldProps } from \"../form-field-context\";\nimport { StatusAdornment } from \"../status-adornment\";\nimport { Pill } from \"../pill\";\nimport { useTruncatePills } from \"./useTruncatePills\";\n\nimport pillInputCss from \"./PillInput.css\";\n\nconst withBaseName = makePrefixer(\"saltPillInput\");\n\nexport interface PillInputProps\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 * The tokens to display in the input.\n */\n pills?: string[];\n onPillRemove?: (event: SyntheticEvent, index: number) => void;\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 hidePillClose?: boolean;\n truncate?: boolean;\n}\n\nexport const PillInput = forwardRef(function PillInput(\n {\n \"aria-activedescendant\": ariaActiveDescendant,\n \"aria-expanded\": ariaExpanded,\n \"aria-owns\": ariaOwns,\n className: classNameProp,\n disabled,\n emptyReadOnlyMarker = \"—\",\n endAdornment,\n hidePillClose,\n id: idProp,\n inputProps = {},\n inputRef: inputRefProp,\n placeholder,\n pills = [],\n onPillRemove,\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 truncate,\n ...other\n }: PillInputProps,\n ref: ForwardedRef<HTMLDivElement>\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-pill-input\",\n css: pillInputCss,\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 [focusedPillIndex, setFocusedPillIndex] = useState(-1);\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 onChange,\n required: inputPropsRequired,\n onKeyDown: inputOnKeyDown,\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 { visiblePills, pillListRef } = useTruncatePills({\n pills,\n enable: truncate && pills.length > 0,\n });\n\n const id = useId(idProp);\n const pillListId = `${id}-optionsList`;\n\n const pillElementsRef = useRef<HTMLElement[]>([]);\n const inputRef = useRef<HTMLInputElement>(null);\n\n const handleInputRef = useForkRef(inputRef, inputRefProp);\n\n const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n const value = event.target.value;\n setValue(value);\n onChange?.(event);\n };\n\n const handleKeyDown = (event: KeyboardEvent<HTMLInputElement>) => {\n const target = event.currentTarget;\n if (target.selectionStart === 0 && target.selectionEnd == 0) {\n const lastPillIndex = pills.length - 1;\n const lastPill = pills[lastPillIndex];\n if (event.key === \"Backspace\" && lastPill) {\n event.preventDefault();\n onPillRemove?.(event, lastPillIndex);\n } else if (event.key === \"ArrowLeft\") {\n event.preventDefault();\n // Move focus to last pill\n pillElementsRef.current[lastPillIndex]?.focus();\n }\n }\n\n inputOnKeyDown?.(event);\n };\n\n const handlePillKeyDown = (event: KeyboardEvent<HTMLButtonElement>) => {\n const target = event.currentTarget;\n const index = Number(target.dataset.index);\n if (event.key === \"ArrowLeft\") {\n event.preventDefault();\n // Move focus to previous pill\n pillElementsRef.current[index - 1]?.focus();\n } else if (event.key === \"ArrowRight\") {\n event.preventDefault();\n // Move focus to next pill or input\n if (index === pills.length - 1) {\n inputRef?.current?.focus();\n } else {\n pillElementsRef.current[index + 1]?.focus();\n }\n } else if (event.key == \"Delete\" || event.key === \"Backspace\") {\n event.preventDefault();\n onPillRemove?.(event, index);\n\n if (pills.length === 1) {\n inputRef.current?.focus();\n } else if (index === pills.length - 1) {\n pillElementsRef.current[pills.length - 2]?.focus();\n } else {\n pillElementsRef.current[index]?.focus();\n }\n }\n };\n\n const handlePillClick = (event: MouseEvent<HTMLButtonElement>) => {\n const target = event.currentTarget;\n const index = Number(target.dataset.index);\n onPillRemove?.(event, index);\n inputRef.current?.focus();\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(\"disabled\")]: isDisabled,\n [withBaseName(\"readOnly\")]: isReadOnly,\n [withBaseName(\"truncate\")]: truncate,\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 <div className={withBaseName(\"inputWrapper\")} ref={pillListRef}>\n <div\n role=\"list\"\n className={withBaseName(\"pillList\")}\n aria-labelledby={clsx(formFieldLabelledBy, pillListId)}\n aria-label=\"Selected Options\"\n id={pillListId}\n >\n {visiblePills?.map((pill, index) => (\n <div role=\"listitem\" key={index}>\n <Pill\n data-index={index}\n disabled={disabled}\n ref={(element) => {\n if (element) {\n pillElementsRef.current[index] = element;\n } else {\n pillElementsRef.current = pillElementsRef.current.filter(\n (pillEl) => pillEl !== element\n );\n }\n }}\n onFocus={() => setFocusedPillIndex(index)}\n onKeyDown={handlePillKeyDown}\n onClick={handlePillClick}\n tabIndex={\n focusedPillIndex === -1 || focusedPillIndex === index ? 0 : -1\n }\n >\n {pill}\n {!hidePillClose && <CloseIcon aria-label=\"click to close\" />}\n </Pill>\n </div>\n ))}\n {visiblePills.length < pills.length && (\n <div role=\"listitem\">\n <div\n data-overflowindicator\n className={withBaseName(\"overflowIndicator\")}\n >\n <OverflowMenuIcon aria-hidden />\n </div>\n </div>\n )}\n </div>\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={handleInputRef}\n role={role}\n tabIndex={isDisabled ? -1 : 0}\n onChange={handleChange}\n onKeyDown={handleKeyDown}\n placeholder={placeholder}\n value={value}\n {...restA11yProps}\n {...restInputProps}\n required={isRequired}\n />\n </div>\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":["PillInput","pillInputCss","value"],"mappings":"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"}
@@ -64,12 +64,18 @@ import '../../multiline-input/MultilineInput.js';
64
64
  import '../../navigation-item/NavigationItem.js';
65
65
  import '../../option/Option.js';
66
66
  import '../../option/OptionGroup.js';
67
+ import '../../overlay/OverlayContext.js';
68
+ import '@floating-ui/react';
69
+ import '../../overlay/OverlayPanel.js';
70
+ import '../../overlay/OverlayPanelCloseButton.js';
71
+ import '../../overlay/OverlayPanelContent.js';
67
72
  import '../../pagination/Pagination.js';
68
73
  import '../../pagination/Paginator.js';
69
74
  import '../../pagination/CompactInput.js';
70
75
  import '../../pagination/CompactPaginator.js';
71
76
  import '../../pagination/GoToInput.js';
72
77
  import '../../panel/Panel.js';
78
+ import '../../parent-child-layout/ParentChildLayout.js';
73
79
  import '../../pill/Pill.js';
74
80
  import '../LinearProgress/LinearProgress.js';
75
81
  import '../../radio-button/RadioButton.js';
@@ -87,7 +93,6 @@ import '../../toggle-button/ToggleButton.js';
87
93
  import '../../toggle-button-group/ToggleButtonGroup.js';
88
94
  import '../../toggle-button-group/ToggleButtonGroupContext.js';
89
95
  import '../../tooltip/Tooltip.js';
90
- import '@floating-ui/react';
91
96
  import css_248z from './CircularProgress.css.js';
92
97
 
93
98
  const withBaseName = makePrefixer("saltCircularProgress");
@@ -1 +1 @@
1
- {"version":3,"file":"CircularProgress.js","sources":["../src/progress/CircularProgress/CircularProgress.tsx"],"sourcesContent":["import { ComponentPropsWithoutRef, CSSProperties, forwardRef } from \"react\";\nimport { clsx } from \"clsx\";\nimport { makePrefixer } from \"../../utils\";\nimport { Text } from \"../../text\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport circularProgressCSS from \"./CircularProgress.css\";\n\nconst withBaseName = makePrefixer(\"saltCircularProgress\");\n\nconst getRotationAngle = (bar: number, shift = 0) => {\n return -180 + ((bar - shift) / 50) * 180;\n};\n\nexport interface CircularProgressProps extends ComponentPropsWithoutRef<\"div\"> {\n /**\n * The value of the buffer indicator.\n * Value between 0 and max.\n */\n bufferValue?: number;\n /**\n * Whether to hide the text label within the progress. Defaults to `false`.\n */\n hideLabel?: boolean;\n /**\n * The value of the max progress indicator.\n * Default value is 100.\n */\n max?: number;\n /**\n * The value of the min progress indicator.\n * Default value is 0.\n */\n min?: number;\n /**\n * The value of the progress indicator.\n * Value between 0 and max.\n */\n value?: number;\n}\n\nexport const CircularProgress = forwardRef<\n HTMLDivElement,\n CircularProgressProps\n>(function CircularProgress(\n {\n className,\n hideLabel = false,\n max = 100,\n min = 0,\n value = 0,\n bufferValue = 0,\n ...rest\n },\n ref\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-circular-progress\",\n css: circularProgressCSS,\n window: targetWindow,\n });\n\n const bufferSubOverlayRightStyle: CSSProperties = {};\n const bufferSubOverlayLeftStyle: CSSProperties = {};\n const barSubOverlayRightStyle: CSSProperties = {};\n const barSubOverlayLeftStyle: CSSProperties = {};\n\n const buffer = ((bufferValue - min) / (max - min)) * 100;\n const progress = ((value - min) / (max - min)) * 100;\n\n if (progress <= 50) {\n const rotationAngle = getRotationAngle(progress);\n barSubOverlayRightStyle.transform = `rotate(${rotationAngle}deg)`;\n barSubOverlayLeftStyle.transform = \"rotate(-180deg)\";\n } else {\n const rotationAngle = getRotationAngle(progress, 50);\n barSubOverlayRightStyle.transform = \"rotate(0deg)\";\n barSubOverlayLeftStyle.transform = `rotate(${rotationAngle}deg)`;\n }\n if (buffer <= 50) {\n const rotationAngle = getRotationAngle(buffer);\n bufferSubOverlayRightStyle.transform = `rotate(${rotationAngle}deg)`;\n bufferSubOverlayLeftStyle.transform = \"rotate(-180deg)\";\n } else {\n const rotationAngle = getRotationAngle(buffer, 50);\n bufferSubOverlayRightStyle.transform = \"rotate(0deg)\";\n bufferSubOverlayLeftStyle.transform = `rotate(${rotationAngle}deg)`;\n }\n\n return (\n <div\n className={clsx(withBaseName(), className)}\n ref={ref}\n role=\"progressbar\"\n aria-valuemax={max}\n aria-valuemin={min}\n aria-valuenow={Math.round(value)}\n {...rest}\n >\n <div className={withBaseName(\"track\")} />\n <div className={withBaseName(\"bars\")}>\n {buffer > 0 && (\n <div className={withBaseName(\"bufferOverlayRight\")}>\n <div\n className={clsx(withBaseName(\"bufferSubOverlayRight\"), {\n [withBaseName(\"bufferSubOverlay\")]: buffer <= 50,\n })}\n style={bufferSubOverlayRightStyle}\n >\n <div className={withBaseName(\"bufferBackground\")} />\n <div className={withBaseName(\"bufferBorder\")} />\n </div>\n </div>\n )}\n <div className={withBaseName(\"barOverlayRight\")}>\n <div\n className={withBaseName(\"barSubOverlayRight\")}\n style={barSubOverlayRightStyle}\n >\n <div className={withBaseName(\"bar\")} />\n </div>\n </div>\n {buffer > 0 && (\n <div className={withBaseName(\"bufferOverlayLeft\")}>\n <div\n className={clsx(\n withBaseName(\"bufferSubOverlay\"),\n withBaseName(\"bufferSubOverlayLeft\")\n )}\n style={bufferSubOverlayLeftStyle}\n >\n <div className={withBaseName(\"bufferBorder\")} />\n <div className={withBaseName(\"bufferBackground\")} />\n </div>\n </div>\n )}\n <div className={withBaseName(\"barOverlayLeft\")}>\n <div\n className={withBaseName(\"barSubOverlayLeft\")}\n style={barSubOverlayLeftStyle}\n >\n <div className={withBaseName(\"bar\")} />\n </div>\n </div>\n </div>\n {!hideLabel && (\n <Text styleAs=\"h2\" className={withBaseName(\"progressLabel\")}>\n {`${Math.round(progress)} %`}\n </Text>\n )}\n </div>\n );\n});\n"],"names":["CircularProgress","circularProgressCSS"],"mappings":"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"}
1
+ {"version":3,"file":"CircularProgress.js","sources":["../src/progress/CircularProgress/CircularProgress.tsx"],"sourcesContent":["import { ComponentPropsWithoutRef, CSSProperties, forwardRef } from \"react\";\nimport { clsx } from \"clsx\";\nimport { makePrefixer } from \"../../utils\";\nimport { Text } from \"../../text\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport circularProgressCSS from \"./CircularProgress.css\";\n\nconst withBaseName = makePrefixer(\"saltCircularProgress\");\n\nconst getRotationAngle = (bar: number, shift = 0) => {\n return -180 + ((bar - shift) / 50) * 180;\n};\n\nexport interface CircularProgressProps extends ComponentPropsWithoutRef<\"div\"> {\n /**\n * The value of the buffer indicator.\n * Value between 0 and max.\n */\n bufferValue?: number;\n /**\n * Whether to hide the text label within the progress. Defaults to `false`.\n */\n hideLabel?: boolean;\n /**\n * The value of the max progress indicator.\n * Default value is 100.\n */\n max?: number;\n /**\n * The value of the min progress indicator.\n * Default value is 0.\n */\n min?: number;\n /**\n * The value of the progress indicator.\n * Value between 0 and max.\n */\n value?: number;\n}\n\nexport const CircularProgress = forwardRef<\n HTMLDivElement,\n CircularProgressProps\n>(function CircularProgress(\n {\n className,\n hideLabel = false,\n max = 100,\n min = 0,\n value = 0,\n bufferValue = 0,\n ...rest\n },\n ref\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-circular-progress\",\n css: circularProgressCSS,\n window: targetWindow,\n });\n\n const bufferSubOverlayRightStyle: CSSProperties = {};\n const bufferSubOverlayLeftStyle: CSSProperties = {};\n const barSubOverlayRightStyle: CSSProperties = {};\n const barSubOverlayLeftStyle: CSSProperties = {};\n\n const buffer = ((bufferValue - min) / (max - min)) * 100;\n const progress = ((value - min) / (max - min)) * 100;\n\n if (progress <= 50) {\n const rotationAngle = getRotationAngle(progress);\n barSubOverlayRightStyle.transform = `rotate(${rotationAngle}deg)`;\n barSubOverlayLeftStyle.transform = \"rotate(-180deg)\";\n } else {\n const rotationAngle = getRotationAngle(progress, 50);\n barSubOverlayRightStyle.transform = \"rotate(0deg)\";\n barSubOverlayLeftStyle.transform = `rotate(${rotationAngle}deg)`;\n }\n if (buffer <= 50) {\n const rotationAngle = getRotationAngle(buffer);\n bufferSubOverlayRightStyle.transform = `rotate(${rotationAngle}deg)`;\n bufferSubOverlayLeftStyle.transform = \"rotate(-180deg)\";\n } else {\n const rotationAngle = getRotationAngle(buffer, 50);\n bufferSubOverlayRightStyle.transform = \"rotate(0deg)\";\n bufferSubOverlayLeftStyle.transform = `rotate(${rotationAngle}deg)`;\n }\n\n return (\n <div\n className={clsx(withBaseName(), className)}\n ref={ref}\n role=\"progressbar\"\n aria-valuemax={max}\n aria-valuemin={min}\n aria-valuenow={Math.round(value)}\n {...rest}\n >\n <div className={withBaseName(\"track\")} />\n <div className={withBaseName(\"bars\")}>\n {buffer > 0 && (\n <div className={withBaseName(\"bufferOverlayRight\")}>\n <div\n className={clsx(withBaseName(\"bufferSubOverlayRight\"), {\n [withBaseName(\"bufferSubOverlay\")]: buffer <= 50,\n })}\n style={bufferSubOverlayRightStyle}\n >\n <div className={withBaseName(\"bufferBackground\")} />\n <div className={withBaseName(\"bufferBorder\")} />\n </div>\n </div>\n )}\n <div className={withBaseName(\"barOverlayRight\")}>\n <div\n className={withBaseName(\"barSubOverlayRight\")}\n style={barSubOverlayRightStyle}\n >\n <div className={withBaseName(\"bar\")} />\n </div>\n </div>\n {buffer > 0 && (\n <div className={withBaseName(\"bufferOverlayLeft\")}>\n <div\n className={clsx(\n withBaseName(\"bufferSubOverlay\"),\n withBaseName(\"bufferSubOverlayLeft\")\n )}\n style={bufferSubOverlayLeftStyle}\n >\n <div className={withBaseName(\"bufferBorder\")} />\n <div className={withBaseName(\"bufferBackground\")} />\n </div>\n </div>\n )}\n <div className={withBaseName(\"barOverlayLeft\")}>\n <div\n className={withBaseName(\"barSubOverlayLeft\")}\n style={barSubOverlayLeftStyle}\n >\n <div className={withBaseName(\"bar\")} />\n </div>\n </div>\n </div>\n {!hideLabel && (\n <Text styleAs=\"h2\" className={withBaseName(\"progressLabel\")}>\n {`${Math.round(progress)} %`}\n </Text>\n )}\n </div>\n );\n});\n"],"names":["CircularProgress","circularProgressCSS"],"mappings":"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"}
@@ -64,12 +64,18 @@ import '../../multiline-input/MultilineInput.js';
64
64
  import '../../navigation-item/NavigationItem.js';
65
65
  import '../../option/Option.js';
66
66
  import '../../option/OptionGroup.js';
67
+ import '../../overlay/OverlayContext.js';
68
+ import '@floating-ui/react';
69
+ import '../../overlay/OverlayPanel.js';
70
+ import '../../overlay/OverlayPanelCloseButton.js';
71
+ import '../../overlay/OverlayPanelContent.js';
67
72
  import '../../pagination/Pagination.js';
68
73
  import '../../pagination/Paginator.js';
69
74
  import '../../pagination/CompactInput.js';
70
75
  import '../../pagination/CompactPaginator.js';
71
76
  import '../../pagination/GoToInput.js';
72
77
  import '../../panel/Panel.js';
78
+ import '../../parent-child-layout/ParentChildLayout.js';
73
79
  import '../../pill/Pill.js';
74
80
  import '../CircularProgress/CircularProgress.js';
75
81
  import '../../radio-button/RadioButton.js';
@@ -87,7 +93,6 @@ import '../../toggle-button/ToggleButton.js';
87
93
  import '../../toggle-button-group/ToggleButtonGroup.js';
88
94
  import '../../toggle-button-group/ToggleButtonGroupContext.js';
89
95
  import '../../tooltip/Tooltip.js';
90
- import '@floating-ui/react';
91
96
  import css_248z from './LinearProgress.css.js';
92
97
 
93
98
  const withBaseName = makePrefixer("saltLinearProgress");
@@ -129,10 +134,10 @@ const LinearProgress = forwardRef(
129
134
  className: withBaseName("bar"),
130
135
  style: barStyle
131
136
  }),
132
- bufferValue && /* @__PURE__ */ jsx("div", {
137
+ bufferValue > 0 ? /* @__PURE__ */ jsx("div", {
133
138
  className: withBaseName("buffer"),
134
139
  style: bufferStyle
135
- }),
140
+ }) : null,
136
141
  /* @__PURE__ */ jsx("div", {
137
142
  className: withBaseName("track")
138
143
  })