@salt-ds/core 1.60.0 → 1.62.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 (268) hide show
  1. package/CHANGELOG.md +61 -0
  2. package/css/salt-core.css +492 -1
  3. package/dist-cjs/index.js +32 -0
  4. package/dist-cjs/index.js.map +1 -1
  5. package/dist-cjs/navigation-item/NavigationItem.js +2 -0
  6. package/dist-cjs/navigation-item/NavigationItem.js.map +1 -1
  7. package/dist-cjs/rating/Rating.css.js +6 -0
  8. package/dist-cjs/rating/Rating.css.js.map +1 -0
  9. package/dist-cjs/rating/Rating.js +140 -0
  10. package/dist-cjs/rating/Rating.js.map +1 -0
  11. package/dist-cjs/rating/RatingItem.css.js +6 -0
  12. package/dist-cjs/rating/RatingItem.css.js.map +1 -0
  13. package/dist-cjs/rating/RatingItem.js +75 -0
  14. package/dist-cjs/rating/RatingItem.js.map +1 -0
  15. package/dist-cjs/semantic-icon-provider/SemanticIconProvider.js +22 -20
  16. package/dist-cjs/semantic-icon-provider/SemanticIconProvider.js.map +1 -1
  17. package/dist-cjs/side-panel/SidePanel.css.js +6 -0
  18. package/dist-cjs/side-panel/SidePanel.css.js.map +1 -0
  19. package/dist-cjs/side-panel/SidePanel.js +205 -0
  20. package/dist-cjs/side-panel/SidePanel.js.map +1 -0
  21. package/dist-cjs/side-panel/SidePanelCloseButton.js +44 -0
  22. package/dist-cjs/side-panel/SidePanelCloseButton.js.map +1 -0
  23. package/dist-cjs/side-panel/SidePanelContent.css.js +6 -0
  24. package/dist-cjs/side-panel/SidePanelContent.css.js.map +1 -0
  25. package/dist-cjs/side-panel/SidePanelContent.js +70 -0
  26. package/dist-cjs/side-panel/SidePanelContent.js.map +1 -0
  27. package/dist-cjs/side-panel/SidePanelHeader.css.js +6 -0
  28. package/dist-cjs/side-panel/SidePanelHeader.css.js.map +1 -0
  29. package/dist-cjs/side-panel/SidePanelHeader.js +30 -0
  30. package/dist-cjs/side-panel/SidePanelHeader.js.map +1 -0
  31. package/dist-cjs/side-panel/SidePanelProvider.js +83 -0
  32. package/dist-cjs/side-panel/SidePanelProvider.js.map +1 -0
  33. package/dist-cjs/side-panel/SidePanelTitle.css.js +6 -0
  34. package/dist-cjs/side-panel/SidePanelTitle.css.js.map +1 -0
  35. package/dist-cjs/side-panel/SidePanelTitle.js +60 -0
  36. package/dist-cjs/side-panel/SidePanelTitle.js.map +1 -0
  37. package/dist-cjs/side-panel/SidePanelTrigger.js +43 -0
  38. package/dist-cjs/side-panel/SidePanelTrigger.js.map +1 -0
  39. package/dist-cjs/side-panel/internal/SidePanelContext.js +38 -0
  40. package/dist-cjs/side-panel/internal/SidePanelContext.js.map +1 -0
  41. package/dist-cjs/side-panel/internal/useIsScrollable.js +50 -0
  42. package/dist-cjs/side-panel/internal/useIsScrollable.js.map +1 -0
  43. package/dist-cjs/side-panel/internal/useSidePanelTabOrder.js +214 -0
  44. package/dist-cjs/side-panel/internal/useSidePanelTabOrder.js.map +1 -0
  45. package/dist-cjs/side-panel/useSidePanel.js +49 -0
  46. package/dist-cjs/side-panel/useSidePanel.js.map +1 -0
  47. package/dist-cjs/tabs/Tab.css.js +6 -0
  48. package/dist-cjs/tabs/Tab.css.js.map +1 -0
  49. package/dist-cjs/tabs/Tab.js +211 -0
  50. package/dist-cjs/tabs/Tab.js.map +1 -0
  51. package/dist-cjs/tabs/TabAction.js +63 -0
  52. package/dist-cjs/tabs/TabAction.js.map +1 -0
  53. package/dist-cjs/tabs/TabBar.css.js +6 -0
  54. package/dist-cjs/tabs/TabBar.css.js.map +1 -0
  55. package/dist-cjs/tabs/TabBar.js +45 -0
  56. package/dist-cjs/tabs/TabBar.js.map +1 -0
  57. package/dist-cjs/tabs/TabList.css.js +6 -0
  58. package/dist-cjs/tabs/TabList.css.js.map +1 -0
  59. package/dist-cjs/tabs/TabList.js +281 -0
  60. package/dist-cjs/tabs/TabList.js.map +1 -0
  61. package/dist-cjs/tabs/TabPanel.css.js +6 -0
  62. package/dist-cjs/tabs/TabPanel.css.js.map +1 -0
  63. package/dist-cjs/tabs/TabPanel.js +98 -0
  64. package/dist-cjs/tabs/TabPanel.js.map +1 -0
  65. package/dist-cjs/tabs/TabTrigger.css.js +6 -0
  66. package/dist-cjs/tabs/TabTrigger.css.js.map +1 -0
  67. package/dist-cjs/tabs/TabTrigger.js +188 -0
  68. package/dist-cjs/tabs/TabTrigger.js.map +1 -0
  69. package/dist-cjs/tabs/Tabs.css.js +6 -0
  70. package/dist-cjs/tabs/Tabs.css.js.map +1 -0
  71. package/dist-cjs/tabs/Tabs.js +200 -0
  72. package/dist-cjs/tabs/Tabs.js.map +1 -0
  73. package/dist-cjs/tabs/internal/contexts/TabContext.js +26 -0
  74. package/dist-cjs/tabs/internal/contexts/TabContext.js.map +1 -0
  75. package/dist-cjs/tabs/internal/contexts/TabListLayoutContext.js +19 -0
  76. package/dist-cjs/tabs/internal/contexts/TabListLayoutContext.js.map +1 -0
  77. package/dist-cjs/tabs/internal/contexts/TabSlotRegistryContext.js +22 -0
  78. package/dist-cjs/tabs/internal/contexts/TabSlotRegistryContext.js.map +1 -0
  79. package/dist-cjs/tabs/internal/contexts/TabsContext.js +50 -0
  80. package/dist-cjs/tabs/internal/contexts/TabsContext.js.map +1 -0
  81. package/dist-cjs/tabs/internal/hooks/useFocusWithRetry.js +64 -0
  82. package/dist-cjs/tabs/internal/hooks/useFocusWithRetry.js.map +1 -0
  83. package/dist-cjs/tabs/internal/hooks/useTabListRecovery.js +76 -0
  84. package/dist-cjs/tabs/internal/hooks/useTabListRecovery.js.map +1 -0
  85. package/dist-cjs/tabs/internal/hooks/useTabRemovalHandler.js +165 -0
  86. package/dist-cjs/tabs/internal/hooks/useTabRemovalHandler.js.map +1 -0
  87. package/dist-cjs/tabs/internal/hooks/useTabSelectionFocus.js +87 -0
  88. package/dist-cjs/tabs/internal/hooks/useTabSelectionFocus.js.map +1 -0
  89. package/dist-cjs/tabs/internal/overflow/TabOverflowList.css.js +6 -0
  90. package/dist-cjs/tabs/internal/overflow/TabOverflowList.css.js.map +1 -0
  91. package/dist-cjs/tabs/internal/overflow/TabOverflowList.js +245 -0
  92. package/dist-cjs/tabs/internal/overflow/TabOverflowList.js.map +1 -0
  93. package/dist-cjs/tabs/internal/overflow/TabSlot.js +30 -0
  94. package/dist-cjs/tabs/internal/overflow/TabSlot.js.map +1 -0
  95. package/dist-cjs/tabs/internal/overflow/overflowMath.js +86 -0
  96. package/dist-cjs/tabs/internal/overflow/overflowMath.js.map +1 -0
  97. package/dist-cjs/tabs/internal/overflow/useOverflow.js +273 -0
  98. package/dist-cjs/tabs/internal/overflow/useOverflow.js.map +1 -0
  99. package/dist-cjs/tabs/internal/overflow/useOverflowLayoutState.js +99 -0
  100. package/dist-cjs/tabs/internal/overflow/useOverflowLayoutState.js.map +1 -0
  101. package/dist-cjs/tabs/internal/overflow/useOverflowSelectionState.js +68 -0
  102. package/dist-cjs/tabs/internal/overflow/useOverflowSelectionState.js.map +1 -0
  103. package/dist-cjs/tabs/internal/overflow/useRenderedTabWidth.js +92 -0
  104. package/dist-cjs/tabs/internal/overflow/useRenderedTabWidth.js.map +1 -0
  105. package/dist-cjs/tabs/internal/overflow/widthMeasurement.js +42 -0
  106. package/dist-cjs/tabs/internal/overflow/widthMeasurement.js.map +1 -0
  107. package/dist-cjs/tabs/internal/registry/useCollection.js +197 -0
  108. package/dist-cjs/tabs/internal/registry/useCollection.js.map +1 -0
  109. package/dist-cjs/tabs/internal/registry/useRenderedTabsRegistry.js +206 -0
  110. package/dist-cjs/tabs/internal/registry/useRenderedTabsRegistry.js.map +1 -0
  111. package/dist-cjs/tabs/internal/utils/domUtils.js +13 -0
  112. package/dist-cjs/tabs/internal/utils/domUtils.js.map +1 -0
  113. package/dist-es/index.js +16 -0
  114. package/dist-es/index.js.map +1 -1
  115. package/dist-es/navigation-item/NavigationItem.js +2 -0
  116. package/dist-es/navigation-item/NavigationItem.js.map +1 -1
  117. package/dist-es/rating/Rating.css.js +4 -0
  118. package/dist-es/rating/Rating.css.js.map +1 -0
  119. package/dist-es/rating/Rating.js +138 -0
  120. package/dist-es/rating/Rating.js.map +1 -0
  121. package/dist-es/rating/RatingItem.css.js +4 -0
  122. package/dist-es/rating/RatingItem.css.js.map +1 -0
  123. package/dist-es/rating/RatingItem.js +73 -0
  124. package/dist-es/rating/RatingItem.js.map +1 -0
  125. package/dist-es/semantic-icon-provider/SemanticIconProvider.js +23 -21
  126. package/dist-es/semantic-icon-provider/SemanticIconProvider.js.map +1 -1
  127. package/dist-es/side-panel/SidePanel.css.js +4 -0
  128. package/dist-es/side-panel/SidePanel.css.js.map +1 -0
  129. package/dist-es/side-panel/SidePanel.js +203 -0
  130. package/dist-es/side-panel/SidePanel.js.map +1 -0
  131. package/dist-es/side-panel/SidePanelCloseButton.js +42 -0
  132. package/dist-es/side-panel/SidePanelCloseButton.js.map +1 -0
  133. package/dist-es/side-panel/SidePanelContent.css.js +4 -0
  134. package/dist-es/side-panel/SidePanelContent.css.js.map +1 -0
  135. package/dist-es/side-panel/SidePanelContent.js +68 -0
  136. package/dist-es/side-panel/SidePanelContent.js.map +1 -0
  137. package/dist-es/side-panel/SidePanelHeader.css.js +4 -0
  138. package/dist-es/side-panel/SidePanelHeader.css.js.map +1 -0
  139. package/dist-es/side-panel/SidePanelHeader.js +28 -0
  140. package/dist-es/side-panel/SidePanelHeader.js.map +1 -0
  141. package/dist-es/side-panel/SidePanelProvider.js +81 -0
  142. package/dist-es/side-panel/SidePanelProvider.js.map +1 -0
  143. package/dist-es/side-panel/SidePanelTitle.css.js +4 -0
  144. package/dist-es/side-panel/SidePanelTitle.css.js.map +1 -0
  145. package/dist-es/side-panel/SidePanelTitle.js +58 -0
  146. package/dist-es/side-panel/SidePanelTitle.js.map +1 -0
  147. package/dist-es/side-panel/SidePanelTrigger.js +41 -0
  148. package/dist-es/side-panel/SidePanelTrigger.js.map +1 -0
  149. package/dist-es/side-panel/internal/SidePanelContext.js +35 -0
  150. package/dist-es/side-panel/internal/SidePanelContext.js.map +1 -0
  151. package/dist-es/side-panel/internal/useIsScrollable.js +48 -0
  152. package/dist-es/side-panel/internal/useIsScrollable.js.map +1 -0
  153. package/dist-es/side-panel/internal/useSidePanelTabOrder.js +212 -0
  154. package/dist-es/side-panel/internal/useSidePanelTabOrder.js.map +1 -0
  155. package/dist-es/side-panel/useSidePanel.js +47 -0
  156. package/dist-es/side-panel/useSidePanel.js.map +1 -0
  157. package/dist-es/tabs/Tab.css.js +4 -0
  158. package/dist-es/tabs/Tab.css.js.map +1 -0
  159. package/dist-es/tabs/Tab.js +209 -0
  160. package/dist-es/tabs/Tab.js.map +1 -0
  161. package/dist-es/tabs/TabAction.js +61 -0
  162. package/dist-es/tabs/TabAction.js.map +1 -0
  163. package/dist-es/tabs/TabBar.css.js +4 -0
  164. package/dist-es/tabs/TabBar.css.js.map +1 -0
  165. package/dist-es/tabs/TabBar.js +43 -0
  166. package/dist-es/tabs/TabBar.js.map +1 -0
  167. package/dist-es/tabs/TabList.css.js +4 -0
  168. package/dist-es/tabs/TabList.css.js.map +1 -0
  169. package/dist-es/tabs/TabList.js +279 -0
  170. package/dist-es/tabs/TabList.js.map +1 -0
  171. package/dist-es/tabs/TabPanel.css.js +4 -0
  172. package/dist-es/tabs/TabPanel.css.js.map +1 -0
  173. package/dist-es/tabs/TabPanel.js +96 -0
  174. package/dist-es/tabs/TabPanel.js.map +1 -0
  175. package/dist-es/tabs/TabTrigger.css.js +4 -0
  176. package/dist-es/tabs/TabTrigger.css.js.map +1 -0
  177. package/dist-es/tabs/TabTrigger.js +186 -0
  178. package/dist-es/tabs/TabTrigger.js.map +1 -0
  179. package/dist-es/tabs/Tabs.css.js +4 -0
  180. package/dist-es/tabs/Tabs.css.js.map +1 -0
  181. package/dist-es/tabs/Tabs.js +198 -0
  182. package/dist-es/tabs/Tabs.js.map +1 -0
  183. package/dist-es/tabs/internal/contexts/TabContext.js +23 -0
  184. package/dist-es/tabs/internal/contexts/TabContext.js.map +1 -0
  185. package/dist-es/tabs/internal/contexts/TabListLayoutContext.js +16 -0
  186. package/dist-es/tabs/internal/contexts/TabListLayoutContext.js.map +1 -0
  187. package/dist-es/tabs/internal/contexts/TabSlotRegistryContext.js +19 -0
  188. package/dist-es/tabs/internal/contexts/TabSlotRegistryContext.js.map +1 -0
  189. package/dist-es/tabs/internal/contexts/TabsContext.js +47 -0
  190. package/dist-es/tabs/internal/contexts/TabsContext.js.map +1 -0
  191. package/dist-es/tabs/internal/hooks/useFocusWithRetry.js +62 -0
  192. package/dist-es/tabs/internal/hooks/useFocusWithRetry.js.map +1 -0
  193. package/dist-es/tabs/internal/hooks/useTabListRecovery.js +74 -0
  194. package/dist-es/tabs/internal/hooks/useTabListRecovery.js.map +1 -0
  195. package/dist-es/tabs/internal/hooks/useTabRemovalHandler.js +163 -0
  196. package/dist-es/tabs/internal/hooks/useTabRemovalHandler.js.map +1 -0
  197. package/dist-es/tabs/internal/hooks/useTabSelectionFocus.js +85 -0
  198. package/dist-es/tabs/internal/hooks/useTabSelectionFocus.js.map +1 -0
  199. package/dist-es/tabs/internal/overflow/TabOverflowList.css.js +4 -0
  200. package/dist-es/tabs/internal/overflow/TabOverflowList.css.js.map +1 -0
  201. package/dist-es/tabs/internal/overflow/TabOverflowList.js +243 -0
  202. package/dist-es/tabs/internal/overflow/TabOverflowList.js.map +1 -0
  203. package/dist-es/tabs/internal/overflow/TabSlot.js +28 -0
  204. package/dist-es/tabs/internal/overflow/TabSlot.js.map +1 -0
  205. package/dist-es/tabs/internal/overflow/overflowMath.js +82 -0
  206. package/dist-es/tabs/internal/overflow/overflowMath.js.map +1 -0
  207. package/dist-es/tabs/internal/overflow/useOverflow.js +271 -0
  208. package/dist-es/tabs/internal/overflow/useOverflow.js.map +1 -0
  209. package/dist-es/tabs/internal/overflow/useOverflowLayoutState.js +97 -0
  210. package/dist-es/tabs/internal/overflow/useOverflowLayoutState.js.map +1 -0
  211. package/dist-es/tabs/internal/overflow/useOverflowSelectionState.js +66 -0
  212. package/dist-es/tabs/internal/overflow/useOverflowSelectionState.js.map +1 -0
  213. package/dist-es/tabs/internal/overflow/useRenderedTabWidth.js +90 -0
  214. package/dist-es/tabs/internal/overflow/useRenderedTabWidth.js.map +1 -0
  215. package/dist-es/tabs/internal/overflow/widthMeasurement.js +36 -0
  216. package/dist-es/tabs/internal/overflow/widthMeasurement.js.map +1 -0
  217. package/dist-es/tabs/internal/registry/useCollection.js +195 -0
  218. package/dist-es/tabs/internal/registry/useCollection.js.map +1 -0
  219. package/dist-es/tabs/internal/registry/useRenderedTabsRegistry.js +204 -0
  220. package/dist-es/tabs/internal/registry/useRenderedTabsRegistry.js.map +1 -0
  221. package/dist-es/tabs/internal/utils/domUtils.js +11 -0
  222. package/dist-es/tabs/internal/utils/domUtils.js.map +1 -0
  223. package/dist-types/index.d.ts +3 -0
  224. package/dist-types/rating/Rating.d.ts +48 -0
  225. package/dist-types/rating/RatingItem.d.ts +47 -0
  226. package/dist-types/rating/index.d.ts +1 -0
  227. package/dist-types/semantic-icon-provider/SemanticIconProvider.d.ts +21 -19
  228. package/dist-types/side-panel/SidePanel.d.ts +26 -0
  229. package/dist-types/side-panel/SidePanelCloseButton.d.ts +2 -0
  230. package/dist-types/side-panel/SidePanelContent.d.ts +5 -0
  231. package/dist-types/side-panel/SidePanelHeader.d.ts +5 -0
  232. package/dist-types/side-panel/SidePanelProvider.d.ts +20 -0
  233. package/dist-types/side-panel/SidePanelTitle.d.ts +3 -0
  234. package/dist-types/side-panel/SidePanelTrigger.d.ts +3 -0
  235. package/dist-types/side-panel/index.d.ts +8 -0
  236. package/dist-types/side-panel/internal/SidePanelContext.d.ts +52 -0
  237. package/dist-types/side-panel/internal/index.d.ts +3 -0
  238. package/dist-types/side-panel/internal/useIsScrollable.d.ts +2 -0
  239. package/dist-types/side-panel/internal/useSidePanelTabOrder.d.ts +7 -0
  240. package/dist-types/side-panel/useSidePanel.d.ts +58 -0
  241. package/dist-types/tabs/Tab.d.ts +12 -0
  242. package/dist-types/tabs/TabAction.d.ts +4 -0
  243. package/dist-types/tabs/TabBar.d.ts +12 -0
  244. package/dist-types/tabs/TabList.d.ts +12 -0
  245. package/dist-types/tabs/TabPanel.d.ts +9 -0
  246. package/dist-types/tabs/TabTrigger.d.ts +4 -0
  247. package/dist-types/tabs/Tabs.d.ts +20 -0
  248. package/dist-types/tabs/index.d.ts +7 -0
  249. package/dist-types/tabs/internal/contexts/TabContext.d.ts +12 -0
  250. package/dist-types/tabs/internal/contexts/TabListLayoutContext.d.ts +9 -0
  251. package/dist-types/tabs/internal/contexts/TabSlotRegistryContext.d.ts +5 -0
  252. package/dist-types/tabs/internal/contexts/TabsContext.d.ts +43 -0
  253. package/dist-types/tabs/internal/hooks/useFocusWithRetry.d.ts +9 -0
  254. package/dist-types/tabs/internal/hooks/useTabListRecovery.d.ts +12 -0
  255. package/dist-types/tabs/internal/hooks/useTabRemovalHandler.d.ts +32 -0
  256. package/dist-types/tabs/internal/hooks/useTabSelectionFocus.d.ts +15 -0
  257. package/dist-types/tabs/internal/overflow/TabOverflowList.d.ts +10 -0
  258. package/dist-types/tabs/internal/overflow/TabSlot.d.ts +6 -0
  259. package/dist-types/tabs/internal/overflow/overflowMath.d.ts +18 -0
  260. package/dist-types/tabs/internal/overflow/useOverflow.d.ts +11 -0
  261. package/dist-types/tabs/internal/overflow/useOverflowLayoutState.d.ts +13 -0
  262. package/dist-types/tabs/internal/overflow/useOverflowSelectionState.d.ts +13 -0
  263. package/dist-types/tabs/internal/overflow/useRenderedTabWidth.d.ts +12 -0
  264. package/dist-types/tabs/internal/overflow/widthMeasurement.d.ts +5 -0
  265. package/dist-types/tabs/internal/registry/useCollection.d.ts +30 -0
  266. package/dist-types/tabs/internal/registry/useRenderedTabsRegistry.d.ts +12 -0
  267. package/dist-types/tabs/internal/utils/domUtils.d.ts +1 -0
  268. package/package.json +3 -1
