@salt-ds/lab 1.0.0-alpha.27 → 1.0.0-alpha.29

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 (186) hide show
  1. package/css/salt-lab.css +33 -309
  2. package/dist-cjs/color-chooser/ColorChooser.css.js +1 -1
  3. package/dist-cjs/color-chooser/ColorChooser.js +52 -55
  4. package/dist-cjs/color-chooser/ColorChooser.js.map +1 -1
  5. package/dist-cjs/index.js +4 -22
  6. package/dist-cjs/index.js.map +1 -1
  7. package/dist-cjs/layer-layout/LayerLayout.js +1 -2
  8. package/dist-cjs/layer-layout/LayerLayout.js.map +1 -1
  9. package/dist-cjs/overlay/Overlay.css.js +1 -1
  10. package/dist-cjs/overlay/Overlay.js +89 -60
  11. package/dist-cjs/overlay/Overlay.js.map +1 -1
  12. package/dist-cjs/overlay/OverlayContext.js +43 -0
  13. package/dist-cjs/overlay/OverlayContext.js.map +1 -0
  14. package/dist-cjs/overlay/OverlayPanel.js +64 -0
  15. package/dist-cjs/overlay/OverlayPanel.js.map +1 -0
  16. package/dist-cjs/overlay/OverlayPanelBase.js +65 -0
  17. package/dist-cjs/overlay/OverlayPanelBase.js.map +1 -0
  18. package/dist-cjs/overlay/OverlayTrigger.js +40 -0
  19. package/dist-cjs/overlay/OverlayTrigger.js.map +1 -0
  20. package/dist-es/color-chooser/ColorChooser.css.js +1 -1
  21. package/dist-es/color-chooser/ColorChooser.js +53 -56
  22. package/dist-es/color-chooser/ColorChooser.js.map +1 -1
  23. package/dist-es/index.js +2 -11
  24. package/dist-es/index.js.map +1 -1
  25. package/dist-es/layer-layout/LayerLayout.js +1 -2
  26. package/dist-es/layer-layout/LayerLayout.js.map +1 -1
  27. package/dist-es/overlay/Overlay.css.js +1 -1
  28. package/dist-es/overlay/Overlay.js +91 -62
  29. package/dist-es/overlay/Overlay.js.map +1 -1
  30. package/dist-es/overlay/OverlayContext.js +38 -0
  31. package/dist-es/overlay/OverlayContext.js.map +1 -0
  32. package/dist-es/overlay/OverlayPanel.js +60 -0
  33. package/dist-es/overlay/OverlayPanel.js.map +1 -0
  34. package/dist-es/overlay/OverlayPanelBase.js +57 -0
  35. package/dist-es/overlay/OverlayPanelBase.js.map +1 -0
  36. package/dist-es/overlay/OverlayTrigger.js +36 -0
  37. package/dist-es/overlay/OverlayTrigger.js.map +1 -0
  38. package/dist-types/index.d.ts +0 -4
  39. package/dist-types/layer-layout/LayerLayout.d.ts +1 -1
  40. package/dist-types/overlay/Overlay.d.ts +6 -14
  41. package/dist-types/overlay/OverlayContext.d.ts +26 -0
  42. package/dist-types/overlay/OverlayPanel.d.ts +4 -0
  43. package/dist-types/overlay/OverlayPanelBase.d.ts +2 -0
  44. package/dist-types/overlay/OverlayTrigger.d.ts +5 -0
  45. package/dist-types/overlay/index.d.ts +2 -1
  46. package/package.json +2 -2
  47. package/dist-cjs/file-drop-zone/FileDropZone.css.js +0 -6
  48. package/dist-cjs/file-drop-zone/FileDropZone.css.js.map +0 -1
  49. package/dist-cjs/file-drop-zone/FileDropZone.js +0 -94
  50. package/dist-cjs/file-drop-zone/FileDropZone.js.map +0 -1
  51. package/dist-cjs/file-drop-zone/FileDropZoneIcon.js +0 -25
  52. package/dist-cjs/file-drop-zone/FileDropZoneIcon.js.map +0 -1
  53. package/dist-cjs/file-drop-zone/FileDropZoneTrigger.js +0 -52
  54. package/dist-cjs/file-drop-zone/FileDropZoneTrigger.js.map +0 -1
  55. package/dist-cjs/file-drop-zone/internal/utils.js +0 -30
  56. package/dist-cjs/file-drop-zone/internal/utils.js.map +0 -1
  57. package/dist-cjs/navigation-item/ConditionalWrapper.js +0 -35
  58. package/dist-cjs/navigation-item/ConditionalWrapper.js.map +0 -1
  59. package/dist-cjs/navigation-item/ExpansionIcon.js +0 -29
  60. package/dist-cjs/navigation-item/ExpansionIcon.js.map +0 -1
  61. package/dist-cjs/navigation-item/NavigationItem.css.js +0 -6
  62. package/dist-cjs/navigation-item/NavigationItem.css.js.map +0 -1
  63. package/dist-cjs/navigation-item/NavigationItem.js +0 -78
  64. package/dist-cjs/navigation-item/NavigationItem.js.map +0 -1
  65. package/dist-cjs/overlay/useOverlay.js +0 -97
  66. package/dist-cjs/overlay/useOverlay.js.map +0 -1
  67. package/dist-cjs/pagination/CompactInput.css.js +0 -6
  68. package/dist-cjs/pagination/CompactInput.css.js.map +0 -1
  69. package/dist-cjs/pagination/CompactInput.js +0 -62
  70. package/dist-cjs/pagination/CompactInput.js.map +0 -1
  71. package/dist-cjs/pagination/CompactPaginator.css.js +0 -6
  72. package/dist-cjs/pagination/CompactPaginator.css.js.map +0 -1
  73. package/dist-cjs/pagination/CompactPaginator.js +0 -76
  74. package/dist-cjs/pagination/CompactPaginator.js.map +0 -1
  75. package/dist-cjs/pagination/GoToInput.css.js +0 -6
  76. package/dist-cjs/pagination/GoToInput.css.js.map +0 -1
  77. package/dist-cjs/pagination/GoToInput.js +0 -77
  78. package/dist-cjs/pagination/GoToInput.js.map +0 -1
  79. package/dist-cjs/pagination/PageButton.css.js +0 -6
  80. package/dist-cjs/pagination/PageButton.css.js.map +0 -1
  81. package/dist-cjs/pagination/PageButton.js +0 -44
  82. package/dist-cjs/pagination/PageButton.js.map +0 -1
  83. package/dist-cjs/pagination/PageRanges.css.js +0 -6
  84. package/dist-cjs/pagination/PageRanges.css.js.map +0 -1
  85. package/dist-cjs/pagination/PageRanges.js +0 -73
  86. package/dist-cjs/pagination/PageRanges.js.map +0 -1
  87. package/dist-cjs/pagination/Pagination.css.js +0 -6
  88. package/dist-cjs/pagination/Pagination.css.js.map +0 -1
  89. package/dist-cjs/pagination/Pagination.js +0 -78
  90. package/dist-cjs/pagination/Pagination.js.map +0 -1
  91. package/dist-cjs/pagination/PaginationContext.js +0 -17
  92. package/dist-cjs/pagination/PaginationContext.js.map +0 -1
  93. package/dist-cjs/pagination/Paginator.css.js +0 -6
  94. package/dist-cjs/pagination/Paginator.css.js.map +0 -1
  95. package/dist-cjs/pagination/Paginator.js +0 -69
  96. package/dist-cjs/pagination/Paginator.js.map +0 -1
  97. package/dist-cjs/pagination/usePagination.js +0 -27
  98. package/dist-cjs/pagination/usePagination.js.map +0 -1
  99. package/dist-cjs/pagination/usePaginationContext.js +0 -19
  100. package/dist-cjs/pagination/usePaginationContext.js.map +0 -1
  101. package/dist-cjs/scrim/Scrim.css.js +0 -6
  102. package/dist-cjs/scrim/Scrim.css.js.map +0 -1
  103. package/dist-cjs/scrim/Scrim.js +0 -40
  104. package/dist-cjs/scrim/Scrim.js.map +0 -1
  105. package/dist-es/file-drop-zone/FileDropZone.css.js +0 -4
  106. package/dist-es/file-drop-zone/FileDropZone.css.js.map +0 -1
  107. package/dist-es/file-drop-zone/FileDropZone.js +0 -90
  108. package/dist-es/file-drop-zone/FileDropZone.js.map +0 -1
  109. package/dist-es/file-drop-zone/FileDropZoneIcon.js +0 -21
  110. package/dist-es/file-drop-zone/FileDropZoneIcon.js.map +0 -1
  111. package/dist-es/file-drop-zone/FileDropZoneTrigger.js +0 -48
  112. package/dist-es/file-drop-zone/FileDropZoneTrigger.js.map +0 -1
  113. package/dist-es/file-drop-zone/internal/utils.js +0 -25
  114. package/dist-es/file-drop-zone/internal/utils.js.map +0 -1
  115. package/dist-es/navigation-item/ConditionalWrapper.js +0 -31
  116. package/dist-es/navigation-item/ConditionalWrapper.js.map +0 -1
  117. package/dist-es/navigation-item/ExpansionIcon.js +0 -25
  118. package/dist-es/navigation-item/ExpansionIcon.js.map +0 -1
  119. package/dist-es/navigation-item/NavigationItem.css.js +0 -4
  120. package/dist-es/navigation-item/NavigationItem.css.js.map +0 -1
  121. package/dist-es/navigation-item/NavigationItem.js +0 -74
  122. package/dist-es/navigation-item/NavigationItem.js.map +0 -1
  123. package/dist-es/overlay/useOverlay.js +0 -93
  124. package/dist-es/overlay/useOverlay.js.map +0 -1
  125. package/dist-es/pagination/CompactInput.css.js +0 -4
  126. package/dist-es/pagination/CompactInput.css.js.map +0 -1
  127. package/dist-es/pagination/CompactInput.js +0 -58
  128. package/dist-es/pagination/CompactInput.js.map +0 -1
  129. package/dist-es/pagination/CompactPaginator.css.js +0 -4
  130. package/dist-es/pagination/CompactPaginator.css.js.map +0 -1
  131. package/dist-es/pagination/CompactPaginator.js +0 -72
  132. package/dist-es/pagination/CompactPaginator.js.map +0 -1
  133. package/dist-es/pagination/GoToInput.css.js +0 -4
  134. package/dist-es/pagination/GoToInput.css.js.map +0 -1
  135. package/dist-es/pagination/GoToInput.js +0 -73
  136. package/dist-es/pagination/GoToInput.js.map +0 -1
  137. package/dist-es/pagination/PageButton.css.js +0 -4
  138. package/dist-es/pagination/PageButton.css.js.map +0 -1
  139. package/dist-es/pagination/PageButton.js +0 -40
  140. package/dist-es/pagination/PageButton.js.map +0 -1
  141. package/dist-es/pagination/PageRanges.css.js +0 -4
  142. package/dist-es/pagination/PageRanges.css.js.map +0 -1
  143. package/dist-es/pagination/PageRanges.js +0 -69
  144. package/dist-es/pagination/PageRanges.js.map +0 -1
  145. package/dist-es/pagination/Pagination.css.js +0 -4
  146. package/dist-es/pagination/Pagination.css.js.map +0 -1
  147. package/dist-es/pagination/Pagination.js +0 -74
  148. package/dist-es/pagination/Pagination.js.map +0 -1
  149. package/dist-es/pagination/PaginationContext.js +0 -13
  150. package/dist-es/pagination/PaginationContext.js.map +0 -1
  151. package/dist-es/pagination/Paginator.css.js +0 -4
  152. package/dist-es/pagination/Paginator.css.js.map +0 -1
  153. package/dist-es/pagination/Paginator.js +0 -65
  154. package/dist-es/pagination/Paginator.js.map +0 -1
  155. package/dist-es/pagination/usePagination.js +0 -23
  156. package/dist-es/pagination/usePagination.js.map +0 -1
  157. package/dist-es/pagination/usePaginationContext.js +0 -15
  158. package/dist-es/pagination/usePaginationContext.js.map +0 -1
  159. package/dist-es/scrim/Scrim.css.js +0 -4
  160. package/dist-es/scrim/Scrim.css.js.map +0 -1
  161. package/dist-es/scrim/Scrim.js +0 -36
  162. package/dist-es/scrim/Scrim.js.map +0 -1
  163. package/dist-types/file-drop-zone/FileDropZone.d.ts +0 -17
  164. package/dist-types/file-drop-zone/FileDropZoneIcon.d.ts +0 -9
  165. package/dist-types/file-drop-zone/FileDropZoneTrigger.d.ts +0 -22
  166. package/dist-types/file-drop-zone/index.d.ts +0 -3
  167. package/dist-types/file-drop-zone/internal/utils.d.ts +0 -3
  168. package/dist-types/navigation-item/ConditionalWrapper.d.ts +0 -8
  169. package/dist-types/navigation-item/ExpansionIcon.d.ts +0 -2
  170. package/dist-types/navigation-item/NavigationItem.d.ts +0 -36
  171. package/dist-types/navigation-item/index.d.ts +0 -1
  172. package/dist-types/overlay/useOverlay.d.ts +0 -8
  173. package/dist-types/pagination/CompactInput.d.ts +0 -2
  174. package/dist-types/pagination/CompactPaginator.d.ts +0 -1
  175. package/dist-types/pagination/GoToInput.d.ts +0 -16
  176. package/dist-types/pagination/PageButton.d.ts +0 -6
  177. package/dist-types/pagination/PageRanges.d.ts +0 -5
  178. package/dist-types/pagination/Pagination.d.ts +0 -20
  179. package/dist-types/pagination/PaginationContext.d.ts +0 -7
  180. package/dist-types/pagination/Paginator.d.ts +0 -12
  181. package/dist-types/pagination/index.d.ts +0 -5
  182. package/dist-types/pagination/usePagination.d.ts +0 -2
  183. package/dist-types/pagination/usePaginationContext.d.ts +0 -1
  184. package/dist-types/scrim/Scrim.d.ts +0 -13
  185. package/dist-types/scrim/index.d.ts +0 -1
  186. package/dist-types/scrim/internal/PreventFocus.d.ts +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -5,7 +5,6 @@ Object.defineProperty(exports, '__esModule', { value: true });
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
6
  var React = require('react');
