innxt-design-system 1.6.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 (2499) hide show
  1. package/.browserslistrc +223 -0
  2. package/.circleci/config.yml +361 -0
  3. package/.claude/launch.json +11 -0
  4. package/.codex/environments/environment.toml +11 -0
  5. package/.editorconfig +14 -0
  6. package/.gitattributes +6 -0
  7. package/.lintignore +16 -0
  8. package/.remarkrc.mjs +22 -0
  9. package/.vale.ini +35 -0
  10. package/.vscode/extensions.json +18 -0
  11. package/.vscode/settings.json +13 -0
  12. package/AGENTS.md +72 -0
  13. package/CHANGELOG.md +2648 -0
  14. package/CHANGELOG.old.md +220 -0
  15. package/CLAUDE.md +1 -0
  16. package/CONTRIBUTING.md +181 -0
  17. package/LICENSE +21 -0
  18. package/README.md +37 -0
  19. package/SECURITY.md +14 -0
  20. package/babel.config.mjs +49 -0
  21. package/docs/.env +1 -0
  22. package/docs/README.md +35 -0
  23. package/docs/next.config.mjs +178 -0
  24. package/docs/package.json +91 -0
  25. package/docs/postcss.config.js +7 -0
  26. package/docs/public/_headers +24 -0
  27. package/docs/public/_redirects +26 -0
  28. package/docs/public/fonts/die-grotesk-a-bold.woff2 +0 -0
  29. package/docs/public/fonts/die-grotesk-a-regular.woff2 +0 -0
  30. package/docs/public/fonts/die-grotesk-b-bold.woff2 +0 -0
  31. package/docs/public/fonts/die-grotesk-b-regular.woff2 +0 -0
  32. package/docs/public/fonts/paper-mono.woff2 +0 -0
  33. package/docs/public/static/apple-touch-icon.png +0 -0
  34. package/docs/public/static/favicon-dev.ico +0 -0
  35. package/docs/public/static/favicon-dev.svg +10 -0
  36. package/docs/public/static/favicon.ico +0 -0
  37. package/docs/public/static/favicon.svg +10 -0
  38. package/docs/public/static/logo.svg +5 -0
  39. package/docs/scripts/generateLlmTxt/__snapshots__/mdxToMarkdown.test.mjs.snap +1143 -0
  40. package/docs/scripts/generateLlmTxt/demoProcessor.mjs +172 -0
  41. package/docs/scripts/generateLlmTxt/index.mjs +324 -0
  42. package/docs/scripts/generateLlmTxt/mdxNodeHelpers.mjs +199 -0
  43. package/docs/scripts/generateLlmTxt/mdxToMarkdown.mjs +320 -0
  44. package/docs/scripts/generateLlmTxt/mdxToMarkdown.test.mjs +104 -0
  45. package/docs/scripts/generateLlmTxt/propsReferenceTableProcessor.mjs +174 -0
  46. package/docs/scripts/generateLlmTxt/releaseTimelineProcessor.mjs +80 -0
  47. package/docs/scripts/generateLlmTxt/resolver.mjs +49 -0
  48. package/docs/scripts/generateLlmTxt/typedocProcessor.mjs +50 -0
  49. package/docs/scripts/playground.template.tsx +5 -0
  50. package/docs/scripts/rehypeExtractLinkUrls.mts +46 -0
  51. package/docs/scripts/reportBrokenLinks.mts +16 -0
  52. package/docs/scripts/stylelint/no-unknown-demo-colors.test.mjs +136 -0
  53. package/docs/src/app/(docs)/kb/components/accordion/demos/_index.module.css +100 -0
  54. package/docs/src/app/(docs)/kb/components/accordion/demos/hero/css-modules/index.tsx +69 -0
  55. package/docs/src/app/(docs)/kb/components/accordion/demos/hero/index.ts +9 -0
  56. package/docs/src/app/(docs)/kb/components/accordion/demos/hero/tailwind/index.tsx +68 -0
  57. package/docs/src/app/(docs)/kb/components/accordion/demos/multiple/css-modules/index.tsx +69 -0
  58. package/docs/src/app/(docs)/kb/components/accordion/demos/multiple/index.ts +8 -0
  59. package/docs/src/app/(docs)/kb/components/accordion/demos/multiple/tailwind/index.tsx +71 -0
  60. package/docs/src/app/(docs)/kb/components/accordion/page.mdx +77 -0
  61. package/docs/src/app/(docs)/kb/components/accordion/types.md +402 -0
  62. package/docs/src/app/(docs)/kb/components/accordion/types.ts +7 -0
  63. package/docs/src/app/(docs)/kb/components/alert-dialog/demos/_index.module.css +166 -0
  64. package/docs/src/app/(docs)/kb/components/alert-dialog/demos/detached-triggers-controlled/css-modules/index.tsx +91 -0
  65. package/docs/src/app/(docs)/kb/components/alert-dialog/demos/detached-triggers-controlled/index.ts +8 -0
  66. package/docs/src/app/(docs)/kb/components/alert-dialog/demos/detached-triggers-controlled/tailwind/index.tsx +93 -0
  67. package/docs/src/app/(docs)/kb/components/alert-dialog/demos/detached-triggers-simple/css-modules/index.tsx +39 -0
  68. package/docs/src/app/(docs)/kb/components/alert-dialog/demos/detached-triggers-simple/index.ts +8 -0
  69. package/docs/src/app/(docs)/kb/components/alert-dialog/demos/detached-triggers-simple/tailwind/index.tsx +38 -0
  70. package/docs/src/app/(docs)/kb/components/alert-dialog/demos/hero/css-modules/index.module.css +159 -0
  71. package/docs/src/app/(docs)/kb/components/alert-dialog/demos/hero/css-modules/index.tsx +29 -0
  72. package/docs/src/app/(docs)/kb/components/alert-dialog/demos/hero/index.ts +9 -0
  73. package/docs/src/app/(docs)/kb/components/alert-dialog/demos/hero/tailwind/index.tsx +29 -0
  74. package/docs/src/app/(docs)/kb/components/alert-dialog/page.mdx +257 -0
  75. package/docs/src/app/(docs)/kb/components/alert-dialog/types.md +466 -0
  76. package/docs/src/app/(docs)/kb/components/alert-dialog/types.ts +7 -0
  77. package/docs/src/app/(docs)/kb/components/autocomplete/demos/async/css-modules/index.module.css +186 -0
  78. package/docs/src/app/(docs)/kb/components/autocomplete/demos/async/css-modules/index.tsx +242 -0
  79. package/docs/src/app/(docs)/kb/components/autocomplete/demos/async/index.ts +8 -0
  80. package/docs/src/app/(docs)/kb/components/autocomplete/demos/async/tailwind/index.tsx +260 -0
  81. package/docs/src/app/(docs)/kb/components/autocomplete/demos/auto-highlight/css-modules/index.module.css +142 -0
  82. package/docs/src/app/(docs)/kb/components/autocomplete/demos/auto-highlight/css-modules/index.tsx +80 -0
  83. package/docs/src/app/(docs)/kb/components/autocomplete/demos/auto-highlight/index.ts +8 -0
  84. package/docs/src/app/(docs)/kb/components/autocomplete/demos/auto-highlight/tailwind/index.tsx +88 -0
  85. package/docs/src/app/(docs)/kb/components/autocomplete/demos/command-palette/css-modules/index.module.css +376 -0
  86. package/docs/src/app/(docs)/kb/components/autocomplete/demos/command-palette/css-modules/index.tsx +141 -0
  87. package/docs/src/app/(docs)/kb/components/autocomplete/demos/command-palette/index.ts +8 -0
  88. package/docs/src/app/(docs)/kb/components/autocomplete/demos/command-palette/tailwind/index.tsx +149 -0
  89. package/docs/src/app/(docs)/kb/components/autocomplete/demos/fuzzy-matching/css-modules/index.module.css +176 -0
  90. package/docs/src/app/(docs)/kb/components/autocomplete/demos/fuzzy-matching/css-modules/index.tsx +168 -0
  91. package/docs/src/app/(docs)/kb/components/autocomplete/demos/fuzzy-matching/index.ts +8 -0
  92. package/docs/src/app/(docs)/kb/components/autocomplete/demos/fuzzy-matching/tailwind/index.tsx +182 -0
  93. package/docs/src/app/(docs)/kb/components/autocomplete/demos/grid/css-modules/index.module.css +366 -0
  94. package/docs/src/app/(docs)/kb/components/autocomplete/demos/grid/css-modules/index.tsx +251 -0
  95. package/docs/src/app/(docs)/kb/components/autocomplete/demos/grid/index.ts +8 -0
  96. package/docs/src/app/(docs)/kb/components/autocomplete/demos/grid/tailwind/index.tsx +254 -0
  97. package/docs/src/app/(docs)/kb/components/autocomplete/demos/grouped/css-modules/index.module.css +174 -0
  98. package/docs/src/app/(docs)/kb/components/autocomplete/demos/grouped/css-modules/index.tsx +106 -0
  99. package/docs/src/app/(docs)/kb/components/autocomplete/demos/grouped/index.ts +8 -0
  100. package/docs/src/app/(docs)/kb/components/autocomplete/demos/grouped/tailwind/index.tsx +118 -0
  101. package/docs/src/app/(docs)/kb/components/autocomplete/demos/hero/css-modules/index.module.css +152 -0
  102. package/docs/src/app/(docs)/kb/components/autocomplete/demos/hero/css-modules/index.tsx +80 -0
  103. package/docs/src/app/(docs)/kb/components/autocomplete/demos/hero/index.ts +9 -0
  104. package/docs/src/app/(docs)/kb/components/autocomplete/demos/hero/tailwind/index.tsx +88 -0
  105. package/docs/src/app/(docs)/kb/components/autocomplete/demos/inline/css-modules/index.module.css +141 -0
  106. package/docs/src/app/(docs)/kb/components/autocomplete/demos/inline/css-modules/index.tsx +77 -0
  107. package/docs/src/app/(docs)/kb/components/autocomplete/demos/inline/index.ts +8 -0
  108. package/docs/src/app/(docs)/kb/components/autocomplete/demos/inline/tailwind/index.tsx +83 -0
  109. package/docs/src/app/(docs)/kb/components/autocomplete/demos/limit/css-modules/index.module.css +146 -0
  110. package/docs/src/app/(docs)/kb/components/autocomplete/demos/limit/css-modules/index.tsx +116 -0
  111. package/docs/src/app/(docs)/kb/components/autocomplete/demos/limit/index.ts +8 -0
  112. package/docs/src/app/(docs)/kb/components/autocomplete/demos/limit/tailwind/index.tsx +124 -0
  113. package/docs/src/app/(docs)/kb/components/autocomplete/demos/virtualized/css-modules/index.module.css +138 -0
  114. package/docs/src/app/(docs)/kb/components/autocomplete/demos/virtualized/css-modules/index.tsx +154 -0
  115. package/docs/src/app/(docs)/kb/components/autocomplete/demos/virtualized/index.ts +8 -0
  116. package/docs/src/app/(docs)/kb/components/autocomplete/demos/virtualized/tailwind/index.tsx +151 -0
  117. package/docs/src/app/(docs)/kb/components/autocomplete/page.mdx +285 -0
  118. package/docs/src/app/(docs)/kb/components/autocomplete/types.md +1088 -0
  119. package/docs/src/app/(docs)/kb/components/autocomplete/types.ts +7 -0
  120. package/docs/src/app/(docs)/kb/components/avatar/demos/hero/css-modules/index.module.css +37 -0
  121. package/docs/src/app/(docs)/kb/components/avatar/demos/hero/css-modules/index.tsx +21 -0
  122. package/docs/src/app/(docs)/kb/components/avatar/demos/hero/index.ts +9 -0
  123. package/docs/src/app/(docs)/kb/components/avatar/demos/hero/tailwind/index.tsx +22 -0
  124. package/docs/src/app/(docs)/kb/components/avatar/page.mdx +58 -0
  125. package/docs/src/app/(docs)/kb/components/avatar/types.md +134 -0
  126. package/docs/src/app/(docs)/kb/components/avatar/types.ts +7 -0
  127. package/docs/src/app/(docs)/kb/components/button/demos/hero/css-modules/index.module.css +64 -0
  128. package/docs/src/app/(docs)/kb/components/button/demos/hero/css-modules/index.tsx +6 -0
  129. package/docs/src/app/(docs)/kb/components/button/demos/hero/index.ts +9 -0
  130. package/docs/src/app/(docs)/kb/components/button/demos/hero/tailwind/index.tsx +10 -0
  131. package/docs/src/app/(docs)/kb/components/button/demos/loading/css-modules/index.module.css +64 -0
  132. package/docs/src/app/(docs)/kb/components/button/demos/loading/css-modules/index.tsx +24 -0
  133. package/docs/src/app/(docs)/kb/components/button/demos/loading/index.ts +5 -0
  134. package/docs/src/app/(docs)/kb/components/button/demos/loading/tailwind/index.tsx +23 -0
  135. package/docs/src/app/(docs)/kb/components/button/page.mdx +81 -0
  136. package/docs/src/app/(docs)/kb/components/button/types.md +53 -0
  137. package/docs/src/app/(docs)/kb/components/button/types.ts +4 -0
  138. package/docs/src/app/(docs)/kb/components/checkbox/demos/hero/css-modules/Checkbox.tsx +58 -0
  139. package/docs/src/app/(docs)/kb/components/checkbox/demos/hero/css-modules/index.module.css +63 -0
  140. package/docs/src/app/(docs)/kb/components/checkbox/demos/hero/css-modules/index.tsx +5 -0
  141. package/docs/src/app/(docs)/kb/components/checkbox/demos/hero/index.ts +9 -0
  142. package/docs/src/app/(docs)/kb/components/checkbox/demos/hero/tailwind/index.tsx +34 -0
  143. package/docs/src/app/(docs)/kb/components/checkbox/page.mdx +121 -0
  144. package/docs/src/app/(docs)/kb/components/checkbox/types.md +209 -0
  145. package/docs/src/app/(docs)/kb/components/checkbox/types.ts +7 -0
  146. package/docs/src/app/(docs)/kb/components/checkbox-group/demos/hero/css-modules/index.module.css +76 -0
  147. package/docs/src/app/(docs)/kb/components/checkbox-group/demos/hero/css-modules/index.tsx +63 -0
  148. package/docs/src/app/(docs)/kb/components/checkbox-group/demos/hero/index.ts +9 -0
  149. package/docs/src/app/(docs)/kb/components/checkbox-group/demos/hero/tailwind/index.tsx +74 -0
  150. package/docs/src/app/(docs)/kb/components/checkbox-group/demos/nested/css-modules/index.module.css +76 -0
  151. package/docs/src/app/(docs)/kb/components/checkbox-group/demos/nested/css-modules/index.tsx +174 -0
  152. package/docs/src/app/(docs)/kb/components/checkbox-group/demos/nested/index.ts +4 -0
  153. package/docs/src/app/(docs)/kb/components/checkbox-group/demos/parent/css-modules/index.module.css +76 -0
  154. package/docs/src/app/(docs)/kb/components/checkbox-group/demos/parent/css-modules/index.tsx +101 -0
  155. package/docs/src/app/(docs)/kb/components/checkbox-group/demos/parent/index.ts +4 -0
  156. package/docs/src/app/(docs)/kb/components/checkbox-group/page.mdx +162 -0
  157. package/docs/src/app/(docs)/kb/components/checkbox-group/types.md +87 -0
  158. package/docs/src/app/(docs)/kb/components/checkbox-group/types.ts +4 -0
  159. package/docs/src/app/(docs)/kb/components/collapsible/demos/hero/css-modules/index.module.css +112 -0
  160. package/docs/src/app/(docs)/kb/components/collapsible/demos/hero/css-modules/index.tsx +36 -0
  161. package/docs/src/app/(docs)/kb/components/collapsible/demos/hero/index.ts +9 -0
  162. package/docs/src/app/(docs)/kb/components/collapsible/demos/hero/tailwind/index.tsx +35 -0
  163. package/docs/src/app/(docs)/kb/components/collapsible/page.mdx +56 -0
  164. package/docs/src/app/(docs)/kb/components/collapsible/types.md +168 -0
  165. package/docs/src/app/(docs)/kb/components/collapsible/types.ts +7 -0
  166. package/docs/src/app/(docs)/kb/components/combobox/demos/async-multiple/css-modules/index.module.css +341 -0
  167. package/docs/src/app/(docs)/kb/components/combobox/demos/async-multiple/css-modules/index.tsx +361 -0
  168. package/docs/src/app/(docs)/kb/components/combobox/demos/async-multiple/index.ts +8 -0
  169. package/docs/src/app/(docs)/kb/components/combobox/demos/async-multiple/tailwind/index.tsx +384 -0
  170. package/docs/src/app/(docs)/kb/components/combobox/demos/async-single/css-modules/index.module.css +282 -0
  171. package/docs/src/app/(docs)/kb/components/combobox/demos/async-single/css-modules/index.tsx +337 -0
  172. package/docs/src/app/(docs)/kb/components/combobox/demos/async-single/index.ts +8 -0
  173. package/docs/src/app/(docs)/kb/components/combobox/demos/async-single/tailwind/index.tsx +363 -0
  174. package/docs/src/app/(docs)/kb/components/combobox/demos/creatable/css-modules/index.module.css +496 -0
  175. package/docs/src/app/(docs)/kb/components/combobox/demos/creatable/css-modules/index.tsx +286 -0
  176. package/docs/src/app/(docs)/kb/components/combobox/demos/creatable/index.ts +8 -0
  177. package/docs/src/app/(docs)/kb/components/combobox/demos/creatable/tailwind/index.tsx +306 -0
  178. package/docs/src/app/(docs)/kb/components/combobox/demos/grouped/css-modules/index.module.css +240 -0
  179. package/docs/src/app/(docs)/kb/components/combobox/demos/grouped/css-modules/index.tsx +145 -0
  180. package/docs/src/app/(docs)/kb/components/combobox/demos/grouped/index.ts +8 -0
  181. package/docs/src/app/(docs)/kb/components/combobox/demos/grouped/tailwind/index.tsx +164 -0
  182. package/docs/src/app/(docs)/kb/components/combobox/demos/hero/css-modules/index.module.css +221 -0
  183. package/docs/src/app/(docs)/kb/components/combobox/demos/hero/css-modules/index.tsx +128 -0
  184. package/docs/src/app/(docs)/kb/components/combobox/demos/hero/index.ts +9 -0
  185. package/docs/src/app/(docs)/kb/components/combobox/demos/hero/tailwind/index.tsx +143 -0
  186. package/docs/src/app/(docs)/kb/components/combobox/demos/input-inside-popup/css-modules/index.module.css +273 -0
  187. package/docs/src/app/(docs)/kb/components/combobox/demos/input-inside-popup/css-modules/index.tsx +290 -0
  188. package/docs/src/app/(docs)/kb/components/combobox/demos/input-inside-popup/index.ts +8 -0
  189. package/docs/src/app/(docs)/kb/components/combobox/demos/input-inside-popup/tailwind/index.tsx +303 -0
  190. package/docs/src/app/(docs)/kb/components/combobox/demos/multiple/css-modules/index.module.css +312 -0
  191. package/docs/src/app/(docs)/kb/components/combobox/demos/multiple/css-modules/index.tsx +121 -0
  192. package/docs/src/app/(docs)/kb/components/combobox/demos/multiple/index.ts +8 -0
  193. package/docs/src/app/(docs)/kb/components/combobox/demos/multiple/tailwind/index.tsx +129 -0
  194. package/docs/src/app/(docs)/kb/components/combobox/demos/virtualized/css-modules/index.module.css +150 -0
  195. package/docs/src/app/(docs)/kb/components/combobox/demos/virtualized/css-modules/index.tsx +172 -0
  196. package/docs/src/app/(docs)/kb/components/combobox/demos/virtualized/index.ts +8 -0
  197. package/docs/src/app/(docs)/kb/components/combobox/demos/virtualized/tailwind/index.tsx +175 -0
  198. package/docs/src/app/(docs)/kb/components/combobox/page.mdx +358 -0
  199. package/docs/src/app/(docs)/kb/components/combobox/types.md +1278 -0
  200. package/docs/src/app/(docs)/kb/components/combobox/types.ts +7 -0
  201. package/docs/src/app/(docs)/kb/components/context-menu/demos/hero/css-modules/index.module.css +108 -0
  202. package/docs/src/app/(docs)/kb/components/context-menu/demos/hero/css-modules/index.tsx +24 -0
  203. package/docs/src/app/(docs)/kb/components/context-menu/demos/hero/index.ts +9 -0
  204. package/docs/src/app/(docs)/kb/components/context-menu/demos/hero/tailwind/index.tsx +28 -0
  205. package/docs/src/app/(docs)/kb/components/context-menu/demos/submenu/css-modules/index.module.css +191 -0
  206. package/docs/src/app/(docs)/kb/components/context-menu/demos/submenu/css-modules/index.tsx +63 -0
  207. package/docs/src/app/(docs)/kb/components/context-menu/demos/submenu/index.ts +8 -0
  208. package/docs/src/app/(docs)/kb/components/context-menu/demos/submenu/tailwind/index.tsx +66 -0
  209. package/docs/src/app/(docs)/kb/components/context-menu/page.mdx +156 -0
  210. package/docs/src/app/(docs)/kb/components/context-menu/types.md +1129 -0
  211. package/docs/src/app/(docs)/kb/components/context-menu/types.ts +7 -0
  212. package/docs/src/app/(docs)/kb/components/dialog/demos/_index.module.css +158 -0
  213. package/docs/src/app/(docs)/kb/components/dialog/demos/close-confirmation/css-modules/index.module.css +219 -0
  214. package/docs/src/app/(docs)/kb/components/dialog/demos/close-confirmation/css-modules/index.tsx +91 -0
  215. package/docs/src/app/(docs)/kb/components/dialog/demos/close-confirmation/index.ts +8 -0
  216. package/docs/src/app/(docs)/kb/components/dialog/demos/close-confirmation/tailwind/index.tsx +97 -0
  217. package/docs/src/app/(docs)/kb/components/dialog/demos/detached-triggers-controlled/css-modules/index.tsx +66 -0
  218. package/docs/src/app/(docs)/kb/components/dialog/demos/detached-triggers-controlled/index.ts +8 -0
  219. package/docs/src/app/(docs)/kb/components/dialog/demos/detached-triggers-controlled/tailwind/index.tsx +83 -0
  220. package/docs/src/app/(docs)/kb/components/dialog/demos/detached-triggers-simple/css-modules/index.tsx +33 -0
  221. package/docs/src/app/(docs)/kb/components/dialog/demos/detached-triggers-simple/index.ts +8 -0
  222. package/docs/src/app/(docs)/kb/components/dialog/demos/detached-triggers-simple/tailwind/index.tsx +37 -0
  223. package/docs/src/app/(docs)/kb/components/dialog/demos/hero/css-modules/index.module.css +151 -0
  224. package/docs/src/app/(docs)/kb/components/dialog/demos/hero/css-modules/index.tsx +24 -0
  225. package/docs/src/app/(docs)/kb/components/dialog/demos/hero/index.ts +9 -0
  226. package/docs/src/app/(docs)/kb/components/dialog/demos/hero/tailwind/index.tsx +27 -0
  227. package/docs/src/app/(docs)/kb/components/dialog/demos/inside-scroll/css-modules/index.module.css +273 -0
  228. package/docs/src/app/(docs)/kb/components/dialog/demos/inside-scroll/css-modules/index.tsx +130 -0
  229. package/docs/src/app/(docs)/kb/components/dialog/demos/inside-scroll/index.ts +8 -0
  230. package/docs/src/app/(docs)/kb/components/dialog/demos/inside-scroll/tailwind/index.tsx +133 -0
  231. package/docs/src/app/(docs)/kb/components/dialog/demos/nested/css-modules/index.module.css +218 -0
  232. package/docs/src/app/(docs)/kb/components/dialog/demos/nested/css-modules/index.tsx +39 -0
  233. package/docs/src/app/(docs)/kb/components/dialog/demos/nested/index.ts +5 -0
  234. package/docs/src/app/(docs)/kb/components/dialog/demos/nested/tailwind/index.tsx +46 -0
  235. package/docs/src/app/(docs)/kb/components/dialog/demos/outside-scroll/css-modules/index.module.css +328 -0
  236. package/docs/src/app/(docs)/kb/components/dialog/demos/outside-scroll/css-modules/index.tsx +173 -0
  237. package/docs/src/app/(docs)/kb/components/dialog/demos/outside-scroll/index.ts +8 -0
  238. package/docs/src/app/(docs)/kb/components/dialog/demos/outside-scroll/tailwind/index.tsx +189 -0
  239. package/docs/src/app/(docs)/kb/components/dialog/demos/uncontained/css-modules/index.module.css +198 -0
  240. package/docs/src/app/(docs)/kb/components/dialog/demos/uncontained/css-modules/index.tsx +39 -0
  241. package/docs/src/app/(docs)/kb/components/dialog/demos/uncontained/index.ts +8 -0
  242. package/docs/src/app/(docs)/kb/components/dialog/demos/uncontained/tailwind/index.tsx +43 -0
  243. package/docs/src/app/(docs)/kb/components/dialog/page.mdx +356 -0
  244. package/docs/src/app/(docs)/kb/components/dialog/types.md +512 -0
  245. package/docs/src/app/(docs)/kb/components/dialog/types.ts +7 -0
  246. package/docs/src/app/(docs)/kb/components/drawer/demos/close-confirmation/css-modules/index.module.css +299 -0
  247. package/docs/src/app/(docs)/kb/components/drawer/demos/close-confirmation/css-modules/index.tsx +100 -0
  248. package/docs/src/app/(docs)/kb/components/drawer/demos/close-confirmation/index.ts +8 -0
  249. package/docs/src/app/(docs)/kb/components/drawer/demos/close-confirmation/tailwind/index.tsx +110 -0
  250. package/docs/src/app/(docs)/kb/components/drawer/demos/hero/css-modules/index.module.css +190 -0
  251. package/docs/src/app/(docs)/kb/components/drawer/demos/hero/css-modules/index.tsx +26 -0
  252. package/docs/src/app/(docs)/kb/components/drawer/demos/hero/index.ts +9 -0
  253. package/docs/src/app/(docs)/kb/components/drawer/demos/hero/tailwind/index.tsx +29 -0
  254. package/docs/src/app/(docs)/kb/components/drawer/demos/indent-provider/css-modules/index.module.css +236 -0
  255. package/docs/src/app/(docs)/kb/components/drawer/demos/indent-provider/css-modules/index.tsx +40 -0
  256. package/docs/src/app/(docs)/kb/components/drawer/demos/indent-provider/index.ts +8 -0
  257. package/docs/src/app/(docs)/kb/components/drawer/demos/indent-provider/tailwind/index.tsx +45 -0
  258. package/docs/src/app/(docs)/kb/components/drawer/demos/mobile-nav/css-modules/index.module.css +385 -0
  259. package/docs/src/app/(docs)/kb/components/drawer/demos/mobile-nav/css-modules/index.tsx +132 -0
  260. package/docs/src/app/(docs)/kb/components/drawer/demos/mobile-nav/index.ts +8 -0
  261. package/docs/src/app/(docs)/kb/components/drawer/demos/mobile-nav/tailwind/index.tsx +151 -0
  262. package/docs/src/app/(docs)/kb/components/drawer/demos/nested/css-modules/index.module.css +383 -0
  263. package/docs/src/app/(docs)/kb/components/drawer/demos/nested/css-modules/index.tsx +112 -0
  264. package/docs/src/app/(docs)/kb/components/drawer/demos/nested/index.ts +5 -0
  265. package/docs/src/app/(docs)/kb/components/drawer/demos/nested/tailwind/index.tsx +136 -0
  266. package/docs/src/app/(docs)/kb/components/drawer/demos/non-modal/css-modules/index.module.css +195 -0
  267. package/docs/src/app/(docs)/kb/components/drawer/demos/non-modal/css-modules/index.tsx +26 -0
  268. package/docs/src/app/(docs)/kb/components/drawer/demos/non-modal/index.ts +8 -0
  269. package/docs/src/app/(docs)/kb/components/drawer/demos/non-modal/tailwind/index.tsx +29 -0
  270. package/docs/src/app/(docs)/kb/components/drawer/demos/position/css-modules/index.module.css +181 -0
  271. package/docs/src/app/(docs)/kb/components/drawer/demos/position/css-modules/index.tsx +27 -0
  272. package/docs/src/app/(docs)/kb/components/drawer/demos/position/index.ts +5 -0
  273. package/docs/src/app/(docs)/kb/components/drawer/demos/position/tailwind/index.tsx +32 -0
  274. package/docs/src/app/(docs)/kb/components/drawer/demos/snap-points/css-modules/index.module.css +255 -0
  275. package/docs/src/app/(docs)/kb/components/drawer/demos/snap-points/css-modules/index.tsx +50 -0
  276. package/docs/src/app/(docs)/kb/components/drawer/demos/snap-points/index.ts +8 -0
  277. package/docs/src/app/(docs)/kb/components/drawer/demos/snap-points/tailwind/index.tsx +55 -0
  278. package/docs/src/app/(docs)/kb/components/drawer/demos/swipe-area/css-modules/index.module.css +271 -0
  279. package/docs/src/app/(docs)/kb/components/drawer/demos/swipe-area/css-modules/index.tsx +39 -0
  280. package/docs/src/app/(docs)/kb/components/drawer/demos/swipe-area/index.ts +8 -0
  281. package/docs/src/app/(docs)/kb/components/drawer/demos/swipe-area/tailwind/index.tsx +45 -0
  282. package/docs/src/app/(docs)/kb/components/drawer/demos/uncontained/css-modules/index.module.css +273 -0
  283. package/docs/src/app/(docs)/kb/components/drawer/demos/uncontained/css-modules/index.tsx +53 -0
  284. package/docs/src/app/(docs)/kb/components/drawer/demos/uncontained/index.ts +8 -0
  285. package/docs/src/app/(docs)/kb/components/drawer/demos/uncontained/tailwind/index.tsx +59 -0
  286. package/docs/src/app/(docs)/kb/components/drawer/demos/virtual-keyboard-aware/css-modules/index.module.css +434 -0
  287. package/docs/src/app/(docs)/kb/components/drawer/demos/virtual-keyboard-aware/css-modules/index.tsx +75 -0
  288. package/docs/src/app/(docs)/kb/components/drawer/demos/virtual-keyboard-aware/index.ts +8 -0
  289. package/docs/src/app/(docs)/kb/components/drawer/demos/virtual-keyboard-aware/tailwind/index.tsx +88 -0
  290. package/docs/src/app/(docs)/kb/components/drawer/page.mdx +452 -0
  291. package/docs/src/app/(docs)/kb/components/drawer/types.md +796 -0
  292. package/docs/src/app/(docs)/kb/components/drawer/types.ts +7 -0
  293. package/docs/src/app/(docs)/kb/components/field/demos/hero/css-modules/index.module.css +84 -0
  294. package/docs/src/app/(docs)/kb/components/field/demos/hero/css-modules/index.tsx +17 -0
  295. package/docs/src/app/(docs)/kb/components/field/demos/hero/index.ts +9 -0
  296. package/docs/src/app/(docs)/kb/components/field/demos/hero/tailwind/index.tsx +21 -0
  297. package/docs/src/app/(docs)/kb/components/field/page.mdx +77 -0
  298. package/docs/src/app/(docs)/kb/components/field/types.md +458 -0
  299. package/docs/src/app/(docs)/kb/components/field/types.ts +7 -0
  300. package/docs/src/app/(docs)/kb/components/fieldset/demos/hero/css-modules/index.module.css +106 -0
  301. package/docs/src/app/(docs)/kb/components/fieldset/demos/hero/css-modules/index.tsx +21 -0
  302. package/docs/src/app/(docs)/kb/components/fieldset/demos/hero/index.ts +9 -0
  303. package/docs/src/app/(docs)/kb/components/fieldset/demos/hero/tailwind/index.tsx +32 -0
  304. package/docs/src/app/(docs)/kb/components/fieldset/page.mdx +53 -0
  305. package/docs/src/app/(docs)/kb/components/fieldset/types.md +72 -0
  306. package/docs/src/app/(docs)/kb/components/fieldset/types.ts +7 -0
  307. package/docs/src/app/(docs)/kb/components/form/demos/form-action/css-modules/index.module.css +145 -0
  308. package/docs/src/app/(docs)/kb/components/form/demos/form-action/css-modules/index.tsx +62 -0
  309. package/docs/src/app/(docs)/kb/components/form/demos/form-action/index.ts +8 -0
  310. package/docs/src/app/(docs)/kb/components/form/demos/form-action/tailwind/index.tsx +72 -0
  311. package/docs/src/app/(docs)/kb/components/form/demos/hero/css-modules/index.module.css +145 -0
  312. package/docs/src/app/(docs)/kb/components/form/demos/hero/css-modules/index.tsx +67 -0
  313. package/docs/src/app/(docs)/kb/components/form/demos/hero/index.ts +9 -0
  314. package/docs/src/app/(docs)/kb/components/form/demos/hero/tailwind/index.tsx +73 -0
  315. package/docs/src/app/(docs)/kb/components/form/demos/zod/css-modules/index.module.css +145 -0
  316. package/docs/src/app/(docs)/kb/components/form/demos/zod/css-modules/index.tsx +55 -0
  317. package/docs/src/app/(docs)/kb/components/form/demos/zod/index.ts +5 -0
  318. package/docs/src/app/(docs)/kb/components/form/demos/zod/tailwind/index.tsx +67 -0
  319. package/docs/src/app/(docs)/kb/components/form/page.mdx +91 -0
  320. package/docs/src/app/(docs)/kb/components/form/types.md +88 -0
  321. package/docs/src/app/(docs)/kb/components/form/types.ts +4 -0
  322. package/docs/src/app/(docs)/kb/components/input/demos/hero/css-modules/index.module.css +58 -0
  323. package/docs/src/app/(docs)/kb/components/input/demos/hero/css-modules/index.tsx +11 -0
  324. package/docs/src/app/(docs)/kb/components/input/demos/hero/index.ts +9 -0
  325. package/docs/src/app/(docs)/kb/components/input/demos/hero/tailwind/index.tsx +13 -0
  326. package/docs/src/app/(docs)/kb/components/input/page.mdx +51 -0
  327. package/docs/src/app/(docs)/kb/components/input/types.md +92 -0
  328. package/docs/src/app/(docs)/kb/components/input/types.ts +4 -0
  329. package/docs/src/app/(docs)/kb/components/menu/demos/_index.module.css +250 -0
  330. package/docs/src/app/(docs)/kb/components/menu/demos/arrow/css-modules/index.module.css +199 -0
  331. package/docs/src/app/(docs)/kb/components/menu/demos/arrow/css-modules/index.tsx +47 -0
  332. package/docs/src/app/(docs)/kb/components/menu/demos/arrow/index.ts +8 -0
  333. package/docs/src/app/(docs)/kb/components/menu/demos/arrow/tailwind/index.tsx +49 -0
  334. package/docs/src/app/(docs)/kb/components/menu/demos/checkbox-items/css-modules/index.module.css +172 -0
  335. package/docs/src/app/(docs)/kb/components/menu/demos/checkbox-items/css-modules/index.tsx +85 -0
  336. package/docs/src/app/(docs)/kb/components/menu/demos/checkbox-items/index.ts +8 -0
  337. package/docs/src/app/(docs)/kb/components/menu/demos/checkbox-items/tailwind/index.tsx +87 -0
  338. package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-controlled/css-modules/index.tsx +103 -0
  339. package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-controlled/index.ts +8 -0
  340. package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-controlled/tailwind/index.tsx +112 -0
  341. package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-full/css-modules/index.module.css +75 -0
  342. package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-full/css-modules/index.tsx +90 -0
  343. package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-full/index.ts +8 -0
  344. package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-full/tailwind/index.tsx +150 -0
  345. package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-simple/css-modules/index.tsx +48 -0
  346. package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-simple/index.ts +8 -0
  347. package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-simple/tailwind/index.tsx +56 -0
  348. package/docs/src/app/(docs)/kb/components/menu/demos/group-labels/css-modules/index.module.css +190 -0
  349. package/docs/src/app/(docs)/kb/components/menu/demos/group-labels/css-modules/index.tsx +113 -0
  350. package/docs/src/app/(docs)/kb/components/menu/demos/group-labels/index.ts +8 -0
  351. package/docs/src/app/(docs)/kb/components/menu/demos/group-labels/tailwind/index.tsx +119 -0
  352. package/docs/src/app/(docs)/kb/components/menu/demos/hero/css-modules/index.module.css +160 -0
  353. package/docs/src/app/(docs)/kb/components/menu/demos/hero/css-modules/index.tsx +42 -0
  354. package/docs/src/app/(docs)/kb/components/menu/demos/hero/index.ts +9 -0
  355. package/docs/src/app/(docs)/kb/components/menu/demos/hero/tailwind/index.tsx +44 -0
  356. package/docs/src/app/(docs)/kb/components/menu/demos/open-on-hover/css-modules/index.module.css +160 -0
  357. package/docs/src/app/(docs)/kb/components/menu/demos/open-on-hover/css-modules/index.tsx +39 -0
  358. package/docs/src/app/(docs)/kb/components/menu/demos/open-on-hover/index.ts +8 -0
  359. package/docs/src/app/(docs)/kb/components/menu/demos/open-on-hover/tailwind/index.tsx +44 -0
  360. package/docs/src/app/(docs)/kb/components/menu/demos/radio-items/css-modules/index.module.css +171 -0
  361. package/docs/src/app/(docs)/kb/components/menu/demos/radio-items/css-modules/index.tsx +72 -0
  362. package/docs/src/app/(docs)/kb/components/menu/demos/radio-items/index.ts +8 -0
  363. package/docs/src/app/(docs)/kb/components/menu/demos/radio-items/tailwind/index.tsx +74 -0
  364. package/docs/src/app/(docs)/kb/components/menu/demos/submenu/css-modules/index.module.css +193 -0
  365. package/docs/src/app/(docs)/kb/components/menu/demos/submenu/css-modules/index.tsx +84 -0
  366. package/docs/src/app/(docs)/kb/components/menu/demos/submenu/index.ts +5 -0
  367. package/docs/src/app/(docs)/kb/components/menu/demos/submenu/tailwind/index.tsx +93 -0
  368. package/docs/src/app/(docs)/kb/components/menu/page.mdx +450 -0
  369. package/docs/src/app/(docs)/kb/components/menu/types.md +1205 -0
  370. package/docs/src/app/(docs)/kb/components/menu/types.ts +7 -0
  371. package/docs/src/app/(docs)/kb/components/menubar/demos/hero/css-modules/index.module.css +185 -0
  372. package/docs/src/app/(docs)/kb/components/menubar/demos/hero/css-modules/index.tsx +151 -0
  373. package/docs/src/app/(docs)/kb/components/menubar/demos/hero/index.ts +9 -0
  374. package/docs/src/app/(docs)/kb/components/menubar/demos/hero/tailwind/index.tsx +198 -0
  375. package/docs/src/app/(docs)/kb/components/menubar/page.mdx +79 -0
  376. package/docs/src/app/(docs)/kb/components/menubar/types.md +61 -0
  377. package/docs/src/app/(docs)/kb/components/menubar/types.ts +4 -0
  378. package/docs/src/app/(docs)/kb/components/meter/demos/hero/css-modules/index.module.css +49 -0
  379. package/docs/src/app/(docs)/kb/components/meter/demos/hero/css-modules/index.tsx +14 -0
  380. package/docs/src/app/(docs)/kb/components/meter/demos/hero/index.ts +9 -0
  381. package/docs/src/app/(docs)/kb/components/meter/demos/hero/tailwind/index.tsx +15 -0
  382. package/docs/src/app/(docs)/kb/components/meter/page.mdx +70 -0
  383. package/docs/src/app/(docs)/kb/components/meter/types.md +152 -0
  384. package/docs/src/app/(docs)/kb/components/meter/types.ts +7 -0
  385. package/docs/src/app/(docs)/kb/components/navigation-menu/demos/hero/css-modules/index.module.css +348 -0
  386. package/docs/src/app/(docs)/kb/components/navigation-menu/demos/hero/css-modules/index.tsx +146 -0
  387. package/docs/src/app/(docs)/kb/components/navigation-menu/demos/hero/index.ts +9 -0
  388. package/docs/src/app/(docs)/kb/components/navigation-menu/demos/hero/tailwind/index.tsx +170 -0
  389. package/docs/src/app/(docs)/kb/components/navigation-menu/demos/nested/css-modules/index.module.css +363 -0
  390. package/docs/src/app/(docs)/kb/components/navigation-menu/demos/nested/css-modules/index.tsx +169 -0
  391. package/docs/src/app/(docs)/kb/components/navigation-menu/demos/nested/index.ts +8 -0
  392. package/docs/src/app/(docs)/kb/components/navigation-menu/demos/nested/tailwind/index.tsx +199 -0
  393. package/docs/src/app/(docs)/kb/components/navigation-menu/demos/nested-inline/css-modules/index.module.css +579 -0
  394. package/docs/src/app/(docs)/kb/components/navigation-menu/demos/nested-inline/css-modules/index.tsx +145 -0
  395. package/docs/src/app/(docs)/kb/components/navigation-menu/demos/nested-inline/data.ts +126 -0
  396. package/docs/src/app/(docs)/kb/components/navigation-menu/demos/nested-inline/index.ts +8 -0
  397. package/docs/src/app/(docs)/kb/components/navigation-menu/demos/nested-inline/tailwind/index.tsx +191 -0
  398. package/docs/src/app/(docs)/kb/components/navigation-menu/page.mdx +185 -0
  399. package/docs/src/app/(docs)/kb/components/navigation-menu/types.md +643 -0
  400. package/docs/src/app/(docs)/kb/components/navigation-menu/types.ts +7 -0
  401. package/docs/src/app/(docs)/kb/components/number-field/demos/hero/css-modules/index.module.css +136 -0
  402. package/docs/src/app/(docs)/kb/components/number-field/demos/hero/css-modules/index.tsx +81 -0
  403. package/docs/src/app/(docs)/kb/components/number-field/demos/hero/index.ts +9 -0
  404. package/docs/src/app/(docs)/kb/components/number-field/demos/hero/tailwind/index.tsx +86 -0
  405. package/docs/src/app/(docs)/kb/components/number-field/page.mdx +86 -0
  406. package/docs/src/app/(docs)/kb/components/number-field/types.md +577 -0
  407. package/docs/src/app/(docs)/kb/components/number-field/types.ts +7 -0
  408. package/docs/src/app/(docs)/kb/components/otp-field/demos/alphanumeric/css-modules/index.module.css +73 -0
  409. package/docs/src/app/(docs)/kb/components/otp-field/demos/alphanumeric/css-modules/index.tsx +37 -0
  410. package/docs/src/app/(docs)/kb/components/otp-field/demos/alphanumeric/index.ts +8 -0
  411. package/docs/src/app/(docs)/kb/components/otp-field/demos/alphanumeric/tailwind/index.tsx +36 -0
  412. package/docs/src/app/(docs)/kb/components/otp-field/demos/custom-sanitize/css-modules/index.module.css +153 -0
  413. package/docs/src/app/(docs)/kb/components/otp-field/demos/custom-sanitize/css-modules/index.tsx +74 -0
  414. package/docs/src/app/(docs)/kb/components/otp-field/demos/custom-sanitize/index.ts +6 -0
  415. package/docs/src/app/(docs)/kb/components/otp-field/demos/custom-sanitize/useInvalidFeedback.ts +61 -0
  416. package/docs/src/app/(docs)/kb/components/otp-field/demos/focused-placeholder/css-modules/index.module.css +81 -0
  417. package/docs/src/app/(docs)/kb/components/otp-field/demos/focused-placeholder/css-modules/index.tsx +36 -0
  418. package/docs/src/app/(docs)/kb/components/otp-field/demos/focused-placeholder/index.ts +8 -0
  419. package/docs/src/app/(docs)/kb/components/otp-field/demos/focused-placeholder/tailwind/index.tsx +35 -0
  420. package/docs/src/app/(docs)/kb/components/otp-field/demos/grouped/css-modules/index.module.css +75 -0
  421. package/docs/src/app/(docs)/kb/components/otp-field/demos/grouped/css-modules/index.tsx +38 -0
  422. package/docs/src/app/(docs)/kb/components/otp-field/demos/grouped/index.ts +8 -0
  423. package/docs/src/app/(docs)/kb/components/otp-field/demos/grouped/tailwind/index.tsx +37 -0
  424. package/docs/src/app/(docs)/kb/components/otp-field/demos/hero/css-modules/index.module.css +69 -0
  425. package/docs/src/app/(docs)/kb/components/otp-field/demos/hero/css-modules/index.tsx +35 -0
  426. package/docs/src/app/(docs)/kb/components/otp-field/demos/hero/index.ts +8 -0
  427. package/docs/src/app/(docs)/kb/components/otp-field/demos/hero/tailwind/index.tsx +34 -0
  428. package/docs/src/app/(docs)/kb/components/otp-field/demos/password/css-modules/index.module.css +74 -0
  429. package/docs/src/app/(docs)/kb/components/otp-field/demos/password/css-modules/index.tsx +36 -0
  430. package/docs/src/app/(docs)/kb/components/otp-field/demos/password/index.ts +8 -0
  431. package/docs/src/app/(docs)/kb/components/otp-field/demos/password/tailwind/index.tsx +35 -0
  432. package/docs/src/app/(docs)/kb/components/otp-field/page.mdx +159 -0
  433. package/docs/src/app/(docs)/kb/components/otp-field/types.md +272 -0
  434. package/docs/src/app/(docs)/kb/components/otp-field/types.ts +7 -0
  435. package/docs/src/app/(docs)/kb/components/page.mdx +2013 -0
  436. package/docs/src/app/(docs)/kb/components/popover/demos/_index.module.css +184 -0
  437. package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-controlled/css-modules/index.tsx +64 -0
  438. package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-controlled/index.ts +8 -0
  439. package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-controlled/tailwind/index.tsx +69 -0
  440. package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-full/css-modules/index.module.css +271 -0
  441. package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-full/css-modules/index.tsx +89 -0
  442. package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-full/index.ts +8 -0
  443. package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-full/tailwind/index.tsx +130 -0
  444. package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-simple/css-modules/index.tsx +30 -0
  445. package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-simple/index.ts +8 -0
  446. package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-simple/tailwind/index.tsx +32 -0
  447. package/docs/src/app/(docs)/kb/components/popover/demos/hero/css-modules/index.tsx +22 -0
  448. package/docs/src/app/(docs)/kb/components/popover/demos/hero/index.ts +9 -0
  449. package/docs/src/app/(docs)/kb/components/popover/demos/hero/tailwind/index.tsx +23 -0
  450. package/docs/src/app/(docs)/kb/components/popover/demos/open-on-hover/css-modules/index.tsx +24 -0
  451. package/docs/src/app/(docs)/kb/components/popover/demos/open-on-hover/index.ts +8 -0
  452. package/docs/src/app/(docs)/kb/components/popover/demos/open-on-hover/tailwind/index.tsx +25 -0
  453. package/docs/src/app/(docs)/kb/components/popover/page.mdx +273 -0
  454. package/docs/src/app/(docs)/kb/components/popover/types.md +629 -0
  455. package/docs/src/app/(docs)/kb/components/popover/types.ts +7 -0
  456. package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-controlled/css-modules/index.tsx +132 -0
  457. package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-controlled/index.ts +8 -0
  458. package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-controlled/tailwind/index.tsx +134 -0
  459. package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-full/css-modules/index.module.css +204 -0
  460. package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-full/css-modules/index.tsx +104 -0
  461. package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-full/index.ts +8 -0
  462. package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-full/tailwind/index.tsx +109 -0
  463. package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-simple/css-modules/index.tsx +46 -0
  464. package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-simple/index.ts +8 -0
  465. package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-simple/tailwind/index.tsx +45 -0
  466. package/docs/src/app/(docs)/kb/components/preview-card/demos/hero/css-modules/index.tsx +40 -0
  467. package/docs/src/app/(docs)/kb/components/preview-card/demos/hero/index.ts +9 -0
  468. package/docs/src/app/(docs)/kb/components/preview-card/demos/hero/tailwind/index.tsx +39 -0
  469. package/docs/src/app/(docs)/kb/components/preview-card/demos/index.module.css +221 -0
  470. package/docs/src/app/(docs)/kb/components/preview-card/page.mdx +250 -0
  471. package/docs/src/app/(docs)/kb/components/preview-card/types.md +525 -0
  472. package/docs/src/app/(docs)/kb/components/preview-card/types.ts +7 -0
  473. package/docs/src/app/(docs)/kb/components/progress/demos/hero/css-modules/index.module.css +49 -0
  474. package/docs/src/app/(docs)/kb/components/progress/demos/hero/css-modules/index.tsx +26 -0
  475. package/docs/src/app/(docs)/kb/components/progress/demos/hero/index.ts +9 -0
  476. package/docs/src/app/(docs)/kb/components/progress/demos/hero/tailwind/index.tsx +27 -0
  477. package/docs/src/app/(docs)/kb/components/progress/page.mdx +70 -0
  478. package/docs/src/app/(docs)/kb/components/progress/types.md +216 -0
  479. package/docs/src/app/(docs)/kb/components/progress/types.ts +7 -0
  480. package/docs/src/app/(docs)/kb/components/radio/demos/hero/css-modules/index.module.css +85 -0
  481. package/docs/src/app/(docs)/kb/components/radio/demos/hero/css-modules/index.tsx +37 -0
  482. package/docs/src/app/(docs)/kb/components/radio/demos/hero/index.ts +9 -0
  483. package/docs/src/app/(docs)/kb/components/radio/demos/hero/tailwind/index.tsx +49 -0
  484. package/docs/src/app/(docs)/kb/components/radio/page.mdx +155 -0
  485. package/docs/src/app/(docs)/kb/components/radio/types.md +147 -0
  486. package/docs/src/app/(docs)/kb/components/radio/types.ts +7 -0
  487. package/docs/src/app/(docs)/kb/components/radio-group/types.md +96 -0
  488. package/docs/src/app/(docs)/kb/components/radio-group/types.ts +4 -0
  489. package/docs/src/app/(docs)/kb/components/scroll-area/demos/both/css-modules/index.module.css +95 -0
  490. package/docs/src/app/(docs)/kb/components/scroll-area/demos/both/css-modules/index.tsx +27 -0
  491. package/docs/src/app/(docs)/kb/components/scroll-area/demos/both/index.ts +8 -0
  492. package/docs/src/app/(docs)/kb/components/scroll-area/demos/both/tailwind/index.tsx +32 -0
  493. package/docs/src/app/(docs)/kb/components/scroll-area/demos/hero/css-modules/index.module.css +84 -0
  494. package/docs/src/app/(docs)/kb/components/scroll-area/demos/hero/css-modules/index.tsx +35 -0
  495. package/docs/src/app/(docs)/kb/components/scroll-area/demos/hero/index.ts +9 -0
  496. package/docs/src/app/(docs)/kb/components/scroll-area/demos/hero/tailwind/index.tsx +34 -0
  497. package/docs/src/app/(docs)/kb/components/scroll-area/demos/scroll-fade/css-modules/index.module.css +92 -0
  498. package/docs/src/app/(docs)/kb/components/scroll-area/demos/scroll-fade/css-modules/index.tsx +35 -0
  499. package/docs/src/app/(docs)/kb/components/scroll-area/demos/scroll-fade/index.ts +8 -0
  500. package/docs/src/app/(docs)/kb/components/scroll-area/demos/scroll-fade/tailwind/index.tsx +34 -0
  501. package/docs/src/app/(docs)/kb/components/scroll-area/page.mdx +142 -0
  502. package/docs/src/app/(docs)/kb/components/scroll-area/types.md +356 -0
  503. package/docs/src/app/(docs)/kb/components/scroll-area/types.ts +7 -0
  504. package/docs/src/app/(docs)/kb/components/select/demos/grouped/css-modules/index.module.css +269 -0
  505. package/docs/src/app/(docs)/kb/components/select/demos/grouped/css-modules/index.tsx +148 -0
  506. package/docs/src/app/(docs)/kb/components/select/demos/grouped/index.ts +8 -0
  507. package/docs/src/app/(docs)/kb/components/select/demos/grouped/tailwind/index.tsx +156 -0
  508. package/docs/src/app/(docs)/kb/components/select/demos/hero/css-modules/index.module.css +232 -0
  509. package/docs/src/app/(docs)/kb/components/select/demos/hero/css-modules/index.tsx +110 -0
  510. package/docs/src/app/(docs)/kb/components/select/demos/hero/index.ts +9 -0
  511. package/docs/src/app/(docs)/kb/components/select/demos/hero/tailwind/index.tsx +118 -0
  512. package/docs/src/app/(docs)/kb/components/select/demos/multiple/css-modules/index.module.css +182 -0
  513. package/docs/src/app/(docs)/kb/components/select/demos/multiple/css-modules/index.tsx +96 -0
  514. package/docs/src/app/(docs)/kb/components/select/demos/multiple/index.ts +5 -0
  515. package/docs/src/app/(docs)/kb/components/select/demos/multiple/tailwind/index.tsx +103 -0
  516. package/docs/src/app/(docs)/kb/components/select/demos/object-values/css-modules/index.module.css +279 -0
  517. package/docs/src/app/(docs)/kb/components/select/demos/object-values/css-modules/index.tsx +145 -0
  518. package/docs/src/app/(docs)/kb/components/select/demos/object-values/index.ts +8 -0
  519. package/docs/src/app/(docs)/kb/components/select/demos/object-values/tailwind/index.tsx +150 -0
  520. package/docs/src/app/(docs)/kb/components/select/page.mdx +330 -0
  521. package/docs/src/app/(docs)/kb/components/select/types.md +907 -0
  522. package/docs/src/app/(docs)/kb/components/select/types.ts +7 -0
  523. package/docs/src/app/(docs)/kb/components/separator/demos/hero/css-modules/index.module.css +45 -0
  524. package/docs/src/app/(docs)/kb/components/separator/demos/hero/css-modules/index.tsx +30 -0
  525. package/docs/src/app/(docs)/kb/components/separator/demos/hero/index.ts +9 -0
  526. package/docs/src/app/(docs)/kb/components/separator/demos/hero/tailwind/index.tsx +47 -0
  527. package/docs/src/app/(docs)/kb/components/separator/page.mdx +46 -0
  528. package/docs/src/app/(docs)/kb/components/separator/types.md +53 -0
  529. package/docs/src/app/(docs)/kb/components/separator/types.ts +4 -0
  530. package/docs/src/app/(docs)/kb/components/slider/demos/edge-alignment/css-modules/index.module.css +56 -0
  531. package/docs/src/app/(docs)/kb/components/slider/demos/edge-alignment/css-modules/index.tsx +15 -0
  532. package/docs/src/app/(docs)/kb/components/slider/demos/edge-alignment/index.ts +8 -0
  533. package/docs/src/app/(docs)/kb/components/slider/demos/edge-alignment/tailwind/index.tsx +17 -0
  534. package/docs/src/app/(docs)/kb/components/slider/demos/hero/css-modules/index.module.css +56 -0
  535. package/docs/src/app/(docs)/kb/components/slider/demos/hero/css-modules/index.tsx +15 -0
  536. package/docs/src/app/(docs)/kb/components/slider/demos/hero/index.ts +9 -0
  537. package/docs/src/app/(docs)/kb/components/slider/demos/hero/tailwind/index.tsx +17 -0
  538. package/docs/src/app/(docs)/kb/components/slider/demos/range-slider/css-modules/index.module.css +56 -0
  539. package/docs/src/app/(docs)/kb/components/slider/demos/range-slider/css-modules/index.tsx +16 -0
  540. package/docs/src/app/(docs)/kb/components/slider/demos/range-slider/index.ts +8 -0
  541. package/docs/src/app/(docs)/kb/components/slider/demos/range-slider/tailwind/index.tsx +23 -0
  542. package/docs/src/app/(docs)/kb/components/slider/demos/vertical/css-modules/index.module.css +61 -0
  543. package/docs/src/app/(docs)/kb/components/slider/demos/vertical/css-modules/index.tsx +15 -0
  544. package/docs/src/app/(docs)/kb/components/slider/demos/vertical/index.ts +8 -0
  545. package/docs/src/app/(docs)/kb/components/slider/demos/vertical/tailwind/index.tsx +17 -0
  546. package/docs/src/app/(docs)/kb/components/slider/page.mdx +207 -0
  547. package/docs/src/app/(docs)/kb/components/slider/types.md +641 -0
  548. package/docs/src/app/(docs)/kb/components/slider/types.ts +7 -0
  549. package/docs/src/app/(docs)/kb/components/switch/demos/hero/css-modules/index.module.css +69 -0
  550. package/docs/src/app/(docs)/kb/components/switch/demos/hero/css-modules/index.tsx +13 -0
  551. package/docs/src/app/(docs)/kb/components/switch/demos/hero/index.ts +9 -0
  552. package/docs/src/app/(docs)/kb/components/switch/demos/hero/tailwind/index.tsx +15 -0
  553. package/docs/src/app/(docs)/kb/components/switch/page.mdx +118 -0
  554. package/docs/src/app/(docs)/kb/components/switch/types.md +178 -0
  555. package/docs/src/app/(docs)/kb/components/switch/types.ts +7 -0
  556. package/docs/src/app/(docs)/kb/components/tabs/demos/hero/css-modules/index.module.css +145 -0
  557. package/docs/src/app/(docs)/kb/components/tabs/demos/hero/css-modules/index.tsx +32 -0
  558. package/docs/src/app/(docs)/kb/components/tabs/demos/hero/index.ts +9 -0
  559. package/docs/src/app/(docs)/kb/components/tabs/demos/hero/tailwind/index.tsx +37 -0
  560. package/docs/src/app/(docs)/kb/components/tabs/page.mdx +97 -0
  561. package/docs/src/app/(docs)/kb/components/tabs/types.md +331 -0
  562. package/docs/src/app/(docs)/kb/components/tabs/types.ts +7 -0
  563. package/docs/src/app/(docs)/kb/components/toast/demos/anchored/css-modules/index.module.css +457 -0
  564. package/docs/src/app/(docs)/kb/components/toast/demos/anchored/css-modules/index.tsx +160 -0
  565. package/docs/src/app/(docs)/kb/components/toast/demos/anchored/index.ts +8 -0
  566. package/docs/src/app/(docs)/kb/components/toast/demos/anchored/tailwind/index.tsx +176 -0
  567. package/docs/src/app/(docs)/kb/components/toast/demos/custom/css-modules/index.module.css +271 -0
  568. package/docs/src/app/(docs)/kb/components/toast/demos/custom/css-modules/index.tsx +69 -0
  569. package/docs/src/app/(docs)/kb/components/toast/demos/custom/index.ts +4 -0
  570. package/docs/src/app/(docs)/kb/components/toast/demos/deduplicate/css-modules/index.module.css +305 -0
  571. package/docs/src/app/(docs)/kb/components/toast/demos/deduplicate/css-modules/index.tsx +62 -0
  572. package/docs/src/app/(docs)/kb/components/toast/demos/deduplicate/index.ts +4 -0
  573. package/docs/src/app/(docs)/kb/components/toast/demos/hero/css-modules/index.module.css +271 -0
  574. package/docs/src/app/(docs)/kb/components/toast/demos/hero/css-modules/index.tsx +51 -0
  575. package/docs/src/app/(docs)/kb/components/toast/demos/hero/index.ts +9 -0
  576. package/docs/src/app/(docs)/kb/components/toast/demos/hero/tailwind/index.tsx +60 -0
  577. package/docs/src/app/(docs)/kb/components/toast/demos/position/css-modules/index.module.css +266 -0
  578. package/docs/src/app/(docs)/kb/components/toast/demos/position/css-modules/index.tsx +51 -0
  579. package/docs/src/app/(docs)/kb/components/toast/demos/position/index.ts +5 -0
  580. package/docs/src/app/(docs)/kb/components/toast/demos/position/tailwind/index.tsx +61 -0
  581. package/docs/src/app/(docs)/kb/components/toast/demos/promise/css-modules/index.module.css +287 -0
  582. package/docs/src/app/(docs)/kb/components/toast/demos/promise/css-modules/index.tsx +63 -0
  583. package/docs/src/app/(docs)/kb/components/toast/demos/promise/index.ts +4 -0
  584. package/docs/src/app/(docs)/kb/components/toast/demos/undo/css-modules/index.module.css +277 -0
  585. package/docs/src/app/(docs)/kb/components/toast/demos/undo/css-modules/index.tsx +62 -0
  586. package/docs/src/app/(docs)/kb/components/toast/demos/undo/index.ts +4 -0
  587. package/docs/src/app/(docs)/kb/components/toast/demos/varying-heights/css-modules/index.module.css +271 -0
  588. package/docs/src/app/(docs)/kb/components/toast/demos/varying-heights/css-modules/index.tsx +59 -0
  589. package/docs/src/app/(docs)/kb/components/toast/demos/varying-heights/index.ts +4 -0
  590. package/docs/src/app/(docs)/kb/components/toast/page.mdx +477 -0
  591. package/docs/src/app/(docs)/kb/components/toast/types.md +947 -0
  592. package/docs/src/app/(docs)/kb/components/toast/types.ts +7 -0
  593. package/docs/src/app/(docs)/kb/components/toggle/demos/hero/css-modules/index.module.css +55 -0
  594. package/docs/src/app/(docs)/kb/components/toggle/demos/hero/css-modules/index.tsx +64 -0
  595. package/docs/src/app/(docs)/kb/components/toggle/demos/hero/index.ts +9 -0
  596. package/docs/src/app/(docs)/kb/components/toggle/demos/hero/tailwind/index.tsx +61 -0
  597. package/docs/src/app/(docs)/kb/components/toggle/page.mdx +43 -0
  598. package/docs/src/app/(docs)/kb/components/toggle/types.md +82 -0
  599. package/docs/src/app/(docs)/kb/components/toggle/types.ts +4 -0
  600. package/docs/src/app/(docs)/kb/components/toggle-group/demos/hero/css-modules/index.module.css +82 -0
  601. package/docs/src/app/(docs)/kb/components/toggle-group/demos/hero/css-modules/index.tsx +66 -0
  602. package/docs/src/app/(docs)/kb/components/toggle-group/demos/hero/index.ts +9 -0
  603. package/docs/src/app/(docs)/kb/components/toggle-group/demos/hero/tailwind/index.tsx +81 -0
  604. package/docs/src/app/(docs)/kb/components/toggle-group/demos/multiple/css-modules/index.module.css +82 -0
  605. package/docs/src/app/(docs)/kb/components/toggle-group/demos/multiple/css-modules/index.tsx +69 -0
  606. package/docs/src/app/(docs)/kb/components/toggle-group/demos/multiple/index.ts +8 -0
  607. package/docs/src/app/(docs)/kb/components/toggle-group/demos/multiple/tailwind/index.tsx +80 -0
  608. package/docs/src/app/(docs)/kb/components/toggle-group/page.mdx +52 -0
  609. package/docs/src/app/(docs)/kb/components/toggle-group/types.md +98 -0
  610. package/docs/src/app/(docs)/kb/components/toggle-group/types.ts +4 -0
  611. package/docs/src/app/(docs)/kb/components/toolbar/demos/hero/css-modules/index.module.css +242 -0
  612. package/docs/src/app/(docs)/kb/components/toolbar/demos/hero/css-modules/index.tsx +102 -0
  613. package/docs/src/app/(docs)/kb/components/toolbar/demos/hero/index.ts +9 -0
  614. package/docs/src/app/(docs)/kb/components/toolbar/demos/hero/tailwind/index.tsx +119 -0
  615. package/docs/src/app/(docs)/kb/components/toolbar/page.mdx +139 -0
  616. package/docs/src/app/(docs)/kb/components/toolbar/types.md +275 -0
  617. package/docs/src/app/(docs)/kb/components/toolbar/types.ts +7 -0
  618. package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-controlled/css-modules/index.tsx +138 -0
  619. package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-controlled/index.ts +8 -0
  620. package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-controlled/tailwind/index.tsx +94 -0
  621. package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-full/css-modules/index.module.css +229 -0
  622. package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-full/css-modules/index.tsx +115 -0
  623. package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-full/index.ts +8 -0
  624. package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-full/tailwind/index.tsx +116 -0
  625. package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-simple/css-modules/index.tsx +49 -0
  626. package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-simple/index.ts +8 -0
  627. package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-simple/tailwind/index.tsx +34 -0
  628. package/docs/src/app/(docs)/kb/components/tooltip/demos/hero/css-modules/index.module.css +149 -0
  629. package/docs/src/app/(docs)/kb/components/tooltip/demos/hero/css-modules/index.tsx +98 -0
  630. package/docs/src/app/(docs)/kb/components/tooltip/demos/hero/index.ts +9 -0
  631. package/docs/src/app/(docs)/kb/components/tooltip/demos/hero/tailwind/index.tsx +104 -0
  632. package/docs/src/app/(docs)/kb/components/tooltip/demos/icons-tw.tsx +61 -0
  633. package/docs/src/app/(docs)/kb/components/tooltip/demos/index.module.css +233 -0
  634. package/docs/src/app/(docs)/kb/components/tooltip/page.mdx +270 -0
  635. package/docs/src/app/(docs)/kb/components/tooltip/types.md +524 -0
  636. package/docs/src/app/(docs)/kb/components/tooltip/types.ts +7 -0
  637. package/docs/src/app/(docs)/kb/handbook/animation/demos/animated-popover-motion-keep-mounted-false/css-modules/index.module.css +90 -0
  638. package/docs/src/app/(docs)/kb/handbook/animation/demos/animated-popover-motion-keep-mounted-false/css-modules/index.tsx +35 -0
  639. package/docs/src/app/(docs)/kb/handbook/animation/demos/animated-popover-motion-keep-mounted-false/index.ts +6 -0
  640. package/docs/src/app/(docs)/kb/handbook/animation/demos/animated-popover-motion-keep-mounted-true/css-modules/index.module.css +89 -0
  641. package/docs/src/app/(docs)/kb/handbook/animation/demos/animated-popover-motion-keep-mounted-true/css-modules/index.tsx +32 -0
  642. package/docs/src/app/(docs)/kb/handbook/animation/demos/animated-popover-motion-keep-mounted-true/index.ts +6 -0
  643. package/docs/src/app/(docs)/kb/handbook/animation/demos/animated-select-motion/css-modules/index.module.css +238 -0
  644. package/docs/src/app/(docs)/kb/handbook/animation/demos/animated-select-motion/css-modules/index.tsx +107 -0
  645. package/docs/src/app/(docs)/kb/handbook/animation/demos/animated-select-motion/index.ts +6 -0
  646. package/docs/src/app/(docs)/kb/handbook/animation/page.mdx +233 -0
  647. package/docs/src/app/(docs)/kb/handbook/composition/page.mdx +113 -0
  648. package/docs/src/app/(docs)/kb/handbook/customization/page.mdx +144 -0
  649. package/docs/src/app/(docs)/kb/handbook/forms/demos/components/autocomplete.tsx +73 -0
  650. package/docs/src/app/(docs)/kb/handbook/forms/demos/components/button.tsx +20 -0
  651. package/docs/src/app/(docs)/kb/handbook/forms/demos/components/checkbox-group.tsx +15 -0
  652. package/docs/src/app/(docs)/kb/handbook/forms/demos/components/checkbox.tsx +21 -0
  653. package/docs/src/app/(docs)/kb/handbook/forms/demos/components/combobox.tsx +161 -0
  654. package/docs/src/app/(docs)/kb/handbook/forms/demos/components/field.tsx +56 -0
  655. package/docs/src/app/(docs)/kb/handbook/forms/demos/components/fieldset.tsx +16 -0
  656. package/docs/src/app/(docs)/kb/handbook/forms/demos/components/form.tsx +12 -0
  657. package/docs/src/app/(docs)/kb/handbook/forms/demos/components/number-field.tsx +53 -0
  658. package/docs/src/app/(docs)/kb/handbook/forms/demos/components/radio-group.tsx +15 -0
  659. package/docs/src/app/(docs)/kb/handbook/forms/demos/components/radio.tsx +27 -0
  660. package/docs/src/app/(docs)/kb/handbook/forms/demos/components/select.tsx +129 -0
  661. package/docs/src/app/(docs)/kb/handbook/forms/demos/components/slider.tsx +55 -0
  662. package/docs/src/app/(docs)/kb/handbook/forms/demos/components/switch.tsx +27 -0
  663. package/docs/src/app/(docs)/kb/handbook/forms/demos/components/toast.tsx +64 -0
  664. package/docs/src/app/(docs)/kb/handbook/forms/demos/hero/index.ts +8 -0
  665. package/docs/src/app/(docs)/kb/handbook/forms/demos/hero/tailwind/index.tsx +357 -0
  666. package/docs/src/app/(docs)/kb/handbook/forms/demos/react-hook-form/index.ts +4 -0
  667. package/docs/src/app/(docs)/kb/handbook/forms/demos/react-hook-form/tailwind/index.tsx +511 -0
  668. package/docs/src/app/(docs)/kb/handbook/forms/demos/tanstack-form/index.ts +4 -0
  669. package/docs/src/app/(docs)/kb/handbook/forms/demos/tanstack-form/tailwind/index.tsx +591 -0
  670. package/docs/src/app/(docs)/kb/handbook/forms/page.mdx +736 -0
  671. package/docs/src/app/(docs)/kb/handbook/page.mdx +167 -0
  672. package/docs/src/app/(docs)/kb/handbook/styling/page.mdx +176 -0
  673. package/docs/src/app/(docs)/kb/handbook/typescript/page.mdx +93 -0
  674. package/docs/src/app/(docs)/kb/overview/accessibility/page.mdx +63 -0
  675. package/docs/src/app/(docs)/kb/overview/page.mdx +128 -0
  676. package/docs/src/app/(docs)/kb/overview/quick-start/page.mdx +95 -0
  677. package/docs/src/app/(docs)/kb/page.mdx +130 -0
  678. package/docs/src/app/(docs)/kb/utils/csp-provider/page.mdx +107 -0
  679. package/docs/src/app/(docs)/kb/utils/csp-provider/types.md +35 -0
  680. package/docs/src/app/(docs)/kb/utils/csp-provider/types.ts +4 -0
  681. package/docs/src/app/(docs)/kb/utils/direction-provider/demos/hero/css-modules/index.module.css +56 -0
  682. package/docs/src/app/(docs)/kb/utils/direction-provider/demos/hero/css-modules/index.tsx +20 -0
  683. package/docs/src/app/(docs)/kb/utils/direction-provider/demos/hero/index.ts +9 -0
  684. package/docs/src/app/(docs)/kb/utils/direction-provider/demos/hero/tailwind/index.tsx +19 -0
  685. package/docs/src/app/(docs)/kb/utils/direction-provider/page.mdx +62 -0
  686. package/docs/src/app/(docs)/kb/utils/direction-provider/types.md +48 -0
  687. package/docs/src/app/(docs)/kb/utils/direction-provider/types.ts +8 -0
  688. package/docs/src/app/(docs)/kb/utils/merge-props/demos/prevent-base-ui-handler/css-modules/index.module.css +123 -0
  689. package/docs/src/app/(docs)/kb/utils/merge-props/demos/prevent-base-ui-handler/css-modules/index.tsx +74 -0
  690. package/docs/src/app/(docs)/kb/utils/merge-props/demos/prevent-base-ui-handler/index.ts +4 -0
  691. package/docs/src/app/(docs)/kb/utils/merge-props/page.mdx +87 -0
  692. package/docs/src/app/(docs)/kb/utils/merge-props/types.md +96 -0
  693. package/docs/src/app/(docs)/kb/utils/merge-props/types.ts +7 -0
  694. package/docs/src/app/(docs)/kb/utils/page.mdx +126 -0
  695. package/docs/src/app/(docs)/kb/utils/use-render/demos/render/css-modules/index.module.css +13 -0
  696. package/docs/src/app/(docs)/kb/utils/use-render/demos/render/css-modules/index.tsx +27 -0
  697. package/docs/src/app/(docs)/kb/utils/use-render/demos/render/index.ts +8 -0
  698. package/docs/src/app/(docs)/kb/utils/use-render/demos/render-callback/css-modules/index.module.css +71 -0
  699. package/docs/src/app/(docs)/kb/utils/use-render/demos/render-callback/css-modules/index.tsx +55 -0
  700. package/docs/src/app/(docs)/kb/utils/use-render/demos/render-callback/index.ts +6 -0
  701. package/docs/src/app/(docs)/kb/utils/use-render/page.mdx +198 -0
  702. package/docs/src/app/(docs)/kb/utils/use-render/types.md +557 -0
  703. package/docs/src/app/(docs)/kb/utils/use-render/types.ts +4 -0
  704. package/docs/src/app/(docs)/layout.css +89 -0
  705. package/docs/src/app/(docs)/layout.tsx +196 -0
  706. package/docs/src/app/(docs)/opengraph-image.png +0 -0
  707. package/docs/src/app/(docs)/production-error/ErrorCode.tsx +23 -0
  708. package/docs/src/app/(docs)/production-error/ErrorDisplay.tsx +36 -0
  709. package/docs/src/app/(docs)/production-error/page.mdx +16 -0
  710. package/docs/src/app/(private)/docs-theme/page.module.css +250 -0
  711. package/docs/src/app/(private)/docs-theme/page.tsx +220 -0
  712. package/docs/src/app/(private)/experiments/[...slug]/page.tsx +74 -0
  713. package/docs/src/app/(private)/experiments/_components/Button.module.css +22 -0
  714. package/docs/src/app/(private)/experiments/_components/Button.tsx +29 -0
  715. package/docs/src/app/(private)/experiments/_components/EditPanel.tsx +132 -0
  716. package/docs/src/app/(private)/experiments/_components/ExperimentRoot.module.css +61 -0
  717. package/docs/src/app/(private)/experiments/_components/ExperimentRoot.tsx +41 -0
  718. package/docs/src/app/(private)/experiments/_components/ExperimentsList.module.css +29 -0
  719. package/docs/src/app/(private)/experiments/_components/ExperimentsList.tsx +93 -0
  720. package/docs/src/app/(private)/experiments/_components/HideSidebar.tsx +20 -0
  721. package/docs/src/app/(private)/experiments/_components/Input.module.css +18 -0
  722. package/docs/src/app/(private)/experiments/_components/Input.tsx +7 -0
  723. package/docs/src/app/(private)/experiments/_components/SandboxLink.tsx +53 -0
  724. package/docs/src/app/(private)/experiments/_components/Select.module.css +174 -0
  725. package/docs/src/app/(private)/experiments/_components/Select.tsx +91 -0
  726. package/docs/src/app/(private)/experiments/_components/SettingsPanel.module.css +111 -0
  727. package/docs/src/app/(private)/experiments/_components/SettingsPanel.tsx +282 -0
  728. package/docs/src/app/(private)/experiments/_components/ShowSidebar.module.css +48 -0
  729. package/docs/src/app/(private)/experiments/_components/ShowSidebar.tsx +21 -0
  730. package/docs/src/app/(private)/experiments/_components/Sidebar.module.css +15 -0
  731. package/docs/src/app/(private)/experiments/_components/Sidebar.tsx +35 -0
  732. package/docs/src/app/(private)/experiments/_components/Switch.module.css +104 -0
  733. package/docs/src/app/(private)/experiments/_components/Switch.tsx +42 -0
  734. package/docs/src/app/(private)/experiments/_components/Tooltip.module.css +76 -0
  735. package/docs/src/app/(private)/experiments/_components/Tooltip.tsx +47 -0
  736. package/docs/src/app/(private)/experiments/_css/index.css +61 -0
  737. package/docs/src/app/(private)/experiments/_css/reset.css +384 -0
  738. package/docs/src/app/(private)/experiments/accordion/_components/Accordion.module.css +69 -0
  739. package/docs/src/app/(private)/experiments/accordion/_components/Accordion.tsx +35 -0
  740. package/docs/src/app/(private)/experiments/accordion/accordion.module.css +21 -0
  741. package/docs/src/app/(private)/experiments/accordion/animations.module.css +37 -0
  742. package/docs/src/app/(private)/experiments/accordion/animations.tsx +223 -0
  743. package/docs/src/app/(private)/experiments/accordion/horizontal.module.css +115 -0
  744. package/docs/src/app/(private)/experiments/accordion/horizontal.tsx +107 -0
  745. package/docs/src/app/(private)/experiments/accordion/transitions.module.css +19 -0
  746. package/docs/src/app/(private)/experiments/accordion/transitions.tsx +302 -0
  747. package/docs/src/app/(private)/experiments/anchor-positioning.module.css +12 -0
  748. package/docs/src/app/(private)/experiments/anchor-positioning.tsx +402 -0
  749. package/docs/src/app/(private)/experiments/anchor-side-animations.module.css +46 -0
  750. package/docs/src/app/(private)/experiments/anchor-side-animations.tsx +32 -0
  751. package/docs/src/app/(private)/experiments/collapsible/_components/Collapsible.module.css +54 -0
  752. package/docs/src/app/(private)/experiments/collapsible/_components/Collapsible.tsx +27 -0
  753. package/docs/src/app/(private)/experiments/collapsible/animate-presence.tsx +57 -0
  754. package/docs/src/app/(private)/experiments/collapsible/animations.module.css +58 -0
  755. package/docs/src/app/(private)/experiments/collapsible/animations.tsx +183 -0
  756. package/docs/src/app/(private)/experiments/collapsible/collapsible.module.css +21 -0
  757. package/docs/src/app/(private)/experiments/collapsible/plain.tsx +56 -0
  758. package/docs/src/app/(private)/experiments/collapsible/transitions.module.css +18 -0
  759. package/docs/src/app/(private)/experiments/collapsible/transitions.tsx +154 -0
  760. package/docs/src/app/(private)/experiments/combobox/creatable-tags.module.css +153 -0
  761. package/docs/src/app/(private)/experiments/combobox/creatable-tags.tsx +307 -0
  762. package/docs/src/app/(private)/experiments/combobox/dialog-combobox-multiple.tsx +112 -0
  763. package/docs/src/app/(private)/experiments/combobox/dialog-combobox.module.css +318 -0
  764. package/docs/src/app/(private)/experiments/combobox/dialog-combobox.tsx +88 -0
  765. package/docs/src/app/(private)/experiments/combobox/limited-chips.module.css +278 -0
  766. package/docs/src/app/(private)/experiments/combobox/limited-chips.tsx +203 -0
  767. package/docs/src/app/(private)/experiments/combobox/priority-combobox.module.css +187 -0
  768. package/docs/src/app/(private)/experiments/combobox/priority-combobox.tsx +171 -0
  769. package/docs/src/app/(private)/experiments/combobox-composition.module.css +154 -0
  770. package/docs/src/app/(private)/experiments/combobox-composition.tsx +114 -0
  771. package/docs/src/app/(private)/experiments/combobox-perf.module.css +166 -0
  772. package/docs/src/app/(private)/experiments/combobox-perf.tsx +158 -0
  773. package/docs/src/app/(private)/experiments/context-menu.module.css +342 -0
  774. package/docs/src/app/(private)/experiments/context-menu.tsx +409 -0
  775. package/docs/src/app/(private)/experiments/dialog/dialog.module.css +83 -0
  776. package/docs/src/app/(private)/experiments/dialog/dialogs.tsx +358 -0
  777. package/docs/src/app/(private)/experiments/dialog/nested.module.css +276 -0
  778. package/docs/src/app/(private)/experiments/dialog/nested.tsx +215 -0
  779. package/docs/src/app/(private)/experiments/drawer/cross-axis-scroll.module.css +136 -0
  780. package/docs/src/app/(private)/experiments/drawer/cross-axis-scroll.tsx +162 -0
  781. package/docs/src/app/(private)/experiments/drawer/drawer-controlled-opening.module.css +174 -0
  782. package/docs/src/app/(private)/experiments/drawer/drawer-controlled-opening.tsx +57 -0
  783. package/docs/src/app/(private)/experiments/drawer/touch-ignore.module.css +338 -0
  784. package/docs/src/app/(private)/experiments/drawer/touch-ignore.tsx +155 -0
  785. package/docs/src/app/(private)/experiments/drawer/virtual-keyboard-aware.module.css +112 -0
  786. package/docs/src/app/(private)/experiments/drawer/virtual-keyboard-aware.tsx +220 -0
  787. package/docs/src/app/(private)/experiments/drawer-slider.module.css +196 -0
  788. package/docs/src/app/(private)/experiments/drawer-slider.tsx +39 -0
  789. package/docs/src/app/(private)/experiments/forms/_icons.tsx +47 -0
  790. package/docs/src/app/(private)/experiments/forms/autofill.module.css +467 -0
  791. package/docs/src/app/(private)/experiments/forms/autofill.tsx +325 -0
  792. package/docs/src/app/(private)/experiments/forms/button-controls.tsx +195 -0
  793. package/docs/src/app/(private)/experiments/forms/form.module.css +693 -0
  794. package/docs/src/app/(private)/experiments/forms/form.tsx +523 -0
  795. package/docs/src/app/(private)/experiments/forms/rhf.tsx +988 -0
  796. package/docs/src/app/(private)/experiments/inline-positioning.module.css +171 -0
  797. package/docs/src/app/(private)/experiments/inline-positioning.tsx +169 -0
  798. package/docs/src/app/(private)/experiments/layout.tsx +5 -0
  799. package/docs/src/app/(private)/experiments/long-select.module.css +241 -0
  800. package/docs/src/app/(private)/experiments/long-select.tsx +375 -0
  801. package/docs/src/app/(private)/experiments/menu/complex-nesting.tsx +136 -0
  802. package/docs/src/app/(private)/experiments/menu/dialog-trigger-item.tsx +130 -0
  803. package/docs/src/app/(private)/experiments/menu/menu-anchor-el.tsx +40 -0
  804. package/docs/src/app/(private)/experiments/menu/menu-anchor-ref.tsx +37 -0
  805. package/docs/src/app/(private)/experiments/menu/menu-disabled-items.tsx +87 -0
  806. package/docs/src/app/(private)/experiments/menu/menu-fully-featured.tsx +312 -0
  807. package/docs/src/app/(private)/experiments/menu/menu-horizontal.module.css +193 -0
  808. package/docs/src/app/(private)/experiments/menu/menu-horizontal.tsx +127 -0
  809. package/docs/src/app/(private)/experiments/menu/menu-nested.module.css +190 -0
  810. package/docs/src/app/(private)/experiments/menu/menu-nested.tsx +133 -0
  811. package/docs/src/app/(private)/experiments/menu/menu-submenus.tsx +182 -0
  812. package/docs/src/app/(private)/experiments/menu/menu.module.css +412 -0
  813. package/docs/src/app/(private)/experiments/menu/nested-detached-triggers.module.css +115 -0
  814. package/docs/src/app/(private)/experiments/menu/nested-detached-triggers.tsx +270 -0
  815. package/docs/src/app/(private)/experiments/menu/perf-contained.tsx +90 -0
  816. package/docs/src/app/(private)/experiments/menu/perf-detached.tsx +99 -0
  817. package/docs/src/app/(private)/experiments/menu/pointer-events-scope.module.css +305 -0
  818. package/docs/src/app/(private)/experiments/menu/pointer-events-scope.tsx +254 -0
  819. package/docs/src/app/(private)/experiments/menu/triggers.module.css +47 -0
  820. package/docs/src/app/(private)/experiments/menu/triggers.tsx +421 -0
  821. package/docs/src/app/(private)/experiments/menubar.module.css +63 -0
  822. package/docs/src/app/(private)/experiments/menubar.tsx +239 -0
  823. package/docs/src/app/(private)/experiments/meter.module.css +52 -0
  824. package/docs/src/app/(private)/experiments/meter.tsx +44 -0
  825. package/docs/src/app/(private)/experiments/mobile-scroll-lock.module.css +100 -0
  826. package/docs/src/app/(private)/experiments/mobile-scroll-lock.tsx +38 -0
  827. package/docs/src/app/(private)/experiments/modality.module.css +239 -0
  828. package/docs/src/app/(private)/experiments/modality.tsx +128 -0
  829. package/docs/src/app/(private)/experiments/motion.tsx +113 -0
  830. package/docs/src/app/(private)/experiments/navigation-menu-popups.tsx +214 -0
  831. package/docs/src/app/(private)/experiments/navigation-menu.module.css +638 -0
  832. package/docs/src/app/(private)/experiments/navigation-menu.tsx +611 -0
  833. package/docs/src/app/(private)/experiments/page.tsx +15 -0
  834. package/docs/src/app/(private)/experiments/perf/contained-triggers.tsx +270 -0
  835. package/docs/src/app/(private)/experiments/perf/detached-triggers.tsx +317 -0
  836. package/docs/src/app/(private)/experiments/perf/menu-open.tsx +167 -0
  837. package/docs/src/app/(private)/experiments/perf/perf.module.css +171 -0
  838. package/docs/src/app/(private)/experiments/perf/radix-triggers.tsx +261 -0
  839. package/docs/src/app/(private)/experiments/perf/utils/benchmark.tsx +208 -0
  840. package/docs/src/app/(private)/experiments/perf/utils/wait.ts +27 -0
  841. package/docs/src/app/(private)/experiments/popover/calendar-shared.ts +15 -0
  842. package/docs/src/app/(private)/experiments/popover/calendar.module.css +187 -0
  843. package/docs/src/app/(private)/experiments/popover/calendar.tsx +175 -0
  844. package/docs/src/app/(private)/experiments/popover/dynamic-size.module.css +11 -0
  845. package/docs/src/app/(private)/experiments/popover/dynamic-size.tsx +87 -0
  846. package/docs/src/app/(private)/experiments/popover/nested-open-on-hover.module.css +179 -0
  847. package/docs/src/app/(private)/experiments/popover/nested-open-on-hover.tsx +64 -0
  848. package/docs/src/app/(private)/experiments/popover/popovers.module.css +91 -0
  849. package/docs/src/app/(private)/experiments/popover/popovers.tsx +335 -0
  850. package/docs/src/app/(private)/experiments/popover/vertical-shared.ts +3 -0
  851. package/docs/src/app/(private)/experiments/popover/vertical.module.css +411 -0
  852. package/docs/src/app/(private)/experiments/popover/vertical.tsx +207 -0
  853. package/docs/src/app/(private)/experiments/popup-tabbing.module.css +399 -0
  854. package/docs/src/app/(private)/experiments/popup-tabbing.tsx +247 -0
  855. package/docs/src/app/(private)/experiments/popups/popups-in-popups.module.css +806 -0
  856. package/docs/src/app/(private)/experiments/popups/popups-in-popups.tsx +510 -0
  857. package/docs/src/app/(private)/experiments/popups/popups-transform-origin.module.css +42 -0
  858. package/docs/src/app/(private)/experiments/popups/popups-transform-origin.tsx +77 -0
  859. package/docs/src/app/(private)/experiments/preview-card/nested.module.css +119 -0
  860. package/docs/src/app/(private)/experiments/preview-card/nested.tsx +61 -0
  861. package/docs/src/app/(private)/experiments/preview-card/triggers.module.css +156 -0
  862. package/docs/src/app/(private)/experiments/preview-card/triggers.tsx +446 -0
  863. package/docs/src/app/(private)/experiments/rtl.module.css +170 -0
  864. package/docs/src/app/(private)/experiments/rtl.tsx +187 -0
  865. package/docs/src/app/(private)/experiments/scroll-area/inside-menu.module.css +207 -0
  866. package/docs/src/app/(private)/experiments/scroll-area/inside-menu.tsx +90 -0
  867. package/docs/src/app/(private)/experiments/scroll-area/inside-select.module.css +204 -0
  868. package/docs/src/app/(private)/experiments/scroll-area/inside-select.tsx +67 -0
  869. package/docs/src/app/(private)/experiments/scroll-area/scroll-area-inset.module.css +41 -0
  870. package/docs/src/app/(private)/experiments/scroll-area/scroll-area-inset.tsx +55 -0
  871. package/docs/src/app/(private)/experiments/scroll-area/scroll-area-slight.module.css +30 -0
  872. package/docs/src/app/(private)/experiments/scroll-area/scroll-area-slight.tsx +23 -0
  873. package/docs/src/app/(private)/experiments/scroll-area/scroll-area.module.css +82 -0
  874. package/docs/src/app/(private)/experiments/scroll-area/scroll-area.tsx +25 -0
  875. package/docs/src/app/(private)/experiments/scroll-area/tabs-scroll-area.tsx +109 -0
  876. package/docs/src/app/(private)/experiments/scroll-lock.tsx +136 -0
  877. package/docs/src/app/(private)/experiments/select-perf.module.css +177 -0
  878. package/docs/src/app/(private)/experiments/select-perf.tsx +80 -0
  879. package/docs/src/app/(private)/experiments/select-rtl-align-item-with-trigger.tsx +313 -0
  880. package/docs/src/app/(private)/experiments/slider/inset.module.css +254 -0
  881. package/docs/src/app/(private)/experiments/slider/inset.tsx +150 -0
  882. package/docs/src/app/(private)/experiments/slider/slider.module.css +67 -0
  883. package/docs/src/app/(private)/experiments/slider/slider.tsx +191 -0
  884. package/docs/src/app/(private)/experiments/slider/small.module.css +83 -0
  885. package/docs/src/app/(private)/experiments/slider/vertical.module.css +64 -0
  886. package/docs/src/app/(private)/experiments/storeWithControlledValues.module.css +23 -0
  887. package/docs/src/app/(private)/experiments/storeWithControlledValues.tsx +125 -0
  888. package/docs/src/app/(private)/experiments/tabs/tabs-animations.module.css +264 -0
  889. package/docs/src/app/(private)/experiments/tabs/tabs-animations.tsx +110 -0
  890. package/docs/src/app/(private)/experiments/tabs/tabs-basic.module.css +162 -0
  891. package/docs/src/app/(private)/experiments/tabs/tabs-basic.tsx +96 -0
  892. package/docs/src/app/(private)/experiments/tabs/tabs-onValueChange.module.css +187 -0
  893. package/docs/src/app/(private)/experiments/tabs/tabs-onValueChange.tsx +260 -0
  894. package/docs/src/app/(private)/experiments/tabs/tabs-overflow.module.css +92 -0
  895. package/docs/src/app/(private)/experiments/tabs/tabs-overflow.tsx +81 -0
  896. package/docs/src/app/(private)/experiments/toast.module.css +91 -0
  897. package/docs/src/app/(private)/experiments/toast.tsx +124 -0
  898. package/docs/src/app/(private)/experiments/toggle-group.tsx +121 -0
  899. package/docs/src/app/(private)/experiments/toggle.module.css +75 -0
  900. package/docs/src/app/(private)/experiments/toolbar/_icons.tsx +223 -0
  901. package/docs/src/app/(private)/experiments/toolbar/basic.tsx +101 -0
  902. package/docs/src/app/(private)/experiments/toolbar/slider.module.css +118 -0
  903. package/docs/src/app/(private)/experiments/toolbar/text-editor.tsx +365 -0
  904. package/docs/src/app/(private)/experiments/toolbar/toolbar.module.css +302 -0
  905. package/docs/src/app/(private)/experiments/toolbar/triggers.module.css +52 -0
  906. package/docs/src/app/(private)/experiments/toolbar/triggers.tsx +371 -0
  907. package/docs/src/app/(private)/experiments/tooltip/disabled.module.css +188 -0
  908. package/docs/src/app/(private)/experiments/tooltip/disabled.tsx +72 -0
  909. package/docs/src/app/(private)/experiments/tooltip/nested.module.css +36 -0
  910. package/docs/src/app/(private)/experiments/tooltip/nested.tsx +112 -0
  911. package/docs/src/app/(private)/experiments/tooltip/prevent-open.module.css +119 -0
  912. package/docs/src/app/(private)/experiments/tooltip/prevent-open.tsx +123 -0
  913. package/docs/src/app/(private)/experiments/tooltip/tooltips.module.css +196 -0
  914. package/docs/src/app/(private)/experiments/tooltip/tooltips.tsx +406 -0
  915. package/docs/src/app/(private)/experiments/tooltip/transitions.module.css +109 -0
  916. package/docs/src/app/(private)/experiments/tooltip/transitions.tsx +217 -0
  917. package/docs/src/app/(private)/experiments/transition-attrs.module.css +296 -0
  918. package/docs/src/app/(private)/experiments/transition-attrs.tsx +253 -0
  919. package/docs/src/app/(private)/hydration-repro/index.css +4 -0
  920. package/docs/src/app/(private)/hydration-repro/page.tsx +42 -0
  921. package/docs/src/app/(private)/layout.tsx +63 -0
  922. package/docs/src/app/(private)/playground/[slug]/page.tsx +54 -0
  923. package/docs/src/app/(private)/playground/index.css +9 -0
  924. package/docs/src/app/(private)/playground/layout.tsx +5 -0
  925. package/docs/src/app/(website)/careers/design-engineer/page.tsx +213 -0
  926. package/docs/src/app/(website)/css/components/Accordion.css +60 -0
  927. package/docs/src/app/(website)/css/components/Body.css +8 -0
  928. package/docs/src/app/(website)/css/components/BulletList.css +11 -0
  929. package/docs/src/app/(website)/css/components/Figure.css +10 -0
  930. package/docs/src/app/(website)/css/components/Icon.css +7 -0
  931. package/docs/src/app/(website)/css/components/List.css +14 -0
  932. package/docs/src/app/(website)/css/components/Separator.css +8 -0
  933. package/docs/src/app/(website)/css/components/Text.css +97 -0
  934. package/docs/src/app/(website)/css/index.css +10 -0
  935. package/docs/src/app/(website)/icons/MinusIcon.tsx +19 -0
  936. package/docs/src/app/(website)/icons/PlusIcon.tsx +19 -0
  937. package/docs/src/app/(website)/layout.tsx +108 -0
  938. package/docs/src/app/(website)/logos/GitHub.tsx +9 -0
  939. package/docs/src/app/(website)/logos/HighlightAI.tsx +20 -0
  940. package/docs/src/app/(website)/logos/Interfere.tsx +22 -0
  941. package/docs/src/app/(website)/logos/Operate.tsx +12 -0
  942. package/docs/src/app/(website)/logos/Paper.tsx +12 -0
  943. package/docs/src/app/(website)/logos/Unsplash.tsx +16 -0
  944. package/docs/src/app/(website)/logos/Zed.tsx +21 -0
  945. package/docs/src/app/(website)/opengraph-image.png +0 -0
  946. package/docs/src/app/(website)/page.tsx +47 -0
  947. package/docs/src/app/global-not-found.tsx +20 -0
  948. package/docs/src/app/robots.txt +9 -0
  949. package/docs/src/app/sitemap/index.ts +12 -0
  950. package/docs/src/blocks/Demo/DemoContext.ts +25 -0
  951. package/docs/src/blocks/Demo/DemoPlayground.tsx +29 -0
  952. package/docs/src/blocks/Demo/DemoRoot.tsx +43 -0
  953. package/docs/src/blocks/Demo/DemoSourceCopy.tsx +48 -0
  954. package/docs/src/blocks/Demo/index.ts +6 -0
  955. package/docs/src/blocks/Demo/types.ts +37 -0
  956. package/docs/src/blocks/GoogleAnalyticsProvider.tsx +158 -0
  957. package/docs/src/blocks/GoogleTagManager.tsx +17 -0
  958. package/docs/src/blocks/PackageManagerSnippet/PackageManagerSnippetCode.tsx +16 -0
  959. package/docs/src/blocks/PackageManagerSnippet/PackageManagerSnippetProvider.tsx +59 -0
  960. package/docs/src/blocks/PackageManagerSnippet/PackageManagerSnippetRoot.tsx +49 -0
  961. package/docs/src/blocks/PackageManagerSnippet/index.ts +2 -0
  962. package/docs/src/blocks/README.txt +1 -0
  963. package/docs/src/blocks/createCodeSandbox/CreateReactApp.ts +62 -0
  964. package/docs/src/blocks/createCodeSandbox/addHiddenInput.ts +7 -0
  965. package/docs/src/blocks/createCodeSandbox/createCodeSandbox.ts +190 -0
  966. package/docs/src/blocks/createCodeSandbox/createStackBlitzProject.ts +162 -0
  967. package/docs/src/blocks/createCodeSandbox/flattenRelativeImports.ts +10 -0
  968. package/docs/src/blocks/createCodeSandbox/packDemo.test.ts +66 -0
  969. package/docs/src/blocks/createCodeSandbox/packDemo.ts +60 -0
  970. package/docs/src/code-components.tsx +22 -0
  971. package/docs/src/components/Accordion.css +183 -0
  972. package/docs/src/components/Accordion.tsx +132 -0
  973. package/docs/src/components/Code.css +40 -0
  974. package/docs/src/components/Code.tsx +6 -0
  975. package/docs/src/components/CodeBlock/CodeBlock.css +139 -0
  976. package/docs/src/components/CodeBlock/CodeBlock.tsx +138 -0
  977. package/docs/src/components/CodeBlock/CodeBlockPreComputed.tsx +44 -0
  978. package/docs/src/components/CodeBlock/CodeBlockPreComputedContent.tsx +24 -0
  979. package/docs/src/components/CodeBlock/index.ts +1 -0
  980. package/docs/src/components/CodeBlock/rehypeEagerCodeBlocks.mjs +20 -0
  981. package/docs/src/components/Demo/Demo.css +475 -0
  982. package/docs/src/components/Demo/Demo.tsx +271 -0
  983. package/docs/src/components/Demo/DemoCodeBlock.tsx +96 -0
  984. package/docs/src/components/Demo/DemoErrorFallback.tsx +15 -0
  985. package/docs/src/components/Demo/DemoFileSelector.tsx +83 -0
  986. package/docs/src/components/Demo/DemoPlayground.tsx +24 -0
  987. package/docs/src/components/Demo/DemoVariantSelector.tsx +52 -0
  988. package/docs/src/components/DescriptionList.css +101 -0
  989. package/docs/src/components/DescriptionList.tsx +34 -0
  990. package/docs/src/components/DocsProviders.tsx +19 -0
  991. package/docs/src/components/GhostButton.css +43 -0
  992. package/docs/src/components/GhostButton.tsx +18 -0
  993. package/docs/src/components/GoogleAnalytics.tsx +32 -0
  994. package/docs/src/components/Header.css +184 -0
  995. package/docs/src/components/Header.tsx +101 -0
  996. package/docs/src/components/HeadingLink.css +34 -0
  997. package/docs/src/components/HeadingLink.tsx +7 -0
  998. package/docs/src/components/InstallationBlock/InstallationBlock.css +105 -0
  999. package/docs/src/components/InstallationBlock/InstallationBlock.tsx +73 -0
  1000. package/docs/src/components/InstallationBlock/index.ts +1 -0
  1001. package/docs/src/components/InstallationBlock/model.ts +12 -0
  1002. package/docs/src/components/Kbd/Kbd.css +47 -0
  1003. package/docs/src/components/Kbd/Kbd.tsx +7 -0
  1004. package/docs/src/components/Kbd/rehypeKbd.mjs +14 -0
  1005. package/docs/src/components/Link.css +63 -0
  1006. package/docs/src/components/Link.tsx +54 -0
  1007. package/docs/src/components/Logo.tsx +10 -0
  1008. package/docs/src/components/Menu.css +87 -0
  1009. package/docs/src/components/Menu.tsx +37 -0
  1010. package/docs/src/components/MobileNav.css +273 -0
  1011. package/docs/src/components/MobileNav.tsx +218 -0
  1012. package/docs/src/components/Popup.css +30 -0
  1013. package/docs/src/components/Popup.tsx +7 -0
  1014. package/docs/src/components/QuickNav/QuickNav.css +134 -0
  1015. package/docs/src/components/QuickNav/QuickNav.tsx +71 -0
  1016. package/docs/src/components/QuickNav/rehypeConcatHeadings.mjs +36 -0
  1017. package/docs/src/components/QuickNav/rehypeQuickNav.mjs +134 -0
  1018. package/docs/src/components/QuickNav/rehypeSlug.mjs +70 -0
  1019. package/docs/src/components/QuickNav/remarkQuickNavExcludeHeading.mjs +31 -0
  1020. package/docs/src/components/ReferenceTable/AdditionalTypes.tsx +77 -0
  1021. package/docs/src/components/ReferenceTable/AttributesReferenceTable.tsx +92 -0
  1022. package/docs/src/components/ReferenceTable/CssVariablesReferenceTable.tsx +93 -0
  1023. package/docs/src/components/ReferenceTable/MethodsReferenceAccordion.tsx +147 -0
  1024. package/docs/src/components/ReferenceTable/ParametersReferenceTable.tsx +35 -0
  1025. package/docs/src/components/ReferenceTable/PropertiesReferenceAccordion.tsx +139 -0
  1026. package/docs/src/components/ReferenceTable/ReferenceAccordion.tsx +168 -0
  1027. package/docs/src/components/ReferenceTable/ReferenceTable.css +391 -0
  1028. package/docs/src/components/ReferenceTable/ReferenceTable.tsx +264 -0
  1029. package/docs/src/components/ReleaseTimeline/ReleaseTimeline.css +219 -0
  1030. package/docs/src/components/ReleaseTimeline/ReleaseTimeline.tsx +54 -0
  1031. package/docs/src/components/ReleaseTimeline/index.tsx +1 -0
  1032. package/docs/src/components/ScrollArea.css +92 -0
  1033. package/docs/src/components/ScrollArea.tsx +21 -0
  1034. package/docs/src/components/Search/Search.css +329 -0
  1035. package/docs/src/components/Search/Search.tsx +73 -0
  1036. package/docs/src/components/Search/SearchBar.tsx +450 -0
  1037. package/docs/src/components/Search/index.ts +1 -0
  1038. package/docs/src/components/SearchTrigger.css +57 -0
  1039. package/docs/src/components/SearchTrigger.tsx +40 -0
  1040. package/docs/src/components/Select.css +91 -0
  1041. package/docs/src/components/Select.tsx +40 -0
  1042. package/docs/src/components/SideNav.css +202 -0
  1043. package/docs/src/components/SideNav.tsx +122 -0
  1044. package/docs/src/components/SkipNav.css +38 -0
  1045. package/docs/src/components/SkipNav.tsx +10 -0
  1046. package/docs/src/components/Subtitle/MarkdownLink.tsx +22 -0
  1047. package/docs/src/components/Subtitle/Subtitle.css +65 -0
  1048. package/docs/src/components/Subtitle/Subtitle.tsx +21 -0
  1049. package/docs/src/components/Subtitle/ViewSourceLink.tsx +51 -0
  1050. package/docs/src/components/Subtitle/rehypeSubtitle.mjs +19 -0
  1051. package/docs/src/components/Table.css +90 -0
  1052. package/docs/src/components/Table.tsx +61 -0
  1053. package/docs/src/components/TableCode.css +6 -0
  1054. package/docs/src/components/TableCode.tsx +10 -0
  1055. package/docs/src/components/TypePropRef/TypePropRef.css +8 -0
  1056. package/docs/src/components/TypePropRef/TypePropRef.tsx +33 -0
  1057. package/docs/src/components/TypePropRef/index.ts +1 -0
  1058. package/docs/src/components/TypeRef/TypeRef.css +87 -0
  1059. package/docs/src/components/TypeRef/TypeRef.tsx +103 -0
  1060. package/docs/src/components/TypeRef/index.ts +1 -0
  1061. package/docs/src/css/README.md +3 -0
  1062. package/docs/src/css/custom-media.css +9 -0
  1063. package/docs/src/css/fonts/index.css +41 -0
  1064. package/docs/src/css/index.css +452 -0
  1065. package/docs/src/css/mdx-components.css +110 -0
  1066. package/docs/src/css/syntax.css +299 -0
  1067. package/docs/src/css/utilities/align-items.css +13 -0
  1068. package/docs/src/css/utilities/box-sizing.css +5 -0
  1069. package/docs/src/css/utilities/display.css +87 -0
  1070. package/docs/src/css/utilities/flex-direction.css +5 -0
  1071. package/docs/src/css/utilities/flex-wrap.css +9 -0
  1072. package/docs/src/css/utilities/font-weight.css +9 -0
  1073. package/docs/src/css/utilities/gap.css +179 -0
  1074. package/docs/src/css/utilities/grid-auto-rows.css +5 -0
  1075. package/docs/src/css/utilities/grid-column-end.css +227 -0
  1076. package/docs/src/css/utilities/grid-column-start.css +247 -0
  1077. package/docs/src/css/utilities/grid-template-columns.css +107 -0
  1078. package/docs/src/css/utilities/height.css +5 -0
  1079. package/docs/src/css/utilities/index.css +25 -0
  1080. package/docs/src/css/utilities/justify-content.css +17 -0
  1081. package/docs/src/css/utilities/left.css +5 -0
  1082. package/docs/src/css/utilities/margin.css +25 -0
  1083. package/docs/src/css/utilities/outline.css +5 -0
  1084. package/docs/src/css/utilities/padding.css +211 -0
  1085. package/docs/src/css/utilities/position.css +5 -0
  1086. package/docs/src/css/utilities/scroll-margin-top.css +5 -0
  1087. package/docs/src/css/utilities/text-align.css +13 -0
  1088. package/docs/src/css/utilities/top.css +5 -0
  1089. package/docs/src/css/utilities/visibility.css +5 -0
  1090. package/docs/src/css/utilities/visually-hidden.css +13 -0
  1091. package/docs/src/css/utilities/white-space.css +5 -0
  1092. package/docs/src/css/utilities/width.css +9 -0
  1093. package/docs/src/data/releases.ts +283 -0
  1094. package/docs/src/demo-data/theme/css-modules/theme.css +33 -0
  1095. package/docs/src/error-codes.json +99 -0
  1096. package/docs/src/icons/ArrowRightIcon.tsx +15 -0
  1097. package/docs/src/icons/CaretSortIcon.tsx +9 -0
  1098. package/docs/src/icons/CheckIcon.tsx +9 -0
  1099. package/docs/src/icons/CopyIcon.tsx +9 -0
  1100. package/docs/src/icons/ExternalLinkIcon.tsx +10 -0
  1101. package/docs/src/icons/GitHubIcon.tsx +9 -0
  1102. package/docs/src/icons/MagnifyingGlassIcon.tsx +19 -0
  1103. package/docs/src/icons/MarkdownIcon.tsx +12 -0
  1104. package/docs/src/icons/MoreVertIcon.tsx +9 -0
  1105. package/docs/src/icons/NpmIcon.tsx +11 -0
  1106. package/docs/src/mdx/createHast.mjs +10 -0
  1107. package/docs/src/mdx/createMdxComponent.ts +14 -0
  1108. package/docs/src/mdx/createMdxElement.mjs +58 -0
  1109. package/docs/src/mdx-components.tsx +89 -0
  1110. package/docs/src/utils/camelToSentenceCase.ts +14 -0
  1111. package/docs/src/utils/createDemo.ts +29 -0
  1112. package/docs/src/utils/createTypes.tsx +55 -0
  1113. package/docs/src/utils/demoExportOptions.test.ts +201 -0
  1114. package/docs/src/utils/demoExportOptions.ts +751 -0
  1115. package/docs/src/utils/getGitHubDemoUrl.test.ts +58 -0
  1116. package/docs/src/utils/getGitHubDemoUrl.ts +43 -0
  1117. package/docs/src/utils/observeScrollableInner.ts +36 -0
  1118. package/docs/src/utils/typeOrder.mjs +209 -0
  1119. package/docs/tsconfig.json +47 -0
  1120. package/docs/types.d.ts +18 -0
  1121. package/docs/vitest.config.mts +19 -0
  1122. package/eslint.config.mjs +201 -0
  1123. package/examples/tanstack-start-tailwind-css/.devcontainer/devcontainer.json +4 -0
  1124. package/examples/tanstack-start-tailwind-css/.prettierignore +4 -0
  1125. package/examples/tanstack-start-tailwind-css/.vscode/settings.json +11 -0
  1126. package/examples/tanstack-start-tailwind-css/README.md +57 -0
  1127. package/examples/tanstack-start-tailwind-css/eslint.config.js +13 -0
  1128. package/examples/tanstack-start-tailwind-css/package.json +40 -0
  1129. package/examples/tanstack-start-tailwind-css/prettier.config.js +14 -0
  1130. package/examples/tanstack-start-tailwind-css/public/favicon.ico +0 -0
  1131. package/examples/tanstack-start-tailwind-css/public/logo192.png +0 -0
  1132. package/examples/tanstack-start-tailwind-css/public/logo512.png +0 -0
  1133. package/examples/tanstack-start-tailwind-css/public/manifest.json +25 -0
  1134. package/examples/tanstack-start-tailwind-css/public/robots.txt +3 -0
  1135. package/examples/tanstack-start-tailwind-css/public/tanstack-circle-logo.png +0 -0
  1136. package/examples/tanstack-start-tailwind-css/src/components/button.tsx +15 -0
  1137. package/examples/tanstack-start-tailwind-css/src/components/combobox.tsx +120 -0
  1138. package/examples/tanstack-start-tailwind-css/src/components/dialog.tsx +67 -0
  1139. package/examples/tanstack-start-tailwind-css/src/components/input.tsx +21 -0
  1140. package/examples/tanstack-start-tailwind-css/src/components/link.tsx +19 -0
  1141. package/examples/tanstack-start-tailwind-css/src/components/menu.tsx +109 -0
  1142. package/examples/tanstack-start-tailwind-css/src/components/navigation-menu.tsx +177 -0
  1143. package/examples/tanstack-start-tailwind-css/src/components/popover.tsx +78 -0
  1144. package/examples/tanstack-start-tailwind-css/src/components/toggle.tsx +21 -0
  1145. package/examples/tanstack-start-tailwind-css/src/routeTree.gen.ts +86 -0
  1146. package/examples/tanstack-start-tailwind-css/src/router.tsx +16 -0
  1147. package/examples/tanstack-start-tailwind-css/src/routes/__root.tsx +59 -0
  1148. package/examples/tanstack-start-tailwind-css/src/routes/combobox-server-fn.tsx +91 -0
  1149. package/examples/tanstack-start-tailwind-css/src/routes/index.tsx +153 -0
  1150. package/examples/tanstack-start-tailwind-css/src/styles.css +17 -0
  1151. package/examples/tanstack-start-tailwind-css/tsconfig.json +29 -0
  1152. package/examples/tanstack-start-tailwind-css/vite.config.ts +14 -0
  1153. package/examples/vite-css/README.md +46 -0
  1154. package/examples/vite-css/eslint.config.js +25 -0
  1155. package/examples/vite-css/index.html +14 -0
  1156. package/examples/vite-css/package.json +30 -0
  1157. package/examples/vite-css/src/App.css +52 -0
  1158. package/examples/vite-css/src/App.tsx +39 -0
  1159. package/examples/vite-css/src/assets/base-ui.svg +5 -0
  1160. package/examples/vite-css/src/assets/react.svg +1 -0
  1161. package/examples/vite-css/src/assets/vite.svg +1 -0
  1162. package/examples/vite-css/src/index.css +105 -0
  1163. package/examples/vite-css/src/main.tsx +10 -0
  1164. package/examples/vite-css/src/vite-env.d.ts +1 -0
  1165. package/examples/vite-css/src/widgets/Switch.module.css +89 -0
  1166. package/examples/vite-css/src/widgets/Switch.tsx +13 -0
  1167. package/examples/vite-css/tsconfig.app.json +27 -0
  1168. package/examples/vite-css/tsconfig.json +4 -0
  1169. package/examples/vite-css/tsconfig.node.json +25 -0
  1170. package/examples/vite-css/vite.config.ts +7 -0
  1171. package/greptile.json +3 -0
  1172. package/lerna.json +5 -0
  1173. package/my_docs/vanilla-extract-setup.md +82 -0
  1174. package/netlify/functions/deploy-succeeded.js +41 -0
  1175. package/netlify.toml +13 -0
  1176. package/nx.json +10 -0
  1177. package/package.json +118 -0
  1178. package/packages/react/README.md +47 -0
  1179. package/packages/react/package.json +173 -0
  1180. package/packages/react/scripts/stagePublishedDocs.mjs +29 -0
  1181. package/packages/react/src/accordion/header/AccordionHeader.test.tsx +16 -0
  1182. package/packages/react/src/accordion/header/AccordionHeader.tsx +40 -0
  1183. package/packages/react/src/accordion/header/AccordionHeaderDataAttributes.ts +15 -0
  1184. package/packages/react/src/accordion/index.parts.ts +5 -0
  1185. package/packages/react/src/accordion/index.ts +7 -0
  1186. package/packages/react/src/accordion/item/AccordionItem.test.tsx +45 -0
  1187. package/packages/react/src/accordion/item/AccordionItem.tsx +199 -0
  1188. package/packages/react/src/accordion/item/AccordionItemContext.ts +24 -0
  1189. package/packages/react/src/accordion/item/AccordionItemDataAttributes.ts +15 -0
  1190. package/packages/react/src/accordion/item/stateAttributesMapping.ts +14 -0
  1191. package/packages/react/src/accordion/panel/AccordionPanel.test.tsx +253 -0
  1192. package/packages/react/src/accordion/panel/AccordionPanel.tsx +158 -0
  1193. package/packages/react/src/accordion/panel/AccordionPanelCssVars.ts +12 -0
  1194. package/packages/react/src/accordion/panel/AccordionPanelDataAttributes.ts +29 -0
  1195. package/packages/react/src/accordion/root/AccordionRoot.spec.tsx +63 -0
  1196. package/packages/react/src/accordion/root/AccordionRoot.test.tsx +865 -0
  1197. package/packages/react/src/accordion/root/AccordionRoot.tsx +251 -0
  1198. package/packages/react/src/accordion/root/AccordionRootContext.ts +30 -0
  1199. package/packages/react/src/accordion/root/AccordionRootDataAttributes.ts +10 -0
  1200. package/packages/react/src/accordion/trigger/AccordionTrigger.test.tsx +38 -0
  1201. package/packages/react/src/accordion/trigger/AccordionTrigger.tsx +79 -0
  1202. package/packages/react/src/accordion/trigger/AccordionTriggerDataAttributes.ts +10 -0
  1203. package/packages/react/src/alert-dialog/handle.ts +32 -0
  1204. package/packages/react/src/alert-dialog/index.parts.ts +10 -0
  1205. package/packages/react/src/alert-dialog/index.ts +33 -0
  1206. package/packages/react/src/alert-dialog/root/AlertDialogRoot.spec.tsx +42 -0
  1207. package/packages/react/src/alert-dialog/root/AlertDialogRoot.test.tsx +1144 -0
  1208. package/packages/react/src/alert-dialog/root/AlertDialogRoot.tsx +59 -0
  1209. package/packages/react/src/alert-dialog/trigger/AlertDialogTrigger.tsx +38 -0
  1210. package/packages/react/src/alert-dialog/trigger/AlertDialogTriggerDataAttributes.ts +12 -0
  1211. package/packages/react/src/autocomplete/clear/AutocompleteClearDataAttributes.ts +1 -0
  1212. package/packages/react/src/autocomplete/index.parts.ts +25 -0
  1213. package/packages/react/src/autocomplete/index.ts +73 -0
  1214. package/packages/react/src/autocomplete/input-group/AutocompleteInputGroup.tsx +53 -0
  1215. package/packages/react/src/autocomplete/input-group/AutocompleteInputGroupDataAttributes.ts +51 -0
  1216. package/packages/react/src/autocomplete/item/AutocompleteItem.test.tsx +101 -0
  1217. package/packages/react/src/autocomplete/item/AutocompleteItem.tsx +56 -0
  1218. package/packages/react/src/autocomplete/item/AutocompleteItemDataAttributes.ts +12 -0
  1219. package/packages/react/src/autocomplete/root/AutocompleteRoot.spec.tsx +117 -0
  1220. package/packages/react/src/autocomplete/root/AutocompleteRoot.test.tsx +2158 -0
  1221. package/packages/react/src/autocomplete/root/AutocompleteRoot.tsx +285 -0
  1222. package/packages/react/src/autocomplete/trigger/AutocompleteTrigger.tsx +53 -0
  1223. package/packages/react/src/autocomplete/trigger/AutocompleteTriggerDataAttributes.ts +57 -0
  1224. package/packages/react/src/autocomplete/value/AutocompleteValue.test.tsx +97 -0
  1225. package/packages/react/src/autocomplete/value/AutocompleteValue.tsx +37 -0
  1226. package/packages/react/src/avatar/Avatar.spec.tsx +31 -0
  1227. package/packages/react/src/avatar/fallback/AvatarFallback.test.tsx +271 -0
  1228. package/packages/react/src/avatar/fallback/AvatarFallback.tsx +64 -0
  1229. package/packages/react/src/avatar/image/AvatarImage.test.tsx +383 -0
  1230. package/packages/react/src/avatar/image/AvatarImage.tsx +108 -0
  1231. package/packages/react/src/avatar/image/AvatarImageDataAttributes.ts +12 -0
  1232. package/packages/react/src/avatar/image/useImageLoadingStatus.ts +65 -0
  1233. package/packages/react/src/avatar/index.parts.ts +3 -0
  1234. package/packages/react/src/avatar/index.ts +5 -0
  1235. package/packages/react/src/avatar/root/AvatarRoot.test.tsx +11 -0
  1236. package/packages/react/src/avatar/root/AvatarRoot.tsx +58 -0
  1237. package/packages/react/src/avatar/root/AvatarRootContext.ts +20 -0
  1238. package/packages/react/src/avatar/root/stateAttributesMapping.ts +3 -0
  1239. package/packages/react/src/button/Button.css.ts +170 -0
  1240. package/packages/react/src/button/Button.spec.tsx +10 -0
  1241. package/packages/react/src/button/Button.test.tsx +198 -0
  1242. package/packages/react/src/button/Button.tsx +140 -0
  1243. package/packages/react/src/button/ButtonDataAttributes.tsx +6 -0
  1244. package/packages/react/src/button/index.ts +3 -0
  1245. package/packages/react/src/checkbox/index.parts.ts +2 -0
  1246. package/packages/react/src/checkbox/index.ts +4 -0
  1247. package/packages/react/src/checkbox/indicator/CheckboxIndicator.test.tsx +293 -0
  1248. package/packages/react/src/checkbox/indicator/CheckboxIndicator.tsx +94 -0
  1249. package/packages/react/src/checkbox/indicator/CheckboxIndicatorDataAttributes.ts +60 -0
  1250. package/packages/react/src/checkbox/root/Checkbox.css.ts +76 -0
  1251. package/packages/react/src/checkbox/root/CheckboxRoot.test.tsx +1512 -0
  1252. package/packages/react/src/checkbox/root/CheckboxRoot.tsx +557 -0
  1253. package/packages/react/src/checkbox/root/CheckboxRootContext.ts +18 -0
  1254. package/packages/react/src/checkbox/root/CheckboxRootDataAttributes.ts +50 -0
  1255. package/packages/react/src/checkbox/utils/useStateAttributesMapping.ts +31 -0
  1256. package/packages/react/src/checkbox-group/CheckboxGroup.test.tsx +1027 -0
  1257. package/packages/react/src/checkbox-group/CheckboxGroup.tsx +207 -0
  1258. package/packages/react/src/checkbox-group/CheckboxGroupContext.ts +37 -0
  1259. package/packages/react/src/checkbox-group/CheckboxGroupDataAttributes.ts +6 -0
  1260. package/packages/react/src/checkbox-group/index.ts +2 -0
  1261. package/packages/react/src/checkbox-group/useCheckboxGroupParent.test.tsx +404 -0
  1262. package/packages/react/src/checkbox-group/useCheckboxGroupParent.ts +151 -0
  1263. package/packages/react/src/collapsible/index.parts.ts +3 -0
  1264. package/packages/react/src/collapsible/index.ts +5 -0
  1265. package/packages/react/src/collapsible/panel/CollapsiblePanel.test.tsx +1190 -0
  1266. package/packages/react/src/collapsible/panel/CollapsiblePanel.tsx +163 -0
  1267. package/packages/react/src/collapsible/panel/CollapsiblePanelCssVars.ts +12 -0
  1268. package/packages/react/src/collapsible/panel/CollapsiblePanelDataAttributes.ts +20 -0
  1269. package/packages/react/src/collapsible/panel/useCollapsiblePanel.ts +555 -0
  1270. package/packages/react/src/collapsible/root/CollapsibleRoot.spec.tsx +45 -0
  1271. package/packages/react/src/collapsible/root/CollapsibleRoot.test.tsx +384 -0
  1272. package/packages/react/src/collapsible/root/CollapsibleRoot.tsx +115 -0
  1273. package/packages/react/src/collapsible/root/CollapsibleRootContext.ts +24 -0
  1274. package/packages/react/src/collapsible/root/stateAttributesMapping.ts +9 -0
  1275. package/packages/react/src/collapsible/root/useCollapsibleRoot.ts +116 -0
  1276. package/packages/react/src/collapsible/trigger/CollapsibleTrigger.test.tsx +32 -0
  1277. package/packages/react/src/collapsible/trigger/CollapsibleTrigger.tsx +76 -0
  1278. package/packages/react/src/collapsible/trigger/CollapsibleTriggerDataAttributes.ts +6 -0
  1279. package/packages/react/src/combobox/arrow/ComboboxArrow.test.tsx +19 -0
  1280. package/packages/react/src/combobox/arrow/ComboboxArrow.tsx +72 -0
  1281. package/packages/react/src/combobox/arrow/ComboboxArrowDataAttributes.ts +26 -0
  1282. package/packages/react/src/combobox/backdrop/ComboboxBackdrop.test.tsx +17 -0
  1283. package/packages/react/src/combobox/backdrop/ComboboxBackdrop.tsx +75 -0
  1284. package/packages/react/src/combobox/backdrop/ComboboxBackdropDataAttributes.ts +20 -0
  1285. package/packages/react/src/combobox/chip/ComboboxChip.test.tsx +447 -0
  1286. package/packages/react/src/combobox/chip/ComboboxChip.tsx +152 -0
  1287. package/packages/react/src/combobox/chip/ComboboxChipContext.ts +18 -0
  1288. package/packages/react/src/combobox/chip-remove/ComboboxChipRemove.test.tsx +305 -0
  1289. package/packages/react/src/combobox/chip-remove/ComboboxChipRemove.tsx +146 -0
  1290. package/packages/react/src/combobox/chips/ComboboxChips.test.tsx +246 -0
  1291. package/packages/react/src/combobox/chips/ComboboxChips.tsx +78 -0
  1292. package/packages/react/src/combobox/chips/ComboboxChipsContext.ts +16 -0
  1293. package/packages/react/src/combobox/clear/ComboboxClear.test.tsx +252 -0
  1294. package/packages/react/src/combobox/clear/ComboboxClear.tsx +183 -0
  1295. package/packages/react/src/combobox/clear/ComboboxClearDataAttributes.ts +27 -0
  1296. package/packages/react/src/combobox/collection/ComboboxCollection.test.tsx +35 -0
  1297. package/packages/react/src/combobox/collection/ComboboxCollection.tsx +38 -0
  1298. package/packages/react/src/combobox/collection/GroupCollectionContext.tsx +31 -0
  1299. package/packages/react/src/combobox/empty/ComboboxEmpty.test.tsx +214 -0
  1300. package/packages/react/src/combobox/empty/ComboboxEmpty.tsx +56 -0
  1301. package/packages/react/src/combobox/group/ComboboxGroup.test.tsx +54 -0
  1302. package/packages/react/src/combobox/group/ComboboxGroup.tsx +66 -0
  1303. package/packages/react/src/combobox/group/ComboboxGroupContext.ts +26 -0
  1304. package/packages/react/src/combobox/group-label/ComboboxGroupLabel.test.tsx +60 -0
  1305. package/packages/react/src/combobox/group-label/ComboboxGroupLabel.tsx +50 -0
  1306. package/packages/react/src/combobox/icon/ComboboxIcon.test.tsx +13 -0
  1307. package/packages/react/src/combobox/icon/ComboboxIcon.tsx +39 -0
  1308. package/packages/react/src/combobox/index.parts.ts +30 -0
  1309. package/packages/react/src/combobox/index.ts +32 -0
  1310. package/packages/react/src/combobox/input/ComboboxInput.test.tsx +682 -0
  1311. package/packages/react/src/combobox/input/ComboboxInput.tsx +552 -0
  1312. package/packages/react/src/combobox/input/ComboboxInputDataAttributes.ts +57 -0
  1313. package/packages/react/src/combobox/input-group/ComboboxInputGroup.test.tsx +206 -0
  1314. package/packages/react/src/combobox/input-group/ComboboxInputGroup.tsx +116 -0
  1315. package/packages/react/src/combobox/input-group/ComboboxInputGroupDataAttributes.ts +55 -0
  1316. package/packages/react/src/combobox/item/ComboboxItem.test.tsx +519 -0
  1317. package/packages/react/src/combobox/item/ComboboxItem.tsx +328 -0
  1318. package/packages/react/src/combobox/item/ComboboxItemContext.ts +19 -0
  1319. package/packages/react/src/combobox/item/ComboboxItemDataAttributes.ts +14 -0
  1320. package/packages/react/src/combobox/item-indicator/ComboboxItemIndicator.test.tsx +17 -0
  1321. package/packages/react/src/combobox/item-indicator/ComboboxItemIndicator.tsx +107 -0
  1322. package/packages/react/src/combobox/item-indicator/ComboboxItemIndicatorDataAttributes.ts +12 -0
  1323. package/packages/react/src/combobox/label/ComboboxLabel.test.tsx +25 -0
  1324. package/packages/react/src/combobox/label/ComboboxLabel.tsx +83 -0
  1325. package/packages/react/src/combobox/list/ComboboxList.test.tsx +34 -0
  1326. package/packages/react/src/combobox/list/ComboboxList.tsx +149 -0
  1327. package/packages/react/src/combobox/popup/ComboboxPopup.test.tsx +74 -0
  1328. package/packages/react/src/combobox/popup/ComboboxPopup.tsx +214 -0
  1329. package/packages/react/src/combobox/popup/ComboboxPopupDataAttributes.ts +39 -0
  1330. package/packages/react/src/combobox/portal/ComboboxPortal.test.tsx +14 -0
  1331. package/packages/react/src/combobox/portal/ComboboxPortal.tsx +52 -0
  1332. package/packages/react/src/combobox/portal/ComboboxPortalContext.tsx +12 -0
  1333. package/packages/react/src/combobox/positioner/ComboboxPositioner.test.tsx +144 -0
  1334. package/packages/react/src/combobox/positioner/ComboboxPositioner.tsx +171 -0
  1335. package/packages/react/src/combobox/positioner/ComboboxPositionerContext.tsx +30 -0
  1336. package/packages/react/src/combobox/positioner/ComboboxPositionerCssVars.ts +27 -0
  1337. package/packages/react/src/combobox/positioner/ComboboxPositionerDataAttributes.ts +30 -0
  1338. package/packages/react/src/combobox/root/AriaCombobox.tsx +1687 -0
  1339. package/packages/react/src/combobox/root/ComboboxRoot.spec.tsx +279 -0
  1340. package/packages/react/src/combobox/root/ComboboxRoot.test.tsx +7788 -0
  1341. package/packages/react/src/combobox/root/ComboboxRoot.tsx +176 -0
  1342. package/packages/react/src/combobox/root/ComboboxRootContext.tsx +62 -0
  1343. package/packages/react/src/combobox/root/utils/constants.ts +5 -0
  1344. package/packages/react/src/combobox/root/utils/index.ts +65 -0
  1345. package/packages/react/src/combobox/root/utils/useFilter.ts +55 -0
  1346. package/packages/react/src/combobox/root/utils/useFilteredItems.ts +9 -0
  1347. package/packages/react/src/combobox/row/ComboboxRow.tsx +35 -0
  1348. package/packages/react/src/combobox/row/ComboboxRowContext.ts +8 -0
  1349. package/packages/react/src/combobox/status/ComboboxStatus.iOS.test.tsx +49 -0
  1350. package/packages/react/src/combobox/status/ComboboxStatus.test.tsx +124 -0
  1351. package/packages/react/src/combobox/status/ComboboxStatus.tsx +47 -0
  1352. package/packages/react/src/combobox/store.ts +180 -0
  1353. package/packages/react/src/combobox/trigger/ComboboxTrigger.test.tsx +785 -0
  1354. package/packages/react/src/combobox/trigger/ComboboxTrigger.tsx +327 -0
  1355. package/packages/react/src/combobox/trigger/ComboboxTriggerDataAttributes.ts +61 -0
  1356. package/packages/react/src/combobox/utils/ComboboxInternalDismissButton.tsx +46 -0
  1357. package/packages/react/src/combobox/utils/handleInputPress.ts +39 -0
  1358. package/packages/react/src/combobox/utils/stateAttributesMapping.ts +17 -0
  1359. package/packages/react/src/combobox/utils/useInitialLiveRegionTextMutation.ts +65 -0
  1360. package/packages/react/src/combobox/value/ComboboxValue.test.tsx +900 -0
  1361. package/packages/react/src/combobox/value/ComboboxValue.tsx +58 -0
  1362. package/packages/react/src/context-menu/index.parts.ts +21 -0
  1363. package/packages/react/src/context-menu/index.ts +69 -0
  1364. package/packages/react/src/context-menu/root/ContextMenuRoot.non-mac.test.tsx +76 -0
  1365. package/packages/react/src/context-menu/root/ContextMenuRoot.test.tsx +283 -0
  1366. package/packages/react/src/context-menu/root/ContextMenuRoot.tsx +80 -0
  1367. package/packages/react/src/context-menu/root/ContextMenuRootContext.ts +33 -0
  1368. package/packages/react/src/context-menu/trigger/ContextMenuTrigger.test.tsx +343 -0
  1369. package/packages/react/src/context-menu/trigger/ContextMenuTrigger.tsx +218 -0
  1370. package/packages/react/src/context-menu/trigger/ContextMenuTriggerDataAttributes.ts +12 -0
  1371. package/packages/react/src/csp-provider/CSPProvider.test.tsx +76 -0
  1372. package/packages/react/src/csp-provider/CSPProvider.tsx +43 -0
  1373. package/packages/react/src/csp-provider/index.parts.ts +1 -0
  1374. package/packages/react/src/csp-provider/index.ts +3 -0
  1375. package/packages/react/src/dialog/backdrop/DialogBackdrop.test.tsx +149 -0
  1376. package/packages/react/src/dialog/backdrop/DialogBackdrop.tsx +81 -0
  1377. package/packages/react/src/dialog/backdrop/DialogBackdropDataAttributes.ts +20 -0
  1378. package/packages/react/src/dialog/close/DialogClose.test.tsx +117 -0
  1379. package/packages/react/src/dialog/close/DialogClose.tsx +65 -0
  1380. package/packages/react/src/dialog/close/DialogCloseDataAttributes.ts +6 -0
  1381. package/packages/react/src/dialog/description/DialogDescription.test.tsx +19 -0
  1382. package/packages/react/src/dialog/description/DialogDescription.tsx +39 -0
  1383. package/packages/react/src/dialog/index.parts.ts +10 -0
  1384. package/packages/react/src/dialog/index.ts +11 -0
  1385. package/packages/react/src/dialog/popup/DialogPopup.test.tsx +987 -0
  1386. package/packages/react/src/dialog/popup/DialogPopup.tsx +181 -0
  1387. package/packages/react/src/dialog/popup/DialogPopupCssVars.ts +7 -0
  1388. package/packages/react/src/dialog/popup/DialogPopupDataAttributes.ts +28 -0
  1389. package/packages/react/src/dialog/portal/DialogPortal.test.tsx +56 -0
  1390. package/packages/react/src/dialog/portal/DialogPortal.tsx +61 -0
  1391. package/packages/react/src/dialog/portal/DialogPortalContext.ts +12 -0
  1392. package/packages/react/src/dialog/root/DialogRoot.detached-triggers.test.tsx +791 -0
  1393. package/packages/react/src/dialog/root/DialogRoot.spec.tsx +28 -0
  1394. package/packages/react/src/dialog/root/DialogRoot.test.tsx +1718 -0
  1395. package/packages/react/src/dialog/root/DialogRoot.tsx +116 -0
  1396. package/packages/react/src/dialog/root/DialogRootContext.ts +25 -0
  1397. package/packages/react/src/dialog/root/useDialogRoot.ts +152 -0
  1398. package/packages/react/src/dialog/root/useRenderDialogRoot.tsx +93 -0
  1399. package/packages/react/src/dialog/store/DialogHandle.ts +83 -0
  1400. package/packages/react/src/dialog/store/DialogStore.ts +145 -0
  1401. package/packages/react/src/dialog/title/DialogTitle.test.tsx +19 -0
  1402. package/packages/react/src/dialog/title/DialogTitle.tsx +39 -0
  1403. package/packages/react/src/dialog/trigger/DialogTrigger.test.tsx +72 -0
  1404. package/packages/react/src/dialog/trigger/DialogTrigger.tsx +140 -0
  1405. package/packages/react/src/dialog/trigger/DialogTriggerDataAttributes.ts +12 -0
  1406. package/packages/react/src/dialog/viewport/DialogViewport.test.tsx +66 -0
  1407. package/packages/react/src/dialog/viewport/DialogViewport.tsx +101 -0
  1408. package/packages/react/src/dialog/viewport/DialogViewportDataAttributes.ts +28 -0
  1409. package/packages/react/src/direction-provider/DirectionProvider.spec.tsx +28 -0
  1410. package/packages/react/src/direction-provider/DirectionProvider.test.tsx +42 -0
  1411. package/packages/react/src/direction-provider/DirectionProvider.tsx +37 -0
  1412. package/packages/react/src/direction-provider/index.parts.ts +5 -0
  1413. package/packages/react/src/direction-provider/index.ts +2 -0
  1414. package/packages/react/src/drawer/backdrop/DrawerBackdrop.tsx +86 -0
  1415. package/packages/react/src/drawer/backdrop/DrawerBackdropCssVars.ts +7 -0
  1416. package/packages/react/src/drawer/backdrop/DrawerBackdropDataAttributes.ts +20 -0
  1417. package/packages/react/src/drawer/close/DrawerClose.tsx +31 -0
  1418. package/packages/react/src/drawer/content/DrawerContent.test.tsx +40 -0
  1419. package/packages/react/src/drawer/content/DrawerContent.tsx +35 -0
  1420. package/packages/react/src/drawer/content/DrawerContentDataAttributes.ts +1 -0
  1421. package/packages/react/src/drawer/description/DrawerDescription.tsx +25 -0
  1422. package/packages/react/src/drawer/indent/DrawerIndent.test.tsx +40 -0
  1423. package/packages/react/src/drawer/indent/DrawerIndent.tsx +102 -0
  1424. package/packages/react/src/drawer/indent-background/DrawerIndentBackground.test.tsx +39 -0
  1425. package/packages/react/src/drawer/indent-background/DrawerIndentBackground.tsx +59 -0
  1426. package/packages/react/src/drawer/index.parts.ts +19 -0
  1427. package/packages/react/src/drawer/index.ts +17 -0
  1428. package/packages/react/src/drawer/popup/DrawerPopup.test.tsx +586 -0
  1429. package/packages/react/src/drawer/popup/DrawerPopup.tsx +481 -0
  1430. package/packages/react/src/drawer/popup/DrawerPopupCssVars.ts +37 -0
  1431. package/packages/react/src/drawer/popup/DrawerPopupDataAttributes.ts +45 -0
  1432. package/packages/react/src/drawer/portal/DrawerPortal.tsx +38 -0
  1433. package/packages/react/src/drawer/provider/DrawerProvider.tsx +129 -0
  1434. package/packages/react/src/drawer/provider/DrawerProviderContext.ts +36 -0
  1435. package/packages/react/src/drawer/root/DrawerRoot.spec.tsx +39 -0
  1436. package/packages/react/src/drawer/root/DrawerRoot.test.tsx +1263 -0
  1437. package/packages/react/src/drawer/root/DrawerRoot.tsx +483 -0
  1438. package/packages/react/src/drawer/root/DrawerRootContext.ts +111 -0
  1439. package/packages/react/src/drawer/root/useDrawerSnapPoints.test.ts +18 -0
  1440. package/packages/react/src/drawer/root/useDrawerSnapPoints.ts +205 -0
  1441. package/packages/react/src/drawer/swipe-area/DrawerSwipeArea.test.tsx +522 -0
  1442. package/packages/react/src/drawer/swipe-area/DrawerSwipeArea.tsx +488 -0
  1443. package/packages/react/src/drawer/swipe-area/DrawerSwipeAreaDataAttributes.ts +25 -0
  1444. package/packages/react/src/drawer/title/DrawerTitle.tsx +25 -0
  1445. package/packages/react/src/drawer/trigger/DrawerTrigger.tsx +53 -0
  1446. package/packages/react/src/drawer/viewport/DrawerViewport.test.tsx +2524 -0
  1447. package/packages/react/src/drawer/viewport/DrawerViewport.tsx +1405 -0
  1448. package/packages/react/src/drawer/viewport/DrawerViewportContext.tsx +25 -0
  1449. package/packages/react/src/drawer/viewport/DrawerViewportCssVars.ts +8 -0
  1450. package/packages/react/src/drawer/viewport/DrawerViewportDataAttributes.ts +24 -0
  1451. package/packages/react/src/drawer/virtual-keyboard-provider/DrawerVirtualKeyboardContext.tsx +19 -0
  1452. package/packages/react/src/drawer/virtual-keyboard-provider/DrawerVirtualKeyboardProvider.test.tsx +2053 -0
  1453. package/packages/react/src/drawer/virtual-keyboard-provider/DrawerVirtualKeyboardProvider.tsx +644 -0
  1454. package/packages/react/src/field/control/FieldControl.spec.tsx +7 -0
  1455. package/packages/react/src/field/control/FieldControl.test.tsx +104 -0
  1456. package/packages/react/src/field/control/FieldControl.tsx +179 -0
  1457. package/packages/react/src/field/control/FieldControlDataAttributes.ts +30 -0
  1458. package/packages/react/src/field/description/FieldDescription.test.tsx +54 -0
  1459. package/packages/react/src/field/description/FieldDescription.tsx +65 -0
  1460. package/packages/react/src/field/description/FieldDescriptionDataAttributes.ts +30 -0
  1461. package/packages/react/src/field/error/FieldError.test.tsx +393 -0
  1462. package/packages/react/src/field/error/FieldError.tsx +158 -0
  1463. package/packages/react/src/field/error/FieldErrorDataAttributes.ts +40 -0
  1464. package/packages/react/src/field/index.parts.ts +9 -0
  1465. package/packages/react/src/field/index.ts +9 -0
  1466. package/packages/react/src/field/item/FieldItem.test.tsx +84 -0
  1467. package/packages/react/src/field/item/FieldItem.tsx +69 -0
  1468. package/packages/react/src/field/item/FieldItemContext.ts +14 -0
  1469. package/packages/react/src/field/item/FieldItemDataAttributes.ts +30 -0
  1470. package/packages/react/src/field/label/FieldLabel.test.tsx +128 -0
  1471. package/packages/react/src/field/label/FieldLabel.tsx +104 -0
  1472. package/packages/react/src/field/label/FieldLabelDataAttributes.ts +30 -0
  1473. package/packages/react/src/field/root/FieldRoot.test.tsx +1688 -0
  1474. package/packages/react/src/field/root/FieldRoot.tsx +344 -0
  1475. package/packages/react/src/field/root/FieldRootDataAttributes.ts +30 -0
  1476. package/packages/react/src/field/root/useFieldValidation.ts +363 -0
  1477. package/packages/react/src/field/utils/getCombinedFieldValidityData.ts +18 -0
  1478. package/packages/react/src/field/validity/FieldValidity.test.tsx +104 -0
  1479. package/packages/react/src/field/validity/FieldValidity.tsx +66 -0
  1480. package/packages/react/src/fieldset/index.parts.ts +2 -0
  1481. package/packages/react/src/fieldset/index.ts +4 -0
  1482. package/packages/react/src/fieldset/legend/FieldsetLegend.test.tsx +79 -0
  1483. package/packages/react/src/fieldset/legend/FieldsetLegend.tsx +57 -0
  1484. package/packages/react/src/fieldset/root/FieldsetRoot.test.tsx +66 -0
  1485. package/packages/react/src/fieldset/root/FieldsetRoot.tsx +72 -0
  1486. package/packages/react/src/fieldset/root/FieldsetRootContext.ts +22 -0
  1487. package/packages/react/src/floating-ui-react/components/FloatingDelayGroup.test.tsx +344 -0
  1488. package/packages/react/src/floating-ui-react/components/FloatingDelayGroup.tsx +286 -0
  1489. package/packages/react/src/floating-ui-react/components/FloatingFocusManager.test.tsx +2325 -0
  1490. package/packages/react/src/floating-ui-react/components/FloatingFocusManager.tsx +991 -0
  1491. package/packages/react/src/floating-ui-react/components/FloatingPortal.test.tsx +153 -0
  1492. package/packages/react/src/floating-ui-react/components/FloatingPortal.tsx +307 -0
  1493. package/packages/react/src/floating-ui-react/components/FloatingRootStore.ts +140 -0
  1494. package/packages/react/src/floating-ui-react/components/FloatingTree.tsx +95 -0
  1495. package/packages/react/src/floating-ui-react/components/FloatingTreeStore.ts +23 -0
  1496. package/packages/react/src/floating-ui-react/hooks/gridNavigation.ts +50 -0
  1497. package/packages/react/src/floating-ui-react/hooks/useClick.test.tsx +298 -0
  1498. package/packages/react/src/floating-ui-react/hooks/useClick.ts +226 -0
  1499. package/packages/react/src/floating-ui-react/hooks/useClientPoint.test.tsx +505 -0
  1500. package/packages/react/src/floating-ui-react/hooks/useClientPoint.ts +260 -0
  1501. package/packages/react/src/floating-ui-react/hooks/useDismiss.test.tsx +1217 -0
  1502. package/packages/react/src/floating-ui-react/hooks/useDismiss.ts +754 -0
  1503. package/packages/react/src/floating-ui-react/hooks/useFloating.test.tsx +42 -0
  1504. package/packages/react/src/floating-ui-react/hooks/useFloating.ts +184 -0
  1505. package/packages/react/src/floating-ui-react/hooks/useFloatingRootContext.ts +80 -0
  1506. package/packages/react/src/floating-ui-react/hooks/useFocus.ts +250 -0
  1507. package/packages/react/src/floating-ui-react/hooks/useHover.test.tsx +369 -0
  1508. package/packages/react/src/floating-ui-react/hooks/useHover.ts +467 -0
  1509. package/packages/react/src/floating-ui-react/hooks/useHoverFloatingInteraction.ts +273 -0
  1510. package/packages/react/src/floating-ui-react/hooks/useHoverInteractionSharedState.ts +131 -0
  1511. package/packages/react/src/floating-ui-react/hooks/useHoverReferenceInteraction.test.tsx +350 -0
  1512. package/packages/react/src/floating-ui-react/hooks/useHoverReferenceInteraction.ts +481 -0
  1513. package/packages/react/src/floating-ui-react/hooks/useHoverShared.ts +72 -0
  1514. package/packages/react/src/floating-ui-react/hooks/useListNavigation.test.tsx +1528 -0
  1515. package/packages/react/src/floating-ui-react/hooks/useListNavigation.ts +930 -0
  1516. package/packages/react/src/floating-ui-react/hooks/useSyncedFloatingRootContext.ts +101 -0
  1517. package/packages/react/src/floating-ui-react/hooks/useTypeahead.test.tsx +343 -0
  1518. package/packages/react/src/floating-ui-react/hooks/useTypeahead.ts +253 -0
  1519. package/packages/react/src/floating-ui-react/index.ts +41 -0
  1520. package/packages/react/src/floating-ui-react/middleware/arrow.ts +123 -0
  1521. package/packages/react/src/floating-ui-react/safePolygon.test.ts +340 -0
  1522. package/packages/react/src/floating-ui-react/safePolygon.ts +451 -0
  1523. package/packages/react/src/floating-ui-react/types.ts +202 -0
  1524. package/packages/react/src/floating-ui-react/utils/composite.test.ts +45 -0
  1525. package/packages/react/src/floating-ui-react/utils/composite.ts +518 -0
  1526. package/packages/react/src/floating-ui-react/utils/constants.ts +10 -0
  1527. package/packages/react/src/floating-ui-react/utils/createAttribute.ts +3 -0
  1528. package/packages/react/src/floating-ui-react/utils/createEventEmitter.ts +19 -0
  1529. package/packages/react/src/floating-ui-react/utils/element.ts +95 -0
  1530. package/packages/react/src/floating-ui-react/utils/enqueueFocus.ts +37 -0
  1531. package/packages/react/src/floating-ui-react/utils/event.ts +59 -0
  1532. package/packages/react/src/floating-ui-react/utils/getEmptyRootContext.ts +17 -0
  1533. package/packages/react/src/floating-ui-react/utils/markOthers.test.ts +310 -0
  1534. package/packages/react/src/floating-ui-react/utils/markOthers.ts +219 -0
  1535. package/packages/react/src/floating-ui-react/utils/nodes.test.ts +115 -0
  1536. package/packages/react/src/floating-ui-react/utils/nodes.ts +54 -0
  1537. package/packages/react/src/floating-ui-react/utils/tabbable.test.ts +378 -0
  1538. package/packages/react/src/floating-ui-react/utils/tabbable.ts +282 -0
  1539. package/packages/react/src/floating-ui-react/utils.ts +5 -0
  1540. package/packages/react/src/form/Form.spec.tsx +17 -0
  1541. package/packages/react/src/form/Form.test.tsx +752 -0
  1542. package/packages/react/src/form/Form.tsx +229 -0
  1543. package/packages/react/src/form/index.ts +3 -0
  1544. package/packages/react/src/global.d.ts +9 -0
  1545. package/packages/react/src/index.test.ts +60 -0
  1546. package/packages/react/src/index.ts +44 -0
  1547. package/packages/react/src/input/Input.spec.tsx +7 -0
  1548. package/packages/react/src/input/Input.test.tsx +12 -0
  1549. package/packages/react/src/input/Input.tsx +44 -0
  1550. package/packages/react/src/input/InputDataAttributes.ts +30 -0
  1551. package/packages/react/src/input/index.ts +3 -0
  1552. package/packages/react/src/internals/RequestQueue.test.ts +152 -0
  1553. package/packages/react/src/internals/RequestQueue.ts +126 -0
  1554. package/packages/react/src/internals/TimeoutManager.test.ts +76 -0
  1555. package/packages/react/src/internals/TimeoutManager.ts +29 -0
  1556. package/packages/react/src/internals/areArraysEqual.ts +12 -0
  1557. package/packages/react/src/internals/clamp.test.ts +10 -0
  1558. package/packages/react/src/internals/clamp.ts +7 -0
  1559. package/packages/react/src/internals/composite/composite.ts +182 -0
  1560. package/packages/react/src/internals/composite/constants.ts +1 -0
  1561. package/packages/react/src/internals/composite/index.ts +18 -0
  1562. package/packages/react/src/internals/composite/item/CompositeItem.tsx +59 -0
  1563. package/packages/react/src/internals/composite/item/useCompositeItem.ts +49 -0
  1564. package/packages/react/src/internals/composite/list/CompositeList.test.tsx +37 -0
  1565. package/packages/react/src/internals/composite/list/CompositeList.tsx +195 -0
  1566. package/packages/react/src/internals/composite/list/CompositeListContext.ts +25 -0
  1567. package/packages/react/src/internals/composite/list/useCompositeListItem.ts +103 -0
  1568. package/packages/react/src/internals/composite/root/CompositeRoot.test.tsx +1018 -0
  1569. package/packages/react/src/internals/composite/root/CompositeRoot.tsx +141 -0
  1570. package/packages/react/src/internals/composite/root/CompositeRootContext.ts +32 -0
  1571. package/packages/react/src/internals/composite/root/gridNavigation.ts +127 -0
  1572. package/packages/react/src/internals/composite/root/useCompositeRoot.ts +355 -0
  1573. package/packages/react/src/internals/constants.ts +41 -0
  1574. package/packages/react/src/internals/createBaseUIEventDetails.spec.ts +12 -0
  1575. package/packages/react/src/internals/createBaseUIEventDetails.ts +166 -0
  1576. package/packages/react/src/internals/csp-context/CSPContext.tsx +23 -0
  1577. package/packages/react/src/internals/csp-context/index.ts +2 -0
  1578. package/packages/react/src/internals/direction-context/DirectionContext.tsx +19 -0
  1579. package/packages/react/src/internals/direction-context/index.ts +2 -0
  1580. package/packages/react/src/internals/field-constants/constants.ts +48 -0
  1581. package/packages/react/src/internals/field-constants/index.ts +6 -0
  1582. package/packages/react/src/internals/field-register-control/index.ts +6 -0
  1583. package/packages/react/src/internals/field-register-control/useFieldControlRegistration.ts +169 -0
  1584. package/packages/react/src/internals/field-register-control/useRegisterFieldControl.ts +43 -0
  1585. package/packages/react/src/internals/field-root-context/FieldRootContext.ts +94 -0
  1586. package/packages/react/src/internals/field-root-context/index.ts +2 -0
  1587. package/packages/react/src/internals/filter.test.ts +11 -0
  1588. package/packages/react/src/internals/filter.ts +82 -0
  1589. package/packages/react/src/internals/form-context/FormContext.ts +48 -0
  1590. package/packages/react/src/internals/form-context/index.ts +2 -0
  1591. package/packages/react/src/internals/getStateAttributesProps.test.ts +83 -0
  1592. package/packages/react/src/internals/getStateAttributesProps.ts +32 -0
  1593. package/packages/react/src/internals/itemEquality.ts +60 -0
  1594. package/packages/react/src/internals/labelable-provider/LabelableContext.ts +42 -0
  1595. package/packages/react/src/internals/labelable-provider/LabelableProvider.tsx +116 -0
  1596. package/packages/react/src/internals/labelable-provider/index.ts +6 -0
  1597. package/packages/react/src/internals/labelable-provider/useAriaLabelledBy.ts +75 -0
  1598. package/packages/react/src/internals/labelable-provider/useLabel.ts +111 -0
  1599. package/packages/react/src/internals/labelable-provider/useLabelableId.ts +100 -0
  1600. package/packages/react/src/internals/noop.ts +1 -0
  1601. package/packages/react/src/internals/reason-parts.ts +42 -0
  1602. package/packages/react/src/internals/reasons.ts +5 -0
  1603. package/packages/react/src/internals/resolveValueLabel.test.ts +101 -0
  1604. package/packages/react/src/internals/resolveValueLabel.tsx +151 -0
  1605. package/packages/react/src/internals/serializeValue.ts +13 -0
  1606. package/packages/react/src/internals/shadowDom.ts +47 -0
  1607. package/packages/react/src/internals/stateAttributesMapping.ts +28 -0
  1608. package/packages/react/src/internals/temporal/index.ts +2 -0
  1609. package/packages/react/src/internals/temporal/temporal-adapter.ts +382 -0
  1610. package/packages/react/src/internals/temporal/temporal.ts +49 -0
  1611. package/packages/react/src/internals/temporal-adapter-date-fns/TemporalAdapterDateFns.test.ts +63 -0
  1612. package/packages/react/src/internals/temporal-adapter-date-fns/TemporalAdapterDateFns.ts +474 -0
  1613. package/packages/react/src/internals/temporal-adapter-date-fns/index.ts +1 -0
  1614. package/packages/react/src/internals/temporal-adapter-luxon/TemporalAdapterLuxon.test.ts +16 -0
  1615. package/packages/react/src/internals/temporal-adapter-luxon/TemporalAdapterLuxon.ts +380 -0
  1616. package/packages/react/src/internals/temporal-adapter-luxon/index.ts +1 -0
  1617. package/packages/react/src/internals/types.ts +97 -0
  1618. package/packages/react/src/internals/use-button/index.ts +1 -0
  1619. package/packages/react/src/internals/use-button/useButton.test.tsx +820 -0
  1620. package/packages/react/src/internals/use-button/useButton.ts +290 -0
  1621. package/packages/react/src/internals/useAnimationsFinished.ts +121 -0
  1622. package/packages/react/src/internals/useBaseUiId.ts +11 -0
  1623. package/packages/react/src/internals/useOpenChangeComplete.tsx +50 -0
  1624. package/packages/react/src/internals/usePressAndHold.ts +288 -0
  1625. package/packages/react/src/internals/useRenderElement.spec.tsx +38 -0
  1626. package/packages/react/src/internals/useRenderElement.test.tsx +588 -0
  1627. package/packages/react/src/internals/useRenderElement.tsx +287 -0
  1628. package/packages/react/src/internals/useTransitionStatus.ts +89 -0
  1629. package/packages/react/src/internals/useValueChanged.ts +21 -0
  1630. package/packages/react/src/menu/arrow/MenuArrow.test.tsx +21 -0
  1631. package/packages/react/src/menu/arrow/MenuArrow.tsx +69 -0
  1632. package/packages/react/src/menu/arrow/MenuArrowDataAttributes.ts +26 -0
  1633. package/packages/react/src/menu/backdrop/MenuBackdrop.test.tsx +55 -0
  1634. package/packages/react/src/menu/backdrop/MenuBackdrop.tsx +80 -0
  1635. package/packages/react/src/menu/backdrop/MenuBackdropDataAttributes.ts +20 -0
  1636. package/packages/react/src/menu/checkbox-item/MenuCheckboxItem.test.tsx +452 -0
  1637. package/packages/react/src/menu/checkbox-item/MenuCheckboxItem.tsx +180 -0
  1638. package/packages/react/src/menu/checkbox-item/MenuCheckboxItemContext.ts +23 -0
  1639. package/packages/react/src/menu/checkbox-item/MenuCheckboxItemDataAttributes.ts +18 -0
  1640. package/packages/react/src/menu/checkbox-item-indicator/MenuCheckboxItemIndicator.test.tsx +131 -0
  1641. package/packages/react/src/menu/checkbox-item-indicator/MenuCheckboxItemIndicator.tsx +92 -0
  1642. package/packages/react/src/menu/checkbox-item-indicator/MenuCheckboxItemIndicatorDataAttributes.ts +24 -0
  1643. package/packages/react/src/menu/group/MenuGroup.test.tsx +18 -0
  1644. package/packages/react/src/menu/group/MenuGroup.tsx +45 -0
  1645. package/packages/react/src/menu/group/MenuGroupContext.ts +17 -0
  1646. package/packages/react/src/menu/group-label/MenuGroupLabel.test.tsx +142 -0
  1647. package/packages/react/src/menu/group-label/MenuGroupLabel.tsx +49 -0
  1648. package/packages/react/src/menu/index.parts.ts +21 -0
  1649. package/packages/react/src/menu/index.ts +21 -0
  1650. package/packages/react/src/menu/item/MenuItem.test.tsx +257 -0
  1651. package/packages/react/src/menu/item/MenuItem.tsx +105 -0
  1652. package/packages/react/src/menu/item/MenuItemDataAttributes.ts +10 -0
  1653. package/packages/react/src/menu/item/useMenuItem.ts +144 -0
  1654. package/packages/react/src/menu/item/useMenuItemCommonProps.ts +136 -0
  1655. package/packages/react/src/menu/link-item/MenuLinkItem.test.tsx +167 -0
  1656. package/packages/react/src/menu/link-item/MenuLinkItem.tsx +100 -0
  1657. package/packages/react/src/menu/link-item/MenuLinkItemDataAttributes.ts +6 -0
  1658. package/packages/react/src/menu/popup/MenuPopup.test.tsx +214 -0
  1659. package/packages/react/src/menu/popup/MenuPopup.tsx +210 -0
  1660. package/packages/react/src/menu/popup/MenuPopupDataAttributes.ts +35 -0
  1661. package/packages/react/src/menu/portal/MenuPortal.test.tsx +14 -0
  1662. package/packages/react/src/menu/portal/MenuPortal.tsx +48 -0
  1663. package/packages/react/src/menu/portal/MenuPortalContext.ts +12 -0
  1664. package/packages/react/src/menu/positioner/MenuPositioner.spec.tsx +4 -0
  1665. package/packages/react/src/menu/positioner/MenuPositioner.test.tsx +662 -0
  1666. package/packages/react/src/menu/positioner/MenuPositioner.tsx +355 -0
  1667. package/packages/react/src/menu/positioner/MenuPositionerContext.ts +24 -0
  1668. package/packages/react/src/menu/positioner/MenuPositionerCssVars.ts +27 -0
  1669. package/packages/react/src/menu/positioner/MenuPositionerDataAttributes.ts +26 -0
  1670. package/packages/react/src/menu/radio-group/MenuRadioGroup.test.tsx +18 -0
  1671. package/packages/react/src/menu/radio-group/MenuRadioGroup.tsx +130 -0
  1672. package/packages/react/src/menu/radio-group/MenuRadioGroupContext.ts +24 -0
  1673. package/packages/react/src/menu/radio-item/MenuRadioItem.test.tsx +528 -0
  1674. package/packages/react/src/menu/radio-item/MenuRadioItem.tsx +152 -0
  1675. package/packages/react/src/menu/radio-item/MenuRadioItemContext.ts +23 -0
  1676. package/packages/react/src/menu/radio-item/MenuRadioItemDataAttributes.ts +18 -0
  1677. package/packages/react/src/menu/radio-item-indicator/MenuRadioItemIndicator.test.tsx +141 -0
  1678. package/packages/react/src/menu/radio-item-indicator/MenuRadioItemIndicator.tsx +92 -0
  1679. package/packages/react/src/menu/radio-item-indicator/MenuRadioItemIndicatorDataAttributes.ts +24 -0
  1680. package/packages/react/src/menu/root/MenuRoot.detached-triggers.test.tsx +1126 -0
  1681. package/packages/react/src/menu/root/MenuRoot.test.tsx +2761 -0
  1682. package/packages/react/src/menu/root/MenuRoot.tsx +684 -0
  1683. package/packages/react/src/menu/root/MenuRootContext.ts +24 -0
  1684. package/packages/react/src/menu/store/MenuHandle.ts +56 -0
  1685. package/packages/react/src/menu/store/MenuStore.ts +216 -0
  1686. package/packages/react/src/menu/submenu-root/MenuSubmenuRoot.tsx +65 -0
  1687. package/packages/react/src/menu/submenu-root/MenuSubmenuRootContext.ts +15 -0
  1688. package/packages/react/src/menu/submenu-trigger/MenuSubmenuTrigger.test.tsx +242 -0
  1689. package/packages/react/src/menu/submenu-trigger/MenuSubmenuTrigger.tsx +245 -0
  1690. package/packages/react/src/menu/submenu-trigger/MenuSubmenuTriggerDataAttributes.ts +16 -0
  1691. package/packages/react/src/menu/trigger/MenuTrigger.test.tsx +468 -0
  1692. package/packages/react/src/menu/trigger/MenuTrigger.tsx +417 -0
  1693. package/packages/react/src/menu/trigger/MenuTriggerDataAttributes.ts +12 -0
  1694. package/packages/react/src/menu/utils/findRootOwnerId.ts +13 -0
  1695. package/packages/react/src/menu/utils/stateAttributesMapping.ts +17 -0
  1696. package/packages/react/src/menu/utils/types.ts +8 -0
  1697. package/packages/react/src/menu/viewport/MenuViewport.test.tsx +410 -0
  1698. package/packages/react/src/menu/viewport/MenuViewport.tsx +85 -0
  1699. package/packages/react/src/menu/viewport/MenuViewportCssVars.ts +14 -0
  1700. package/packages/react/src/menu/viewport/MenuViewportDataAttributes.ts +26 -0
  1701. package/packages/react/src/menubar/Menubar.test.tsx +1342 -0
  1702. package/packages/react/src/menubar/Menubar.tsx +169 -0
  1703. package/packages/react/src/menubar/MenubarContext.ts +30 -0
  1704. package/packages/react/src/menubar/MenubarDataAttributes.ts +15 -0
  1705. package/packages/react/src/menubar/index.ts +3 -0
  1706. package/packages/react/src/merge-props/index.ts +1 -0
  1707. package/packages/react/src/merge-props/mergeProps.test.ts +599 -0
  1708. package/packages/react/src/merge-props/mergeProps.ts +296 -0
  1709. package/packages/react/src/meter/index.parts.ts +5 -0
  1710. package/packages/react/src/meter/index.ts +7 -0
  1711. package/packages/react/src/meter/indicator/MeterIndicator.test.tsx +89 -0
  1712. package/packages/react/src/meter/indicator/MeterIndicator.tsx +44 -0
  1713. package/packages/react/src/meter/label/MeterLabel.test.tsx +13 -0
  1714. package/packages/react/src/meter/label/MeterLabel.tsx +44 -0
  1715. package/packages/react/src/meter/root/MeterRoot.test.tsx +262 -0
  1716. package/packages/react/src/meter/root/MeterRoot.tsx +129 -0
  1717. package/packages/react/src/meter/root/MeterRootContext.ts +27 -0
  1718. package/packages/react/src/meter/track/MeterTrack.test.tsx +13 -0
  1719. package/packages/react/src/meter/track/MeterTrack.tsx +32 -0
  1720. package/packages/react/src/meter/value/MeterValue.test.tsx +87 -0
  1721. package/packages/react/src/meter/value/MeterValue.tsx +46 -0
  1722. package/packages/react/src/navigation-menu/arrow/NavigationMenuArrow.test.tsx +19 -0
  1723. package/packages/react/src/navigation-menu/arrow/NavigationMenuArrow.tsx +75 -0
  1724. package/packages/react/src/navigation-menu/arrow/NavigationMenuArrowDataAttributes.ts +26 -0
  1725. package/packages/react/src/navigation-menu/backdrop/NavigationMenuBackdrop.test.tsx +13 -0
  1726. package/packages/react/src/navigation-menu/backdrop/NavigationMenuBackdrop.tsx +74 -0
  1727. package/packages/react/src/navigation-menu/backdrop/NavigationMenuBackdropDataAttributes.ts +20 -0
  1728. package/packages/react/src/navigation-menu/content/NavigationMenuContent.test.tsx +221 -0
  1729. package/packages/react/src/navigation-menu/content/NavigationMenuContent.tsx +205 -0
  1730. package/packages/react/src/navigation-menu/content/NavigationMenuContentDataAttributes.ts +25 -0
  1731. package/packages/react/src/navigation-menu/icon/NavigationMenuIcon.test.tsx +17 -0
  1732. package/packages/react/src/navigation-menu/icon/NavigationMenuIcon.tsx +54 -0
  1733. package/packages/react/src/navigation-menu/icon/NavigationMenuIconDataAttributes.ts +8 -0
  1734. package/packages/react/src/navigation-menu/index.parts.ts +13 -0
  1735. package/packages/react/src/navigation-menu/index.ts +15 -0
  1736. package/packages/react/src/navigation-menu/item/NavigationMenuItem.test.tsx +13 -0
  1737. package/packages/react/src/navigation-menu/item/NavigationMenuItem.tsx +57 -0
  1738. package/packages/react/src/navigation-menu/item/NavigationMenuItemContext.ts +20 -0
  1739. package/packages/react/src/navigation-menu/link/NavigationMenuLink.test.tsx +133 -0
  1740. package/packages/react/src/navigation-menu/link/NavigationMenuLink.tsx +105 -0
  1741. package/packages/react/src/navigation-menu/link/NavigationMenuLinkDataAttributes.ts +6 -0
  1742. package/packages/react/src/navigation-menu/list/NavigationMenuDismissContext.ts +11 -0
  1743. package/packages/react/src/navigation-menu/list/NavigationMenuList.test.tsx +13 -0
  1744. package/packages/react/src/navigation-menu/list/NavigationMenuList.tsx +142 -0
  1745. package/packages/react/src/navigation-menu/popup/NavigationMenuPopup.test.tsx +19 -0
  1746. package/packages/react/src/navigation-menu/popup/NavigationMenuPopup.tsx +111 -0
  1747. package/packages/react/src/navigation-menu/popup/NavigationMenuPopupCssVars.ts +12 -0
  1748. package/packages/react/src/navigation-menu/popup/NavigationMenuPopupDataAttributes.ts +34 -0
  1749. package/packages/react/src/navigation-menu/portal/NavigationMenuPortal.test.tsx +14 -0
  1750. package/packages/react/src/navigation-menu/portal/NavigationMenuPortal.tsx +51 -0
  1751. package/packages/react/src/navigation-menu/portal/NavigationMenuPortalContext.ts +12 -0
  1752. package/packages/react/src/navigation-menu/positioner/NavigationMenuPositioner.test.tsx +17 -0
  1753. package/packages/react/src/navigation-menu/positioner/NavigationMenuPositioner.tsx +219 -0
  1754. package/packages/react/src/navigation-menu/positioner/NavigationMenuPositionerContext.ts +25 -0
  1755. package/packages/react/src/navigation-menu/positioner/NavigationMenuPositionerCssVars.ts +37 -0
  1756. package/packages/react/src/navigation-menu/positioner/NavigationMenuPositionerDataAttributes.ts +30 -0
  1757. package/packages/react/src/navigation-menu/root/NavigationMenuRoot.spec.tsx +63 -0
  1758. package/packages/react/src/navigation-menu/root/NavigationMenuRoot.test.tsx +3769 -0
  1759. package/packages/react/src/navigation-menu/root/NavigationMenuRoot.tsx +439 -0
  1760. package/packages/react/src/navigation-menu/root/NavigationMenuRoot.webkit.test.tsx +140 -0
  1761. package/packages/react/src/navigation-menu/root/NavigationMenuRootContext.ts +83 -0
  1762. package/packages/react/src/navigation-menu/trigger/NavigationMenuTrigger.test.tsx +448 -0
  1763. package/packages/react/src/navigation-menu/trigger/NavigationMenuTrigger.tsx +914 -0
  1764. package/packages/react/src/navigation-menu/trigger/NavigationMenuTriggerDataAttributes.ts +12 -0
  1765. package/packages/react/src/navigation-menu/utils/constants.ts +3 -0
  1766. package/packages/react/src/navigation-menu/utils/isOutsideMenuEvent.ts +41 -0
  1767. package/packages/react/src/navigation-menu/utils/setSharedFixedSize.ts +20 -0
  1768. package/packages/react/src/navigation-menu/viewport/NavigationMenuViewport.test.tsx +13 -0
  1769. package/packages/react/src/navigation-menu/viewport/NavigationMenuViewport.tsx +144 -0
  1770. package/packages/react/src/number-field/decrement/NumberFieldDecrement.test.tsx +572 -0
  1771. package/packages/react/src/number-field/decrement/NumberFieldDecrement.tsx +28 -0
  1772. package/packages/react/src/number-field/decrement/NumberFieldDecrementDataAttributes.ts +42 -0
  1773. package/packages/react/src/number-field/group/NumberFieldGroup.test.tsx +24 -0
  1774. package/packages/react/src/number-field/group/NumberFieldGroup.tsx +40 -0
  1775. package/packages/react/src/number-field/group/NumberFieldGroupDataAttributes.ts +42 -0
  1776. package/packages/react/src/number-field/increment/NumberFieldIncrement.test.tsx +829 -0
  1777. package/packages/react/src/number-field/increment/NumberFieldIncrement.tsx +28 -0
  1778. package/packages/react/src/number-field/increment/NumberFieldIncrementDataAttributes.ts +42 -0
  1779. package/packages/react/src/number-field/index.parts.ts +7 -0
  1780. package/packages/react/src/number-field/index.ts +9 -0
  1781. package/packages/react/src/number-field/input/NumberFieldInput.test.tsx +1408 -0
  1782. package/packages/react/src/number-field/input/NumberFieldInput.tsx +485 -0
  1783. package/packages/react/src/number-field/input/NumberFieldInputDataAttributes.ts +42 -0
  1784. package/packages/react/src/number-field/root/NumberFieldRoot.spec.tsx +74 -0
  1785. package/packages/react/src/number-field/root/NumberFieldRoot.test.tsx +2595 -0
  1786. package/packages/react/src/number-field/root/NumberFieldRoot.tsx +718 -0
  1787. package/packages/react/src/number-field/root/NumberFieldRootContext.ts +57 -0
  1788. package/packages/react/src/number-field/root/NumberFieldRootDataAttributes.ts +42 -0
  1789. package/packages/react/src/number-field/root/useNumberFieldButton.ts +175 -0
  1790. package/packages/react/src/number-field/root/useNumberFieldStepperButton.ts +91 -0
  1791. package/packages/react/src/number-field/scrub-area/NumberFieldScrubArea.test.tsx +351 -0
  1792. package/packages/react/src/number-field/scrub-area/NumberFieldScrubArea.tsx +393 -0
  1793. package/packages/react/src/number-field/scrub-area/NumberFieldScrubAreaContext.ts +23 -0
  1794. package/packages/react/src/number-field/scrub-area/NumberFieldScrubAreaDataAttributes.ts +42 -0
  1795. package/packages/react/src/number-field/scrub-area-cursor/NumberFieldScrubAreaCursor.test.tsx +203 -0
  1796. package/packages/react/src/number-field/scrub-area-cursor/NumberFieldScrubAreaCursor.tsx +71 -0
  1797. package/packages/react/src/number-field/scrub-area-cursor/NumberFieldScrubAreaCursorDataAttributes.ts +42 -0
  1798. package/packages/react/src/number-field/utils/constants.ts +3 -0
  1799. package/packages/react/src/number-field/utils/getViewportRect.ts +34 -0
  1800. package/packages/react/src/number-field/utils/parse.test.ts +298 -0
  1801. package/packages/react/src/number-field/utils/parse.ts +252 -0
  1802. package/packages/react/src/number-field/utils/stateAttributesMapping.ts +9 -0
  1803. package/packages/react/src/number-field/utils/subscribeToVisualViewportResize.ts +24 -0
  1804. package/packages/react/src/number-field/utils/types.ts +24 -0
  1805. package/packages/react/src/number-field/utils/validate.test.ts +730 -0
  1806. package/packages/react/src/number-field/utils/validate.ts +151 -0
  1807. package/packages/react/src/otp-field/index.parts.ts +3 -0
  1808. package/packages/react/src/otp-field/index.ts +4 -0
  1809. package/packages/react/src/otp-field/input/OTPFieldInput.spec.tsx +5 -0
  1810. package/packages/react/src/otp-field/input/OTPFieldInput.test.tsx +811 -0
  1811. package/packages/react/src/otp-field/input/OTPFieldInput.tsx +356 -0
  1812. package/packages/react/src/otp-field/input/OTPFieldInputDataAttributes.ts +42 -0
  1813. package/packages/react/src/otp-field/root/OTPFieldRoot.spec.tsx +113 -0
  1814. package/packages/react/src/otp-field/root/OTPFieldRoot.test.tsx +1407 -0
  1815. package/packages/react/src/otp-field/root/OTPFieldRoot.tsx +680 -0
  1816. package/packages/react/src/otp-field/root/OTPFieldRootContext.ts +57 -0
  1817. package/packages/react/src/otp-field/root/OTPFieldRootDataAttributes.ts +42 -0
  1818. package/packages/react/src/otp-field/utils/otp.test.ts +94 -0
  1819. package/packages/react/src/otp-field/utils/otp.ts +118 -0
  1820. package/packages/react/src/otp-field/utils/stateAttributesMapping.ts +16 -0
  1821. package/packages/react/src/popover/arrow/PopoverArrow.test.tsx +22 -0
  1822. package/packages/react/src/popover/arrow/PopoverArrow.tsx +67 -0
  1823. package/packages/react/src/popover/arrow/PopoverArrowDataAttributes.ts +26 -0
  1824. package/packages/react/src/popover/backdrop/PopoverBackdrop.test.tsx +55 -0
  1825. package/packages/react/src/popover/backdrop/PopoverBackdrop.tsx +78 -0
  1826. package/packages/react/src/popover/backdrop/PopoverBackdropDataAttributes.ts +20 -0
  1827. package/packages/react/src/popover/close/PopoverClose.test.tsx +159 -0
  1828. package/packages/react/src/popover/close/PopoverClose.tsx +63 -0
  1829. package/packages/react/src/popover/description/PopoverDescription.test.tsx +42 -0
  1830. package/packages/react/src/popover/description/PopoverDescription.tsx +44 -0
  1831. package/packages/react/src/popover/index.parts.ts +15 -0
  1832. package/packages/react/src/popover/index.ts +13 -0
  1833. package/packages/react/src/popover/popup/PopoverPopup.test.tsx +623 -0
  1834. package/packages/react/src/popover/popup/PopoverPopup.tsx +200 -0
  1835. package/packages/react/src/popover/popup/PopoverPopupCssVars.ts +10 -0
  1836. package/packages/react/src/popover/popup/PopoverPopupDataAttributes.ts +35 -0
  1837. package/packages/react/src/popover/portal/PopoverPortal.test.tsx +14 -0
  1838. package/packages/react/src/popover/portal/PopoverPortal.tsx +48 -0
  1839. package/packages/react/src/popover/portal/PopoverPortalContext.ts +12 -0
  1840. package/packages/react/src/popover/positioner/PopoverPositioner.spec.tsx +4 -0
  1841. package/packages/react/src/popover/positioner/PopoverPositioner.test.tsx +478 -0
  1842. package/packages/react/src/popover/positioner/PopoverPositioner.tsx +200 -0
  1843. package/packages/react/src/popover/positioner/PopoverPositionerContext.ts +27 -0
  1844. package/packages/react/src/popover/positioner/PopoverPositionerCssVars.ts +37 -0
  1845. package/packages/react/src/popover/positioner/PopoverPositionerDataAttributes.ts +26 -0
  1846. package/packages/react/src/popover/root/PopoverRoot.detached-triggers.test.tsx +961 -0
  1847. package/packages/react/src/popover/root/PopoverRoot.spec.tsx +27 -0
  1848. package/packages/react/src/popover/root/PopoverRoot.test.tsx +2347 -0
  1849. package/packages/react/src/popover/root/PopoverRoot.tsx +249 -0
  1850. package/packages/react/src/popover/root/PopoverRootContext.ts +21 -0
  1851. package/packages/react/src/popover/store/PopoverHandle.ts +64 -0
  1852. package/packages/react/src/popover/store/PopoverStore.ts +216 -0
  1853. package/packages/react/src/popover/title/PopoverTitle.test.tsx +42 -0
  1854. package/packages/react/src/popover/title/PopoverTitle.tsx +44 -0
  1855. package/packages/react/src/popover/trigger/PopoverTrigger.test.tsx +411 -0
  1856. package/packages/react/src/popover/trigger/PopoverTrigger.tsx +233 -0
  1857. package/packages/react/src/popover/trigger/PopoverTriggerDataAttributes.ts +12 -0
  1858. package/packages/react/src/popover/utils/constants.ts +1 -0
  1859. package/packages/react/src/popover/viewport/PopoverViewport.test.tsx +494 -0
  1860. package/packages/react/src/popover/viewport/PopoverViewport.tsx +85 -0
  1861. package/packages/react/src/popover/viewport/PopoverViewportCssVars.ts +14 -0
  1862. package/packages/react/src/popover/viewport/PopoverViewportDataAttributes.ts +26 -0
  1863. package/packages/react/src/preview-card/arrow/PreviewCardArrow.test.tsx +21 -0
  1864. package/packages/react/src/preview-card/arrow/PreviewCardArrow.tsx +68 -0
  1865. package/packages/react/src/preview-card/arrow/PreviewCardArrowDataAttributes.ts +26 -0
  1866. package/packages/react/src/preview-card/backdrop/PreviewCardBackdrop.test.tsx +37 -0
  1867. package/packages/react/src/preview-card/backdrop/PreviewCardBackdrop.tsx +78 -0
  1868. package/packages/react/src/preview-card/backdrop/PreviewCardBackdropDataAttributes.ts +20 -0
  1869. package/packages/react/src/preview-card/index.parts.ts +12 -0
  1870. package/packages/react/src/preview-card/index.ts +10 -0
  1871. package/packages/react/src/preview-card/popup/PreviewCardPopup.test.tsx +35 -0
  1872. package/packages/react/src/preview-card/popup/PreviewCardPopup.tsx +105 -0
  1873. package/packages/react/src/preview-card/popup/PreviewCardPopupDataAttributes.ts +30 -0
  1874. package/packages/react/src/preview-card/portal/PreviewCardPortal.test.tsx +14 -0
  1875. package/packages/react/src/preview-card/portal/PreviewCardPortal.tsx +48 -0
  1876. package/packages/react/src/preview-card/portal/PreviewCardPortalContext.ts +12 -0
  1877. package/packages/react/src/preview-card/positioner/PreviewCardPositioner.spec.tsx +4 -0
  1878. package/packages/react/src/preview-card/positioner/PreviewCardPositioner.test.tsx +1103 -0
  1879. package/packages/react/src/preview-card/positioner/PreviewCardPositioner.tsx +144 -0
  1880. package/packages/react/src/preview-card/positioner/PreviewCardPositionerContext.ts +23 -0
  1881. package/packages/react/src/preview-card/positioner/PreviewCardPositionerCssVars.ts +27 -0
  1882. package/packages/react/src/preview-card/positioner/PreviewCardPositionerDataAttributes.ts +26 -0
  1883. package/packages/react/src/preview-card/root/PreviewCardContext.ts +22 -0
  1884. package/packages/react/src/preview-card/root/PreviewCardRoot.detached-triggers.test.tsx +1385 -0
  1885. package/packages/react/src/preview-card/root/PreviewCardRoot.spec.tsx +27 -0
  1886. package/packages/react/src/preview-card/root/PreviewCardRoot.test.tsx +1165 -0
  1887. package/packages/react/src/preview-card/root/PreviewCardRoot.tsx +210 -0
  1888. package/packages/react/src/preview-card/store/PreviewCardHandle.ts +65 -0
  1889. package/packages/react/src/preview-card/store/PreviewCardStore.ts +120 -0
  1890. package/packages/react/src/preview-card/trigger/PreviewCardTrigger.test.tsx +13 -0
  1891. package/packages/react/src/preview-card/trigger/PreviewCardTrigger.tsx +148 -0
  1892. package/packages/react/src/preview-card/trigger/PreviewCardTriggerDataAttributes.ts +8 -0
  1893. package/packages/react/src/preview-card/utils/constants.ts +2 -0
  1894. package/packages/react/src/preview-card/viewport/PreviewCardViewport.test.tsx +424 -0
  1895. package/packages/react/src/preview-card/viewport/PreviewCardViewport.tsx +88 -0
  1896. package/packages/react/src/preview-card/viewport/PreviewCardViewportCssVars.ts +14 -0
  1897. package/packages/react/src/preview-card/viewport/PreviewCardViewportDataAttributes.ts +26 -0
  1898. package/packages/react/src/progress/index.parts.ts +7 -0
  1899. package/packages/react/src/progress/index.ts +7 -0
  1900. package/packages/react/src/progress/indicator/ProgressIndicator.test.tsx +65 -0
  1901. package/packages/react/src/progress/indicator/ProgressIndicator.tsx +61 -0
  1902. package/packages/react/src/progress/indicator/ProgressIndicatorDataAttributes.ts +14 -0
  1903. package/packages/react/src/progress/label/ProgressLabel.test.tsx +13 -0
  1904. package/packages/react/src/progress/label/ProgressLabel.tsx +49 -0
  1905. package/packages/react/src/progress/label/ProgressLabelDataAttributes.ts +14 -0
  1906. package/packages/react/src/progress/root/ProgressRoot.test.tsx +106 -0
  1907. package/packages/react/src/progress/root/ProgressRoot.tsx +145 -0
  1908. package/packages/react/src/progress/root/ProgressRootContext.tsx +41 -0
  1909. package/packages/react/src/progress/root/ProgressRootDataAttributes.ts +14 -0
  1910. package/packages/react/src/progress/root/stateAttributesMapping.ts +18 -0
  1911. package/packages/react/src/progress/track/ProgressTrack.test.tsx +13 -0
  1912. package/packages/react/src/progress/track/ProgressTrack.tsx +40 -0
  1913. package/packages/react/src/progress/track/ProgressTrackDataAttributes.ts +14 -0
  1914. package/packages/react/src/progress/value/ProgressValue.test.tsx +82 -0
  1915. package/packages/react/src/progress/value/ProgressValue.tsx +59 -0
  1916. package/packages/react/src/progress/value/ProgressValueDataAttributes.ts +14 -0
  1917. package/packages/react/src/radio/index.parts.ts +2 -0
  1918. package/packages/react/src/radio/index.ts +4 -0
  1919. package/packages/react/src/radio/indicator/RadioIndicator.test.tsx +237 -0
  1920. package/packages/react/src/radio/indicator/RadioIndicator.tsx +80 -0
  1921. package/packages/react/src/radio/indicator/RadioIndicatorDataAttributes.ts +56 -0
  1922. package/packages/react/src/radio/root/RadioRoot.spec.tsx +12 -0
  1923. package/packages/react/src/radio/root/RadioRoot.test.tsx +135 -0
  1924. package/packages/react/src/radio/root/RadioRoot.tsx +352 -0
  1925. package/packages/react/src/radio/root/RadioRootContext.ts +18 -0
  1926. package/packages/react/src/radio/root/RadioRootDataAttributes.ts +46 -0
  1927. package/packages/react/src/radio/utils/stateAttributesMapping.ts +20 -0
  1928. package/packages/react/src/radio-group/RadioGroup.spec.tsx +57 -0
  1929. package/packages/react/src/radio-group/RadioGroup.test.tsx +1396 -0
  1930. package/packages/react/src/radio-group/RadioGroup.tsx +338 -0
  1931. package/packages/react/src/radio-group/RadioGroupContext.ts +29 -0
  1932. package/packages/react/src/radio-group/RadioGroupDataAttributes.ts +6 -0
  1933. package/packages/react/src/radio-group/index.ts +3 -0
  1934. package/packages/react/src/scroll-area/constants.ts +2 -0
  1935. package/packages/react/src/scroll-area/content/ScrollAreaContent.test.tsx +18 -0
  1936. package/packages/react/src/scroll-area/content/ScrollAreaContent.tsx +88 -0
  1937. package/packages/react/src/scroll-area/content/ScrollAreaContentDataAttributes.ts +30 -0
  1938. package/packages/react/src/scroll-area/corner/ScrollAreaCorner.test.tsx +72 -0
  1939. package/packages/react/src/scroll-area/corner/ScrollAreaCorner.tsx +51 -0
  1940. package/packages/react/src/scroll-area/index.parts.ts +6 -0
  1941. package/packages/react/src/scroll-area/index.ts +8 -0
  1942. package/packages/react/src/scroll-area/root/ScrollAreaRoot.test.tsx +883 -0
  1943. package/packages/react/src/scroll-area/root/ScrollAreaRoot.tsx +404 -0
  1944. package/packages/react/src/scroll-area/root/ScrollAreaRootContext.ts +62 -0
  1945. package/packages/react/src/scroll-area/root/ScrollAreaRootCssVars.ts +12 -0
  1946. package/packages/react/src/scroll-area/root/ScrollAreaRootDataAttributes.ts +30 -0
  1947. package/packages/react/src/scroll-area/root/stateAttributes.ts +13 -0
  1948. package/packages/react/src/scroll-area/scrollbar/ScrollAreaScrollbar.test.tsx +573 -0
  1949. package/packages/react/src/scroll-area/scrollbar/ScrollAreaScrollbar.tsx +288 -0
  1950. package/packages/react/src/scroll-area/scrollbar/ScrollAreaScrollbarContext.ts +20 -0
  1951. package/packages/react/src/scroll-area/scrollbar/ScrollAreaScrollbarCssVars.ts +12 -0
  1952. package/packages/react/src/scroll-area/scrollbar/ScrollAreaScrollbarDataAttributes.ts +39 -0
  1953. package/packages/react/src/scroll-area/thumb/ScrollAreaThumb.test.tsx +227 -0
  1954. package/packages/react/src/scroll-area/thumb/ScrollAreaThumb.tsx +93 -0
  1955. package/packages/react/src/scroll-area/thumb/ScrollAreaThumbDataAttributes.ts +11 -0
  1956. package/packages/react/src/scroll-area/utils/getOffset.ts +22 -0
  1957. package/packages/react/src/scroll-area/viewport/ScrollAreaViewport.test.tsx +111 -0
  1958. package/packages/react/src/scroll-area/viewport/ScrollAreaViewport.tsx +482 -0
  1959. package/packages/react/src/scroll-area/viewport/ScrollAreaViewportContext.ts +20 -0
  1960. package/packages/react/src/scroll-area/viewport/ScrollAreaViewportCssVars.ts +22 -0
  1961. package/packages/react/src/scroll-area/viewport/ScrollAreaViewportDataAttributes.ts +30 -0
  1962. package/packages/react/src/select/arrow/SelectArrow.test.tsx +17 -0
  1963. package/packages/react/src/select/arrow/SelectArrow.tsx +82 -0
  1964. package/packages/react/src/select/arrow/SelectArrowDataAttributes.ts +26 -0
  1965. package/packages/react/src/select/backdrop/SelectBackdrop.test.tsx +13 -0
  1966. package/packages/react/src/select/backdrop/SelectBackdrop.tsx +77 -0
  1967. package/packages/react/src/select/backdrop/SelectBackdropDataAttributes.ts +20 -0
  1968. package/packages/react/src/select/group/SelectGroup.test.tsx +50 -0
  1969. package/packages/react/src/select/group/SelectGroup.tsx +50 -0
  1970. package/packages/react/src/select/group/SelectGroupContext.ts +19 -0
  1971. package/packages/react/src/select/group-label/SelectGroupLabel.test.tsx +17 -0
  1972. package/packages/react/src/select/group-label/SelectGroupLabel.tsx +44 -0
  1973. package/packages/react/src/select/icon/SelectIcon.test.tsx +13 -0
  1974. package/packages/react/src/select/icon/SelectIcon.tsx +51 -0
  1975. package/packages/react/src/select/icon/SelectIconDataAttributes.ts +8 -0
  1976. package/packages/react/src/select/index.parts.ts +19 -0
  1977. package/packages/react/src/select/index.ts +20 -0
  1978. package/packages/react/src/select/item/SelectItem.test.tsx +778 -0
  1979. package/packages/react/src/select/item/SelectItem.tsx +310 -0
  1980. package/packages/react/src/select/item/SelectItemContext.ts +22 -0
  1981. package/packages/react/src/select/item/SelectItemDataAttributes.ts +14 -0
  1982. package/packages/react/src/select/item-indicator/SelectItemIndicator.test.tsx +22 -0
  1983. package/packages/react/src/select/item-indicator/SelectItemIndicator.tsx +106 -0
  1984. package/packages/react/src/select/item-indicator/SelectItemIndicatorDataAttributes.ts +12 -0
  1985. package/packages/react/src/select/item-text/SelectItemText.test.tsx +19 -0
  1986. package/packages/react/src/select/item-text/SelectItemText.tsx +56 -0
  1987. package/packages/react/src/select/label/SelectLabel.test.tsx +21 -0
  1988. package/packages/react/src/select/label/SelectLabel.tsx +62 -0
  1989. package/packages/react/src/select/list/SelectList.test.tsx +21 -0
  1990. package/packages/react/src/select/list/SelectList.tsx +64 -0
  1991. package/packages/react/src/select/popup/SelectPopup.test.tsx +1189 -0
  1992. package/packages/react/src/select/popup/SelectPopup.tsx +629 -0
  1993. package/packages/react/src/select/popup/SelectPopupDataAttributes.ts +30 -0
  1994. package/packages/react/src/select/popup/utils.ts +12 -0
  1995. package/packages/react/src/select/portal/SelectPortal.test.tsx +14 -0
  1996. package/packages/react/src/select/portal/SelectPortal.tsx +43 -0
  1997. package/packages/react/src/select/portal/SelectPortalContext.ts +12 -0
  1998. package/packages/react/src/select/positioner/SelectPositioner.spec.tsx +4 -0
  1999. package/packages/react/src/select/positioner/SelectPositioner.test.tsx +284 -0
  2000. package/packages/react/src/select/positioner/SelectPositioner.tsx +283 -0
  2001. package/packages/react/src/select/positioner/SelectPositionerContext.ts +25 -0
  2002. package/packages/react/src/select/positioner/SelectPositionerCssVars.ts +27 -0
  2003. package/packages/react/src/select/positioner/SelectPositionerDataAttributes.ts +26 -0
  2004. package/packages/react/src/select/root/SelectRoot.spec.tsx +247 -0
  2005. package/packages/react/src/select/root/SelectRoot.test.tsx +5492 -0
  2006. package/packages/react/src/select/root/SelectRoot.tsx +810 -0
  2007. package/packages/react/src/select/root/SelectRootContext.ts +63 -0
  2008. package/packages/react/src/select/scroll-arrow/SelectScrollArrow.tsx +248 -0
  2009. package/packages/react/src/select/scroll-down-arrow/SelectScrollDownArrow.test.tsx +193 -0
  2010. package/packages/react/src/select/scroll-down-arrow/SelectScrollDownArrow.tsx +35 -0
  2011. package/packages/react/src/select/scroll-down-arrow/SelectScrollDownArrowDataAttributes.ts +26 -0
  2012. package/packages/react/src/select/scroll-up-arrow/SelectScrollUpArrow.test.tsx +105 -0
  2013. package/packages/react/src/select/scroll-up-arrow/SelectScrollUpArrow.tsx +35 -0
  2014. package/packages/react/src/select/scroll-up-arrow/SelectScrollUpArrowDataAttributes.ts +26 -0
  2015. package/packages/react/src/select/store.ts +120 -0
  2016. package/packages/react/src/select/trigger/SelectTrigger.test.tsx +268 -0
  2017. package/packages/react/src/select/trigger/SelectTrigger.tsx +287 -0
  2018. package/packages/react/src/select/trigger/SelectTriggerDataAttributes.ts +57 -0
  2019. package/packages/react/src/select/value/SelectValue.test.tsx +764 -0
  2020. package/packages/react/src/select/value/SelectValue.tsx +107 -0
  2021. package/packages/react/src/select/value/SelectValueDataAttributes.ts +6 -0
  2022. package/packages/react/src/separator/Separator.test.tsx +28 -0
  2023. package/packages/react/src/separator/Separator.tsx +47 -0
  2024. package/packages/react/src/separator/SeparatorDataAttributes.ts +7 -0
  2025. package/packages/react/src/separator/index.ts +3 -0
  2026. package/packages/react/src/slider/control/SliderControl.test.tsx +27 -0
  2027. package/packages/react/src/slider/control/SliderControl.tsx +563 -0
  2028. package/packages/react/src/slider/control/SliderControlDataAttributes.ts +35 -0
  2029. package/packages/react/src/slider/index.parts.ts +7 -0
  2030. package/packages/react/src/slider/index.ts +9 -0
  2031. package/packages/react/src/slider/indicator/SliderIndicator.test.tsx +13 -0
  2032. package/packages/react/src/slider/indicator/SliderIndicator.tsx +139 -0
  2033. package/packages/react/src/slider/indicator/SliderIndicatorDataAttributes.ts +35 -0
  2034. package/packages/react/src/slider/label/SliderLabel.test.tsx +20 -0
  2035. package/packages/react/src/slider/label/SliderLabel.tsx +69 -0
  2036. package/packages/react/src/slider/root/SliderRoot.spec.tsx +98 -0
  2037. package/packages/react/src/slider/root/SliderRoot.test.tsx +3321 -0
  2038. package/packages/react/src/slider/root/SliderRoot.tsx +630 -0
  2039. package/packages/react/src/slider/root/SliderRootContext.ts +112 -0
  2040. package/packages/react/src/slider/root/SliderRootDataAttributes.ts +35 -0
  2041. package/packages/react/src/slider/root/stateAttributesMapping.ts +13 -0
  2042. package/packages/react/src/slider/thumb/SliderThumb.test.tsx +1054 -0
  2043. package/packages/react/src/slider/thumb/SliderThumb.tsx +598 -0
  2044. package/packages/react/src/slider/thumb/SliderThumbDataAttributes.ts +39 -0
  2045. package/packages/react/src/slider/thumb/prehydrationScript.min.ts +5 -0
  2046. package/packages/react/src/slider/thumb/prehydrationScript.template.js +69 -0
  2047. package/packages/react/src/slider/track/SliderTrack.test.tsx +13 -0
  2048. package/packages/react/src/slider/track/SliderTrack.tsx +47 -0
  2049. package/packages/react/src/slider/track/SliderTrackDataAttributes.ts +35 -0
  2050. package/packages/react/src/slider/utils/asc.ts +3 -0
  2051. package/packages/react/src/slider/utils/getMidpoint.ts +9 -0
  2052. package/packages/react/src/slider/utils/getPushedThumbValues.test.ts +105 -0
  2053. package/packages/react/src/slider/utils/getPushedThumbValues.ts +72 -0
  2054. package/packages/react/src/slider/utils/getSliderValue.test.ts +27 -0
  2055. package/packages/react/src/slider/utils/getSliderValue.ts +26 -0
  2056. package/packages/react/src/slider/utils/replaceArrayItemAtIndex.ts +7 -0
  2057. package/packages/react/src/slider/utils/resolveThumbCollision.test.ts +235 -0
  2058. package/packages/react/src/slider/utils/resolveThumbCollision.ts +175 -0
  2059. package/packages/react/src/slider/utils/roundValueToStep.test.ts +8 -0
  2060. package/packages/react/src/slider/utils/roundValueToStep.ts +21 -0
  2061. package/packages/react/src/slider/utils/test-utils.ts +28 -0
  2062. package/packages/react/src/slider/utils/validateMinimumDistance.ts +21 -0
  2063. package/packages/react/src/slider/utils/valueArrayToPercentages.ts +10 -0
  2064. package/packages/react/src/slider/value/SliderValue.test.tsx +72 -0
  2065. package/packages/react/src/slider/value/SliderValue.tsx +85 -0
  2066. package/packages/react/src/slider/value/SliderValueDataAttributes.ts +35 -0
  2067. package/packages/react/src/switch/index.parts.ts +2 -0
  2068. package/packages/react/src/switch/index.ts +4 -0
  2069. package/packages/react/src/switch/root/SwitchRoot.test.tsx +1116 -0
  2070. package/packages/react/src/switch/root/SwitchRoot.tsx +348 -0
  2071. package/packages/react/src/switch/root/SwitchRootContext.ts +18 -0
  2072. package/packages/react/src/switch/root/SwitchRootDataAttributes.ts +46 -0
  2073. package/packages/react/src/switch/stateAttributesMapping.ts +19 -0
  2074. package/packages/react/src/switch/thumb/SwitchThumb.test.tsx +28 -0
  2075. package/packages/react/src/switch/thumb/SwitchThumb.tsx +38 -0
  2076. package/packages/react/src/switch/thumb/SwitchThumbDataAttributes.ts +46 -0
  2077. package/packages/react/src/tabs/index.parts.ts +5 -0
  2078. package/packages/react/src/tabs/index.ts +7 -0
  2079. package/packages/react/src/tabs/indicator/TabsIndicator.test.tsx +442 -0
  2080. package/packages/react/src/tabs/indicator/TabsIndicator.tsx +185 -0
  2081. package/packages/react/src/tabs/indicator/TabsIndicatorCssVars.ts +32 -0
  2082. package/packages/react/src/tabs/indicator/TabsIndicatorDataAttributes.ts +12 -0
  2083. package/packages/react/src/tabs/indicator/prehydrationScript.min.ts +5 -0
  2084. package/packages/react/src/tabs/indicator/prehydrationScript.template.js +87 -0
  2085. package/packages/react/src/tabs/list/TabsList.test.tsx +135 -0
  2086. package/packages/react/src/tabs/list/TabsList.tsx +167 -0
  2087. package/packages/react/src/tabs/list/TabsListContext.ts +27 -0
  2088. package/packages/react/src/tabs/list/TabsListDataAttributes.ts +12 -0
  2089. package/packages/react/src/tabs/panel/TabsPanel.test.tsx +186 -0
  2090. package/packages/react/src/tabs/panel/TabsPanel.tsx +157 -0
  2091. package/packages/react/src/tabs/panel/TabsPanelDataAttributes.ts +30 -0
  2092. package/packages/react/src/tabs/root/TabsRoot.test.tsx +2325 -0
  2093. package/packages/react/src/tabs/root/TabsRoot.tsx +514 -0
  2094. package/packages/react/src/tabs/root/TabsRootContext.ts +56 -0
  2095. package/packages/react/src/tabs/root/TabsRootDataAttributes.ts +12 -0
  2096. package/packages/react/src/tabs/root/stateAttributesMapping.ts +9 -0
  2097. package/packages/react/src/tabs/tab/TabsTab.test.tsx +90 -0
  2098. package/packages/react/src/tabs/tab/TabsTab.tsx +287 -0
  2099. package/packages/react/src/tabs/tab/TabsTabDataAttributes.ts +20 -0
  2100. package/packages/react/src/toast/action/ToastAction.test.tsx +81 -0
  2101. package/packages/react/src/toast/action/ToastAction.tsx +74 -0
  2102. package/packages/react/src/toast/action/ToastActionDataAttributes.ts +7 -0
  2103. package/packages/react/src/toast/arrow/ToastArrow.test.tsx +22 -0
  2104. package/packages/react/src/toast/arrow/ToastArrow.tsx +57 -0
  2105. package/packages/react/src/toast/arrow/ToastArrowDataAttributes.ts +18 -0
  2106. package/packages/react/src/toast/close/ToastClose.test.tsx +57 -0
  2107. package/packages/react/src/toast/close/ToastClose.tsx +80 -0
  2108. package/packages/react/src/toast/close/ToastCloseDataAttributes.ts +7 -0
  2109. package/packages/react/src/toast/content/ToastContent.test.tsx +87 -0
  2110. package/packages/react/src/toast/content/ToastContent.tsx +80 -0
  2111. package/packages/react/src/toast/content/ToastContentDataAttributes.ts +12 -0
  2112. package/packages/react/src/toast/createToastManager.spec.tsx +84 -0
  2113. package/packages/react/src/toast/createToastManager.test.tsx +795 -0
  2114. package/packages/react/src/toast/createToastManager.ts +98 -0
  2115. package/packages/react/src/toast/description/ToastDescription.test.tsx +92 -0
  2116. package/packages/react/src/toast/description/ToastDescription.tsx +82 -0
  2117. package/packages/react/src/toast/description/ToastDescriptionDataAttributes.ts +7 -0
  2118. package/packages/react/src/toast/index.parts.ts +14 -0
  2119. package/packages/react/src/toast/index.ts +15 -0
  2120. package/packages/react/src/toast/portal/ToastPortal.test.tsx +14 -0
  2121. package/packages/react/src/toast/portal/ToastPortal.tsx +20 -0
  2122. package/packages/react/src/toast/positioner/ToastPositioner.test.tsx +18 -0
  2123. package/packages/react/src/toast/positioner/ToastPositioner.tsx +155 -0
  2124. package/packages/react/src/toast/positioner/ToastPositionerContext.ts +22 -0
  2125. package/packages/react/src/toast/positioner/ToastPositionerCssVars.ts +27 -0
  2126. package/packages/react/src/toast/positioner/ToastPositionerDataAttributes.ts +18 -0
  2127. package/packages/react/src/toast/provider/ToastProvider.tsx +94 -0
  2128. package/packages/react/src/toast/provider/ToastProviderContext.ts +15 -0
  2129. package/packages/react/src/toast/root/ToastRoot.test.tsx +888 -0
  2130. package/packages/react/src/toast/root/ToastRoot.tsx +629 -0
  2131. package/packages/react/src/toast/root/ToastRootContext.ts +30 -0
  2132. package/packages/react/src/toast/root/ToastRootCssVars.ts +27 -0
  2133. package/packages/react/src/toast/root/ToastRootDataAttributes.ts +37 -0
  2134. package/packages/react/src/toast/store.test.ts +178 -0
  2135. package/packages/react/src/toast/store.ts +556 -0
  2136. package/packages/react/src/toast/title/ToastTitle.test.tsx +92 -0
  2137. package/packages/react/src/toast/title/ToastTitle.tsx +81 -0
  2138. package/packages/react/src/toast/title/ToastTitleDataAttributes.ts +7 -0
  2139. package/packages/react/src/toast/useToastManager.spec.tsx +88 -0
  2140. package/packages/react/src/toast/useToastManager.test.tsx +2024 -0
  2141. package/packages/react/src/toast/useToastManager.ts +149 -0
  2142. package/packages/react/src/toast/utils/focusVisible.ts +1 -0
  2143. package/packages/react/src/toast/utils/resolvePromiseOptions.ts +22 -0
  2144. package/packages/react/src/toast/utils/test-utils.tsx +39 -0
  2145. package/packages/react/src/toast/viewport/ToastViewport.test.tsx +720 -0
  2146. package/packages/react/src/toast/viewport/ToastViewport.tsx +338 -0
  2147. package/packages/react/src/toast/viewport/ToastViewportCssVars.ts +7 -0
  2148. package/packages/react/src/toast/viewport/ToastViewportDataAttributes.ts +7 -0
  2149. package/packages/react/src/toggle/Toggle.test.tsx +171 -0
  2150. package/packages/react/src/toggle/Toggle.tsx +201 -0
  2151. package/packages/react/src/toggle/ToggleDataAttributes.ts +10 -0
  2152. package/packages/react/src/toggle/index.ts +3 -0
  2153. package/packages/react/src/toggle-group/ToggleGroup.spec.tsx +27 -0
  2154. package/packages/react/src/toggle-group/ToggleGroup.test.tsx +527 -0
  2155. package/packages/react/src/toggle-group/ToggleGroup.tsx +218 -0
  2156. package/packages/react/src/toggle-group/ToggleGroupContext.ts +36 -0
  2157. package/packages/react/src/toggle-group/ToggleGroupDataAttributes.ts +15 -0
  2158. package/packages/react/src/toggle-group/index.ts +3 -0
  2159. package/packages/react/src/toolbar/button/ToolbarButton.test.tsx +1173 -0
  2160. package/packages/react/src/toolbar/button/ToolbarButton.tsx +106 -0
  2161. package/packages/react/src/toolbar/button/ToolbarButtonDataAttributes.ts +15 -0
  2162. package/packages/react/src/toolbar/group/ToolbarGroup.test.tsx +71 -0
  2163. package/packages/react/src/toolbar/group/ToolbarGroup.tsx +67 -0
  2164. package/packages/react/src/toolbar/group/ToolbarGroupContext.ts +20 -0
  2165. package/packages/react/src/toolbar/group/ToolbarGroupDataAttributes.ts +11 -0
  2166. package/packages/react/src/toolbar/index.parts.ts +8 -0
  2167. package/packages/react/src/toolbar/index.ts +9 -0
  2168. package/packages/react/src/toolbar/input/ToolbarInput.test.tsx +237 -0
  2169. package/packages/react/src/toolbar/input/ToolbarInput.tsx +108 -0
  2170. package/packages/react/src/toolbar/input/ToolbarInputDataAttributes.ts +15 -0
  2171. package/packages/react/src/toolbar/link/ToolbarLink.test.tsx +50 -0
  2172. package/packages/react/src/toolbar/link/ToolbarLink.tsx +58 -0
  2173. package/packages/react/src/toolbar/link/ToolbarLinkDataAttributes.ts +7 -0
  2174. package/packages/react/src/toolbar/root/ToolbarRoot.test.tsx +274 -0
  2175. package/packages/react/src/toolbar/root/ToolbarRoot.tsx +124 -0
  2176. package/packages/react/src/toolbar/root/ToolbarRootContext.ts +28 -0
  2177. package/packages/react/src/toolbar/root/ToolbarRootDataAttributes.ts +11 -0
  2178. package/packages/react/src/toolbar/separator/ToolbarSeparator.tsx +44 -0
  2179. package/packages/react/src/toolbar/separator/ToolbarSeparatorDataAttributes.ts +7 -0
  2180. package/packages/react/src/tooltip/arrow/TooltipArrow.test.tsx +21 -0
  2181. package/packages/react/src/tooltip/arrow/TooltipArrow.tsx +74 -0
  2182. package/packages/react/src/tooltip/arrow/TooltipArrowDataAttributes.ts +31 -0
  2183. package/packages/react/src/tooltip/index.parts.ts +12 -0
  2184. package/packages/react/src/tooltip/index.ts +10 -0
  2185. package/packages/react/src/tooltip/popup/TooltipPopup.test.tsx +35 -0
  2186. package/packages/react/src/tooltip/popup/TooltipPopup.tsx +107 -0
  2187. package/packages/react/src/tooltip/popup/TooltipPopupDataAttributes.ts +35 -0
  2188. package/packages/react/src/tooltip/portal/TooltipPortal.test.tsx +14 -0
  2189. package/packages/react/src/tooltip/portal/TooltipPortal.tsx +48 -0
  2190. package/packages/react/src/tooltip/portal/TooltipPortalContext.ts +12 -0
  2191. package/packages/react/src/tooltip/positioner/TooltipPositioner.spec.tsx +4 -0
  2192. package/packages/react/src/tooltip/positioner/TooltipPositioner.test.tsx +302 -0
  2193. package/packages/react/src/tooltip/positioner/TooltipPositioner.tsx +149 -0
  2194. package/packages/react/src/tooltip/positioner/TooltipPositionerContext.ts +22 -0
  2195. package/packages/react/src/tooltip/positioner/TooltipPositionerCssVars.ts +27 -0
  2196. package/packages/react/src/tooltip/positioner/TooltipPositionerDataAttributes.ts +26 -0
  2197. package/packages/react/src/tooltip/provider/TooltipProvider.test.tsx +183 -0
  2198. package/packages/react/src/tooltip/provider/TooltipProvider.tsx +57 -0
  2199. package/packages/react/src/tooltip/provider/TooltipProviderContext.ts +15 -0
  2200. package/packages/react/src/tooltip/root/TooltipRoot.detached-triggers.test.tsx +1021 -0
  2201. package/packages/react/src/tooltip/root/TooltipRoot.test.tsx +2634 -0
  2202. package/packages/react/src/tooltip/root/TooltipRoot.tsx +281 -0
  2203. package/packages/react/src/tooltip/root/TooltipRootContext.ts +20 -0
  2204. package/packages/react/src/tooltip/store/TooltipHandle.ts +65 -0
  2205. package/packages/react/src/tooltip/store/TooltipStore.ts +121 -0
  2206. package/packages/react/src/tooltip/trigger/TooltipTrigger.spec.tsx +6 -0
  2207. package/packages/react/src/tooltip/trigger/TooltipTrigger.test.tsx +90 -0
  2208. package/packages/react/src/tooltip/trigger/TooltipTrigger.tsx +365 -0
  2209. package/packages/react/src/tooltip/trigger/TooltipTriggerDataAttributes.ts +12 -0
  2210. package/packages/react/src/tooltip/utils/constants.ts +1 -0
  2211. package/packages/react/src/tooltip/viewport/TooltipViewport.test.tsx +421 -0
  2212. package/packages/react/src/tooltip/viewport/TooltipViewport.tsx +85 -0
  2213. package/packages/react/src/tooltip/viewport/TooltipViewportCssVars.ts +14 -0
  2214. package/packages/react/src/tooltip/viewport/TooltipViewportDataAttributes.ts +26 -0
  2215. package/packages/react/src/types/index.ts +26 -0
  2216. package/packages/react/src/unstable-use-media-query/index.ts +90 -0
  2217. package/packages/react/src/use-render/index.ts +2 -0
  2218. package/packages/react/src/use-render/useRender.spec.tsx +59 -0
  2219. package/packages/react/src/use-render/useRender.test.tsx +318 -0
  2220. package/packages/react/src/use-render/useRender.ts +113 -0
  2221. package/packages/react/src/utils/FloatingPortalLite.tsx +43 -0
  2222. package/packages/react/src/utils/FocusGuard.tsx +42 -0
  2223. package/packages/react/src/utils/InternalBackdrop.tsx +50 -0
  2224. package/packages/react/src/utils/adaptiveOriginMiddleware.ts +77 -0
  2225. package/packages/react/src/utils/closePart.tsx +46 -0
  2226. package/packages/react/src/utils/collapsibleOpenStateMapping.ts +35 -0
  2227. package/packages/react/src/utils/formatNumber.test.ts +42 -0
  2228. package/packages/react/src/utils/formatNumber.ts +43 -0
  2229. package/packages/react/src/utils/getCssDimensions.ts +24 -0
  2230. package/packages/react/src/utils/getDisabledMountTransitionStyles.ts +9 -0
  2231. package/packages/react/src/utils/getElementAtPoint.ts +3 -0
  2232. package/packages/react/src/utils/getPseudoElementBounds.test.ts +66 -0
  2233. package/packages/react/src/utils/getPseudoElementBounds.ts +49 -0
  2234. package/packages/react/src/utils/hideMiddleware.ts +17 -0
  2235. package/packages/react/src/utils/popupStateMapping.ts +100 -0
  2236. package/packages/react/src/utils/popups/index.ts +4 -0
  2237. package/packages/react/src/utils/popups/inlineRect.test.ts +470 -0
  2238. package/packages/react/src/utils/popups/inlineRect.ts +292 -0
  2239. package/packages/react/src/utils/popups/popupStoreUtils.test.tsx +630 -0
  2240. package/packages/react/src/utils/popups/popupStoreUtils.ts +512 -0
  2241. package/packages/react/src/utils/popups/popupTriggerMap.test.ts +94 -0
  2242. package/packages/react/src/utils/popups/popupTriggerMap.ts +104 -0
  2243. package/packages/react/src/utils/popups/store.test.ts +68 -0
  2244. package/packages/react/src/utils/popups/store.ts +224 -0
  2245. package/packages/react/src/utils/popups/useTriggerFocusGuards.ts +95 -0
  2246. package/packages/react/src/utils/resolveAriaLabelledBy.ts +12 -0
  2247. package/packages/react/src/utils/resolveClassName.ts +13 -0
  2248. package/packages/react/src/utils/resolveRef.ts +13 -0
  2249. package/packages/react/src/utils/resolveStyle.ts +13 -0
  2250. package/packages/react/src/utils/scrollEdges.test.ts +30 -0
  2251. package/packages/react/src/utils/scrollEdges.ts +33 -0
  2252. package/packages/react/src/utils/scrollable.ts +72 -0
  2253. package/packages/react/src/utils/stringifyLocale.test.ts +11 -0
  2254. package/packages/react/src/utils/stringifyLocale.ts +11 -0
  2255. package/packages/react/src/utils/styles.tsx +12 -0
  2256. package/packages/react/src/utils/useAnchorPositioning.ts +755 -0
  2257. package/packages/react/src/utils/useAnchoredPopupScrollLock.ts +43 -0
  2258. package/packages/react/src/utils/useFocusableWhenDisabled.ts +99 -0
  2259. package/packages/react/src/utils/useIsHydrating.test.tsx +39 -0
  2260. package/packages/react/src/utils/useIsHydrating.ts +22 -0
  2261. package/packages/react/src/utils/useMixedToggleClickHandler.ts +61 -0
  2262. package/packages/react/src/utils/useOpenInteractionType.ts +62 -0
  2263. package/packages/react/src/utils/usePopupAutoResize.ts +238 -0
  2264. package/packages/react/src/utils/usePopupViewport.tsx +375 -0
  2265. package/packages/react/src/utils/usePositioner.tsx +44 -0
  2266. package/packages/react/src/utils/useRegisteredLabelId.ts +20 -0
  2267. package/packages/react/src/utils/useSwipeDismiss.test.tsx +1404 -0
  2268. package/packages/react/src/utils/useSwipeDismiss.ts +1208 -0
  2269. package/packages/react/src/utils/valueToPercent.ts +3 -0
  2270. package/packages/react/test/addVitestMatchers.ts +49 -0
  2271. package/packages/react/test/conformanceTests/className.tsx +25 -0
  2272. package/packages/react/test/conformanceTests/propForwarding.tsx +129 -0
  2273. package/packages/react/test/conformanceTests/refForwarding.tsx +40 -0
  2274. package/packages/react/test/conformanceTests/renderProp.tsx +180 -0
  2275. package/packages/react/test/conformanceTests/utils.ts +6 -0
  2276. package/packages/react/test/createRenderer.ts +49 -0
  2277. package/packages/react/test/describeConformance.tsx +70 -0
  2278. package/packages/react/test/describeGregorianAdapter/describeGregorianAdapter.ts +24 -0
  2279. package/packages/react/test/describeGregorianAdapter/describeGregorianAdapter.types.ts +36 -0
  2280. package/packages/react/test/describeGregorianAdapter/describeGregorianAdapter.utils.ts +3 -0
  2281. package/packages/react/test/describeGregorianAdapter/index.ts +2 -0
  2282. package/packages/react/test/describeGregorianAdapter/testComputations.ts +858 -0
  2283. package/packages/react/test/describeGregorianAdapter/testFormats.ts +32 -0
  2284. package/packages/react/test/describeGregorianAdapter/testLocalization.ts +14 -0
  2285. package/packages/react/test/floating-ui-tests/Button.module.css +18 -0
  2286. package/packages/react/test/floating-ui-tests/Button.tsx +14 -0
  2287. package/packages/react/test/floating-ui-tests/ComplexGrid.module.css +12 -0
  2288. package/packages/react/test/floating-ui-tests/ComplexGrid.tsx +102 -0
  2289. package/packages/react/test/floating-ui-tests/EmojiPicker.module.css +83 -0
  2290. package/packages/react/test/floating-ui-tests/EmojiPicker.tsx +302 -0
  2291. package/packages/react/test/floating-ui-tests/Grid.module.css +12 -0
  2292. package/packages/react/test/floating-ui-tests/Grid.tsx +95 -0
  2293. package/packages/react/test/floating-ui-tests/ListboxFocus.tsx +120 -0
  2294. package/packages/react/test/floating-ui-tests/Menu.module.css +95 -0
  2295. package/packages/react/test/floating-ui-tests/Menu.tsx +420 -0
  2296. package/packages/react/test/floating-ui-tests/MenuOrientation.module.css +100 -0
  2297. package/packages/react/test/floating-ui-tests/MenuOrientation.tsx +505 -0
  2298. package/packages/react/test/floating-ui-tests/Navigation.module.css +56 -0
  2299. package/packages/react/test/floating-ui-tests/Navigation.tsx +143 -0
  2300. package/packages/react/test/floating-ui-tests/Popover.module.css +45 -0
  2301. package/packages/react/test/floating-ui-tests/Popover.tsx +192 -0
  2302. package/packages/react/test/floating-ui-tests/gridNavigationWithColumns.ts +27 -0
  2303. package/packages/react/test/floating-ui-tests/renderGridRows.tsx +17 -0
  2304. package/packages/react/test/index.ts +9 -0
  2305. package/packages/react/test/popupConformanceTests.tsx +281 -0
  2306. package/packages/react/test/types.d.ts +1 -0
  2307. package/packages/react/test/useTestInteractions.test.tsx +154 -0
  2308. package/packages/react/test/useTestInteractions.ts +161 -0
  2309. package/packages/react/test/wait.ts +19 -0
  2310. package/packages/react/tsconfig.build.json +19 -0
  2311. package/packages/react/tsconfig.json +11 -0
  2312. package/packages/react/tsconfig.test.json +25 -0
  2313. package/packages/react/vitest-env.d.ts +6 -0
  2314. package/packages/react/vitest.config.mts +16 -0
  2315. package/packages/utils/CHANGELOG.md +91 -0
  2316. package/packages/utils/MAINTAINERS.md +8 -0
  2317. package/packages/utils/README.md +3 -0
  2318. package/packages/utils/package.json +61 -0
  2319. package/packages/utils/src/addEventListener.spec.ts +41 -0
  2320. package/packages/utils/src/addEventListener.test.ts +21 -0
  2321. package/packages/utils/src/addEventListener.ts +63 -0
  2322. package/packages/utils/src/empty.ts +5 -0
  2323. package/packages/utils/src/error.ts +18 -0
  2324. package/packages/utils/src/fastHooks.ts +70 -0
  2325. package/packages/utils/src/fastObjectShallowCompare.ts +32 -0
  2326. package/packages/utils/src/formatErrorMessage.test.ts +49 -0
  2327. package/packages/utils/src/formatErrorMessage.ts +33 -0
  2328. package/packages/utils/src/generateId.ts +5 -0
  2329. package/packages/utils/src/getDefaultFormSubmitter.test.ts +70 -0
  2330. package/packages/utils/src/getDefaultFormSubmitter.ts +34 -0
  2331. package/packages/utils/src/getReactElementRef.test.tsx +38 -0
  2332. package/packages/utils/src/getReactElementRef.ts +16 -0
  2333. package/packages/utils/src/inertValue.ts +9 -0
  2334. package/packages/utils/src/isElementDisabled.ts +7 -0
  2335. package/packages/utils/src/isMouseWithinBounds.ts +20 -0
  2336. package/packages/utils/src/mergeCleanups.test.ts +15 -0
  2337. package/packages/utils/src/mergeCleanups.ts +15 -0
  2338. package/packages/utils/src/mergeObjects.ts +15 -0
  2339. package/packages/utils/src/owner.ts +5 -0
  2340. package/packages/utils/src/platform/engine.ts +22 -0
  2341. package/packages/utils/src/platform/env.ts +4 -0
  2342. package/packages/utils/src/platform/index.ts +27 -0
  2343. package/packages/utils/src/platform/os.ts +24 -0
  2344. package/packages/utils/src/platform/parts.ts +4 -0
  2345. package/packages/utils/src/platform/screen-reader.ts +12 -0
  2346. package/packages/utils/src/platform/shared.ts +51 -0
  2347. package/packages/utils/src/reactVersion.ts +9 -0
  2348. package/packages/utils/src/safeReact.ts +11 -0
  2349. package/packages/utils/src/store/ReactStore.spec.ts +94 -0
  2350. package/packages/utils/src/store/ReactStore.test.tsx +574 -0
  2351. package/packages/utils/src/store/ReactStore.ts +282 -0
  2352. package/packages/utils/src/store/Store.ts +123 -0
  2353. package/packages/utils/src/store/StoreInspector.tsx +595 -0
  2354. package/packages/utils/src/store/createSelector.ts +137 -0
  2355. package/packages/utils/src/store/createSelectorMemoized.ts +99 -0
  2356. package/packages/utils/src/store/index.ts +6 -0
  2357. package/packages/utils/src/store/useStore.ts +193 -0
  2358. package/packages/utils/src/testUtils.ts +21 -0
  2359. package/packages/utils/src/useAnimationFrame.ts +132 -0
  2360. package/packages/utils/src/useControlled.test.tsx +272 -0
  2361. package/packages/utils/src/useControlled.ts +112 -0
  2362. package/packages/utils/src/useEnhancedClickHandler.ts +50 -0
  2363. package/packages/utils/src/useForcedRerendering.ts +13 -0
  2364. package/packages/utils/src/useId.test.tsx +124 -0
  2365. package/packages/utils/src/useId.ts +42 -0
  2366. package/packages/utils/src/useInterval.ts +42 -0
  2367. package/packages/utils/src/useIsoLayoutEffect.ts +6 -0
  2368. package/packages/utils/src/useMergedRefs.test.tsx +174 -0
  2369. package/packages/utils/src/useMergedRefs.ts +151 -0
  2370. package/packages/utils/src/useOnFirstRender.ts +10 -0
  2371. package/packages/utils/src/useOnMount.ts +14 -0
  2372. package/packages/utils/src/usePreviousValue.test.tsx +185 -0
  2373. package/packages/utils/src/usePreviousValue.ts +20 -0
  2374. package/packages/utils/src/useRefWithInit.ts +23 -0
  2375. package/packages/utils/src/useScrollLock.ts +289 -0
  2376. package/packages/utils/src/useStableCallback.ts +62 -0
  2377. package/packages/utils/src/useTimeout.ts +52 -0
  2378. package/packages/utils/src/useValueAsRef.ts +30 -0
  2379. package/packages/utils/src/visuallyHidden.ts +24 -0
  2380. package/packages/utils/src/warn.ts +14 -0
  2381. package/packages/utils/tsconfig.build.json +19 -0
  2382. package/packages/utils/tsconfig.json +11 -0
  2383. package/packages/utils/tsconfig.test.json +16 -0
  2384. package/packages/utils/vitest.config.mts +12 -0
  2385. package/playground/vite-app/README.md +45 -0
  2386. package/playground/vite-app/index.html +13 -0
  2387. package/playground/vite-app/package.json +34 -0
  2388. package/playground/vite-app/public/base-ui-logo.svg +5 -0
  2389. package/playground/vite-app/public/vite.svg +1 -0
  2390. package/playground/vite-app/src/Home.tsx +41 -0
  2391. package/playground/vite-app/src/experiments/perf/SettingsPanel.tsx +115 -0
  2392. package/playground/vite-app/src/experiments/perf/contained-triggers.tsx +226 -0
  2393. package/playground/vite-app/src/experiments/perf/detached-triggers.tsx +286 -0
  2394. package/playground/vite-app/src/experiments/perf/perf.module.css +99 -0
  2395. package/playground/vite-app/src/experiments/perf/radix-triggers.tsx +224 -0
  2396. package/playground/vite-app/src/experiments/perf/utils/benchmark.tsx +184 -0
  2397. package/playground/vite-app/src/index.css +50 -0
  2398. package/playground/vite-app/src/index.tsx +74 -0
  2399. package/playground/vite-app/src/routes.tsx +50 -0
  2400. package/playground/vite-app/tsconfig.app.json +38 -0
  2401. package/playground/vite-app/tsconfig.json +4 -0
  2402. package/playground/vite-app/tsconfig.node.json +26 -0
  2403. package/playground/vite-app/vite.config.ts +36 -0
  2404. package/pnpm-workspace.yaml +31 -0
  2405. package/prettier.config.mjs +3 -0
  2406. package/renovate.json +31 -0
  2407. package/scripts/README.md +58 -0
  2408. package/scripts/changelog.config.mjs +60 -0
  2409. package/scripts/inlineScripts.mts +56 -0
  2410. package/scripts/stylelint/no-unknown-demo-colors.mjs +447 -0
  2411. package/scripts/tsconfig.json +10 -0
  2412. package/stylelint.config.mjs +59 -0
  2413. package/test/README.md +205 -0
  2414. package/test/assets/fake.png +0 -0
  2415. package/test/assets/fake2.png +0 -0
  2416. package/test/bundle-size/bundle-size-checker.config.mjs +69 -0
  2417. package/test/bundle-size/package.json +16 -0
  2418. package/test/docs-regressions-before.png +0 -0
  2419. package/test/docs-regressions-diff.png +0 -0
  2420. package/test/e2e/README.md +30 -0
  2421. package/test/e2e/TestViewer.tsx +21 -0
  2422. package/test/e2e/fixtures/.gitkeep +0 -0
  2423. package/test/e2e/fixtures/Radio.module.css +56 -0
  2424. package/test/e2e/fixtures/Radio.tsx +35 -0
  2425. package/test/e2e/fixtures/field/validate-on-change/Input.module.css +26 -0
  2426. package/test/e2e/fixtures/field/validate-on-change/Input.tsx +22 -0
  2427. package/test/e2e/fixtures/field/validate-on-change/Select.module.css +162 -0
  2428. package/test/e2e/fixtures/field/validate-on-change/Select.tsx +56 -0
  2429. package/test/e2e/fixtures/menu/LinkItemNavigation.module.css +50 -0
  2430. package/test/e2e/fixtures/menu/LinkItemNavigation.tsx +40 -0
  2431. package/test/e2e/fixtures/menu/PageOne.tsx +3 -0
  2432. package/test/e2e/fixtures/menu/PageTwo.tsx +3 -0
  2433. package/test/e2e/fixtures/menu/ReactRouterLinkItemNavigation.tsx +43 -0
  2434. package/test/e2e/fixtures/navigation-menu/InlineSubmenuHoverHandoff.tsx +293 -0
  2435. package/test/e2e/fixtures/slider/Inset.module.css +23 -0
  2436. package/test/e2e/fixtures/slider/Inset.tsx +13 -0
  2437. package/test/e2e/fixtures/slider/Range.module.css +33 -0
  2438. package/test/e2e/fixtures/slider/Range.tsx +15 -0
  2439. package/test/e2e/fixtures/slider/RangeSliderMax.module.css +33 -0
  2440. package/test/e2e/fixtures/slider/RangeSliderMax.tsx +15 -0
  2441. package/test/e2e/index.html +21 -0
  2442. package/test/e2e/index.test.ts +347 -0
  2443. package/test/e2e/main.tsx +134 -0
  2444. package/test/e2e/postcss.config.js +7 -0
  2445. package/test/e2e/serve.json +4 -0
  2446. package/test/e2e/vite.config.mjs +10 -0
  2447. package/test/e2e/vitest.config.mts +21 -0
  2448. package/test/node-resolution/index.mjs +6 -0
  2449. package/test/node-resolution/package.json +11 -0
  2450. package/test/package.json +25 -0
  2451. package/test/performance/package.json +19 -0
  2452. package/test/performance/tests/checkbox.bench.tsx +20 -0
  2453. package/test/performance/tests/combobox.bench.tsx +87 -0
  2454. package/test/performance/tests/dialog.bench.tsx +28 -0
  2455. package/test/performance/tests/menu.bench.tsx +70 -0
  2456. package/test/performance/tests/mixed.bench.tsx +173 -0
  2457. package/test/performance/tests/popover.bench.tsx +28 -0
  2458. package/test/performance/tests/scroll-area.bench.tsx +34 -0
  2459. package/test/performance/tests/select.bench.tsx +86 -0
  2460. package/test/performance/tests/shared.tsx +26 -0
  2461. package/test/performance/tests/slider.bench.tsx +26 -0
  2462. package/test/performance/tests/tabs.bench.tsx +33 -0
  2463. package/test/performance/tests/tooltip.bench.tsx +27 -0
  2464. package/test/performance/tsconfig.json +11 -0
  2465. package/test/performance/vitest.config.ts +3 -0
  2466. package/test/public-types/autocomplete.tsx +80 -0
  2467. package/test/public-types/checkbox.tsx +6 -0
  2468. package/test/public-types/combobox.tsx +71 -0
  2469. package/test/public-types/index.tsx +129 -0
  2470. package/test/public-types/menu.tsx +11 -0
  2471. package/test/public-types/package.json +10 -0
  2472. package/test/public-types/separator.tsx +6 -0
  2473. package/test/public-types/toast.tsx +27 -0
  2474. package/test/public-types/tsconfig.json +25 -0
  2475. package/test/public-types/use-render.tsx +59 -0
  2476. package/test/regressions/README.md +56 -0
  2477. package/test/regressions/TestViewer.tsx +84 -0
  2478. package/test/regressions/fixtures/.gitkeep +0 -0
  2479. package/test/regressions/fixtures.ts +111 -0
  2480. package/test/regressions/index.html +20 -0
  2481. package/test/regressions/index.test.ts +100 -0
  2482. package/test/regressions/main.tsx +127 -0
  2483. package/test/regressions/manual/README.md +4 -0
  2484. package/test/regressions/postcss.config.js +7 -0
  2485. package/test/regressions/public/fonts/die-grotesk-a-bold.woff2 +0 -0
  2486. package/test/regressions/public/fonts/die-grotesk-a-regular.woff2 +0 -0
  2487. package/test/regressions/public/fonts/die-grotesk-b-bold.woff2 +0 -0
  2488. package/test/regressions/public/fonts/die-grotesk-b-regular.woff2 +0 -0
  2489. package/test/regressions/serve.json +4 -0
  2490. package/test/regressions/vite.config.mjs +10 -0
  2491. package/test/regressions/vitest.config.mts +22 -0
  2492. package/test/setupVitest.ts +37 -0
  2493. package/test/tsconfig.json +10 -0
  2494. package/test/vite.d.ts +1 -0
  2495. package/test/vite.shared.config.mjs +25 -0
  2496. package/tsconfig.base.json +26 -0
  2497. package/tsconfig.json +22 -0
  2498. package/vitest.config.mts +30 -0
  2499. package/vitest.shared.mts +67 -0
@@ -0,0 +1,3769 @@
1
+ import { expect, vi } from 'vitest';
2
+ import * as React from 'react';
3
+ import { fireEvent, screen, flushMicrotasks, act, within, waitFor } from '@mui/internal-test-utils';
4
+ import { NavigationMenu } from '@lizuzsusil/react/navigation-menu';
5
+ import { Dialog } from '@lizuzsusil/react/dialog';
6
+ import { DirectionProvider, type TextDirection } from '@lizuzsusil/react/direction-provider';
7
+ import { Popover } from '@lizuzsusil/react/popover';
8
+ import { createRenderer, describeConformance, isJSDOM } from '#test-utils';
9
+ import { PATIENT_CLICK_THRESHOLD } from '../../internals/constants';
10
+ import { OPEN_DELAY } from '../utils/constants';
11
+
12
+ type FalsyNavigationMenuValue = 0 | '' | false;
13
+
14
+ const falsyNavigationMenuValueCases = [
15
+ ['0', 0],
16
+ ['empty string', ''],
17
+ ['false', false],
18
+ ] as const satisfies ReadonlyArray<[string, FalsyNavigationMenuValue]>;
19
+
20
+ function TestNavigationMenu(
21
+ props: NavigationMenu.Root.Props & {
22
+ keepMountedPortal?: boolean;
23
+ },
24
+ ) {
25
+ const { keepMountedPortal = false, ...rootProps } = props;
26
+
27
+ return (
28
+ <NavigationMenu.Root {...rootProps}>
29
+ <NavigationMenu.List>
30
+ <NavigationMenu.Item value="item-1">
31
+ <NavigationMenu.Trigger data-testid="trigger-1">Item 1</NavigationMenu.Trigger>
32
+ <NavigationMenu.Content data-testid="popup-1">
33
+ <NavigationMenu.Link href="#link-1">Link 1</NavigationMenu.Link>
34
+ <NavigationMenu.Link href="#link-2">Link 2</NavigationMenu.Link>
35
+ </NavigationMenu.Content>
36
+ </NavigationMenu.Item>
37
+ <NavigationMenu.Item value="item-2">
38
+ <NavigationMenu.Trigger data-testid="trigger-2">Item 2</NavigationMenu.Trigger>
39
+ <NavigationMenu.Content data-testid="popup-2">
40
+ <NavigationMenu.Link href="#link-3">Link 3</NavigationMenu.Link>
41
+ <NavigationMenu.Link href="#link-4">Link 4</NavigationMenu.Link>
42
+ </NavigationMenu.Content>
43
+ </NavigationMenu.Item>
44
+ </NavigationMenu.List>
45
+
46
+ <NavigationMenu.Portal keepMounted={keepMountedPortal}>
47
+ <NavigationMenu.Positioner data-testid="top-level-positioner">
48
+ <NavigationMenu.Popup data-testid="popup-root">
49
+ <NavigationMenu.Viewport />
50
+ </NavigationMenu.Popup>
51
+ </NavigationMenu.Positioner>
52
+ </NavigationMenu.Portal>
53
+ </NavigationMenu.Root>
54
+ );
55
+ }
56
+
57
+ function TestNavigationMenuWithTopLevelLink(props: NavigationMenu.Root.Props = {}) {
58
+ return (
59
+ <NavigationMenu.Root {...props}>
60
+ <NavigationMenu.List>
61
+ <NavigationMenu.Item value="item-1">
62
+ <NavigationMenu.Trigger data-testid="trigger-1">Item 1</NavigationMenu.Trigger>
63
+ <NavigationMenu.Content data-testid="popup-1">
64
+ <NavigationMenu.Link href="#link-1">Link 1</NavigationMenu.Link>
65
+ </NavigationMenu.Content>
66
+ </NavigationMenu.Item>
67
+ <NavigationMenu.Item value="item-2">
68
+ <NavigationMenu.Trigger data-testid="trigger-2">Item 2</NavigationMenu.Trigger>
69
+ <NavigationMenu.Content data-testid="popup-2">
70
+ <NavigationMenu.Link href="#link-2">Link 2</NavigationMenu.Link>
71
+ </NavigationMenu.Content>
72
+ </NavigationMenu.Item>
73
+ <NavigationMenu.Item>
74
+ <NavigationMenu.Link href="#top-level-link" data-testid="top-level-link">
75
+ Top level link
76
+ </NavigationMenu.Link>
77
+ </NavigationMenu.Item>
78
+ </NavigationMenu.List>
79
+
80
+ <NavigationMenu.Portal>
81
+ <NavigationMenu.Positioner data-testid="top-level-positioner">
82
+ <NavigationMenu.Popup>
83
+ <NavigationMenu.Viewport />
84
+ </NavigationMenu.Popup>
85
+ </NavigationMenu.Positioner>
86
+ </NavigationMenu.Portal>
87
+ </NavigationMenu.Root>
88
+ );
89
+ }
90
+
91
+ function TestNavigationMenuWithDisabledTrigger(props: NavigationMenu.Root.Props = {}) {
92
+ return (
93
+ <NavigationMenu.Root {...props}>
94
+ <NavigationMenu.List>
95
+ <NavigationMenu.Item value="item-1">
96
+ <NavigationMenu.Trigger data-testid="trigger-1" disabled>
97
+ Item 1
98
+ </NavigationMenu.Trigger>
99
+ <NavigationMenu.Content data-testid="popup-1">
100
+ <NavigationMenu.Link href="#link-1">Link 1</NavigationMenu.Link>
101
+ </NavigationMenu.Content>
102
+ </NavigationMenu.Item>
103
+ </NavigationMenu.List>
104
+
105
+ <NavigationMenu.Portal>
106
+ <NavigationMenu.Positioner>
107
+ <NavigationMenu.Popup>
108
+ <NavigationMenu.Viewport />
109
+ </NavigationMenu.Popup>
110
+ </NavigationMenu.Positioner>
111
+ </NavigationMenu.Portal>
112
+ </NavigationMenu.Root>
113
+ );
114
+ }
115
+
116
+ const scopedPopupAnimationStyles = `
117
+ .test-navigation-menu-popup {
118
+ transition-property: opacity, transform, width, height;
119
+ transition-duration: 350ms;
120
+ transition-timing-function: cubic-bezier(0.22, 1, 0.36, 1);
121
+ }
122
+
123
+ .test-navigation-menu-popup[data-starting-style],
124
+ .test-navigation-menu-popup[data-ending-style] {
125
+ opacity: 0;
126
+ transform: scale(0.9);
127
+ }
128
+
129
+ .test-navigation-menu-popup[data-ending-style] {
130
+ transition-property: opacity, transform;
131
+ transition-duration: 150ms;
132
+ transition-timing-function: ease;
133
+ }
134
+
135
+ .test-navigation-menu-content {
136
+ transition:
137
+ opacity 175ms ease,
138
+ transform 350ms cubic-bezier(0.4, 0, 0.2, 1);
139
+ }
140
+
141
+ .test-navigation-menu-content[data-starting-style],
142
+ .test-navigation-menu-content[data-ending-style] {
143
+ opacity: 0;
144
+ }
145
+
146
+ .test-navigation-menu-content[data-starting-style][data-activation-direction='left'] {
147
+ transform: translateX(-2rem);
148
+ }
149
+
150
+ .test-navigation-menu-content[data-starting-style][data-activation-direction='right'] {
151
+ transform: translateX(2rem);
152
+ }
153
+
154
+ .test-navigation-menu-content[data-ending-style] {
155
+ transition-duration: 175ms;
156
+ transition-timing-function: ease;
157
+ }
158
+
159
+ .test-navigation-menu-content[data-ending-style][data-activation-direction='left'] {
160
+ transform: translateX(2rem);
161
+ }
162
+
163
+ .test-navigation-menu-content[data-ending-style][data-activation-direction='right'] {
164
+ transform: translateX(-2rem);
165
+ }
166
+ `;
167
+
168
+ function TestNavigationMenuWithTopLevelLinkScopedPopupAnimation() {
169
+ return (
170
+ <NavigationMenu.Root>
171
+ {/* eslint-disable-next-line react/no-danger */}
172
+ <style dangerouslySetInnerHTML={{ __html: scopedPopupAnimationStyles }} />
173
+ <NavigationMenu.List>
174
+ <NavigationMenu.Item value="item-1">
175
+ <NavigationMenu.Trigger data-testid="trigger-product">Product</NavigationMenu.Trigger>
176
+ <NavigationMenu.Content className="test-navigation-menu-content">
177
+ <div style={{ width: 675, height: 220 }}>Product panel</div>
178
+ </NavigationMenu.Content>
179
+ </NavigationMenu.Item>
180
+
181
+ <NavigationMenu.Item>
182
+ <NavigationMenu.Link href="#top-level-link" data-testid="top-level-link">
183
+ Top level link
184
+ </NavigationMenu.Link>
185
+ </NavigationMenu.Item>
186
+
187
+ <NavigationMenu.Item value="item-2">
188
+ <NavigationMenu.Trigger data-testid="trigger-learn">Learn</NavigationMenu.Trigger>
189
+ <NavigationMenu.Content className="test-navigation-menu-content">
190
+ <div style={{ width: 500, height: 180 }}>Learn panel</div>
191
+ </NavigationMenu.Content>
192
+ </NavigationMenu.Item>
193
+ </NavigationMenu.List>
194
+
195
+ <NavigationMenu.Portal keepMounted>
196
+ <NavigationMenu.Positioner data-testid="positioner">
197
+ <NavigationMenu.Popup className="test-navigation-menu-popup" data-testid="popup-root">
198
+ <NavigationMenu.Viewport />
199
+ </NavigationMenu.Popup>
200
+ </NavigationMenu.Positioner>
201
+ </NavigationMenu.Portal>
202
+ </NavigationMenu.Root>
203
+ );
204
+ }
205
+
206
+ function TestNestedNavigationMenu(props: NavigationMenu.Root.Props = {}) {
207
+ return (
208
+ <NavigationMenu.Root {...props}>
209
+ <NavigationMenu.List>
210
+ <NavigationMenu.Item value="item-1">
211
+ <NavigationMenu.Trigger data-testid="trigger-1">Item 1</NavigationMenu.Trigger>
212
+
213
+ <NavigationMenu.Content data-testid="popup-1">
214
+ <NavigationMenu.Link href="#link-1">Link 1</NavigationMenu.Link>
215
+ <NavigationMenu.Root>
216
+ <NavigationMenu.List>
217
+ <NavigationMenu.Item value="nested-item-1">
218
+ <NavigationMenu.Trigger data-testid="nested-trigger-1">
219
+ Nested Item 1
220
+ </NavigationMenu.Trigger>
221
+ <NavigationMenu.Content data-testid="nested-popup-1">
222
+ <NavigationMenu.Link href="#nested-link-1">Nested Link 1</NavigationMenu.Link>
223
+ </NavigationMenu.Content>
224
+ </NavigationMenu.Item>
225
+ </NavigationMenu.List>
226
+
227
+ <NavigationMenu.Portal>
228
+ <NavigationMenu.Positioner side="right" data-testid="nested-positioner">
229
+ <NavigationMenu.Popup>
230
+ <NavigationMenu.Viewport />
231
+ </NavigationMenu.Popup>
232
+ </NavigationMenu.Positioner>
233
+ </NavigationMenu.Portal>
234
+ </NavigationMenu.Root>
235
+ </NavigationMenu.Content>
236
+ </NavigationMenu.Item>
237
+
238
+ <NavigationMenu.Item value="item-2">
239
+ <NavigationMenu.Trigger data-testid="trigger-2">Item 2</NavigationMenu.Trigger>
240
+ <NavigationMenu.Content data-testid="popup-2">
241
+ <NavigationMenu.Link href="#link-3">Link 3</NavigationMenu.Link>
242
+ </NavigationMenu.Content>
243
+ </NavigationMenu.Item>
244
+ </NavigationMenu.List>
245
+
246
+ <NavigationMenu.Portal>
247
+ <NavigationMenu.Positioner data-testid="top-level-positioner">
248
+ <NavigationMenu.Popup>
249
+ <NavigationMenu.Viewport />
250
+ </NavigationMenu.Popup>
251
+ </NavigationMenu.Positioner>
252
+ </NavigationMenu.Portal>
253
+ </NavigationMenu.Root>
254
+ );
255
+ }
256
+
257
+ function TestNavigationMenuOrientationAttributes() {
258
+ return (
259
+ <NavigationMenu.Root data-testid="top-level-root" defaultValue="item-1" orientation="vertical">
260
+ <NavigationMenu.List data-testid="top-level-list">
261
+ <NavigationMenu.Item value="item-1">
262
+ <NavigationMenu.Trigger>Item 1</NavigationMenu.Trigger>
263
+ <NavigationMenu.Content>
264
+ <NavigationMenu.Root
265
+ data-testid="nested-root"
266
+ defaultValue="nested-item-1"
267
+ orientation="vertical"
268
+ >
269
+ <NavigationMenu.List data-testid="nested-list">
270
+ <NavigationMenu.Item value="nested-item-1">
271
+ <NavigationMenu.Trigger>Nested Item 1</NavigationMenu.Trigger>
272
+ <NavigationMenu.Content>
273
+ <NavigationMenu.Link href="#nested-link-1">Nested Link 1</NavigationMenu.Link>
274
+ </NavigationMenu.Content>
275
+ </NavigationMenu.Item>
276
+ </NavigationMenu.List>
277
+
278
+ <NavigationMenu.Viewport />
279
+ </NavigationMenu.Root>
280
+ </NavigationMenu.Content>
281
+ </NavigationMenu.Item>
282
+ </NavigationMenu.List>
283
+
284
+ <NavigationMenu.Portal>
285
+ <NavigationMenu.Positioner>
286
+ <NavigationMenu.Popup>
287
+ <NavigationMenu.Viewport />
288
+ </NavigationMenu.Popup>
289
+ </NavigationMenu.Positioner>
290
+ </NavigationMenu.Portal>
291
+ </NavigationMenu.Root>
292
+ );
293
+ }
294
+
295
+ function TestInlineNestedNavigationMenu(
296
+ props: {
297
+ nestedDefaultValue?: string | number | boolean | null;
298
+ nestedItem1Value?: string | number | boolean;
299
+ keepMountedContent?: boolean;
300
+ nestedLinkCloseOnClick?: boolean;
301
+ } = {},
302
+ ) {
303
+ const {
304
+ nestedDefaultValue = 'nested-item-1',
305
+ nestedItem1Value = 'nested-item-1',
306
+ keepMountedContent = false,
307
+ nestedLinkCloseOnClick = false,
308
+ } = props;
309
+ const nestedRootProps =
310
+ nestedDefaultValue == null ? undefined : { defaultValue: nestedDefaultValue };
311
+
312
+ return (
313
+ <NavigationMenu.Root>
314
+ <NavigationMenu.List>
315
+ <NavigationMenu.Item value="item-1">
316
+ <NavigationMenu.Trigger data-testid="trigger-1">Item 1</NavigationMenu.Trigger>
317
+
318
+ <NavigationMenu.Content data-testid="popup-1" keepMounted={keepMountedContent}>
319
+ <NavigationMenu.Link href="#link-1">Link 1</NavigationMenu.Link>
320
+ <NavigationMenu.Root {...nestedRootProps}>
321
+ <NavigationMenu.List data-testid="inline-nested-list">
322
+ <NavigationMenu.Item value={nestedItem1Value}>
323
+ <NavigationMenu.Trigger data-testid="nested-trigger-1">
324
+ Nested Item 1
325
+ </NavigationMenu.Trigger>
326
+ <NavigationMenu.Content
327
+ data-testid="nested-popup-1"
328
+ keepMounted={keepMountedContent}
329
+ >
330
+ <NavigationMenu.Link
331
+ href="#nested-link-1"
332
+ closeOnClick={nestedLinkCloseOnClick}
333
+ >
334
+ Nested Link 1
335
+ </NavigationMenu.Link>
336
+ </NavigationMenu.Content>
337
+ </NavigationMenu.Item>
338
+ <NavigationMenu.Item value="nested-item-2">
339
+ <NavigationMenu.Trigger data-testid="nested-trigger-2">
340
+ Nested Item 2
341
+ </NavigationMenu.Trigger>
342
+ <NavigationMenu.Content
343
+ data-testid="nested-popup-2"
344
+ keepMounted={keepMountedContent}
345
+ >
346
+ <NavigationMenu.Link href="#nested-link-2">Nested Link 2</NavigationMenu.Link>
347
+ </NavigationMenu.Content>
348
+ </NavigationMenu.Item>
349
+ </NavigationMenu.List>
350
+
351
+ <NavigationMenu.Viewport data-testid="inline-nested-viewport" />
352
+ </NavigationMenu.Root>
353
+ </NavigationMenu.Content>
354
+ </NavigationMenu.Item>
355
+
356
+ <NavigationMenu.Item value="item-2">
357
+ <NavigationMenu.Trigger data-testid="trigger-2">Item 2</NavigationMenu.Trigger>
358
+ <NavigationMenu.Content data-testid="popup-2" keepMounted={keepMountedContent}>
359
+ <NavigationMenu.Link href="#link-3">Link 3</NavigationMenu.Link>
360
+ </NavigationMenu.Content>
361
+ </NavigationMenu.Item>
362
+ </NavigationMenu.List>
363
+
364
+ <NavigationMenu.Portal>
365
+ <NavigationMenu.Positioner data-testid="positioner">
366
+ <NavigationMenu.Popup data-testid="popup-root">
367
+ <NavigationMenu.Viewport />
368
+ </NavigationMenu.Popup>
369
+ </NavigationMenu.Positioner>
370
+ </NavigationMenu.Portal>
371
+ </NavigationMenu.Root>
372
+ );
373
+ }
374
+
375
+ function TestInlineNestedNavigationMenuWithDynamicContent({
376
+ initialContentStage = 0,
377
+ }: {
378
+ initialContentStage?: number;
379
+ } = {}) {
380
+ const [contentStage, setContentStage] = React.useState(initialContentStage);
381
+
382
+ return (
383
+ <NavigationMenu.Root>
384
+ <NavigationMenu.List>
385
+ <NavigationMenu.Item value="item-1">
386
+ <NavigationMenu.Trigger data-testid="trigger-1">Item 1</NavigationMenu.Trigger>
387
+
388
+ <NavigationMenu.Content data-testid="popup-1">
389
+ <NavigationMenu.Link href="#link-1">Link 1</NavigationMenu.Link>
390
+ <NavigationMenu.Root defaultValue="nested-item-1">
391
+ <NavigationMenu.List>
392
+ <NavigationMenu.Item value="nested-item-1">
393
+ <NavigationMenu.Trigger data-testid="nested-trigger-1">
394
+ Nested Item 1
395
+ </NavigationMenu.Trigger>
396
+ <NavigationMenu.Content data-testid="nested-popup-1">
397
+ <button
398
+ type="button"
399
+ data-testid="insert-content"
400
+ onClick={() => {
401
+ setContentStage((prev) => Math.min(prev + 1, 2));
402
+ }}
403
+ >
404
+ Insert content
405
+ </button>
406
+ {contentStage >= 1 && (
407
+ <div data-testid="extra-content">
408
+ <NavigationMenu.Link href="#nested-link-1">
409
+ Nested Link 1
410
+ </NavigationMenu.Link>
411
+ <NavigationMenu.Link href="#nested-link-2">
412
+ Nested Link 2
413
+ </NavigationMenu.Link>
414
+ <NavigationMenu.Link href="#nested-link-3">
415
+ Nested Link 3
416
+ </NavigationMenu.Link>
417
+ </div>
418
+ )}
419
+ {contentStage >= 2 && (
420
+ <div data-testid="extra-content-2">
421
+ <NavigationMenu.Link href="#nested-link-4">
422
+ Nested Link 4
423
+ </NavigationMenu.Link>
424
+ <NavigationMenu.Link href="#nested-link-5">
425
+ Nested Link 5
426
+ </NavigationMenu.Link>
427
+ </div>
428
+ )}
429
+ </NavigationMenu.Content>
430
+ </NavigationMenu.Item>
431
+ </NavigationMenu.List>
432
+
433
+ <NavigationMenu.Viewport />
434
+ </NavigationMenu.Root>
435
+ </NavigationMenu.Content>
436
+ </NavigationMenu.Item>
437
+ </NavigationMenu.List>
438
+
439
+ <NavigationMenu.Portal>
440
+ <NavigationMenu.Positioner data-testid="positioner">
441
+ <NavigationMenu.Popup data-testid="popup-root">
442
+ <NavigationMenu.Viewport />
443
+ </NavigationMenu.Popup>
444
+ </NavigationMenu.Positioner>
445
+ </NavigationMenu.Portal>
446
+ </NavigationMenu.Root>
447
+ );
448
+ }
449
+
450
+ function TestInlineNestedNavigationMenuTabForwardBoundary() {
451
+ return (
452
+ <NavigationMenu.Root>
453
+ <NavigationMenu.List>
454
+ <NavigationMenu.Item value="item-1">
455
+ <NavigationMenu.Trigger data-testid="trigger-1">Product</NavigationMenu.Trigger>
456
+
457
+ <NavigationMenu.Content data-testid="popup-1">
458
+ <NavigationMenu.Root defaultValue="nested-item-2">
459
+ <NavigationMenu.List>
460
+ <NavigationMenu.Item value="nested-item-1">
461
+ <NavigationMenu.Trigger data-testid="nested-trigger-1">
462
+ Engineering Leads
463
+ </NavigationMenu.Trigger>
464
+ <NavigationMenu.Content data-testid="nested-popup-1">
465
+ <NavigationMenu.Link href="#releases">Releases</NavigationMenu.Link>
466
+ </NavigationMenu.Content>
467
+ </NavigationMenu.Item>
468
+ <NavigationMenu.Item value="nested-item-2">
469
+ <NavigationMenu.Trigger data-testid="nested-trigger-2">
470
+ Startups
471
+ </NavigationMenu.Trigger>
472
+ <NavigationMenu.Content data-testid="nested-popup-2">
473
+ <NavigationMenu.Link href="#quick-start">Quick start</NavigationMenu.Link>
474
+ <NavigationMenu.Link href="#menu">Menu</NavigationMenu.Link>
475
+ <NavigationMenu.Link href="#select" data-testid="nested-last-link">
476
+ Select
477
+ </NavigationMenu.Link>
478
+ </NavigationMenu.Content>
479
+ </NavigationMenu.Item>
480
+ </NavigationMenu.List>
481
+
482
+ <NavigationMenu.Viewport />
483
+ </NavigationMenu.Root>
484
+ </NavigationMenu.Content>
485
+ </NavigationMenu.Item>
486
+
487
+ <NavigationMenu.Item value="item-2">
488
+ <NavigationMenu.Trigger data-testid="trigger-2">Learn</NavigationMenu.Trigger>
489
+ <NavigationMenu.Content data-testid="popup-2">
490
+ <NavigationMenu.Link href="#learn">Learn link</NavigationMenu.Link>
491
+ </NavigationMenu.Content>
492
+ </NavigationMenu.Item>
493
+ </NavigationMenu.List>
494
+
495
+ <NavigationMenu.Portal>
496
+ <NavigationMenu.Positioner>
497
+ <NavigationMenu.Popup>
498
+ <NavigationMenu.Viewport />
499
+ </NavigationMenu.Popup>
500
+ </NavigationMenu.Positioner>
501
+ </NavigationMenu.Portal>
502
+ </NavigationMenu.Root>
503
+ );
504
+ }
505
+
506
+ function TestInlineNestedNavigationMenuTabFlow() {
507
+ return (
508
+ <NavigationMenu.Root>
509
+ <NavigationMenu.List>
510
+ <NavigationMenu.Item value="item-1">
511
+ <NavigationMenu.Trigger data-testid="trigger-product">Product</NavigationMenu.Trigger>
512
+
513
+ <NavigationMenu.Content data-testid="popup-product">
514
+ <NavigationMenu.Root defaultValue="developers" orientation="vertical">
515
+ <NavigationMenu.List>
516
+ <NavigationMenu.Item value="developers">
517
+ <NavigationMenu.Trigger data-testid="nested-trigger-developers">
518
+ Developers
519
+ </NavigationMenu.Trigger>
520
+ <NavigationMenu.Content data-testid="nested-popup-developers">
521
+ <NavigationMenu.Link href="#get-started" data-testid="nested-link-get-started">
522
+ Get started
523
+ </NavigationMenu.Link>
524
+ <NavigationMenu.Link href="#composition" data-testid="nested-link-composition">
525
+ Composition
526
+ </NavigationMenu.Link>
527
+ </NavigationMenu.Content>
528
+ </NavigationMenu.Item>
529
+ <NavigationMenu.Item value="design-systems">
530
+ <NavigationMenu.Trigger data-testid="nested-trigger-design-systems">
531
+ Design Systems
532
+ </NavigationMenu.Trigger>
533
+ <NavigationMenu.Content data-testid="nested-popup-design-systems">
534
+ <NavigationMenu.Link
535
+ href="#styling"
536
+ data-testid="nested-link-design-systems-styling"
537
+ >
538
+ Styling
539
+ </NavigationMenu.Link>
540
+ <NavigationMenu.Link href="#accessibility">Accessibility</NavigationMenu.Link>
541
+ </NavigationMenu.Content>
542
+ </NavigationMenu.Item>
543
+ <NavigationMenu.Item value="engineering-leads">
544
+ <NavigationMenu.Trigger>Engineering Leads</NavigationMenu.Trigger>
545
+ <NavigationMenu.Content>
546
+ <NavigationMenu.Link href="#releases">Releases</NavigationMenu.Link>
547
+ </NavigationMenu.Content>
548
+ </NavigationMenu.Item>
549
+ </NavigationMenu.List>
550
+
551
+ <NavigationMenu.Viewport />
552
+ </NavigationMenu.Root>
553
+ </NavigationMenu.Content>
554
+ </NavigationMenu.Item>
555
+
556
+ <NavigationMenu.Item value="item-2">
557
+ <NavigationMenu.Trigger data-testid="trigger-learn">Learn</NavigationMenu.Trigger>
558
+ <NavigationMenu.Content>
559
+ <NavigationMenu.Link href="#learn">Learn link</NavigationMenu.Link>
560
+ </NavigationMenu.Content>
561
+ </NavigationMenu.Item>
562
+ </NavigationMenu.List>
563
+
564
+ <NavigationMenu.Portal>
565
+ <NavigationMenu.Positioner>
566
+ <NavigationMenu.Popup>
567
+ <NavigationMenu.Viewport />
568
+ </NavigationMenu.Popup>
569
+ </NavigationMenu.Positioner>
570
+ </NavigationMenu.Portal>
571
+ </NavigationMenu.Root>
572
+ );
573
+ }
574
+
575
+ function TestNavigationMenuWithKeepMountedContent() {
576
+ return (
577
+ <NavigationMenu.Root defaultValue="item-1">
578
+ <NavigationMenu.List>
579
+ <NavigationMenu.Item value="item-1">
580
+ <NavigationMenu.Trigger data-testid="trigger-product">Product</NavigationMenu.Trigger>
581
+ <NavigationMenu.Content keepMounted>
582
+ <div style={{ width: 675, height: 220 }}>Product panel</div>
583
+ </NavigationMenu.Content>
584
+ </NavigationMenu.Item>
585
+
586
+ <NavigationMenu.Item value="item-2">
587
+ <NavigationMenu.Trigger data-testid="trigger-learn">Learn</NavigationMenu.Trigger>
588
+ <NavigationMenu.Content keepMounted>
589
+ <div style={{ width: 500, height: 180 }}>Learn panel</div>
590
+ </NavigationMenu.Content>
591
+ </NavigationMenu.Item>
592
+ </NavigationMenu.List>
593
+
594
+ <NavigationMenu.Portal>
595
+ <NavigationMenu.Positioner data-testid="positioner">
596
+ <NavigationMenu.Popup data-testid="popup-root">
597
+ <NavigationMenu.Viewport />
598
+ </NavigationMenu.Popup>
599
+ </NavigationMenu.Positioner>
600
+ </NavigationMenu.Portal>
601
+ </NavigationMenu.Root>
602
+ );
603
+ }
604
+
605
+ function TestNavigationMenuWithKeepMountedContentClosed() {
606
+ return (
607
+ <NavigationMenu.Root>
608
+ <NavigationMenu.List>
609
+ <NavigationMenu.Item value="item-1">
610
+ <NavigationMenu.Trigger data-testid="trigger-product">Product</NavigationMenu.Trigger>
611
+ <NavigationMenu.Content keepMounted>
612
+ <div style={{ width: 675, height: 220 }}>Product panel</div>
613
+ </NavigationMenu.Content>
614
+ </NavigationMenu.Item>
615
+
616
+ <NavigationMenu.Item value="item-2">
617
+ <NavigationMenu.Trigger data-testid="trigger-learn">Learn</NavigationMenu.Trigger>
618
+ <NavigationMenu.Content keepMounted>
619
+ <div style={{ width: 500, height: 180 }}>Learn panel</div>
620
+ </NavigationMenu.Content>
621
+ </NavigationMenu.Item>
622
+ </NavigationMenu.List>
623
+
624
+ <NavigationMenu.Portal keepMounted>
625
+ <NavigationMenu.Positioner data-testid="positioner">
626
+ <NavigationMenu.Popup data-testid="popup-root">
627
+ <NavigationMenu.Viewport />
628
+ </NavigationMenu.Popup>
629
+ </NavigationMenu.Positioner>
630
+ </NavigationMenu.Portal>
631
+ </NavigationMenu.Root>
632
+ );
633
+ }
634
+
635
+ function TestNavigationMenuWithScopedPopupExitAnimation(
636
+ props: {
637
+ onOpenChangeComplete?: NavigationMenu.Root.Props['onOpenChangeComplete'];
638
+ } = {},
639
+ ) {
640
+ const { onOpenChangeComplete } = props;
641
+
642
+ return (
643
+ <NavigationMenu.Root onOpenChangeComplete={onOpenChangeComplete}>
644
+ {/* eslint-disable-next-line react/no-danger */}
645
+ <style dangerouslySetInnerHTML={{ __html: scopedPopupAnimationStyles }} />
646
+ <NavigationMenu.List>
647
+ <NavigationMenu.Item value="item-1">
648
+ <NavigationMenu.Trigger data-testid="trigger-product">Product</NavigationMenu.Trigger>
649
+ <NavigationMenu.Content className="test-navigation-menu-content">
650
+ <div style={{ width: 675, height: 220 }}>Product panel</div>
651
+ </NavigationMenu.Content>
652
+ </NavigationMenu.Item>
653
+
654
+ <NavigationMenu.Item value="item-2">
655
+ <NavigationMenu.Trigger data-testid="trigger-learn">Learn</NavigationMenu.Trigger>
656
+ <NavigationMenu.Content className="test-navigation-menu-content">
657
+ <div style={{ width: 500, height: 180 }}>Learn panel</div>
658
+ </NavigationMenu.Content>
659
+ </NavigationMenu.Item>
660
+ </NavigationMenu.List>
661
+
662
+ <NavigationMenu.Portal>
663
+ <NavigationMenu.Positioner>
664
+ <NavigationMenu.Popup className="test-navigation-menu-popup" data-testid="popup-root">
665
+ <NavigationMenu.Viewport />
666
+ </NavigationMenu.Popup>
667
+ </NavigationMenu.Positioner>
668
+ </NavigationMenu.Portal>
669
+ </NavigationMenu.Root>
670
+ );
671
+ }
672
+
673
+ function mockBoundingClientRect(
674
+ element: Element,
675
+ rect: { x: number; y: number; width: number; height: number },
676
+ ) {
677
+ const domRect = {
678
+ x: rect.x,
679
+ y: rect.y,
680
+ width: rect.width,
681
+ height: rect.height,
682
+ top: rect.y,
683
+ left: rect.x,
684
+ right: rect.x + rect.width,
685
+ bottom: rect.y + rect.height,
686
+ toJSON: () => ({}),
687
+ };
688
+
689
+ Object.defineProperty(element, 'getBoundingClientRect', {
690
+ configurable: true,
691
+ value: () => domRect,
692
+ });
693
+ }
694
+
695
+ function mockAnimations(element: HTMLElement) {
696
+ type MockAnimation = {
697
+ finished: Promise<void>;
698
+ resolveFinished: (() => void) | null;
699
+ };
700
+
701
+ function createAnimation(): MockAnimation {
702
+ let resolveFinished: (() => void) | null = null;
703
+
704
+ return {
705
+ finished: new Promise<void>((resolve) => {
706
+ resolveFinished = resolve;
707
+ }),
708
+ resolveFinished,
709
+ };
710
+ }
711
+
712
+ let currentAnimation = createAnimation();
713
+ let activeAnimations: MockAnimation[] = [];
714
+
715
+ Object.defineProperty(element, 'getAnimations', {
716
+ configurable: true,
717
+ value: () =>
718
+ activeAnimations.map((animation) => ({
719
+ finished: animation.finished,
720
+ })),
721
+ });
722
+
723
+ return {
724
+ start() {
725
+ currentAnimation = createAnimation();
726
+ activeAnimations.push(currentAnimation);
727
+ return currentAnimation;
728
+ },
729
+ finish(animation: MockAnimation = currentAnimation) {
730
+ const finished = animation.finished;
731
+ animation.resolveFinished?.();
732
+ animation.resolveFinished = null;
733
+ activeAnimations = activeAnimations.filter((item) => item !== animation);
734
+ return finished;
735
+ },
736
+ };
737
+ }
738
+
739
+ function mockResizeObserver() {
740
+ const originalResizeObserver = globalThis.ResizeObserver;
741
+
742
+ globalThis.ResizeObserver = class {
743
+ observe() {}
744
+ unobserve() {}
745
+ disconnect() {}
746
+ } as unknown as typeof ResizeObserver;
747
+
748
+ return () => {
749
+ globalThis.ResizeObserver = originalResizeObserver;
750
+ };
751
+ }
752
+
753
+ function primeOpenPopupSize(
754
+ popupRoot: HTMLElement,
755
+ positioner: HTMLElement,
756
+ width: number,
757
+ height: number,
758
+ ) {
759
+ popupRoot.style.setProperty('--popup-width', 'auto');
760
+ popupRoot.style.setProperty('--popup-height', 'auto');
761
+ positioner.style.setProperty('--positioner-width', `${width}px`);
762
+ positioner.style.setProperty('--positioner-height', `${height}px`);
763
+ }
764
+
765
+ function TestDeeplyNestedNavigationMenu() {
766
+ return (
767
+ <NavigationMenu.Root>
768
+ <NavigationMenu.List>
769
+ <NavigationMenu.Item value="item-1">
770
+ <NavigationMenu.Trigger data-testid="trigger-1">Item 1</NavigationMenu.Trigger>
771
+
772
+ <NavigationMenu.Content data-testid="content-1">
773
+ <NavigationMenu.Link href="#link-1" data-testid="link-1">
774
+ Link 1
775
+ </NavigationMenu.Link>
776
+ {/* Level 2 */}
777
+ <NavigationMenu.Root defaultValue="level2-item-1">
778
+ <NavigationMenu.List>
779
+ <NavigationMenu.Item value="level2-item-1">
780
+ <NavigationMenu.Trigger data-testid="level2-trigger-1">
781
+ Level 2 Item 1
782
+ </NavigationMenu.Trigger>
783
+ <NavigationMenu.Content data-testid="level2-content-1">
784
+ <NavigationMenu.Link href="#level2-link-1" data-testid="level2-link-1">
785
+ Level 2 Link 1
786
+ </NavigationMenu.Link>
787
+ {/* Level 3 */}
788
+ <NavigationMenu.Root defaultValue="level3-item-1">
789
+ <NavigationMenu.List>
790
+ <NavigationMenu.Item value="level3-item-1">
791
+ <NavigationMenu.Trigger data-testid="level3-trigger-1">
792
+ Level 3 Item 1
793
+ </NavigationMenu.Trigger>
794
+ <NavigationMenu.Content data-testid="level3-content-1">
795
+ <NavigationMenu.Link href="#level3-link-1">
796
+ Level 3 Link 1
797
+ </NavigationMenu.Link>
798
+ </NavigationMenu.Content>
799
+ </NavigationMenu.Item>
800
+ <NavigationMenu.Item value="level3-item-2">
801
+ <NavigationMenu.Trigger data-testid="level3-trigger-2">
802
+ Level 3 Item 2
803
+ </NavigationMenu.Trigger>
804
+ <NavigationMenu.Content data-testid="level3-content-2">
805
+ <NavigationMenu.Link href="#level3-link-2">
806
+ Level 3 Link 2
807
+ </NavigationMenu.Link>
808
+ </NavigationMenu.Content>
809
+ </NavigationMenu.Item>
810
+ </NavigationMenu.List>
811
+ <NavigationMenu.Viewport />
812
+ </NavigationMenu.Root>
813
+ </NavigationMenu.Content>
814
+ </NavigationMenu.Item>
815
+ <NavigationMenu.Item value="level2-item-2">
816
+ <NavigationMenu.Trigger data-testid="level2-trigger-2">
817
+ Level 2 Item 2
818
+ </NavigationMenu.Trigger>
819
+ <NavigationMenu.Content data-testid="level2-content-2">
820
+ <NavigationMenu.Link href="#level2-link-2">Level 2 Link 2</NavigationMenu.Link>
821
+ </NavigationMenu.Content>
822
+ </NavigationMenu.Item>
823
+ </NavigationMenu.List>
824
+ <NavigationMenu.Viewport />
825
+ </NavigationMenu.Root>
826
+ </NavigationMenu.Content>
827
+ </NavigationMenu.Item>
828
+ </NavigationMenu.List>
829
+
830
+ <NavigationMenu.Portal>
831
+ <NavigationMenu.Positioner>
832
+ <NavigationMenu.Popup>
833
+ <NavigationMenu.Viewport />
834
+ </NavigationMenu.Popup>
835
+ </NavigationMenu.Positioner>
836
+ </NavigationMenu.Portal>
837
+ </NavigationMenu.Root>
838
+ );
839
+ }
840
+
841
+ function TestNestedNavigationMenuWithCloseOnClick(props: {
842
+ onValueChange?: NavigationMenu.Root.Props['onValueChange'];
843
+ }) {
844
+ return (
845
+ <NavigationMenu.Root onValueChange={props.onValueChange}>
846
+ <NavigationMenu.List>
847
+ <NavigationMenu.Item value="item-1">
848
+ <NavigationMenu.Trigger data-testid="trigger-1">Item 1</NavigationMenu.Trigger>
849
+
850
+ <NavigationMenu.Content data-testid="popup-1">
851
+ <NavigationMenu.Link href="#link-1" closeOnClick>
852
+ Link 1
853
+ </NavigationMenu.Link>
854
+ <NavigationMenu.Root>
855
+ <NavigationMenu.List>
856
+ <NavigationMenu.Item value="nested-item-1">
857
+ <NavigationMenu.Trigger data-testid="nested-trigger-1">
858
+ Nested Item 1
859
+ </NavigationMenu.Trigger>
860
+ <NavigationMenu.Content data-testid="nested-popup-1">
861
+ <NavigationMenu.Link
862
+ href="#nested-link-1"
863
+ closeOnClick
864
+ data-testid="nested-link-1"
865
+ >
866
+ Nested Link 1
867
+ </NavigationMenu.Link>
868
+ </NavigationMenu.Content>
869
+ </NavigationMenu.Item>
870
+ </NavigationMenu.List>
871
+
872
+ <NavigationMenu.Portal>
873
+ <NavigationMenu.Positioner side="right">
874
+ <NavigationMenu.Popup>
875
+ <NavigationMenu.Viewport />
876
+ </NavigationMenu.Popup>
877
+ </NavigationMenu.Positioner>
878
+ </NavigationMenu.Portal>
879
+ </NavigationMenu.Root>
880
+ </NavigationMenu.Content>
881
+ </NavigationMenu.Item>
882
+ </NavigationMenu.List>
883
+
884
+ <NavigationMenu.Portal>
885
+ <NavigationMenu.Positioner>
886
+ <NavigationMenu.Popup>
887
+ <NavigationMenu.Viewport />
888
+ </NavigationMenu.Popup>
889
+ </NavigationMenu.Positioner>
890
+ </NavigationMenu.Portal>
891
+ </NavigationMenu.Root>
892
+ );
893
+ }
894
+
895
+ function TestDeeplyNestedNavigationMenuWithCloseOnClick() {
896
+ return (
897
+ <NavigationMenu.Root>
898
+ <NavigationMenu.List>
899
+ <NavigationMenu.Item value="item-1">
900
+ <NavigationMenu.Trigger data-testid="trigger-1">Item 1</NavigationMenu.Trigger>
901
+
902
+ <NavigationMenu.Content data-testid="content-1">
903
+ <NavigationMenu.Root defaultValue="level2-item-1">
904
+ <NavigationMenu.List>
905
+ <NavigationMenu.Item value="level2-item-1">
906
+ <NavigationMenu.Trigger data-testid="level2-trigger-1">
907
+ Level 2 Item 1
908
+ </NavigationMenu.Trigger>
909
+ <NavigationMenu.Content data-testid="level2-content-1">
910
+ <NavigationMenu.Root defaultValue="level3-item-1">
911
+ <NavigationMenu.List>
912
+ <NavigationMenu.Item value="level3-item-1">
913
+ <NavigationMenu.Trigger data-testid="level3-trigger-1">
914
+ Level 3 Item 1
915
+ </NavigationMenu.Trigger>
916
+ <NavigationMenu.Content data-testid="level3-content-1">
917
+ <NavigationMenu.Link
918
+ href="#level3-link-1"
919
+ closeOnClick
920
+ data-testid="level3-link-1"
921
+ >
922
+ Level 3 Link 1
923
+ </NavigationMenu.Link>
924
+ </NavigationMenu.Content>
925
+ </NavigationMenu.Item>
926
+ </NavigationMenu.List>
927
+ <NavigationMenu.Viewport />
928
+ </NavigationMenu.Root>
929
+ </NavigationMenu.Content>
930
+ </NavigationMenu.Item>
931
+ </NavigationMenu.List>
932
+ <NavigationMenu.Viewport />
933
+ </NavigationMenu.Root>
934
+ </NavigationMenu.Content>
935
+ </NavigationMenu.Item>
936
+ </NavigationMenu.List>
937
+
938
+ <NavigationMenu.Portal>
939
+ <NavigationMenu.Positioner>
940
+ <NavigationMenu.Popup>
941
+ <NavigationMenu.Viewport />
942
+ </NavigationMenu.Popup>
943
+ </NavigationMenu.Positioner>
944
+ </NavigationMenu.Portal>
945
+ </NavigationMenu.Root>
946
+ );
947
+ }
948
+
949
+ function TestNavigationMenuWithNestedPopup(props: { children: React.ReactNode }) {
950
+ const { children } = props;
951
+ return (
952
+ <NavigationMenu.Root>
953
+ <NavigationMenu.List>
954
+ <NavigationMenu.Item value="item-1">
955
+ <NavigationMenu.Trigger data-testid="trigger-1">Item 1</NavigationMenu.Trigger>
956
+
957
+ <NavigationMenu.Content data-testid="popup-1">{children}</NavigationMenu.Content>
958
+ </NavigationMenu.Item>
959
+ </NavigationMenu.List>
960
+
961
+ <NavigationMenu.Portal>
962
+ <NavigationMenu.Positioner>
963
+ <NavigationMenu.Popup>
964
+ <NavigationMenu.Viewport />
965
+ </NavigationMenu.Popup>
966
+ </NavigationMenu.Positioner>
967
+ </NavigationMenu.Portal>
968
+ </NavigationMenu.Root>
969
+ );
970
+ }
971
+
972
+ function TestNavigationMenuWithDialog() {
973
+ return (
974
+ <TestNavigationMenuWithNestedPopup>
975
+ <Dialog.Root>
976
+ <Dialog.Trigger data-testid="dialog-trigger">Open dialog</Dialog.Trigger>
977
+ <Dialog.Portal>
978
+ <Dialog.Popup
979
+ data-testid="dialog-popup"
980
+ onClick={(event) => {
981
+ event.stopPropagation();
982
+ }}
983
+ >
984
+ <button type="button" data-testid="dialog-button">
985
+ Dialog button
986
+ </button>
987
+ </Dialog.Popup>
988
+ </Dialog.Portal>
989
+ </Dialog.Root>
990
+ </TestNavigationMenuWithNestedPopup>
991
+ );
992
+ }
993
+
994
+ function TestNavigationMenuWithPopover() {
995
+ return (
996
+ <TestNavigationMenuWithNestedPopup>
997
+ <Popover.Root>
998
+ <Popover.Trigger data-testid="popover-trigger">Open popover</Popover.Trigger>
999
+ <Popover.Portal>
1000
+ <Popover.Positioner>
1001
+ <Popover.Popup
1002
+ data-testid="popover-popup"
1003
+ onClick={(event) => {
1004
+ event.stopPropagation();
1005
+ }}
1006
+ >
1007
+ <button type="button" data-testid="popover-button">
1008
+ Popover button
1009
+ </button>
1010
+ </Popover.Popup>
1011
+ </Popover.Positioner>
1012
+ </Popover.Portal>
1013
+ </Popover.Root>
1014
+ </TestNavigationMenuWithNestedPopup>
1015
+ );
1016
+ }
1017
+
1018
+ describe('<NavigationMenu.Root />', () => {
1019
+ const { render, clock } = createRenderer({
1020
+ clockOptions: {
1021
+ shouldAdvanceTime: true,
1022
+ },
1023
+ });
1024
+
1025
+ clock.withFakeTimers();
1026
+
1027
+ describeConformance(<NavigationMenu.Root />, () => ({
1028
+ refInstanceof: window.HTMLElement,
1029
+ render(node) {
1030
+ return render(node);
1031
+ },
1032
+ }));
1033
+
1034
+ it('does not apply aria-orientation to the top-level list or root element', async () => {
1035
+ await render(<TestNavigationMenuOrientationAttributes />);
1036
+
1037
+ expect(screen.getByTestId('top-level-root')).not.toHaveAttribute('aria-orientation');
1038
+ expect(screen.getByTestId('top-level-list')).not.toHaveAttribute('aria-orientation');
1039
+ });
1040
+
1041
+ it('does not apply aria-orientation to nested lists or root elements', async () => {
1042
+ await render(<TestNavigationMenuOrientationAttributes />);
1043
+
1044
+ expect(screen.getByTestId('nested-root')).not.toHaveAttribute('aria-orientation');
1045
+ expect(screen.getByTestId('nested-list')).not.toHaveAttribute('aria-orientation');
1046
+ });
1047
+
1048
+ describe('interactions', () => {
1049
+ it('opens on hover with mouse input', async () => {
1050
+ await render(<TestNavigationMenu />);
1051
+ const trigger = screen.getByTestId('trigger-1');
1052
+
1053
+ fireEvent.mouseEnter(trigger);
1054
+ fireEvent.mouseMove(trigger);
1055
+ clock.tick(50);
1056
+ await flushMicrotasks();
1057
+
1058
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
1059
+ expect(trigger).toHaveAttribute('aria-expanded', 'true');
1060
+ });
1061
+
1062
+ it('blocks pointer events on the list while traversing from a top-level trigger to the popup', async () => {
1063
+ await render(<TestNavigationMenu />);
1064
+ const trigger = screen.getByTestId('trigger-1');
1065
+ const siblingTrigger = screen.getByTestId('trigger-2');
1066
+ const topLevelList = trigger.closest('ul') as HTMLElement;
1067
+
1068
+ fireEvent.mouseEnter(trigger);
1069
+ fireEvent.mouseMove(trigger);
1070
+ clock.tick(50);
1071
+ await flushMicrotasks();
1072
+
1073
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
1074
+ expect(topLevelList.style.pointerEvents).toBe('none');
1075
+ expect(document.body.style.pointerEvents).toBe('');
1076
+ expect(getComputedStyle(siblingTrigger).pointerEvents).toBe('none');
1077
+
1078
+ fireEvent.mouseEnter(screen.getByTestId('top-level-positioner'));
1079
+ await flushMicrotasks();
1080
+
1081
+ expect(topLevelList.style.pointerEvents).toBe('');
1082
+ });
1083
+
1084
+ it('reapplies top-level safePolygon pointer events after returning from the popup and switching triggers', async () => {
1085
+ await render(<TestNavigationMenuWithTopLevelLink />);
1086
+ const trigger1 = screen.getByTestId('trigger-1');
1087
+ const trigger2 = screen.getByTestId('trigger-2');
1088
+ const topLevelLink = screen.getByTestId('top-level-link');
1089
+ const topLevelList = trigger1.closest('ul') as HTMLElement;
1090
+
1091
+ fireEvent.mouseEnter(trigger1);
1092
+ fireEvent.mouseMove(trigger1);
1093
+ clock.tick(OPEN_DELAY);
1094
+ await flushMicrotasks();
1095
+
1096
+ const positioner = screen.getByTestId('top-level-positioner');
1097
+
1098
+ expect(topLevelList.style.pointerEvents).toBe('none');
1099
+ expect(document.body.style.pointerEvents).toBe('');
1100
+ expect(getComputedStyle(topLevelLink).pointerEvents).toBe('none');
1101
+
1102
+ fireEvent.mouseEnter(positioner);
1103
+ await flushMicrotasks();
1104
+
1105
+ expect(topLevelList.style.pointerEvents).toBe('');
1106
+
1107
+ fireEvent.mouseLeave(positioner, { relatedTarget: trigger1 });
1108
+ fireEvent.mouseEnter(trigger1);
1109
+ fireEvent.mouseMove(trigger1);
1110
+ await flushMicrotasks();
1111
+
1112
+ expect(topLevelList.style.pointerEvents).toBe('none');
1113
+ expect(document.body.style.pointerEvents).toBe('');
1114
+ expect(getComputedStyle(topLevelLink).pointerEvents).toBe('none');
1115
+
1116
+ fireEvent.mouseEnter(positioner);
1117
+ await flushMicrotasks();
1118
+
1119
+ expect(topLevelList.style.pointerEvents).toBe('');
1120
+
1121
+ fireEvent.mouseLeave(positioner, { relatedTarget: trigger2 });
1122
+ fireEvent.mouseEnter(trigger2);
1123
+ fireEvent.mouseMove(trigger2);
1124
+ await flushMicrotasks();
1125
+
1126
+ expect(topLevelList.style.pointerEvents).toBe('none');
1127
+ expect(document.body.style.pointerEvents).toBe('');
1128
+ expect(getComputedStyle(topLevelLink).pointerEvents).toBe('none');
1129
+ expect(trigger2).toHaveAttribute('aria-expanded', 'true');
1130
+ expect(screen.queryByTestId('popup-2')).not.toBe(null);
1131
+ });
1132
+
1133
+ it('keeps top-level safePolygon pointer events active when switching directly to a different trigger', async () => {
1134
+ await render(<TestNavigationMenuWithTopLevelLink />);
1135
+ const trigger1 = screen.getByTestId('trigger-1');
1136
+ const trigger2 = screen.getByTestId('trigger-2');
1137
+ const topLevelLink = screen.getByTestId('top-level-link');
1138
+ const topLevelList = trigger1.closest('ul') as HTMLElement;
1139
+
1140
+ fireEvent.mouseEnter(trigger1);
1141
+ fireEvent.mouseMove(trigger1);
1142
+ clock.tick(OPEN_DELAY);
1143
+ await flushMicrotasks();
1144
+
1145
+ fireEvent.mouseEnter(trigger2);
1146
+ fireEvent.mouseMove(trigger2);
1147
+ await flushMicrotasks();
1148
+
1149
+ expect(topLevelList.style.pointerEvents).toBe('none');
1150
+ expect(document.body.style.pointerEvents).toBe('');
1151
+ expect(getComputedStyle(trigger1).pointerEvents).toBe('none');
1152
+ expect(getComputedStyle(topLevelLink).pointerEvents).toBe('none');
1153
+ expect(trigger1).toHaveAttribute('aria-expanded', 'false');
1154
+ expect(trigger2).toHaveAttribute('aria-expanded', 'true');
1155
+ expect(screen.queryByTestId('popup-2')).not.toBe(null);
1156
+ });
1157
+
1158
+ it('clears top-level safePolygon pointer events on trigger pointerdown', async () => {
1159
+ await render(<TestNavigationMenu />);
1160
+ const trigger = screen.getByTestId('trigger-1');
1161
+ const topLevelList = trigger.closest('ul') as HTMLElement;
1162
+
1163
+ fireEvent.mouseEnter(trigger);
1164
+ fireEvent.mouseMove(trigger);
1165
+ clock.tick(OPEN_DELAY);
1166
+ await flushMicrotasks();
1167
+
1168
+ expect(topLevelList.style.pointerEvents).toBe('none');
1169
+
1170
+ fireEvent.pointerDown(trigger, { pointerType: 'mouse' });
1171
+
1172
+ expect(topLevelList.style.pointerEvents).toBe('');
1173
+ });
1174
+
1175
+ it.skipIf(isJSDOM)(
1176
+ 'blocks pointer events on sibling top-level triggers when opened through real hover',
1177
+ async () => {
1178
+ const { user } = await render(<TestNavigationMenu />);
1179
+ const trigger = screen.getByTestId('trigger-1');
1180
+ const siblingTrigger = screen.getByTestId('trigger-2');
1181
+ const topLevelList = trigger.closest('ul') as HTMLElement;
1182
+
1183
+ await user.hover(trigger);
1184
+
1185
+ await waitFor(() => {
1186
+ expect(topLevelList.style.pointerEvents).toBe('none');
1187
+ });
1188
+
1189
+ expect(getComputedStyle(siblingTrigger).pointerEvents).toBe('none');
1190
+ },
1191
+ );
1192
+
1193
+ it('opens on click with mouse input', async () => {
1194
+ await render(<TestNavigationMenu />);
1195
+ const trigger = screen.getByTestId('trigger-1');
1196
+
1197
+ fireEvent.click(trigger);
1198
+ await flushMicrotasks();
1199
+
1200
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
1201
+ expect(trigger).toHaveAttribute('aria-expanded', 'true');
1202
+ });
1203
+
1204
+ it('does not open on hover with touch input', async () => {
1205
+ await render(<TestNavigationMenu />);
1206
+ const trigger = screen.getByTestId('trigger-1');
1207
+
1208
+ fireEvent.pointerEnter(trigger, { pointerType: 'touch' });
1209
+ await flushMicrotasks();
1210
+
1211
+ expect(screen.queryByTestId('popup-1')).toBe(null);
1212
+ expect(trigger).toHaveAttribute('aria-expanded', 'false');
1213
+ });
1214
+
1215
+ it('opens on click with touch input', async () => {
1216
+ await render(<TestNavigationMenu />);
1217
+ const trigger = screen.getByTestId('trigger-1');
1218
+
1219
+ fireEvent.pointerDown(trigger, { pointerType: 'touch' });
1220
+ fireEvent.pointerUp(trigger, { pointerType: 'touch' });
1221
+ fireEvent.click(trigger);
1222
+ await flushMicrotasks();
1223
+
1224
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
1225
+ expect(trigger).toHaveAttribute('aria-expanded', 'true');
1226
+ });
1227
+
1228
+ it.skipIf(isJSDOM)('restores hover open after a touch click closes outside', async () => {
1229
+ const { user } = await render(
1230
+ <div>
1231
+ <TestNavigationMenu />
1232
+ <button data-testid="outside" />
1233
+ </div>,
1234
+ );
1235
+ const trigger1 = screen.getByTestId('trigger-1');
1236
+ const trigger2 = screen.getByTestId('trigger-2');
1237
+
1238
+ fireEvent.pointerEnter(trigger1, { pointerType: 'touch' });
1239
+ fireEvent.pointerDown(trigger1, { pointerType: 'touch' });
1240
+ fireEvent.pointerUp(trigger1, { pointerType: 'touch' });
1241
+ fireEvent.click(trigger1);
1242
+ await flushMicrotasks();
1243
+
1244
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
1245
+
1246
+ await user.click(screen.getByTestId('outside'));
1247
+ await flushMicrotasks();
1248
+
1249
+ expect(screen.queryByTestId('popup-1')).toBe(null);
1250
+
1251
+ await user.hover(trigger2);
1252
+
1253
+ await waitFor(() => {
1254
+ expect(screen.queryByTestId('popup-2')).not.toBe(null);
1255
+ });
1256
+ });
1257
+
1258
+ it.skipIf(isJSDOM)(
1259
+ 'restores hover open after touching a nested submenu trigger and closing outside',
1260
+ async () => {
1261
+ const { user } = await render(
1262
+ <div>
1263
+ <TestInlineNestedNavigationMenu />
1264
+ <button data-testid="outside" />
1265
+ </div>,
1266
+ );
1267
+ const trigger = screen.getByTestId('trigger-1');
1268
+
1269
+ fireEvent.pointerEnter(trigger, { pointerType: 'touch' });
1270
+ fireEvent.pointerDown(trigger, { pointerType: 'touch' });
1271
+ fireEvent.pointerUp(trigger, { pointerType: 'touch' });
1272
+ fireEvent.click(trigger);
1273
+ await flushMicrotasks();
1274
+
1275
+ const nestedTrigger2 = screen.getByTestId('nested-trigger-2');
1276
+ fireEvent.pointerEnter(nestedTrigger2, { pointerType: 'touch' });
1277
+ fireEvent.pointerDown(nestedTrigger2, { pointerType: 'touch' });
1278
+ fireEvent.pointerUp(nestedTrigger2, { pointerType: 'touch' });
1279
+ fireEvent.click(nestedTrigger2);
1280
+ await flushMicrotasks();
1281
+
1282
+ expect(screen.queryByTestId('nested-popup-2')).not.toBe(null);
1283
+
1284
+ await user.click(screen.getByTestId('outside'));
1285
+ await flushMicrotasks();
1286
+
1287
+ expect(screen.queryByTestId('popup-1')).toBe(null);
1288
+
1289
+ await user.hover(trigger);
1290
+
1291
+ await waitFor(() => {
1292
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
1293
+ });
1294
+ },
1295
+ );
1296
+
1297
+ it('restores hover open after a quick click then trigger switch', async () => {
1298
+ const { user } = await render(<TestNavigationMenu />);
1299
+ const trigger1 = screen.getByTestId('trigger-1');
1300
+ const trigger2 = screen.getByTestId('trigger-2');
1301
+
1302
+ await user.hover(trigger1);
1303
+
1304
+ await waitFor(() => {
1305
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
1306
+ });
1307
+
1308
+ await user.click(trigger1);
1309
+ await flushMicrotasks();
1310
+
1311
+ await user.hover(trigger2);
1312
+
1313
+ await waitFor(() => {
1314
+ expect(screen.queryByTestId('popup-2')).not.toBe(null);
1315
+ });
1316
+
1317
+ await user.unhover(trigger2);
1318
+
1319
+ await waitFor(() => {
1320
+ expect(screen.queryByTestId('popup-2')).toBe(null);
1321
+ });
1322
+
1323
+ await user.hover(trigger1);
1324
+
1325
+ await waitFor(() => {
1326
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
1327
+ });
1328
+ });
1329
+
1330
+ it('closes after pointerdown on a link in a hover-open popup when pointer leaves', async () => {
1331
+ const { user } = await render(<TestNavigationMenu />);
1332
+ const trigger1 = screen.getByTestId('trigger-1');
1333
+
1334
+ await user.hover(trigger1);
1335
+
1336
+ await waitFor(() => {
1337
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
1338
+ });
1339
+
1340
+ const popup1 = screen.getByTestId('popup-1');
1341
+ const link1 = within(popup1).getByText('Link 1');
1342
+
1343
+ await user.hover(link1);
1344
+ fireEvent.pointerDown(link1, { pointerType: 'mouse' });
1345
+ await user.unhover(link1);
1346
+
1347
+ await waitFor(() => {
1348
+ expect(screen.queryByTestId('popup-1')).toBe(null);
1349
+ });
1350
+ });
1351
+
1352
+ it('does not close menu when clicking a different trigger with mouse', async () => {
1353
+ await render(<TestNavigationMenu />);
1354
+ const trigger1 = screen.getByTestId('trigger-1');
1355
+ const trigger2 = screen.getByTestId('trigger-2');
1356
+
1357
+ fireEvent.click(trigger1);
1358
+ await flushMicrotasks();
1359
+
1360
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
1361
+ expect(trigger1).toHaveAttribute('aria-expanded', 'true');
1362
+
1363
+ fireEvent.click(trigger2);
1364
+ await flushMicrotasks();
1365
+
1366
+ expect(screen.queryByTestId('popup-1')).toBe(null);
1367
+ expect(trigger1).toHaveAttribute('aria-expanded', 'false');
1368
+ expect(screen.queryByTestId('popup-2')).not.toBe(null);
1369
+ expect(trigger2).toHaveAttribute('aria-expanded', 'true');
1370
+ });
1371
+
1372
+ it('does not close menu when clicking a different trigger on touch', async () => {
1373
+ await render(<TestNavigationMenu />);
1374
+ const trigger1 = screen.getByTestId('trigger-1');
1375
+ const trigger2 = screen.getByTestId('trigger-2');
1376
+
1377
+ fireEvent.click(trigger1);
1378
+ await flushMicrotasks();
1379
+
1380
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
1381
+ expect(trigger1).toHaveAttribute('aria-expanded', 'true');
1382
+
1383
+ fireEvent.pointerDown(trigger2, { pointerType: 'touch' });
1384
+ fireEvent.pointerUp(trigger2, { pointerType: 'touch' });
1385
+ fireEvent.click(trigger2);
1386
+ await flushMicrotasks();
1387
+
1388
+ expect(screen.queryByTestId('popup-1')).toBe(null);
1389
+ expect(trigger1).toHaveAttribute('aria-expanded', 'false');
1390
+ expect(screen.queryByTestId('popup-2')).not.toBe(null);
1391
+ expect(trigger2).toHaveAttribute('aria-expanded', 'true');
1392
+ });
1393
+
1394
+ it('returns focus to trigger when closing menu', async () => {
1395
+ const { user } = await render(
1396
+ <div>
1397
+ <button data-testid="first" />
1398
+ <TestNavigationMenu />
1399
+ <button data-testid="last" />
1400
+ </div>,
1401
+ );
1402
+
1403
+ const trigger = screen.getByTestId('trigger-1');
1404
+
1405
+ await user.click(trigger);
1406
+ await flushMicrotasks();
1407
+
1408
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
1409
+ expect(trigger).toHaveFocus();
1410
+
1411
+ await user.keyboard('{Escape}');
1412
+ await flushMicrotasks();
1413
+
1414
+ expect(screen.queryByTestId('popup-1')).toBe(null);
1415
+ expect(trigger).toHaveFocus();
1416
+ });
1417
+
1418
+ it('respects focus outside when clicking menu', async () => {
1419
+ const { user } = await render(
1420
+ <div>
1421
+ <button data-testid="first" />
1422
+ <TestNavigationMenu />
1423
+ <button data-testid="last" />
1424
+ </div>,
1425
+ );
1426
+
1427
+ const trigger = screen.getByTestId('trigger-1');
1428
+ const last = screen.getByTestId('last');
1429
+
1430
+ await user.click(trigger);
1431
+ await flushMicrotasks();
1432
+
1433
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
1434
+ expect(trigger).toHaveFocus();
1435
+
1436
+ await user.click(screen.getByTestId('last'));
1437
+ await flushMicrotasks();
1438
+
1439
+ expect(screen.queryByTestId('popup-1')).toBe(null);
1440
+ expect(last).toHaveFocus();
1441
+ });
1442
+
1443
+ it('does not restore focus to the trigger when closed via hover', async () => {
1444
+ await render(<TestNavigationMenu />);
1445
+ const trigger = screen.getByTestId('trigger-1');
1446
+
1447
+ fireEvent.mouseEnter(trigger);
1448
+ fireEvent.mouseMove(trigger);
1449
+ clock.tick(OPEN_DELAY);
1450
+
1451
+ const popup = await screen.findByTestId('popup-1');
1452
+ expect(trigger).toHaveAttribute('aria-expanded', 'true');
1453
+
1454
+ fireEvent.mouseLeave(trigger);
1455
+ fireEvent.mouseLeave(popup);
1456
+ clock.tick(50);
1457
+
1458
+ await waitFor(() => {
1459
+ expect(screen.queryByTestId('popup-1')).toBe(null);
1460
+ });
1461
+ expect(trigger).toHaveAttribute('aria-expanded', 'false');
1462
+ expect(trigger).not.toHaveFocus();
1463
+ });
1464
+
1465
+ it('does not restore focus to the trigger when focus moves outside', async () => {
1466
+ const { user } = await render(
1467
+ <div>
1468
+ <button data-testid="first" />
1469
+ <TestNavigationMenu />
1470
+ <button data-testid="last" />
1471
+ </div>,
1472
+ );
1473
+
1474
+ const trigger = screen.getByTestId('trigger-1');
1475
+ const last = screen.getByTestId('last');
1476
+
1477
+ await act(async () => trigger.focus());
1478
+
1479
+ await user.click(trigger);
1480
+ await user.tab();
1481
+ await user.tab();
1482
+ await user.tab();
1483
+ await user.tab();
1484
+
1485
+ await waitFor(() => {
1486
+ expect(screen.queryByTestId('popup-1')).toBe(null);
1487
+ });
1488
+ expect(last).toHaveFocus();
1489
+ expect(trigger).not.toHaveFocus();
1490
+ });
1491
+ });
1492
+
1493
+ describe('patient click threshold', () => {
1494
+ it('closes if hovered then clicked after the patient threshold', async () => {
1495
+ await render(<TestNavigationMenu />);
1496
+ const trigger = screen.getByTestId('trigger-1');
1497
+
1498
+ fireEvent.click(trigger);
1499
+ clock.tick(OPEN_DELAY);
1500
+ await flushMicrotasks();
1501
+
1502
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
1503
+
1504
+ clock.tick(PATIENT_CLICK_THRESHOLD);
1505
+
1506
+ fireEvent.click(trigger);
1507
+ await flushMicrotasks();
1508
+
1509
+ expect(screen.queryByTestId('popup-1')).toBe(null);
1510
+ expect(trigger).toHaveAttribute('aria-expanded', 'false');
1511
+ });
1512
+ });
1513
+
1514
+ describe('prop: defaultValue', () => {
1515
+ it('should respect defaultValue', async () => {
1516
+ await render(<TestNavigationMenu defaultValue="item-1" />);
1517
+ const trigger = screen.getByTestId('trigger-1');
1518
+
1519
+ fireEvent.mouseEnter(trigger);
1520
+ fireEvent.mouseMove(trigger);
1521
+ clock.tick(OPEN_DELAY);
1522
+ await flushMicrotasks();
1523
+ expect(trigger).toHaveAttribute('aria-expanded', 'true');
1524
+ });
1525
+
1526
+ it('disables popup and arrow transitions while a kept portal opens', async () => {
1527
+ await render(
1528
+ <NavigationMenu.Root>
1529
+ <NavigationMenu.List>
1530
+ <NavigationMenu.Item value="item-1">
1531
+ <NavigationMenu.Trigger data-testid="trigger-1">Item 1</NavigationMenu.Trigger>
1532
+ <NavigationMenu.Content>
1533
+ <NavigationMenu.Link href="#link-1">Link 1</NavigationMenu.Link>
1534
+ </NavigationMenu.Content>
1535
+ </NavigationMenu.Item>
1536
+ </NavigationMenu.List>
1537
+ <NavigationMenu.Portal keepMounted>
1538
+ <NavigationMenu.Positioner>
1539
+ <NavigationMenu.Popup data-testid="popup-root">
1540
+ <NavigationMenu.Arrow data-testid="arrow" />
1541
+ <NavigationMenu.Viewport />
1542
+ </NavigationMenu.Popup>
1543
+ </NavigationMenu.Positioner>
1544
+ </NavigationMenu.Portal>
1545
+ </NavigationMenu.Root>,
1546
+ );
1547
+
1548
+ fireEvent.click(screen.getByTestId('trigger-1'));
1549
+
1550
+ expect(screen.getByTestId('popup-root')).toHaveStyle({
1551
+ transition: 'none',
1552
+ });
1553
+ expect(screen.getByTestId('arrow')).toHaveStyle({
1554
+ transition: 'none',
1555
+ });
1556
+
1557
+ await waitFor(() => {
1558
+ expect(screen.getByTestId('popup-root')).not.toHaveStyle({
1559
+ transition: 'none',
1560
+ });
1561
+ });
1562
+ expect(screen.getByTestId('arrow')).not.toHaveStyle({
1563
+ transition: 'none',
1564
+ });
1565
+ });
1566
+ });
1567
+
1568
+ describe('prop: onValueChange', () => {
1569
+ it('should call onValueChange when value changes', async () => {
1570
+ const onValueChange = vi.fn();
1571
+ await render(<TestNavigationMenu onValueChange={onValueChange} />);
1572
+ const trigger1 = screen.getByTestId('trigger-1');
1573
+ const trigger2 = screen.getByTestId('trigger-2');
1574
+
1575
+ fireEvent.click(trigger1);
1576
+ await flushMicrotasks();
1577
+ expect(onValueChange.mock.calls.length).toBe(1);
1578
+ expect(onValueChange.mock.lastCall?.[0]).toBe('item-1');
1579
+
1580
+ fireEvent.click(trigger2);
1581
+ await flushMicrotasks();
1582
+ expect(onValueChange.mock.calls.length).toBe(2);
1583
+ expect(onValueChange.mock.lastCall?.[0]).toBe('item-2');
1584
+ });
1585
+
1586
+ it('does not emit a duplicate onValueChange when switching items via keyboard', async () => {
1587
+ const onValueChange = vi.fn();
1588
+ const { user } = await render(<TestNavigationMenu onValueChange={onValueChange} />);
1589
+ const trigger1 = screen.getByTestId('trigger-1');
1590
+ const trigger2 = screen.getByTestId('trigger-2');
1591
+
1592
+ await user.click(trigger1);
1593
+ await flushMicrotasks();
1594
+ expect(onValueChange.mock.calls.length).toBe(1);
1595
+ expect(onValueChange.mock.lastCall?.[0]).toBe('item-1');
1596
+
1597
+ await act(async () => {
1598
+ trigger1.focus();
1599
+ });
1600
+ await user.keyboard('{ArrowRight}');
1601
+ await flushMicrotasks();
1602
+ expect(trigger2).toHaveFocus();
1603
+ expect(onValueChange.mock.calls.filter((call) => call[0] === 'item-2')).toHaveLength(0);
1604
+
1605
+ await user.keyboard('{ArrowDown}');
1606
+ await flushMicrotasks();
1607
+
1608
+ expect(onValueChange.mock.calls.filter((call) => call[0] === 'item-2')).toHaveLength(1);
1609
+ expect(trigger2).toHaveAttribute('aria-expanded', 'true');
1610
+ });
1611
+
1612
+ it.each(falsyNavigationMenuValueCases)(
1613
+ 'treats a falsy item value (%s) as a valid open value',
1614
+ async (_label, itemValue) => {
1615
+ const onValueChange = vi.fn();
1616
+ await render(
1617
+ <NavigationMenu.Root<FalsyNavigationMenuValue> onValueChange={onValueChange}>
1618
+ <NavigationMenu.List>
1619
+ <NavigationMenu.Item value={itemValue}>
1620
+ <NavigationMenu.Trigger data-testid="trigger-0">Zero</NavigationMenu.Trigger>
1621
+ <NavigationMenu.Content data-testid="popup-0">
1622
+ <NavigationMenu.Link href="#link-0">Zero link</NavigationMenu.Link>
1623
+ </NavigationMenu.Content>
1624
+ </NavigationMenu.Item>
1625
+ </NavigationMenu.List>
1626
+ <NavigationMenu.Portal>
1627
+ <NavigationMenu.Positioner>
1628
+ <NavigationMenu.Popup>
1629
+ <NavigationMenu.Viewport />
1630
+ </NavigationMenu.Popup>
1631
+ </NavigationMenu.Positioner>
1632
+ </NavigationMenu.Portal>
1633
+ </NavigationMenu.Root>,
1634
+ );
1635
+
1636
+ const trigger = screen.getByTestId('trigger-0');
1637
+
1638
+ fireEvent.click(trigger);
1639
+ await flushMicrotasks();
1640
+
1641
+ expect(onValueChange.mock.calls.length).toBe(1);
1642
+ expect(onValueChange.mock.lastCall?.[0]).toBe(itemValue);
1643
+ expect(trigger).toHaveAttribute('aria-expanded', 'true');
1644
+ expect(screen.queryByTestId('popup-0')).not.toBe(null);
1645
+ },
1646
+ );
1647
+
1648
+ it('should be controlled by value prop', async () => {
1649
+ const { setProps } = await render(<TestNavigationMenu value="item-1" />);
1650
+
1651
+ let trigger1 = screen.getByTestId('trigger-1');
1652
+ fireEvent.mouseEnter(trigger1);
1653
+ fireEvent.mouseMove(trigger1);
1654
+ clock.tick(OPEN_DELAY);
1655
+ await flushMicrotasks();
1656
+ expect(trigger1).toHaveAttribute('aria-expanded', 'true');
1657
+
1658
+ await setProps({ value: 'item-2' });
1659
+
1660
+ const trigger2 = screen.getByTestId('trigger-2');
1661
+ fireEvent.mouseLeave(trigger1);
1662
+ fireEvent.mouseEnter(trigger2);
1663
+ fireEvent.mouseMove(trigger2);
1664
+ await flushMicrotasks();
1665
+
1666
+ trigger1 = screen.getByTestId('trigger-1');
1667
+ expect(trigger1).toHaveAttribute('aria-expanded', 'false');
1668
+ expect(trigger2).toHaveAttribute('aria-expanded', 'true');
1669
+ });
1670
+
1671
+ async function assertPopupSizeIsPreservedWhenControlledValueClosesExternally(
1672
+ keepMountedPortal = false,
1673
+ ) {
1674
+ const previousAnimationsDisabled = globalThis.BASE_UI_ANIMATIONS_DISABLED;
1675
+ const originalOffsetWidth = Object.getOwnPropertyDescriptor(
1676
+ HTMLElement.prototype,
1677
+ 'offsetWidth',
1678
+ );
1679
+ const originalOffsetHeight = Object.getOwnPropertyDescriptor(
1680
+ HTMLElement.prototype,
1681
+ 'offsetHeight',
1682
+ );
1683
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = false;
1684
+
1685
+ try {
1686
+ function isPopupOpen() {
1687
+ return screen.queryByTestId('popup-1')?.hasAttribute('data-open') ?? false;
1688
+ }
1689
+
1690
+ Object.defineProperty(HTMLElement.prototype, 'offsetWidth', {
1691
+ configurable: true,
1692
+ get() {
1693
+ if (this.getAttribute('data-testid') === 'popup-root') {
1694
+ return isPopupOpen() ? 675 : 0;
1695
+ }
1696
+
1697
+ return originalOffsetWidth?.get?.call(this) ?? 0;
1698
+ },
1699
+ });
1700
+ Object.defineProperty(HTMLElement.prototype, 'offsetHeight', {
1701
+ configurable: true,
1702
+ get() {
1703
+ if (this.getAttribute('data-testid') === 'popup-root') {
1704
+ return isPopupOpen() ? 220 : 0;
1705
+ }
1706
+
1707
+ return originalOffsetHeight?.get?.call(this) ?? 0;
1708
+ },
1709
+ });
1710
+
1711
+ function ControlledNavigationMenu(props: { value: string | null }) {
1712
+ return <TestNavigationMenu value={props.value} keepMountedPortal={keepMountedPortal} />;
1713
+ }
1714
+
1715
+ const { rerender } = await render(<ControlledNavigationMenu value="item-1" />);
1716
+
1717
+ const positioner = screen.getByTestId('top-level-positioner');
1718
+ const popupRoot = screen.getByTestId('popup-root');
1719
+ const animations = mockAnimations(popupRoot);
1720
+
1721
+ animations.start();
1722
+ await rerender(<ControlledNavigationMenu value={null} />);
1723
+ await flushMicrotasks();
1724
+
1725
+ expect(popupRoot).toHaveAttribute('data-ending-style');
1726
+ expect(popupRoot.style.getPropertyValue('--popup-width')).toBe('675px');
1727
+ expect(popupRoot.style.getPropertyValue('--popup-height')).toBe('220px');
1728
+ expect(positioner.style.getPropertyValue('--positioner-width')).toBe('675px');
1729
+ expect(positioner.style.getPropertyValue('--positioner-height')).toBe('220px');
1730
+
1731
+ await act(async () => {
1732
+ animations.finish();
1733
+ await flushMicrotasks();
1734
+ });
1735
+ } finally {
1736
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = previousAnimationsDisabled;
1737
+ if (originalOffsetWidth) {
1738
+ Object.defineProperty(HTMLElement.prototype, 'offsetWidth', originalOffsetWidth);
1739
+ } else {
1740
+ Reflect.deleteProperty(HTMLElement.prototype, 'offsetWidth');
1741
+ }
1742
+ if (originalOffsetHeight) {
1743
+ Object.defineProperty(HTMLElement.prototype, 'offsetHeight', originalOffsetHeight);
1744
+ } else {
1745
+ Reflect.deleteProperty(HTMLElement.prototype, 'offsetHeight');
1746
+ }
1747
+ }
1748
+ }
1749
+
1750
+ it('preserves popup size when controlled value closes externally', async () => {
1751
+ await assertPopupSizeIsPreservedWhenControlledValueClosesExternally();
1752
+ });
1753
+
1754
+ it('preserves popup size when controlled value closes externally with keepMounted portal', async () => {
1755
+ await assertPopupSizeIsPreservedWhenControlledValueClosesExternally(true);
1756
+ });
1757
+
1758
+ it('clears activation direction when controlled value closes externally after switching triggers', async () => {
1759
+ const previousAnimationsDisabled = globalThis.BASE_UI_ANIMATIONS_DISABLED;
1760
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = false;
1761
+
1762
+ try {
1763
+ function ControlledNavigationMenu(props: { value: string | null }) {
1764
+ return <TestNavigationMenu value={props.value} />;
1765
+ }
1766
+
1767
+ const { rerender } = await render(<ControlledNavigationMenu value="item-1" />);
1768
+
1769
+ const trigger1 = screen.getByTestId('trigger-1');
1770
+ const trigger2 = screen.getByTestId('trigger-2');
1771
+
1772
+ mockBoundingClientRect(trigger1, { x: 0, y: 0, width: 80, height: 32 });
1773
+ mockBoundingClientRect(trigger2, { x: 120, y: 0, width: 80, height: 32 });
1774
+
1775
+ fireEvent.click(trigger2);
1776
+ await rerender(<ControlledNavigationMenu value="item-2" />);
1777
+
1778
+ expect(screen.getByTestId('popup-2')).toHaveAttribute('data-activation-direction', 'right');
1779
+
1780
+ const exitingContent = screen.getByTestId('popup-2');
1781
+ const animations = mockAnimations(exitingContent);
1782
+
1783
+ animations.start();
1784
+ await rerender(<ControlledNavigationMenu value={null} />);
1785
+
1786
+ expect(exitingContent).toHaveAttribute('data-ending-style');
1787
+ expect(exitingContent).not.toHaveAttribute('data-activation-direction');
1788
+
1789
+ await act(async () => {
1790
+ animations.finish();
1791
+ await flushMicrotasks();
1792
+ });
1793
+ } finally {
1794
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = previousAnimationsDisabled;
1795
+ }
1796
+ });
1797
+ });
1798
+
1799
+ describe('prop: delay', () => {
1800
+ it('respects custom delay value', async () => {
1801
+ const customDelay = 100;
1802
+ await render(<TestNavigationMenu delay={customDelay} />);
1803
+ const trigger = screen.getByTestId('trigger-1');
1804
+
1805
+ fireEvent.mouseEnter(trigger);
1806
+ fireEvent.mouseMove(trigger);
1807
+ clock.tick(customDelay - 25);
1808
+ await flushMicrotasks();
1809
+
1810
+ // Menu shouldn't be open yet since we're before the delay
1811
+ expect(screen.queryByTestId('popup-1')).toBe(null);
1812
+
1813
+ clock.tick(50);
1814
+ await flushMicrotasks();
1815
+
1816
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
1817
+ expect(trigger).toHaveAttribute('aria-expanded', 'true');
1818
+ });
1819
+ });
1820
+
1821
+ describe('prop: closeDelay', () => {
1822
+ it('respects custom closeDelay value', async () => {
1823
+ const customCloseDelay = 100;
1824
+ await render(<TestNavigationMenu closeDelay={customCloseDelay} />);
1825
+ const trigger = screen.getByTestId('trigger-1');
1826
+
1827
+ fireEvent.mouseEnter(trigger);
1828
+ fireEvent.mouseMove(trigger);
1829
+ clock.tick(OPEN_DELAY);
1830
+ await flushMicrotasks();
1831
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
1832
+
1833
+ fireEvent.mouseLeave(trigger);
1834
+ clock.tick(customCloseDelay - 25);
1835
+ await flushMicrotasks();
1836
+
1837
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
1838
+
1839
+ // Complete the closeDelay
1840
+ clock.tick(50);
1841
+ await flushMicrotasks();
1842
+
1843
+ expect(screen.queryByTestId('popup-1')).toBe(null);
1844
+ expect(trigger).toHaveAttribute('aria-expanded', 'false');
1845
+ });
1846
+ });
1847
+
1848
+ describe('prop: disabled', () => {
1849
+ it('does not open on hover when the trigger is disabled', async () => {
1850
+ const onValueChange = vi.fn();
1851
+ await render(<TestNavigationMenuWithDisabledTrigger onValueChange={onValueChange} />);
1852
+ const trigger = screen.getByTestId('trigger-1');
1853
+
1854
+ fireEvent.mouseEnter(trigger);
1855
+ fireEvent.mouseMove(trigger);
1856
+ clock.tick(OPEN_DELAY);
1857
+ await flushMicrotasks();
1858
+
1859
+ expect(trigger).toHaveAttribute('aria-expanded', 'false');
1860
+ expect(screen.queryByTestId('popup-1')).toBe(null);
1861
+ expect(onValueChange).not.toHaveBeenCalled();
1862
+ });
1863
+
1864
+ it('does not open on click when the trigger is disabled', async () => {
1865
+ const onValueChange = vi.fn();
1866
+ await render(<TestNavigationMenuWithDisabledTrigger onValueChange={onValueChange} />);
1867
+ const trigger = screen.getByTestId('trigger-1');
1868
+
1869
+ fireEvent.click(trigger);
1870
+ await flushMicrotasks();
1871
+
1872
+ expect(trigger).toHaveAttribute('aria-expanded', 'false');
1873
+ expect(screen.queryByTestId('popup-1')).toBe(null);
1874
+ expect(onValueChange).not.toHaveBeenCalled();
1875
+ });
1876
+
1877
+ it('does not open on touch when the trigger is disabled', async () => {
1878
+ const onValueChange = vi.fn();
1879
+ await render(<TestNavigationMenuWithDisabledTrigger onValueChange={onValueChange} />);
1880
+ const trigger = screen.getByTestId('trigger-1');
1881
+
1882
+ fireEvent.pointerDown(trigger, { pointerType: 'touch' });
1883
+ fireEvent.pointerUp(trigger, { pointerType: 'touch' });
1884
+ fireEvent.click(trigger);
1885
+ await flushMicrotasks();
1886
+
1887
+ expect(trigger).toHaveAttribute('aria-expanded', 'false');
1888
+ expect(screen.queryByTestId('popup-1')).toBe(null);
1889
+ expect(onValueChange).not.toHaveBeenCalled();
1890
+ });
1891
+
1892
+ it('does not open via keyboard when the trigger is disabled', async () => {
1893
+ const onValueChange = vi.fn();
1894
+ const { user } = await render(
1895
+ <TestNavigationMenuWithDisabledTrigger onValueChange={onValueChange} />,
1896
+ );
1897
+ const trigger = screen.getByTestId('trigger-1');
1898
+
1899
+ await act(async () => {
1900
+ trigger.focus();
1901
+ });
1902
+ await user.keyboard('{ArrowDown}');
1903
+ await flushMicrotasks();
1904
+
1905
+ expect(trigger).toHaveAttribute('aria-expanded', 'false');
1906
+ expect(screen.queryByTestId('popup-1')).toBe(null);
1907
+ expect(onValueChange).not.toHaveBeenCalled();
1908
+ });
1909
+ });
1910
+
1911
+ describe('prop: actionsRef', () => {
1912
+ it('exposes an unmount action and defers unmounting until it is called', async () => {
1913
+ const actionsRef = React.createRef<NavigationMenu.Root.Actions>();
1914
+
1915
+ function ControlledNavigationMenu(props: { value: string | null }) {
1916
+ return <TestNavigationMenu value={props.value} actionsRef={actionsRef} />;
1917
+ }
1918
+
1919
+ const { rerender } = await render(<ControlledNavigationMenu value="item-1" />);
1920
+
1921
+ expect(actionsRef.current).not.toBe(null);
1922
+ expect(actionsRef.current?.unmount).toBeTypeOf('function');
1923
+ expect(screen.queryByTestId('popup-root')).not.toBe(null);
1924
+
1925
+ // Closing keeps the popup mounted because `actionsRef` disables the automatic unmount.
1926
+ await rerender(<ControlledNavigationMenu value={null} />);
1927
+ await flushMicrotasks();
1928
+ expect(screen.queryByTestId('popup-root')).not.toBe(null);
1929
+
1930
+ await act(async () => {
1931
+ actionsRef.current?.unmount();
1932
+ });
1933
+ await flushMicrotasks();
1934
+
1935
+ expect(screen.queryByTestId('popup-root')).toBe(null);
1936
+ });
1937
+
1938
+ it('unmounts immediately when called while the popup is closing', async () => {
1939
+ const previousAnimationsDisabled = globalThis.BASE_UI_ANIMATIONS_DISABLED;
1940
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = false;
1941
+
1942
+ try {
1943
+ const actionsRef = React.createRef<NavigationMenu.Root.Actions>();
1944
+
1945
+ function ControlledNavigationMenu(props: { value: string | null }) {
1946
+ return <TestNavigationMenu value={props.value} actionsRef={actionsRef} />;
1947
+ }
1948
+
1949
+ const { rerender } = await render(<ControlledNavigationMenu value="item-1" />);
1950
+
1951
+ const popupRoot = screen.getByTestId('popup-root');
1952
+ const animations = mockAnimations(popupRoot);
1953
+ const closingAnimation = animations.start();
1954
+
1955
+ await rerender(<ControlledNavigationMenu value={null} />);
1956
+ await flushMicrotasks();
1957
+
1958
+ expect(popupRoot).toHaveAttribute('data-ending-style');
1959
+
1960
+ await act(async () => {
1961
+ actionsRef.current?.unmount();
1962
+ });
1963
+ await flushMicrotasks();
1964
+
1965
+ expect(screen.queryByTestId('popup-root')).toBe(null);
1966
+
1967
+ await act(async () => {
1968
+ animations.finish(closingAnimation);
1969
+ await flushMicrotasks();
1970
+ });
1971
+ } finally {
1972
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = previousAnimationsDisabled;
1973
+ }
1974
+ });
1975
+ });
1976
+
1977
+ describe('prop: side', () => {
1978
+ it.each([
1979
+ ['left in LTR', 'ltr', 'left'],
1980
+ ['inline-start in LTR', 'ltr', 'inline-start'],
1981
+ ['inline-end in RTL', 'rtl', 'inline-end'],
1982
+ ] as const)(
1983
+ 'pins the popup to the right edge when side is %s so it grows leftward',
1984
+ async (_label, direction, side) => {
1985
+ await render(
1986
+ <DirectionProvider direction={direction as TextDirection}>
1987
+ <NavigationMenu.Root>
1988
+ <NavigationMenu.List>
1989
+ <NavigationMenu.Item value="item-1">
1990
+ <NavigationMenu.Trigger data-testid="trigger-1">Item 1</NavigationMenu.Trigger>
1991
+ <NavigationMenu.Content>
1992
+ <NavigationMenu.Link href="#link-1">Link 1</NavigationMenu.Link>
1993
+ </NavigationMenu.Content>
1994
+ </NavigationMenu.Item>
1995
+ </NavigationMenu.List>
1996
+ <NavigationMenu.Portal>
1997
+ <NavigationMenu.Positioner side={side}>
1998
+ <NavigationMenu.Popup data-testid="popup-root">
1999
+ <NavigationMenu.Viewport />
2000
+ </NavigationMenu.Popup>
2001
+ </NavigationMenu.Positioner>
2002
+ </NavigationMenu.Portal>
2003
+ </NavigationMenu.Root>
2004
+ </DirectionProvider>,
2005
+ );
2006
+
2007
+ const trigger = screen.getByTestId('trigger-1');
2008
+ fireEvent.click(trigger);
2009
+ await flushMicrotasks();
2010
+
2011
+ const popup = screen.getByTestId('popup-root');
2012
+ expect(popup).toHaveAttribute('data-side', side);
2013
+ expect(popup).toHaveStyle({ position: 'absolute', top: '0px', right: '0px' });
2014
+ },
2015
+ );
2016
+ });
2017
+
2018
+ describe('tabbing', () => {
2019
+ it('moves focus through the menu correctly', async () => {
2020
+ const { user } = await render(
2021
+ <div>
2022
+ <button data-testid="first" />
2023
+ <TestNavigationMenu />
2024
+ </div>,
2025
+ );
2026
+ const trigger1 = screen.getByTestId('trigger-1');
2027
+
2028
+ await act(async () => trigger1.focus());
2029
+
2030
+ fireEvent.click(trigger1);
2031
+ await flushMicrotasks();
2032
+
2033
+ expect(screen.getByTestId('popup-1')).not.toBe(null);
2034
+ expect(trigger1).toHaveFocus();
2035
+
2036
+ await user.tab();
2037
+ expect(screen.getByText('Link 1')).toHaveFocus();
2038
+
2039
+ await user.tab();
2040
+ expect(screen.getByText('Link 2')).toHaveFocus();
2041
+
2042
+ await user.tab();
2043
+ expect(screen.getByTestId('trigger-2')).toHaveFocus();
2044
+
2045
+ fireEvent.click(screen.getByTestId('trigger-2'));
2046
+ await flushMicrotasks();
2047
+
2048
+ expect(screen.getByTestId('popup-2')).not.toBe(null);
2049
+
2050
+ await user.tab();
2051
+ expect(screen.getByText('Link 3')).toHaveFocus();
2052
+
2053
+ await user.tab();
2054
+ expect(screen.getByText('Link 4')).toHaveFocus();
2055
+
2056
+ await user.tab({ shift: true });
2057
+ await user.tab({ shift: true });
2058
+ await user.tab({ shift: true });
2059
+
2060
+ expect(trigger1).toHaveFocus();
2061
+ });
2062
+
2063
+ it('closes the menu when tabbing forward out', async () => {
2064
+ const { user } = await render(
2065
+ <div>
2066
+ <button data-testid="first" />
2067
+ <TestNavigationMenu />
2068
+ <button data-testid="last" />
2069
+ </div>,
2070
+ );
2071
+ const trigger = screen.getByTestId('trigger-1');
2072
+
2073
+ await act(async () => trigger.focus());
2074
+ fireEvent.click(trigger);
2075
+ await flushMicrotasks();
2076
+
2077
+ expect(screen.getByTestId('popup-1')).not.toBe(null);
2078
+ expect(trigger).toHaveFocus();
2079
+
2080
+ await user.tab(); // Link 1
2081
+ await user.tab(); // Link 2
2082
+ await user.tab(); // trigger 2
2083
+ await user.tab(); // last
2084
+
2085
+ expect(screen.queryByTestId('popup-1')).toBe(null);
2086
+ });
2087
+
2088
+ it('returns to the last submenu item when shift+tabbing after tabbing out of it', async () => {
2089
+ const { user } = await render(
2090
+ <div>
2091
+ <button data-testid="first" />
2092
+ <TestNavigationMenu />
2093
+ <button data-testid="last" />
2094
+ </div>,
2095
+ );
2096
+ const trigger = screen.getByTestId('trigger-1');
2097
+
2098
+ await act(async () => trigger.focus());
2099
+ fireEvent.click(trigger);
2100
+ await flushMicrotasks();
2101
+
2102
+ expect(screen.getByTestId('popup-1')).not.toBe(null);
2103
+ expect(trigger).toHaveFocus();
2104
+
2105
+ await user.tab();
2106
+ expect(screen.getByText('Link 1')).toHaveFocus();
2107
+
2108
+ await user.tab();
2109
+ expect(screen.getByText('Link 2')).toHaveFocus();
2110
+
2111
+ await user.tab();
2112
+ expect(screen.getByTestId('trigger-2')).toHaveFocus();
2113
+
2114
+ await user.tab({ shift: true });
2115
+ expect(screen.getByText('Link 2')).toHaveFocus();
2116
+ });
2117
+
2118
+ it('closes the menu when tabbing back out', async () => {
2119
+ const { user } = await render(
2120
+ <div>
2121
+ <button data-testid="first" />
2122
+ <TestNavigationMenu />
2123
+ </div>,
2124
+ );
2125
+ const trigger = screen.getByTestId('trigger-1');
2126
+
2127
+ await act(async () => trigger.focus());
2128
+ fireEvent.click(trigger);
2129
+ await flushMicrotasks();
2130
+
2131
+ expect(screen.getByTestId('popup-1')).not.toBe(null);
2132
+ expect(trigger).toHaveFocus();
2133
+
2134
+ await user.tab();
2135
+ expect(screen.getByText('Link 1')).toHaveFocus();
2136
+
2137
+ await user.tab({ shift: true }); // trigger 1
2138
+ await user.tab({ shift: true }); // first
2139
+
2140
+ expect(screen.queryByTestId('popup-1')).toBe(null);
2141
+ });
2142
+ });
2143
+
2144
+ describe('nested popups', () => {
2145
+ it('keeps a hover-open menu open when pointerdown happens on a nested dialog trigger', async () => {
2146
+ const { user } = await render(<TestNavigationMenuWithDialog />);
2147
+ const trigger = screen.getByTestId('trigger-1');
2148
+
2149
+ fireEvent.mouseEnter(trigger);
2150
+ fireEvent.mouseMove(trigger);
2151
+ clock.tick(OPEN_DELAY);
2152
+ await flushMicrotasks();
2153
+
2154
+ const popup = screen.getByTestId('popup-1');
2155
+ const dialogTrigger = screen.getByTestId('dialog-trigger');
2156
+
2157
+ fireEvent.pointerDown(dialogTrigger, { pointerType: 'mouse' });
2158
+ fireEvent.mouseLeave(popup);
2159
+
2160
+ await user.click(dialogTrigger);
2161
+
2162
+ expect(await screen.findByTestId('dialog-popup')).not.toBe(null);
2163
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
2164
+ expect(trigger).toHaveAttribute('aria-expanded', 'true');
2165
+ });
2166
+
2167
+ it('keeps the menu open when interacting with a nested dialog', async () => {
2168
+ const { user } = await render(<TestNavigationMenuWithDialog />);
2169
+ const trigger = screen.getByTestId('trigger-1');
2170
+
2171
+ await user.click(trigger);
2172
+
2173
+ await waitFor(() => {
2174
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
2175
+ });
2176
+ expect(trigger).toHaveAttribute('aria-expanded', 'true');
2177
+
2178
+ const dialogTrigger = screen.getByTestId('dialog-trigger');
2179
+ await user.click(dialogTrigger);
2180
+
2181
+ expect(await screen.findByTestId('dialog-popup')).not.toBe(null);
2182
+
2183
+ await user.click(screen.getByTestId('dialog-button'));
2184
+
2185
+ await waitFor(() => {
2186
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
2187
+ });
2188
+ expect(trigger).toHaveAttribute('aria-expanded', 'true');
2189
+ });
2190
+
2191
+ it('keeps the menu open when interacting with a nested popover', async () => {
2192
+ const { user } = await render(<TestNavigationMenuWithPopover />);
2193
+ const trigger = screen.getByTestId('trigger-1');
2194
+
2195
+ await user.click(trigger);
2196
+
2197
+ await waitFor(() => {
2198
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
2199
+ });
2200
+ expect(trigger).toHaveAttribute('aria-expanded', 'true');
2201
+
2202
+ const popoverTrigger = screen.getByTestId('popover-trigger');
2203
+ await user.click(popoverTrigger);
2204
+
2205
+ expect(await screen.findByTestId('popover-popup')).not.toBe(null);
2206
+
2207
+ await user.click(screen.getByTestId('popover-button'));
2208
+
2209
+ await waitFor(() => {
2210
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
2211
+ });
2212
+ expect(trigger).toHaveAttribute('aria-expanded', 'true');
2213
+ });
2214
+ });
2215
+
2216
+ describe('nested menus', () => {
2217
+ it('opens nested menu on hover and stays open when hovering over nested popup', async () => {
2218
+ await render(<TestNestedNavigationMenu />);
2219
+ const trigger1 = screen.getByTestId('trigger-1');
2220
+
2221
+ fireEvent.mouseEnter(trigger1);
2222
+ fireEvent.mouseMove(trigger1);
2223
+ clock.tick(OPEN_DELAY);
2224
+ await flushMicrotasks();
2225
+
2226
+ const popup1 = screen.getByTestId('popup-1');
2227
+ expect(popup1).not.toBe(null);
2228
+ expect(trigger1).toHaveAttribute('aria-expanded', 'true');
2229
+
2230
+ const nestedTrigger1 = within(popup1).getByTestId('nested-trigger-1');
2231
+
2232
+ fireEvent.mouseEnter(nestedTrigger1);
2233
+ fireEvent.mouseMove(nestedTrigger1);
2234
+ clock.tick(OPEN_DELAY);
2235
+ await flushMicrotasks();
2236
+
2237
+ const nestedPopup1 = screen.getByTestId('nested-popup-1');
2238
+ expect(nestedPopup1).not.toBe(null);
2239
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'true');
2240
+
2241
+ fireEvent.mouseEnter(nestedPopup1);
2242
+ fireEvent.mouseMove(nestedPopup1);
2243
+ await flushMicrotasks();
2244
+
2245
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
2246
+ expect(screen.queryByTestId('nested-popup-1')).not.toBe(null);
2247
+ expect(trigger1).toHaveAttribute('aria-expanded', 'true');
2248
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'true');
2249
+ });
2250
+
2251
+ it('handles inline nested menu without positioner/popup correctly', async () => {
2252
+ await render(<TestInlineNestedNavigationMenu />);
2253
+ const trigger1 = screen.getByTestId('trigger-1');
2254
+
2255
+ fireEvent.mouseEnter(trigger1);
2256
+ fireEvent.mouseMove(trigger1);
2257
+ clock.tick(OPEN_DELAY);
2258
+ await flushMicrotasks();
2259
+
2260
+ const popup1 = screen.getByTestId('popup-1');
2261
+ expect(popup1).not.toBe(null);
2262
+ expect(trigger1).toHaveAttribute('aria-expanded', 'true');
2263
+
2264
+ const nestedTrigger1 = within(popup1).getByTestId('nested-trigger-1');
2265
+
2266
+ fireEvent.mouseEnter(nestedTrigger1);
2267
+ fireEvent.mouseMove(nestedTrigger1);
2268
+ clock.tick(OPEN_DELAY);
2269
+ await flushMicrotasks();
2270
+
2271
+ const nestedPopup1 = screen.getByTestId('nested-popup-1');
2272
+ expect(nestedPopup1).not.toBe(null);
2273
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'true');
2274
+
2275
+ fireEvent.mouseEnter(nestedPopup1);
2276
+ fireEvent.mouseMove(nestedPopup1);
2277
+ await flushMicrotasks();
2278
+
2279
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
2280
+ expect(screen.queryByTestId('nested-popup-1')).not.toBe(null);
2281
+ expect(trigger1).toHaveAttribute('aria-expanded', 'true');
2282
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'true');
2283
+
2284
+ const nestedTrigger2 = within(popup1).getByTestId('nested-trigger-2');
2285
+ fireEvent.mouseEnter(nestedTrigger2);
2286
+ fireEvent.mouseMove(nestedTrigger2);
2287
+ clock.tick(OPEN_DELAY);
2288
+ await flushMicrotasks();
2289
+
2290
+ const nestedPopup2 = screen.getByTestId('nested-popup-2');
2291
+ expect(nestedPopup2).not.toBe(null);
2292
+ expect(nestedTrigger2).toHaveAttribute('aria-expanded', 'true');
2293
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'false');
2294
+ });
2295
+
2296
+ it('keeps parent menu open when hovering inline nested triggers without defaultValue', async () => {
2297
+ await render(<TestInlineNestedNavigationMenu nestedDefaultValue={null} />);
2298
+ const trigger1 = screen.getByTestId('trigger-1');
2299
+
2300
+ fireEvent.mouseEnter(trigger1);
2301
+ fireEvent.mouseMove(trigger1);
2302
+ clock.tick(OPEN_DELAY);
2303
+ await flushMicrotasks();
2304
+
2305
+ const popup1 = screen.getByTestId('popup-1');
2306
+ const nestedTrigger1 = within(popup1).getByTestId('nested-trigger-1');
2307
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'false');
2308
+
2309
+ fireEvent.mouseEnter(nestedTrigger1);
2310
+ fireEvent.mouseMove(nestedTrigger1);
2311
+ clock.tick(OPEN_DELAY);
2312
+ await flushMicrotasks();
2313
+
2314
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
2315
+ expect(trigger1).toHaveAttribute('aria-expanded', 'true');
2316
+ expect(screen.getByTestId('nested-popup-1')).not.toBe(null);
2317
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'true');
2318
+
2319
+ const nestedTrigger2 = within(popup1).getByTestId('nested-trigger-2');
2320
+ fireEvent.mouseEnter(nestedTrigger2);
2321
+ fireEvent.mouseMove(nestedTrigger2);
2322
+ clock.tick(OPEN_DELAY);
2323
+ await flushMicrotasks();
2324
+
2325
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
2326
+ expect(trigger1).toHaveAttribute('aria-expanded', 'true');
2327
+ expect(screen.getByTestId('nested-popup-2')).not.toBe(null);
2328
+ expect(nestedTrigger2).toHaveAttribute('aria-expanded', 'true');
2329
+ });
2330
+
2331
+ it('closes the parent menu after a nested submenu closes on delayed hover-out', async () => {
2332
+ const closeDelay = 200;
2333
+
2334
+ await render(<TestNestedNavigationMenu closeDelay={closeDelay} />);
2335
+ const trigger1 = screen.getByTestId('trigger-1');
2336
+
2337
+ fireEvent.mouseEnter(trigger1);
2338
+ fireEvent.mouseMove(trigger1);
2339
+ clock.tick(OPEN_DELAY);
2340
+ await flushMicrotasks();
2341
+
2342
+ const popup1 = screen.getByTestId('popup-1');
2343
+ const nestedTrigger1 = within(popup1).getByTestId('nested-trigger-1');
2344
+ const topLevelPositioner = screen.getByTestId('top-level-positioner');
2345
+
2346
+ fireEvent.mouseEnter(nestedTrigger1);
2347
+ fireEvent.mouseMove(nestedTrigger1);
2348
+ clock.tick(OPEN_DELAY);
2349
+ await flushMicrotasks();
2350
+
2351
+ const nestedPopup1 = screen.getByTestId('nested-popup-1');
2352
+ const nestedPositioner = screen.getByTestId('nested-positioner');
2353
+ expect(nestedPopup1).not.toBe(null);
2354
+
2355
+ fireEvent.mouseLeave(nestedTrigger1);
2356
+ fireEvent.mouseLeave(nestedPositioner);
2357
+ fireEvent.mouseLeave(topLevelPositioner);
2358
+ clock.tick(closeDelay);
2359
+ await flushMicrotasks();
2360
+
2361
+ expect(screen.queryByTestId('nested-popup-1')).toBe(null);
2362
+ expect(screen.queryByTestId('popup-1')).toBe(null);
2363
+ expect(trigger1).toHaveAttribute('aria-expanded', 'false');
2364
+ });
2365
+
2366
+ it('closes the parent menu when a nested link with closeOnClick is clicked', async () => {
2367
+ const { user } = await render(<TestNestedNavigationMenuWithCloseOnClick />);
2368
+ const trigger1 = screen.getByTestId('trigger-1');
2369
+
2370
+ await user.click(trigger1);
2371
+
2372
+ await waitFor(() => {
2373
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
2374
+ });
2375
+
2376
+ const popup1 = screen.getByTestId('popup-1');
2377
+ const nestedTrigger1 = within(popup1).getByTestId('nested-trigger-1');
2378
+
2379
+ fireEvent.mouseEnter(nestedTrigger1);
2380
+ fireEvent.mouseMove(nestedTrigger1);
2381
+ clock.tick(OPEN_DELAY);
2382
+ await flushMicrotasks();
2383
+
2384
+ expect(screen.queryByTestId('nested-popup-1')).not.toBe(null);
2385
+
2386
+ const nestedLink = screen.getByTestId('nested-link-1');
2387
+ await user.click(nestedLink);
2388
+
2389
+ await waitFor(() => {
2390
+ expect(screen.queryByTestId('nested-popup-1')).toBe(null);
2391
+ });
2392
+ expect(screen.queryByTestId('popup-1')).toBe(null);
2393
+ expect(trigger1).toHaveAttribute('aria-expanded', 'false');
2394
+ });
2395
+
2396
+ it('calls onValueChange on the parent root when nested closeOnClick link is clicked', async () => {
2397
+ const onValueChange = vi.fn();
2398
+ const { user } = await render(
2399
+ <TestNestedNavigationMenuWithCloseOnClick onValueChange={onValueChange} />,
2400
+ );
2401
+ const trigger1 = screen.getByTestId('trigger-1');
2402
+
2403
+ await user.click(trigger1);
2404
+
2405
+ await waitFor(() => {
2406
+ expect(screen.queryByTestId('popup-1')).not.toBe(null);
2407
+ });
2408
+
2409
+ const popup1 = screen.getByTestId('popup-1');
2410
+ const nestedTrigger1 = within(popup1).getByTestId('nested-trigger-1');
2411
+
2412
+ fireEvent.mouseEnter(nestedTrigger1);
2413
+ fireEvent.mouseMove(nestedTrigger1);
2414
+ clock.tick(OPEN_DELAY);
2415
+ await flushMicrotasks();
2416
+
2417
+ const nestedLink = screen.getByTestId('nested-link-1');
2418
+ await user.click(nestedLink);
2419
+
2420
+ await waitFor(() => {
2421
+ expect(onValueChange.mock.lastCall?.[0]).toBe(null);
2422
+ });
2423
+ });
2424
+
2425
+ it('closes all levels when a deeply nested link with closeOnClick is clicked', async () => {
2426
+ const { user } = await render(<TestDeeplyNestedNavigationMenuWithCloseOnClick />);
2427
+ const trigger1 = screen.getByTestId('trigger-1');
2428
+
2429
+ await user.click(trigger1);
2430
+
2431
+ await waitFor(() => {
2432
+ expect(screen.queryByTestId('content-1')).not.toBe(null);
2433
+ });
2434
+
2435
+ expect(screen.queryByTestId('level2-content-1')).not.toBe(null);
2436
+ expect(screen.queryByTestId('level3-content-1')).not.toBe(null);
2437
+
2438
+ const level3Link = screen.getByTestId('level3-link-1');
2439
+ await user.click(level3Link);
2440
+
2441
+ await waitFor(() => {
2442
+ expect(screen.queryByTestId('level3-content-1')).toBe(null);
2443
+ });
2444
+ expect(screen.queryByTestId('level2-content-1')).toBe(null);
2445
+ expect(screen.queryByTestId('content-1')).toBe(null);
2446
+ expect(trigger1).toHaveAttribute('aria-expanded', 'false');
2447
+ });
2448
+
2449
+ describe('inline nested viewport', () => {
2450
+ it('renders viewport content correctly for inline nested menu', async () => {
2451
+ await render(<TestInlineNestedNavigationMenu />);
2452
+ const trigger1 = screen.getByTestId('trigger-1');
2453
+
2454
+ fireEvent.mouseEnter(trigger1);
2455
+ fireEvent.mouseMove(trigger1);
2456
+ clock.tick(OPEN_DELAY);
2457
+ await flushMicrotasks();
2458
+
2459
+ const popup1 = screen.getByTestId('popup-1');
2460
+ expect(popup1).not.toBe(null);
2461
+
2462
+ const nestedTrigger1 = within(popup1).getByTestId('nested-trigger-1');
2463
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'true');
2464
+
2465
+ const nestedPopup1 = screen.getByTestId('nested-popup-1');
2466
+ expect(nestedPopup1).not.toBe(null);
2467
+ expect(screen.getByText('Nested Link 1')).not.toBe(null);
2468
+ });
2469
+
2470
+ it('switches content in viewport when hovering different nested triggers', async () => {
2471
+ await render(<TestInlineNestedNavigationMenu />);
2472
+ const trigger1 = screen.getByTestId('trigger-1');
2473
+
2474
+ fireEvent.mouseEnter(trigger1);
2475
+ fireEvent.mouseMove(trigger1);
2476
+ clock.tick(OPEN_DELAY);
2477
+ await flushMicrotasks();
2478
+
2479
+ const popup1 = screen.getByTestId('popup-1');
2480
+ const nestedTrigger1 = within(popup1).getByTestId('nested-trigger-1');
2481
+ const nestedTrigger2 = within(popup1).getByTestId('nested-trigger-2');
2482
+
2483
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'true');
2484
+ expect(screen.getByTestId('nested-popup-1')).not.toBe(null);
2485
+
2486
+ fireEvent.mouseEnter(nestedTrigger2);
2487
+ fireEvent.mouseMove(nestedTrigger2);
2488
+ clock.tick(OPEN_DELAY);
2489
+ await flushMicrotasks();
2490
+
2491
+ expect(nestedTrigger2).toHaveAttribute('aria-expanded', 'true');
2492
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'false');
2493
+ expect(screen.getByTestId('nested-popup-2')).not.toBe(null);
2494
+ expect(screen.queryByTestId('nested-popup-1')).toBe(null);
2495
+
2496
+ fireEvent.mouseEnter(nestedTrigger1);
2497
+ fireEvent.mouseMove(nestedTrigger1);
2498
+ clock.tick(OPEN_DELAY);
2499
+ await flushMicrotasks();
2500
+
2501
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'true');
2502
+ expect(nestedTrigger2).toHaveAttribute('aria-expanded', 'false');
2503
+ expect(screen.getByTestId('nested-popup-1')).not.toBe(null);
2504
+ expect(screen.queryByTestId('nested-popup-2')).toBe(null);
2505
+ });
2506
+
2507
+ it('scopes inline safePolygon pointer events to the submenu list while traversing to the viewport', async () => {
2508
+ await render(<TestInlineNestedNavigationMenu />);
2509
+ const trigger1 = screen.getByTestId('trigger-1');
2510
+
2511
+ fireEvent.mouseEnter(trigger1);
2512
+ fireEvent.mouseMove(trigger1);
2513
+ clock.tick(OPEN_DELAY);
2514
+ await flushMicrotasks();
2515
+
2516
+ const nestedList = screen.getByTestId('inline-nested-list');
2517
+ const nestedTrigger1 = screen.getByTestId('nested-trigger-1');
2518
+ const nestedViewport = screen.getByTestId('inline-nested-viewport');
2519
+
2520
+ mockBoundingClientRect(nestedTrigger1, { x: 0, y: 40, width: 100, height: 40 });
2521
+ mockBoundingClientRect(nestedViewport, { x: 200, y: 0, width: 300, height: 300 });
2522
+ fireEvent.mouseEnter(nestedTrigger1);
2523
+
2524
+ expect(nestedList.style.pointerEvents).toBe('none');
2525
+
2526
+ fireEvent.mouseLeave(nestedTrigger1, {
2527
+ clientX: 98,
2528
+ clientY: 60,
2529
+ });
2530
+
2531
+ expect(nestedList.style.pointerEvents).toBe('none');
2532
+ expect(document.body.style.pointerEvents).toBe('');
2533
+
2534
+ fireEvent.mouseMove(document, { clientX: 150, clientY: 80 });
2535
+ await flushMicrotasks();
2536
+
2537
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'true');
2538
+ expect(screen.getByTestId('nested-popup-1')).not.toBe(null);
2539
+ expect(nestedList.style.pointerEvents).toBe('none');
2540
+
2541
+ fireEvent.mouseEnter(nestedViewport);
2542
+ await flushMicrotasks();
2543
+
2544
+ expect(nestedList.style.pointerEvents).toBe('');
2545
+ });
2546
+
2547
+ it('clears inline safePolygon pointer events when the pointer leaves the traversal path', async () => {
2548
+ await render(<TestInlineNestedNavigationMenu />);
2549
+ const trigger1 = screen.getByTestId('trigger-1');
2550
+
2551
+ fireEvent.mouseEnter(trigger1);
2552
+ fireEvent.mouseMove(trigger1);
2553
+ clock.tick(OPEN_DELAY);
2554
+ await flushMicrotasks();
2555
+
2556
+ const nestedList = screen.getByTestId('inline-nested-list');
2557
+ const nestedTrigger1 = screen.getByTestId('nested-trigger-1');
2558
+ const nestedViewport = screen.getByTestId('inline-nested-viewport');
2559
+
2560
+ mockBoundingClientRect(nestedTrigger1, { x: 0, y: 40, width: 100, height: 40 });
2561
+ mockBoundingClientRect(nestedViewport, { x: 200, y: 0, width: 300, height: 300 });
2562
+ fireEvent.mouseEnter(nestedTrigger1);
2563
+
2564
+ expect(nestedList.style.pointerEvents).toBe('none');
2565
+
2566
+ fireEvent.mouseLeave(nestedTrigger1, {
2567
+ clientX: 98,
2568
+ clientY: 60,
2569
+ });
2570
+ expect(nestedList.style.pointerEvents).toBe('none');
2571
+
2572
+ fireEvent.mouseMove(document, { clientX: 40, clientY: 220 });
2573
+ await flushMicrotasks();
2574
+
2575
+ expect(nestedList.style.pointerEvents).toBe('');
2576
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'true');
2577
+ expect(screen.getByTestId('nested-popup-1')).not.toBe(null);
2578
+ });
2579
+
2580
+ it('keeps inline safePolygon pointer events when returning to the original trigger before traversing again', async () => {
2581
+ await render(<TestInlineNestedNavigationMenu />);
2582
+ const trigger1 = screen.getByTestId('trigger-1');
2583
+
2584
+ fireEvent.mouseEnter(trigger1);
2585
+ fireEvent.mouseMove(trigger1);
2586
+ clock.tick(OPEN_DELAY);
2587
+ await flushMicrotasks();
2588
+
2589
+ const nestedList = screen.getByTestId('inline-nested-list');
2590
+ const nestedTrigger1 = screen.getByTestId('nested-trigger-1');
2591
+ const nestedTrigger2 = screen.getByTestId('nested-trigger-2');
2592
+ const nestedViewport = screen.getByTestId('inline-nested-viewport');
2593
+
2594
+ mockBoundingClientRect(nestedTrigger1, { x: 0, y: 40, width: 100, height: 40 });
2595
+ mockBoundingClientRect(nestedTrigger2, { x: 0, y: 100, width: 100, height: 40 });
2596
+ mockBoundingClientRect(nestedViewport, { x: 200, y: 0, width: 300, height: 300 });
2597
+
2598
+ fireEvent.mouseEnter(nestedTrigger1);
2599
+ fireEvent.mouseLeave(nestedTrigger1, {
2600
+ clientX: 98,
2601
+ clientY: 60,
2602
+ });
2603
+ fireEvent.mouseMove(document, { clientX: 150, clientY: 80 });
2604
+ await flushMicrotasks();
2605
+ fireEvent.mouseEnter(nestedViewport);
2606
+ await flushMicrotasks();
2607
+
2608
+ fireEvent.mouseEnter(nestedTrigger2);
2609
+ fireEvent.mouseMove(nestedTrigger2);
2610
+ clock.tick(OPEN_DELAY);
2611
+ await flushMicrotasks();
2612
+
2613
+ fireEvent.mouseEnter(nestedTrigger1);
2614
+ fireEvent.mouseMove(nestedTrigger1);
2615
+ clock.tick(OPEN_DELAY);
2616
+ await flushMicrotasks();
2617
+
2618
+ expect(nestedList.style.pointerEvents).toBe('none');
2619
+
2620
+ fireEvent.mouseLeave(nestedTrigger1, {
2621
+ clientX: 98,
2622
+ clientY: 60,
2623
+ });
2624
+ fireEvent.mouseMove(document, { clientX: 150, clientY: 80 });
2625
+ await flushMicrotasks();
2626
+
2627
+ expect(nestedList.style.pointerEvents).toBe('none');
2628
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'true');
2629
+ expect(nestedTrigger2).toHaveAttribute('aria-expanded', 'false');
2630
+ expect(screen.getByTestId('nested-popup-1')).not.toBe(null);
2631
+ expect(screen.queryByTestId('nested-popup-2')).toBe(null);
2632
+ });
2633
+
2634
+ it('closes inline nested viewport when parent menu closes', async () => {
2635
+ await render(<TestInlineNestedNavigationMenu />);
2636
+ const trigger1 = screen.getByTestId('trigger-1');
2637
+
2638
+ fireEvent.mouseEnter(trigger1);
2639
+ fireEvent.mouseMove(trigger1);
2640
+ clock.tick(OPEN_DELAY);
2641
+ await flushMicrotasks();
2642
+
2643
+ const popup1 = screen.getByTestId('popup-1');
2644
+ expect(popup1).not.toBe(null);
2645
+
2646
+ const nestedTrigger1 = within(popup1).getByTestId('nested-trigger-1');
2647
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'true');
2648
+ expect(screen.getByTestId('nested-popup-1')).not.toBe(null);
2649
+
2650
+ fireEvent.mouseLeave(trigger1);
2651
+ fireEvent.mouseLeave(popup1);
2652
+ clock.tick(50); // closeDelay
2653
+ await flushMicrotasks();
2654
+
2655
+ expect(screen.queryByTestId('popup-1')).toBe(null);
2656
+ expect(screen.queryByTestId('nested-popup-1')).toBe(null);
2657
+ expect(trigger1).toHaveAttribute('aria-expanded', 'false');
2658
+ });
2659
+
2660
+ it('maintains inline viewport state when hovering between triggers and content', async () => {
2661
+ await render(<TestInlineNestedNavigationMenu />);
2662
+ const trigger1 = screen.getByTestId('trigger-1');
2663
+
2664
+ fireEvent.mouseEnter(trigger1);
2665
+ fireEvent.mouseMove(trigger1);
2666
+ clock.tick(OPEN_DELAY);
2667
+ await flushMicrotasks();
2668
+
2669
+ const popup1 = screen.getByTestId('popup-1');
2670
+
2671
+ const nestedTrigger2 = within(popup1).getByTestId('nested-trigger-2');
2672
+ fireEvent.mouseEnter(nestedTrigger2);
2673
+ fireEvent.mouseMove(nestedTrigger2);
2674
+ clock.tick(OPEN_DELAY);
2675
+ await flushMicrotasks();
2676
+
2677
+ expect(nestedTrigger2).toHaveAttribute('aria-expanded', 'true');
2678
+ const nestedPopup2 = screen.getByTestId('nested-popup-2');
2679
+ expect(nestedPopup2).not.toBe(null);
2680
+
2681
+ fireEvent.mouseEnter(nestedPopup2);
2682
+ fireEvent.mouseMove(nestedPopup2);
2683
+ await flushMicrotasks();
2684
+
2685
+ expect(nestedTrigger2).toHaveAttribute('aria-expanded', 'true');
2686
+ expect(screen.getByTestId('nested-popup-2')).not.toBe(null);
2687
+
2688
+ fireEvent.mouseEnter(nestedTrigger2);
2689
+ fireEvent.mouseMove(nestedTrigger2);
2690
+ await flushMicrotasks();
2691
+
2692
+ expect(nestedTrigger2).toHaveAttribute('aria-expanded', 'true');
2693
+ expect(screen.getByTestId('nested-popup-2')).not.toBe(null);
2694
+ });
2695
+
2696
+ it('handles click interactions on inline nested menu triggers', async () => {
2697
+ await render(<TestInlineNestedNavigationMenu />);
2698
+ const trigger1 = screen.getByTestId('trigger-1');
2699
+
2700
+ fireEvent.click(trigger1);
2701
+ await flushMicrotasks();
2702
+
2703
+ const popup1 = screen.getByTestId('popup-1');
2704
+ expect(popup1).not.toBe(null);
2705
+
2706
+ const nestedTrigger1 = within(popup1).getByTestId('nested-trigger-1');
2707
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'true');
2708
+
2709
+ const nestedTrigger2 = within(popup1).getByTestId('nested-trigger-2');
2710
+ fireEvent.click(nestedTrigger2);
2711
+ await flushMicrotasks();
2712
+
2713
+ expect(nestedTrigger2).toHaveAttribute('aria-expanded', 'true');
2714
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'false');
2715
+ expect(screen.getByTestId('nested-popup-2')).not.toBe(null);
2716
+ expect(screen.queryByTestId('nested-popup-1')).toBe(null);
2717
+
2718
+ fireEvent.click(nestedTrigger2);
2719
+ await flushMicrotasks();
2720
+
2721
+ expect(nestedTrigger2).toHaveAttribute('aria-expanded', 'true');
2722
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'false');
2723
+ expect(screen.queryByTestId('nested-popup-2')).not.toBe(null);
2724
+ expect(screen.queryByTestId('nested-popup-1')).toBe(null);
2725
+ });
2726
+
2727
+ it('adds popup-open data attributes to the active icon', async () => {
2728
+ await render(
2729
+ <NavigationMenu.Root defaultValue="item-1">
2730
+ <NavigationMenu.List>
2731
+ <NavigationMenu.Item value="item-1">
2732
+ <NavigationMenu.Trigger>
2733
+ Item 1
2734
+ <NavigationMenu.Icon data-testid="icon-1" />
2735
+ </NavigationMenu.Trigger>
2736
+ <NavigationMenu.Content>
2737
+ <NavigationMenu.Link href="#link-1">Link 1</NavigationMenu.Link>
2738
+ </NavigationMenu.Content>
2739
+ </NavigationMenu.Item>
2740
+ <NavigationMenu.Item value="item-2">
2741
+ <NavigationMenu.Trigger>
2742
+ Item 2
2743
+ <NavigationMenu.Icon data-testid="icon-2" />
2744
+ </NavigationMenu.Trigger>
2745
+ <NavigationMenu.Content>
2746
+ <NavigationMenu.Link href="#link-2">Link 2</NavigationMenu.Link>
2747
+ </NavigationMenu.Content>
2748
+ </NavigationMenu.Item>
2749
+ </NavigationMenu.List>
2750
+
2751
+ <NavigationMenu.Portal>
2752
+ <NavigationMenu.Positioner>
2753
+ <NavigationMenu.Popup>
2754
+ <NavigationMenu.Viewport />
2755
+ </NavigationMenu.Popup>
2756
+ </NavigationMenu.Positioner>
2757
+ </NavigationMenu.Portal>
2758
+ </NavigationMenu.Root>,
2759
+ );
2760
+
2761
+ expect(screen.getByTestId('icon-1')).toHaveAttribute('data-popup-open');
2762
+ expect(screen.getByTestId('icon-2')).not.toHaveAttribute('data-popup-open');
2763
+ });
2764
+
2765
+ it.each(falsyNavigationMenuValueCases)(
2766
+ 'treats a falsy value (%s) as open for inline nested trigger interactions',
2767
+ async (_label, itemValue) => {
2768
+ await render(
2769
+ <TestInlineNestedNavigationMenu
2770
+ nestedDefaultValue={itemValue}
2771
+ nestedItem1Value={itemValue}
2772
+ />,
2773
+ );
2774
+ const trigger1 = screen.getByTestId('trigger-1');
2775
+
2776
+ fireEvent.click(trigger1);
2777
+ await flushMicrotasks();
2778
+
2779
+ const popup1 = screen.getByTestId('popup-1');
2780
+ const nestedTrigger1 = within(popup1).getByTestId('nested-trigger-1');
2781
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'true');
2782
+ expect(screen.queryByTestId('nested-popup-1')).not.toBe(null);
2783
+
2784
+ fireEvent.click(nestedTrigger1);
2785
+ await flushMicrotasks();
2786
+
2787
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'true');
2788
+ expect(screen.queryByTestId('nested-popup-1')).not.toBe(null);
2789
+ },
2790
+ );
2791
+
2792
+ it('propagates a nested close with a falsy open value to the parent root', async () => {
2793
+ await render(
2794
+ <TestInlineNestedNavigationMenu
2795
+ nestedDefaultValue={false}
2796
+ nestedItem1Value={false}
2797
+ nestedLinkCloseOnClick
2798
+ />,
2799
+ );
2800
+ const trigger1 = screen.getByTestId('trigger-1');
2801
+
2802
+ fireEvent.click(trigger1);
2803
+ await flushMicrotasks();
2804
+
2805
+ const popup1 = screen.getByTestId('popup-1');
2806
+ const nestedTrigger1 = within(popup1).getByTestId('nested-trigger-1');
2807
+ expect(nestedTrigger1).toHaveAttribute('aria-expanded', 'true');
2808
+
2809
+ fireEvent.click(screen.getByText('Nested Link 1'));
2810
+ await flushMicrotasks();
2811
+
2812
+ expect(trigger1).toHaveAttribute('aria-expanded', 'false');
2813
+ expect(screen.queryByTestId('popup-1')).toBe(null);
2814
+ });
2815
+
2816
+ it('allows arrow key navigation to submenu triggers', async () => {
2817
+ const { user } = await render(<TestInlineNestedNavigationMenu />);
2818
+ const trigger1 = screen.getByTestId('trigger-1');
2819
+
2820
+ fireEvent.click(trigger1);
2821
+ await flushMicrotasks();
2822
+
2823
+ const popup1 = screen.getByTestId('popup-1');
2824
+ expect(popup1).not.toBe(null);
2825
+
2826
+ const link1 = screen.getByText('Link 1');
2827
+ await act(async () => link1.focus());
2828
+
2829
+ // Arrow down should move to nested-trigger-1
2830
+ await user.keyboard('{ArrowDown}');
2831
+
2832
+ const nestedTrigger1 = within(popup1).getByTestId('nested-trigger-1');
2833
+ expect(nestedTrigger1).toHaveFocus();
2834
+
2835
+ // Arrow down should move to nested-trigger-2
2836
+ await user.keyboard('{ArrowDown}');
2837
+
2838
+ const nestedTrigger2 = within(popup1).getByTestId('nested-trigger-2');
2839
+ expect(nestedTrigger2).toHaveFocus();
2840
+
2841
+ // Arrow up should move back to nested-trigger-1
2842
+ await user.keyboard('{ArrowUp}');
2843
+ expect(nestedTrigger1).toHaveFocus();
2844
+
2845
+ // Arrow up should move back to Link 1
2846
+ await user.keyboard('{ArrowUp}');
2847
+ expect(link1).toHaveFocus();
2848
+ });
2849
+
2850
+ it('allows arrow key navigation with 3+ levels of nesting', async () => {
2851
+ const { user } = await render(<TestDeeplyNestedNavigationMenu />);
2852
+ const trigger1 = screen.getByTestId('trigger-1');
2853
+
2854
+ fireEvent.click(trigger1);
2855
+ await flushMicrotasks();
2856
+
2857
+ const content1 = screen.getByTestId('content-1');
2858
+ expect(content1).not.toBe(null);
2859
+
2860
+ // Level 1 content contains: Link 1, Level2-trigger-1, Level2-trigger-2
2861
+ const link1 = screen.getByTestId('link-1');
2862
+ await act(async () => link1.focus());
2863
+
2864
+ // Navigate through Level 1 content items
2865
+ await user.keyboard('{ArrowDown}');
2866
+ const level2Trigger1 = screen.getByTestId('level2-trigger-1');
2867
+ expect(level2Trigger1).toHaveFocus();
2868
+
2869
+ await user.keyboard('{ArrowDown}');
2870
+ const level2Trigger2 = screen.getByTestId('level2-trigger-2');
2871
+ expect(level2Trigger2).toHaveFocus();
2872
+
2873
+ await user.keyboard('{ArrowUp}');
2874
+ expect(level2Trigger1).toHaveFocus();
2875
+
2876
+ await user.keyboard('{ArrowUp}');
2877
+ expect(link1).toHaveFocus();
2878
+
2879
+ // Now navigate into Level 2 content (which contains Level 3 triggers)
2880
+ const level2Content1 = screen.getByTestId('level2-content-1');
2881
+ const level2Link1 = within(level2Content1).getByTestId('level2-link-1');
2882
+ await act(async () => level2Link1.focus());
2883
+
2884
+ // Navigate through Level 2 content items (includes Level 3 triggers)
2885
+ await user.keyboard('{ArrowDown}');
2886
+ const level3Trigger1 = screen.getByTestId('level3-trigger-1');
2887
+ expect(level3Trigger1).toHaveFocus();
2888
+
2889
+ await user.keyboard('{ArrowDown}');
2890
+ const level3Trigger2 = screen.getByTestId('level3-trigger-2');
2891
+ expect(level3Trigger2).toHaveFocus();
2892
+
2893
+ await user.keyboard('{ArrowUp}');
2894
+ expect(level3Trigger1).toHaveFocus();
2895
+
2896
+ await user.keyboard('{ArrowUp}');
2897
+ expect(level2Link1).toHaveFocus();
2898
+ });
2899
+
2900
+ it('updates popup sizing when inline nested content is inserted while active', async () => {
2901
+ const originalResizeObserver = globalThis.ResizeObserver;
2902
+ const previousAnimationsDisabled = globalThis.BASE_UI_ANIMATIONS_DISABLED;
2903
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = false;
2904
+
2905
+ if (typeof originalResizeObserver === 'function') {
2906
+ globalThis.ResizeObserver = undefined as unknown as typeof ResizeObserver;
2907
+ }
2908
+
2909
+ try {
2910
+ await render(<TestInlineNestedNavigationMenuWithDynamicContent />);
2911
+ const trigger1 = screen.getByTestId('trigger-1');
2912
+
2913
+ fireEvent.click(trigger1);
2914
+ await flushMicrotasks();
2915
+
2916
+ const popupRoot = screen.getByTestId('popup-root');
2917
+ const positioner = screen.getByTestId('positioner');
2918
+ const animations = mockAnimations(popupRoot);
2919
+
2920
+ const popupWidth = 250;
2921
+ let popupHeight = 120;
2922
+
2923
+ Object.defineProperty(popupRoot, 'offsetWidth', {
2924
+ configurable: true,
2925
+ get: () => popupWidth,
2926
+ });
2927
+ Object.defineProperty(popupRoot, 'offsetHeight', {
2928
+ configurable: true,
2929
+ get: () => popupHeight,
2930
+ });
2931
+
2932
+ popupHeight = 220;
2933
+ animations.start();
2934
+ fireEvent.click(screen.getByTestId('insert-content'));
2935
+ await flushMicrotasks();
2936
+
2937
+ expect(screen.getByTestId('extra-content')).not.toBe(null);
2938
+ await waitFor(() => {
2939
+ expect(
2940
+ parseInt(getComputedStyle(positioner).getPropertyValue('--positioner-height'), 10),
2941
+ ).toBe(220);
2942
+ });
2943
+
2944
+ await act(async () => {
2945
+ await animations.finish();
2946
+ await flushMicrotasks();
2947
+ });
2948
+
2949
+ await waitFor(() => {
2950
+ expect(popupRoot.style.getPropertyValue('--popup-width')).toBe('auto');
2951
+ expect(popupRoot.style.getPropertyValue('--popup-height')).toBe('auto');
2952
+ expect(positioner.style.getPropertyValue('--positioner-width')).toBe('250px');
2953
+ expect(positioner.style.getPropertyValue('--positioner-height')).toBe('220px');
2954
+ });
2955
+ } finally {
2956
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = previousAnimationsDisabled;
2957
+ if (typeof originalResizeObserver === 'function') {
2958
+ globalThis.ResizeObserver = originalResizeObserver;
2959
+ }
2960
+ }
2961
+ });
2962
+
2963
+ it('does not animate popup sizing when nested default content mounts during opening', async () => {
2964
+ const previousAnimationsDisabled = globalThis.BASE_UI_ANIMATIONS_DISABLED;
2965
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = false;
2966
+
2967
+ try {
2968
+ await render(<TestInlineNestedNavigationMenu />);
2969
+ const trigger1 = screen.getByTestId('trigger-1');
2970
+
2971
+ fireEvent.click(trigger1);
2972
+
2973
+ const popupRoot = screen.getByTestId('popup-root');
2974
+ const positioner = screen.getByTestId('positioner');
2975
+
2976
+ const popupHeightValues = [120, 220];
2977
+ const popupWidth = 250;
2978
+ let popupHeight = 220;
2979
+
2980
+ Object.defineProperty(popupRoot, 'offsetWidth', {
2981
+ configurable: true,
2982
+ get: () => popupWidth,
2983
+ });
2984
+ Object.defineProperty(popupRoot, 'offsetHeight', {
2985
+ configurable: true,
2986
+ get: () => {
2987
+ const nextHeight = popupHeightValues.shift();
2988
+ if (nextHeight != null) {
2989
+ popupHeight = nextHeight;
2990
+ }
2991
+
2992
+ return popupHeight;
2993
+ },
2994
+ });
2995
+
2996
+ await flushMicrotasks();
2997
+
2998
+ expect(screen.getByTestId('nested-popup-1')).not.toBe(null);
2999
+ await waitFor(() => {
3000
+ expect(popupRoot.style.getPropertyValue('--popup-width')).toBe('auto');
3001
+ expect(popupRoot.style.getPropertyValue('--popup-height')).toBe('auto');
3002
+ expect(positioner.style.getPropertyValue('--positioner-width')).toBe('250px');
3003
+ expect(positioner.style.getPropertyValue('--positioner-height')).toBe('220px');
3004
+ });
3005
+ } finally {
3006
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = previousAnimationsDisabled;
3007
+ }
3008
+ });
3009
+
3010
+ it('does not animate popup sizing when kept nested default content first moves into the portal', async () => {
3011
+ const previousAnimationsDisabled = globalThis.BASE_UI_ANIMATIONS_DISABLED;
3012
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = false;
3013
+
3014
+ let setPopupPropertySpy: ReturnType<typeof vi.spyOn> | undefined;
3015
+
3016
+ try {
3017
+ await render(<TestInlineNestedNavigationMenu keepMountedContent />);
3018
+ const trigger1 = screen.getByTestId('trigger-1');
3019
+
3020
+ fireEvent.click(trigger1);
3021
+
3022
+ const popupRoot = screen.getByTestId('popup-root');
3023
+ const positioner = screen.getByTestId('positioner');
3024
+
3025
+ setPopupPropertySpy = vi.spyOn(popupRoot.style, 'setProperty');
3026
+
3027
+ const popupHeightValues = [120, 220];
3028
+ const popupWidth = 250;
3029
+ let popupHeight = 220;
3030
+
3031
+ Object.defineProperty(popupRoot, 'offsetWidth', {
3032
+ configurable: true,
3033
+ get: () => popupWidth,
3034
+ });
3035
+ Object.defineProperty(popupRoot, 'offsetHeight', {
3036
+ configurable: true,
3037
+ get: () => {
3038
+ const nextHeight = popupHeightValues.shift();
3039
+ if (nextHeight != null) {
3040
+ popupHeight = nextHeight;
3041
+ }
3042
+
3043
+ return popupHeight;
3044
+ },
3045
+ });
3046
+
3047
+ await flushMicrotasks();
3048
+
3049
+ expect(screen.getByTestId('nested-popup-1')).not.toHaveAttribute('hidden');
3050
+ await waitFor(() => {
3051
+ expect(popupRoot.style.getPropertyValue('--popup-width')).toBe('auto');
3052
+ expect(popupRoot.style.getPropertyValue('--popup-height')).toBe('auto');
3053
+ expect(positioner.style.getPropertyValue('--positioner-width')).toBe('250px');
3054
+ expect(positioner.style.getPropertyValue('--positioner-height')).toBe('220px');
3055
+ });
3056
+
3057
+ const popupSetPropertyCalls = setPopupPropertySpy.mock.calls as Array<
3058
+ [property: string, value: string, priority?: string]
3059
+ >;
3060
+ const fixedPopupHeightCalls = popupSetPropertyCalls
3061
+ .filter((call) => call[0] === '--popup-height')
3062
+ .map((call) => call[1])
3063
+ .filter((value) => value !== 'auto' && value !== '0px');
3064
+
3065
+ expect(fixedPopupHeightCalls.length).toBeGreaterThan(0);
3066
+ expect(fixedPopupHeightCalls.every((value) => value === '220px')).toBe(true);
3067
+ } finally {
3068
+ setPopupPropertySpy?.mockRestore();
3069
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = previousAnimationsDisabled;
3070
+ }
3071
+ });
3072
+
3073
+ it('updates popup sizing when switching kept inline nested content', async () => {
3074
+ const restoreResizeObserver = mockResizeObserver();
3075
+ const previousAnimationsDisabled = globalThis.BASE_UI_ANIMATIONS_DISABLED;
3076
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = false;
3077
+
3078
+ try {
3079
+ await render(<TestInlineNestedNavigationMenu keepMountedContent />);
3080
+ const trigger1 = screen.getByTestId('trigger-1');
3081
+
3082
+ fireEvent.click(trigger1);
3083
+ await flushMicrotasks();
3084
+
3085
+ const popupRoot = screen.getByTestId('popup-root');
3086
+ const positioner = screen.getByTestId('positioner');
3087
+ const animations = mockAnimations(popupRoot);
3088
+
3089
+ const popupWidth = 250;
3090
+ let popupHeight = 220;
3091
+
3092
+ Object.defineProperty(popupRoot, 'offsetWidth', {
3093
+ configurable: true,
3094
+ get: () => popupWidth,
3095
+ });
3096
+ Object.defineProperty(popupRoot, 'offsetHeight', {
3097
+ configurable: true,
3098
+ get: () => popupHeight,
3099
+ });
3100
+
3101
+ primeOpenPopupSize(popupRoot, positioner, 250, 220);
3102
+
3103
+ popupHeight = 300;
3104
+ animations.start();
3105
+ fireEvent.click(screen.getByTestId('nested-trigger-2'));
3106
+ await flushMicrotasks();
3107
+
3108
+ expect(screen.getByTestId('nested-popup-2')).not.toHaveAttribute('hidden');
3109
+ await waitFor(() => {
3110
+ expect(screen.getByTestId('nested-popup-1')).toHaveAttribute('hidden');
3111
+ });
3112
+ await waitFor(() => {
3113
+ expect(
3114
+ parseInt(getComputedStyle(positioner).getPropertyValue('--positioner-height'), 10),
3115
+ ).toBe(300);
3116
+ });
3117
+
3118
+ await act(async () => {
3119
+ await animations.finish();
3120
+ await flushMicrotasks();
3121
+ });
3122
+
3123
+ await waitFor(() => {
3124
+ expect(popupRoot.style.getPropertyValue('--popup-width')).toBe('auto');
3125
+ expect(popupRoot.style.getPropertyValue('--popup-height')).toBe('auto');
3126
+ expect(positioner.style.getPropertyValue('--positioner-width')).toBe('250px');
3127
+ expect(positioner.style.getPropertyValue('--positioner-height')).toBe('300px');
3128
+ });
3129
+ } finally {
3130
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = previousAnimationsDisabled;
3131
+ restoreResizeObserver();
3132
+ }
3133
+ });
3134
+
3135
+ it('updates popup sizing when a kept nested content hidden attribute changes', async () => {
3136
+ const restoreResizeObserver = mockResizeObserver();
3137
+ const previousAnimationsDisabled = globalThis.BASE_UI_ANIMATIONS_DISABLED;
3138
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = false;
3139
+
3140
+ try {
3141
+ await render(<TestInlineNestedNavigationMenu keepMountedContent />);
3142
+ const trigger1 = screen.getByTestId('trigger-1');
3143
+
3144
+ fireEvent.click(trigger1);
3145
+ await flushMicrotasks();
3146
+
3147
+ const popupRoot = screen.getByTestId('popup-root');
3148
+ const positioner = screen.getByTestId('positioner');
3149
+
3150
+ const popupWidth = 250;
3151
+ let popupHeight = 220;
3152
+
3153
+ Object.defineProperty(popupRoot, 'offsetWidth', {
3154
+ configurable: true,
3155
+ get: () => popupWidth,
3156
+ });
3157
+ Object.defineProperty(popupRoot, 'offsetHeight', {
3158
+ configurable: true,
3159
+ get: () => popupHeight,
3160
+ });
3161
+
3162
+ primeOpenPopupSize(popupRoot, positioner, 250, 220);
3163
+
3164
+ popupHeight = 300;
3165
+
3166
+ await act(async () => {
3167
+ // Contract-level check for the MutationObserver path; the sibling
3168
+ // switch test above covers the React-driven `hidden` toggle.
3169
+ screen.getByTestId('nested-popup-1').setAttribute('hidden', '');
3170
+ await flushMicrotasks();
3171
+ });
3172
+
3173
+ await waitFor(() => {
3174
+ expect(positioner.style.getPropertyValue('--positioner-width')).toBe('250px');
3175
+ expect(positioner.style.getPropertyValue('--positioner-height')).toBe('300px');
3176
+ });
3177
+ } finally {
3178
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = previousAnimationsDisabled;
3179
+ restoreResizeObserver();
3180
+ }
3181
+ });
3182
+
3183
+ it('keeps inline mutation resize interruptible when content updates again mid-transition', async () => {
3184
+ const previousAnimationsDisabled = globalThis.BASE_UI_ANIMATIONS_DISABLED;
3185
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = false;
3186
+
3187
+ try {
3188
+ await render(
3189
+ <TestInlineNestedNavigationMenuWithDynamicContent initialContentStage={1} />,
3190
+ );
3191
+ const trigger1 = screen.getByTestId('trigger-1');
3192
+
3193
+ fireEvent.click(trigger1);
3194
+ await flushMicrotasks();
3195
+
3196
+ const popupRoot = screen.getByTestId('popup-root');
3197
+ const positioner = screen.getByTestId('positioner');
3198
+ const animations = mockAnimations(popupRoot);
3199
+
3200
+ const popupWidth = 250;
3201
+ const popupHeightValues = [190, 260];
3202
+ let popupHeight = 260;
3203
+
3204
+ Object.defineProperty(popupRoot, 'offsetWidth', {
3205
+ configurable: true,
3206
+ get: () => popupWidth,
3207
+ });
3208
+ Object.defineProperty(popupRoot, 'offsetHeight', {
3209
+ configurable: true,
3210
+ get: () => {
3211
+ const nextHeight = popupHeightValues.shift();
3212
+ if (nextHeight != null) {
3213
+ popupHeight = nextHeight;
3214
+ }
3215
+
3216
+ return popupHeight;
3217
+ },
3218
+ });
3219
+
3220
+ popupRoot.style.setProperty('--popup-width', '250px');
3221
+ popupRoot.style.setProperty('--popup-height', '220px');
3222
+ positioner.style.setProperty('--positioner-width', '250px');
3223
+ positioner.style.setProperty('--positioner-height', '220px');
3224
+
3225
+ const setPropertySpy = vi.spyOn(positioner.style, 'setProperty');
3226
+
3227
+ animations.start();
3228
+ fireEvent.click(screen.getByTestId('insert-content'));
3229
+ await flushMicrotasks();
3230
+
3231
+ expect(screen.getByTestId('extra-content-2')).not.toBe(null);
3232
+ expect(
3233
+ setPropertySpy.mock.calls.some(
3234
+ (call) => call[0] === '--positioner-height' && call[1] === '190px',
3235
+ ),
3236
+ ).toBe(true);
3237
+
3238
+ await act(async () => {
3239
+ animations.finish();
3240
+ await flushMicrotasks();
3241
+ });
3242
+
3243
+ await waitFor(() => {
3244
+ expect(positioner.style.getPropertyValue('--positioner-height')).toBe('260px');
3245
+ expect(popupRoot.style.getPropertyValue('--popup-height')).toBe('auto');
3246
+ });
3247
+
3248
+ setPropertySpy.mockRestore();
3249
+ } finally {
3250
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = previousAnimationsDisabled;
3251
+ }
3252
+ });
3253
+
3254
+ it('updates popup sizing when the window is resized while the popup is open', async () => {
3255
+ const restoreResizeObserver = mockResizeObserver();
3256
+
3257
+ try {
3258
+ await render(<TestNavigationMenuWithKeepMountedContent />);
3259
+
3260
+ const popupRoot = screen.getByTestId('popup-root');
3261
+ const positioner = screen.getByTestId('positioner');
3262
+
3263
+ let popupWidth = 675;
3264
+ let popupHeight = 220;
3265
+
3266
+ Object.defineProperty(popupRoot, 'offsetWidth', {
3267
+ configurable: true,
3268
+ get: () => popupWidth,
3269
+ });
3270
+ Object.defineProperty(popupRoot, 'offsetHeight', {
3271
+ configurable: true,
3272
+ get: () => popupHeight,
3273
+ });
3274
+
3275
+ popupRoot.style.setProperty('--popup-width', 'auto');
3276
+ popupRoot.style.setProperty('--popup-height', 'auto');
3277
+ positioner.style.setProperty('--positioner-width', '675px');
3278
+ positioner.style.setProperty('--positioner-height', '220px');
3279
+
3280
+ popupWidth = 500;
3281
+ popupHeight = 180;
3282
+
3283
+ fireEvent(window, new Event('resize'));
3284
+ expect(positioner).toHaveAttribute('data-instant');
3285
+
3286
+ clock.tick(0);
3287
+ await flushMicrotasks();
3288
+ expect(positioner).toHaveAttribute('data-instant');
3289
+
3290
+ clock.tick(100);
3291
+ await flushMicrotasks();
3292
+ expect(positioner).not.toHaveAttribute('data-instant');
3293
+
3294
+ await waitFor(() => {
3295
+ expect(popupRoot.style.getPropertyValue('--popup-width')).toBe('auto');
3296
+ expect(popupRoot.style.getPropertyValue('--popup-height')).toBe('auto');
3297
+ expect(positioner.style.getPropertyValue('--positioner-width')).toBe('500px');
3298
+ expect(positioner.style.getPropertyValue('--positioner-height')).toBe('180px');
3299
+ });
3300
+ } finally {
3301
+ restoreResizeObserver();
3302
+ }
3303
+ });
3304
+
3305
+ it('updates popup sizing immediately when switching to a keepMounted trigger', async () => {
3306
+ const restoreResizeObserver = mockResizeObserver();
3307
+ const previousAnimationsDisabled = globalThis.BASE_UI_ANIMATIONS_DISABLED;
3308
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = false;
3309
+
3310
+ try {
3311
+ await render(<TestNavigationMenuWithKeepMountedContent />);
3312
+
3313
+ const popupRoot = screen.getByTestId('popup-root');
3314
+ const positioner = screen.getByTestId('positioner');
3315
+ const animations = mockAnimations(popupRoot);
3316
+
3317
+ let popupWidth = 675;
3318
+ let popupHeight = 220;
3319
+
3320
+ Object.defineProperty(popupRoot, 'offsetWidth', {
3321
+ configurable: true,
3322
+ get: () => popupWidth,
3323
+ });
3324
+ Object.defineProperty(popupRoot, 'offsetHeight', {
3325
+ configurable: true,
3326
+ get: () => popupHeight,
3327
+ });
3328
+
3329
+ popupRoot.style.setProperty('--popup-width', 'auto');
3330
+ popupRoot.style.setProperty('--popup-height', 'auto');
3331
+ positioner.style.setProperty('--positioner-width', '675px');
3332
+ positioner.style.setProperty('--positioner-height', '220px');
3333
+
3334
+ popupWidth = 500;
3335
+ popupHeight = 180;
3336
+ animations.start();
3337
+ fireEvent.click(screen.getByTestId('trigger-learn'));
3338
+ await flushMicrotasks();
3339
+
3340
+ expect(positioner.style.getPropertyValue('--positioner-width')).toBe('500px');
3341
+ expect(positioner.style.getPropertyValue('--positioner-height')).toBe('180px');
3342
+
3343
+ await act(async () => {
3344
+ animations.finish();
3345
+ await flushMicrotasks();
3346
+ });
3347
+
3348
+ await waitFor(() => {
3349
+ expect(popupRoot.style.getPropertyValue('--popup-width')).toBe('auto');
3350
+ expect(popupRoot.style.getPropertyValue('--popup-height')).toBe('auto');
3351
+ expect(positioner.style.getPropertyValue('--positioner-width')).toBe('500px');
3352
+ expect(positioner.style.getPropertyValue('--positioner-height')).toBe('180px');
3353
+ });
3354
+ } finally {
3355
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = previousAnimationsDisabled;
3356
+ restoreResizeObserver();
3357
+ }
3358
+ });
3359
+
3360
+ it('ignores the initial open size reset once a trigger switch has started', async () => {
3361
+ const restoreResizeObserver = mockResizeObserver();
3362
+ const previousAnimationsDisabled = globalThis.BASE_UI_ANIMATIONS_DISABLED;
3363
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = false;
3364
+
3365
+ try {
3366
+ function waitForAnimationFrame() {
3367
+ return new Promise<void>((resolve) => {
3368
+ requestAnimationFrame(() => {
3369
+ resolve();
3370
+ });
3371
+ });
3372
+ }
3373
+
3374
+ await render(<TestNavigationMenuWithKeepMountedContentClosed />);
3375
+
3376
+ const popupRoot = screen.getByTestId('popup-root');
3377
+ const positioner = screen.getByTestId('positioner');
3378
+ const animations = mockAnimations(popupRoot);
3379
+
3380
+ async function waitForSettledAnimations() {
3381
+ await act(async () => {
3382
+ await flushMicrotasks();
3383
+ await waitForAnimationFrame();
3384
+ await waitForAnimationFrame();
3385
+ });
3386
+ }
3387
+
3388
+ async function finishAnimation(animation: Parameters<typeof animations.finish>[0]) {
3389
+ await act(async () => {
3390
+ await animations.finish(animation);
3391
+ await flushMicrotasks();
3392
+ await waitForAnimationFrame();
3393
+ await waitForAnimationFrame();
3394
+ });
3395
+ }
3396
+
3397
+ let popupWidth = 675;
3398
+ let popupHeight = 220;
3399
+
3400
+ Object.defineProperty(popupRoot, 'offsetWidth', {
3401
+ configurable: true,
3402
+ get: () => popupWidth,
3403
+ });
3404
+ Object.defineProperty(popupRoot, 'offsetHeight', {
3405
+ configurable: true,
3406
+ get: () => popupHeight,
3407
+ });
3408
+
3409
+ const openAnimation = animations.start();
3410
+ fireEvent.click(screen.getByTestId('trigger-product'));
3411
+ await waitForSettledAnimations();
3412
+
3413
+ popupWidth = 500;
3414
+ popupHeight = 180;
3415
+
3416
+ const switchAnimation = animations.start();
3417
+ fireEvent.click(screen.getByTestId('trigger-learn'));
3418
+ await waitForSettledAnimations();
3419
+
3420
+ await waitFor(() => {
3421
+ expect(positioner.style.getPropertyValue('--positioner-width')).toBe('500px');
3422
+ expect(positioner.style.getPropertyValue('--positioner-height')).toBe('180px');
3423
+ });
3424
+
3425
+ await finishAnimation(openAnimation);
3426
+
3427
+ expect(popupRoot.style.getPropertyValue('--popup-width')).toBe('500px');
3428
+ expect(popupRoot.style.getPropertyValue('--popup-height')).toBe('180px');
3429
+
3430
+ await finishAnimation(switchAnimation);
3431
+
3432
+ await waitFor(() => {
3433
+ expect(popupRoot.style.getPropertyValue('--popup-width')).toBe('auto');
3434
+ expect(popupRoot.style.getPropertyValue('--popup-height')).toBe('auto');
3435
+ });
3436
+ } finally {
3437
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = previousAnimationsDisabled;
3438
+ restoreResizeObserver();
3439
+ }
3440
+ });
3441
+
3442
+ it('seeds the popup width from the exiting panel when reopening after hovering a top-level link', async () => {
3443
+ const previousAnimationsDisabled = globalThis.BASE_UI_ANIMATIONS_DISABLED;
3444
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = false;
3445
+
3446
+ let popupWidthSpy: ReturnType<typeof vi.spyOn> | undefined;
3447
+
3448
+ try {
3449
+ function waitForAnimationFrame() {
3450
+ return new Promise<void>((resolve) => {
3451
+ requestAnimationFrame(() => {
3452
+ resolve();
3453
+ });
3454
+ });
3455
+ }
3456
+
3457
+ await render(<TestNavigationMenuWithTopLevelLinkScopedPopupAnimation />);
3458
+
3459
+ const triggerProduct = screen.getByTestId('trigger-product');
3460
+ const triggerLearn = screen.getByTestId('trigger-learn');
3461
+ const topLevelLink = screen.getByTestId('top-level-link');
3462
+ const popupRoot = screen.getByTestId('popup-root');
3463
+ const positioner = screen.getByTestId('positioner');
3464
+ const animations = mockAnimations(popupRoot);
3465
+
3466
+ let nextPanelWidth = 675;
3467
+ let nextPanelHeight = 220;
3468
+
3469
+ Object.defineProperty(popupRoot, 'offsetWidth', {
3470
+ configurable: true,
3471
+ get: () => {
3472
+ const fixedWidth = popupRoot.style.getPropertyValue('--popup-width');
3473
+ return fixedWidth && fixedWidth !== 'auto'
3474
+ ? parseInt(fixedWidth, 10)
3475
+ : nextPanelWidth;
3476
+ },
3477
+ });
3478
+ Object.defineProperty(popupRoot, 'offsetHeight', {
3479
+ configurable: true,
3480
+ get: () => {
3481
+ const fixedHeight = popupRoot.style.getPropertyValue('--popup-height');
3482
+ return fixedHeight && fixedHeight !== 'auto'
3483
+ ? parseInt(fixedHeight, 10)
3484
+ : nextPanelHeight;
3485
+ },
3486
+ });
3487
+
3488
+ const openAnimation = animations.start();
3489
+ fireEvent.mouseEnter(triggerProduct);
3490
+ fireEvent.mouseMove(triggerProduct);
3491
+ clock.tick(OPEN_DELAY);
3492
+ await flushMicrotasks();
3493
+
3494
+ await act(async () => {
3495
+ await animations.finish(openAnimation);
3496
+ await flushMicrotasks();
3497
+ });
3498
+
3499
+ await waitFor(() => {
3500
+ expect(triggerProduct).toHaveAttribute('aria-expanded', 'true');
3501
+ expect(popupRoot.style.getPropertyValue('--popup-width')).toBe('auto');
3502
+ });
3503
+
3504
+ const productContent = screen
3505
+ .getByText('Product panel')
3506
+ .closest('.test-navigation-menu-content') as HTMLElement;
3507
+ const productContentAnimations = mockAnimations(productContent);
3508
+ const productContentCloseAnimation = productContentAnimations.start();
3509
+
3510
+ const closeAnimation = animations.start();
3511
+ fireEvent.mouseLeave(triggerProduct, { relatedTarget: topLevelLink });
3512
+ fireEvent.mouseEnter(topLevelLink);
3513
+ fireEvent.mouseMove(topLevelLink);
3514
+ clock.tick(OPEN_DELAY);
3515
+ await flushMicrotasks();
3516
+
3517
+ await waitFor(() => {
3518
+ expect(triggerProduct).toHaveAttribute('aria-expanded', 'false');
3519
+ });
3520
+
3521
+ nextPanelWidth = 500;
3522
+ nextPanelHeight = 180;
3523
+ popupWidthSpy = vi.spyOn(popupRoot.style, 'setProperty');
3524
+
3525
+ const reopenAnimation = animations.start();
3526
+ fireEvent.mouseEnter(triggerLearn);
3527
+ fireEvent.mouseMove(triggerLearn);
3528
+ clock.tick(OPEN_DELAY);
3529
+ await flushMicrotasks();
3530
+
3531
+ await act(async () => {
3532
+ await waitForAnimationFrame();
3533
+ await flushMicrotasks();
3534
+ });
3535
+
3536
+ const popupWidthCalls = (
3537
+ popupWidthSpy.mock.calls as Array<[property: string, value: string, priority?: string]>
3538
+ )
3539
+ .filter((call) => call[0] === '--popup-width')
3540
+ .map((call) => call[1]);
3541
+ const exitingWidthIndex = popupWidthCalls.indexOf('675px');
3542
+ const reopeningWidthIndex = popupWidthCalls.lastIndexOf('500px');
3543
+
3544
+ expect(triggerLearn).toHaveAttribute('aria-expanded', 'true');
3545
+ expect(positioner.style.getPropertyValue('--positioner-width')).toBe('500px');
3546
+ expect(exitingWidthIndex).toBeGreaterThan(-1);
3547
+ expect(reopeningWidthIndex).toBeGreaterThan(exitingWidthIndex);
3548
+
3549
+ await act(async () => {
3550
+ await productContentAnimations.finish(productContentCloseAnimation);
3551
+ await animations.finish(closeAnimation);
3552
+ await animations.finish(reopenAnimation);
3553
+ await flushMicrotasks();
3554
+ });
3555
+ } finally {
3556
+ popupWidthSpy?.mockRestore();
3557
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = previousAnimationsDisabled;
3558
+ }
3559
+ });
3560
+
3561
+ it.skipIf(isJSDOM)('closes on the short exit path after switching content', async () => {
3562
+ const animationsDisabled = globalThis.BASE_UI_ANIMATIONS_DISABLED;
3563
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = false;
3564
+
3565
+ try {
3566
+ function waitForAnimationFrame() {
3567
+ return new Promise<void>((resolve) => {
3568
+ requestAnimationFrame(() => {
3569
+ resolve();
3570
+ });
3571
+ });
3572
+ }
3573
+
3574
+ const onOpenChangeComplete = vi.fn();
3575
+ await render(
3576
+ <TestNavigationMenuWithScopedPopupExitAnimation
3577
+ onOpenChangeComplete={onOpenChangeComplete}
3578
+ />,
3579
+ );
3580
+
3581
+ const triggerProduct = screen.getByTestId('trigger-product');
3582
+ const triggerLearn = screen.getByTestId('trigger-learn');
3583
+
3584
+ fireEvent.click(triggerProduct);
3585
+ await flushMicrotasks();
3586
+
3587
+ const productContent = screen
3588
+ .getByText('Product panel')
3589
+ .closest('.test-navigation-menu-content') as HTMLElement;
3590
+ const productContentAnimations = mockAnimations(productContent);
3591
+ const productContentCloseAnimation = productContentAnimations.start();
3592
+
3593
+ fireEvent.click(triggerLearn);
3594
+ await flushMicrotasks();
3595
+
3596
+ let popupRoot: HTMLElement | null = null;
3597
+
3598
+ await waitFor(() => {
3599
+ popupRoot = screen.getByTestId('popup-root');
3600
+ expect(triggerProduct).toHaveAttribute('aria-expanded', 'false');
3601
+ expect(triggerLearn).toHaveAttribute('aria-expanded', 'true');
3602
+ });
3603
+
3604
+ await act(async () => {
3605
+ await waitForAnimationFrame();
3606
+ await flushMicrotasks();
3607
+ await productContentAnimations.finish(productContentCloseAnimation);
3608
+ await flushMicrotasks();
3609
+ });
3610
+
3611
+ await waitFor(() => {
3612
+ const hasRunningAnimations = popupRoot!
3613
+ .getAnimations()
3614
+ .some((animation) => animation.playState !== 'finished');
3615
+ expect(hasRunningAnimations).toBe(false);
3616
+ });
3617
+
3618
+ await act(async () => triggerLearn.focus());
3619
+
3620
+ const closeStart = performance.now();
3621
+ fireEvent.keyDown(triggerLearn, { key: 'Escape' });
3622
+ await flushMicrotasks();
3623
+
3624
+ await waitFor(() => {
3625
+ expect(onOpenChangeComplete.mock.calls.length).toBe(1);
3626
+ expect(onOpenChangeComplete.mock.calls[0][0]).toBe(false);
3627
+ });
3628
+
3629
+ expect(performance.now() - closeStart).toBeLessThan(325);
3630
+ } finally {
3631
+ globalThis.BASE_UI_ANIMATIONS_DISABLED = animationsDisabled;
3632
+ }
3633
+ });
3634
+
3635
+ it('does not collapse auto-sized popup to zero on close if measurement temporarily returns 0', async () => {
3636
+ await render(<TestInlineNestedNavigationMenuWithDynamicContent />);
3637
+ const trigger1 = screen.getByTestId('trigger-1');
3638
+
3639
+ fireEvent.click(trigger1);
3640
+ await flushMicrotasks();
3641
+
3642
+ const popupRoot = screen.getByTestId('popup-root');
3643
+ const positioner = screen.getByTestId('positioner');
3644
+
3645
+ primeOpenPopupSize(popupRoot, positioner, 250, 120);
3646
+
3647
+ Object.defineProperty(popupRoot, 'offsetWidth', {
3648
+ configurable: true,
3649
+ get: () => (screen.queryByTestId('popup-1')?.hasAttribute('data-open') ? 250 : 0),
3650
+ });
3651
+ Object.defineProperty(popupRoot, 'offsetHeight', {
3652
+ configurable: true,
3653
+ get: () => (screen.queryByTestId('popup-1')?.hasAttribute('data-open') ? 120 : 0),
3654
+ });
3655
+ Object.defineProperty(positioner, 'offsetWidth', {
3656
+ configurable: true,
3657
+ get: () => 0,
3658
+ });
3659
+ Object.defineProperty(positioner, 'offsetHeight', {
3660
+ configurable: true,
3661
+ get: () => 0,
3662
+ });
3663
+
3664
+ fireEvent.blur(trigger1, { relatedTarget: document.body });
3665
+ await flushMicrotasks();
3666
+
3667
+ expect(popupRoot.style.getPropertyValue('--popup-width')).toBe('250px');
3668
+ expect(popupRoot.style.getPropertyValue('--popup-height')).toBe('120px');
3669
+ expect(positioner.style.getPropertyValue('--positioner-width')).toBe('250px');
3670
+ expect(positioner.style.getPropertyValue('--positioner-height')).toBe('120px');
3671
+ });
3672
+
3673
+ it('tabs from the last link of the last nested panel to the next top-level trigger', async () => {
3674
+ const { user } = await render(<TestInlineNestedNavigationMenuTabForwardBoundary />);
3675
+ const trigger1 = screen.getByTestId('trigger-1');
3676
+
3677
+ await user.click(trigger1);
3678
+ await flushMicrotasks();
3679
+
3680
+ const nestedLastLink = screen.getByTestId('nested-last-link');
3681
+ await act(async () => nestedLastLink.focus());
3682
+ expect(nestedLastLink).toHaveFocus();
3683
+
3684
+ await user.tab();
3685
+
3686
+ expect(screen.getByTestId('trigger-2')).toHaveFocus();
3687
+ expect(screen.getByTestId('nested-popup-2')).not.toBe(null);
3688
+ expect(screen.getByTestId('nested-trigger-2')).toHaveAttribute('aria-expanded', 'true');
3689
+ });
3690
+
3691
+ it('tabs between nested triggers and links without opening inactive panels', async () => {
3692
+ const { user } = await render(<TestInlineNestedNavigationMenuTabFlow />);
3693
+ const triggerProduct = screen.getByTestId('trigger-product');
3694
+
3695
+ await user.click(triggerProduct);
3696
+ await flushMicrotasks();
3697
+
3698
+ const nestedDevelopersTrigger = screen.getByTestId('nested-trigger-developers');
3699
+ await act(async () => nestedDevelopersTrigger.focus());
3700
+ expect(nestedDevelopersTrigger).toHaveFocus();
3701
+
3702
+ await user.tab();
3703
+ expect(screen.getByTestId('nested-link-get-started')).toHaveFocus();
3704
+
3705
+ await user.tab({ shift: true });
3706
+ expect(nestedDevelopersTrigger).toHaveFocus();
3707
+
3708
+ await user.tab();
3709
+ expect(screen.getByTestId('nested-link-get-started')).toHaveFocus();
3710
+
3711
+ await user.tab();
3712
+ expect(screen.getByTestId('nested-link-composition')).toHaveFocus();
3713
+
3714
+ await user.tab();
3715
+ expect(screen.getByTestId('nested-trigger-design-systems')).toHaveFocus();
3716
+ expect(screen.queryByTestId('nested-popup-design-systems')).toBe(null);
3717
+
3718
+ await user.tab();
3719
+ expect(screen.getByText('Engineering Leads')).toHaveFocus();
3720
+ });
3721
+
3722
+ it('returns to the last inline submenu item when shift+tabbing after leaving it', async () => {
3723
+ const { user } = await render(<TestInlineNestedNavigationMenuTabFlow />);
3724
+ const triggerProduct = screen.getByTestId('trigger-product');
3725
+
3726
+ await user.click(triggerProduct);
3727
+ await flushMicrotasks();
3728
+
3729
+ await user.tab();
3730
+ expect(screen.getByTestId('nested-trigger-developers')).toHaveFocus();
3731
+
3732
+ await user.tab();
3733
+ expect(screen.getByTestId('nested-link-get-started')).toHaveFocus();
3734
+
3735
+ await user.tab();
3736
+ expect(screen.getByTestId('nested-link-composition')).toHaveFocus();
3737
+
3738
+ await user.tab();
3739
+ expect(screen.getByTestId('nested-trigger-design-systems')).toHaveFocus();
3740
+
3741
+ await user.tab({ shift: true });
3742
+ expect(screen.getByTestId('nested-link-composition')).toHaveFocus();
3743
+ });
3744
+ });
3745
+ });
3746
+ });
3747
+
3748
+ describe('initial open', () => {
3749
+ // A dedicated renderer without `shouldAdvanceTime` so the one-frame instant reset
3750
+ // (scheduled via a zero-delay timeout) can be observed deterministically rather
3751
+ // than racing the assertion.
3752
+ const { render, clock } = createRenderer();
3753
+
3754
+ clock.withFakeTimers();
3755
+
3756
+ it('suppresses the positioner transition for the first frame while initially open', async () => {
3757
+ await render(<TestNavigationMenu defaultValue="item-1" />);
3758
+
3759
+ // While initially open, the positioner starts with its transition suppressed so a
3760
+ // default value does not animate in from the unpositioned portal state.
3761
+ const positioner = screen.getByTestId('top-level-positioner');
3762
+ expect(positioner).toHaveAttribute('data-instant');
3763
+
3764
+ // The suppression is released on the next tick.
3765
+ clock.tick(0);
3766
+ await flushMicrotasks();
3767
+ expect(positioner).not.toHaveAttribute('data-instant');
3768
+ });
3769
+ });