@@ -0,0 +1,43 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { useComponentCssInjection } from '@salt-ds/styles';
3
+ import { useWindow } from '@salt-ds/window';
4
+ import { clsx } from 'clsx';
5
+ import { forwardRef } from 'react';
6
+ import { makePrefixer } from '../utils/makePrefixer.js';
7
+ import '../utils/useFloatingUI/useFloatingUI.js';
8
+ import '../utils/useId.js';
9
+ import '../salt-provider/SaltProvider.js';
10
+ import '../viewport/ViewportProvider.js';
11
+ import css_248z from './TabBar.css.js';
12
+
13
+ const withBaseName = makePrefixer("saltTabBar");
14
+ const TabBar = forwardRef(
15
+ function TabBar2(props, ref) {
16
+ const { className, children, divider, inset, ...rest } = props;
17
+ const targetWindow = useWindow();
18
+ useComponentCssInjection({
19
+ testId: "salt-tab-bar",
20
+ css: css_248z,
21
+ window: targetWindow
22
+ });
23
+ return /* @__PURE__ */ jsx(
24
+ "div",
25
+ {
26
+ className: clsx(
27
+ withBaseName(),
28
+ {
29
+ [withBaseName("divider")]: divider,
30
+ [withBaseName("inset")]: inset
31
+ },
32
+ className
33
+ ),
34
+ ...rest,
35
+ ref,
36
+ children: /* @__PURE__ */ jsx("div", { className: withBaseName("strip"), children })
37
+ }
38
+ );
39
+ }
40
+ );
41
+
42
+ export { TabBar };
43
+ //# sourceMappingURL=TabBar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TabBar.js","sources":["../src/tabs/TabBar.tsx"],"sourcesContent":["import { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport { type ComponentPropsWithRef, forwardRef } from \"react\";\nimport { makePrefixer } from \"../utils\";\nimport tabBarCss from \"./TabBar.css\";\n\nexport interface TabBarProps extends ComponentPropsWithRef<\"div\"> {\n /**\n * Styling variant with a bottom separator. Defaults to false\n */\n divider?: boolean;\n /**\n * Styling variant with left and right padding. Defaults to false\n */\n inset?: boolean;\n}\n\nconst withBaseName = makePrefixer(\"saltTabBar\");\n\nexport const TabBar = forwardRef<HTMLDivElement, TabBarProps>(\n function TabBar(props, ref) {\n const { className, children, divider, inset, ...rest } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-tab-bar\",\n css: tabBarCss,\n window: targetWindow,\n });\n\n return (\n <div\n className={clsx(\n withBaseName(),\n {\n [withBaseName(\"divider\")]: divider,\n [withBaseName(\"inset\")]: inset,\n },\n className,\n )}\n {...rest}\n ref={ref}\n >\n <div className={withBaseName(\"strip\")}>{children}</div>\n </div>\n );\n },\n);\n"],"names":["TabBar","tabBarCss"],"mappings":";;;;;;;;;;;;AAkBA,MAAM,YAAA,GAAe,aAAa,YAAY,CAAA;AAEvC,MAAM,MAAA,GAAS,UAAA;AAAA,EACpB,SAASA,OAAAA,CAAO,KAAA,EAAO,GAAA,EAAK;AAC1B,IAAA,MAAM,EAAE,SAAA,EAAW,QAAA,EAAU,SAAS,KAAA,EAAO,GAAG,MAAK,GAAI,KAAA;AAEzD,IAAA,MAAM,eAAe,SAAA,EAAU;AAC/B,IAAA,wBAAA,CAAyB;AAAA,MACvB,MAAA,EAAQ,cAAA;AAAA,MACR,GAAA,EAAKC,QAAA;AAAA,MACL,MAAA,EAAQ;AAAA,KACT,CAAA;AAED,IAAA,uBACE,GAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACC,SAAA,EAAW,IAAA;AAAA,UACT,YAAA,EAAa;AAAA,UACb;AAAA,YACE,CAAC,YAAA,CAAa,SAAS,CAAC,GAAG,OAAA;AAAA,YAC3B,CAAC,YAAA,CAAa,OAAO,CAAC,GAAG;AAAA,WAC3B;AAAA,UACA;AAAA,SACF;AAAA,QACC,GAAG,IAAA;AAAA,QACJ,GAAA;AAAA,QAEA,8BAAC,KAAA,EAAA,EAAI,SAAA,EAAW,YAAA,CAAa,OAAO,GAAI,QAAA,EAAS;AAAA;AAAA,KACnD;AAAA,EAEJ;AACF;;;;"}
@@ -0,0 +1,4 @@
1
+ var css_248z = "/* Component class applied to the root element */\n.saltTabList {\n display: flex;\n flex-wrap: nowrap;\n justify-content: flex-start;\n align-items: center;\n position: relative;\n background: transparent;\n min-height: calc(var(--salt-size-base) + var(--salt-spacing-100));\n gap: var(--salt-spacing-100);\n max-width: 100%;\n min-width: 0;\n flex: 0 1 auto;\n}\n\n.saltTabList-center {\n justify-content: center;\n}\n\n.saltTabList-right {\n justify-content: flex-end;\n}\n\n.saltTabList-activeColorPrimary {\n --saltTabList-activeColor: var(--salt-container-primary-background);\n}\n\n.saltTabList-activeColorSecondary {\n --saltTabList-activeColor: var(--salt-container-secondary-background);\n}\n\n.saltTabList-activeColorTertiary {\n --saltTabList-activeColor: var(--salt-container-tertiary-background);\n}\n\n.saltTabList-measureContainer {\n position: absolute;\n top: 0;\n left: 0;\n height: 0;\n overflow: hidden;\n pointer-events: none;\n visibility: hidden;\n white-space: nowrap;\n}\n";
2
+
3
+ export { css_248z as default };
4
+ //# sourceMappingURL=TabList.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TabList.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
@@ -0,0 +1,279 @@
1
+ import { jsx, jsxs } from 'react/jsx-runtime';
2
+ import { useComponentCssInjection } from '@salt-ds/styles';
3
+ import { useWindow } from '@salt-ds/window';
4
+ import { clsx } from 'clsx';
5
+ import { forwardRef, useRef, useState, useEffect, useCallback, useMemo } from 'react';
6
+ import { useAriaAnnouncer } from '../aria-announcer/useAriaAnnouncer.js';
7
+ import '../aria-announcer/AriaAnnouncerContext.js';
8
+ import '../aria-announcer/AriaAnnouncerProvider.js';
9
+ import { capitalize } from '../utils/capitalize.js';
10
+ import { makePrefixer } from '../utils/makePrefixer.js';
11
+ import { useIsomorphicLayoutEffect } from '../utils/useIsomorphicLayoutEffect.js';
12
+ import '../utils/useFloatingUI/useFloatingUI.js';
13
+ import { useForkRef } from '../utils/useForkRef.js';
14
+ import '../utils/useId.js';
15
+ import '../salt-provider/SaltProvider.js';
16
+ import '../viewport/ViewportProvider.js';
17
+ import { TabListLayoutContext } from './internal/contexts/TabListLayoutContext.js';
18
+ import { TabSlotRegistryContext } from './internal/contexts/TabSlotRegistryContext.js';
19
+ import { useTabs } from './internal/contexts/TabsContext.js';
20
+ import { useFocusWithRetry } from './internal/hooks/useFocusWithRetry.js';
21
+ import { useTabListRecovery } from './internal/hooks/useTabListRecovery.js';
22
+ import { useTabRemovalHandler } from './internal/hooks/useTabRemovalHandler.js';
23
+ import { useTabSelectionFocus } from './internal/hooks/useTabSelectionFocus.js';
24
+ import { TabOverflowList } from './internal/overflow/TabOverflowList.js';
25
+ import { TabSlot } from './internal/overflow/TabSlot.js';
26
+ import { useOverflow } from './internal/overflow/useOverflow.js';
27
+ import { useOverflowLayoutState } from './internal/overflow/useOverflowLayoutState.js';
28
+ import css_248z from './TabList.css.js';
29
+
30
+ const withBaseName = makePrefixer("saltTabList");
31
+ const MAX_FOCUS_RETRY_ATTEMPTS = 120;
32
+ const TabList = forwardRef(
33
+ function TabList2(props, ref) {
34
+ const {
35
+ appearance = "bordered",
36
+ activeColor = "primary",
37
+ children,
38
+ className,
39
+ onKeyDown,
40
+ ...rest
41
+ } = props;
42
+ const targetWindow = useWindow();
43
+ useComponentCssInjection({
44
+ testId: "salt-tab-list",
45
+ css: css_248z,
46
+ window: targetWindow
47
+ });
48
+ const {
49
+ renderMode,
50
+ selected,
51
+ setSelected,
52
+ setBootstrapOverflowReady,
53
+ getNext,
54
+ getPrevious,
55
+ getFirst,
56
+ getLast,
57
+ getIndex,
58
+ item,
59
+ itemAt,
60
+ activeTab,
61
+ selectionFromOverflowValueRef,
62
+ menuOpen,
63
+ setMenuOpen,
64
+ sortItems,
65
+ getRemovedItems,
66
+ getRenderedTab,
67
+ renderedTabs,
68
+ removalVersion
69
+ } = useTabs();
70
+ const tabstripRef = useRef(null);
71
+ const overflowListRef = useRef(null);
72
+ const slotMapRef = useRef(/* @__PURE__ */ new Map());
73
+ const removalRecoveryRafRef = useRef(null);
74
+ const pendingRemovalRecoveryRef = useRef(false);
75
+ const pendingRemovalRecoveryRetriesRef = useRef(0);
76
+ const [slotVersion, setSlotVersion] = useState(0);
77
+ const handleRef = useForkRef(tabstripRef, ref);
78
+ const overflowButtonRef = useRef(null);
79
+ const { announce } = useAriaAnnouncer();
80
+ const overflowMenuOpen = renderMode === "portal" ? menuOpen : false;
81
+ const [visibleValues, hiddenValues, isMeasuring] = useOverflow({
82
+ container: tabstripRef,
83
+ menuOpen: overflowMenuOpen,
84
+ selected,
85
+ tabs: renderedTabs,
86
+ overflowButton: overflowButtonRef
87
+ });
88
+ useEffect(() => {
89
+ setBootstrapOverflowReady(
90
+ renderMode === "inline" && renderedTabs.length > 0 && !isMeasuring
91
+ );
92
+ }, [
93
+ isMeasuring,
94
+ renderMode,
95
+ renderedTabs.length,
96
+ setBootstrapOverflowReady
97
+ ]);
98
+ const { resolvedOverflowActiveValue, tabListLayoutContext } = useOverflowLayoutState({
99
+ hiddenValues,
100
+ menuOpen,
101
+ overflowMenuOpen,
102
+ visibleValues
103
+ });
104
+ const registerSlot = useCallback(
105
+ (slotId, element) => {
106
+ const currentElement = slotMapRef.current.get(slotId) ?? null;
107
+ if (currentElement === element) {
108
+ return;
109
+ }
110
+ if (element) {
111
+ slotMapRef.current.set(slotId, element);
112
+ } else {
113
+ slotMapRef.current.delete(slotId);
114
+ }
115
+ setSlotVersion((currentVersion) => currentVersion + 1);
116
+ },
117
+ []
118
+ );
119
+ const slotRegistryContext = useMemo(
120
+ () => ({ registerSlot }),
121
+ [registerSlot]
122
+ );
123
+ const slotAssignments = useMemo(() => {
124
+ const nextAssignments = /* @__PURE__ */ new Map();
125
+ for (const value of visibleValues) {
126
+ nextAssignments.set(value, `main:${value}`);
127
+ }
128
+ for (const value of hiddenValues) {
129
+ nextAssignments.set(
130
+ value,
131
+ menuOpen ? `overflow:${value}` : `measure:${value}`
132
+ );
133
+ }
134
+ return {
135
+ map: nextAssignments,
136
+ version: slotVersion
137
+ };
138
+ }, [hiddenValues, menuOpen, slotVersion, visibleValues]);
139
+ useIsomorphicLayoutEffect(() => {
140
+ var _a;
141
+ if (renderMode !== "portal") {
142
+ return;
143
+ }
144
+ for (const [value, slotId] of slotAssignments.map) {
145
+ const host = (_a = getRenderedTab(value)) == null ? void 0 : _a.host;
146
+ const slot = slotMapRef.current.get(slotId);
147
+ if (host && slot && host.parentElement !== slot) {
148
+ slot.appendChild(host);
149
+ }
150
+ }
151
+ }, [getRenderedTab, renderMode, slotAssignments]);
152
+ const handleKeyDown = (event) => {
153
+ var _a, _b;
154
+ onKeyDown == null ? void 0 : onKeyDown(event);
155
+ if (menuOpen) return;
156
+ const actionMap = {
157
+ ArrowRight: getNext,
158
+ ArrowLeft: getPrevious,
159
+ Home: getFirst,
160
+ End: getLast
161
+ };
162
+ const action = actionMap[event.key];
163
+ if (action) {
164
+ event.preventDefault();
165
+ sortItems();
166
+ const activeTabId = (_a = activeTab.current) == null ? void 0 : _a.id;
167
+ if (!activeTabId) return;
168
+ const nextItem = action(activeTabId);
169
+ if (nextItem) {
170
+ (_b = nextItem.element) == null ? void 0 : _b.focus({ preventScroll: true });
171
+ }
172
+ }
173
+ };
174
+ const getSelectedTabElement = useCallback(() => {
175
+ var _a, _b, _c;
176
+ return ((_a = tabstripRef.current) == null ? void 0 : _a.querySelector(
177
+ '[role="tab"][aria-selected="true"]'
178
+ )) ?? ((_c = item((_b = activeTab.current) == null ? void 0 : _b.id)) == null ? void 0 : _c.element);
179
+ }, [item, activeTab]);
180
+ const { focusElementWithRetry } = useFocusWithRetry({
181
+ maxAttempts: MAX_FOCUS_RETRY_ATTEMPTS,
182
+ targetWindow
183
+ });
184
+ useTabSelectionFocus({
185
+ announce,
186
+ focusElementWithRetry,
187
+ getRenderedTab,
188
+ getSelectedTabElement,
189
+ menuOpen,
190
+ resolvedOverflowActiveValue,
191
+ selected,
192
+ selectionFromOverflowValueRef,
193
+ targetWindow
194
+ });
195
+ const handleTabRemoval = useTabRemovalHandler({
196
+ activeTab,
197
+ focusElementWithRetry,
198
+ getFirst,
199
+ getIndex,
200
+ getLast,
201
+ getRemovedItems,
202
+ getRenderedTab,
203
+ getSelectedTabElement,
204
+ item,
205
+ itemAt,
206
+ maxRetryAttempts: MAX_FOCUS_RETRY_ATTEMPTS,
207
+ menuOpen,
208
+ overflowButtonRef,
209
+ overflowListRef,
210
+ pendingRemovalRecoveryRef,
211
+ pendingRemovalRecoveryRetriesRef,
212
+ removalRecoveryRafRef,
213
+ selected,
214
+ setSelected,
215
+ tabstripRef,
216
+ targetWindow
217
+ });
218
+ useTabListRecovery({
219
+ removalVersion,
220
+ targetWindow,
221
+ tabstripRef,
222
+ overflowListRef,
223
+ handleTabRemoval,
224
+ pendingRemovalRecoveryRef,
225
+ pendingRemovalRecoveryRetriesRef
226
+ });
227
+ return /* @__PURE__ */ jsx(
228
+ "div",
229
+ {
230
+ role: "tablist",
231
+ className: clsx(
232
+ withBaseName(),
233
+ withBaseName(appearance),
234
+ withBaseName("horizontal"),
235
+ withBaseName(`activeColor${capitalize(activeColor)}`),
236
+ className
237
+ ),
238
+ "data-ismeasuring": renderMode === "portal" && isMeasuring ? true : void 0,
239
+ ref: handleRef,
240
+ onKeyDown: handleKeyDown,
241
+ ...rest,
242
+ children: renderMode === "inline" ? children : /* @__PURE__ */ jsx(TabSlotRegistryContext.Provider, { value: slotRegistryContext, children: /* @__PURE__ */ jsxs(TabListLayoutContext.Provider, { value: tabListLayoutContext, children: [
243
+ children,
244
+ visibleValues.map((value) => /* @__PURE__ */ jsx(TabSlot, { slotId: `main:${value}`, value }, value)),
245
+ !menuOpen && hiddenValues.length > 0 ? /* @__PURE__ */ jsx(
246
+ "div",
247
+ {
248
+ "aria-hidden": "true",
249
+ role: "presentation",
250
+ className: withBaseName("measureContainer"),
251
+ children: hiddenValues.map((value) => /* @__PURE__ */ jsx(
252
+ TabSlot,
253
+ {
254
+ slotId: `measure:${value}`,
255
+ value
256
+ },
257
+ `measure-${value}`
258
+ ))
259
+ }
260
+ ) : null,
261
+ /* @__PURE__ */ jsx(
262
+ TabOverflowList,
263
+ {
264
+ buttonRef: overflowButtonRef,
265
+ hiddenValues,
266
+ open: menuOpen,
267
+ order: renderedTabs.length,
268
+ setOpen: setMenuOpen,
269
+ ref: overflowListRef
270
+ }
271
+ )
272
+ ] }) })
273
+ }
274
+ );
275
+ }
276
+ );
277
+
278
+ export { TabList };
279
+ //# sourceMappingURL=TabList.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TabList.js","sources":["../src/tabs/TabList.tsx"],"sourcesContent":["import { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport {\n type ComponentPropsWithoutRef,\n forwardRef,\n type KeyboardEvent,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { useAriaAnnouncer } from \"../aria-announcer\";\nimport {\n capitalize,\n makePrefixer,\n useForkRef,\n useIsomorphicLayoutEffect,\n} from \"../utils\";\nimport { TabListLayoutContext } from \"./internal/contexts/TabListLayoutContext\";\nimport { TabSlotRegistryContext } from \"./internal/contexts/TabSlotRegistryContext\";\nimport { useTabs } from \"./internal/contexts/TabsContext\";\nimport { useFocusWithRetry } from \"./internal/hooks/useFocusWithRetry\";\nimport { useTabListRecovery } from \"./internal/hooks/useTabListRecovery\";\nimport { useTabRemovalHandler } from \"./internal/hooks/useTabRemovalHandler\";\nimport { useTabSelectionFocus } from \"./internal/hooks/useTabSelectionFocus\";\nimport { TabOverflowList } from \"./internal/overflow/TabOverflowList\";\nimport { TabSlot } from \"./internal/overflow/TabSlot\";\nimport { useOverflow } from \"./internal/overflow/useOverflow\";\nimport { useOverflowLayoutState } from \"./internal/overflow/useOverflowLayoutState\";\nimport tabListCss from \"./TabList.css\";\n\nconst withBaseName = makePrefixer(\"saltTabList\");\nconst MAX_FOCUS_RETRY_ATTEMPTS = 120;\n\nexport interface TabListProps\n extends Omit<ComponentPropsWithoutRef<\"div\">, \"onChange\"> {\n /**\n * Styling active color variant. Defaults to \"primary\".\n */\n activeColor?: \"primary\" | \"secondary\" | \"tertiary\";\n /**\n * The appearance of the tabs. Defaults to \"bordered\".\n */\n appearance?: \"bordered\" | \"transparent\";\n}\n\nexport const TabList = forwardRef<HTMLDivElement, TabListProps>(\n function TabList(props, ref) {\n const {\n appearance = \"bordered\",\n activeColor = \"primary\",\n children,\n className,\n onKeyDown,\n ...rest\n } = props;\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-tab-list\",\n css: tabListCss,\n window: targetWindow,\n });\n\n const {\n renderMode,\n selected,\n setSelected,\n setBootstrapOverflowReady,\n getNext,\n getPrevious,\n getFirst,\n getLast,\n getIndex,\n item,\n itemAt,\n activeTab,\n selectionFromOverflowValueRef,\n menuOpen,\n setMenuOpen,\n sortItems,\n getRemovedItems,\n getRenderedTab,\n renderedTabs,\n removalVersion,\n } = useTabs();\n\n const tabstripRef = useRef<HTMLDivElement>(null);\n const overflowListRef = useRef<HTMLDivElement>(null);\n const slotMapRef = useRef<Map<string, HTMLDivElement>>(new Map());\n const removalRecoveryRafRef = useRef<number | null>(null);\n const pendingRemovalRecoveryRef = useRef(false);\n const pendingRemovalRecoveryRetriesRef = useRef(0);\n const [slotVersion, setSlotVersion] = useState(0);\n\n const handleRef = useForkRef(tabstripRef, ref);\n const overflowButtonRef = useRef<HTMLButtonElement>(null);\n\n const { announce } = useAriaAnnouncer();\n const overflowMenuOpen = renderMode === \"portal\" ? menuOpen : false;\n\n const [visibleValues, hiddenValues, isMeasuring] = useOverflow({\n container: tabstripRef,\n menuOpen: overflowMenuOpen,\n selected,\n tabs: renderedTabs,\n overflowButton: overflowButtonRef,\n });\n\n useEffect(() => {\n setBootstrapOverflowReady(\n renderMode === \"inline\" && renderedTabs.length > 0 && !isMeasuring,\n );\n }, [\n isMeasuring,\n renderMode,\n renderedTabs.length,\n setBootstrapOverflowReady,\n ]);\n\n const { resolvedOverflowActiveValue, tabListLayoutContext } =\n useOverflowLayoutState({\n hiddenValues,\n menuOpen,\n overflowMenuOpen,\n visibleValues,\n });\n const registerSlot = useCallback(\n (slotId: string, element: HTMLDivElement | null) => {\n const currentElement = slotMapRef.current.get(slotId) ?? null;\n if (currentElement === element) {\n return;\n }\n\n if (element) {\n slotMapRef.current.set(slotId, element);\n } else {\n slotMapRef.current.delete(slotId);\n }\n\n setSlotVersion((currentVersion) => currentVersion + 1);\n },\n [],\n );\n const slotRegistryContext = useMemo(\n () => ({ registerSlot }),\n [registerSlot],\n );\n const slotAssignments = useMemo(() => {\n const nextAssignments = new Map<string, string>();\n\n for (const value of visibleValues) {\n nextAssignments.set(value, `main:${value}`);\n }\n\n for (const value of hiddenValues) {\n nextAssignments.set(\n value,\n menuOpen ? `overflow:${value}` : `measure:${value}`,\n );\n }\n\n return {\n map: nextAssignments,\n version: slotVersion,\n };\n }, [hiddenValues, menuOpen, slotVersion, visibleValues]);\n\n useIsomorphicLayoutEffect(() => {\n if (renderMode !== \"portal\") {\n return;\n }\n\n for (const [value, slotId] of slotAssignments.map) {\n const host = getRenderedTab(value)?.host;\n const slot = slotMapRef.current.get(slotId);\n\n if (host && slot && host.parentElement !== slot) {\n slot.appendChild(host);\n }\n }\n }, [getRenderedTab, renderMode, slotAssignments]);\n\n const handleKeyDown = (event: KeyboardEvent<HTMLDivElement>) => {\n onKeyDown?.(event);\n\n if (menuOpen) return;\n\n const actionMap = {\n ArrowRight: getNext,\n ArrowLeft: getPrevious,\n Home: getFirst,\n End: getLast,\n };\n\n const action = actionMap[event.key as keyof typeof actionMap];\n\n if (action) {\n event.preventDefault();\n // Item registration/sorting is raf-driven; flush before keyboard nav to\n // avoid navigating against stale collection order/registration.\n sortItems();\n const activeTabId = activeTab.current?.id;\n if (!activeTabId) return;\n const nextItem = action(activeTabId);\n if (nextItem) {\n // Scrolling is handled by TabTrigger.\n nextItem.element?.focus({ preventScroll: true });\n }\n }\n };\n\n const getSelectedTabElement = useCallback(() => {\n return (\n tabstripRef.current?.querySelector<HTMLElement>(\n '[role=\"tab\"][aria-selected=\"true\"]',\n ) ?? item(activeTab.current?.id)?.element\n );\n }, [item, activeTab]);\n const { focusElementWithRetry } = useFocusWithRetry({\n maxAttempts: MAX_FOCUS_RETRY_ATTEMPTS,\n targetWindow,\n });\n useTabSelectionFocus({\n announce,\n focusElementWithRetry,\n getRenderedTab,\n getSelectedTabElement,\n menuOpen,\n resolvedOverflowActiveValue,\n selected,\n selectionFromOverflowValueRef,\n targetWindow,\n });\n\n const handleTabRemoval = useTabRemovalHandler({\n activeTab,\n focusElementWithRetry,\n getFirst,\n getIndex,\n getLast,\n getRemovedItems,\n getRenderedTab,\n getSelectedTabElement,\n item,\n itemAt,\n maxRetryAttempts: MAX_FOCUS_RETRY_ATTEMPTS,\n menuOpen,\n overflowButtonRef,\n overflowListRef,\n pendingRemovalRecoveryRef,\n pendingRemovalRecoveryRetriesRef,\n removalRecoveryRafRef,\n selected,\n setSelected,\n tabstripRef,\n targetWindow,\n });\n\n useTabListRecovery({\n removalVersion,\n targetWindow,\n tabstripRef,\n overflowListRef,\n handleTabRemoval,\n pendingRemovalRecoveryRef,\n pendingRemovalRecoveryRetriesRef,\n });\n\n return (\n <div\n role=\"tablist\"\n className={clsx(\n withBaseName(),\n withBaseName(appearance),\n withBaseName(\"horizontal\"),\n withBaseName(`activeColor${capitalize(activeColor)}`),\n className,\n )}\n data-ismeasuring={\n renderMode === \"portal\" && isMeasuring ? true : undefined\n }\n ref={handleRef}\n onKeyDown={handleKeyDown}\n {...rest}\n >\n {renderMode === \"inline\" ? (\n children\n ) : (\n <TabSlotRegistryContext.Provider value={slotRegistryContext}>\n <TabListLayoutContext.Provider value={tabListLayoutContext}>\n {children}\n {visibleValues.map((value) => (\n <TabSlot key={value} slotId={`main:${value}`} value={value} />\n ))}\n {!menuOpen && hiddenValues.length > 0 ? (\n <div\n aria-hidden=\"true\"\n role=\"presentation\"\n className={withBaseName(\"measureContainer\")}\n >\n {hiddenValues.map((value) => (\n <TabSlot\n key={`measure-${value}`}\n slotId={`measure:${value}`}\n value={value}\n />\n ))}\n </div>\n ) : null}\n <TabOverflowList\n buttonRef={overflowButtonRef}\n hiddenValues={hiddenValues}\n open={menuOpen}\n order={renderedTabs.length}\n setOpen={setMenuOpen}\n ref={overflowListRef}\n />\n </TabListLayoutContext.Provider>\n </TabSlotRegistryContext.Provider>\n )}\n </div>\n );\n },\n);\n"],"names":["TabList","tabListCss"],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ var css_248z = ".saltTabPanel {\n height: 100%;\n width: 100%;\n}\n\n.saltTabPanel[hidden] {\n display: none;\n}\n\n.saltTabPanel:focus-visible {\n outline: var(--salt-focused-outline);\n}\n";
2
+
3
+ export { css_248z as default };
4
+ //# sourceMappingURL=TabPanel.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TabPanel.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
@@ -0,0 +1,96 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { useComponentCssInjection } from '@salt-ds/styles';
3
+ import { useWindow } from '@salt-ds/window';
4
+ import { clsx } from 'clsx';
5
+ import { forwardRef, useRef, useState, useEffect } from 'react';
6
+ import { tabbable } from 'tabbable';
7
+ import { makePrefixer } from '../utils/makePrefixer.js';
8
+ import { useIsomorphicLayoutEffect } from '../utils/useIsomorphicLayoutEffect.js';
9
+ import '../utils/useFloatingUI/useFloatingUI.js';
10
+ import { useForkRef } from '../utils/useForkRef.js';
11
+ import { useId } from '../utils/useId.js';
12
+ import '../salt-provider/SaltProvider.js';
13
+ import '../viewport/ViewportProvider.js';
14
+ import { useTabs } from './internal/contexts/TabsContext.js';
15
+ import css_248z from './TabPanel.css.js';
16
+
17
+ const withBaseName = makePrefixer("saltTabPanel");
18
+ const TabPanel = forwardRef(
19
+ function TabPanel2(props, ref) {
20
+ const { className, children, id: idProp, value, ...rest } = props;
21
+ const targetWindow = useWindow();
22
+ useComponentCssInjection({
23
+ testId: "salt-tab-panel",
24
+ css: css_248z,
25
+ window: targetWindow
26
+ });
27
+ const id = useId(idProp);
28
+ const { registerPanel, getTabId, selected } = useTabs();
29
+ const hidden = selected !== value;
30
+ const panelRef = useRef(null);
31
+ const handleRef = useForkRef(panelRef, ref);
32
+ useIsomorphicLayoutEffect(() => {
33
+ if (id) {
34
+ return registerPanel(id, value);
35
+ }
36
+ }, [value, id, registerPanel]);
37
+ const [hasFocusableChildren, setHasFocusableChildren] = useState(false);
38
+ useEffect(() => {
39
+ const element = panelRef.current;
40
+ const mutationObserverCtor = targetWindow == null ? void 0 : targetWindow.MutationObserver;
41
+ if (!element || hidden) return;
42
+ let rafId = null;
43
+ const detectFocusableChildren = () => {
44
+ rafId = null;
45
+ const elements = tabbable(element);
46
+ const nextHasFocusableChildren = elements.length > 0;
47
+ setHasFocusableChildren((prev) => {
48
+ return prev === nextHasFocusableChildren ? prev : nextHasFocusableChildren;
49
+ });
50
+ };
51
+ const scheduleDetectFocusableChildren = () => {
52
+ if (rafId != null && targetWindow) {
53
+ targetWindow.cancelAnimationFrame(rafId);
54
+ }
55
+ if (!(targetWindow == null ? void 0 : targetWindow.requestAnimationFrame)) {
56
+ detectFocusableChildren();
57
+ return;
58
+ }
59
+ rafId = targetWindow.requestAnimationFrame(detectFocusableChildren);
60
+ };
61
+ const observer = mutationObserverCtor ? new mutationObserverCtor(() => {
62
+ scheduleDetectFocusableChildren();
63
+ }) : null;
64
+ scheduleDetectFocusableChildren();
65
+ observer == null ? void 0 : observer.observe(element, {
66
+ childList: true,
67
+ subtree: true,
68
+ attributes: true
69
+ });
70
+ return () => {
71
+ observer == null ? void 0 : observer.disconnect();
72
+ if (rafId != null && targetWindow) {
73
+ targetWindow.cancelAnimationFrame(rafId);
74
+ }
75
+ };
76
+ }, [hidden, targetWindow]);
77
+ const tabId = getTabId(value);
78
+ return /* @__PURE__ */ jsx(
79
+ "div",
80
+ {
81
+ id,
82
+ ref: handleRef,
83
+ role: "tabpanel",
84
+ "aria-labelledby": tabId,
85
+ className: clsx(withBaseName(), className),
86
+ hidden: hidden || void 0,
87
+ tabIndex: hidden || hasFocusableChildren ? void 0 : 0,
88
+ ...rest,
89
+ children
90
+ }
91
+ );
92
+ }
93
+ );
94
+
95
+ export { TabPanel };
96
+ //# sourceMappingURL=TabPanel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TabPanel.js","sources":["../src/tabs/TabPanel.tsx"],"sourcesContent":["import { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport {\n type ComponentPropsWithoutRef,\n forwardRef,\n useEffect,\n useRef,\n useState,\n} from \"react\";\nimport { tabbable } from \"tabbable\";\nimport {\n makePrefixer,\n useForkRef,\n useId,\n useIsomorphicLayoutEffect,\n} from \"../utils\";\nimport { useTabs } from \"./internal/contexts/TabsContext\";\nimport tabPanelCss from \"./TabPanel.css\";\n\nexport interface TabPanelProps extends ComponentPropsWithoutRef<\"div\"> {\n /**\n * The value of the panel. This should map to the corresponding tab and must\n * be unique within a `Tabs` instance.\n */\n value: string;\n}\n\nconst withBaseName = makePrefixer(\"saltTabPanel\");\n\nexport const TabPanel = forwardRef<HTMLDivElement, TabPanelProps>(\n function TabPanel(props, ref) {\n const { className, children, id: idProp, value, ...rest } = props;\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-tab-panel\",\n css: tabPanelCss,\n window: targetWindow,\n });\n const id = useId(idProp);\n const { registerPanel, getTabId, selected } = useTabs();\n const hidden = selected !== value;\n\n const panelRef = useRef<HTMLDivElement>(null);\n const handleRef = useForkRef(panelRef, ref);\n\n useIsomorphicLayoutEffect(() => {\n if (id) {\n return registerPanel(id, value);\n }\n }, [value, id, registerPanel]);\n\n const [hasFocusableChildren, setHasFocusableChildren] = useState(false);\n useEffect(() => {\n const element = panelRef.current;\n const mutationObserverCtor = (\n targetWindow as\n | (Window & { MutationObserver?: typeof MutationObserver })\n | undefined\n )?.MutationObserver;\n if (!element || hidden) return;\n\n let rafId: number | null = null;\n\n const detectFocusableChildren = () => {\n rafId = null;\n const elements = tabbable(element);\n const nextHasFocusableChildren = elements.length > 0;\n setHasFocusableChildren((prev) => {\n return prev === nextHasFocusableChildren\n ? prev\n : nextHasFocusableChildren;\n });\n };\n\n const scheduleDetectFocusableChildren = () => {\n if (rafId != null && targetWindow) {\n targetWindow.cancelAnimationFrame(rafId);\n }\n\n if (!targetWindow?.requestAnimationFrame) {\n detectFocusableChildren();\n return;\n }\n\n rafId = targetWindow.requestAnimationFrame(detectFocusableChildren);\n };\n\n const observer = mutationObserverCtor\n ? new mutationObserverCtor(() => {\n scheduleDetectFocusableChildren();\n })\n : null;\n\n scheduleDetectFocusableChildren();\n\n observer?.observe(element, {\n childList: true,\n subtree: true,\n attributes: true,\n });\n\n return () => {\n observer?.disconnect();\n if (rafId != null && targetWindow) {\n targetWindow.cancelAnimationFrame(rafId);\n }\n };\n }, [hidden, targetWindow]);\n\n const tabId = getTabId(value);\n\n return (\n <div\n id={id}\n ref={handleRef}\n role=\"tabpanel\"\n aria-labelledby={tabId}\n className={clsx(withBaseName(), className)}\n hidden={hidden || undefined}\n tabIndex={hidden || hasFocusableChildren ? undefined : 0}\n {...rest}\n >\n {children}\n </div>\n );\n },\n);\n"],"names":["TabPanel","tabPanelCss"],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ var css_248z = ".saltTabTrigger {\n all: unset;\n display: flex;\n gap: var(--salt-spacing-100);\n align-items: center;\n justify-content: center;\n flex: 1;\n overflow: hidden;\n}\n\n/* The action should be triggered by clicking anywhere on the tab. */\n.saltTabTrigger::before {\n content: \"\";\n position: absolute;\n width: 100%;\n height: 100%;\n left: 0;\n top: 0;\n}\n\n.saltTabTrigger:focus-visible {\n outline: none;\n}\n";
2
+
3
+ export { css_248z as default };
4
+ //# sourceMappingURL=TabTrigger.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TabTrigger.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}