7
7
  var clsx = require('clsx');
8
- var Scrim = require('../scrim/Scrim.js');
9
8
  var core = require('@salt-ds/core');
10
9
  var useIsViewportLargerThanBreakpoint = require('../utils/useIsViewportLargerThanBreakpoint.js');
11
10
  var window = require('@salt-ds/window');
@@ -80,7 +79,7 @@ const LayerLayout = React.forwardRef(
80
79
  ...rest,
81
80
  children
82
81
  }) : null;
83
- return disableScrim ? layerLayout : /* @__PURE__ */ jsxRuntime.jsx(Scrim.Scrim, {
82
+ return disableScrim ? layerLayout : /* @__PURE__ */ jsxRuntime.jsx(core.Scrim, {
84
83
  open: showComponent,
85
84
  className: clsx.clsx({
86
85
  [withBaseName("enter-animation")]: enterAnimation,
@@ -1 +1 @@
1
- {"version":3,"file":"LayerLayout.js","sources":["../src/layer-layout/LayerLayout.tsx"],"sourcesContent":["import { forwardRef, HTMLAttributes, useEffect, useState } from \"react\";\nimport { clsx } from \"clsx\";\n\nimport { Scrim, ScrimProps } from \"../scrim\";\n\nimport { Breakpoints, makePrefixer, usePrevious } from \"@salt-ds/core\";\nimport { useIsViewportLargerThanBreakpoint } from \"../utils\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport layerLayoutCss from \"./LayerLayout.css\";\n\nexport const LAYER_POSITIONS = [\n \"center\",\n \"left\",\n \"top\",\n \"right\",\n \"bottom\",\n] as const;\n\nexport type LayerPositions = (typeof LAYER_POSITIONS)[number];\n\nexport interface LayerLayoutProps extends HTMLAttributes<HTMLDivElement> {\n /**\n * Disable the scrim.\n */\n disableScrim?: boolean;\n /**\n * Defines the layer position within the screen.\n */\n position?: LayerPositions;\n /**\n * Breakpoint at which the layer will become fullscreen.\n */\n fullScreenAtBreakpoint?: keyof Breakpoints;\n /**\n * Disable all animations.\n */\n disableAnimations?: boolean;\n /**\n * Display or hide the component.\n */\n isOpen?: boolean;\n /**\n * Props to be passed to the Scrim component.\n */\n scrimProps?: Partial<ScrimProps>;\n}\n\nconst withBaseName = makePrefixer(\"saltLayerLayout\");\n\nconst ariaAttributes = { role: \"dialog\", \"aria-modal\": true };\n\nexport const LayerLayout = forwardRef<HTMLDivElement, LayerLayoutProps>(\n function LayerLayout(props, ref) {\n const {\n children,\n className,\n disableScrim = false,\n position = \"center\",\n fullScreenAtBreakpoint = \"sm\",\n disableAnimations = false,\n scrimProps,\n isOpen = true,\n ...rest\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-layer-layout\",\n css: layerLayoutCss,\n window: targetWindow,\n });\n\n const previousDisableAnimationsProp = usePrevious(\n disableAnimations,\n [disableAnimations],\n false\n ); // we check the previous value for this prop to prevent the animations from triggering again when it changes\n\n const [showComponent, setShowComponent] = useState(false);\n\n const [isAnimating, setIsAnimating] = useState(false);\n\n useEffect(() => {\n if ((!isOpen && disableAnimations) || (!isOpen && !isAnimating)) {\n setShowComponent(false);\n }\n\n if (isOpen && !showComponent) {\n setShowComponent(true);\n }\n }, [isOpen, showComponent, disableAnimations, isAnimating]);\n\n const fullScreen = useIsViewportLargerThanBreakpoint(\n fullScreenAtBreakpoint\n );\n\n const anchored = position !== \"center\" && !fullScreen;\n\n const enterAnimation =\n !disableAnimations && isOpen && !previousDisableAnimationsProp;\n\n const exitAnimation = !disableAnimations && !isOpen;\n\n const layerLayout = showComponent ? (\n <div\n ref={ref}\n className={clsx(withBaseName(), className, {\n [withBaseName(\"anchor\")]: anchored,\n [withBaseName(\"fullScreen\")]: fullScreen,\n [withBaseName(position)]: !fullScreen,\n [withBaseName(\"enter-animation\")]: enterAnimation,\n [withBaseName(\"exit-animation\")]: exitAnimation,\n })}\n onAnimationStart={() => setIsAnimating(true)}\n onAnimationEnd={() => {\n if (!isOpen && showComponent) {\n setShowComponent(false);\n }\n }}\n {...(disableScrim && ariaAttributes)}\n {...rest}\n >\n {children}\n </div>\n ) : null;\n\n return disableScrim ? (\n layerLayout\n ) : (\n <Scrim\n open={showComponent}\n className={clsx({\n [withBaseName(\"enter-animation\")]: enterAnimation,\n [withBaseName(\"exit-animation\")]: exitAnimation,\n })}\n {...scrimProps}\n >\n {layerLayout}\n </Scrim>\n );\n }\n);\n"],"names":["makePrefixer","forwardRef","LayerLayout","useWindow","useComponentCssInjection","layerLayoutCss","usePrevious","useState","useEffect","useIsViewportLargerThanBreakpoint","jsx","clsx","Scrim"],"mappings":"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"}
1
+ {"version":3,"file":"LayerLayout.js","sources":["../src/layer-layout/LayerLayout.tsx"],"sourcesContent":["import { forwardRef, HTMLAttributes, useEffect, useState } from \"react\";\nimport { clsx } from \"clsx\";\n\nimport { Scrim, ScrimProps } from \"@salt-ds/core\";\n\nimport { Breakpoints, makePrefixer, usePrevious } from \"@salt-ds/core\";\nimport { useIsViewportLargerThanBreakpoint } from \"../utils\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport layerLayoutCss from \"./LayerLayout.css\";\n\nexport const LAYER_POSITIONS = [\n \"center\",\n \"left\",\n \"top\",\n \"right\",\n \"bottom\",\n] as const;\n\nexport type LayerPositions = (typeof LAYER_POSITIONS)[number];\n\nexport interface LayerLayoutProps extends HTMLAttributes<HTMLDivElement> {\n /**\n * Disable the scrim.\n */\n disableScrim?: boolean;\n /**\n * Defines the layer position within the screen.\n */\n position?: LayerPositions;\n /**\n * Breakpoint at which the layer will become fullscreen.\n */\n fullScreenAtBreakpoint?: keyof Breakpoints;\n /**\n * Disable all animations.\n */\n disableAnimations?: boolean;\n /**\n * Display or hide the component.\n */\n isOpen?: boolean;\n /**\n * Props to be passed to the Scrim component.\n */\n scrimProps?: Partial<ScrimProps>;\n}\n\nconst withBaseName = makePrefixer(\"saltLayerLayout\");\n\nconst ariaAttributes = { role: \"dialog\", \"aria-modal\": true };\n\nexport const LayerLayout = forwardRef<HTMLDivElement, LayerLayoutProps>(\n function LayerLayout(props, ref) {\n const {\n children,\n className,\n disableScrim = false,\n position = \"center\",\n fullScreenAtBreakpoint = \"sm\",\n disableAnimations = false,\n scrimProps,\n isOpen = true,\n ...rest\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-layer-layout\",\n css: layerLayoutCss,\n window: targetWindow,\n });\n\n const previousDisableAnimationsProp = usePrevious(\n disableAnimations,\n [disableAnimations],\n false\n ); // we check the previous value for this prop to prevent the animations from triggering again when it changes\n\n const [showComponent, setShowComponent] = useState(false);\n\n const [isAnimating, setIsAnimating] = useState(false);\n\n useEffect(() => {\n if ((!isOpen && disableAnimations) || (!isOpen && !isAnimating)) {\n setShowComponent(false);\n }\n\n if (isOpen && !showComponent) {\n setShowComponent(true);\n }\n }, [isOpen, showComponent, disableAnimations, isAnimating]);\n\n const fullScreen = useIsViewportLargerThanBreakpoint(\n fullScreenAtBreakpoint\n );\n\n const anchored = position !== \"center\" && !fullScreen;\n\n const enterAnimation =\n !disableAnimations && isOpen && !previousDisableAnimationsProp;\n\n const exitAnimation = !disableAnimations && !isOpen;\n\n const layerLayout = showComponent ? (\n <div\n ref={ref}\n className={clsx(withBaseName(), className, {\n [withBaseName(\"anchor\")]: anchored,\n [withBaseName(\"fullScreen\")]: fullScreen,\n [withBaseName(position)]: !fullScreen,\n [withBaseName(\"enter-animation\")]: enterAnimation,\n [withBaseName(\"exit-animation\")]: exitAnimation,\n })}\n onAnimationStart={() => setIsAnimating(true)}\n onAnimationEnd={() => {\n if (!isOpen && showComponent) {\n setShowComponent(false);\n }\n }}\n {...(disableScrim && ariaAttributes)}\n {...rest}\n >\n {children}\n </div>\n ) : null;\n\n return disableScrim ? (\n layerLayout\n ) : (\n <Scrim\n open={showComponent}\n className={clsx({\n [withBaseName(\"enter-animation\")]: enterAnimation,\n [withBaseName(\"exit-animation\")]: exitAnimation,\n })}\n {...scrimProps}\n >\n {layerLayout}\n </Scrim>\n );\n }\n);\n"],"names":["makePrefixer","forwardRef","LayerLayout","useWindow","useComponentCssInjection","layerLayoutCss","usePrevious","useState","useEffect","useIsViewportLargerThanBreakpoint","jsx","clsx","Scrim"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- var css_248z = "/* Experimental - Overlay css variable API */\n.saltOverlay {\n --overlay-text-color: var(--salt-content-primary-foreground);\n --overlay-spacing: var(--salt-size-unit);\n --overlay-fontSize: var(--salt-text-fontSize);\n --overlay-background: var(--salt-container-primary-background);\n --overlay-borderColor: var(--salt-container-primary-borderColor);\n /* TODO: z-index audit, provide z index here or rely on popper */\n --overlay-zindex: var(--salt-zIndex-flyover);\n}\n\n.saltOverlay-secondary.saltOverlay {\n --overlay-background: var(--salt-container-secondary-background);\n --overlay-borderColor: var(--salt-container-secondary-borderColor);\n}\n\n.saltOverlay-content {\n display: flex;\n padding: calc(var(--overlay-spacing) * 2);\n font-size: var(--overlay-fontSize);\n\n border: 1px solid var(--overlay-borderColor);\n box-shadow: var(--salt-overlayable-shadow-popout);\n line-height: var(--salt-text-lineHeight);\n background: var(--overlay-background);\n color: var(--overlay-text-color);\n position: relative;\n opacity: 1;\n overflow: visible;\n z-index: var(--overlay-zindex);\n}\n\n.saltOverlay-arrow,\n.saltOverlay-arrow::after {\n border: 8px solid transparent;\n position: absolute;\n}\n\n.saltOverlay-arrow::after {\n content: \"\";\n}\n\n.saltOverlay[data-placement^=\"top\"] .saltOverlay-arrow {\n border-top-color: var(--overlay-borderColor);\n bottom: -17px;\n}\n\n.saltOverlay[data-placement^=\"bottom\"] .saltOverlay-arrow {\n border-bottom-color: var(--overlay-borderColor);\n top: -17px;\n}\n\n.saltOverlay[data-placement^=\"left\"] .saltOverlay-arrow {\n border-left-color: var(--overlay-borderColor);\n right: -17px;\n}\n\n.saltOverlay[data-placement^=\"right\"] .saltOverlay-arrow {\n border-right-color: var(--overlay-borderColor);\n left: -17px;\n}\n\n.saltOverlay[data-placement^=\"top\"] .saltOverlay-arrow::after {\n border-top-color: var(--overlay-background);\n bottom: -7px;\n left: calc(100% - 8px);\n}\n\n.saltOverlay[data-placement^=\"bottom\"] .saltOverlay-arrow::after {\n border-bottom-color: var(--overlay-background);\n top: -7px;\n left: calc(100% - 8px);\n}\n\n.saltOverlay[data-placement^=\"left\"] .saltOverlay-arrow::after {\n border-left-color: var(--overlay-background);\n right: -7px;\n top: calc(100% - 8px);\n}\n\n.saltOverlay[data-placement^=\"right\"] .saltOverlay-arrow::after {\n border-right-color: var(--overlay-background);\n left: -7px;\n top: calc(100% - 8px);\n}\n\n/* Close Button */\n.saltOverlay-close {\n position: absolute;\n right: 0;\n top: 0;\n z-index: var(--salt-zIndex-default);\n}\n";
3
+ var css_248z = ".saltOverlayPanel {\n --overlay-borderColor: var(--saltOverlay-borderColor, var(--salt-container-primary-borderColor));\n --overlay-background: var(--saltOverlay-background, var(--salt-container-primary-background));\n}\n\n.saltOverlayPanel {\n font-family: var(--salt-text-fontFamily);\n font-size: var(--saltOverlay-fontSize, var(--salt-text-fontSize));\n font-weight: var(--saltOverlay-fontWeight, var(--salt-text-fontWeight));\n line-height: var(--saltOverlay-lineHeight, var(--salt-text-lineHeight));\n\n border-color: var(--overlay-borderColor);\n border-style: var(--saltOverlay-borderStyle, var(--salt-container-borderStyle));\n border-width: var(--saltOverlay-borderWidth, var(--salt-size-border));\n\n background: var(--overlay-background);\n box-shadow: var(--saltOverlay-boxShadow, var(--salt-overlayable-shadow-popout));\n\n color: var(--saltOverlay-text-color, var(--salt-text-primary-foreground));\n z-index: var(--saltOverlay-zIndex, var(--salt-zIndex-flyover));\n width: max-content;\n}\n\n.saltOverlayPanelBase-container {\n animation: fade-in var(--salt-duration-perceptible) ease-in-out;\n position: relative;\n}\n\n@keyframes fade-in {\n 0% {\n opacity: 0;\n }\n 100% {\n opacity: 1;\n }\n}\n\n.saltOverlayPanelBase-content {\n overflow: auto;\n padding: var(--saltOverlay-content-padding, var(--salt-spacing-100) 0 var(--salt-spacing-100) var(--salt-spacing-100));\n}\n\n.saltButton-secondary.saltOverlayPanelBase-closeButton {\n position: sticky;\n top: 0;\n float: right;\n}\n";
4
4
 
5
5
  module.exports = css_248z;
6
6
  //# sourceMappingURL=Overlay.css.js.map
@@ -3,73 +3,102 @@
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
- var core = require('@salt-ds/core');
7
- var icons = require('@salt-ds/icons');
8
- var clsx = require('clsx');
9
6
  var React = require('react');
10
- var Portal = require('../portal/Portal.js');
11
- var styles = require('@salt-ds/styles');
12
- var window = require('@salt-ds/window');
13
- var WindowContext = require('../window/WindowContext.js');
14
- require('../window/ElectronWindow.js');
15
- var Overlay$1 = require('./Overlay.css.js');
7
+ var OverlayContext = require('./OverlayContext.js');
8
+ var core = require('@salt-ds/core');
9
+ var react = require('@floating-ui/react');
16
10
 
17
- const withBaseName = core.makePrefixer("saltOverlay");
18
11
  const Overlay = React.forwardRef(
19
- ({
20
- adaExceptions: { showClose } = {
21
- showClose: true
22
- },
23
- arrowProps,
24
- children,
25
- className,
26
- open,
27
- onOpenChange,
28
- variant = "primary",
29
- ...rest
30
- }, ref) => {
31
- const targetWindow = window.useWindow();
32
- styles.useComponentCssInjection({
33
- testId: "salt-overlay",
34
- css: Overlay$1,
35
- window: targetWindow
12
+ function Overlay2(props, ref) {
13
+ const {
14
+ children,
15
+ open,
16
+ onOpenChange,
17
+ placement: placementProp = "top",
18
+ id: idProp,
19
+ onClose,
20
+ ...rest
21
+ } = props;
22
+ const id = core.useId(idProp);
23
+ const arrowRef = React.useRef(null);
24
+ const [openState, setOpenState] = core.useControlled({
25
+ controlled: open,
26
+ default: false,
27
+ name: "Overlay",
28
+ state: "open"
29
+ });
30
+ const {
31
+ x,
32
+ y,
33
+ strategy,
34
+ context,
35
+ elements,
36
+ floating,
37
+ reference,
38
+ middlewareData: { arrow: { x: arrowX, y: arrowY } = {} },
39
+ placement
40
+ } = core.useFloatingUI({
41
+ open: openState,
42
+ onOpenChange: setOpenState,
43
+ placement: placementProp,
44
+ middleware: [
45
+ react.offset(11),
46
+ react.flip(),
47
+ react.shift({ limiter: react.limitShift() }),
48
+ react.arrow({ element: arrowRef })
49
+ ]
36
50
  });
37
- const id = core.useId();
38
- const Window = WindowContext.useWindow();
39
- const handleCloseButton = () => {
40
- onOpenChange == null ? void 0 : onOpenChange(false);
51
+ const { getReferenceProps, getFloatingProps } = react.useInteractions([
52
+ react.useRole(context, { role: "dialog" }),
53
+ react.useClick(context),
54
+ react.useDismiss(context)
55
+ ]);
56
+ const floatingStyles = React.useMemo(() => {
57
+ var _a, _b;
58
+ return {
59
+ top: y != null ? y : 0,
60
+ left: x != null ? x : 0,
61
+ position: strategy,
62
+ width: (_a = elements.floating) == null ? void 0 : _a.offsetWidth,
63
+ height: (_b = elements.floating) == null ? void 0 : _b.offsetHeight
64
+ };
65
+ }, [elements.floating, strategy, x, y]);
66
+ const setOpen = (event, newOpen) => {
67
+ setOpenState(newOpen);
68
+ onOpenChange == null ? void 0 : onOpenChange(event, newOpen);
69
+ };
70
+ const arrowProps = {
71
+ ref: arrowRef,
72
+ context,
73
+ style: {
74
+ position: strategy,
75
+ left: arrowX != null ? arrowX : 0,
76
+ top: arrowY != null ? arrowY : 0
77
+ }
78
+ };
79
+ const handleCloseButton = (event) => {
80
+ setOpen(event, false);
81
+ onClose == null ? void 0 : onClose(event);
41
82
  };
42
- if (!open) {
43
- return null;
44
- }
45
- return /* @__PURE__ */ jsxRuntime.jsx(Portal.Portal, {
46
- children: /* @__PURE__ */ jsxRuntime.jsx(Window, {
47
- className: clsx.clsx(withBaseName(), className, {
48
- [withBaseName(variant)]: variant === "secondary"
49
- }),
50
- id,
83
+ return /* @__PURE__ */ jsxRuntime.jsx(OverlayContext.OverlayContext.Provider, {
84
+ value: {
85
+ id: id != null ? id : "",
86
+ openState,
87
+ setOpen,
88
+ floatingStyles,
89
+ placement,
90
+ context,
91
+ arrowProps,
92
+ floating,
93
+ reference,
94
+ handleCloseButton,
95
+ getFloatingProps,
96
+ getReferenceProps
97
+ },
98
+ children: /* @__PURE__ */ jsxRuntime.jsx("div", {
51
99
  ref,
52
100
  ...rest,
53
- children: /* @__PURE__ */ jsxRuntime.jsxs("div", {
54
- className: clsx.clsx(withBaseName("content")),
55
- "data-testid": "overlay-content",
56
- children: [
57
- showClose && /* @__PURE__ */ jsxRuntime.jsx(core.Button, {
58
- onClick: handleCloseButton,
59
- className: withBaseName("close"),
60
- variant: "secondary",
61
- children: /* @__PURE__ */ jsxRuntime.jsx(icons.CloseIcon, {
62
- "accessible-text": "close overlay",
63
- className: withBaseName("closeIcon")
64
- })
65
- }),
66
- children,
67
- /* @__PURE__ */ jsxRuntime.jsx("div", {
68
- className: withBaseName("arrow"),
69
- ...arrowProps
70
- })
71
- ]
72
- })
101
+ children
73
102
  })
74
103
  });
75
104
  }
@@ -1 +1 @@
1
- {"version":3,"file":"Overlay.js","sources":["../src/overlay/Overlay.tsx"],"sourcesContent":["import { Button, makePrefixer, UseFloatingUIProps, useId } from \"@salt-ds/core\";\nimport { CloseIcon } from \"@salt-ds/icons\";\nimport { clsx } from \"clsx\";\nimport { ComponentProps, ComponentPropsWithoutRef, forwardRef } from \"react\";\nimport { Portal } from \"../portal\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport { useWindow as usePortalWindow } from \"../window\";\n\nimport overlayCSS from \"./Overlay.css\";\n\ninterface ADAExceptions {\n showClose?: boolean;\n}\n\nexport interface OverlayProps\n extends ComponentPropsWithoutRef<\"div\">,\n Partial<Pick<UseFloatingUIProps, \"onOpenChange\" | \"open\">> {\n /**\n * object that houses ada related props.\n * adaExceptions.showClose defaults to true. It can be removed at the risk of ADA compliance\n */\n adaExceptions?: ADAExceptions;\n arrowProps?: ComponentProps<\"div\">;\n variant?: \"primary\" | \"secondary\";\n}\n\nconst withBaseName = makePrefixer(\"saltOverlay\");\n\nexport const Overlay = forwardRef<HTMLDivElement, OverlayProps>(\n (\n {\n adaExceptions: { showClose } = {\n showClose: true,\n },\n arrowProps,\n children,\n className,\n open,\n onOpenChange,\n variant = \"primary\",\n ...rest\n },\n ref\n ) => {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-overlay\",\n css: overlayCSS,\n window: targetWindow,\n });\n\n // Will need to figure out a better way to assign popper id's for the electron windows\n const id = useId();\n const Window = usePortalWindow();\n\n const handleCloseButton = () => {\n onOpenChange?.(false);\n };\n\n if (!open) {\n return null;\n }\n\n return (\n <Portal>\n <Window\n className={clsx(withBaseName(), className, {\n [withBaseName(variant)]: variant === \"secondary\",\n })}\n id={id}\n ref={ref}\n {...rest}\n >\n <div\n className={clsx(withBaseName(\"content\"))}\n data-testid=\"overlay-content\"\n >\n {showClose && (\n <Button\n onClick={handleCloseButton}\n className={withBaseName(\"close\")}\n variant=\"secondary\"\n >\n <CloseIcon\n accessible-text=\"close overlay\"\n className={withBaseName(\"closeIcon\")}\n />\n </Button>\n )}\n {children}\n <div className={withBaseName(\"arrow\")} {...arrowProps} />\n </div>\n </Window>\n </Portal>\n );\n }\n);\n"],"names":["makePrefixer","forwardRef","useWindow","useComponentCssInjection","overlayCSS","useId","usePortalWindow","jsx","Portal","clsx","jsxs","Button","CloseIcon"],"mappings":";;;;;;;;;;;;;;;;AA6BA,MAAM,YAAA,GAAeA,kBAAa,aAAa,CAAA,CAAA;AAExC,MAAM,OAAU,GAAAC,gBAAA;AAAA,EACrB,CACE;AAAA,IACE,aAAA,EAAe,EAAE,SAAA,EAAc,GAAA;AAAA,MAC7B,SAAW,EAAA,IAAA;AAAA,KACb;AAAA,IACA,UAAA;AAAA,IACA,QAAA;AAAA,IACA,SAAA;AAAA,IACA,IAAA;AAAA,IACA,YAAA;AAAA,IACA,OAAU,GAAA,SAAA;AAAA,IACP,GAAA,IAAA;AAAA,KAEL,GACG,KAAA;AACH,IAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,cAAA;AAAA,MACR,GAAK,EAAAC,SAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAGD,IAAA,MAAM,KAAKC,UAAM,EAAA,CAAA;AACjB,IAAA,MAAM,SAASC,uBAAgB,EAAA,CAAA;AAE/B,IAAA,MAAM,oBAAoB,MAAM;AAC9B,MAAe,YAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,YAAA,CAAA,KAAA,CAAA,CAAA;AAAA,KACjB,CAAA;AAEA,IAAA,IAAI,CAAC,IAAM,EAAA;AACT,MAAO,OAAA,IAAA,CAAA;AAAA,KACT;AAEA,IAAA,uBACGC,cAAA,CAAAC,aAAA,EAAA;AAAA,MACC,QAAC,kBAAAD,cAAA,CAAA,MAAA,EAAA;AAAA,QACC,SAAW,EAAAE,SAAA,CAAK,YAAa,EAAA,EAAG,SAAW,EAAA;AAAA,UACzC,CAAC,YAAA,CAAa,OAAO,CAAA,GAAI,OAAY,KAAA,WAAA;AAAA,SACtC,CAAA;AAAA,QACD,EAAA;AAAA,QACA,GAAA;AAAA,QACC,GAAG,IAAA;AAAA,QAEJ,QAAC,kBAAAC,eAAA,CAAA,KAAA,EAAA;AAAA,UACC,SAAW,EAAAD,SAAA,CAAK,YAAa,CAAA,SAAS,CAAC,CAAA;AAAA,UACvC,aAAY,EAAA,iBAAA;AAAA,UAEX,QAAA,EAAA;AAAA,YAAA,SAAA,oBACEF,cAAA,CAAAI,WAAA,EAAA;AAAA,cACC,OAAS,EAAA,iBAAA;AAAA,cACT,SAAA,EAAW,aAAa,OAAO,CAAA;AAAA,cAC/B,OAAQ,EAAA,WAAA;AAAA,cAER,QAAC,kBAAAJ,cAAA,CAAAK,eAAA,EAAA;AAAA,gBACC,iBAAgB,EAAA,eAAA;AAAA,gBAChB,SAAA,EAAW,aAAa,WAAW,CAAA;AAAA,eACrC,CAAA;AAAA,aACF,CAAA;AAAA,YAED,QAAA;AAAA,4BACAL,cAAA,CAAA,KAAA,EAAA;AAAA,cAAI,SAAA,EAAW,aAAa,OAAO,CAAA;AAAA,cAAI,GAAG,UAAA;AAAA,aAAY,CAAA;AAAA,WAAA;AAAA,SACzD,CAAA;AAAA,OACF,CAAA;AAAA,KACF,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
1
+ {"version":3,"file":"Overlay.js","sources":["../src/overlay/Overlay.tsx"],"sourcesContent":["import {\n ComponentPropsWithoutRef,\n forwardRef,\n SyntheticEvent,\n useMemo,\n useRef,\n} from \"react\";\nimport { OverlayContext } from \"./OverlayContext\";\nimport { useControlled, useFloatingUI, useId } from \"@salt-ds/core\";\nimport {\n flip,\n offset,\n shift,\n limitShift,\n arrow,\n useClick,\n useDismiss,\n useInteractions,\n useRole,\n} from \"@floating-ui/react\";\n\nexport interface OverlayProps extends ComponentPropsWithoutRef<\"div\"> {\n open?: boolean;\n onOpenChange?: (event: SyntheticEvent, newOpen: boolean) => void;\n /*\n * Set the placement of the Overlay component relative to the trigger element. Defaults to `top`.\n */\n placement?: \"top\" | \"bottom\" | \"left\" | \"right\";\n /*\n * Use in controlled version to close Overlay.\n */\n onClose?: (event: SyntheticEvent) => void;\n}\n\nexport const Overlay = forwardRef<HTMLDivElement, OverlayProps>(\n function Overlay(props, ref) {\n const {\n children,\n open,\n onOpenChange,\n placement: placementProp = \"top\",\n id: idProp,\n onClose,\n ...rest\n } = props;\n\n const id = useId(idProp);\n const arrowRef = useRef<SVGSVGElement | null>(null);\n\n const [openState, setOpenState] = useControlled({\n controlled: open,\n default: false,\n name: \"Overlay\",\n state: \"open\",\n });\n\n const {\n x,\n y,\n strategy,\n context,\n elements,\n floating,\n reference,\n middlewareData: { arrow: { x: arrowX, y: arrowY } = {} },\n placement,\n } = useFloatingUI({\n open: openState,\n onOpenChange: setOpenState,\n placement: placementProp,\n middleware: [\n offset(11),\n flip(),\n shift({ limiter: limitShift() }),\n arrow({ element: arrowRef }),\n ],\n });\n\n const { getReferenceProps, getFloatingProps } = useInteractions([\n useRole(context, { role: \"dialog\" }),\n useClick(context),\n useDismiss(context),\n ]);\n\n const floatingStyles = useMemo(() => {\n return {\n top: y ?? 0,\n left: x ?? 0,\n position: strategy,\n width: elements.floating?.offsetWidth,\n height: elements.floating?.offsetHeight,\n };\n }, [elements.floating, strategy, x, y]);\n\n const setOpen = (event: SyntheticEvent, newOpen: boolean) => {\n setOpenState(newOpen);\n onOpenChange?.(event, newOpen);\n };\n\n const arrowProps = {\n ref: arrowRef,\n context,\n style: {\n position: strategy,\n left: arrowX ?? 0,\n top: arrowY ?? 0,\n },\n };\n\n const handleCloseButton = (event: SyntheticEvent) => {\n setOpen(event, false);\n onClose?.(event);\n };\n\n return (\n <OverlayContext.Provider\n value={{\n id: id ?? \"\",\n openState,\n setOpen,\n floatingStyles,\n placement,\n context,\n arrowProps,\n floating,\n reference,\n handleCloseButton,\n getFloatingProps,\n getReferenceProps,\n }}\n >\n <div ref={ref} {...rest}>\n {children}\n </div>\n </OverlayContext.Provider>\n );\n }\n);\n"],"names":["forwardRef","Overlay","useId","useRef","useControlled","useFloatingUI","offset","flip","shift","limitShift","arrow","useInteractions","useRole","useClick","useDismiss","useMemo","jsx","OverlayContext"],"mappings":"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"}
@@ -0,0 +1,43 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var core = require('@salt-ds/core');
6
+ var React = require('react');
7
+
8
+ const OverlayContext = core.createContext(
9
+ "OverlayContext",
10
+ {
11
+ id: "",
12
+ openState: false,
13
+ setOpen() {
14
+ return void 0;
15
+ },
16
+ floatingStyles: {
17
+ top: 0,
18
+ left: 0,
19
+ position: ""
20
+ },
21
+ placement: "",
22
+ context: {},
23
+ arrowProps: {},
24
+ handleCloseButton() {
25
+ return void 0;
26
+ },
27
+ reference: {},
28
+ floating: {},
29
+ getFloatingProps() {
30
+ return {};
31
+ },
32
+ getReferenceProps() {
33
+ return {};
34
+ }
35
+ }
36
+ );
37
+ function useOverlayContext() {
38
+ return React.useContext(OverlayContext);
39
+ }
40
+
41
+ exports.OverlayContext = OverlayContext;
42
+ exports.useOverlayContext = useOverlayContext;
43
+ //# sourceMappingURL=OverlayContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OverlayContext.js","sources":["../src/overlay/OverlayContext.ts"],"sourcesContent":["import {\n FloatingArrowProps,\n FloatingContext,\n Placement,\n ReferenceType,\n Strategy,\n} from \"@floating-ui/react\";\nimport { createContext, useFloatingUI } from \"@salt-ds/core\";\nimport { SyntheticEvent, useContext } from \"react\";\n\ntype FloatingReturn = ReturnType<typeof useFloatingUI>;\ntype FloatingStyleProps = {\n top: number;\n left: number;\n position: Strategy;\n width?: number;\n height?: number;\n};\n\nexport interface OverlayContextValue {\n id: string;\n openState: boolean;\n setOpen: (event: SyntheticEvent, newOpen: boolean) => void;\n floatingStyles: FloatingStyleProps;\n placement: Placement;\n arrowProps: FloatingArrowProps;\n context: FloatingContext;\n reference?: (node: ReferenceType | null) => void;\n floating?: (node: HTMLElement | null) => void;\n handleCloseButton: (event: SyntheticEvent) => void;\n getFloatingProps: (\n userProps?: React.HTMLProps<HTMLElement> | undefined\n ) => Record<string, unknown>;\n getReferenceProps: (\n userProps?: React.HTMLProps<Element> | undefined\n ) => Record<string, unknown>;\n}\n\nexport const OverlayContext = createContext<OverlayContextValue>(\n \"OverlayContext\",\n {\n id: \"\",\n openState: false,\n setOpen() {\n return undefined;\n },\n floatingStyles: {\n top: 0,\n left: 0,\n position: \"\" as Strategy,\n },\n placement: \"\" as Placement,\n context: {} as FloatingContext,\n arrowProps: {} as FloatingArrowProps,\n handleCloseButton() {\n return undefined;\n },\n reference: {} as FloatingReturn[\"reference\"],\n floating: {} as FloatingReturn[\"floating\"],\n getFloatingProps() {\n return {} as Record<string, unknown>;\n },\n getReferenceProps() {\n return {} as Record<string, unknown>;\n },\n }\n);\n\nexport function useOverlayContext() {\n return useContext(OverlayContext);\n}\n"],"names":["createContext","useContext"],"mappings":";;;;;;;AAsCO,MAAM,cAAiB,GAAAA,kBAAA;AAAA,EAC5B,gBAAA;AAAA,EACA;AAAA,IACE,EAAI,EAAA,EAAA;AAAA,IACJ,SAAW,EAAA,KAAA;AAAA,IACX,OAAU,GAAA;AACR,MAAO,OAAA,KAAA,CAAA,CAAA;AAAA,KACT;AAAA,IACA,cAAgB,EAAA;AAAA,MACd,GAAK,EAAA,CAAA;AAAA,MACL,IAAM,EAAA,CAAA;AAAA,MACN,QAAU,EAAA,EAAA;AAAA,KACZ;AAAA,IACA,SAAW,EAAA,EAAA;AAAA,IACX,SAAS,EAAC;AAAA,IACV,YAAY,EAAC;AAAA,IACb,iBAAoB,GAAA;AAClB,MAAO,OAAA,KAAA,CAAA,CAAA;AAAA,KACT;AAAA,IACA,WAAW,EAAC;AAAA,IACZ,UAAU,EAAC;AAAA,IACX,gBAAmB,GAAA;AACjB,MAAA,OAAO,EAAC,CAAA;AAAA,KACV;AAAA,IACA,iBAAoB,GAAA;AAClB,MAAA,OAAO,EAAC,CAAA;AAAA,KACV;AAAA,GACF;AACF,EAAA;AAEO,SAAS,iBAAoB,GAAA;AAClC,EAAA,OAAOC,iBAAW,cAAc,CAAA,CAAA;AAClC;;;;;"}
@@ -0,0 +1,64 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var React = require('react');
7
+ var core = require('@salt-ds/core');
8
+ var clsx = require('clsx');
9
+ var OverlayContext = require('./OverlayContext.js');
10
+ var react = require('@floating-ui/react');
11
+ var OverlayPanelBase = require('./OverlayPanelBase.js');
12
+
13
+ const withBaseName = core.makePrefixer("saltOverlayPanel");
14
+ const OverlayPanel = React.forwardRef(
15
+ function OverlayPanel2(props, ref) {
16
+ const { className, ...rest } = props;
17
+ const { Component: FloatingComponent } = core.useFloatingComponent();
18
+ const {
19
+ id,
20
+ openState,
21
+ floatingStyles,
22
+ placement,
23
+ context,
24
+ getFloatingProps,
25
+ floating
26
+ } = OverlayContext.useOverlayContext();
27
+ const handleRef = core.useForkRef(floating, ref);
28
+ const { top, left, width, height, position } = floatingStyles;
29
+ const getOverlayProps = () => {
30
+ return getFloatingProps({
31
+ "data-placement": placement,
32
+ ref: floating,
33
+ id: `${id}-panel`
34
+ });
35
+ };
36
+ if (!openState)
37
+ return /* @__PURE__ */ jsxRuntime.jsx(jsxRuntime.Fragment, {});
38
+ return /* @__PURE__ */ jsxRuntime.jsx(react.FloatingOverlay, {
39
+ children: /* @__PURE__ */ jsxRuntime.jsx(FloatingComponent, {
40
+ open: openState,
41
+ className: clsx.clsx(withBaseName(), className),
42
+ "aria-modal": "true",
43
+ "aria-labelledby": `${id}-header`,
44
+ "aria-describedby": `${id}-content`,
45
+ ...getOverlayProps(),
46
+ ref: handleRef,
47
+ width,
48
+ height,
49
+ top,
50
+ left,
51
+ position,
52
+ focusManagerProps: {
53
+ context
54
+ },
55
+ children: /* @__PURE__ */ jsxRuntime.jsx(OverlayPanelBase.OverlayPanelBase, {
56
+ ...rest
57
+ })
58
+ })
59
+ });
60
+ }
61
+ );
62
+
63
+ exports.OverlayPanel = OverlayPanel;
64
+ //# sourceMappingURL=OverlayPanel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OverlayPanel.js","sources":["../src/overlay/OverlayPanel.tsx"],"sourcesContent":["import {\n ComponentPropsWithoutRef,\n ForwardedRef,\n forwardRef,\n HTMLProps,\n} from \"react\";\nimport { makePrefixer, useFloatingComponent, useForkRef } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { useOverlayContext } from \"./OverlayContext\";\nimport { FloatingOverlay } from \"@floating-ui/react\";\nimport { OverlayPanelBase } from \"./OverlayPanelBase\";\n\nconst withBaseName = makePrefixer(\"saltOverlayPanel\");\n\nexport interface OverlayPanelProps extends ComponentPropsWithoutRef<\"div\"> {}\n\nexport const OverlayPanel = forwardRef<HTMLDivElement, OverlayPanelProps>(\n function OverlayPanel(props, ref: ForwardedRef<HTMLDivElement>) {\n const { className, ...rest } = props;\n\n const { Component: FloatingComponent } = useFloatingComponent();\n\n const {\n id,\n openState,\n floatingStyles,\n placement,\n context,\n getFloatingProps,\n floating,\n } = useOverlayContext();\n\n const handleRef = useForkRef<HTMLDivElement>(floating, ref);\n\n const { top, left, width, height, position } = floatingStyles;\n\n const getOverlayProps = (): HTMLProps<HTMLDivElement> => {\n return getFloatingProps({\n // @ts-ignore data-placement does not exist\n \"data-placement\": placement,\n ref: floating,\n id: `${id}-panel`,\n });\n };\n\n if (!openState) return <></>;\n\n return (\n <FloatingOverlay>\n <FloatingComponent\n open={openState}\n className={clsx(withBaseName(), className)}\n aria-modal=\"true\"\n aria-labelledby={`${id}-header`}\n aria-describedby={`${id}-content`}\n {...getOverlayProps()}\n ref={handleRef}\n width={width}\n height={height}\n top={top}\n left={left}\n position={position}\n focusManagerProps={{\n context: context,\n }}\n >\n <OverlayPanelBase {...rest} />\n </FloatingComponent>\n </FloatingOverlay>\n );\n }\n);\n"],"names":["makePrefixer","forwardRef","OverlayPanel","useFloatingComponent","useOverlayContext","useForkRef","jsx","Fragment","FloatingOverlay","clsx","OverlayPanelBase"],"mappings":";;;;;;;;;;;;AAYA,MAAM,YAAA,GAAeA,kBAAa,kBAAkB,CAAA,CAAA;AAI7C,MAAM,YAAe,GAAAC,gBAAA;AAAA,EAC1B,SAASC,aAAa,CAAA,KAAA,EAAO,GAAmC,EAAA;AAC9D,IAAM,MAAA,EAAE,SAAc,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AAE/B,IAAA,MAAM,EAAE,SAAA,EAAW,iBAAkB,EAAA,GAAIC,yBAAqB,EAAA,CAAA;AAE9D,IAAM,MAAA;AAAA,MACJ,EAAA;AAAA,MACA,SAAA;AAAA,MACA,cAAA;AAAA,MACA,SAAA;AAAA,MACA,OAAA;AAAA,MACA,gBAAA;AAAA,MACA,QAAA;AAAA,QACEC,gCAAkB,EAAA,CAAA;AAEtB,IAAM,MAAA,SAAA,GAAYC,eAA2B,CAAA,QAAA,EAAU,GAAG,CAAA,CAAA;AAE1D,IAAA,MAAM,EAAE,GAAK,EAAA,IAAA,EAAM,KAAO,EAAA,MAAA,EAAQ,UAAa,GAAA,cAAA,CAAA;AAE/C,IAAA,MAAM,kBAAkB,MAAiC;AACvD,MAAA,OAAO,gBAAiB,CAAA;AAAA,QAEtB,gBAAkB,EAAA,SAAA;AAAA,QAClB,GAAK,EAAA,QAAA;AAAA,QACL,IAAI,CAAG,EAAA,EAAA,CAAA,MAAA,CAAA;AAAA,OACR,CAAA,CAAA;AAAA,KACH,CAAA;AAEA,IAAA,IAAI,CAAC,SAAA;AAAW,MAAA,uBAASC,cAAA,CAAAC,mBAAA,EAAA,EAAA,CAAA,CAAA;AAEzB,IAAA,uBACGD,cAAA,CAAAE,qBAAA,EAAA;AAAA,MACC,QAAC,kBAAAF,cAAA,CAAA,iBAAA,EAAA;AAAA,QACC,IAAM,EAAA,SAAA;AAAA,QACN,SAAW,EAAAG,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,QACzC,YAAW,EAAA,MAAA;AAAA,QACX,mBAAiB,CAAG,EAAA,EAAA,CAAA,OAAA,CAAA;AAAA,QACpB,oBAAkB,CAAG,EAAA,EAAA,CAAA,QAAA,CAAA;AAAA,QACpB,GAAG,eAAgB,EAAA;AAAA,QACpB,GAAK,EAAA,SAAA;AAAA,QACL,KAAA;AAAA,QACA,MAAA;AAAA,QACA,GAAA;AAAA,QACA,IAAA;AAAA,QACA,QAAA;AAAA,QACA,iBAAmB,EAAA;AAAA,UACjB,OAAA;AAAA,SACF;AAAA,QAEA,QAAC,kBAAAH,cAAA,CAAAI,iCAAA,EAAA;AAAA,UAAkB,GAAG,IAAA;AAAA,SAAM,CAAA;AAAA,OAC9B,CAAA;AAAA,KACF,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
@@ -0,0 +1,65 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var react = require('@floating-ui/react');
7
+ var Overlay = require('./Overlay.css.js');
8
+ var window = require('@salt-ds/window');
9
+ var styles = require('@salt-ds/styles');
10
+ var core = require('@salt-ds/core');
11
+ var icons = require('@salt-ds/icons');
12
+ var OverlayContext = require('./OverlayContext.js');
13
+ var clsx = require('clsx');
14
+
15
+ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
16
+
17
+ var clsx__default = /*#__PURE__*/_interopDefaultLegacy(clsx);
18
+
19
+ const withBaseName = core.makePrefixer("saltOverlayPanelBase");
20
+ const OverlayPanelBase = (props) => {
21
+ const targetWindow = window.useWindow();
22
+ styles.useComponentCssInjection({
23
+ testId: "salt-overlay",
24
+ css: Overlay,
25
+ window: targetWindow
26
+ });
27
+ const { arrowProps, handleCloseButton } = OverlayContext.useOverlayContext();
28
+ const { children, className, ...rest } = props;
29
+ return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, {
30
+ children: [
31
+ /* @__PURE__ */ jsxRuntime.jsxs("div", {
32
+ className: clsx__default["default"](withBaseName("container"), className),
33
+ ...rest,
34
+ children: [
35
+ /* @__PURE__ */ jsxRuntime.jsx(core.Button, {
36
+ onClick: handleCloseButton,
37
+ variant: "secondary",
38
+ className: withBaseName("closeButton"),
39
+ "aria-label": "Close Overlay",
40
+ children: /* @__PURE__ */ jsxRuntime.jsx(icons.CloseIcon, {
41
+ "aria-hidden": true
42
+ })
43
+ }),
44
+ /* @__PURE__ */ jsxRuntime.jsx("div", {
45
+ className: withBaseName("content"),
46
+ children
47
+ })
48
+ ]
49
+ }),
50
+ /* @__PURE__ */ jsxRuntime.jsx(react.FloatingArrow, {
51
+ ...arrowProps,
52
+ strokeWidth: 1,
53
+ fill: "var(--overlay-background)",
54
+ stroke: "var(--overlay-borderColor)",
55
+ style: {
56
+ height: "calc(var(--salt-size-adornment) + 6px)",
57
+ width: "calc(var(--salt-size-adornment) + 8px)"
58
+ }
59
+ })
60
+ ]
61
+ });
62
+ };
63
+
64
+ exports.OverlayPanelBase = OverlayPanelBase;
65
+ //# sourceMappingURL=OverlayPanelBase.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OverlayPanelBase.js","sources":["../src/overlay/OverlayPanelBase.tsx"],"sourcesContent":["import { FloatingArrow } from \"@floating-ui/react\";\n\nimport overlayCss from \"./Overlay.css\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { Button, makePrefixer } from \"@salt-ds/core\";\nimport { CloseIcon } from \"@salt-ds/icons\";\nimport { ComponentPropsWithoutRef } from \"react\";\nimport { useOverlayContext } from \"./OverlayContext\";\nimport clsx from \"clsx\";\n\nconst withBaseName = makePrefixer(\"saltOverlayPanelBase\");\n\n// OverlayPanelBase component needed for CSS style injection\nexport const OverlayPanelBase = (props: ComponentPropsWithoutRef<\"div\">) => {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-overlay\",\n css: overlayCss,\n window: targetWindow,\n });\n\n const { arrowProps, handleCloseButton } = useOverlayContext();\n const { children, className, ...rest } = props;\n\n return (\n <>\n <div className={clsx(withBaseName(\"container\"), className)} {...rest}>\n <Button\n onClick={handleCloseButton}\n variant=\"secondary\"\n className={withBaseName(\"closeButton\")}\n aria-label=\"Close Overlay\"\n >\n <CloseIcon aria-hidden />\n </Button>\n <div className={withBaseName(\"content\")}>{children}</div>\n </div>\n\n <FloatingArrow\n {...arrowProps}\n strokeWidth={1}\n fill=\"var(--overlay-background)\"\n stroke=\"var(--overlay-borderColor)\"\n style={{\n height: \"calc(var(--salt-size-adornment) + 6px)\", // FIXME: +6px to account for Floating UI's FloatingArrow positioning calculation\n width: \"calc(var(--salt-size-adornment) + 8px)\", // FIXME: +8px to account for Floating UI's FloatingArrow positioning calculation\n }}\n />\n </>\n );\n};\n"],"names":["makePrefixer","useWindow","useComponentCssInjection","overlayCss","useOverlayContext","jsxs","Fragment","clsx","jsx","Button","CloseIcon","FloatingArrow"],"mappings":";;;;;;;;;;;;;;;;;;AAWA,MAAM,YAAA,GAAeA,kBAAa,sBAAsB,CAAA,CAAA;AAG3C,MAAA,gBAAA,GAAmB,CAAC,KAA2C,KAAA;AAC1E,EAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,cAAA;AAAA,IACR,GAAK,EAAAC,OAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,MAAM,EAAE,UAAA,EAAY,iBAAkB,EAAA,GAAIC,gCAAkB,EAAA,CAAA;AAC5D,EAAA,MAAM,EAAE,QAAA,EAAU,SAAc,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AAEzC,EACE,uBAAAC,eAAA,CAAAC,mBAAA,EAAA;AAAA,IACE,QAAA,EAAA;AAAA,sBAACD,eAAA,CAAA,KAAA,EAAA;AAAA,QAAI,SAAW,EAAAE,wBAAA,CAAK,YAAa,CAAA,WAAW,GAAG,SAAS,CAAA;AAAA,QAAI,GAAG,IAAA;AAAA,QAC9D,QAAA,EAAA;AAAA,0BAACC,cAAA,CAAAC,WAAA,EAAA;AAAA,YACC,OAAS,EAAA,iBAAA;AAAA,YACT,OAAQ,EAAA,WAAA;AAAA,YACR,SAAA,EAAW,aAAa,aAAa,CAAA;AAAA,YACrC,YAAW,EAAA,eAAA;AAAA,YAEX,QAAC,kBAAAD,cAAA,CAAAE,eAAA,EAAA;AAAA,cAAU,aAAW,EAAA,IAAA;AAAA,aAAC,CAAA;AAAA,WACzB,CAAA;AAAA,0BACCF,cAAA,CAAA,KAAA,EAAA;AAAA,YAAI,SAAA,EAAW,aAAa,SAAS,CAAA;AAAA,YAAI,QAAA;AAAA,WAAS,CAAA;AAAA,SAAA;AAAA,OACrD,CAAA;AAAA,sBAECA,cAAA,CAAAG,mBAAA,EAAA;AAAA,QACE,GAAG,UAAA;AAAA,QACJ,WAAa,EAAA,CAAA;AAAA,QACb,IAAK,EAAA,2BAAA;AAAA,QACL,MAAO,EAAA,4BAAA;AAAA,QACP,KAAO,EAAA;AAAA,UACL,MAAQ,EAAA,wCAAA;AAAA,UACR,KAAO,EAAA,wCAAA;AAAA,SACT;AAAA,OACF,CAAA;AAAA,KAAA;AAAA,GACF,CAAA,CAAA;AAEJ;;;;"}
@@ -0,0 +1,40 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var React = require('react');
7
+ var core = require('@salt-ds/core');
8
+ var OverlayContext = require('./OverlayContext.js');
9
+
10
+ function OverlayTrigger(props) {
11
+ const { children } = props;
12
+ const { setOpen, reference, getReferenceProps, id } = OverlayContext.useOverlayContext();
13
+ const triggerRef = core.useForkRef(
14
+ React.isValidElement(children) ? children.ref : null,
15
+ reference
16
+ );
17
+ if (!children || !React.isValidElement(children)) {
18
+ return /* @__PURE__ */ jsxRuntime.jsx(jsxRuntime.Fragment, {
19
+ children
20
+ });
21
+ }
22
+ const handleClick = (event) => {
23
+ setOpen(event, true);
24
+ };
25
+ const getTriggerProps = () => getReferenceProps({
26
+ ref: reference,
27
+ onClick: handleClick,
28
+ id: `${id}-trigger`,
29
+ "aria-controls": `${id}-panel`
30
+ });
31
+ return /* @__PURE__ */ jsxRuntime.jsx(jsxRuntime.Fragment, {
32
+ children: React.cloneElement(children, {
33
+ ...core.mergeProps(getTriggerProps(), children.props),
34
+ ref: triggerRef
35
+ })
36
+ });
37
+ }
38
+
39
+ exports.OverlayTrigger = OverlayTrigger;
40
+ //# sourceMappingURL=OverlayTrigger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OverlayTrigger.js","sources":["../src/overlay/OverlayTrigger.tsx"],"sourcesContent":["import { cloneElement, isValidElement, ReactNode, MouseEvent } from \"react\";\nimport { mergeProps, useForkRef } from \"@salt-ds/core\";\nimport { useOverlayContext } from \"./OverlayContext\";\n\nexport interface OverlayTriggerProps {\n children?: ReactNode;\n}\n\nexport function OverlayTrigger(props: OverlayTriggerProps) {\n const { children } = props;\n\n const { setOpen, reference, getReferenceProps, id } = useOverlayContext();\n\n const triggerRef = useForkRef(\n // @ts-ignore error TS2339 missing property ref\n isValidElement(children) ? children.ref : null,\n reference\n );\n\n if (!children || !isValidElement(children)) {\n return <>{children}</>;\n }\n const handleClick = (event: MouseEvent) => {\n setOpen(event, true);\n };\n\n const getTriggerProps = () =>\n getReferenceProps({\n ref: reference,\n onClick: handleClick,\n id: `${id}-trigger`,\n \"aria-controls\": `${id}-panel`,\n });\n\n return (\n <>\n {cloneElement(children, {\n ...mergeProps(getTriggerProps(), children.props),\n ref: triggerRef,\n })}\n </>\n );\n}\n"],"names":["useOverlayContext","useForkRef","isValidElement","jsx","Fragment","mergeProps"],"mappings":";;;;;;;;;AAQO,SAAS,eAAe,KAA4B,EAAA;AACzD,EAAM,MAAA,EAAE,UAAa,GAAA,KAAA,CAAA;AAErB,EAAA,MAAM,EAAE,OAAS,EAAA,SAAA,EAAW,iBAAmB,EAAA,EAAA,KAAOA,gCAAkB,EAAA,CAAA;AAExE,EAAA,MAAM,UAAa,GAAAC,eAAA;AAAA,IAEjBC,oBAAe,CAAA,QAAQ,CAAI,GAAA,QAAA,CAAS,GAAM,GAAA,IAAA;AAAA,IAC1C,SAAA;AAAA,GACF,CAAA;AAEA,EAAA,IAAI,CAAC,QAAA,IAAY,CAACA,oBAAA,CAAe,QAAQ,CAAG,EAAA;AAC1C,IAAO,uBAAAC,cAAA,CAAAC,mBAAA,EAAA;AAAA,MAAG,QAAA;AAAA,KAAS,CAAA,CAAA;AAAA,GACrB;AACA,EAAM,MAAA,WAAA,GAAc,CAAC,KAAsB,KAAA;AACzC,IAAA,OAAA,CAAQ,OAAO,IAAI,CAAA,CAAA;AAAA,GACrB,CAAA;AAEA,EAAM,MAAA,eAAA,GAAkB,MACtB,iBAAkB,CAAA;AAAA,IAChB,GAAK,EAAA,SAAA;AAAA,IACL,OAAS,EAAA,WAAA;AAAA,IACT,IAAI,CAAG,EAAA,EAAA,CAAA,QAAA,CAAA;AAAA,IACP,iBAAiB,CAAG,EAAA,EAAA,CAAA,MAAA,CAAA;AAAA,GACrB,CAAA,CAAA;AAEH,EACE,uBAAAD,cAAA,CAAAC,mBAAA,EAAA;AAAA,IACG,6BAAa,QAAU,EAAA;AAAA,MACtB,GAAGC,eAAA,CAAW,eAAgB,EAAA,EAAG,SAAS,KAAK,CAAA;AAAA,MAC/C,GAAK,EAAA,UAAA;AAAA,KACN,CAAA;AAAA,GACH,CAAA,CAAA;AAEJ;;;;"}
@@ -1,4 +1,4 @@
1
- var css_248z = ".saltColorChooser-overlayButtonSwatch {\n margin-right: 10px;\n height: calc(2 * var(--salt-size-unit));\n width: calc(2 * var(--salt-size-unit));\n}\n\n.saltColorChooser-overlayButtonSwatchWithBorder {\n border: 0.2px solid var(--salt-editable-borderColor);\n}\n\n.saltColorChooser-overlayButtonSwatchTransparent {\n height: calc(var(--salt-size-container-spacing) - 2px) !important;\n width: calc(var(--salt-size-container-spacing) - 2px) !important;\n border: 1px solid var(--salt-status-negative-foreground);\n /* RGBA using red-700 */\n background: linear-gradient(\n to top left,\n rgba(166, 21, 11, 0) 0%,\n rgba(166, 21, 11, 0) calc(50% - 0.8px),\n rgba(166, 21, 11, 1) 50%,\n rgba(166, 21, 11, 0) calc(50% + 0.8px),\n rgba(166, 21, 11, 0) 100%\n );\n}\n\n.saltColorChooser-overlayButtonText {\n font-weight: var(--salt-text-fontWeight);\n font-family: var(--saltButton-fontFamily, var(--salt-text-fontFamily));\n font-size: var(--salt-text-fontSize);\n letter-spacing: normal;\n}\n\n.saltColorChooser-overlayButton {\n background: transparent;\n text-transform: none;\n justify-content: flex-start;\n}\n\n.saltColorChooser-overlayButtonHiddenLabel {\n width: var(--salt-size-container-spacing);\n display: contents;\n}\n\n.saltColorChooser-overlayButtonClose {\n margin: 5px;\n}\n\n.saltColorChooser-defaultButton {\n float: right;\n background: transparent;\n padding: 6px 2px 6px 2px;\n height: var(--salt-size-stackable);\n}\n\n.saltColorChooser-defaultButton {\n border-bottom: var(--salt-size-border) var(--salt-editable-borderStyle) var(--salt-editable-borderColor);\n}\n\n.saltColorChooser-overlayContent {\n max-width: 100%;\n}\n\n.saltColorChooser-refreshIcon {\n padding-right: 5px;\n}\n";
1
+ var css_248z = ".saltColorChooser-overlayButtonSwatch {\n margin-right: 10px;\n height: calc(2 * var(--salt-size-unit));\n width: calc(2 * var(--salt-size-unit));\n}\n\n.saltColorChooser-overlayButtonSwatchWithBorder {\n border: 0.2px solid var(--salt-editable-borderColor);\n}\n\n.saltColorChooser-overlayButtonSwatchTransparent {\n height: calc(var(--salt-size-container-spacing) - 2px) !important;\n width: calc(var(--salt-size-container-spacing) - 2px) !important;\n border: 1px solid var(--salt-status-negative-foreground);\n /* RGBA using red-700 */\n background: linear-gradient(\n to top left,\n rgba(166, 21, 11, 0) 0%,\n rgba(166, 21, 11, 0) calc(50% - 0.8px),\n rgba(166, 21, 11, 1) 50%,\n rgba(166, 21, 11, 0) calc(50% + 0.8px),\n rgba(166, 21, 11, 0) 100%\n );\n}\n\n.saltColorChooser-overlayButtonText {\n font-weight: var(--salt-text-fontWeight);\n font-family: var(--saltButton-fontFamily, var(--salt-text-fontFamily));\n font-size: var(--salt-text-fontSize);\n letter-spacing: normal;\n}\n\n.saltColorChooser-overlayButton {\n background: transparent;\n text-transform: none;\n justify-content: flex-start;\n}\n\n.saltColorChooser-overlayButtonHiddenLabel {\n width: var(--salt-size-container-spacing);\n display: contents;\n}\n\n.saltColorChooser-defaultButton {\n float: right;\n background: transparent;\n padding: 6px 2px 6px 2px;\n height: var(--salt-size-stackable);\n}\n\n.saltColorChooser-defaultButton {\n border-bottom: var(--salt-size-border) var(--salt-editable-borderStyle) var(--salt-editable-borderColor);\n}\n\n.saltColorChooser-overlayContent {\n max-width: 100%;\n}\n\n.saltColorChooser-refreshIcon {\n padding-right: 5px;\n}\n";
2
2
 
3
3
  export { css_248z as default };
4
4
  //# sourceMappingURL=ColorChooser.css.js.map