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.
- package/.browserslistrc +223 -0
- package/.circleci/config.yml +361 -0
- package/.claude/launch.json +11 -0
- package/.codex/environments/environment.toml +11 -0
- package/.editorconfig +14 -0
- package/.gitattributes +6 -0
- package/.lintignore +16 -0
- package/.remarkrc.mjs +22 -0
- package/.vale.ini +35 -0
- package/.vscode/extensions.json +18 -0
- package/.vscode/settings.json +13 -0
- package/AGENTS.md +72 -0
- package/CHANGELOG.md +2648 -0
- package/CHANGELOG.old.md +220 -0
- package/CLAUDE.md +1 -0
- package/CONTRIBUTING.md +181 -0
- package/LICENSE +21 -0
- package/README.md +37 -0
- package/SECURITY.md +14 -0
- package/babel.config.mjs +49 -0
- package/docs/.env +1 -0
- package/docs/README.md +35 -0
- package/docs/next.config.mjs +178 -0
- package/docs/package.json +91 -0
- package/docs/postcss.config.js +7 -0
- package/docs/public/_headers +24 -0
- package/docs/public/_redirects +26 -0
- package/docs/public/fonts/die-grotesk-a-bold.woff2 +0 -0
- package/docs/public/fonts/die-grotesk-a-regular.woff2 +0 -0
- package/docs/public/fonts/die-grotesk-b-bold.woff2 +0 -0
- package/docs/public/fonts/die-grotesk-b-regular.woff2 +0 -0
- package/docs/public/fonts/paper-mono.woff2 +0 -0
- package/docs/public/static/apple-touch-icon.png +0 -0
- package/docs/public/static/favicon-dev.ico +0 -0
- package/docs/public/static/favicon-dev.svg +10 -0
- package/docs/public/static/favicon.ico +0 -0
- package/docs/public/static/favicon.svg +10 -0
- package/docs/public/static/logo.svg +5 -0
- package/docs/scripts/generateLlmTxt/__snapshots__/mdxToMarkdown.test.mjs.snap +1143 -0
- package/docs/scripts/generateLlmTxt/demoProcessor.mjs +172 -0
- package/docs/scripts/generateLlmTxt/index.mjs +324 -0
- package/docs/scripts/generateLlmTxt/mdxNodeHelpers.mjs +199 -0
- package/docs/scripts/generateLlmTxt/mdxToMarkdown.mjs +320 -0
- package/docs/scripts/generateLlmTxt/mdxToMarkdown.test.mjs +104 -0
- package/docs/scripts/generateLlmTxt/propsReferenceTableProcessor.mjs +174 -0
- package/docs/scripts/generateLlmTxt/releaseTimelineProcessor.mjs +80 -0
- package/docs/scripts/generateLlmTxt/resolver.mjs +49 -0
- package/docs/scripts/generateLlmTxt/typedocProcessor.mjs +50 -0
- package/docs/scripts/playground.template.tsx +5 -0
- package/docs/scripts/rehypeExtractLinkUrls.mts +46 -0
- package/docs/scripts/reportBrokenLinks.mts +16 -0
- package/docs/scripts/stylelint/no-unknown-demo-colors.test.mjs +136 -0
- package/docs/src/app/(docs)/kb/components/accordion/demos/_index.module.css +100 -0
- package/docs/src/app/(docs)/kb/components/accordion/demos/hero/css-modules/index.tsx +69 -0
- package/docs/src/app/(docs)/kb/components/accordion/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/accordion/demos/hero/tailwind/index.tsx +68 -0
- package/docs/src/app/(docs)/kb/components/accordion/demos/multiple/css-modules/index.tsx +69 -0
- package/docs/src/app/(docs)/kb/components/accordion/demos/multiple/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/accordion/demos/multiple/tailwind/index.tsx +71 -0
- package/docs/src/app/(docs)/kb/components/accordion/page.mdx +77 -0
- package/docs/src/app/(docs)/kb/components/accordion/types.md +402 -0
- package/docs/src/app/(docs)/kb/components/accordion/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/alert-dialog/demos/_index.module.css +166 -0
- package/docs/src/app/(docs)/kb/components/alert-dialog/demos/detached-triggers-controlled/css-modules/index.tsx +91 -0
- package/docs/src/app/(docs)/kb/components/alert-dialog/demos/detached-triggers-controlled/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/alert-dialog/demos/detached-triggers-controlled/tailwind/index.tsx +93 -0
- package/docs/src/app/(docs)/kb/components/alert-dialog/demos/detached-triggers-simple/css-modules/index.tsx +39 -0
- package/docs/src/app/(docs)/kb/components/alert-dialog/demos/detached-triggers-simple/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/alert-dialog/demos/detached-triggers-simple/tailwind/index.tsx +38 -0
- package/docs/src/app/(docs)/kb/components/alert-dialog/demos/hero/css-modules/index.module.css +159 -0
- package/docs/src/app/(docs)/kb/components/alert-dialog/demos/hero/css-modules/index.tsx +29 -0
- package/docs/src/app/(docs)/kb/components/alert-dialog/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/alert-dialog/demos/hero/tailwind/index.tsx +29 -0
- package/docs/src/app/(docs)/kb/components/alert-dialog/page.mdx +257 -0
- package/docs/src/app/(docs)/kb/components/alert-dialog/types.md +466 -0
- package/docs/src/app/(docs)/kb/components/alert-dialog/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/async/css-modules/index.module.css +186 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/async/css-modules/index.tsx +242 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/async/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/async/tailwind/index.tsx +260 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/auto-highlight/css-modules/index.module.css +142 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/auto-highlight/css-modules/index.tsx +80 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/auto-highlight/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/auto-highlight/tailwind/index.tsx +88 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/command-palette/css-modules/index.module.css +376 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/command-palette/css-modules/index.tsx +141 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/command-palette/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/command-palette/tailwind/index.tsx +149 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/fuzzy-matching/css-modules/index.module.css +176 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/fuzzy-matching/css-modules/index.tsx +168 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/fuzzy-matching/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/fuzzy-matching/tailwind/index.tsx +182 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/grid/css-modules/index.module.css +366 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/grid/css-modules/index.tsx +251 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/grid/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/grid/tailwind/index.tsx +254 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/grouped/css-modules/index.module.css +174 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/grouped/css-modules/index.tsx +106 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/grouped/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/grouped/tailwind/index.tsx +118 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/hero/css-modules/index.module.css +152 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/hero/css-modules/index.tsx +80 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/hero/tailwind/index.tsx +88 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/inline/css-modules/index.module.css +141 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/inline/css-modules/index.tsx +77 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/inline/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/inline/tailwind/index.tsx +83 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/limit/css-modules/index.module.css +146 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/limit/css-modules/index.tsx +116 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/limit/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/limit/tailwind/index.tsx +124 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/virtualized/css-modules/index.module.css +138 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/virtualized/css-modules/index.tsx +154 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/virtualized/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/demos/virtualized/tailwind/index.tsx +151 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/page.mdx +285 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/types.md +1088 -0
- package/docs/src/app/(docs)/kb/components/autocomplete/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/avatar/demos/hero/css-modules/index.module.css +37 -0
- package/docs/src/app/(docs)/kb/components/avatar/demos/hero/css-modules/index.tsx +21 -0
- package/docs/src/app/(docs)/kb/components/avatar/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/avatar/demos/hero/tailwind/index.tsx +22 -0
- package/docs/src/app/(docs)/kb/components/avatar/page.mdx +58 -0
- package/docs/src/app/(docs)/kb/components/avatar/types.md +134 -0
- package/docs/src/app/(docs)/kb/components/avatar/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/button/demos/hero/css-modules/index.module.css +64 -0
- package/docs/src/app/(docs)/kb/components/button/demos/hero/css-modules/index.tsx +6 -0
- package/docs/src/app/(docs)/kb/components/button/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/button/demos/hero/tailwind/index.tsx +10 -0
- package/docs/src/app/(docs)/kb/components/button/demos/loading/css-modules/index.module.css +64 -0
- package/docs/src/app/(docs)/kb/components/button/demos/loading/css-modules/index.tsx +24 -0
- package/docs/src/app/(docs)/kb/components/button/demos/loading/index.ts +5 -0
- package/docs/src/app/(docs)/kb/components/button/demos/loading/tailwind/index.tsx +23 -0
- package/docs/src/app/(docs)/kb/components/button/page.mdx +81 -0
- package/docs/src/app/(docs)/kb/components/button/types.md +53 -0
- package/docs/src/app/(docs)/kb/components/button/types.ts +4 -0
- package/docs/src/app/(docs)/kb/components/checkbox/demos/hero/css-modules/Checkbox.tsx +58 -0
- package/docs/src/app/(docs)/kb/components/checkbox/demos/hero/css-modules/index.module.css +63 -0
- package/docs/src/app/(docs)/kb/components/checkbox/demos/hero/css-modules/index.tsx +5 -0
- package/docs/src/app/(docs)/kb/components/checkbox/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/checkbox/demos/hero/tailwind/index.tsx +34 -0
- package/docs/src/app/(docs)/kb/components/checkbox/page.mdx +121 -0
- package/docs/src/app/(docs)/kb/components/checkbox/types.md +209 -0
- package/docs/src/app/(docs)/kb/components/checkbox/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/checkbox-group/demos/hero/css-modules/index.module.css +76 -0
- package/docs/src/app/(docs)/kb/components/checkbox-group/demos/hero/css-modules/index.tsx +63 -0
- package/docs/src/app/(docs)/kb/components/checkbox-group/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/checkbox-group/demos/hero/tailwind/index.tsx +74 -0
- package/docs/src/app/(docs)/kb/components/checkbox-group/demos/nested/css-modules/index.module.css +76 -0
- package/docs/src/app/(docs)/kb/components/checkbox-group/demos/nested/css-modules/index.tsx +174 -0
- package/docs/src/app/(docs)/kb/components/checkbox-group/demos/nested/index.ts +4 -0
- package/docs/src/app/(docs)/kb/components/checkbox-group/demos/parent/css-modules/index.module.css +76 -0
- package/docs/src/app/(docs)/kb/components/checkbox-group/demos/parent/css-modules/index.tsx +101 -0
- package/docs/src/app/(docs)/kb/components/checkbox-group/demos/parent/index.ts +4 -0
- package/docs/src/app/(docs)/kb/components/checkbox-group/page.mdx +162 -0
- package/docs/src/app/(docs)/kb/components/checkbox-group/types.md +87 -0
- package/docs/src/app/(docs)/kb/components/checkbox-group/types.ts +4 -0
- package/docs/src/app/(docs)/kb/components/collapsible/demos/hero/css-modules/index.module.css +112 -0
- package/docs/src/app/(docs)/kb/components/collapsible/demos/hero/css-modules/index.tsx +36 -0
- package/docs/src/app/(docs)/kb/components/collapsible/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/collapsible/demos/hero/tailwind/index.tsx +35 -0
- package/docs/src/app/(docs)/kb/components/collapsible/page.mdx +56 -0
- package/docs/src/app/(docs)/kb/components/collapsible/types.md +168 -0
- package/docs/src/app/(docs)/kb/components/collapsible/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/async-multiple/css-modules/index.module.css +341 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/async-multiple/css-modules/index.tsx +361 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/async-multiple/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/async-multiple/tailwind/index.tsx +384 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/async-single/css-modules/index.module.css +282 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/async-single/css-modules/index.tsx +337 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/async-single/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/async-single/tailwind/index.tsx +363 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/creatable/css-modules/index.module.css +496 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/creatable/css-modules/index.tsx +286 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/creatable/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/creatable/tailwind/index.tsx +306 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/grouped/css-modules/index.module.css +240 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/grouped/css-modules/index.tsx +145 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/grouped/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/grouped/tailwind/index.tsx +164 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/hero/css-modules/index.module.css +221 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/hero/css-modules/index.tsx +128 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/hero/tailwind/index.tsx +143 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/input-inside-popup/css-modules/index.module.css +273 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/input-inside-popup/css-modules/index.tsx +290 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/input-inside-popup/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/input-inside-popup/tailwind/index.tsx +303 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/multiple/css-modules/index.module.css +312 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/multiple/css-modules/index.tsx +121 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/multiple/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/multiple/tailwind/index.tsx +129 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/virtualized/css-modules/index.module.css +150 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/virtualized/css-modules/index.tsx +172 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/virtualized/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/combobox/demos/virtualized/tailwind/index.tsx +175 -0
- package/docs/src/app/(docs)/kb/components/combobox/page.mdx +358 -0
- package/docs/src/app/(docs)/kb/components/combobox/types.md +1278 -0
- package/docs/src/app/(docs)/kb/components/combobox/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/context-menu/demos/hero/css-modules/index.module.css +108 -0
- package/docs/src/app/(docs)/kb/components/context-menu/demos/hero/css-modules/index.tsx +24 -0
- package/docs/src/app/(docs)/kb/components/context-menu/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/context-menu/demos/hero/tailwind/index.tsx +28 -0
- package/docs/src/app/(docs)/kb/components/context-menu/demos/submenu/css-modules/index.module.css +191 -0
- package/docs/src/app/(docs)/kb/components/context-menu/demos/submenu/css-modules/index.tsx +63 -0
- package/docs/src/app/(docs)/kb/components/context-menu/demos/submenu/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/context-menu/demos/submenu/tailwind/index.tsx +66 -0
- package/docs/src/app/(docs)/kb/components/context-menu/page.mdx +156 -0
- package/docs/src/app/(docs)/kb/components/context-menu/types.md +1129 -0
- package/docs/src/app/(docs)/kb/components/context-menu/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/_index.module.css +158 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/close-confirmation/css-modules/index.module.css +219 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/close-confirmation/css-modules/index.tsx +91 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/close-confirmation/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/close-confirmation/tailwind/index.tsx +97 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/detached-triggers-controlled/css-modules/index.tsx +66 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/detached-triggers-controlled/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/detached-triggers-controlled/tailwind/index.tsx +83 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/detached-triggers-simple/css-modules/index.tsx +33 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/detached-triggers-simple/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/detached-triggers-simple/tailwind/index.tsx +37 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/hero/css-modules/index.module.css +151 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/hero/css-modules/index.tsx +24 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/hero/tailwind/index.tsx +27 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/inside-scroll/css-modules/index.module.css +273 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/inside-scroll/css-modules/index.tsx +130 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/inside-scroll/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/inside-scroll/tailwind/index.tsx +133 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/nested/css-modules/index.module.css +218 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/nested/css-modules/index.tsx +39 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/nested/index.ts +5 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/nested/tailwind/index.tsx +46 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/outside-scroll/css-modules/index.module.css +328 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/outside-scroll/css-modules/index.tsx +173 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/outside-scroll/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/outside-scroll/tailwind/index.tsx +189 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/uncontained/css-modules/index.module.css +198 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/uncontained/css-modules/index.tsx +39 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/uncontained/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/dialog/demos/uncontained/tailwind/index.tsx +43 -0
- package/docs/src/app/(docs)/kb/components/dialog/page.mdx +356 -0
- package/docs/src/app/(docs)/kb/components/dialog/types.md +512 -0
- package/docs/src/app/(docs)/kb/components/dialog/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/close-confirmation/css-modules/index.module.css +299 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/close-confirmation/css-modules/index.tsx +100 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/close-confirmation/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/close-confirmation/tailwind/index.tsx +110 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/hero/css-modules/index.module.css +190 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/hero/css-modules/index.tsx +26 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/hero/tailwind/index.tsx +29 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/indent-provider/css-modules/index.module.css +236 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/indent-provider/css-modules/index.tsx +40 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/indent-provider/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/indent-provider/tailwind/index.tsx +45 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/mobile-nav/css-modules/index.module.css +385 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/mobile-nav/css-modules/index.tsx +132 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/mobile-nav/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/mobile-nav/tailwind/index.tsx +151 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/nested/css-modules/index.module.css +383 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/nested/css-modules/index.tsx +112 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/nested/index.ts +5 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/nested/tailwind/index.tsx +136 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/non-modal/css-modules/index.module.css +195 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/non-modal/css-modules/index.tsx +26 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/non-modal/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/non-modal/tailwind/index.tsx +29 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/position/css-modules/index.module.css +181 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/position/css-modules/index.tsx +27 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/position/index.ts +5 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/position/tailwind/index.tsx +32 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/snap-points/css-modules/index.module.css +255 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/snap-points/css-modules/index.tsx +50 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/snap-points/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/snap-points/tailwind/index.tsx +55 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/swipe-area/css-modules/index.module.css +271 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/swipe-area/css-modules/index.tsx +39 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/swipe-area/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/swipe-area/tailwind/index.tsx +45 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/uncontained/css-modules/index.module.css +273 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/uncontained/css-modules/index.tsx +53 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/uncontained/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/uncontained/tailwind/index.tsx +59 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/virtual-keyboard-aware/css-modules/index.module.css +434 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/virtual-keyboard-aware/css-modules/index.tsx +75 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/virtual-keyboard-aware/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/drawer/demos/virtual-keyboard-aware/tailwind/index.tsx +88 -0
- package/docs/src/app/(docs)/kb/components/drawer/page.mdx +452 -0
- package/docs/src/app/(docs)/kb/components/drawer/types.md +796 -0
- package/docs/src/app/(docs)/kb/components/drawer/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/field/demos/hero/css-modules/index.module.css +84 -0
- package/docs/src/app/(docs)/kb/components/field/demos/hero/css-modules/index.tsx +17 -0
- package/docs/src/app/(docs)/kb/components/field/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/field/demos/hero/tailwind/index.tsx +21 -0
- package/docs/src/app/(docs)/kb/components/field/page.mdx +77 -0
- package/docs/src/app/(docs)/kb/components/field/types.md +458 -0
- package/docs/src/app/(docs)/kb/components/field/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/fieldset/demos/hero/css-modules/index.module.css +106 -0
- package/docs/src/app/(docs)/kb/components/fieldset/demos/hero/css-modules/index.tsx +21 -0
- package/docs/src/app/(docs)/kb/components/fieldset/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/fieldset/demos/hero/tailwind/index.tsx +32 -0
- package/docs/src/app/(docs)/kb/components/fieldset/page.mdx +53 -0
- package/docs/src/app/(docs)/kb/components/fieldset/types.md +72 -0
- package/docs/src/app/(docs)/kb/components/fieldset/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/form/demos/form-action/css-modules/index.module.css +145 -0
- package/docs/src/app/(docs)/kb/components/form/demos/form-action/css-modules/index.tsx +62 -0
- package/docs/src/app/(docs)/kb/components/form/demos/form-action/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/form/demos/form-action/tailwind/index.tsx +72 -0
- package/docs/src/app/(docs)/kb/components/form/demos/hero/css-modules/index.module.css +145 -0
- package/docs/src/app/(docs)/kb/components/form/demos/hero/css-modules/index.tsx +67 -0
- package/docs/src/app/(docs)/kb/components/form/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/form/demos/hero/tailwind/index.tsx +73 -0
- package/docs/src/app/(docs)/kb/components/form/demos/zod/css-modules/index.module.css +145 -0
- package/docs/src/app/(docs)/kb/components/form/demos/zod/css-modules/index.tsx +55 -0
- package/docs/src/app/(docs)/kb/components/form/demos/zod/index.ts +5 -0
- package/docs/src/app/(docs)/kb/components/form/demos/zod/tailwind/index.tsx +67 -0
- package/docs/src/app/(docs)/kb/components/form/page.mdx +91 -0
- package/docs/src/app/(docs)/kb/components/form/types.md +88 -0
- package/docs/src/app/(docs)/kb/components/form/types.ts +4 -0
- package/docs/src/app/(docs)/kb/components/input/demos/hero/css-modules/index.module.css +58 -0
- package/docs/src/app/(docs)/kb/components/input/demos/hero/css-modules/index.tsx +11 -0
- package/docs/src/app/(docs)/kb/components/input/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/input/demos/hero/tailwind/index.tsx +13 -0
- package/docs/src/app/(docs)/kb/components/input/page.mdx +51 -0
- package/docs/src/app/(docs)/kb/components/input/types.md +92 -0
- package/docs/src/app/(docs)/kb/components/input/types.ts +4 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/_index.module.css +250 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/arrow/css-modules/index.module.css +199 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/arrow/css-modules/index.tsx +47 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/arrow/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/arrow/tailwind/index.tsx +49 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/checkbox-items/css-modules/index.module.css +172 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/checkbox-items/css-modules/index.tsx +85 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/checkbox-items/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/checkbox-items/tailwind/index.tsx +87 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-controlled/css-modules/index.tsx +103 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-controlled/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-controlled/tailwind/index.tsx +112 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-full/css-modules/index.module.css +75 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-full/css-modules/index.tsx +90 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-full/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-full/tailwind/index.tsx +150 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-simple/css-modules/index.tsx +48 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-simple/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/detached-triggers-simple/tailwind/index.tsx +56 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/group-labels/css-modules/index.module.css +190 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/group-labels/css-modules/index.tsx +113 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/group-labels/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/group-labels/tailwind/index.tsx +119 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/hero/css-modules/index.module.css +160 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/hero/css-modules/index.tsx +42 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/hero/tailwind/index.tsx +44 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/open-on-hover/css-modules/index.module.css +160 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/open-on-hover/css-modules/index.tsx +39 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/open-on-hover/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/open-on-hover/tailwind/index.tsx +44 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/radio-items/css-modules/index.module.css +171 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/radio-items/css-modules/index.tsx +72 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/radio-items/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/radio-items/tailwind/index.tsx +74 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/submenu/css-modules/index.module.css +193 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/submenu/css-modules/index.tsx +84 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/submenu/index.ts +5 -0
- package/docs/src/app/(docs)/kb/components/menu/demos/submenu/tailwind/index.tsx +93 -0
- package/docs/src/app/(docs)/kb/components/menu/page.mdx +450 -0
- package/docs/src/app/(docs)/kb/components/menu/types.md +1205 -0
- package/docs/src/app/(docs)/kb/components/menu/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/menubar/demos/hero/css-modules/index.module.css +185 -0
- package/docs/src/app/(docs)/kb/components/menubar/demos/hero/css-modules/index.tsx +151 -0
- package/docs/src/app/(docs)/kb/components/menubar/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/menubar/demos/hero/tailwind/index.tsx +198 -0
- package/docs/src/app/(docs)/kb/components/menubar/page.mdx +79 -0
- package/docs/src/app/(docs)/kb/components/menubar/types.md +61 -0
- package/docs/src/app/(docs)/kb/components/menubar/types.ts +4 -0
- package/docs/src/app/(docs)/kb/components/meter/demos/hero/css-modules/index.module.css +49 -0
- package/docs/src/app/(docs)/kb/components/meter/demos/hero/css-modules/index.tsx +14 -0
- package/docs/src/app/(docs)/kb/components/meter/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/meter/demos/hero/tailwind/index.tsx +15 -0
- package/docs/src/app/(docs)/kb/components/meter/page.mdx +70 -0
- package/docs/src/app/(docs)/kb/components/meter/types.md +152 -0
- package/docs/src/app/(docs)/kb/components/meter/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/navigation-menu/demos/hero/css-modules/index.module.css +348 -0
- package/docs/src/app/(docs)/kb/components/navigation-menu/demos/hero/css-modules/index.tsx +146 -0
- package/docs/src/app/(docs)/kb/components/navigation-menu/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/navigation-menu/demos/hero/tailwind/index.tsx +170 -0
- package/docs/src/app/(docs)/kb/components/navigation-menu/demos/nested/css-modules/index.module.css +363 -0
- package/docs/src/app/(docs)/kb/components/navigation-menu/demos/nested/css-modules/index.tsx +169 -0
- package/docs/src/app/(docs)/kb/components/navigation-menu/demos/nested/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/navigation-menu/demos/nested/tailwind/index.tsx +199 -0
- package/docs/src/app/(docs)/kb/components/navigation-menu/demos/nested-inline/css-modules/index.module.css +579 -0
- package/docs/src/app/(docs)/kb/components/navigation-menu/demos/nested-inline/css-modules/index.tsx +145 -0
- package/docs/src/app/(docs)/kb/components/navigation-menu/demos/nested-inline/data.ts +126 -0
- package/docs/src/app/(docs)/kb/components/navigation-menu/demos/nested-inline/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/navigation-menu/demos/nested-inline/tailwind/index.tsx +191 -0
- package/docs/src/app/(docs)/kb/components/navigation-menu/page.mdx +185 -0
- package/docs/src/app/(docs)/kb/components/navigation-menu/types.md +643 -0
- package/docs/src/app/(docs)/kb/components/navigation-menu/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/number-field/demos/hero/css-modules/index.module.css +136 -0
- package/docs/src/app/(docs)/kb/components/number-field/demos/hero/css-modules/index.tsx +81 -0
- package/docs/src/app/(docs)/kb/components/number-field/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/number-field/demos/hero/tailwind/index.tsx +86 -0
- package/docs/src/app/(docs)/kb/components/number-field/page.mdx +86 -0
- package/docs/src/app/(docs)/kb/components/number-field/types.md +577 -0
- package/docs/src/app/(docs)/kb/components/number-field/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/alphanumeric/css-modules/index.module.css +73 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/alphanumeric/css-modules/index.tsx +37 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/alphanumeric/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/alphanumeric/tailwind/index.tsx +36 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/custom-sanitize/css-modules/index.module.css +153 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/custom-sanitize/css-modules/index.tsx +74 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/custom-sanitize/index.ts +6 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/custom-sanitize/useInvalidFeedback.ts +61 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/focused-placeholder/css-modules/index.module.css +81 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/focused-placeholder/css-modules/index.tsx +36 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/focused-placeholder/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/focused-placeholder/tailwind/index.tsx +35 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/grouped/css-modules/index.module.css +75 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/grouped/css-modules/index.tsx +38 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/grouped/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/grouped/tailwind/index.tsx +37 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/hero/css-modules/index.module.css +69 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/hero/css-modules/index.tsx +35 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/hero/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/hero/tailwind/index.tsx +34 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/password/css-modules/index.module.css +74 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/password/css-modules/index.tsx +36 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/password/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/otp-field/demos/password/tailwind/index.tsx +35 -0
- package/docs/src/app/(docs)/kb/components/otp-field/page.mdx +159 -0
- package/docs/src/app/(docs)/kb/components/otp-field/types.md +272 -0
- package/docs/src/app/(docs)/kb/components/otp-field/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/page.mdx +2013 -0
- package/docs/src/app/(docs)/kb/components/popover/demos/_index.module.css +184 -0
- package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-controlled/css-modules/index.tsx +64 -0
- package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-controlled/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-controlled/tailwind/index.tsx +69 -0
- package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-full/css-modules/index.module.css +271 -0
- package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-full/css-modules/index.tsx +89 -0
- package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-full/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-full/tailwind/index.tsx +130 -0
- package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-simple/css-modules/index.tsx +30 -0
- package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-simple/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/popover/demos/detached-triggers-simple/tailwind/index.tsx +32 -0
- package/docs/src/app/(docs)/kb/components/popover/demos/hero/css-modules/index.tsx +22 -0
- package/docs/src/app/(docs)/kb/components/popover/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/popover/demos/hero/tailwind/index.tsx +23 -0
- package/docs/src/app/(docs)/kb/components/popover/demos/open-on-hover/css-modules/index.tsx +24 -0
- package/docs/src/app/(docs)/kb/components/popover/demos/open-on-hover/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/popover/demos/open-on-hover/tailwind/index.tsx +25 -0
- package/docs/src/app/(docs)/kb/components/popover/page.mdx +273 -0
- package/docs/src/app/(docs)/kb/components/popover/types.md +629 -0
- package/docs/src/app/(docs)/kb/components/popover/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-controlled/css-modules/index.tsx +132 -0
- package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-controlled/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-controlled/tailwind/index.tsx +134 -0
- package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-full/css-modules/index.module.css +204 -0
- package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-full/css-modules/index.tsx +104 -0
- package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-full/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-full/tailwind/index.tsx +109 -0
- package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-simple/css-modules/index.tsx +46 -0
- package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-simple/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/preview-card/demos/detached-triggers-simple/tailwind/index.tsx +45 -0
- package/docs/src/app/(docs)/kb/components/preview-card/demos/hero/css-modules/index.tsx +40 -0
- package/docs/src/app/(docs)/kb/components/preview-card/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/preview-card/demos/hero/tailwind/index.tsx +39 -0
- package/docs/src/app/(docs)/kb/components/preview-card/demos/index.module.css +221 -0
- package/docs/src/app/(docs)/kb/components/preview-card/page.mdx +250 -0
- package/docs/src/app/(docs)/kb/components/preview-card/types.md +525 -0
- package/docs/src/app/(docs)/kb/components/preview-card/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/progress/demos/hero/css-modules/index.module.css +49 -0
- package/docs/src/app/(docs)/kb/components/progress/demos/hero/css-modules/index.tsx +26 -0
- package/docs/src/app/(docs)/kb/components/progress/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/progress/demos/hero/tailwind/index.tsx +27 -0
- package/docs/src/app/(docs)/kb/components/progress/page.mdx +70 -0
- package/docs/src/app/(docs)/kb/components/progress/types.md +216 -0
- package/docs/src/app/(docs)/kb/components/progress/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/radio/demos/hero/css-modules/index.module.css +85 -0
- package/docs/src/app/(docs)/kb/components/radio/demos/hero/css-modules/index.tsx +37 -0
- package/docs/src/app/(docs)/kb/components/radio/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/radio/demos/hero/tailwind/index.tsx +49 -0
- package/docs/src/app/(docs)/kb/components/radio/page.mdx +155 -0
- package/docs/src/app/(docs)/kb/components/radio/types.md +147 -0
- package/docs/src/app/(docs)/kb/components/radio/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/radio-group/types.md +96 -0
- package/docs/src/app/(docs)/kb/components/radio-group/types.ts +4 -0
- package/docs/src/app/(docs)/kb/components/scroll-area/demos/both/css-modules/index.module.css +95 -0
- package/docs/src/app/(docs)/kb/components/scroll-area/demos/both/css-modules/index.tsx +27 -0
- package/docs/src/app/(docs)/kb/components/scroll-area/demos/both/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/scroll-area/demos/both/tailwind/index.tsx +32 -0
- package/docs/src/app/(docs)/kb/components/scroll-area/demos/hero/css-modules/index.module.css +84 -0
- package/docs/src/app/(docs)/kb/components/scroll-area/demos/hero/css-modules/index.tsx +35 -0
- package/docs/src/app/(docs)/kb/components/scroll-area/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/scroll-area/demos/hero/tailwind/index.tsx +34 -0
- package/docs/src/app/(docs)/kb/components/scroll-area/demos/scroll-fade/css-modules/index.module.css +92 -0
- package/docs/src/app/(docs)/kb/components/scroll-area/demos/scroll-fade/css-modules/index.tsx +35 -0
- package/docs/src/app/(docs)/kb/components/scroll-area/demos/scroll-fade/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/scroll-area/demos/scroll-fade/tailwind/index.tsx +34 -0
- package/docs/src/app/(docs)/kb/components/scroll-area/page.mdx +142 -0
- package/docs/src/app/(docs)/kb/components/scroll-area/types.md +356 -0
- package/docs/src/app/(docs)/kb/components/scroll-area/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/select/demos/grouped/css-modules/index.module.css +269 -0
- package/docs/src/app/(docs)/kb/components/select/demos/grouped/css-modules/index.tsx +148 -0
- package/docs/src/app/(docs)/kb/components/select/demos/grouped/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/select/demos/grouped/tailwind/index.tsx +156 -0
- package/docs/src/app/(docs)/kb/components/select/demos/hero/css-modules/index.module.css +232 -0
- package/docs/src/app/(docs)/kb/components/select/demos/hero/css-modules/index.tsx +110 -0
- package/docs/src/app/(docs)/kb/components/select/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/select/demos/hero/tailwind/index.tsx +118 -0
- package/docs/src/app/(docs)/kb/components/select/demos/multiple/css-modules/index.module.css +182 -0
- package/docs/src/app/(docs)/kb/components/select/demos/multiple/css-modules/index.tsx +96 -0
- package/docs/src/app/(docs)/kb/components/select/demos/multiple/index.ts +5 -0
- package/docs/src/app/(docs)/kb/components/select/demos/multiple/tailwind/index.tsx +103 -0
- package/docs/src/app/(docs)/kb/components/select/demos/object-values/css-modules/index.module.css +279 -0
- package/docs/src/app/(docs)/kb/components/select/demos/object-values/css-modules/index.tsx +145 -0
- package/docs/src/app/(docs)/kb/components/select/demos/object-values/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/select/demos/object-values/tailwind/index.tsx +150 -0
- package/docs/src/app/(docs)/kb/components/select/page.mdx +330 -0
- package/docs/src/app/(docs)/kb/components/select/types.md +907 -0
- package/docs/src/app/(docs)/kb/components/select/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/separator/demos/hero/css-modules/index.module.css +45 -0
- package/docs/src/app/(docs)/kb/components/separator/demos/hero/css-modules/index.tsx +30 -0
- package/docs/src/app/(docs)/kb/components/separator/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/separator/demos/hero/tailwind/index.tsx +47 -0
- package/docs/src/app/(docs)/kb/components/separator/page.mdx +46 -0
- package/docs/src/app/(docs)/kb/components/separator/types.md +53 -0
- package/docs/src/app/(docs)/kb/components/separator/types.ts +4 -0
- package/docs/src/app/(docs)/kb/components/slider/demos/edge-alignment/css-modules/index.module.css +56 -0
- package/docs/src/app/(docs)/kb/components/slider/demos/edge-alignment/css-modules/index.tsx +15 -0
- package/docs/src/app/(docs)/kb/components/slider/demos/edge-alignment/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/slider/demos/edge-alignment/tailwind/index.tsx +17 -0
- package/docs/src/app/(docs)/kb/components/slider/demos/hero/css-modules/index.module.css +56 -0
- package/docs/src/app/(docs)/kb/components/slider/demos/hero/css-modules/index.tsx +15 -0
- package/docs/src/app/(docs)/kb/components/slider/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/slider/demos/hero/tailwind/index.tsx +17 -0
- package/docs/src/app/(docs)/kb/components/slider/demos/range-slider/css-modules/index.module.css +56 -0
- package/docs/src/app/(docs)/kb/components/slider/demos/range-slider/css-modules/index.tsx +16 -0
- package/docs/src/app/(docs)/kb/components/slider/demos/range-slider/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/slider/demos/range-slider/tailwind/index.tsx +23 -0
- package/docs/src/app/(docs)/kb/components/slider/demos/vertical/css-modules/index.module.css +61 -0
- package/docs/src/app/(docs)/kb/components/slider/demos/vertical/css-modules/index.tsx +15 -0
- package/docs/src/app/(docs)/kb/components/slider/demos/vertical/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/slider/demos/vertical/tailwind/index.tsx +17 -0
- package/docs/src/app/(docs)/kb/components/slider/page.mdx +207 -0
- package/docs/src/app/(docs)/kb/components/slider/types.md +641 -0
- package/docs/src/app/(docs)/kb/components/slider/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/switch/demos/hero/css-modules/index.module.css +69 -0
- package/docs/src/app/(docs)/kb/components/switch/demos/hero/css-modules/index.tsx +13 -0
- package/docs/src/app/(docs)/kb/components/switch/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/switch/demos/hero/tailwind/index.tsx +15 -0
- package/docs/src/app/(docs)/kb/components/switch/page.mdx +118 -0
- package/docs/src/app/(docs)/kb/components/switch/types.md +178 -0
- package/docs/src/app/(docs)/kb/components/switch/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/tabs/demos/hero/css-modules/index.module.css +145 -0
- package/docs/src/app/(docs)/kb/components/tabs/demos/hero/css-modules/index.tsx +32 -0
- package/docs/src/app/(docs)/kb/components/tabs/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/tabs/demos/hero/tailwind/index.tsx +37 -0
- package/docs/src/app/(docs)/kb/components/tabs/page.mdx +97 -0
- package/docs/src/app/(docs)/kb/components/tabs/types.md +331 -0
- package/docs/src/app/(docs)/kb/components/tabs/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/anchored/css-modules/index.module.css +457 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/anchored/css-modules/index.tsx +160 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/anchored/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/anchored/tailwind/index.tsx +176 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/custom/css-modules/index.module.css +271 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/custom/css-modules/index.tsx +69 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/custom/index.ts +4 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/deduplicate/css-modules/index.module.css +305 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/deduplicate/css-modules/index.tsx +62 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/deduplicate/index.ts +4 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/hero/css-modules/index.module.css +271 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/hero/css-modules/index.tsx +51 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/hero/tailwind/index.tsx +60 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/position/css-modules/index.module.css +266 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/position/css-modules/index.tsx +51 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/position/index.ts +5 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/position/tailwind/index.tsx +61 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/promise/css-modules/index.module.css +287 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/promise/css-modules/index.tsx +63 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/promise/index.ts +4 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/undo/css-modules/index.module.css +277 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/undo/css-modules/index.tsx +62 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/undo/index.ts +4 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/varying-heights/css-modules/index.module.css +271 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/varying-heights/css-modules/index.tsx +59 -0
- package/docs/src/app/(docs)/kb/components/toast/demos/varying-heights/index.ts +4 -0
- package/docs/src/app/(docs)/kb/components/toast/page.mdx +477 -0
- package/docs/src/app/(docs)/kb/components/toast/types.md +947 -0
- package/docs/src/app/(docs)/kb/components/toast/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/toggle/demos/hero/css-modules/index.module.css +55 -0
- package/docs/src/app/(docs)/kb/components/toggle/demos/hero/css-modules/index.tsx +64 -0
- package/docs/src/app/(docs)/kb/components/toggle/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/toggle/demos/hero/tailwind/index.tsx +61 -0
- package/docs/src/app/(docs)/kb/components/toggle/page.mdx +43 -0
- package/docs/src/app/(docs)/kb/components/toggle/types.md +82 -0
- package/docs/src/app/(docs)/kb/components/toggle/types.ts +4 -0
- package/docs/src/app/(docs)/kb/components/toggle-group/demos/hero/css-modules/index.module.css +82 -0
- package/docs/src/app/(docs)/kb/components/toggle-group/demos/hero/css-modules/index.tsx +66 -0
- package/docs/src/app/(docs)/kb/components/toggle-group/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/toggle-group/demos/hero/tailwind/index.tsx +81 -0
- package/docs/src/app/(docs)/kb/components/toggle-group/demos/multiple/css-modules/index.module.css +82 -0
- package/docs/src/app/(docs)/kb/components/toggle-group/demos/multiple/css-modules/index.tsx +69 -0
- package/docs/src/app/(docs)/kb/components/toggle-group/demos/multiple/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/toggle-group/demos/multiple/tailwind/index.tsx +80 -0
- package/docs/src/app/(docs)/kb/components/toggle-group/page.mdx +52 -0
- package/docs/src/app/(docs)/kb/components/toggle-group/types.md +98 -0
- package/docs/src/app/(docs)/kb/components/toggle-group/types.ts +4 -0
- package/docs/src/app/(docs)/kb/components/toolbar/demos/hero/css-modules/index.module.css +242 -0
- package/docs/src/app/(docs)/kb/components/toolbar/demos/hero/css-modules/index.tsx +102 -0
- package/docs/src/app/(docs)/kb/components/toolbar/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/toolbar/demos/hero/tailwind/index.tsx +119 -0
- package/docs/src/app/(docs)/kb/components/toolbar/page.mdx +139 -0
- package/docs/src/app/(docs)/kb/components/toolbar/types.md +275 -0
- package/docs/src/app/(docs)/kb/components/toolbar/types.ts +7 -0
- package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-controlled/css-modules/index.tsx +138 -0
- package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-controlled/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-controlled/tailwind/index.tsx +94 -0
- package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-full/css-modules/index.module.css +229 -0
- package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-full/css-modules/index.tsx +115 -0
- package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-full/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-full/tailwind/index.tsx +116 -0
- package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-simple/css-modules/index.tsx +49 -0
- package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-simple/index.ts +8 -0
- package/docs/src/app/(docs)/kb/components/tooltip/demos/detached-triggers-simple/tailwind/index.tsx +34 -0
- package/docs/src/app/(docs)/kb/components/tooltip/demos/hero/css-modules/index.module.css +149 -0
- package/docs/src/app/(docs)/kb/components/tooltip/demos/hero/css-modules/index.tsx +98 -0
- package/docs/src/app/(docs)/kb/components/tooltip/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/components/tooltip/demos/hero/tailwind/index.tsx +104 -0
- package/docs/src/app/(docs)/kb/components/tooltip/demos/icons-tw.tsx +61 -0
- package/docs/src/app/(docs)/kb/components/tooltip/demos/index.module.css +233 -0
- package/docs/src/app/(docs)/kb/components/tooltip/page.mdx +270 -0
- package/docs/src/app/(docs)/kb/components/tooltip/types.md +524 -0
- package/docs/src/app/(docs)/kb/components/tooltip/types.ts +7 -0
- package/docs/src/app/(docs)/kb/handbook/animation/demos/animated-popover-motion-keep-mounted-false/css-modules/index.module.css +90 -0
- package/docs/src/app/(docs)/kb/handbook/animation/demos/animated-popover-motion-keep-mounted-false/css-modules/index.tsx +35 -0
- package/docs/src/app/(docs)/kb/handbook/animation/demos/animated-popover-motion-keep-mounted-false/index.ts +6 -0
- package/docs/src/app/(docs)/kb/handbook/animation/demos/animated-popover-motion-keep-mounted-true/css-modules/index.module.css +89 -0
- package/docs/src/app/(docs)/kb/handbook/animation/demos/animated-popover-motion-keep-mounted-true/css-modules/index.tsx +32 -0
- package/docs/src/app/(docs)/kb/handbook/animation/demos/animated-popover-motion-keep-mounted-true/index.ts +6 -0
- package/docs/src/app/(docs)/kb/handbook/animation/demos/animated-select-motion/css-modules/index.module.css +238 -0
- package/docs/src/app/(docs)/kb/handbook/animation/demos/animated-select-motion/css-modules/index.tsx +107 -0
- package/docs/src/app/(docs)/kb/handbook/animation/demos/animated-select-motion/index.ts +6 -0
- package/docs/src/app/(docs)/kb/handbook/animation/page.mdx +233 -0
- package/docs/src/app/(docs)/kb/handbook/composition/page.mdx +113 -0
- package/docs/src/app/(docs)/kb/handbook/customization/page.mdx +144 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/components/autocomplete.tsx +73 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/components/button.tsx +20 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/components/checkbox-group.tsx +15 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/components/checkbox.tsx +21 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/components/combobox.tsx +161 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/components/field.tsx +56 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/components/fieldset.tsx +16 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/components/form.tsx +12 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/components/number-field.tsx +53 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/components/radio-group.tsx +15 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/components/radio.tsx +27 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/components/select.tsx +129 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/components/slider.tsx +55 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/components/switch.tsx +27 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/components/toast.tsx +64 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/hero/index.ts +8 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/hero/tailwind/index.tsx +357 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/react-hook-form/index.ts +4 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/react-hook-form/tailwind/index.tsx +511 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/tanstack-form/index.ts +4 -0
- package/docs/src/app/(docs)/kb/handbook/forms/demos/tanstack-form/tailwind/index.tsx +591 -0
- package/docs/src/app/(docs)/kb/handbook/forms/page.mdx +736 -0
- package/docs/src/app/(docs)/kb/handbook/page.mdx +167 -0
- package/docs/src/app/(docs)/kb/handbook/styling/page.mdx +176 -0
- package/docs/src/app/(docs)/kb/handbook/typescript/page.mdx +93 -0
- package/docs/src/app/(docs)/kb/overview/accessibility/page.mdx +63 -0
- package/docs/src/app/(docs)/kb/overview/page.mdx +128 -0
- package/docs/src/app/(docs)/kb/overview/quick-start/page.mdx +95 -0
- package/docs/src/app/(docs)/kb/page.mdx +130 -0
- package/docs/src/app/(docs)/kb/utils/csp-provider/page.mdx +107 -0
- package/docs/src/app/(docs)/kb/utils/csp-provider/types.md +35 -0
- package/docs/src/app/(docs)/kb/utils/csp-provider/types.ts +4 -0
- package/docs/src/app/(docs)/kb/utils/direction-provider/demos/hero/css-modules/index.module.css +56 -0
- package/docs/src/app/(docs)/kb/utils/direction-provider/demos/hero/css-modules/index.tsx +20 -0
- package/docs/src/app/(docs)/kb/utils/direction-provider/demos/hero/index.ts +9 -0
- package/docs/src/app/(docs)/kb/utils/direction-provider/demos/hero/tailwind/index.tsx +19 -0
- package/docs/src/app/(docs)/kb/utils/direction-provider/page.mdx +62 -0
- package/docs/src/app/(docs)/kb/utils/direction-provider/types.md +48 -0
- package/docs/src/app/(docs)/kb/utils/direction-provider/types.ts +8 -0
- package/docs/src/app/(docs)/kb/utils/merge-props/demos/prevent-base-ui-handler/css-modules/index.module.css +123 -0
- package/docs/src/app/(docs)/kb/utils/merge-props/demos/prevent-base-ui-handler/css-modules/index.tsx +74 -0
- package/docs/src/app/(docs)/kb/utils/merge-props/demos/prevent-base-ui-handler/index.ts +4 -0
- package/docs/src/app/(docs)/kb/utils/merge-props/page.mdx +87 -0
- package/docs/src/app/(docs)/kb/utils/merge-props/types.md +96 -0
- package/docs/src/app/(docs)/kb/utils/merge-props/types.ts +7 -0
- package/docs/src/app/(docs)/kb/utils/page.mdx +126 -0
- package/docs/src/app/(docs)/kb/utils/use-render/demos/render/css-modules/index.module.css +13 -0
- package/docs/src/app/(docs)/kb/utils/use-render/demos/render/css-modules/index.tsx +27 -0
- package/docs/src/app/(docs)/kb/utils/use-render/demos/render/index.ts +8 -0
- package/docs/src/app/(docs)/kb/utils/use-render/demos/render-callback/css-modules/index.module.css +71 -0
- package/docs/src/app/(docs)/kb/utils/use-render/demos/render-callback/css-modules/index.tsx +55 -0
- package/docs/src/app/(docs)/kb/utils/use-render/demos/render-callback/index.ts +6 -0
- package/docs/src/app/(docs)/kb/utils/use-render/page.mdx +198 -0
- package/docs/src/app/(docs)/kb/utils/use-render/types.md +557 -0
- package/docs/src/app/(docs)/kb/utils/use-render/types.ts +4 -0
- package/docs/src/app/(docs)/layout.css +89 -0
- package/docs/src/app/(docs)/layout.tsx +196 -0
- package/docs/src/app/(docs)/opengraph-image.png +0 -0
- package/docs/src/app/(docs)/production-error/ErrorCode.tsx +23 -0
- package/docs/src/app/(docs)/production-error/ErrorDisplay.tsx +36 -0
- package/docs/src/app/(docs)/production-error/page.mdx +16 -0
- package/docs/src/app/(private)/docs-theme/page.module.css +250 -0
- package/docs/src/app/(private)/docs-theme/page.tsx +220 -0
- package/docs/src/app/(private)/experiments/[...slug]/page.tsx +74 -0
- package/docs/src/app/(private)/experiments/_components/Button.module.css +22 -0
- package/docs/src/app/(private)/experiments/_components/Button.tsx +29 -0
- package/docs/src/app/(private)/experiments/_components/EditPanel.tsx +132 -0
- package/docs/src/app/(private)/experiments/_components/ExperimentRoot.module.css +61 -0
- package/docs/src/app/(private)/experiments/_components/ExperimentRoot.tsx +41 -0
- package/docs/src/app/(private)/experiments/_components/ExperimentsList.module.css +29 -0
- package/docs/src/app/(private)/experiments/_components/ExperimentsList.tsx +93 -0
- package/docs/src/app/(private)/experiments/_components/HideSidebar.tsx +20 -0
- package/docs/src/app/(private)/experiments/_components/Input.module.css +18 -0
- package/docs/src/app/(private)/experiments/_components/Input.tsx +7 -0
- package/docs/src/app/(private)/experiments/_components/SandboxLink.tsx +53 -0
- package/docs/src/app/(private)/experiments/_components/Select.module.css +174 -0
- package/docs/src/app/(private)/experiments/_components/Select.tsx +91 -0
- package/docs/src/app/(private)/experiments/_components/SettingsPanel.module.css +111 -0
- package/docs/src/app/(private)/experiments/_components/SettingsPanel.tsx +282 -0
- package/docs/src/app/(private)/experiments/_components/ShowSidebar.module.css +48 -0
- package/docs/src/app/(private)/experiments/_components/ShowSidebar.tsx +21 -0
- package/docs/src/app/(private)/experiments/_components/Sidebar.module.css +15 -0
- package/docs/src/app/(private)/experiments/_components/Sidebar.tsx +35 -0
- package/docs/src/app/(private)/experiments/_components/Switch.module.css +104 -0
- package/docs/src/app/(private)/experiments/_components/Switch.tsx +42 -0
- package/docs/src/app/(private)/experiments/_components/Tooltip.module.css +76 -0
- package/docs/src/app/(private)/experiments/_components/Tooltip.tsx +47 -0
- package/docs/src/app/(private)/experiments/_css/index.css +61 -0
- package/docs/src/app/(private)/experiments/_css/reset.css +384 -0
- package/docs/src/app/(private)/experiments/accordion/_components/Accordion.module.css +69 -0
- package/docs/src/app/(private)/experiments/accordion/_components/Accordion.tsx +35 -0
- package/docs/src/app/(private)/experiments/accordion/accordion.module.css +21 -0
- package/docs/src/app/(private)/experiments/accordion/animations.module.css +37 -0
- package/docs/src/app/(private)/experiments/accordion/animations.tsx +223 -0
- package/docs/src/app/(private)/experiments/accordion/horizontal.module.css +115 -0
- package/docs/src/app/(private)/experiments/accordion/horizontal.tsx +107 -0
- package/docs/src/app/(private)/experiments/accordion/transitions.module.css +19 -0
- package/docs/src/app/(private)/experiments/accordion/transitions.tsx +302 -0
- package/docs/src/app/(private)/experiments/anchor-positioning.module.css +12 -0
- package/docs/src/app/(private)/experiments/anchor-positioning.tsx +402 -0
- package/docs/src/app/(private)/experiments/anchor-side-animations.module.css +46 -0
- package/docs/src/app/(private)/experiments/anchor-side-animations.tsx +32 -0
- package/docs/src/app/(private)/experiments/collapsible/_components/Collapsible.module.css +54 -0
- package/docs/src/app/(private)/experiments/collapsible/_components/Collapsible.tsx +27 -0
- package/docs/src/app/(private)/experiments/collapsible/animate-presence.tsx +57 -0
- package/docs/src/app/(private)/experiments/collapsible/animations.module.css +58 -0
- package/docs/src/app/(private)/experiments/collapsible/animations.tsx +183 -0
- package/docs/src/app/(private)/experiments/collapsible/collapsible.module.css +21 -0
- package/docs/src/app/(private)/experiments/collapsible/plain.tsx +56 -0
- package/docs/src/app/(private)/experiments/collapsible/transitions.module.css +18 -0
- package/docs/src/app/(private)/experiments/collapsible/transitions.tsx +154 -0
- package/docs/src/app/(private)/experiments/combobox/creatable-tags.module.css +153 -0
- package/docs/src/app/(private)/experiments/combobox/creatable-tags.tsx +307 -0
- package/docs/src/app/(private)/experiments/combobox/dialog-combobox-multiple.tsx +112 -0
- package/docs/src/app/(private)/experiments/combobox/dialog-combobox.module.css +318 -0
- package/docs/src/app/(private)/experiments/combobox/dialog-combobox.tsx +88 -0
- package/docs/src/app/(private)/experiments/combobox/limited-chips.module.css +278 -0
- package/docs/src/app/(private)/experiments/combobox/limited-chips.tsx +203 -0
- package/docs/src/app/(private)/experiments/combobox/priority-combobox.module.css +187 -0
- package/docs/src/app/(private)/experiments/combobox/priority-combobox.tsx +171 -0
- package/docs/src/app/(private)/experiments/combobox-composition.module.css +154 -0
- package/docs/src/app/(private)/experiments/combobox-composition.tsx +114 -0
- package/docs/src/app/(private)/experiments/combobox-perf.module.css +166 -0
- package/docs/src/app/(private)/experiments/combobox-perf.tsx +158 -0
- package/docs/src/app/(private)/experiments/context-menu.module.css +342 -0
- package/docs/src/app/(private)/experiments/context-menu.tsx +409 -0
- package/docs/src/app/(private)/experiments/dialog/dialog.module.css +83 -0
- package/docs/src/app/(private)/experiments/dialog/dialogs.tsx +358 -0
- package/docs/src/app/(private)/experiments/dialog/nested.module.css +276 -0
- package/docs/src/app/(private)/experiments/dialog/nested.tsx +215 -0
- package/docs/src/app/(private)/experiments/drawer/cross-axis-scroll.module.css +136 -0
- package/docs/src/app/(private)/experiments/drawer/cross-axis-scroll.tsx +162 -0
- package/docs/src/app/(private)/experiments/drawer/drawer-controlled-opening.module.css +174 -0
- package/docs/src/app/(private)/experiments/drawer/drawer-controlled-opening.tsx +57 -0
- package/docs/src/app/(private)/experiments/drawer/touch-ignore.module.css +338 -0
- package/docs/src/app/(private)/experiments/drawer/touch-ignore.tsx +155 -0
- package/docs/src/app/(private)/experiments/drawer/virtual-keyboard-aware.module.css +112 -0
- package/docs/src/app/(private)/experiments/drawer/virtual-keyboard-aware.tsx +220 -0
- package/docs/src/app/(private)/experiments/drawer-slider.module.css +196 -0
- package/docs/src/app/(private)/experiments/drawer-slider.tsx +39 -0
- package/docs/src/app/(private)/experiments/forms/_icons.tsx +47 -0
- package/docs/src/app/(private)/experiments/forms/autofill.module.css +467 -0
- package/docs/src/app/(private)/experiments/forms/autofill.tsx +325 -0
- package/docs/src/app/(private)/experiments/forms/button-controls.tsx +195 -0
- package/docs/src/app/(private)/experiments/forms/form.module.css +693 -0
- package/docs/src/app/(private)/experiments/forms/form.tsx +523 -0
- package/docs/src/app/(private)/experiments/forms/rhf.tsx +988 -0
- package/docs/src/app/(private)/experiments/inline-positioning.module.css +171 -0
- package/docs/src/app/(private)/experiments/inline-positioning.tsx +169 -0
- package/docs/src/app/(private)/experiments/layout.tsx +5 -0
- package/docs/src/app/(private)/experiments/long-select.module.css +241 -0
- package/docs/src/app/(private)/experiments/long-select.tsx +375 -0
- package/docs/src/app/(private)/experiments/menu/complex-nesting.tsx +136 -0
- package/docs/src/app/(private)/experiments/menu/dialog-trigger-item.tsx +130 -0
- package/docs/src/app/(private)/experiments/menu/menu-anchor-el.tsx +40 -0
- package/docs/src/app/(private)/experiments/menu/menu-anchor-ref.tsx +37 -0
- package/docs/src/app/(private)/experiments/menu/menu-disabled-items.tsx +87 -0
- package/docs/src/app/(private)/experiments/menu/menu-fully-featured.tsx +312 -0
- package/docs/src/app/(private)/experiments/menu/menu-horizontal.module.css +193 -0
- package/docs/src/app/(private)/experiments/menu/menu-horizontal.tsx +127 -0
- package/docs/src/app/(private)/experiments/menu/menu-nested.module.css +190 -0
- package/docs/src/app/(private)/experiments/menu/menu-nested.tsx +133 -0
- package/docs/src/app/(private)/experiments/menu/menu-submenus.tsx +182 -0
- package/docs/src/app/(private)/experiments/menu/menu.module.css +412 -0
- package/docs/src/app/(private)/experiments/menu/nested-detached-triggers.module.css +115 -0
- package/docs/src/app/(private)/experiments/menu/nested-detached-triggers.tsx +270 -0
- package/docs/src/app/(private)/experiments/menu/perf-contained.tsx +90 -0
- package/docs/src/app/(private)/experiments/menu/perf-detached.tsx +99 -0
- package/docs/src/app/(private)/experiments/menu/pointer-events-scope.module.css +305 -0
- package/docs/src/app/(private)/experiments/menu/pointer-events-scope.tsx +254 -0
- package/docs/src/app/(private)/experiments/menu/triggers.module.css +47 -0
- package/docs/src/app/(private)/experiments/menu/triggers.tsx +421 -0
- package/docs/src/app/(private)/experiments/menubar.module.css +63 -0
- package/docs/src/app/(private)/experiments/menubar.tsx +239 -0
- package/docs/src/app/(private)/experiments/meter.module.css +52 -0
- package/docs/src/app/(private)/experiments/meter.tsx +44 -0
- package/docs/src/app/(private)/experiments/mobile-scroll-lock.module.css +100 -0
- package/docs/src/app/(private)/experiments/mobile-scroll-lock.tsx +38 -0
- package/docs/src/app/(private)/experiments/modality.module.css +239 -0
- package/docs/src/app/(private)/experiments/modality.tsx +128 -0
- package/docs/src/app/(private)/experiments/motion.tsx +113 -0
- package/docs/src/app/(private)/experiments/navigation-menu-popups.tsx +214 -0
- package/docs/src/app/(private)/experiments/navigation-menu.module.css +638 -0
- package/docs/src/app/(private)/experiments/navigation-menu.tsx +611 -0
- package/docs/src/app/(private)/experiments/page.tsx +15 -0
- package/docs/src/app/(private)/experiments/perf/contained-triggers.tsx +270 -0
- package/docs/src/app/(private)/experiments/perf/detached-triggers.tsx +317 -0
- package/docs/src/app/(private)/experiments/perf/menu-open.tsx +167 -0
- package/docs/src/app/(private)/experiments/perf/perf.module.css +171 -0
- package/docs/src/app/(private)/experiments/perf/radix-triggers.tsx +261 -0
- package/docs/src/app/(private)/experiments/perf/utils/benchmark.tsx +208 -0
- package/docs/src/app/(private)/experiments/perf/utils/wait.ts +27 -0
- package/docs/src/app/(private)/experiments/popover/calendar-shared.ts +15 -0
- package/docs/src/app/(private)/experiments/popover/calendar.module.css +187 -0
- package/docs/src/app/(private)/experiments/popover/calendar.tsx +175 -0
- package/docs/src/app/(private)/experiments/popover/dynamic-size.module.css +11 -0
- package/docs/src/app/(private)/experiments/popover/dynamic-size.tsx +87 -0
- package/docs/src/app/(private)/experiments/popover/nested-open-on-hover.module.css +179 -0
- package/docs/src/app/(private)/experiments/popover/nested-open-on-hover.tsx +64 -0
- package/docs/src/app/(private)/experiments/popover/popovers.module.css +91 -0
- package/docs/src/app/(private)/experiments/popover/popovers.tsx +335 -0
- package/docs/src/app/(private)/experiments/popover/vertical-shared.ts +3 -0
- package/docs/src/app/(private)/experiments/popover/vertical.module.css +411 -0
- package/docs/src/app/(private)/experiments/popover/vertical.tsx +207 -0
- package/docs/src/app/(private)/experiments/popup-tabbing.module.css +399 -0
- package/docs/src/app/(private)/experiments/popup-tabbing.tsx +247 -0
- package/docs/src/app/(private)/experiments/popups/popups-in-popups.module.css +806 -0
- package/docs/src/app/(private)/experiments/popups/popups-in-popups.tsx +510 -0
- package/docs/src/app/(private)/experiments/popups/popups-transform-origin.module.css +42 -0
- package/docs/src/app/(private)/experiments/popups/popups-transform-origin.tsx +77 -0
- package/docs/src/app/(private)/experiments/preview-card/nested.module.css +119 -0
- package/docs/src/app/(private)/experiments/preview-card/nested.tsx +61 -0
- package/docs/src/app/(private)/experiments/preview-card/triggers.module.css +156 -0
- package/docs/src/app/(private)/experiments/preview-card/triggers.tsx +446 -0
- package/docs/src/app/(private)/experiments/rtl.module.css +170 -0
- package/docs/src/app/(private)/experiments/rtl.tsx +187 -0
- package/docs/src/app/(private)/experiments/scroll-area/inside-menu.module.css +207 -0
- package/docs/src/app/(private)/experiments/scroll-area/inside-menu.tsx +90 -0
- package/docs/src/app/(private)/experiments/scroll-area/inside-select.module.css +204 -0
- package/docs/src/app/(private)/experiments/scroll-area/inside-select.tsx +67 -0
- package/docs/src/app/(private)/experiments/scroll-area/scroll-area-inset.module.css +41 -0
- package/docs/src/app/(private)/experiments/scroll-area/scroll-area-inset.tsx +55 -0
- package/docs/src/app/(private)/experiments/scroll-area/scroll-area-slight.module.css +30 -0
- package/docs/src/app/(private)/experiments/scroll-area/scroll-area-slight.tsx +23 -0
- package/docs/src/app/(private)/experiments/scroll-area/scroll-area.module.css +82 -0
- package/docs/src/app/(private)/experiments/scroll-area/scroll-area.tsx +25 -0
- package/docs/src/app/(private)/experiments/scroll-area/tabs-scroll-area.tsx +109 -0
- package/docs/src/app/(private)/experiments/scroll-lock.tsx +136 -0
- package/docs/src/app/(private)/experiments/select-perf.module.css +177 -0
- package/docs/src/app/(private)/experiments/select-perf.tsx +80 -0
- package/docs/src/app/(private)/experiments/select-rtl-align-item-with-trigger.tsx +313 -0
- package/docs/src/app/(private)/experiments/slider/inset.module.css +254 -0
- package/docs/src/app/(private)/experiments/slider/inset.tsx +150 -0
- package/docs/src/app/(private)/experiments/slider/slider.module.css +67 -0
- package/docs/src/app/(private)/experiments/slider/slider.tsx +191 -0
- package/docs/src/app/(private)/experiments/slider/small.module.css +83 -0
- package/docs/src/app/(private)/experiments/slider/vertical.module.css +64 -0
- package/docs/src/app/(private)/experiments/storeWithControlledValues.module.css +23 -0
- package/docs/src/app/(private)/experiments/storeWithControlledValues.tsx +125 -0
- package/docs/src/app/(private)/experiments/tabs/tabs-animations.module.css +264 -0
- package/docs/src/app/(private)/experiments/tabs/tabs-animations.tsx +110 -0
- package/docs/src/app/(private)/experiments/tabs/tabs-basic.module.css +162 -0
- package/docs/src/app/(private)/experiments/tabs/tabs-basic.tsx +96 -0
- package/docs/src/app/(private)/experiments/tabs/tabs-onValueChange.module.css +187 -0
- package/docs/src/app/(private)/experiments/tabs/tabs-onValueChange.tsx +260 -0
- package/docs/src/app/(private)/experiments/tabs/tabs-overflow.module.css +92 -0
- package/docs/src/app/(private)/experiments/tabs/tabs-overflow.tsx +81 -0
- package/docs/src/app/(private)/experiments/toast.module.css +91 -0
- package/docs/src/app/(private)/experiments/toast.tsx +124 -0
- package/docs/src/app/(private)/experiments/toggle-group.tsx +121 -0
- package/docs/src/app/(private)/experiments/toggle.module.css +75 -0
- package/docs/src/app/(private)/experiments/toolbar/_icons.tsx +223 -0
- package/docs/src/app/(private)/experiments/toolbar/basic.tsx +101 -0
- package/docs/src/app/(private)/experiments/toolbar/slider.module.css +118 -0
- package/docs/src/app/(private)/experiments/toolbar/text-editor.tsx +365 -0
- package/docs/src/app/(private)/experiments/toolbar/toolbar.module.css +302 -0
- package/docs/src/app/(private)/experiments/toolbar/triggers.module.css +52 -0
- package/docs/src/app/(private)/experiments/toolbar/triggers.tsx +371 -0
- package/docs/src/app/(private)/experiments/tooltip/disabled.module.css +188 -0
- package/docs/src/app/(private)/experiments/tooltip/disabled.tsx +72 -0
- package/docs/src/app/(private)/experiments/tooltip/nested.module.css +36 -0
- package/docs/src/app/(private)/experiments/tooltip/nested.tsx +112 -0
- package/docs/src/app/(private)/experiments/tooltip/prevent-open.module.css +119 -0
- package/docs/src/app/(private)/experiments/tooltip/prevent-open.tsx +123 -0
- package/docs/src/app/(private)/experiments/tooltip/tooltips.module.css +196 -0
- package/docs/src/app/(private)/experiments/tooltip/tooltips.tsx +406 -0
- package/docs/src/app/(private)/experiments/tooltip/transitions.module.css +109 -0
- package/docs/src/app/(private)/experiments/tooltip/transitions.tsx +217 -0
- package/docs/src/app/(private)/experiments/transition-attrs.module.css +296 -0
- package/docs/src/app/(private)/experiments/transition-attrs.tsx +253 -0
- package/docs/src/app/(private)/hydration-repro/index.css +4 -0
- package/docs/src/app/(private)/hydration-repro/page.tsx +42 -0
- package/docs/src/app/(private)/layout.tsx +63 -0
- package/docs/src/app/(private)/playground/[slug]/page.tsx +54 -0
- package/docs/src/app/(private)/playground/index.css +9 -0
- package/docs/src/app/(private)/playground/layout.tsx +5 -0
- package/docs/src/app/(website)/careers/design-engineer/page.tsx +213 -0
- package/docs/src/app/(website)/css/components/Accordion.css +60 -0
- package/docs/src/app/(website)/css/components/Body.css +8 -0
- package/docs/src/app/(website)/css/components/BulletList.css +11 -0
- package/docs/src/app/(website)/css/components/Figure.css +10 -0
- package/docs/src/app/(website)/css/components/Icon.css +7 -0
- package/docs/src/app/(website)/css/components/List.css +14 -0
- package/docs/src/app/(website)/css/components/Separator.css +8 -0
- package/docs/src/app/(website)/css/components/Text.css +97 -0
- package/docs/src/app/(website)/css/index.css +10 -0
- package/docs/src/app/(website)/icons/MinusIcon.tsx +19 -0
- package/docs/src/app/(website)/icons/PlusIcon.tsx +19 -0
- package/docs/src/app/(website)/layout.tsx +108 -0
- package/docs/src/app/(website)/logos/GitHub.tsx +9 -0
- package/docs/src/app/(website)/logos/HighlightAI.tsx +20 -0
- package/docs/src/app/(website)/logos/Interfere.tsx +22 -0
- package/docs/src/app/(website)/logos/Operate.tsx +12 -0
- package/docs/src/app/(website)/logos/Paper.tsx +12 -0
- package/docs/src/app/(website)/logos/Unsplash.tsx +16 -0
- package/docs/src/app/(website)/logos/Zed.tsx +21 -0
- package/docs/src/app/(website)/opengraph-image.png +0 -0
- package/docs/src/app/(website)/page.tsx +47 -0
- package/docs/src/app/global-not-found.tsx +20 -0
- package/docs/src/app/robots.txt +9 -0
- package/docs/src/app/sitemap/index.ts +12 -0
- package/docs/src/blocks/Demo/DemoContext.ts +25 -0
- package/docs/src/blocks/Demo/DemoPlayground.tsx +29 -0
- package/docs/src/blocks/Demo/DemoRoot.tsx +43 -0
- package/docs/src/blocks/Demo/DemoSourceCopy.tsx +48 -0
- package/docs/src/blocks/Demo/index.ts +6 -0
- package/docs/src/blocks/Demo/types.ts +37 -0
- package/docs/src/blocks/GoogleAnalyticsProvider.tsx +158 -0
- package/docs/src/blocks/GoogleTagManager.tsx +17 -0
- package/docs/src/blocks/PackageManagerSnippet/PackageManagerSnippetCode.tsx +16 -0
- package/docs/src/blocks/PackageManagerSnippet/PackageManagerSnippetProvider.tsx +59 -0
- package/docs/src/blocks/PackageManagerSnippet/PackageManagerSnippetRoot.tsx +49 -0
- package/docs/src/blocks/PackageManagerSnippet/index.ts +2 -0
- package/docs/src/blocks/README.txt +1 -0
- package/docs/src/blocks/createCodeSandbox/CreateReactApp.ts +62 -0
- package/docs/src/blocks/createCodeSandbox/addHiddenInput.ts +7 -0
- package/docs/src/blocks/createCodeSandbox/createCodeSandbox.ts +190 -0
- package/docs/src/blocks/createCodeSandbox/createStackBlitzProject.ts +162 -0
- package/docs/src/blocks/createCodeSandbox/flattenRelativeImports.ts +10 -0
- package/docs/src/blocks/createCodeSandbox/packDemo.test.ts +66 -0
- package/docs/src/blocks/createCodeSandbox/packDemo.ts +60 -0
- package/docs/src/code-components.tsx +22 -0
- package/docs/src/components/Accordion.css +183 -0
- package/docs/src/components/Accordion.tsx +132 -0
- package/docs/src/components/Code.css +40 -0
- package/docs/src/components/Code.tsx +6 -0
- package/docs/src/components/CodeBlock/CodeBlock.css +139 -0
- package/docs/src/components/CodeBlock/CodeBlock.tsx +138 -0
- package/docs/src/components/CodeBlock/CodeBlockPreComputed.tsx +44 -0
- package/docs/src/components/CodeBlock/CodeBlockPreComputedContent.tsx +24 -0
- package/docs/src/components/CodeBlock/index.ts +1 -0
- package/docs/src/components/CodeBlock/rehypeEagerCodeBlocks.mjs +20 -0
- package/docs/src/components/Demo/Demo.css +475 -0
- package/docs/src/components/Demo/Demo.tsx +271 -0
- package/docs/src/components/Demo/DemoCodeBlock.tsx +96 -0
- package/docs/src/components/Demo/DemoErrorFallback.tsx +15 -0
- package/docs/src/components/Demo/DemoFileSelector.tsx +83 -0
- package/docs/src/components/Demo/DemoPlayground.tsx +24 -0
- package/docs/src/components/Demo/DemoVariantSelector.tsx +52 -0
- package/docs/src/components/DescriptionList.css +101 -0
- package/docs/src/components/DescriptionList.tsx +34 -0
- package/docs/src/components/DocsProviders.tsx +19 -0
- package/docs/src/components/GhostButton.css +43 -0
- package/docs/src/components/GhostButton.tsx +18 -0
- package/docs/src/components/GoogleAnalytics.tsx +32 -0
- package/docs/src/components/Header.css +184 -0
- package/docs/src/components/Header.tsx +101 -0
- package/docs/src/components/HeadingLink.css +34 -0
- package/docs/src/components/HeadingLink.tsx +7 -0
- package/docs/src/components/InstallationBlock/InstallationBlock.css +105 -0
- package/docs/src/components/InstallationBlock/InstallationBlock.tsx +73 -0
- package/docs/src/components/InstallationBlock/index.ts +1 -0
- package/docs/src/components/InstallationBlock/model.ts +12 -0
- package/docs/src/components/Kbd/Kbd.css +47 -0
- package/docs/src/components/Kbd/Kbd.tsx +7 -0
- package/docs/src/components/Kbd/rehypeKbd.mjs +14 -0
- package/docs/src/components/Link.css +63 -0
- package/docs/src/components/Link.tsx +54 -0
- package/docs/src/components/Logo.tsx +10 -0
- package/docs/src/components/Menu.css +87 -0
- package/docs/src/components/Menu.tsx +37 -0
- package/docs/src/components/MobileNav.css +273 -0
- package/docs/src/components/MobileNav.tsx +218 -0
- package/docs/src/components/Popup.css +30 -0
- package/docs/src/components/Popup.tsx +7 -0
- package/docs/src/components/QuickNav/QuickNav.css +134 -0
- package/docs/src/components/QuickNav/QuickNav.tsx +71 -0
- package/docs/src/components/QuickNav/rehypeConcatHeadings.mjs +36 -0
- package/docs/src/components/QuickNav/rehypeQuickNav.mjs +134 -0
- package/docs/src/components/QuickNav/rehypeSlug.mjs +70 -0
- package/docs/src/components/QuickNav/remarkQuickNavExcludeHeading.mjs +31 -0
- package/docs/src/components/ReferenceTable/AdditionalTypes.tsx +77 -0
- package/docs/src/components/ReferenceTable/AttributesReferenceTable.tsx +92 -0
- package/docs/src/components/ReferenceTable/CssVariablesReferenceTable.tsx +93 -0
- package/docs/src/components/ReferenceTable/MethodsReferenceAccordion.tsx +147 -0
- package/docs/src/components/ReferenceTable/ParametersReferenceTable.tsx +35 -0
- package/docs/src/components/ReferenceTable/PropertiesReferenceAccordion.tsx +139 -0
- package/docs/src/components/ReferenceTable/ReferenceAccordion.tsx +168 -0
- package/docs/src/components/ReferenceTable/ReferenceTable.css +391 -0
- package/docs/src/components/ReferenceTable/ReferenceTable.tsx +264 -0
- package/docs/src/components/ReleaseTimeline/ReleaseTimeline.css +219 -0
- package/docs/src/components/ReleaseTimeline/ReleaseTimeline.tsx +54 -0
- package/docs/src/components/ReleaseTimeline/index.tsx +1 -0
- package/docs/src/components/ScrollArea.css +92 -0
- package/docs/src/components/ScrollArea.tsx +21 -0
- package/docs/src/components/Search/Search.css +329 -0
- package/docs/src/components/Search/Search.tsx +73 -0
- package/docs/src/components/Search/SearchBar.tsx +450 -0
- package/docs/src/components/Search/index.ts +1 -0
- package/docs/src/components/SearchTrigger.css +57 -0
- package/docs/src/components/SearchTrigger.tsx +40 -0
- package/docs/src/components/Select.css +91 -0
- package/docs/src/components/Select.tsx +40 -0
- package/docs/src/components/SideNav.css +202 -0
- package/docs/src/components/SideNav.tsx +122 -0
- package/docs/src/components/SkipNav.css +38 -0
- package/docs/src/components/SkipNav.tsx +10 -0
- package/docs/src/components/Subtitle/MarkdownLink.tsx +22 -0
- package/docs/src/components/Subtitle/Subtitle.css +65 -0
- package/docs/src/components/Subtitle/Subtitle.tsx +21 -0
- package/docs/src/components/Subtitle/ViewSourceLink.tsx +51 -0
- package/docs/src/components/Subtitle/rehypeSubtitle.mjs +19 -0
- package/docs/src/components/Table.css +90 -0
- package/docs/src/components/Table.tsx +61 -0
- package/docs/src/components/TableCode.css +6 -0
- package/docs/src/components/TableCode.tsx +10 -0
- package/docs/src/components/TypePropRef/TypePropRef.css +8 -0
- package/docs/src/components/TypePropRef/TypePropRef.tsx +33 -0
- package/docs/src/components/TypePropRef/index.ts +1 -0
- package/docs/src/components/TypeRef/TypeRef.css +87 -0
- package/docs/src/components/TypeRef/TypeRef.tsx +103 -0
- package/docs/src/components/TypeRef/index.ts +1 -0
- package/docs/src/css/README.md +3 -0
- package/docs/src/css/custom-media.css +9 -0
- package/docs/src/css/fonts/index.css +41 -0
- package/docs/src/css/index.css +452 -0
- package/docs/src/css/mdx-components.css +110 -0
- package/docs/src/css/syntax.css +299 -0
- package/docs/src/css/utilities/align-items.css +13 -0
- package/docs/src/css/utilities/box-sizing.css +5 -0
- package/docs/src/css/utilities/display.css +87 -0
- package/docs/src/css/utilities/flex-direction.css +5 -0
- package/docs/src/css/utilities/flex-wrap.css +9 -0
- package/docs/src/css/utilities/font-weight.css +9 -0
- package/docs/src/css/utilities/gap.css +179 -0
- package/docs/src/css/utilities/grid-auto-rows.css +5 -0
- package/docs/src/css/utilities/grid-column-end.css +227 -0
- package/docs/src/css/utilities/grid-column-start.css +247 -0
- package/docs/src/css/utilities/grid-template-columns.css +107 -0
- package/docs/src/css/utilities/height.css +5 -0
- package/docs/src/css/utilities/index.css +25 -0
- package/docs/src/css/utilities/justify-content.css +17 -0
- package/docs/src/css/utilities/left.css +5 -0
- package/docs/src/css/utilities/margin.css +25 -0
- package/docs/src/css/utilities/outline.css +5 -0
- package/docs/src/css/utilities/padding.css +211 -0
- package/docs/src/css/utilities/position.css +5 -0
- package/docs/src/css/utilities/scroll-margin-top.css +5 -0
- package/docs/src/css/utilities/text-align.css +13 -0
- package/docs/src/css/utilities/top.css +5 -0
- package/docs/src/css/utilities/visibility.css +5 -0
- package/docs/src/css/utilities/visually-hidden.css +13 -0
- package/docs/src/css/utilities/white-space.css +5 -0
- package/docs/src/css/utilities/width.css +9 -0
- package/docs/src/data/releases.ts +283 -0
- package/docs/src/demo-data/theme/css-modules/theme.css +33 -0
- package/docs/src/error-codes.json +99 -0
- package/docs/src/icons/ArrowRightIcon.tsx +15 -0
- package/docs/src/icons/CaretSortIcon.tsx +9 -0
- package/docs/src/icons/CheckIcon.tsx +9 -0
- package/docs/src/icons/CopyIcon.tsx +9 -0
- package/docs/src/icons/ExternalLinkIcon.tsx +10 -0
- package/docs/src/icons/GitHubIcon.tsx +9 -0
- package/docs/src/icons/MagnifyingGlassIcon.tsx +19 -0
- package/docs/src/icons/MarkdownIcon.tsx +12 -0
- package/docs/src/icons/MoreVertIcon.tsx +9 -0
- package/docs/src/icons/NpmIcon.tsx +11 -0
- package/docs/src/mdx/createHast.mjs +10 -0
- package/docs/src/mdx/createMdxComponent.ts +14 -0
- package/docs/src/mdx/createMdxElement.mjs +58 -0
- package/docs/src/mdx-components.tsx +89 -0
- package/docs/src/utils/camelToSentenceCase.ts +14 -0
- package/docs/src/utils/createDemo.ts +29 -0
- package/docs/src/utils/createTypes.tsx +55 -0
- package/docs/src/utils/demoExportOptions.test.ts +201 -0
- package/docs/src/utils/demoExportOptions.ts +751 -0
- package/docs/src/utils/getGitHubDemoUrl.test.ts +58 -0
- package/docs/src/utils/getGitHubDemoUrl.ts +43 -0
- package/docs/src/utils/observeScrollableInner.ts +36 -0
- package/docs/src/utils/typeOrder.mjs +209 -0
- package/docs/tsconfig.json +47 -0
- package/docs/types.d.ts +18 -0
- package/docs/vitest.config.mts +19 -0
- package/eslint.config.mjs +201 -0
- package/examples/tanstack-start-tailwind-css/.devcontainer/devcontainer.json +4 -0
- package/examples/tanstack-start-tailwind-css/.prettierignore +4 -0
- package/examples/tanstack-start-tailwind-css/.vscode/settings.json +11 -0
- package/examples/tanstack-start-tailwind-css/README.md +57 -0
- package/examples/tanstack-start-tailwind-css/eslint.config.js +13 -0
- package/examples/tanstack-start-tailwind-css/package.json +40 -0
- package/examples/tanstack-start-tailwind-css/prettier.config.js +14 -0
- package/examples/tanstack-start-tailwind-css/public/favicon.ico +0 -0
- package/examples/tanstack-start-tailwind-css/public/logo192.png +0 -0
- package/examples/tanstack-start-tailwind-css/public/logo512.png +0 -0
- package/examples/tanstack-start-tailwind-css/public/manifest.json +25 -0
- package/examples/tanstack-start-tailwind-css/public/robots.txt +3 -0
- package/examples/tanstack-start-tailwind-css/public/tanstack-circle-logo.png +0 -0
- package/examples/tanstack-start-tailwind-css/src/components/button.tsx +15 -0
- package/examples/tanstack-start-tailwind-css/src/components/combobox.tsx +120 -0
- package/examples/tanstack-start-tailwind-css/src/components/dialog.tsx +67 -0
- package/examples/tanstack-start-tailwind-css/src/components/input.tsx +21 -0
- package/examples/tanstack-start-tailwind-css/src/components/link.tsx +19 -0
- package/examples/tanstack-start-tailwind-css/src/components/menu.tsx +109 -0
- package/examples/tanstack-start-tailwind-css/src/components/navigation-menu.tsx +177 -0
- package/examples/tanstack-start-tailwind-css/src/components/popover.tsx +78 -0
- package/examples/tanstack-start-tailwind-css/src/components/toggle.tsx +21 -0
- package/examples/tanstack-start-tailwind-css/src/routeTree.gen.ts +86 -0
- package/examples/tanstack-start-tailwind-css/src/router.tsx +16 -0
- package/examples/tanstack-start-tailwind-css/src/routes/__root.tsx +59 -0
- package/examples/tanstack-start-tailwind-css/src/routes/combobox-server-fn.tsx +91 -0
- package/examples/tanstack-start-tailwind-css/src/routes/index.tsx +153 -0
- package/examples/tanstack-start-tailwind-css/src/styles.css +17 -0
- package/examples/tanstack-start-tailwind-css/tsconfig.json +29 -0
- package/examples/tanstack-start-tailwind-css/vite.config.ts +14 -0
- package/examples/vite-css/README.md +46 -0
- package/examples/vite-css/eslint.config.js +25 -0
- package/examples/vite-css/index.html +14 -0
- package/examples/vite-css/package.json +30 -0
- package/examples/vite-css/src/App.css +52 -0
- package/examples/vite-css/src/App.tsx +39 -0
- package/examples/vite-css/src/assets/base-ui.svg +5 -0
- package/examples/vite-css/src/assets/react.svg +1 -0
- package/examples/vite-css/src/assets/vite.svg +1 -0
- package/examples/vite-css/src/index.css +105 -0
- package/examples/vite-css/src/main.tsx +10 -0
- package/examples/vite-css/src/vite-env.d.ts +1 -0
- package/examples/vite-css/src/widgets/Switch.module.css +89 -0
- package/examples/vite-css/src/widgets/Switch.tsx +13 -0
- package/examples/vite-css/tsconfig.app.json +27 -0
- package/examples/vite-css/tsconfig.json +4 -0
- package/examples/vite-css/tsconfig.node.json +25 -0
- package/examples/vite-css/vite.config.ts +7 -0
- package/greptile.json +3 -0
- package/lerna.json +5 -0
- package/my_docs/vanilla-extract-setup.md +82 -0
- package/netlify/functions/deploy-succeeded.js +41 -0
- package/netlify.toml +13 -0
- package/nx.json +10 -0
- package/package.json +118 -0
- package/packages/react/README.md +47 -0
- package/packages/react/package.json +173 -0
- package/packages/react/scripts/stagePublishedDocs.mjs +29 -0
- package/packages/react/src/accordion/header/AccordionHeader.test.tsx +16 -0
- package/packages/react/src/accordion/header/AccordionHeader.tsx +40 -0
- package/packages/react/src/accordion/header/AccordionHeaderDataAttributes.ts +15 -0
- package/packages/react/src/accordion/index.parts.ts +5 -0
- package/packages/react/src/accordion/index.ts +7 -0
- package/packages/react/src/accordion/item/AccordionItem.test.tsx +45 -0
- package/packages/react/src/accordion/item/AccordionItem.tsx +199 -0
- package/packages/react/src/accordion/item/AccordionItemContext.ts +24 -0
- package/packages/react/src/accordion/item/AccordionItemDataAttributes.ts +15 -0
- package/packages/react/src/accordion/item/stateAttributesMapping.ts +14 -0
- package/packages/react/src/accordion/panel/AccordionPanel.test.tsx +253 -0
- package/packages/react/src/accordion/panel/AccordionPanel.tsx +158 -0
- package/packages/react/src/accordion/panel/AccordionPanelCssVars.ts +12 -0
- package/packages/react/src/accordion/panel/AccordionPanelDataAttributes.ts +29 -0
- package/packages/react/src/accordion/root/AccordionRoot.spec.tsx +63 -0
- package/packages/react/src/accordion/root/AccordionRoot.test.tsx +865 -0
- package/packages/react/src/accordion/root/AccordionRoot.tsx +251 -0
- package/packages/react/src/accordion/root/AccordionRootContext.ts +30 -0
- package/packages/react/src/accordion/root/AccordionRootDataAttributes.ts +10 -0
- package/packages/react/src/accordion/trigger/AccordionTrigger.test.tsx +38 -0
- package/packages/react/src/accordion/trigger/AccordionTrigger.tsx +79 -0
- package/packages/react/src/accordion/trigger/AccordionTriggerDataAttributes.ts +10 -0
- package/packages/react/src/alert-dialog/handle.ts +32 -0
- package/packages/react/src/alert-dialog/index.parts.ts +10 -0
- package/packages/react/src/alert-dialog/index.ts +33 -0
- package/packages/react/src/alert-dialog/root/AlertDialogRoot.spec.tsx +42 -0
- package/packages/react/src/alert-dialog/root/AlertDialogRoot.test.tsx +1144 -0
- package/packages/react/src/alert-dialog/root/AlertDialogRoot.tsx +59 -0
- package/packages/react/src/alert-dialog/trigger/AlertDialogTrigger.tsx +38 -0
- package/packages/react/src/alert-dialog/trigger/AlertDialogTriggerDataAttributes.ts +12 -0
- package/packages/react/src/autocomplete/clear/AutocompleteClearDataAttributes.ts +1 -0
- package/packages/react/src/autocomplete/index.parts.ts +25 -0
- package/packages/react/src/autocomplete/index.ts +73 -0
- package/packages/react/src/autocomplete/input-group/AutocompleteInputGroup.tsx +53 -0
- package/packages/react/src/autocomplete/input-group/AutocompleteInputGroupDataAttributes.ts +51 -0
- package/packages/react/src/autocomplete/item/AutocompleteItem.test.tsx +101 -0
- package/packages/react/src/autocomplete/item/AutocompleteItem.tsx +56 -0
- package/packages/react/src/autocomplete/item/AutocompleteItemDataAttributes.ts +12 -0
- package/packages/react/src/autocomplete/root/AutocompleteRoot.spec.tsx +117 -0
- package/packages/react/src/autocomplete/root/AutocompleteRoot.test.tsx +2158 -0
- package/packages/react/src/autocomplete/root/AutocompleteRoot.tsx +285 -0
- package/packages/react/src/autocomplete/trigger/AutocompleteTrigger.tsx +53 -0
- package/packages/react/src/autocomplete/trigger/AutocompleteTriggerDataAttributes.ts +57 -0
- package/packages/react/src/autocomplete/value/AutocompleteValue.test.tsx +97 -0
- package/packages/react/src/autocomplete/value/AutocompleteValue.tsx +37 -0
- package/packages/react/src/avatar/Avatar.spec.tsx +31 -0
- package/packages/react/src/avatar/fallback/AvatarFallback.test.tsx +271 -0
- package/packages/react/src/avatar/fallback/AvatarFallback.tsx +64 -0
- package/packages/react/src/avatar/image/AvatarImage.test.tsx +383 -0
- package/packages/react/src/avatar/image/AvatarImage.tsx +108 -0
- package/packages/react/src/avatar/image/AvatarImageDataAttributes.ts +12 -0
- package/packages/react/src/avatar/image/useImageLoadingStatus.ts +65 -0
- package/packages/react/src/avatar/index.parts.ts +3 -0
- package/packages/react/src/avatar/index.ts +5 -0
- package/packages/react/src/avatar/root/AvatarRoot.test.tsx +11 -0
- package/packages/react/src/avatar/root/AvatarRoot.tsx +58 -0
- package/packages/react/src/avatar/root/AvatarRootContext.ts +20 -0
- package/packages/react/src/avatar/root/stateAttributesMapping.ts +3 -0
- package/packages/react/src/button/Button.css.ts +170 -0
- package/packages/react/src/button/Button.spec.tsx +10 -0
- package/packages/react/src/button/Button.test.tsx +198 -0
- package/packages/react/src/button/Button.tsx +140 -0
- package/packages/react/src/button/ButtonDataAttributes.tsx +6 -0
- package/packages/react/src/button/index.ts +3 -0
- package/packages/react/src/checkbox/index.parts.ts +2 -0
- package/packages/react/src/checkbox/index.ts +4 -0
- package/packages/react/src/checkbox/indicator/CheckboxIndicator.test.tsx +293 -0
- package/packages/react/src/checkbox/indicator/CheckboxIndicator.tsx +94 -0
- package/packages/react/src/checkbox/indicator/CheckboxIndicatorDataAttributes.ts +60 -0
- package/packages/react/src/checkbox/root/Checkbox.css.ts +76 -0
- package/packages/react/src/checkbox/root/CheckboxRoot.test.tsx +1512 -0
- package/packages/react/src/checkbox/root/CheckboxRoot.tsx +557 -0
- package/packages/react/src/checkbox/root/CheckboxRootContext.ts +18 -0
- package/packages/react/src/checkbox/root/CheckboxRootDataAttributes.ts +50 -0
- package/packages/react/src/checkbox/utils/useStateAttributesMapping.ts +31 -0
- package/packages/react/src/checkbox-group/CheckboxGroup.test.tsx +1027 -0
- package/packages/react/src/checkbox-group/CheckboxGroup.tsx +207 -0
- package/packages/react/src/checkbox-group/CheckboxGroupContext.ts +37 -0
- package/packages/react/src/checkbox-group/CheckboxGroupDataAttributes.ts +6 -0
- package/packages/react/src/checkbox-group/index.ts +2 -0
- package/packages/react/src/checkbox-group/useCheckboxGroupParent.test.tsx +404 -0
- package/packages/react/src/checkbox-group/useCheckboxGroupParent.ts +151 -0
- package/packages/react/src/collapsible/index.parts.ts +3 -0
- package/packages/react/src/collapsible/index.ts +5 -0
- package/packages/react/src/collapsible/panel/CollapsiblePanel.test.tsx +1190 -0
- package/packages/react/src/collapsible/panel/CollapsiblePanel.tsx +163 -0
- package/packages/react/src/collapsible/panel/CollapsiblePanelCssVars.ts +12 -0
- package/packages/react/src/collapsible/panel/CollapsiblePanelDataAttributes.ts +20 -0
- package/packages/react/src/collapsible/panel/useCollapsiblePanel.ts +555 -0
- package/packages/react/src/collapsible/root/CollapsibleRoot.spec.tsx +45 -0
- package/packages/react/src/collapsible/root/CollapsibleRoot.test.tsx +384 -0
- package/packages/react/src/collapsible/root/CollapsibleRoot.tsx +115 -0
- package/packages/react/src/collapsible/root/CollapsibleRootContext.ts +24 -0
- package/packages/react/src/collapsible/root/stateAttributesMapping.ts +9 -0
- package/packages/react/src/collapsible/root/useCollapsibleRoot.ts +116 -0
- package/packages/react/src/collapsible/trigger/CollapsibleTrigger.test.tsx +32 -0
- package/packages/react/src/collapsible/trigger/CollapsibleTrigger.tsx +76 -0
- package/packages/react/src/collapsible/trigger/CollapsibleTriggerDataAttributes.ts +6 -0
- package/packages/react/src/combobox/arrow/ComboboxArrow.test.tsx +19 -0
- package/packages/react/src/combobox/arrow/ComboboxArrow.tsx +72 -0
- package/packages/react/src/combobox/arrow/ComboboxArrowDataAttributes.ts +26 -0
- package/packages/react/src/combobox/backdrop/ComboboxBackdrop.test.tsx +17 -0
- package/packages/react/src/combobox/backdrop/ComboboxBackdrop.tsx +75 -0
- package/packages/react/src/combobox/backdrop/ComboboxBackdropDataAttributes.ts +20 -0
- package/packages/react/src/combobox/chip/ComboboxChip.test.tsx +447 -0
- package/packages/react/src/combobox/chip/ComboboxChip.tsx +152 -0
- package/packages/react/src/combobox/chip/ComboboxChipContext.ts +18 -0
- package/packages/react/src/combobox/chip-remove/ComboboxChipRemove.test.tsx +305 -0
- package/packages/react/src/combobox/chip-remove/ComboboxChipRemove.tsx +146 -0
- package/packages/react/src/combobox/chips/ComboboxChips.test.tsx +246 -0
- package/packages/react/src/combobox/chips/ComboboxChips.tsx +78 -0
- package/packages/react/src/combobox/chips/ComboboxChipsContext.ts +16 -0
- package/packages/react/src/combobox/clear/ComboboxClear.test.tsx +252 -0
- package/packages/react/src/combobox/clear/ComboboxClear.tsx +183 -0
- package/packages/react/src/combobox/clear/ComboboxClearDataAttributes.ts +27 -0
- package/packages/react/src/combobox/collection/ComboboxCollection.test.tsx +35 -0
- package/packages/react/src/combobox/collection/ComboboxCollection.tsx +38 -0
- package/packages/react/src/combobox/collection/GroupCollectionContext.tsx +31 -0
- package/packages/react/src/combobox/empty/ComboboxEmpty.test.tsx +214 -0
- package/packages/react/src/combobox/empty/ComboboxEmpty.tsx +56 -0
- package/packages/react/src/combobox/group/ComboboxGroup.test.tsx +54 -0
- package/packages/react/src/combobox/group/ComboboxGroup.tsx +66 -0
- package/packages/react/src/combobox/group/ComboboxGroupContext.ts +26 -0
- package/packages/react/src/combobox/group-label/ComboboxGroupLabel.test.tsx +60 -0
- package/packages/react/src/combobox/group-label/ComboboxGroupLabel.tsx +50 -0
- package/packages/react/src/combobox/icon/ComboboxIcon.test.tsx +13 -0
- package/packages/react/src/combobox/icon/ComboboxIcon.tsx +39 -0
- package/packages/react/src/combobox/index.parts.ts +30 -0
- package/packages/react/src/combobox/index.ts +32 -0
- package/packages/react/src/combobox/input/ComboboxInput.test.tsx +682 -0
- package/packages/react/src/combobox/input/ComboboxInput.tsx +552 -0
- package/packages/react/src/combobox/input/ComboboxInputDataAttributes.ts +57 -0
- package/packages/react/src/combobox/input-group/ComboboxInputGroup.test.tsx +206 -0
- package/packages/react/src/combobox/input-group/ComboboxInputGroup.tsx +116 -0
- package/packages/react/src/combobox/input-group/ComboboxInputGroupDataAttributes.ts +55 -0
- package/packages/react/src/combobox/item/ComboboxItem.test.tsx +519 -0
- package/packages/react/src/combobox/item/ComboboxItem.tsx +328 -0
- package/packages/react/src/combobox/item/ComboboxItemContext.ts +19 -0
- package/packages/react/src/combobox/item/ComboboxItemDataAttributes.ts +14 -0
- package/packages/react/src/combobox/item-indicator/ComboboxItemIndicator.test.tsx +17 -0
- package/packages/react/src/combobox/item-indicator/ComboboxItemIndicator.tsx +107 -0
- package/packages/react/src/combobox/item-indicator/ComboboxItemIndicatorDataAttributes.ts +12 -0
- package/packages/react/src/combobox/label/ComboboxLabel.test.tsx +25 -0
- package/packages/react/src/combobox/label/ComboboxLabel.tsx +83 -0
- package/packages/react/src/combobox/list/ComboboxList.test.tsx +34 -0
- package/packages/react/src/combobox/list/ComboboxList.tsx +149 -0
- package/packages/react/src/combobox/popup/ComboboxPopup.test.tsx +74 -0
- package/packages/react/src/combobox/popup/ComboboxPopup.tsx +214 -0
- package/packages/react/src/combobox/popup/ComboboxPopupDataAttributes.ts +39 -0
- package/packages/react/src/combobox/portal/ComboboxPortal.test.tsx +14 -0
- package/packages/react/src/combobox/portal/ComboboxPortal.tsx +52 -0
- package/packages/react/src/combobox/portal/ComboboxPortalContext.tsx +12 -0
- package/packages/react/src/combobox/positioner/ComboboxPositioner.test.tsx +144 -0
- package/packages/react/src/combobox/positioner/ComboboxPositioner.tsx +171 -0
- package/packages/react/src/combobox/positioner/ComboboxPositionerContext.tsx +30 -0
- package/packages/react/src/combobox/positioner/ComboboxPositionerCssVars.ts +27 -0
- package/packages/react/src/combobox/positioner/ComboboxPositionerDataAttributes.ts +30 -0
- package/packages/react/src/combobox/root/AriaCombobox.tsx +1687 -0
- package/packages/react/src/combobox/root/ComboboxRoot.spec.tsx +279 -0
- package/packages/react/src/combobox/root/ComboboxRoot.test.tsx +7788 -0
- package/packages/react/src/combobox/root/ComboboxRoot.tsx +176 -0
- package/packages/react/src/combobox/root/ComboboxRootContext.tsx +62 -0
- package/packages/react/src/combobox/root/utils/constants.ts +5 -0
- package/packages/react/src/combobox/root/utils/index.ts +65 -0
- package/packages/react/src/combobox/root/utils/useFilter.ts +55 -0
- package/packages/react/src/combobox/root/utils/useFilteredItems.ts +9 -0
- package/packages/react/src/combobox/row/ComboboxRow.tsx +35 -0
- package/packages/react/src/combobox/row/ComboboxRowContext.ts +8 -0
- package/packages/react/src/combobox/status/ComboboxStatus.iOS.test.tsx +49 -0
- package/packages/react/src/combobox/status/ComboboxStatus.test.tsx +124 -0
- package/packages/react/src/combobox/status/ComboboxStatus.tsx +47 -0
- package/packages/react/src/combobox/store.ts +180 -0
- package/packages/react/src/combobox/trigger/ComboboxTrigger.test.tsx +785 -0
- package/packages/react/src/combobox/trigger/ComboboxTrigger.tsx +327 -0
- package/packages/react/src/combobox/trigger/ComboboxTriggerDataAttributes.ts +61 -0
- package/packages/react/src/combobox/utils/ComboboxInternalDismissButton.tsx +46 -0
- package/packages/react/src/combobox/utils/handleInputPress.ts +39 -0
- package/packages/react/src/combobox/utils/stateAttributesMapping.ts +17 -0
- package/packages/react/src/combobox/utils/useInitialLiveRegionTextMutation.ts +65 -0
- package/packages/react/src/combobox/value/ComboboxValue.test.tsx +900 -0
- package/packages/react/src/combobox/value/ComboboxValue.tsx +58 -0
- package/packages/react/src/context-menu/index.parts.ts +21 -0
- package/packages/react/src/context-menu/index.ts +69 -0
- package/packages/react/src/context-menu/root/ContextMenuRoot.non-mac.test.tsx +76 -0
- package/packages/react/src/context-menu/root/ContextMenuRoot.test.tsx +283 -0
- package/packages/react/src/context-menu/root/ContextMenuRoot.tsx +80 -0
- package/packages/react/src/context-menu/root/ContextMenuRootContext.ts +33 -0
- package/packages/react/src/context-menu/trigger/ContextMenuTrigger.test.tsx +343 -0
- package/packages/react/src/context-menu/trigger/ContextMenuTrigger.tsx +218 -0
- package/packages/react/src/context-menu/trigger/ContextMenuTriggerDataAttributes.ts +12 -0
- package/packages/react/src/csp-provider/CSPProvider.test.tsx +76 -0
- package/packages/react/src/csp-provider/CSPProvider.tsx +43 -0
- package/packages/react/src/csp-provider/index.parts.ts +1 -0
- package/packages/react/src/csp-provider/index.ts +3 -0
- package/packages/react/src/dialog/backdrop/DialogBackdrop.test.tsx +149 -0
- package/packages/react/src/dialog/backdrop/DialogBackdrop.tsx +81 -0
- package/packages/react/src/dialog/backdrop/DialogBackdropDataAttributes.ts +20 -0
- package/packages/react/src/dialog/close/DialogClose.test.tsx +117 -0
- package/packages/react/src/dialog/close/DialogClose.tsx +65 -0
- package/packages/react/src/dialog/close/DialogCloseDataAttributes.ts +6 -0
- package/packages/react/src/dialog/description/DialogDescription.test.tsx +19 -0
- package/packages/react/src/dialog/description/DialogDescription.tsx +39 -0
- package/packages/react/src/dialog/index.parts.ts +10 -0
- package/packages/react/src/dialog/index.ts +11 -0
- package/packages/react/src/dialog/popup/DialogPopup.test.tsx +987 -0
- package/packages/react/src/dialog/popup/DialogPopup.tsx +181 -0
- package/packages/react/src/dialog/popup/DialogPopupCssVars.ts +7 -0
- package/packages/react/src/dialog/popup/DialogPopupDataAttributes.ts +28 -0
- package/packages/react/src/dialog/portal/DialogPortal.test.tsx +56 -0
- package/packages/react/src/dialog/portal/DialogPortal.tsx +61 -0
- package/packages/react/src/dialog/portal/DialogPortalContext.ts +12 -0
- package/packages/react/src/dialog/root/DialogRoot.detached-triggers.test.tsx +791 -0
- package/packages/react/src/dialog/root/DialogRoot.spec.tsx +28 -0
- package/packages/react/src/dialog/root/DialogRoot.test.tsx +1718 -0
- package/packages/react/src/dialog/root/DialogRoot.tsx +116 -0
- package/packages/react/src/dialog/root/DialogRootContext.ts +25 -0
- package/packages/react/src/dialog/root/useDialogRoot.ts +152 -0
- package/packages/react/src/dialog/root/useRenderDialogRoot.tsx +93 -0
- package/packages/react/src/dialog/store/DialogHandle.ts +83 -0
- package/packages/react/src/dialog/store/DialogStore.ts +145 -0
- package/packages/react/src/dialog/title/DialogTitle.test.tsx +19 -0
- package/packages/react/src/dialog/title/DialogTitle.tsx +39 -0
- package/packages/react/src/dialog/trigger/DialogTrigger.test.tsx +72 -0
- package/packages/react/src/dialog/trigger/DialogTrigger.tsx +140 -0
- package/packages/react/src/dialog/trigger/DialogTriggerDataAttributes.ts +12 -0
- package/packages/react/src/dialog/viewport/DialogViewport.test.tsx +66 -0
- package/packages/react/src/dialog/viewport/DialogViewport.tsx +101 -0
- package/packages/react/src/dialog/viewport/DialogViewportDataAttributes.ts +28 -0
- package/packages/react/src/direction-provider/DirectionProvider.spec.tsx +28 -0
- package/packages/react/src/direction-provider/DirectionProvider.test.tsx +42 -0
- package/packages/react/src/direction-provider/DirectionProvider.tsx +37 -0
- package/packages/react/src/direction-provider/index.parts.ts +5 -0
- package/packages/react/src/direction-provider/index.ts +2 -0
- package/packages/react/src/drawer/backdrop/DrawerBackdrop.tsx +86 -0
- package/packages/react/src/drawer/backdrop/DrawerBackdropCssVars.ts +7 -0
- package/packages/react/src/drawer/backdrop/DrawerBackdropDataAttributes.ts +20 -0
- package/packages/react/src/drawer/close/DrawerClose.tsx +31 -0
- package/packages/react/src/drawer/content/DrawerContent.test.tsx +40 -0
- package/packages/react/src/drawer/content/DrawerContent.tsx +35 -0
- package/packages/react/src/drawer/content/DrawerContentDataAttributes.ts +1 -0
- package/packages/react/src/drawer/description/DrawerDescription.tsx +25 -0
- package/packages/react/src/drawer/indent/DrawerIndent.test.tsx +40 -0
- package/packages/react/src/drawer/indent/DrawerIndent.tsx +102 -0
- package/packages/react/src/drawer/indent-background/DrawerIndentBackground.test.tsx +39 -0
- package/packages/react/src/drawer/indent-background/DrawerIndentBackground.tsx +59 -0
- package/packages/react/src/drawer/index.parts.ts +19 -0
- package/packages/react/src/drawer/index.ts +17 -0
- package/packages/react/src/drawer/popup/DrawerPopup.test.tsx +586 -0
- package/packages/react/src/drawer/popup/DrawerPopup.tsx +481 -0
- package/packages/react/src/drawer/popup/DrawerPopupCssVars.ts +37 -0
- package/packages/react/src/drawer/popup/DrawerPopupDataAttributes.ts +45 -0
- package/packages/react/src/drawer/portal/DrawerPortal.tsx +38 -0
- package/packages/react/src/drawer/provider/DrawerProvider.tsx +129 -0
- package/packages/react/src/drawer/provider/DrawerProviderContext.ts +36 -0
- package/packages/react/src/drawer/root/DrawerRoot.spec.tsx +39 -0
- package/packages/react/src/drawer/root/DrawerRoot.test.tsx +1263 -0
- package/packages/react/src/drawer/root/DrawerRoot.tsx +483 -0
- package/packages/react/src/drawer/root/DrawerRootContext.ts +111 -0
- package/packages/react/src/drawer/root/useDrawerSnapPoints.test.ts +18 -0
- package/packages/react/src/drawer/root/useDrawerSnapPoints.ts +205 -0
- package/packages/react/src/drawer/swipe-area/DrawerSwipeArea.test.tsx +522 -0
- package/packages/react/src/drawer/swipe-area/DrawerSwipeArea.tsx +488 -0
- package/packages/react/src/drawer/swipe-area/DrawerSwipeAreaDataAttributes.ts +25 -0
- package/packages/react/src/drawer/title/DrawerTitle.tsx +25 -0
- package/packages/react/src/drawer/trigger/DrawerTrigger.tsx +53 -0
- package/packages/react/src/drawer/viewport/DrawerViewport.test.tsx +2524 -0
- package/packages/react/src/drawer/viewport/DrawerViewport.tsx +1405 -0
- package/packages/react/src/drawer/viewport/DrawerViewportContext.tsx +25 -0
- package/packages/react/src/drawer/viewport/DrawerViewportCssVars.ts +8 -0
- package/packages/react/src/drawer/viewport/DrawerViewportDataAttributes.ts +24 -0
- package/packages/react/src/drawer/virtual-keyboard-provider/DrawerVirtualKeyboardContext.tsx +19 -0
- package/packages/react/src/drawer/virtual-keyboard-provider/DrawerVirtualKeyboardProvider.test.tsx +2053 -0
- package/packages/react/src/drawer/virtual-keyboard-provider/DrawerVirtualKeyboardProvider.tsx +644 -0
- package/packages/react/src/field/control/FieldControl.spec.tsx +7 -0
- package/packages/react/src/field/control/FieldControl.test.tsx +104 -0
- package/packages/react/src/field/control/FieldControl.tsx +179 -0
- package/packages/react/src/field/control/FieldControlDataAttributes.ts +30 -0
- package/packages/react/src/field/description/FieldDescription.test.tsx +54 -0
- package/packages/react/src/field/description/FieldDescription.tsx +65 -0
- package/packages/react/src/field/description/FieldDescriptionDataAttributes.ts +30 -0
- package/packages/react/src/field/error/FieldError.test.tsx +393 -0
- package/packages/react/src/field/error/FieldError.tsx +158 -0
- package/packages/react/src/field/error/FieldErrorDataAttributes.ts +40 -0
- package/packages/react/src/field/index.parts.ts +9 -0
- package/packages/react/src/field/index.ts +9 -0
- package/packages/react/src/field/item/FieldItem.test.tsx +84 -0
- package/packages/react/src/field/item/FieldItem.tsx +69 -0
- package/packages/react/src/field/item/FieldItemContext.ts +14 -0
- package/packages/react/src/field/item/FieldItemDataAttributes.ts +30 -0
- package/packages/react/src/field/label/FieldLabel.test.tsx +128 -0
- package/packages/react/src/field/label/FieldLabel.tsx +104 -0
- package/packages/react/src/field/label/FieldLabelDataAttributes.ts +30 -0
- package/packages/react/src/field/root/FieldRoot.test.tsx +1688 -0
- package/packages/react/src/field/root/FieldRoot.tsx +344 -0
- package/packages/react/src/field/root/FieldRootDataAttributes.ts +30 -0
- package/packages/react/src/field/root/useFieldValidation.ts +363 -0
- package/packages/react/src/field/utils/getCombinedFieldValidityData.ts +18 -0
- package/packages/react/src/field/validity/FieldValidity.test.tsx +104 -0
- package/packages/react/src/field/validity/FieldValidity.tsx +66 -0
- package/packages/react/src/fieldset/index.parts.ts +2 -0
- package/packages/react/src/fieldset/index.ts +4 -0
- package/packages/react/src/fieldset/legend/FieldsetLegend.test.tsx +79 -0
- package/packages/react/src/fieldset/legend/FieldsetLegend.tsx +57 -0
- package/packages/react/src/fieldset/root/FieldsetRoot.test.tsx +66 -0
- package/packages/react/src/fieldset/root/FieldsetRoot.tsx +72 -0
- package/packages/react/src/fieldset/root/FieldsetRootContext.ts +22 -0
- package/packages/react/src/floating-ui-react/components/FloatingDelayGroup.test.tsx +344 -0
- package/packages/react/src/floating-ui-react/components/FloatingDelayGroup.tsx +286 -0
- package/packages/react/src/floating-ui-react/components/FloatingFocusManager.test.tsx +2325 -0
- package/packages/react/src/floating-ui-react/components/FloatingFocusManager.tsx +991 -0
- package/packages/react/src/floating-ui-react/components/FloatingPortal.test.tsx +153 -0
- package/packages/react/src/floating-ui-react/components/FloatingPortal.tsx +307 -0
- package/packages/react/src/floating-ui-react/components/FloatingRootStore.ts +140 -0
- package/packages/react/src/floating-ui-react/components/FloatingTree.tsx +95 -0
- package/packages/react/src/floating-ui-react/components/FloatingTreeStore.ts +23 -0
- package/packages/react/src/floating-ui-react/hooks/gridNavigation.ts +50 -0
- package/packages/react/src/floating-ui-react/hooks/useClick.test.tsx +298 -0
- package/packages/react/src/floating-ui-react/hooks/useClick.ts +226 -0
- package/packages/react/src/floating-ui-react/hooks/useClientPoint.test.tsx +505 -0
- package/packages/react/src/floating-ui-react/hooks/useClientPoint.ts +260 -0
- package/packages/react/src/floating-ui-react/hooks/useDismiss.test.tsx +1217 -0
- package/packages/react/src/floating-ui-react/hooks/useDismiss.ts +754 -0
- package/packages/react/src/floating-ui-react/hooks/useFloating.test.tsx +42 -0
- package/packages/react/src/floating-ui-react/hooks/useFloating.ts +184 -0
- package/packages/react/src/floating-ui-react/hooks/useFloatingRootContext.ts +80 -0
- package/packages/react/src/floating-ui-react/hooks/useFocus.ts +250 -0
- package/packages/react/src/floating-ui-react/hooks/useHover.test.tsx +369 -0
- package/packages/react/src/floating-ui-react/hooks/useHover.ts +467 -0
- package/packages/react/src/floating-ui-react/hooks/useHoverFloatingInteraction.ts +273 -0
- package/packages/react/src/floating-ui-react/hooks/useHoverInteractionSharedState.ts +131 -0
- package/packages/react/src/floating-ui-react/hooks/useHoverReferenceInteraction.test.tsx +350 -0
- package/packages/react/src/floating-ui-react/hooks/useHoverReferenceInteraction.ts +481 -0
- package/packages/react/src/floating-ui-react/hooks/useHoverShared.ts +72 -0
- package/packages/react/src/floating-ui-react/hooks/useListNavigation.test.tsx +1528 -0
- package/packages/react/src/floating-ui-react/hooks/useListNavigation.ts +930 -0
- package/packages/react/src/floating-ui-react/hooks/useSyncedFloatingRootContext.ts +101 -0
- package/packages/react/src/floating-ui-react/hooks/useTypeahead.test.tsx +343 -0
- package/packages/react/src/floating-ui-react/hooks/useTypeahead.ts +253 -0
- package/packages/react/src/floating-ui-react/index.ts +41 -0
- package/packages/react/src/floating-ui-react/middleware/arrow.ts +123 -0
- package/packages/react/src/floating-ui-react/safePolygon.test.ts +340 -0
- package/packages/react/src/floating-ui-react/safePolygon.ts +451 -0
- package/packages/react/src/floating-ui-react/types.ts +202 -0
- package/packages/react/src/floating-ui-react/utils/composite.test.ts +45 -0
- package/packages/react/src/floating-ui-react/utils/composite.ts +518 -0
- package/packages/react/src/floating-ui-react/utils/constants.ts +10 -0
- package/packages/react/src/floating-ui-react/utils/createAttribute.ts +3 -0
- package/packages/react/src/floating-ui-react/utils/createEventEmitter.ts +19 -0
- package/packages/react/src/floating-ui-react/utils/element.ts +95 -0
- package/packages/react/src/floating-ui-react/utils/enqueueFocus.ts +37 -0
- package/packages/react/src/floating-ui-react/utils/event.ts +59 -0
- package/packages/react/src/floating-ui-react/utils/getEmptyRootContext.ts +17 -0
- package/packages/react/src/floating-ui-react/utils/markOthers.test.ts +310 -0
- package/packages/react/src/floating-ui-react/utils/markOthers.ts +219 -0
- package/packages/react/src/floating-ui-react/utils/nodes.test.ts +115 -0
- package/packages/react/src/floating-ui-react/utils/nodes.ts +54 -0
- package/packages/react/src/floating-ui-react/utils/tabbable.test.ts +378 -0
- package/packages/react/src/floating-ui-react/utils/tabbable.ts +282 -0
- package/packages/react/src/floating-ui-react/utils.ts +5 -0
- package/packages/react/src/form/Form.spec.tsx +17 -0
- package/packages/react/src/form/Form.test.tsx +752 -0
- package/packages/react/src/form/Form.tsx +229 -0
- package/packages/react/src/form/index.ts +3 -0
- package/packages/react/src/global.d.ts +9 -0
- package/packages/react/src/index.test.ts +60 -0
- package/packages/react/src/index.ts +44 -0
- package/packages/react/src/input/Input.spec.tsx +7 -0
- package/packages/react/src/input/Input.test.tsx +12 -0
- package/packages/react/src/input/Input.tsx +44 -0
- package/packages/react/src/input/InputDataAttributes.ts +30 -0
- package/packages/react/src/input/index.ts +3 -0
- package/packages/react/src/internals/RequestQueue.test.ts +152 -0
- package/packages/react/src/internals/RequestQueue.ts +126 -0
- package/packages/react/src/internals/TimeoutManager.test.ts +76 -0
- package/packages/react/src/internals/TimeoutManager.ts +29 -0
- package/packages/react/src/internals/areArraysEqual.ts +12 -0
- package/packages/react/src/internals/clamp.test.ts +10 -0
- package/packages/react/src/internals/clamp.ts +7 -0
- package/packages/react/src/internals/composite/composite.ts +182 -0
- package/packages/react/src/internals/composite/constants.ts +1 -0
- package/packages/react/src/internals/composite/index.ts +18 -0
- package/packages/react/src/internals/composite/item/CompositeItem.tsx +59 -0
- package/packages/react/src/internals/composite/item/useCompositeItem.ts +49 -0
- package/packages/react/src/internals/composite/list/CompositeList.test.tsx +37 -0
- package/packages/react/src/internals/composite/list/CompositeList.tsx +195 -0
- package/packages/react/src/internals/composite/list/CompositeListContext.ts +25 -0
- package/packages/react/src/internals/composite/list/useCompositeListItem.ts +103 -0
- package/packages/react/src/internals/composite/root/CompositeRoot.test.tsx +1018 -0
- package/packages/react/src/internals/composite/root/CompositeRoot.tsx +141 -0
- package/packages/react/src/internals/composite/root/CompositeRootContext.ts +32 -0
- package/packages/react/src/internals/composite/root/gridNavigation.ts +127 -0
- package/packages/react/src/internals/composite/root/useCompositeRoot.ts +355 -0
- package/packages/react/src/internals/constants.ts +41 -0
- package/packages/react/src/internals/createBaseUIEventDetails.spec.ts +12 -0
- package/packages/react/src/internals/createBaseUIEventDetails.ts +166 -0
- package/packages/react/src/internals/csp-context/CSPContext.tsx +23 -0
- package/packages/react/src/internals/csp-context/index.ts +2 -0
- package/packages/react/src/internals/direction-context/DirectionContext.tsx +19 -0
- package/packages/react/src/internals/direction-context/index.ts +2 -0
- package/packages/react/src/internals/field-constants/constants.ts +48 -0
- package/packages/react/src/internals/field-constants/index.ts +6 -0
- package/packages/react/src/internals/field-register-control/index.ts +6 -0
- package/packages/react/src/internals/field-register-control/useFieldControlRegistration.ts +169 -0
- package/packages/react/src/internals/field-register-control/useRegisterFieldControl.ts +43 -0
- package/packages/react/src/internals/field-root-context/FieldRootContext.ts +94 -0
- package/packages/react/src/internals/field-root-context/index.ts +2 -0
- package/packages/react/src/internals/filter.test.ts +11 -0
- package/packages/react/src/internals/filter.ts +82 -0
- package/packages/react/src/internals/form-context/FormContext.ts +48 -0
- package/packages/react/src/internals/form-context/index.ts +2 -0
- package/packages/react/src/internals/getStateAttributesProps.test.ts +83 -0
- package/packages/react/src/internals/getStateAttributesProps.ts +32 -0
- package/packages/react/src/internals/itemEquality.ts +60 -0
- package/packages/react/src/internals/labelable-provider/LabelableContext.ts +42 -0
- package/packages/react/src/internals/labelable-provider/LabelableProvider.tsx +116 -0
- package/packages/react/src/internals/labelable-provider/index.ts +6 -0
- package/packages/react/src/internals/labelable-provider/useAriaLabelledBy.ts +75 -0
- package/packages/react/src/internals/labelable-provider/useLabel.ts +111 -0
- package/packages/react/src/internals/labelable-provider/useLabelableId.ts +100 -0
- package/packages/react/src/internals/noop.ts +1 -0
- package/packages/react/src/internals/reason-parts.ts +42 -0
- package/packages/react/src/internals/reasons.ts +5 -0
- package/packages/react/src/internals/resolveValueLabel.test.ts +101 -0
- package/packages/react/src/internals/resolveValueLabel.tsx +151 -0
- package/packages/react/src/internals/serializeValue.ts +13 -0
- package/packages/react/src/internals/shadowDom.ts +47 -0
- package/packages/react/src/internals/stateAttributesMapping.ts +28 -0
- package/packages/react/src/internals/temporal/index.ts +2 -0
- package/packages/react/src/internals/temporal/temporal-adapter.ts +382 -0
- package/packages/react/src/internals/temporal/temporal.ts +49 -0
- package/packages/react/src/internals/temporal-adapter-date-fns/TemporalAdapterDateFns.test.ts +63 -0
- package/packages/react/src/internals/temporal-adapter-date-fns/TemporalAdapterDateFns.ts +474 -0
- package/packages/react/src/internals/temporal-adapter-date-fns/index.ts +1 -0
- package/packages/react/src/internals/temporal-adapter-luxon/TemporalAdapterLuxon.test.ts +16 -0
- package/packages/react/src/internals/temporal-adapter-luxon/TemporalAdapterLuxon.ts +380 -0
- package/packages/react/src/internals/temporal-adapter-luxon/index.ts +1 -0
- package/packages/react/src/internals/types.ts +97 -0
- package/packages/react/src/internals/use-button/index.ts +1 -0
- package/packages/react/src/internals/use-button/useButton.test.tsx +820 -0
- package/packages/react/src/internals/use-button/useButton.ts +290 -0
- package/packages/react/src/internals/useAnimationsFinished.ts +121 -0
- package/packages/react/src/internals/useBaseUiId.ts +11 -0
- package/packages/react/src/internals/useOpenChangeComplete.tsx +50 -0
- package/packages/react/src/internals/usePressAndHold.ts +288 -0
- package/packages/react/src/internals/useRenderElement.spec.tsx +38 -0
- package/packages/react/src/internals/useRenderElement.test.tsx +588 -0
- package/packages/react/src/internals/useRenderElement.tsx +287 -0
- package/packages/react/src/internals/useTransitionStatus.ts +89 -0
- package/packages/react/src/internals/useValueChanged.ts +21 -0
- package/packages/react/src/menu/arrow/MenuArrow.test.tsx +21 -0
- package/packages/react/src/menu/arrow/MenuArrow.tsx +69 -0
- package/packages/react/src/menu/arrow/MenuArrowDataAttributes.ts +26 -0
- package/packages/react/src/menu/backdrop/MenuBackdrop.test.tsx +55 -0
- package/packages/react/src/menu/backdrop/MenuBackdrop.tsx +80 -0
- package/packages/react/src/menu/backdrop/MenuBackdropDataAttributes.ts +20 -0
- package/packages/react/src/menu/checkbox-item/MenuCheckboxItem.test.tsx +452 -0
- package/packages/react/src/menu/checkbox-item/MenuCheckboxItem.tsx +180 -0
- package/packages/react/src/menu/checkbox-item/MenuCheckboxItemContext.ts +23 -0
- package/packages/react/src/menu/checkbox-item/MenuCheckboxItemDataAttributes.ts +18 -0
- package/packages/react/src/menu/checkbox-item-indicator/MenuCheckboxItemIndicator.test.tsx +131 -0
- package/packages/react/src/menu/checkbox-item-indicator/MenuCheckboxItemIndicator.tsx +92 -0
- package/packages/react/src/menu/checkbox-item-indicator/MenuCheckboxItemIndicatorDataAttributes.ts +24 -0
- package/packages/react/src/menu/group/MenuGroup.test.tsx +18 -0
- package/packages/react/src/menu/group/MenuGroup.tsx +45 -0
- package/packages/react/src/menu/group/MenuGroupContext.ts +17 -0
- package/packages/react/src/menu/group-label/MenuGroupLabel.test.tsx +142 -0
- package/packages/react/src/menu/group-label/MenuGroupLabel.tsx +49 -0
- package/packages/react/src/menu/index.parts.ts +21 -0
- package/packages/react/src/menu/index.ts +21 -0
- package/packages/react/src/menu/item/MenuItem.test.tsx +257 -0
- package/packages/react/src/menu/item/MenuItem.tsx +105 -0
- package/packages/react/src/menu/item/MenuItemDataAttributes.ts +10 -0
- package/packages/react/src/menu/item/useMenuItem.ts +144 -0
- package/packages/react/src/menu/item/useMenuItemCommonProps.ts +136 -0
- package/packages/react/src/menu/link-item/MenuLinkItem.test.tsx +167 -0
- package/packages/react/src/menu/link-item/MenuLinkItem.tsx +100 -0
- package/packages/react/src/menu/link-item/MenuLinkItemDataAttributes.ts +6 -0
- package/packages/react/src/menu/popup/MenuPopup.test.tsx +214 -0
- package/packages/react/src/menu/popup/MenuPopup.tsx +210 -0
- package/packages/react/src/menu/popup/MenuPopupDataAttributes.ts +35 -0
- package/packages/react/src/menu/portal/MenuPortal.test.tsx +14 -0
- package/packages/react/src/menu/portal/MenuPortal.tsx +48 -0
- package/packages/react/src/menu/portal/MenuPortalContext.ts +12 -0
- package/packages/react/src/menu/positioner/MenuPositioner.spec.tsx +4 -0
- package/packages/react/src/menu/positioner/MenuPositioner.test.tsx +662 -0
- package/packages/react/src/menu/positioner/MenuPositioner.tsx +355 -0
- package/packages/react/src/menu/positioner/MenuPositionerContext.ts +24 -0
- package/packages/react/src/menu/positioner/MenuPositionerCssVars.ts +27 -0
- package/packages/react/src/menu/positioner/MenuPositionerDataAttributes.ts +26 -0
- package/packages/react/src/menu/radio-group/MenuRadioGroup.test.tsx +18 -0
- package/packages/react/src/menu/radio-group/MenuRadioGroup.tsx +130 -0
- package/packages/react/src/menu/radio-group/MenuRadioGroupContext.ts +24 -0
- package/packages/react/src/menu/radio-item/MenuRadioItem.test.tsx +528 -0
- package/packages/react/src/menu/radio-item/MenuRadioItem.tsx +152 -0
- package/packages/react/src/menu/radio-item/MenuRadioItemContext.ts +23 -0
- package/packages/react/src/menu/radio-item/MenuRadioItemDataAttributes.ts +18 -0
- package/packages/react/src/menu/radio-item-indicator/MenuRadioItemIndicator.test.tsx +141 -0
- package/packages/react/src/menu/radio-item-indicator/MenuRadioItemIndicator.tsx +92 -0
- package/packages/react/src/menu/radio-item-indicator/MenuRadioItemIndicatorDataAttributes.ts +24 -0
- package/packages/react/src/menu/root/MenuRoot.detached-triggers.test.tsx +1126 -0
- package/packages/react/src/menu/root/MenuRoot.test.tsx +2761 -0
- package/packages/react/src/menu/root/MenuRoot.tsx +684 -0
- package/packages/react/src/menu/root/MenuRootContext.ts +24 -0
- package/packages/react/src/menu/store/MenuHandle.ts +56 -0
- package/packages/react/src/menu/store/MenuStore.ts +216 -0
- package/packages/react/src/menu/submenu-root/MenuSubmenuRoot.tsx +65 -0
- package/packages/react/src/menu/submenu-root/MenuSubmenuRootContext.ts +15 -0
- package/packages/react/src/menu/submenu-trigger/MenuSubmenuTrigger.test.tsx +242 -0
- package/packages/react/src/menu/submenu-trigger/MenuSubmenuTrigger.tsx +245 -0
- package/packages/react/src/menu/submenu-trigger/MenuSubmenuTriggerDataAttributes.ts +16 -0
- package/packages/react/src/menu/trigger/MenuTrigger.test.tsx +468 -0
- package/packages/react/src/menu/trigger/MenuTrigger.tsx +417 -0
- package/packages/react/src/menu/trigger/MenuTriggerDataAttributes.ts +12 -0
- package/packages/react/src/menu/utils/findRootOwnerId.ts +13 -0
- package/packages/react/src/menu/utils/stateAttributesMapping.ts +17 -0
- package/packages/react/src/menu/utils/types.ts +8 -0
- package/packages/react/src/menu/viewport/MenuViewport.test.tsx +410 -0
- package/packages/react/src/menu/viewport/MenuViewport.tsx +85 -0
- package/packages/react/src/menu/viewport/MenuViewportCssVars.ts +14 -0
- package/packages/react/src/menu/viewport/MenuViewportDataAttributes.ts +26 -0
- package/packages/react/src/menubar/Menubar.test.tsx +1342 -0
- package/packages/react/src/menubar/Menubar.tsx +169 -0
- package/packages/react/src/menubar/MenubarContext.ts +30 -0
- package/packages/react/src/menubar/MenubarDataAttributes.ts +15 -0
- package/packages/react/src/menubar/index.ts +3 -0
- package/packages/react/src/merge-props/index.ts +1 -0
- package/packages/react/src/merge-props/mergeProps.test.ts +599 -0
- package/packages/react/src/merge-props/mergeProps.ts +296 -0
- package/packages/react/src/meter/index.parts.ts +5 -0
- package/packages/react/src/meter/index.ts +7 -0
- package/packages/react/src/meter/indicator/MeterIndicator.test.tsx +89 -0
- package/packages/react/src/meter/indicator/MeterIndicator.tsx +44 -0
- package/packages/react/src/meter/label/MeterLabel.test.tsx +13 -0
- package/packages/react/src/meter/label/MeterLabel.tsx +44 -0
- package/packages/react/src/meter/root/MeterRoot.test.tsx +262 -0
- package/packages/react/src/meter/root/MeterRoot.tsx +129 -0
- package/packages/react/src/meter/root/MeterRootContext.ts +27 -0
- package/packages/react/src/meter/track/MeterTrack.test.tsx +13 -0
- package/packages/react/src/meter/track/MeterTrack.tsx +32 -0
- package/packages/react/src/meter/value/MeterValue.test.tsx +87 -0
- package/packages/react/src/meter/value/MeterValue.tsx +46 -0
- package/packages/react/src/navigation-menu/arrow/NavigationMenuArrow.test.tsx +19 -0
- package/packages/react/src/navigation-menu/arrow/NavigationMenuArrow.tsx +75 -0
- package/packages/react/src/navigation-menu/arrow/NavigationMenuArrowDataAttributes.ts +26 -0
- package/packages/react/src/navigation-menu/backdrop/NavigationMenuBackdrop.test.tsx +13 -0
- package/packages/react/src/navigation-menu/backdrop/NavigationMenuBackdrop.tsx +74 -0
- package/packages/react/src/navigation-menu/backdrop/NavigationMenuBackdropDataAttributes.ts +20 -0
- package/packages/react/src/navigation-menu/content/NavigationMenuContent.test.tsx +221 -0
- package/packages/react/src/navigation-menu/content/NavigationMenuContent.tsx +205 -0
- package/packages/react/src/navigation-menu/content/NavigationMenuContentDataAttributes.ts +25 -0
- package/packages/react/src/navigation-menu/icon/NavigationMenuIcon.test.tsx +17 -0
- package/packages/react/src/navigation-menu/icon/NavigationMenuIcon.tsx +54 -0
- package/packages/react/src/navigation-menu/icon/NavigationMenuIconDataAttributes.ts +8 -0
- package/packages/react/src/navigation-menu/index.parts.ts +13 -0
- package/packages/react/src/navigation-menu/index.ts +15 -0
- package/packages/react/src/navigation-menu/item/NavigationMenuItem.test.tsx +13 -0
- package/packages/react/src/navigation-menu/item/NavigationMenuItem.tsx +57 -0
- package/packages/react/src/navigation-menu/item/NavigationMenuItemContext.ts +20 -0
- package/packages/react/src/navigation-menu/link/NavigationMenuLink.test.tsx +133 -0
- package/packages/react/src/navigation-menu/link/NavigationMenuLink.tsx +105 -0
- package/packages/react/src/navigation-menu/link/NavigationMenuLinkDataAttributes.ts +6 -0
- package/packages/react/src/navigation-menu/list/NavigationMenuDismissContext.ts +11 -0
- package/packages/react/src/navigation-menu/list/NavigationMenuList.test.tsx +13 -0
- package/packages/react/src/navigation-menu/list/NavigationMenuList.tsx +142 -0
- package/packages/react/src/navigation-menu/popup/NavigationMenuPopup.test.tsx +19 -0
- package/packages/react/src/navigation-menu/popup/NavigationMenuPopup.tsx +111 -0
- package/packages/react/src/navigation-menu/popup/NavigationMenuPopupCssVars.ts +12 -0
- package/packages/react/src/navigation-menu/popup/NavigationMenuPopupDataAttributes.ts +34 -0
- package/packages/react/src/navigation-menu/portal/NavigationMenuPortal.test.tsx +14 -0
- package/packages/react/src/navigation-menu/portal/NavigationMenuPortal.tsx +51 -0
- package/packages/react/src/navigation-menu/portal/NavigationMenuPortalContext.ts +12 -0
- package/packages/react/src/navigation-menu/positioner/NavigationMenuPositioner.test.tsx +17 -0
- package/packages/react/src/navigation-menu/positioner/NavigationMenuPositioner.tsx +219 -0
- package/packages/react/src/navigation-menu/positioner/NavigationMenuPositionerContext.ts +25 -0
- package/packages/react/src/navigation-menu/positioner/NavigationMenuPositionerCssVars.ts +37 -0
- package/packages/react/src/navigation-menu/positioner/NavigationMenuPositionerDataAttributes.ts +30 -0
- package/packages/react/src/navigation-menu/root/NavigationMenuRoot.spec.tsx +63 -0
- package/packages/react/src/navigation-menu/root/NavigationMenuRoot.test.tsx +3769 -0
- package/packages/react/src/navigation-menu/root/NavigationMenuRoot.tsx +439 -0
- package/packages/react/src/navigation-menu/root/NavigationMenuRoot.webkit.test.tsx +140 -0
- package/packages/react/src/navigation-menu/root/NavigationMenuRootContext.ts +83 -0
- package/packages/react/src/navigation-menu/trigger/NavigationMenuTrigger.test.tsx +448 -0
- package/packages/react/src/navigation-menu/trigger/NavigationMenuTrigger.tsx +914 -0
- package/packages/react/src/navigation-menu/trigger/NavigationMenuTriggerDataAttributes.ts +12 -0
- package/packages/react/src/navigation-menu/utils/constants.ts +3 -0
- package/packages/react/src/navigation-menu/utils/isOutsideMenuEvent.ts +41 -0
- package/packages/react/src/navigation-menu/utils/setSharedFixedSize.ts +20 -0
- package/packages/react/src/navigation-menu/viewport/NavigationMenuViewport.test.tsx +13 -0
- package/packages/react/src/navigation-menu/viewport/NavigationMenuViewport.tsx +144 -0
- package/packages/react/src/number-field/decrement/NumberFieldDecrement.test.tsx +572 -0
- package/packages/react/src/number-field/decrement/NumberFieldDecrement.tsx +28 -0
- package/packages/react/src/number-field/decrement/NumberFieldDecrementDataAttributes.ts +42 -0
- package/packages/react/src/number-field/group/NumberFieldGroup.test.tsx +24 -0
- package/packages/react/src/number-field/group/NumberFieldGroup.tsx +40 -0
- package/packages/react/src/number-field/group/NumberFieldGroupDataAttributes.ts +42 -0
- package/packages/react/src/number-field/increment/NumberFieldIncrement.test.tsx +829 -0
- package/packages/react/src/number-field/increment/NumberFieldIncrement.tsx +28 -0
- package/packages/react/src/number-field/increment/NumberFieldIncrementDataAttributes.ts +42 -0
- package/packages/react/src/number-field/index.parts.ts +7 -0
- package/packages/react/src/number-field/index.ts +9 -0
- package/packages/react/src/number-field/input/NumberFieldInput.test.tsx +1408 -0
- package/packages/react/src/number-field/input/NumberFieldInput.tsx +485 -0
- package/packages/react/src/number-field/input/NumberFieldInputDataAttributes.ts +42 -0
- package/packages/react/src/number-field/root/NumberFieldRoot.spec.tsx +74 -0
- package/packages/react/src/number-field/root/NumberFieldRoot.test.tsx +2595 -0
- package/packages/react/src/number-field/root/NumberFieldRoot.tsx +718 -0
- package/packages/react/src/number-field/root/NumberFieldRootContext.ts +57 -0
- package/packages/react/src/number-field/root/NumberFieldRootDataAttributes.ts +42 -0
- package/packages/react/src/number-field/root/useNumberFieldButton.ts +175 -0
- package/packages/react/src/number-field/root/useNumberFieldStepperButton.ts +91 -0
- package/packages/react/src/number-field/scrub-area/NumberFieldScrubArea.test.tsx +351 -0
- package/packages/react/src/number-field/scrub-area/NumberFieldScrubArea.tsx +393 -0
- package/packages/react/src/number-field/scrub-area/NumberFieldScrubAreaContext.ts +23 -0
- package/packages/react/src/number-field/scrub-area/NumberFieldScrubAreaDataAttributes.ts +42 -0
- package/packages/react/src/number-field/scrub-area-cursor/NumberFieldScrubAreaCursor.test.tsx +203 -0
- package/packages/react/src/number-field/scrub-area-cursor/NumberFieldScrubAreaCursor.tsx +71 -0
- package/packages/react/src/number-field/scrub-area-cursor/NumberFieldScrubAreaCursorDataAttributes.ts +42 -0
- package/packages/react/src/number-field/utils/constants.ts +3 -0
- package/packages/react/src/number-field/utils/getViewportRect.ts +34 -0
- package/packages/react/src/number-field/utils/parse.test.ts +298 -0
- package/packages/react/src/number-field/utils/parse.ts +252 -0
- package/packages/react/src/number-field/utils/stateAttributesMapping.ts +9 -0
- package/packages/react/src/number-field/utils/subscribeToVisualViewportResize.ts +24 -0
- package/packages/react/src/number-field/utils/types.ts +24 -0
- package/packages/react/src/number-field/utils/validate.test.ts +730 -0
- package/packages/react/src/number-field/utils/validate.ts +151 -0
- package/packages/react/src/otp-field/index.parts.ts +3 -0
- package/packages/react/src/otp-field/index.ts +4 -0
- package/packages/react/src/otp-field/input/OTPFieldInput.spec.tsx +5 -0
- package/packages/react/src/otp-field/input/OTPFieldInput.test.tsx +811 -0
- package/packages/react/src/otp-field/input/OTPFieldInput.tsx +356 -0
- package/packages/react/src/otp-field/input/OTPFieldInputDataAttributes.ts +42 -0
- package/packages/react/src/otp-field/root/OTPFieldRoot.spec.tsx +113 -0
- package/packages/react/src/otp-field/root/OTPFieldRoot.test.tsx +1407 -0
- package/packages/react/src/otp-field/root/OTPFieldRoot.tsx +680 -0
- package/packages/react/src/otp-field/root/OTPFieldRootContext.ts +57 -0
- package/packages/react/src/otp-field/root/OTPFieldRootDataAttributes.ts +42 -0
- package/packages/react/src/otp-field/utils/otp.test.ts +94 -0
- package/packages/react/src/otp-field/utils/otp.ts +118 -0
- package/packages/react/src/otp-field/utils/stateAttributesMapping.ts +16 -0
- package/packages/react/src/popover/arrow/PopoverArrow.test.tsx +22 -0
- package/packages/react/src/popover/arrow/PopoverArrow.tsx +67 -0
- package/packages/react/src/popover/arrow/PopoverArrowDataAttributes.ts +26 -0
- package/packages/react/src/popover/backdrop/PopoverBackdrop.test.tsx +55 -0
- package/packages/react/src/popover/backdrop/PopoverBackdrop.tsx +78 -0
- package/packages/react/src/popover/backdrop/PopoverBackdropDataAttributes.ts +20 -0
- package/packages/react/src/popover/close/PopoverClose.test.tsx +159 -0
- package/packages/react/src/popover/close/PopoverClose.tsx +63 -0
- package/packages/react/src/popover/description/PopoverDescription.test.tsx +42 -0
- package/packages/react/src/popover/description/PopoverDescription.tsx +44 -0
- package/packages/react/src/popover/index.parts.ts +15 -0
- package/packages/react/src/popover/index.ts +13 -0
- package/packages/react/src/popover/popup/PopoverPopup.test.tsx +623 -0
- package/packages/react/src/popover/popup/PopoverPopup.tsx +200 -0
- package/packages/react/src/popover/popup/PopoverPopupCssVars.ts +10 -0
- package/packages/react/src/popover/popup/PopoverPopupDataAttributes.ts +35 -0
- package/packages/react/src/popover/portal/PopoverPortal.test.tsx +14 -0
- package/packages/react/src/popover/portal/PopoverPortal.tsx +48 -0
- package/packages/react/src/popover/portal/PopoverPortalContext.ts +12 -0
- package/packages/react/src/popover/positioner/PopoverPositioner.spec.tsx +4 -0
- package/packages/react/src/popover/positioner/PopoverPositioner.test.tsx +478 -0
- package/packages/react/src/popover/positioner/PopoverPositioner.tsx +200 -0
- package/packages/react/src/popover/positioner/PopoverPositionerContext.ts +27 -0
- package/packages/react/src/popover/positioner/PopoverPositionerCssVars.ts +37 -0
- package/packages/react/src/popover/positioner/PopoverPositionerDataAttributes.ts +26 -0
- package/packages/react/src/popover/root/PopoverRoot.detached-triggers.test.tsx +961 -0
- package/packages/react/src/popover/root/PopoverRoot.spec.tsx +27 -0
- package/packages/react/src/popover/root/PopoverRoot.test.tsx +2347 -0
- package/packages/react/src/popover/root/PopoverRoot.tsx +249 -0
- package/packages/react/src/popover/root/PopoverRootContext.ts +21 -0
- package/packages/react/src/popover/store/PopoverHandle.ts +64 -0
- package/packages/react/src/popover/store/PopoverStore.ts +216 -0
- package/packages/react/src/popover/title/PopoverTitle.test.tsx +42 -0
- package/packages/react/src/popover/title/PopoverTitle.tsx +44 -0
- package/packages/react/src/popover/trigger/PopoverTrigger.test.tsx +411 -0
- package/packages/react/src/popover/trigger/PopoverTrigger.tsx +233 -0
- package/packages/react/src/popover/trigger/PopoverTriggerDataAttributes.ts +12 -0
- package/packages/react/src/popover/utils/constants.ts +1 -0
- package/packages/react/src/popover/viewport/PopoverViewport.test.tsx +494 -0
- package/packages/react/src/popover/viewport/PopoverViewport.tsx +85 -0
- package/packages/react/src/popover/viewport/PopoverViewportCssVars.ts +14 -0
- package/packages/react/src/popover/viewport/PopoverViewportDataAttributes.ts +26 -0
- package/packages/react/src/preview-card/arrow/PreviewCardArrow.test.tsx +21 -0
- package/packages/react/src/preview-card/arrow/PreviewCardArrow.tsx +68 -0
- package/packages/react/src/preview-card/arrow/PreviewCardArrowDataAttributes.ts +26 -0
- package/packages/react/src/preview-card/backdrop/PreviewCardBackdrop.test.tsx +37 -0
- package/packages/react/src/preview-card/backdrop/PreviewCardBackdrop.tsx +78 -0
- package/packages/react/src/preview-card/backdrop/PreviewCardBackdropDataAttributes.ts +20 -0
- package/packages/react/src/preview-card/index.parts.ts +12 -0
- package/packages/react/src/preview-card/index.ts +10 -0
- package/packages/react/src/preview-card/popup/PreviewCardPopup.test.tsx +35 -0
- package/packages/react/src/preview-card/popup/PreviewCardPopup.tsx +105 -0
- package/packages/react/src/preview-card/popup/PreviewCardPopupDataAttributes.ts +30 -0
- package/packages/react/src/preview-card/portal/PreviewCardPortal.test.tsx +14 -0
- package/packages/react/src/preview-card/portal/PreviewCardPortal.tsx +48 -0
- package/packages/react/src/preview-card/portal/PreviewCardPortalContext.ts +12 -0
- package/packages/react/src/preview-card/positioner/PreviewCardPositioner.spec.tsx +4 -0
- package/packages/react/src/preview-card/positioner/PreviewCardPositioner.test.tsx +1103 -0
- package/packages/react/src/preview-card/positioner/PreviewCardPositioner.tsx +144 -0
- package/packages/react/src/preview-card/positioner/PreviewCardPositionerContext.ts +23 -0
- package/packages/react/src/preview-card/positioner/PreviewCardPositionerCssVars.ts +27 -0
- package/packages/react/src/preview-card/positioner/PreviewCardPositionerDataAttributes.ts +26 -0
- package/packages/react/src/preview-card/root/PreviewCardContext.ts +22 -0
- package/packages/react/src/preview-card/root/PreviewCardRoot.detached-triggers.test.tsx +1385 -0
- package/packages/react/src/preview-card/root/PreviewCardRoot.spec.tsx +27 -0
- package/packages/react/src/preview-card/root/PreviewCardRoot.test.tsx +1165 -0
- package/packages/react/src/preview-card/root/PreviewCardRoot.tsx +210 -0
- package/packages/react/src/preview-card/store/PreviewCardHandle.ts +65 -0
- package/packages/react/src/preview-card/store/PreviewCardStore.ts +120 -0
- package/packages/react/src/preview-card/trigger/PreviewCardTrigger.test.tsx +13 -0
- package/packages/react/src/preview-card/trigger/PreviewCardTrigger.tsx +148 -0
- package/packages/react/src/preview-card/trigger/PreviewCardTriggerDataAttributes.ts +8 -0
- package/packages/react/src/preview-card/utils/constants.ts +2 -0
- package/packages/react/src/preview-card/viewport/PreviewCardViewport.test.tsx +424 -0
- package/packages/react/src/preview-card/viewport/PreviewCardViewport.tsx +88 -0
- package/packages/react/src/preview-card/viewport/PreviewCardViewportCssVars.ts +14 -0
- package/packages/react/src/preview-card/viewport/PreviewCardViewportDataAttributes.ts +26 -0
- package/packages/react/src/progress/index.parts.ts +7 -0
- package/packages/react/src/progress/index.ts +7 -0
- package/packages/react/src/progress/indicator/ProgressIndicator.test.tsx +65 -0
- package/packages/react/src/progress/indicator/ProgressIndicator.tsx +61 -0
- package/packages/react/src/progress/indicator/ProgressIndicatorDataAttributes.ts +14 -0
- package/packages/react/src/progress/label/ProgressLabel.test.tsx +13 -0
- package/packages/react/src/progress/label/ProgressLabel.tsx +49 -0
- package/packages/react/src/progress/label/ProgressLabelDataAttributes.ts +14 -0
- package/packages/react/src/progress/root/ProgressRoot.test.tsx +106 -0
- package/packages/react/src/progress/root/ProgressRoot.tsx +145 -0
- package/packages/react/src/progress/root/ProgressRootContext.tsx +41 -0
- package/packages/react/src/progress/root/ProgressRootDataAttributes.ts +14 -0
- package/packages/react/src/progress/root/stateAttributesMapping.ts +18 -0
- package/packages/react/src/progress/track/ProgressTrack.test.tsx +13 -0
- package/packages/react/src/progress/track/ProgressTrack.tsx +40 -0
- package/packages/react/src/progress/track/ProgressTrackDataAttributes.ts +14 -0
- package/packages/react/src/progress/value/ProgressValue.test.tsx +82 -0
- package/packages/react/src/progress/value/ProgressValue.tsx +59 -0
- package/packages/react/src/progress/value/ProgressValueDataAttributes.ts +14 -0
- package/packages/react/src/radio/index.parts.ts +2 -0
- package/packages/react/src/radio/index.ts +4 -0
- package/packages/react/src/radio/indicator/RadioIndicator.test.tsx +237 -0
- package/packages/react/src/radio/indicator/RadioIndicator.tsx +80 -0
- package/packages/react/src/radio/indicator/RadioIndicatorDataAttributes.ts +56 -0
- package/packages/react/src/radio/root/RadioRoot.spec.tsx +12 -0
- package/packages/react/src/radio/root/RadioRoot.test.tsx +135 -0
- package/packages/react/src/radio/root/RadioRoot.tsx +352 -0
- package/packages/react/src/radio/root/RadioRootContext.ts +18 -0
- package/packages/react/src/radio/root/RadioRootDataAttributes.ts +46 -0
- package/packages/react/src/radio/utils/stateAttributesMapping.ts +20 -0
- package/packages/react/src/radio-group/RadioGroup.spec.tsx +57 -0
- package/packages/react/src/radio-group/RadioGroup.test.tsx +1396 -0
- package/packages/react/src/radio-group/RadioGroup.tsx +338 -0
- package/packages/react/src/radio-group/RadioGroupContext.ts +29 -0
- package/packages/react/src/radio-group/RadioGroupDataAttributes.ts +6 -0
- package/packages/react/src/radio-group/index.ts +3 -0
- package/packages/react/src/scroll-area/constants.ts +2 -0
- package/packages/react/src/scroll-area/content/ScrollAreaContent.test.tsx +18 -0
- package/packages/react/src/scroll-area/content/ScrollAreaContent.tsx +88 -0
- package/packages/react/src/scroll-area/content/ScrollAreaContentDataAttributes.ts +30 -0
- package/packages/react/src/scroll-area/corner/ScrollAreaCorner.test.tsx +72 -0
- package/packages/react/src/scroll-area/corner/ScrollAreaCorner.tsx +51 -0
- package/packages/react/src/scroll-area/index.parts.ts +6 -0
- package/packages/react/src/scroll-area/index.ts +8 -0
- package/packages/react/src/scroll-area/root/ScrollAreaRoot.test.tsx +883 -0
- package/packages/react/src/scroll-area/root/ScrollAreaRoot.tsx +404 -0
- package/packages/react/src/scroll-area/root/ScrollAreaRootContext.ts +62 -0
- package/packages/react/src/scroll-area/root/ScrollAreaRootCssVars.ts +12 -0
- package/packages/react/src/scroll-area/root/ScrollAreaRootDataAttributes.ts +30 -0
- package/packages/react/src/scroll-area/root/stateAttributes.ts +13 -0
- package/packages/react/src/scroll-area/scrollbar/ScrollAreaScrollbar.test.tsx +573 -0
- package/packages/react/src/scroll-area/scrollbar/ScrollAreaScrollbar.tsx +288 -0
- package/packages/react/src/scroll-area/scrollbar/ScrollAreaScrollbarContext.ts +20 -0
- package/packages/react/src/scroll-area/scrollbar/ScrollAreaScrollbarCssVars.ts +12 -0
- package/packages/react/src/scroll-area/scrollbar/ScrollAreaScrollbarDataAttributes.ts +39 -0
- package/packages/react/src/scroll-area/thumb/ScrollAreaThumb.test.tsx +227 -0
- package/packages/react/src/scroll-area/thumb/ScrollAreaThumb.tsx +93 -0
- package/packages/react/src/scroll-area/thumb/ScrollAreaThumbDataAttributes.ts +11 -0
- package/packages/react/src/scroll-area/utils/getOffset.ts +22 -0
- package/packages/react/src/scroll-area/viewport/ScrollAreaViewport.test.tsx +111 -0
- package/packages/react/src/scroll-area/viewport/ScrollAreaViewport.tsx +482 -0
- package/packages/react/src/scroll-area/viewport/ScrollAreaViewportContext.ts +20 -0
- package/packages/react/src/scroll-area/viewport/ScrollAreaViewportCssVars.ts +22 -0
- package/packages/react/src/scroll-area/viewport/ScrollAreaViewportDataAttributes.ts +30 -0
- package/packages/react/src/select/arrow/SelectArrow.test.tsx +17 -0
- package/packages/react/src/select/arrow/SelectArrow.tsx +82 -0
- package/packages/react/src/select/arrow/SelectArrowDataAttributes.ts +26 -0
- package/packages/react/src/select/backdrop/SelectBackdrop.test.tsx +13 -0
- package/packages/react/src/select/backdrop/SelectBackdrop.tsx +77 -0
- package/packages/react/src/select/backdrop/SelectBackdropDataAttributes.ts +20 -0
- package/packages/react/src/select/group/SelectGroup.test.tsx +50 -0
- package/packages/react/src/select/group/SelectGroup.tsx +50 -0
- package/packages/react/src/select/group/SelectGroupContext.ts +19 -0
- package/packages/react/src/select/group-label/SelectGroupLabel.test.tsx +17 -0
- package/packages/react/src/select/group-label/SelectGroupLabel.tsx +44 -0
- package/packages/react/src/select/icon/SelectIcon.test.tsx +13 -0
- package/packages/react/src/select/icon/SelectIcon.tsx +51 -0
- package/packages/react/src/select/icon/SelectIconDataAttributes.ts +8 -0
- package/packages/react/src/select/index.parts.ts +19 -0
- package/packages/react/src/select/index.ts +20 -0
- package/packages/react/src/select/item/SelectItem.test.tsx +778 -0
- package/packages/react/src/select/item/SelectItem.tsx +310 -0
- package/packages/react/src/select/item/SelectItemContext.ts +22 -0
- package/packages/react/src/select/item/SelectItemDataAttributes.ts +14 -0
- package/packages/react/src/select/item-indicator/SelectItemIndicator.test.tsx +22 -0
- package/packages/react/src/select/item-indicator/SelectItemIndicator.tsx +106 -0
- package/packages/react/src/select/item-indicator/SelectItemIndicatorDataAttributes.ts +12 -0
- package/packages/react/src/select/item-text/SelectItemText.test.tsx +19 -0
- package/packages/react/src/select/item-text/SelectItemText.tsx +56 -0
- package/packages/react/src/select/label/SelectLabel.test.tsx +21 -0
- package/packages/react/src/select/label/SelectLabel.tsx +62 -0
- package/packages/react/src/select/list/SelectList.test.tsx +21 -0
- package/packages/react/src/select/list/SelectList.tsx +64 -0
- package/packages/react/src/select/popup/SelectPopup.test.tsx +1189 -0
- package/packages/react/src/select/popup/SelectPopup.tsx +629 -0
- package/packages/react/src/select/popup/SelectPopupDataAttributes.ts +30 -0
- package/packages/react/src/select/popup/utils.ts +12 -0
- package/packages/react/src/select/portal/SelectPortal.test.tsx +14 -0
- package/packages/react/src/select/portal/SelectPortal.tsx +43 -0
- package/packages/react/src/select/portal/SelectPortalContext.ts +12 -0
- package/packages/react/src/select/positioner/SelectPositioner.spec.tsx +4 -0
- package/packages/react/src/select/positioner/SelectPositioner.test.tsx +284 -0
- package/packages/react/src/select/positioner/SelectPositioner.tsx +283 -0
- package/packages/react/src/select/positioner/SelectPositionerContext.ts +25 -0
- package/packages/react/src/select/positioner/SelectPositionerCssVars.ts +27 -0
- package/packages/react/src/select/positioner/SelectPositionerDataAttributes.ts +26 -0
- package/packages/react/src/select/root/SelectRoot.spec.tsx +247 -0
- package/packages/react/src/select/root/SelectRoot.test.tsx +5492 -0
- package/packages/react/src/select/root/SelectRoot.tsx +810 -0
- package/packages/react/src/select/root/SelectRootContext.ts +63 -0
- package/packages/react/src/select/scroll-arrow/SelectScrollArrow.tsx +248 -0
- package/packages/react/src/select/scroll-down-arrow/SelectScrollDownArrow.test.tsx +193 -0
- package/packages/react/src/select/scroll-down-arrow/SelectScrollDownArrow.tsx +35 -0
- package/packages/react/src/select/scroll-down-arrow/SelectScrollDownArrowDataAttributes.ts +26 -0
- package/packages/react/src/select/scroll-up-arrow/SelectScrollUpArrow.test.tsx +105 -0
- package/packages/react/src/select/scroll-up-arrow/SelectScrollUpArrow.tsx +35 -0
- package/packages/react/src/select/scroll-up-arrow/SelectScrollUpArrowDataAttributes.ts +26 -0
- package/packages/react/src/select/store.ts +120 -0
- package/packages/react/src/select/trigger/SelectTrigger.test.tsx +268 -0
- package/packages/react/src/select/trigger/SelectTrigger.tsx +287 -0
- package/packages/react/src/select/trigger/SelectTriggerDataAttributes.ts +57 -0
- package/packages/react/src/select/value/SelectValue.test.tsx +764 -0
- package/packages/react/src/select/value/SelectValue.tsx +107 -0
- package/packages/react/src/select/value/SelectValueDataAttributes.ts +6 -0
- package/packages/react/src/separator/Separator.test.tsx +28 -0
- package/packages/react/src/separator/Separator.tsx +47 -0
- package/packages/react/src/separator/SeparatorDataAttributes.ts +7 -0
- package/packages/react/src/separator/index.ts +3 -0
- package/packages/react/src/slider/control/SliderControl.test.tsx +27 -0
- package/packages/react/src/slider/control/SliderControl.tsx +563 -0
- package/packages/react/src/slider/control/SliderControlDataAttributes.ts +35 -0
- package/packages/react/src/slider/index.parts.ts +7 -0
- package/packages/react/src/slider/index.ts +9 -0
- package/packages/react/src/slider/indicator/SliderIndicator.test.tsx +13 -0
- package/packages/react/src/slider/indicator/SliderIndicator.tsx +139 -0
- package/packages/react/src/slider/indicator/SliderIndicatorDataAttributes.ts +35 -0
- package/packages/react/src/slider/label/SliderLabel.test.tsx +20 -0
- package/packages/react/src/slider/label/SliderLabel.tsx +69 -0
- package/packages/react/src/slider/root/SliderRoot.spec.tsx +98 -0
- package/packages/react/src/slider/root/SliderRoot.test.tsx +3321 -0
- package/packages/react/src/slider/root/SliderRoot.tsx +630 -0
- package/packages/react/src/slider/root/SliderRootContext.ts +112 -0
- package/packages/react/src/slider/root/SliderRootDataAttributes.ts +35 -0
- package/packages/react/src/slider/root/stateAttributesMapping.ts +13 -0
- package/packages/react/src/slider/thumb/SliderThumb.test.tsx +1054 -0
- package/packages/react/src/slider/thumb/SliderThumb.tsx +598 -0
- package/packages/react/src/slider/thumb/SliderThumbDataAttributes.ts +39 -0
- package/packages/react/src/slider/thumb/prehydrationScript.min.ts +5 -0
- package/packages/react/src/slider/thumb/prehydrationScript.template.js +69 -0
- package/packages/react/src/slider/track/SliderTrack.test.tsx +13 -0
- package/packages/react/src/slider/track/SliderTrack.tsx +47 -0
- package/packages/react/src/slider/track/SliderTrackDataAttributes.ts +35 -0
- package/packages/react/src/slider/utils/asc.ts +3 -0
- package/packages/react/src/slider/utils/getMidpoint.ts +9 -0
- package/packages/react/src/slider/utils/getPushedThumbValues.test.ts +105 -0
- package/packages/react/src/slider/utils/getPushedThumbValues.ts +72 -0
- package/packages/react/src/slider/utils/getSliderValue.test.ts +27 -0
- package/packages/react/src/slider/utils/getSliderValue.ts +26 -0
- package/packages/react/src/slider/utils/replaceArrayItemAtIndex.ts +7 -0
- package/packages/react/src/slider/utils/resolveThumbCollision.test.ts +235 -0
- package/packages/react/src/slider/utils/resolveThumbCollision.ts +175 -0
- package/packages/react/src/slider/utils/roundValueToStep.test.ts +8 -0
- package/packages/react/src/slider/utils/roundValueToStep.ts +21 -0
- package/packages/react/src/slider/utils/test-utils.ts +28 -0
- package/packages/react/src/slider/utils/validateMinimumDistance.ts +21 -0
- package/packages/react/src/slider/utils/valueArrayToPercentages.ts +10 -0
- package/packages/react/src/slider/value/SliderValue.test.tsx +72 -0
- package/packages/react/src/slider/value/SliderValue.tsx +85 -0
- package/packages/react/src/slider/value/SliderValueDataAttributes.ts +35 -0
- package/packages/react/src/switch/index.parts.ts +2 -0
- package/packages/react/src/switch/index.ts +4 -0
- package/packages/react/src/switch/root/SwitchRoot.test.tsx +1116 -0
- package/packages/react/src/switch/root/SwitchRoot.tsx +348 -0
- package/packages/react/src/switch/root/SwitchRootContext.ts +18 -0
- package/packages/react/src/switch/root/SwitchRootDataAttributes.ts +46 -0
- package/packages/react/src/switch/stateAttributesMapping.ts +19 -0
- package/packages/react/src/switch/thumb/SwitchThumb.test.tsx +28 -0
- package/packages/react/src/switch/thumb/SwitchThumb.tsx +38 -0
- package/packages/react/src/switch/thumb/SwitchThumbDataAttributes.ts +46 -0
- package/packages/react/src/tabs/index.parts.ts +5 -0
- package/packages/react/src/tabs/index.ts +7 -0
- package/packages/react/src/tabs/indicator/TabsIndicator.test.tsx +442 -0
- package/packages/react/src/tabs/indicator/TabsIndicator.tsx +185 -0
- package/packages/react/src/tabs/indicator/TabsIndicatorCssVars.ts +32 -0
- package/packages/react/src/tabs/indicator/TabsIndicatorDataAttributes.ts +12 -0
- package/packages/react/src/tabs/indicator/prehydrationScript.min.ts +5 -0
- package/packages/react/src/tabs/indicator/prehydrationScript.template.js +87 -0
- package/packages/react/src/tabs/list/TabsList.test.tsx +135 -0
- package/packages/react/src/tabs/list/TabsList.tsx +167 -0
- package/packages/react/src/tabs/list/TabsListContext.ts +27 -0
- package/packages/react/src/tabs/list/TabsListDataAttributes.ts +12 -0
- package/packages/react/src/tabs/panel/TabsPanel.test.tsx +186 -0
- package/packages/react/src/tabs/panel/TabsPanel.tsx +157 -0
- package/packages/react/src/tabs/panel/TabsPanelDataAttributes.ts +30 -0
- package/packages/react/src/tabs/root/TabsRoot.test.tsx +2325 -0
- package/packages/react/src/tabs/root/TabsRoot.tsx +514 -0
- package/packages/react/src/tabs/root/TabsRootContext.ts +56 -0
- package/packages/react/src/tabs/root/TabsRootDataAttributes.ts +12 -0
- package/packages/react/src/tabs/root/stateAttributesMapping.ts +9 -0
- package/packages/react/src/tabs/tab/TabsTab.test.tsx +90 -0
- package/packages/react/src/tabs/tab/TabsTab.tsx +287 -0
- package/packages/react/src/tabs/tab/TabsTabDataAttributes.ts +20 -0
- package/packages/react/src/toast/action/ToastAction.test.tsx +81 -0
- package/packages/react/src/toast/action/ToastAction.tsx +74 -0
- package/packages/react/src/toast/action/ToastActionDataAttributes.ts +7 -0
- package/packages/react/src/toast/arrow/ToastArrow.test.tsx +22 -0
- package/packages/react/src/toast/arrow/ToastArrow.tsx +57 -0
- package/packages/react/src/toast/arrow/ToastArrowDataAttributes.ts +18 -0
- package/packages/react/src/toast/close/ToastClose.test.tsx +57 -0
- package/packages/react/src/toast/close/ToastClose.tsx +80 -0
- package/packages/react/src/toast/close/ToastCloseDataAttributes.ts +7 -0
- package/packages/react/src/toast/content/ToastContent.test.tsx +87 -0
- package/packages/react/src/toast/content/ToastContent.tsx +80 -0
- package/packages/react/src/toast/content/ToastContentDataAttributes.ts +12 -0
- package/packages/react/src/toast/createToastManager.spec.tsx +84 -0
- package/packages/react/src/toast/createToastManager.test.tsx +795 -0
- package/packages/react/src/toast/createToastManager.ts +98 -0
- package/packages/react/src/toast/description/ToastDescription.test.tsx +92 -0
- package/packages/react/src/toast/description/ToastDescription.tsx +82 -0
- package/packages/react/src/toast/description/ToastDescriptionDataAttributes.ts +7 -0
- package/packages/react/src/toast/index.parts.ts +14 -0
- package/packages/react/src/toast/index.ts +15 -0
- package/packages/react/src/toast/portal/ToastPortal.test.tsx +14 -0
- package/packages/react/src/toast/portal/ToastPortal.tsx +20 -0
- package/packages/react/src/toast/positioner/ToastPositioner.test.tsx +18 -0
- package/packages/react/src/toast/positioner/ToastPositioner.tsx +155 -0
- package/packages/react/src/toast/positioner/ToastPositionerContext.ts +22 -0
- package/packages/react/src/toast/positioner/ToastPositionerCssVars.ts +27 -0
- package/packages/react/src/toast/positioner/ToastPositionerDataAttributes.ts +18 -0
- package/packages/react/src/toast/provider/ToastProvider.tsx +94 -0
- package/packages/react/src/toast/provider/ToastProviderContext.ts +15 -0
- package/packages/react/src/toast/root/ToastRoot.test.tsx +888 -0
- package/packages/react/src/toast/root/ToastRoot.tsx +629 -0
- package/packages/react/src/toast/root/ToastRootContext.ts +30 -0
- package/packages/react/src/toast/root/ToastRootCssVars.ts +27 -0
- package/packages/react/src/toast/root/ToastRootDataAttributes.ts +37 -0
- package/packages/react/src/toast/store.test.ts +178 -0
- package/packages/react/src/toast/store.ts +556 -0
- package/packages/react/src/toast/title/ToastTitle.test.tsx +92 -0
- package/packages/react/src/toast/title/ToastTitle.tsx +81 -0
- package/packages/react/src/toast/title/ToastTitleDataAttributes.ts +7 -0
- package/packages/react/src/toast/useToastManager.spec.tsx +88 -0
- package/packages/react/src/toast/useToastManager.test.tsx +2024 -0
- package/packages/react/src/toast/useToastManager.ts +149 -0
- package/packages/react/src/toast/utils/focusVisible.ts +1 -0
- package/packages/react/src/toast/utils/resolvePromiseOptions.ts +22 -0
- package/packages/react/src/toast/utils/test-utils.tsx +39 -0
- package/packages/react/src/toast/viewport/ToastViewport.test.tsx +720 -0
- package/packages/react/src/toast/viewport/ToastViewport.tsx +338 -0
- package/packages/react/src/toast/viewport/ToastViewportCssVars.ts +7 -0
- package/packages/react/src/toast/viewport/ToastViewportDataAttributes.ts +7 -0
- package/packages/react/src/toggle/Toggle.test.tsx +171 -0
- package/packages/react/src/toggle/Toggle.tsx +201 -0
- package/packages/react/src/toggle/ToggleDataAttributes.ts +10 -0
- package/packages/react/src/toggle/index.ts +3 -0
- package/packages/react/src/toggle-group/ToggleGroup.spec.tsx +27 -0
- package/packages/react/src/toggle-group/ToggleGroup.test.tsx +527 -0
- package/packages/react/src/toggle-group/ToggleGroup.tsx +218 -0
- package/packages/react/src/toggle-group/ToggleGroupContext.ts +36 -0
- package/packages/react/src/toggle-group/ToggleGroupDataAttributes.ts +15 -0
- package/packages/react/src/toggle-group/index.ts +3 -0
- package/packages/react/src/toolbar/button/ToolbarButton.test.tsx +1173 -0
- package/packages/react/src/toolbar/button/ToolbarButton.tsx +106 -0
- package/packages/react/src/toolbar/button/ToolbarButtonDataAttributes.ts +15 -0
- package/packages/react/src/toolbar/group/ToolbarGroup.test.tsx +71 -0
- package/packages/react/src/toolbar/group/ToolbarGroup.tsx +67 -0
- package/packages/react/src/toolbar/group/ToolbarGroupContext.ts +20 -0
- package/packages/react/src/toolbar/group/ToolbarGroupDataAttributes.ts +11 -0
- package/packages/react/src/toolbar/index.parts.ts +8 -0
- package/packages/react/src/toolbar/index.ts +9 -0
- package/packages/react/src/toolbar/input/ToolbarInput.test.tsx +237 -0
- package/packages/react/src/toolbar/input/ToolbarInput.tsx +108 -0
- package/packages/react/src/toolbar/input/ToolbarInputDataAttributes.ts +15 -0
- package/packages/react/src/toolbar/link/ToolbarLink.test.tsx +50 -0
- package/packages/react/src/toolbar/link/ToolbarLink.tsx +58 -0
- package/packages/react/src/toolbar/link/ToolbarLinkDataAttributes.ts +7 -0
- package/packages/react/src/toolbar/root/ToolbarRoot.test.tsx +274 -0
- package/packages/react/src/toolbar/root/ToolbarRoot.tsx +124 -0
- package/packages/react/src/toolbar/root/ToolbarRootContext.ts +28 -0
- package/packages/react/src/toolbar/root/ToolbarRootDataAttributes.ts +11 -0
- package/packages/react/src/toolbar/separator/ToolbarSeparator.tsx +44 -0
- package/packages/react/src/toolbar/separator/ToolbarSeparatorDataAttributes.ts +7 -0
- package/packages/react/src/tooltip/arrow/TooltipArrow.test.tsx +21 -0
- package/packages/react/src/tooltip/arrow/TooltipArrow.tsx +74 -0
- package/packages/react/src/tooltip/arrow/TooltipArrowDataAttributes.ts +31 -0
- package/packages/react/src/tooltip/index.parts.ts +12 -0
- package/packages/react/src/tooltip/index.ts +10 -0
- package/packages/react/src/tooltip/popup/TooltipPopup.test.tsx +35 -0
- package/packages/react/src/tooltip/popup/TooltipPopup.tsx +107 -0
- package/packages/react/src/tooltip/popup/TooltipPopupDataAttributes.ts +35 -0
- package/packages/react/src/tooltip/portal/TooltipPortal.test.tsx +14 -0
- package/packages/react/src/tooltip/portal/TooltipPortal.tsx +48 -0
- package/packages/react/src/tooltip/portal/TooltipPortalContext.ts +12 -0
- package/packages/react/src/tooltip/positioner/TooltipPositioner.spec.tsx +4 -0
- package/packages/react/src/tooltip/positioner/TooltipPositioner.test.tsx +302 -0
- package/packages/react/src/tooltip/positioner/TooltipPositioner.tsx +149 -0
- package/packages/react/src/tooltip/positioner/TooltipPositionerContext.ts +22 -0
- package/packages/react/src/tooltip/positioner/TooltipPositionerCssVars.ts +27 -0
- package/packages/react/src/tooltip/positioner/TooltipPositionerDataAttributes.ts +26 -0
- package/packages/react/src/tooltip/provider/TooltipProvider.test.tsx +183 -0
- package/packages/react/src/tooltip/provider/TooltipProvider.tsx +57 -0
- package/packages/react/src/tooltip/provider/TooltipProviderContext.ts +15 -0
- package/packages/react/src/tooltip/root/TooltipRoot.detached-triggers.test.tsx +1021 -0
- package/packages/react/src/tooltip/root/TooltipRoot.test.tsx +2634 -0
- package/packages/react/src/tooltip/root/TooltipRoot.tsx +281 -0
- package/packages/react/src/tooltip/root/TooltipRootContext.ts +20 -0
- package/packages/react/src/tooltip/store/TooltipHandle.ts +65 -0
- package/packages/react/src/tooltip/store/TooltipStore.ts +121 -0
- package/packages/react/src/tooltip/trigger/TooltipTrigger.spec.tsx +6 -0
- package/packages/react/src/tooltip/trigger/TooltipTrigger.test.tsx +90 -0
- package/packages/react/src/tooltip/trigger/TooltipTrigger.tsx +365 -0
- package/packages/react/src/tooltip/trigger/TooltipTriggerDataAttributes.ts +12 -0
- package/packages/react/src/tooltip/utils/constants.ts +1 -0
- package/packages/react/src/tooltip/viewport/TooltipViewport.test.tsx +421 -0
- package/packages/react/src/tooltip/viewport/TooltipViewport.tsx +85 -0
- package/packages/react/src/tooltip/viewport/TooltipViewportCssVars.ts +14 -0
- package/packages/react/src/tooltip/viewport/TooltipViewportDataAttributes.ts +26 -0
- package/packages/react/src/types/index.ts +26 -0
- package/packages/react/src/unstable-use-media-query/index.ts +90 -0
- package/packages/react/src/use-render/index.ts +2 -0
- package/packages/react/src/use-render/useRender.spec.tsx +59 -0
- package/packages/react/src/use-render/useRender.test.tsx +318 -0
- package/packages/react/src/use-render/useRender.ts +113 -0
- package/packages/react/src/utils/FloatingPortalLite.tsx +43 -0
- package/packages/react/src/utils/FocusGuard.tsx +42 -0
- package/packages/react/src/utils/InternalBackdrop.tsx +50 -0
- package/packages/react/src/utils/adaptiveOriginMiddleware.ts +77 -0
- package/packages/react/src/utils/closePart.tsx +46 -0
- package/packages/react/src/utils/collapsibleOpenStateMapping.ts +35 -0
- package/packages/react/src/utils/formatNumber.test.ts +42 -0
- package/packages/react/src/utils/formatNumber.ts +43 -0
- package/packages/react/src/utils/getCssDimensions.ts +24 -0
- package/packages/react/src/utils/getDisabledMountTransitionStyles.ts +9 -0
- package/packages/react/src/utils/getElementAtPoint.ts +3 -0
- package/packages/react/src/utils/getPseudoElementBounds.test.ts +66 -0
- package/packages/react/src/utils/getPseudoElementBounds.ts +49 -0
- package/packages/react/src/utils/hideMiddleware.ts +17 -0
- package/packages/react/src/utils/popupStateMapping.ts +100 -0
- package/packages/react/src/utils/popups/index.ts +4 -0
- package/packages/react/src/utils/popups/inlineRect.test.ts +470 -0
- package/packages/react/src/utils/popups/inlineRect.ts +292 -0
- package/packages/react/src/utils/popups/popupStoreUtils.test.tsx +630 -0
- package/packages/react/src/utils/popups/popupStoreUtils.ts +512 -0
- package/packages/react/src/utils/popups/popupTriggerMap.test.ts +94 -0
- package/packages/react/src/utils/popups/popupTriggerMap.ts +104 -0
- package/packages/react/src/utils/popups/store.test.ts +68 -0
- package/packages/react/src/utils/popups/store.ts +224 -0
- package/packages/react/src/utils/popups/useTriggerFocusGuards.ts +95 -0
- package/packages/react/src/utils/resolveAriaLabelledBy.ts +12 -0
- package/packages/react/src/utils/resolveClassName.ts +13 -0
- package/packages/react/src/utils/resolveRef.ts +13 -0
- package/packages/react/src/utils/resolveStyle.ts +13 -0
- package/packages/react/src/utils/scrollEdges.test.ts +30 -0
- package/packages/react/src/utils/scrollEdges.ts +33 -0
- package/packages/react/src/utils/scrollable.ts +72 -0
- package/packages/react/src/utils/stringifyLocale.test.ts +11 -0
- package/packages/react/src/utils/stringifyLocale.ts +11 -0
- package/packages/react/src/utils/styles.tsx +12 -0
- package/packages/react/src/utils/useAnchorPositioning.ts +755 -0
- package/packages/react/src/utils/useAnchoredPopupScrollLock.ts +43 -0
- package/packages/react/src/utils/useFocusableWhenDisabled.ts +99 -0
- package/packages/react/src/utils/useIsHydrating.test.tsx +39 -0
- package/packages/react/src/utils/useIsHydrating.ts +22 -0
- package/packages/react/src/utils/useMixedToggleClickHandler.ts +61 -0
- package/packages/react/src/utils/useOpenInteractionType.ts +62 -0
- package/packages/react/src/utils/usePopupAutoResize.ts +238 -0
- package/packages/react/src/utils/usePopupViewport.tsx +375 -0
- package/packages/react/src/utils/usePositioner.tsx +44 -0
- package/packages/react/src/utils/useRegisteredLabelId.ts +20 -0
- package/packages/react/src/utils/useSwipeDismiss.test.tsx +1404 -0
- package/packages/react/src/utils/useSwipeDismiss.ts +1208 -0
- package/packages/react/src/utils/valueToPercent.ts +3 -0
- package/packages/react/test/addVitestMatchers.ts +49 -0
- package/packages/react/test/conformanceTests/className.tsx +25 -0
- package/packages/react/test/conformanceTests/propForwarding.tsx +129 -0
- package/packages/react/test/conformanceTests/refForwarding.tsx +40 -0
- package/packages/react/test/conformanceTests/renderProp.tsx +180 -0
- package/packages/react/test/conformanceTests/utils.ts +6 -0
- package/packages/react/test/createRenderer.ts +49 -0
- package/packages/react/test/describeConformance.tsx +70 -0
- package/packages/react/test/describeGregorianAdapter/describeGregorianAdapter.ts +24 -0
- package/packages/react/test/describeGregorianAdapter/describeGregorianAdapter.types.ts +36 -0
- package/packages/react/test/describeGregorianAdapter/describeGregorianAdapter.utils.ts +3 -0
- package/packages/react/test/describeGregorianAdapter/index.ts +2 -0
- package/packages/react/test/describeGregorianAdapter/testComputations.ts +858 -0
- package/packages/react/test/describeGregorianAdapter/testFormats.ts +32 -0
- package/packages/react/test/describeGregorianAdapter/testLocalization.ts +14 -0
- package/packages/react/test/floating-ui-tests/Button.module.css +18 -0
- package/packages/react/test/floating-ui-tests/Button.tsx +14 -0
- package/packages/react/test/floating-ui-tests/ComplexGrid.module.css +12 -0
- package/packages/react/test/floating-ui-tests/ComplexGrid.tsx +102 -0
- package/packages/react/test/floating-ui-tests/EmojiPicker.module.css +83 -0
- package/packages/react/test/floating-ui-tests/EmojiPicker.tsx +302 -0
- package/packages/react/test/floating-ui-tests/Grid.module.css +12 -0
- package/packages/react/test/floating-ui-tests/Grid.tsx +95 -0
- package/packages/react/test/floating-ui-tests/ListboxFocus.tsx +120 -0
- package/packages/react/test/floating-ui-tests/Menu.module.css +95 -0
- package/packages/react/test/floating-ui-tests/Menu.tsx +420 -0
- package/packages/react/test/floating-ui-tests/MenuOrientation.module.css +100 -0
- package/packages/react/test/floating-ui-tests/MenuOrientation.tsx +505 -0
- package/packages/react/test/floating-ui-tests/Navigation.module.css +56 -0
- package/packages/react/test/floating-ui-tests/Navigation.tsx +143 -0
- package/packages/react/test/floating-ui-tests/Popover.module.css +45 -0
- package/packages/react/test/floating-ui-tests/Popover.tsx +192 -0
- package/packages/react/test/floating-ui-tests/gridNavigationWithColumns.ts +27 -0
- package/packages/react/test/floating-ui-tests/renderGridRows.tsx +17 -0
- package/packages/react/test/index.ts +9 -0
- package/packages/react/test/popupConformanceTests.tsx +281 -0
- package/packages/react/test/types.d.ts +1 -0
- package/packages/react/test/useTestInteractions.test.tsx +154 -0
- package/packages/react/test/useTestInteractions.ts +161 -0
- package/packages/react/test/wait.ts +19 -0
- package/packages/react/tsconfig.build.json +19 -0
- package/packages/react/tsconfig.json +11 -0
- package/packages/react/tsconfig.test.json +25 -0
- package/packages/react/vitest-env.d.ts +6 -0
- package/packages/react/vitest.config.mts +16 -0
- package/packages/utils/CHANGELOG.md +91 -0
- package/packages/utils/MAINTAINERS.md +8 -0
- package/packages/utils/README.md +3 -0
- package/packages/utils/package.json +61 -0
- package/packages/utils/src/addEventListener.spec.ts +41 -0
- package/packages/utils/src/addEventListener.test.ts +21 -0
- package/packages/utils/src/addEventListener.ts +63 -0
- package/packages/utils/src/empty.ts +5 -0
- package/packages/utils/src/error.ts +18 -0
- package/packages/utils/src/fastHooks.ts +70 -0
- package/packages/utils/src/fastObjectShallowCompare.ts +32 -0
- package/packages/utils/src/formatErrorMessage.test.ts +49 -0
- package/packages/utils/src/formatErrorMessage.ts +33 -0
- package/packages/utils/src/generateId.ts +5 -0
- package/packages/utils/src/getDefaultFormSubmitter.test.ts +70 -0
- package/packages/utils/src/getDefaultFormSubmitter.ts +34 -0
- package/packages/utils/src/getReactElementRef.test.tsx +38 -0
- package/packages/utils/src/getReactElementRef.ts +16 -0
- package/packages/utils/src/inertValue.ts +9 -0
- package/packages/utils/src/isElementDisabled.ts +7 -0
- package/packages/utils/src/isMouseWithinBounds.ts +20 -0
- package/packages/utils/src/mergeCleanups.test.ts +15 -0
- package/packages/utils/src/mergeCleanups.ts +15 -0
- package/packages/utils/src/mergeObjects.ts +15 -0
- package/packages/utils/src/owner.ts +5 -0
- package/packages/utils/src/platform/engine.ts +22 -0
- package/packages/utils/src/platform/env.ts +4 -0
- package/packages/utils/src/platform/index.ts +27 -0
- package/packages/utils/src/platform/os.ts +24 -0
- package/packages/utils/src/platform/parts.ts +4 -0
- package/packages/utils/src/platform/screen-reader.ts +12 -0
- package/packages/utils/src/platform/shared.ts +51 -0
- package/packages/utils/src/reactVersion.ts +9 -0
- package/packages/utils/src/safeReact.ts +11 -0
- package/packages/utils/src/store/ReactStore.spec.ts +94 -0
- package/packages/utils/src/store/ReactStore.test.tsx +574 -0
- package/packages/utils/src/store/ReactStore.ts +282 -0
- package/packages/utils/src/store/Store.ts +123 -0
- package/packages/utils/src/store/StoreInspector.tsx +595 -0
- package/packages/utils/src/store/createSelector.ts +137 -0
- package/packages/utils/src/store/createSelectorMemoized.ts +99 -0
- package/packages/utils/src/store/index.ts +6 -0
- package/packages/utils/src/store/useStore.ts +193 -0
- package/packages/utils/src/testUtils.ts +21 -0
- package/packages/utils/src/useAnimationFrame.ts +132 -0
- package/packages/utils/src/useControlled.test.tsx +272 -0
- package/packages/utils/src/useControlled.ts +112 -0
- package/packages/utils/src/useEnhancedClickHandler.ts +50 -0
- package/packages/utils/src/useForcedRerendering.ts +13 -0
- package/packages/utils/src/useId.test.tsx +124 -0
- package/packages/utils/src/useId.ts +42 -0
- package/packages/utils/src/useInterval.ts +42 -0
- package/packages/utils/src/useIsoLayoutEffect.ts +6 -0
- package/packages/utils/src/useMergedRefs.test.tsx +174 -0
- package/packages/utils/src/useMergedRefs.ts +151 -0
- package/packages/utils/src/useOnFirstRender.ts +10 -0
- package/packages/utils/src/useOnMount.ts +14 -0
- package/packages/utils/src/usePreviousValue.test.tsx +185 -0
- package/packages/utils/src/usePreviousValue.ts +20 -0
- package/packages/utils/src/useRefWithInit.ts +23 -0
- package/packages/utils/src/useScrollLock.ts +289 -0
- package/packages/utils/src/useStableCallback.ts +62 -0
- package/packages/utils/src/useTimeout.ts +52 -0
- package/packages/utils/src/useValueAsRef.ts +30 -0
- package/packages/utils/src/visuallyHidden.ts +24 -0
- package/packages/utils/src/warn.ts +14 -0
- package/packages/utils/tsconfig.build.json +19 -0
- package/packages/utils/tsconfig.json +11 -0
- package/packages/utils/tsconfig.test.json +16 -0
- package/packages/utils/vitest.config.mts +12 -0
- package/playground/vite-app/README.md +45 -0
- package/playground/vite-app/index.html +13 -0
- package/playground/vite-app/package.json +34 -0
- package/playground/vite-app/public/base-ui-logo.svg +5 -0
- package/playground/vite-app/public/vite.svg +1 -0
- package/playground/vite-app/src/Home.tsx +41 -0
- package/playground/vite-app/src/experiments/perf/SettingsPanel.tsx +115 -0
- package/playground/vite-app/src/experiments/perf/contained-triggers.tsx +226 -0
- package/playground/vite-app/src/experiments/perf/detached-triggers.tsx +286 -0
- package/playground/vite-app/src/experiments/perf/perf.module.css +99 -0
- package/playground/vite-app/src/experiments/perf/radix-triggers.tsx +224 -0
- package/playground/vite-app/src/experiments/perf/utils/benchmark.tsx +184 -0
- package/playground/vite-app/src/index.css +50 -0
- package/playground/vite-app/src/index.tsx +74 -0
- package/playground/vite-app/src/routes.tsx +50 -0
- package/playground/vite-app/tsconfig.app.json +38 -0
- package/playground/vite-app/tsconfig.json +4 -0
- package/playground/vite-app/tsconfig.node.json +26 -0
- package/playground/vite-app/vite.config.ts +36 -0
- package/pnpm-workspace.yaml +31 -0
- package/prettier.config.mjs +3 -0
- package/renovate.json +31 -0
- package/scripts/README.md +58 -0
- package/scripts/changelog.config.mjs +60 -0
- package/scripts/inlineScripts.mts +56 -0
- package/scripts/stylelint/no-unknown-demo-colors.mjs +447 -0
- package/scripts/tsconfig.json +10 -0
- package/stylelint.config.mjs +59 -0
- package/test/README.md +205 -0
- package/test/assets/fake.png +0 -0
- package/test/assets/fake2.png +0 -0
- package/test/bundle-size/bundle-size-checker.config.mjs +69 -0
- package/test/bundle-size/package.json +16 -0
- package/test/docs-regressions-before.png +0 -0
- package/test/docs-regressions-diff.png +0 -0
- package/test/e2e/README.md +30 -0
- package/test/e2e/TestViewer.tsx +21 -0
- package/test/e2e/fixtures/.gitkeep +0 -0
- package/test/e2e/fixtures/Radio.module.css +56 -0
- package/test/e2e/fixtures/Radio.tsx +35 -0
- package/test/e2e/fixtures/field/validate-on-change/Input.module.css +26 -0
- package/test/e2e/fixtures/field/validate-on-change/Input.tsx +22 -0
- package/test/e2e/fixtures/field/validate-on-change/Select.module.css +162 -0
- package/test/e2e/fixtures/field/validate-on-change/Select.tsx +56 -0
- package/test/e2e/fixtures/menu/LinkItemNavigation.module.css +50 -0
- package/test/e2e/fixtures/menu/LinkItemNavigation.tsx +40 -0
- package/test/e2e/fixtures/menu/PageOne.tsx +3 -0
- package/test/e2e/fixtures/menu/PageTwo.tsx +3 -0
- package/test/e2e/fixtures/menu/ReactRouterLinkItemNavigation.tsx +43 -0
- package/test/e2e/fixtures/navigation-menu/InlineSubmenuHoverHandoff.tsx +293 -0
- package/test/e2e/fixtures/slider/Inset.module.css +23 -0
- package/test/e2e/fixtures/slider/Inset.tsx +13 -0
- package/test/e2e/fixtures/slider/Range.module.css +33 -0
- package/test/e2e/fixtures/slider/Range.tsx +15 -0
- package/test/e2e/fixtures/slider/RangeSliderMax.module.css +33 -0
- package/test/e2e/fixtures/slider/RangeSliderMax.tsx +15 -0
- package/test/e2e/index.html +21 -0
- package/test/e2e/index.test.ts +347 -0
- package/test/e2e/main.tsx +134 -0
- package/test/e2e/postcss.config.js +7 -0
- package/test/e2e/serve.json +4 -0
- package/test/e2e/vite.config.mjs +10 -0
- package/test/e2e/vitest.config.mts +21 -0
- package/test/node-resolution/index.mjs +6 -0
- package/test/node-resolution/package.json +11 -0
- package/test/package.json +25 -0
- package/test/performance/package.json +19 -0
- package/test/performance/tests/checkbox.bench.tsx +20 -0
- package/test/performance/tests/combobox.bench.tsx +87 -0
- package/test/performance/tests/dialog.bench.tsx +28 -0
- package/test/performance/tests/menu.bench.tsx +70 -0
- package/test/performance/tests/mixed.bench.tsx +173 -0
- package/test/performance/tests/popover.bench.tsx +28 -0
- package/test/performance/tests/scroll-area.bench.tsx +34 -0
- package/test/performance/tests/select.bench.tsx +86 -0
- package/test/performance/tests/shared.tsx +26 -0
- package/test/performance/tests/slider.bench.tsx +26 -0
- package/test/performance/tests/tabs.bench.tsx +33 -0
- package/test/performance/tests/tooltip.bench.tsx +27 -0
- package/test/performance/tsconfig.json +11 -0
- package/test/performance/vitest.config.ts +3 -0
- package/test/public-types/autocomplete.tsx +80 -0
- package/test/public-types/checkbox.tsx +6 -0
- package/test/public-types/combobox.tsx +71 -0
- package/test/public-types/index.tsx +129 -0
- package/test/public-types/menu.tsx +11 -0
- package/test/public-types/package.json +10 -0
- package/test/public-types/separator.tsx +6 -0
- package/test/public-types/toast.tsx +27 -0
- package/test/public-types/tsconfig.json +25 -0
- package/test/public-types/use-render.tsx +59 -0
- package/test/regressions/README.md +56 -0
- package/test/regressions/TestViewer.tsx +84 -0
- package/test/regressions/fixtures/.gitkeep +0 -0
- package/test/regressions/fixtures.ts +111 -0
- package/test/regressions/index.html +20 -0
- package/test/regressions/index.test.ts +100 -0
- package/test/regressions/main.tsx +127 -0
- package/test/regressions/manual/README.md +4 -0
- package/test/regressions/postcss.config.js +7 -0
- package/test/regressions/public/fonts/die-grotesk-a-bold.woff2 +0 -0
- package/test/regressions/public/fonts/die-grotesk-a-regular.woff2 +0 -0
- package/test/regressions/public/fonts/die-grotesk-b-bold.woff2 +0 -0
- package/test/regressions/public/fonts/die-grotesk-b-regular.woff2 +0 -0
- package/test/regressions/serve.json +4 -0
- package/test/regressions/vite.config.mjs +10 -0
- package/test/regressions/vitest.config.mts +22 -0
- package/test/setupVitest.ts +37 -0
- package/test/tsconfig.json +10 -0
- package/test/vite.d.ts +1 -0
- package/test/vite.shared.config.mjs +25 -0
- package/tsconfig.base.json +26 -0
- package/tsconfig.json +22 -0
- package/vitest.config.mts +30 -0
- package/vitest.shared.mts +67 -0
|
@@ -0,0 +1,2634 @@
|
|
|
1
|
+
import { expect, vi } from 'vitest';
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import { Tooltip } from '@lizuzsusil/react/tooltip';
|
|
4
|
+
import { act, fireEvent, flushMicrotasks, screen, waitFor } from '@mui/internal-test-utils';
|
|
5
|
+
import { createRenderer, isJSDOM, popupConformanceTests } from '#test-utils';
|
|
6
|
+
import { useRefWithInit } from '@lizuzsusil/utils/useRefWithInit';
|
|
7
|
+
import { OPEN_DELAY } from '../utils/constants';
|
|
8
|
+
import { REASONS } from '../../internals/reasons';
|
|
9
|
+
|
|
10
|
+
describe('<Tooltip.Root />', () => {
|
|
11
|
+
beforeEach(async () => {
|
|
12
|
+
globalThis.BASE_UI_ANIMATIONS_DISABLED = true;
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
afterEach(async () => {
|
|
16
|
+
await act(async () => {
|
|
17
|
+
document.body.click();
|
|
18
|
+
});
|
|
19
|
+
});
|
|
20
|
+
|
|
21
|
+
const { render, clock } = createRenderer();
|
|
22
|
+
|
|
23
|
+
popupConformanceTests({
|
|
24
|
+
createComponent: (props) => (
|
|
25
|
+
<Tooltip.Root {...props.root}>
|
|
26
|
+
<Tooltip.Trigger {...props.trigger}>Open menu</Tooltip.Trigger>
|
|
27
|
+
<Tooltip.Portal {...props.portal}>
|
|
28
|
+
<Tooltip.Positioner>
|
|
29
|
+
<Tooltip.Popup {...props.popup}>Content</Tooltip.Popup>
|
|
30
|
+
</Tooltip.Positioner>
|
|
31
|
+
</Tooltip.Portal>
|
|
32
|
+
</Tooltip.Root>
|
|
33
|
+
),
|
|
34
|
+
render,
|
|
35
|
+
triggerMouseAction: 'hover',
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
describe.for([
|
|
39
|
+
{ name: 'contained triggers', Component: ContainedTriggerTooltip },
|
|
40
|
+
{ name: 'detached triggers', Component: DetachedTriggerTooltip },
|
|
41
|
+
{ name: 'multiple detached triggers', Component: MultipleDetachedTriggersTooltip },
|
|
42
|
+
])('when using $name', ({ Component: TestTooltip }) => {
|
|
43
|
+
describe('uncontrolled open', () => {
|
|
44
|
+
clock.withFakeTimers();
|
|
45
|
+
|
|
46
|
+
it('should open when the trigger is hovered', async () => {
|
|
47
|
+
await render(<TestTooltip />);
|
|
48
|
+
|
|
49
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
50
|
+
|
|
51
|
+
fireEvent.pointerDown(trigger, { pointerType: 'mouse' });
|
|
52
|
+
fireEvent.mouseEnter(trigger);
|
|
53
|
+
fireEvent.mouseMove(trigger);
|
|
54
|
+
|
|
55
|
+
clock.tick(OPEN_DELAY);
|
|
56
|
+
|
|
57
|
+
await flushMicrotasks();
|
|
58
|
+
|
|
59
|
+
expect(screen.getByText('Content')).not.toBe(null);
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
it('should close when the trigger is unhovered', async () => {
|
|
63
|
+
await render(<TestTooltip />);
|
|
64
|
+
|
|
65
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
66
|
+
|
|
67
|
+
fireEvent.pointerDown(trigger, { pointerType: 'mouse' });
|
|
68
|
+
fireEvent.mouseEnter(trigger);
|
|
69
|
+
fireEvent.mouseMove(trigger);
|
|
70
|
+
|
|
71
|
+
clock.tick(OPEN_DELAY);
|
|
72
|
+
|
|
73
|
+
await flushMicrotasks();
|
|
74
|
+
|
|
75
|
+
fireEvent.mouseLeave(trigger);
|
|
76
|
+
|
|
77
|
+
await flushMicrotasks();
|
|
78
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
79
|
+
});
|
|
80
|
+
|
|
81
|
+
it('should open when the trigger is focused', async ({ skip }) => {
|
|
82
|
+
if (isJSDOM) {
|
|
83
|
+
skip();
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
await render(<TestTooltip />);
|
|
87
|
+
|
|
88
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
89
|
+
|
|
90
|
+
await act(async () => trigger.focus());
|
|
91
|
+
|
|
92
|
+
await flushMicrotasks();
|
|
93
|
+
|
|
94
|
+
expect(screen.getByText('Content')).not.toBe(null);
|
|
95
|
+
});
|
|
96
|
+
|
|
97
|
+
it('should close when the trigger is blurred', async () => {
|
|
98
|
+
await render(<TestTooltip />);
|
|
99
|
+
|
|
100
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
101
|
+
|
|
102
|
+
await act(async () => {
|
|
103
|
+
trigger.focus();
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
clock.tick(OPEN_DELAY);
|
|
107
|
+
await flushMicrotasks();
|
|
108
|
+
|
|
109
|
+
await act(async () => {
|
|
110
|
+
trigger.blur();
|
|
111
|
+
});
|
|
112
|
+
|
|
113
|
+
clock.tick(OPEN_DELAY);
|
|
114
|
+
|
|
115
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
116
|
+
});
|
|
117
|
+
});
|
|
118
|
+
|
|
119
|
+
describe('controlled open', () => {
|
|
120
|
+
clock.withFakeTimers();
|
|
121
|
+
it('should call onOpenChange when the open state changes', async () => {
|
|
122
|
+
const handleChange = vi.fn();
|
|
123
|
+
|
|
124
|
+
function App() {
|
|
125
|
+
const [open, setOpen] = React.useState(false);
|
|
126
|
+
|
|
127
|
+
return (
|
|
128
|
+
<TestTooltip
|
|
129
|
+
rootProps={{
|
|
130
|
+
open,
|
|
131
|
+
onOpenChange: (nextOpen) => {
|
|
132
|
+
handleChange(open);
|
|
133
|
+
setOpen(nextOpen);
|
|
134
|
+
},
|
|
135
|
+
}}
|
|
136
|
+
/>
|
|
137
|
+
);
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
await render(<App />);
|
|
141
|
+
|
|
142
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
143
|
+
|
|
144
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
145
|
+
|
|
146
|
+
fireEvent.mouseEnter(trigger);
|
|
147
|
+
fireEvent.mouseMove(trigger);
|
|
148
|
+
|
|
149
|
+
clock.tick(OPEN_DELAY);
|
|
150
|
+
|
|
151
|
+
await flushMicrotasks();
|
|
152
|
+
|
|
153
|
+
expect(screen.getByText('Content')).not.toBe(null);
|
|
154
|
+
|
|
155
|
+
fireEvent.mouseLeave(trigger);
|
|
156
|
+
|
|
157
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
158
|
+
expect(handleChange.mock.calls.length).toBe(2);
|
|
159
|
+
expect(handleChange.mock.calls[0][0]).toBe(false);
|
|
160
|
+
expect(handleChange.mock.calls[1][0]).toBe(true);
|
|
161
|
+
});
|
|
162
|
+
|
|
163
|
+
it('should not call onChange when the open state does not change', async () => {
|
|
164
|
+
const handleChange = vi.fn();
|
|
165
|
+
|
|
166
|
+
function App() {
|
|
167
|
+
const [open, setOpen] = React.useState(false);
|
|
168
|
+
|
|
169
|
+
return (
|
|
170
|
+
<TestTooltip
|
|
171
|
+
rootProps={{
|
|
172
|
+
open,
|
|
173
|
+
onOpenChange: (nextOpen) => {
|
|
174
|
+
handleChange(open);
|
|
175
|
+
setOpen(nextOpen);
|
|
176
|
+
},
|
|
177
|
+
}}
|
|
178
|
+
/>
|
|
179
|
+
);
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
await render(<App />);
|
|
183
|
+
|
|
184
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
185
|
+
|
|
186
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
187
|
+
|
|
188
|
+
fireEvent.mouseEnter(trigger);
|
|
189
|
+
fireEvent.mouseMove(trigger);
|
|
190
|
+
|
|
191
|
+
clock.tick(OPEN_DELAY);
|
|
192
|
+
|
|
193
|
+
await flushMicrotasks();
|
|
194
|
+
|
|
195
|
+
expect(screen.getByText('Content')).not.toBe(null);
|
|
196
|
+
expect(handleChange.mock.calls.length).toBe(1);
|
|
197
|
+
expect(handleChange.mock.calls[0][0]).toBe(false);
|
|
198
|
+
});
|
|
199
|
+
});
|
|
200
|
+
|
|
201
|
+
describe('prop: defaultOpen', () => {
|
|
202
|
+
it('should open when the component is rendered', async () => {
|
|
203
|
+
await render(<TestTooltip rootProps={{ defaultOpen: true }} />);
|
|
204
|
+
|
|
205
|
+
await flushMicrotasks();
|
|
206
|
+
|
|
207
|
+
expect(screen.getByText('Content')).not.toBe(null);
|
|
208
|
+
});
|
|
209
|
+
|
|
210
|
+
it('should not open when the component is rendered and open is controlled', async () => {
|
|
211
|
+
await render(<TestTooltip rootProps={{ defaultOpen: true, open: false }} />);
|
|
212
|
+
|
|
213
|
+
await flushMicrotasks();
|
|
214
|
+
|
|
215
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
216
|
+
});
|
|
217
|
+
|
|
218
|
+
it('should not close when the component is rendered and open is controlled', async () => {
|
|
219
|
+
await render(<TestTooltip rootProps={{ defaultOpen: true, open: true }} />);
|
|
220
|
+
|
|
221
|
+
await flushMicrotasks();
|
|
222
|
+
|
|
223
|
+
expect(screen.getByText('Content')).not.toBe(null);
|
|
224
|
+
});
|
|
225
|
+
|
|
226
|
+
it('should remain uncontrolled', async () => {
|
|
227
|
+
await render(<TestTooltip rootProps={{ defaultOpen: true }} />);
|
|
228
|
+
|
|
229
|
+
await flushMicrotasks();
|
|
230
|
+
|
|
231
|
+
expect(screen.getByText('Content')).not.toBe(null);
|
|
232
|
+
|
|
233
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
234
|
+
|
|
235
|
+
fireEvent.mouseLeave(trigger);
|
|
236
|
+
|
|
237
|
+
await flushMicrotasks();
|
|
238
|
+
|
|
239
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
240
|
+
});
|
|
241
|
+
});
|
|
242
|
+
|
|
243
|
+
describe('prop: delay', () => {
|
|
244
|
+
clock.withFakeTimers();
|
|
245
|
+
|
|
246
|
+
it('should open after rest delay', async () => {
|
|
247
|
+
await render(<TestTooltip triggerProps={{ delay: 100 }} />);
|
|
248
|
+
|
|
249
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
250
|
+
|
|
251
|
+
fireEvent.mouseEnter(trigger);
|
|
252
|
+
fireEvent.mouseMove(trigger);
|
|
253
|
+
|
|
254
|
+
await flushMicrotasks();
|
|
255
|
+
|
|
256
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
257
|
+
|
|
258
|
+
clock.tick(100);
|
|
259
|
+
|
|
260
|
+
await flushMicrotasks();
|
|
261
|
+
|
|
262
|
+
expect(screen.getByText('Content')).not.toBe(null);
|
|
263
|
+
});
|
|
264
|
+
});
|
|
265
|
+
|
|
266
|
+
describe('prop: closeDelay', () => {
|
|
267
|
+
clock.withFakeTimers();
|
|
268
|
+
|
|
269
|
+
it('should close after delay', async () => {
|
|
270
|
+
await render(<TestTooltip triggerProps={{ closeDelay: 100 }} />);
|
|
271
|
+
|
|
272
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
273
|
+
|
|
274
|
+
fireEvent.mouseEnter(trigger);
|
|
275
|
+
fireEvent.mouseMove(trigger);
|
|
276
|
+
|
|
277
|
+
clock.tick(OPEN_DELAY);
|
|
278
|
+
|
|
279
|
+
await flushMicrotasks();
|
|
280
|
+
|
|
281
|
+
expect(screen.getByText('Content')).not.toBe(null);
|
|
282
|
+
|
|
283
|
+
fireEvent.mouseLeave(trigger);
|
|
284
|
+
|
|
285
|
+
expect(screen.getByText('Content')).not.toBe(null);
|
|
286
|
+
|
|
287
|
+
clock.tick(100);
|
|
288
|
+
|
|
289
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
290
|
+
});
|
|
291
|
+
});
|
|
292
|
+
|
|
293
|
+
describe('preventUnmountOnClose()', () => {
|
|
294
|
+
it('does not prevent unmounting on later closes', async () => {
|
|
295
|
+
let preventNextClose = true;
|
|
296
|
+
const { user } = await render(
|
|
297
|
+
<TestTooltip
|
|
298
|
+
rootProps={{
|
|
299
|
+
onOpenChange: (open, details) => {
|
|
300
|
+
if (!open && preventNextClose) {
|
|
301
|
+
preventNextClose = false;
|
|
302
|
+
details.preventUnmountOnClose();
|
|
303
|
+
}
|
|
304
|
+
},
|
|
305
|
+
}}
|
|
306
|
+
triggerProps={{
|
|
307
|
+
delay: 0,
|
|
308
|
+
closeDelay: 0,
|
|
309
|
+
}}
|
|
310
|
+
/>,
|
|
311
|
+
);
|
|
312
|
+
|
|
313
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
314
|
+
await user.hover(trigger);
|
|
315
|
+
|
|
316
|
+
await waitFor(() => {
|
|
317
|
+
expect(screen.queryByTestId('positioner')).not.toBe(null);
|
|
318
|
+
});
|
|
319
|
+
|
|
320
|
+
await user.unhover(trigger);
|
|
321
|
+
|
|
322
|
+
await waitFor(() => {
|
|
323
|
+
expect(screen.queryByTestId('positioner')).not.toBe(null);
|
|
324
|
+
});
|
|
325
|
+
|
|
326
|
+
await user.hover(trigger);
|
|
327
|
+
|
|
328
|
+
await waitFor(() => {
|
|
329
|
+
expect(trigger).toHaveAttribute('data-popup-open');
|
|
330
|
+
});
|
|
331
|
+
|
|
332
|
+
await user.unhover(trigger);
|
|
333
|
+
|
|
334
|
+
await waitFor(() => {
|
|
335
|
+
expect(screen.queryByTestId('positioner')).toBe(null);
|
|
336
|
+
});
|
|
337
|
+
});
|
|
338
|
+
});
|
|
339
|
+
|
|
340
|
+
describe('prop: actionsRef', () => {
|
|
341
|
+
it('unmounts the tooltip when the `unmount` method is called', async () => {
|
|
342
|
+
const actionsRef = {
|
|
343
|
+
current: {
|
|
344
|
+
unmount: vi.fn(),
|
|
345
|
+
close: vi.fn(),
|
|
346
|
+
},
|
|
347
|
+
};
|
|
348
|
+
|
|
349
|
+
const { user } = await render(
|
|
350
|
+
<TestTooltip
|
|
351
|
+
rootProps={{
|
|
352
|
+
actionsRef,
|
|
353
|
+
onOpenChange: (open, details) => {
|
|
354
|
+
details.preventUnmountOnClose();
|
|
355
|
+
},
|
|
356
|
+
}}
|
|
357
|
+
/>,
|
|
358
|
+
);
|
|
359
|
+
|
|
360
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
361
|
+
await user.hover(trigger);
|
|
362
|
+
|
|
363
|
+
await waitFor(() => {
|
|
364
|
+
expect(screen.queryByTestId('positioner')).not.toBe(null);
|
|
365
|
+
});
|
|
366
|
+
|
|
367
|
+
await user.unhover(trigger);
|
|
368
|
+
|
|
369
|
+
await waitFor(() => {
|
|
370
|
+
expect(screen.queryByTestId('positioner')).not.toBe(null);
|
|
371
|
+
});
|
|
372
|
+
|
|
373
|
+
await act(async () => actionsRef.current.unmount());
|
|
374
|
+
|
|
375
|
+
await waitFor(() => {
|
|
376
|
+
expect(screen.queryByTestId('positioner')).toBe(null);
|
|
377
|
+
});
|
|
378
|
+
});
|
|
379
|
+
});
|
|
380
|
+
|
|
381
|
+
describe.skipIf(isJSDOM)('prop: onOpenChangeComplete', () => {
|
|
382
|
+
it('is called on close when there is no exit animation defined', async () => {
|
|
383
|
+
const onOpenChangeComplete = vi.fn();
|
|
384
|
+
|
|
385
|
+
function Test() {
|
|
386
|
+
const [open, setOpen] = React.useState(true);
|
|
387
|
+
return (
|
|
388
|
+
<div>
|
|
389
|
+
<button onClick={() => setOpen(false)}>Close</button>
|
|
390
|
+
<Tooltip.Root open={open} onOpenChangeComplete={onOpenChangeComplete}>
|
|
391
|
+
<Tooltip.Portal>
|
|
392
|
+
<Tooltip.Positioner>
|
|
393
|
+
<Tooltip.Popup data-testid="popup" />
|
|
394
|
+
</Tooltip.Positioner>
|
|
395
|
+
</Tooltip.Portal>
|
|
396
|
+
</Tooltip.Root>
|
|
397
|
+
</div>
|
|
398
|
+
);
|
|
399
|
+
}
|
|
400
|
+
|
|
401
|
+
const { user } = await render(<Test />);
|
|
402
|
+
|
|
403
|
+
const closeButton = screen.getByText('Close');
|
|
404
|
+
await user.click(closeButton);
|
|
405
|
+
|
|
406
|
+
await waitFor(() => {
|
|
407
|
+
expect(screen.queryByTestId('popup')).toBe(null);
|
|
408
|
+
});
|
|
409
|
+
|
|
410
|
+
expect(onOpenChangeComplete.mock.calls[0][0]).toBe(true);
|
|
411
|
+
expect(onOpenChangeComplete.mock.lastCall?.[0]).toBe(false);
|
|
412
|
+
});
|
|
413
|
+
|
|
414
|
+
it('is called on close when the exit animation finishes', async () => {
|
|
415
|
+
globalThis.BASE_UI_ANIMATIONS_DISABLED = false;
|
|
416
|
+
|
|
417
|
+
const onOpenChangeComplete = vi.fn();
|
|
418
|
+
|
|
419
|
+
function Test() {
|
|
420
|
+
const style = `
|
|
421
|
+
@keyframes test-anim {
|
|
422
|
+
to {
|
|
423
|
+
opacity: 0;
|
|
424
|
+
}
|
|
425
|
+
}
|
|
426
|
+
|
|
427
|
+
.animation-test-indicator[data-ending-style] {
|
|
428
|
+
animation: test-anim 1ms;
|
|
429
|
+
}
|
|
430
|
+
`;
|
|
431
|
+
|
|
432
|
+
const [open, setOpen] = React.useState(true);
|
|
433
|
+
|
|
434
|
+
return (
|
|
435
|
+
<div>
|
|
436
|
+
{/* eslint-disable-next-line react/no-danger */}
|
|
437
|
+
<style dangerouslySetInnerHTML={{ __html: style }} />
|
|
438
|
+
<button onClick={() => setOpen(false)}>Close</button>
|
|
439
|
+
<Tooltip.Root open={open} onOpenChangeComplete={onOpenChangeComplete}>
|
|
440
|
+
<Tooltip.Portal>
|
|
441
|
+
<Tooltip.Positioner>
|
|
442
|
+
<Tooltip.Popup className="animation-test-indicator" data-testid="popup" />
|
|
443
|
+
</Tooltip.Positioner>
|
|
444
|
+
</Tooltip.Portal>
|
|
445
|
+
</Tooltip.Root>
|
|
446
|
+
</div>
|
|
447
|
+
);
|
|
448
|
+
}
|
|
449
|
+
|
|
450
|
+
const { user } = await render(<Test />);
|
|
451
|
+
|
|
452
|
+
expect(screen.getByTestId('popup')).not.toBe(null);
|
|
453
|
+
|
|
454
|
+
// Wait for open animation to finish
|
|
455
|
+
await waitFor(() => {
|
|
456
|
+
expect(onOpenChangeComplete.mock.calls[0][0]).toBe(true);
|
|
457
|
+
});
|
|
458
|
+
|
|
459
|
+
const closeButton = screen.getByText('Close');
|
|
460
|
+
await user.click(closeButton);
|
|
461
|
+
|
|
462
|
+
await waitFor(() => {
|
|
463
|
+
expect(screen.queryByTestId('popup')).toBe(null);
|
|
464
|
+
});
|
|
465
|
+
|
|
466
|
+
expect(onOpenChangeComplete.mock.lastCall?.[0]).toBe(false);
|
|
467
|
+
});
|
|
468
|
+
|
|
469
|
+
it('is called on open when there is no enter animation defined', async () => {
|
|
470
|
+
const onOpenChangeComplete = vi.fn();
|
|
471
|
+
|
|
472
|
+
function Test() {
|
|
473
|
+
const [open, setOpen] = React.useState(false);
|
|
474
|
+
return (
|
|
475
|
+
<div>
|
|
476
|
+
<button onClick={() => setOpen(true)}>Open</button>
|
|
477
|
+
<Tooltip.Root open={open} onOpenChangeComplete={onOpenChangeComplete}>
|
|
478
|
+
<Tooltip.Portal>
|
|
479
|
+
<Tooltip.Positioner>
|
|
480
|
+
<Tooltip.Popup data-testid="popup" />
|
|
481
|
+
</Tooltip.Positioner>
|
|
482
|
+
</Tooltip.Portal>
|
|
483
|
+
</Tooltip.Root>
|
|
484
|
+
</div>
|
|
485
|
+
);
|
|
486
|
+
}
|
|
487
|
+
|
|
488
|
+
const { user } = await render(<Test />);
|
|
489
|
+
|
|
490
|
+
const openButton = screen.getByText('Open');
|
|
491
|
+
await user.click(openButton);
|
|
492
|
+
|
|
493
|
+
await waitFor(() => {
|
|
494
|
+
expect(screen.queryByTestId('popup')).not.toBe(null);
|
|
495
|
+
});
|
|
496
|
+
|
|
497
|
+
expect(onOpenChangeComplete.mock.calls.length).toBe(2);
|
|
498
|
+
expect(onOpenChangeComplete.mock.calls[0][0]).toBe(true);
|
|
499
|
+
});
|
|
500
|
+
|
|
501
|
+
it('is called on open when the enter animation finishes', async () => {
|
|
502
|
+
globalThis.BASE_UI_ANIMATIONS_DISABLED = false;
|
|
503
|
+
|
|
504
|
+
const onOpenChangeComplete = vi.fn();
|
|
505
|
+
|
|
506
|
+
function Test() {
|
|
507
|
+
const style = `
|
|
508
|
+
@keyframes test-anim {
|
|
509
|
+
from {
|
|
510
|
+
opacity: 0;
|
|
511
|
+
}
|
|
512
|
+
}
|
|
513
|
+
|
|
514
|
+
.animation-test-indicator[data-starting-style] {
|
|
515
|
+
animation: test-anim 1ms;
|
|
516
|
+
}
|
|
517
|
+
`;
|
|
518
|
+
|
|
519
|
+
const [open, setOpen] = React.useState(false);
|
|
520
|
+
|
|
521
|
+
return (
|
|
522
|
+
<div>
|
|
523
|
+
{/* eslint-disable-next-line react/no-danger */}
|
|
524
|
+
<style dangerouslySetInnerHTML={{ __html: style }} />
|
|
525
|
+
<button onClick={() => setOpen(true)}>Open</button>
|
|
526
|
+
<Tooltip.Root
|
|
527
|
+
open={open}
|
|
528
|
+
onOpenChange={setOpen}
|
|
529
|
+
onOpenChangeComplete={onOpenChangeComplete}
|
|
530
|
+
>
|
|
531
|
+
<Tooltip.Portal>
|
|
532
|
+
<Tooltip.Positioner>
|
|
533
|
+
<Tooltip.Popup className="animation-test-indicator" data-testid="popup" />
|
|
534
|
+
</Tooltip.Positioner>
|
|
535
|
+
</Tooltip.Portal>
|
|
536
|
+
</Tooltip.Root>
|
|
537
|
+
</div>
|
|
538
|
+
);
|
|
539
|
+
}
|
|
540
|
+
|
|
541
|
+
const { user } = await render(<Test />);
|
|
542
|
+
|
|
543
|
+
const openButton = screen.getByText('Open');
|
|
544
|
+
await user.click(openButton);
|
|
545
|
+
|
|
546
|
+
// Wait for open animation to finish
|
|
547
|
+
await waitFor(() => {
|
|
548
|
+
expect(onOpenChangeComplete.mock.calls[0][0]).toBe(true);
|
|
549
|
+
});
|
|
550
|
+
|
|
551
|
+
expect(screen.queryByTestId('popup')).not.toBe(null);
|
|
552
|
+
});
|
|
553
|
+
|
|
554
|
+
it('does not get called on mount when not open', async () => {
|
|
555
|
+
const onOpenChangeComplete = vi.fn();
|
|
556
|
+
|
|
557
|
+
await render(
|
|
558
|
+
<Tooltip.Root onOpenChangeComplete={onOpenChangeComplete}>
|
|
559
|
+
<Tooltip.Portal>
|
|
560
|
+
<Tooltip.Positioner>
|
|
561
|
+
<Tooltip.Popup data-testid="popup" />
|
|
562
|
+
</Tooltip.Positioner>
|
|
563
|
+
</Tooltip.Portal>
|
|
564
|
+
</Tooltip.Root>,
|
|
565
|
+
);
|
|
566
|
+
|
|
567
|
+
expect(onOpenChangeComplete.mock.calls.length).toBe(0);
|
|
568
|
+
});
|
|
569
|
+
});
|
|
570
|
+
|
|
571
|
+
describe.skipIf(isJSDOM)('animations', () => {
|
|
572
|
+
it('toggles instant animations for adjacent tooltips only while opening', async () => {
|
|
573
|
+
globalThis.BASE_UI_ANIMATIONS_DISABLED = false;
|
|
574
|
+
|
|
575
|
+
const style = `
|
|
576
|
+
.tooltip {
|
|
577
|
+
transition: opacity 20ms;
|
|
578
|
+
}
|
|
579
|
+
.tooltip[data-starting-style],
|
|
580
|
+
.tooltip[data-ending-style] {
|
|
581
|
+
opacity: 0;
|
|
582
|
+
}
|
|
583
|
+
|
|
584
|
+
.tooltip[data-instant] {
|
|
585
|
+
transition: none;
|
|
586
|
+
}
|
|
587
|
+
`;
|
|
588
|
+
|
|
589
|
+
const { user } = await render(
|
|
590
|
+
<Tooltip.Provider>
|
|
591
|
+
{/* eslint-disable-next-line react/no-danger */}
|
|
592
|
+
<style dangerouslySetInnerHTML={{ __html: style }} />
|
|
593
|
+
<Tooltip.Root>
|
|
594
|
+
<Tooltip.Trigger data-testid="trigger-1" delay={0}>
|
|
595
|
+
First
|
|
596
|
+
</Tooltip.Trigger>
|
|
597
|
+
<Tooltip.Portal>
|
|
598
|
+
<Tooltip.Positioner>
|
|
599
|
+
<Tooltip.Popup className="tooltip" data-testid="popup-1">
|
|
600
|
+
First tooltip
|
|
601
|
+
</Tooltip.Popup>
|
|
602
|
+
</Tooltip.Positioner>
|
|
603
|
+
</Tooltip.Portal>
|
|
604
|
+
</Tooltip.Root>
|
|
605
|
+
<Tooltip.Root>
|
|
606
|
+
<Tooltip.Trigger data-testid="trigger-2" delay={0}>
|
|
607
|
+
Second
|
|
608
|
+
</Tooltip.Trigger>
|
|
609
|
+
<Tooltip.Portal>
|
|
610
|
+
<Tooltip.Positioner>
|
|
611
|
+
<Tooltip.Popup className="tooltip" data-testid="popup-2">
|
|
612
|
+
Second tooltip
|
|
613
|
+
</Tooltip.Popup>
|
|
614
|
+
</Tooltip.Positioner>
|
|
615
|
+
</Tooltip.Portal>
|
|
616
|
+
</Tooltip.Root>
|
|
617
|
+
</Tooltip.Provider>,
|
|
618
|
+
);
|
|
619
|
+
|
|
620
|
+
const firstTrigger = screen.getByTestId('trigger-1');
|
|
621
|
+
const secondTrigger = screen.getByTestId('trigger-2');
|
|
622
|
+
|
|
623
|
+
await user.hover(firstTrigger);
|
|
624
|
+
|
|
625
|
+
const firstPopup = await screen.findByTestId('popup-1');
|
|
626
|
+
expect(firstPopup.dataset.instant).toBe(undefined);
|
|
627
|
+
|
|
628
|
+
await user.unhover(firstTrigger);
|
|
629
|
+
await user.hover(secondTrigger);
|
|
630
|
+
|
|
631
|
+
const secondPopup = await screen.findByTestId('popup-2');
|
|
632
|
+
|
|
633
|
+
await waitFor(() => {
|
|
634
|
+
expect(secondPopup.dataset.instant).toBe('delay');
|
|
635
|
+
expect(secondPopup.getAnimations().length).toBe(0);
|
|
636
|
+
});
|
|
637
|
+
|
|
638
|
+
await user.unhover(secondTrigger);
|
|
639
|
+
|
|
640
|
+
await waitFor(() => {
|
|
641
|
+
expect(secondPopup.dataset.endingStyle).toBe('');
|
|
642
|
+
expect(secondPopup.dataset.instant).toBe(undefined);
|
|
643
|
+
expect(secondPopup.getAnimations().length).toBe(1);
|
|
644
|
+
});
|
|
645
|
+
});
|
|
646
|
+
|
|
647
|
+
it('inline opacity: 0 is removed before user CSS transitions run', async () => {
|
|
648
|
+
globalThis.BASE_UI_ANIMATIONS_DISABLED = false;
|
|
649
|
+
|
|
650
|
+
// The inline opacity: 0 applied before positioning must be removed
|
|
651
|
+
// before CSS transitions start, so it does not trigger an unwanted
|
|
652
|
+
// opacity transition.
|
|
653
|
+
const style = `
|
|
654
|
+
.tooltip {
|
|
655
|
+
transition: opacity 200ms;
|
|
656
|
+
opacity: 1;
|
|
657
|
+
}
|
|
658
|
+
`;
|
|
659
|
+
|
|
660
|
+
const { user } = await render(
|
|
661
|
+
<Tooltip.Root>
|
|
662
|
+
{/* eslint-disable-next-line react/no-danger */}
|
|
663
|
+
<style dangerouslySetInnerHTML={{ __html: style }} />
|
|
664
|
+
<Tooltip.Trigger data-testid="trigger" delay={0}>
|
|
665
|
+
Trigger
|
|
666
|
+
</Tooltip.Trigger>
|
|
667
|
+
<Tooltip.Portal>
|
|
668
|
+
<Tooltip.Positioner>
|
|
669
|
+
<Tooltip.Popup className="tooltip" data-testid="popup">
|
|
670
|
+
Tooltip
|
|
671
|
+
</Tooltip.Popup>
|
|
672
|
+
</Tooltip.Positioner>
|
|
673
|
+
</Tooltip.Portal>
|
|
674
|
+
</Tooltip.Root>,
|
|
675
|
+
);
|
|
676
|
+
|
|
677
|
+
await user.hover(screen.getByTestId('trigger'));
|
|
678
|
+
|
|
679
|
+
const popup = await screen.findByTestId('popup');
|
|
680
|
+
|
|
681
|
+
// Opacity should be 1 immediately — no unwanted fade from 0 to 1.
|
|
682
|
+
// No opacity transition should be running.
|
|
683
|
+
await waitFor(() => {
|
|
684
|
+
expect(Number(getComputedStyle(popup).opacity)).toBe(1);
|
|
685
|
+
const opacityAnimations = popup
|
|
686
|
+
.getAnimations()
|
|
687
|
+
.filter((a) => (a as CSSTransition).transitionProperty === 'opacity');
|
|
688
|
+
expect(opacityAnimations.length).toBe(0);
|
|
689
|
+
});
|
|
690
|
+
});
|
|
691
|
+
});
|
|
692
|
+
|
|
693
|
+
describe('prop: disabled', () => {
|
|
694
|
+
it('should not open when disabled', async () => {
|
|
695
|
+
await render(<TestTooltip rootProps={{ disabled: true }} triggerProps={{ delay: 0 }} />);
|
|
696
|
+
|
|
697
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
698
|
+
|
|
699
|
+
fireEvent.pointerDown(trigger, { pointerType: 'mouse' });
|
|
700
|
+
fireEvent.mouseEnter(trigger);
|
|
701
|
+
fireEvent.mouseMove(trigger);
|
|
702
|
+
|
|
703
|
+
await flushMicrotasks();
|
|
704
|
+
|
|
705
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
706
|
+
|
|
707
|
+
await act(async () => trigger.focus());
|
|
708
|
+
|
|
709
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
710
|
+
});
|
|
711
|
+
|
|
712
|
+
it('should not open on focus when the trigger is disabled', async () => {
|
|
713
|
+
await render(<TestTooltip triggerProps={{ disabled: true, delay: 0 }} />);
|
|
714
|
+
|
|
715
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
716
|
+
|
|
717
|
+
await act(async () => trigger.focus());
|
|
718
|
+
await flushMicrotasks();
|
|
719
|
+
|
|
720
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
721
|
+
});
|
|
722
|
+
|
|
723
|
+
it('should close if open when becoming disabled', async () => {
|
|
724
|
+
function App() {
|
|
725
|
+
const [disabled, setDisabled] = React.useState(false);
|
|
726
|
+
return (
|
|
727
|
+
<div>
|
|
728
|
+
<TestTooltip
|
|
729
|
+
rootProps={{ defaultOpen: true, disabled }}
|
|
730
|
+
triggerProps={{ delay: 0 }}
|
|
731
|
+
/>
|
|
732
|
+
<button
|
|
733
|
+
data-testid="disabled"
|
|
734
|
+
onClick={() => {
|
|
735
|
+
setDisabled(true);
|
|
736
|
+
}}
|
|
737
|
+
/>
|
|
738
|
+
</div>
|
|
739
|
+
);
|
|
740
|
+
}
|
|
741
|
+
|
|
742
|
+
await render(<App />);
|
|
743
|
+
|
|
744
|
+
expect(screen.queryByText('Content')).not.toBe(null);
|
|
745
|
+
|
|
746
|
+
const disabledButton = screen.getByTestId('disabled');
|
|
747
|
+
fireEvent.click(disabledButton);
|
|
748
|
+
|
|
749
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
750
|
+
});
|
|
751
|
+
|
|
752
|
+
it('does not throw error when combined with defaultOpen', async () => {
|
|
753
|
+
await render(<TestTooltip rootProps={{ defaultOpen: true, disabled: true }} />);
|
|
754
|
+
|
|
755
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
756
|
+
});
|
|
757
|
+
});
|
|
758
|
+
|
|
759
|
+
describe('prop: disableHoverablePopup', () => {
|
|
760
|
+
it('applies pointer-events: none to the positioner when `disableHoverablePopup = true`', async () => {
|
|
761
|
+
await render(
|
|
762
|
+
<TestTooltip rootProps={{ disableHoverablePopup: true }} triggerProps={{ delay: 0 }} />,
|
|
763
|
+
);
|
|
764
|
+
|
|
765
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
766
|
+
|
|
767
|
+
fireEvent.pointerDown(trigger, { pointerType: 'mouse' });
|
|
768
|
+
fireEvent.mouseEnter(trigger);
|
|
769
|
+
fireEvent.mouseMove(trigger);
|
|
770
|
+
|
|
771
|
+
await flushMicrotasks();
|
|
772
|
+
|
|
773
|
+
expect(screen.getByTestId('positioner').style.pointerEvents).toBe('none');
|
|
774
|
+
});
|
|
775
|
+
|
|
776
|
+
it('does not apply pointer-events: none to the positioner when `disableHoverablePopup = false`', async () => {
|
|
777
|
+
await render(
|
|
778
|
+
<TestTooltip rootProps={{ disableHoverablePopup: false }} triggerProps={{ delay: 0 }} />,
|
|
779
|
+
);
|
|
780
|
+
|
|
781
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
782
|
+
|
|
783
|
+
fireEvent.pointerDown(trigger, { pointerType: 'mouse' });
|
|
784
|
+
fireEvent.mouseEnter(trigger);
|
|
785
|
+
fireEvent.mouseMove(trigger);
|
|
786
|
+
|
|
787
|
+
await flushMicrotasks();
|
|
788
|
+
|
|
789
|
+
expect(screen.getByTestId('positioner').style.pointerEvents).toBe('');
|
|
790
|
+
});
|
|
791
|
+
});
|
|
792
|
+
|
|
793
|
+
describe('BaseUIChangeEventDetails', () => {
|
|
794
|
+
it('onOpenChange cancel() prevents opening while uncontrolled', async () => {
|
|
795
|
+
await render(
|
|
796
|
+
<TestTooltip
|
|
797
|
+
rootProps={{
|
|
798
|
+
onOpenChange: (nextOpen, eventDetails) => {
|
|
799
|
+
if (nextOpen) {
|
|
800
|
+
eventDetails.cancel();
|
|
801
|
+
}
|
|
802
|
+
},
|
|
803
|
+
}}
|
|
804
|
+
triggerProps={{ delay: 0 }}
|
|
805
|
+
/>,
|
|
806
|
+
);
|
|
807
|
+
|
|
808
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
809
|
+
fireEvent.pointerDown(trigger, { pointerType: 'mouse' });
|
|
810
|
+
fireEvent.mouseEnter(trigger);
|
|
811
|
+
fireEvent.mouseMove(trigger);
|
|
812
|
+
|
|
813
|
+
await flushMicrotasks();
|
|
814
|
+
|
|
815
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
816
|
+
});
|
|
817
|
+
|
|
818
|
+
it('allowPropagation() prevents stopPropagation on Escape while still closing', async () => {
|
|
819
|
+
const stopPropagationSpy = vi.spyOn(Event.prototype as any, 'stopPropagation');
|
|
820
|
+
|
|
821
|
+
await render(
|
|
822
|
+
<TestTooltip
|
|
823
|
+
rootProps={{
|
|
824
|
+
defaultOpen: true,
|
|
825
|
+
onOpenChange: (nextOpen, eventDetails) => {
|
|
826
|
+
if (!nextOpen && eventDetails.reason === REASONS.escapeKey) {
|
|
827
|
+
eventDetails.allowPropagation();
|
|
828
|
+
}
|
|
829
|
+
},
|
|
830
|
+
}}
|
|
831
|
+
triggerProps={{ delay: 0 }}
|
|
832
|
+
/>,
|
|
833
|
+
);
|
|
834
|
+
|
|
835
|
+
expect(screen.getByText('Content')).not.toBe(null);
|
|
836
|
+
|
|
837
|
+
fireEvent.keyDown(document.body, { key: 'Escape' });
|
|
838
|
+
|
|
839
|
+
await waitFor(() => {
|
|
840
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
841
|
+
});
|
|
842
|
+
|
|
843
|
+
expect(stopPropagationSpy).toHaveBeenCalledTimes(0);
|
|
844
|
+
stopPropagationSpy.mockRestore();
|
|
845
|
+
});
|
|
846
|
+
});
|
|
847
|
+
|
|
848
|
+
describe('dismissal', () => {
|
|
849
|
+
clock.withFakeTimers();
|
|
850
|
+
|
|
851
|
+
it('should not open when the trigger was clicked before delay duration', async () => {
|
|
852
|
+
await render(<TestTooltip />);
|
|
853
|
+
|
|
854
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
855
|
+
|
|
856
|
+
fireEvent.pointerDown(trigger, { pointerType: 'mouse' });
|
|
857
|
+
fireEvent.mouseEnter(trigger);
|
|
858
|
+
fireEvent.mouseMove(trigger);
|
|
859
|
+
|
|
860
|
+
clock.tick(OPEN_DELAY / 2);
|
|
861
|
+
|
|
862
|
+
fireEvent.click(trigger);
|
|
863
|
+
|
|
864
|
+
clock.tick(OPEN_DELAY / 2);
|
|
865
|
+
|
|
866
|
+
await flushMicrotasks();
|
|
867
|
+
|
|
868
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
869
|
+
});
|
|
870
|
+
|
|
871
|
+
it('should not open when the trigger receives pointerdown before delay duration', async () => {
|
|
872
|
+
await render(<TestTooltip />);
|
|
873
|
+
|
|
874
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
875
|
+
|
|
876
|
+
fireEvent.pointerEnter(trigger, { pointerType: 'mouse' });
|
|
877
|
+
fireEvent.mouseEnter(trigger);
|
|
878
|
+
fireEvent.mouseMove(trigger);
|
|
879
|
+
|
|
880
|
+
clock.tick(OPEN_DELAY / 2);
|
|
881
|
+
|
|
882
|
+
fireEvent.pointerDown(trigger, { pointerType: 'mouse' });
|
|
883
|
+
|
|
884
|
+
clock.tick(OPEN_DELAY / 2);
|
|
885
|
+
|
|
886
|
+
await flushMicrotasks();
|
|
887
|
+
|
|
888
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
889
|
+
});
|
|
890
|
+
|
|
891
|
+
it('should open when the trigger was clicked before delay duration and closeOnClick is false', async () => {
|
|
892
|
+
await render(<TestTooltip triggerProps={{ closeOnClick: false }} />);
|
|
893
|
+
|
|
894
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
895
|
+
|
|
896
|
+
fireEvent.pointerDown(trigger, { pointerType: 'mouse' });
|
|
897
|
+
fireEvent.mouseEnter(trigger);
|
|
898
|
+
fireEvent.mouseMove(trigger);
|
|
899
|
+
|
|
900
|
+
clock.tick(OPEN_DELAY / 2);
|
|
901
|
+
|
|
902
|
+
fireEvent.click(trigger);
|
|
903
|
+
|
|
904
|
+
clock.tick(OPEN_DELAY / 2);
|
|
905
|
+
|
|
906
|
+
await flushMicrotasks();
|
|
907
|
+
|
|
908
|
+
expect(screen.getByText('Content')).not.toBe(null);
|
|
909
|
+
});
|
|
910
|
+
|
|
911
|
+
it('should close when the trigger is clicked after delay duration', async () => {
|
|
912
|
+
await render(<TestTooltip />);
|
|
913
|
+
|
|
914
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
915
|
+
|
|
916
|
+
fireEvent.pointerDown(trigger, { pointerType: 'mouse' });
|
|
917
|
+
fireEvent.mouseEnter(trigger);
|
|
918
|
+
fireEvent.mouseMove(trigger);
|
|
919
|
+
|
|
920
|
+
clock.tick(OPEN_DELAY);
|
|
921
|
+
|
|
922
|
+
await flushMicrotasks();
|
|
923
|
+
|
|
924
|
+
expect(screen.getByText('Content')).not.toBe(null);
|
|
925
|
+
|
|
926
|
+
fireEvent.click(trigger);
|
|
927
|
+
|
|
928
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
929
|
+
});
|
|
930
|
+
|
|
931
|
+
it('should not close when the trigger is clicked after delay duration and closeOnClick is false', async () => {
|
|
932
|
+
await render(<TestTooltip triggerProps={{ closeOnClick: false }} />);
|
|
933
|
+
|
|
934
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
935
|
+
|
|
936
|
+
fireEvent.pointerDown(trigger, { pointerType: 'mouse' });
|
|
937
|
+
fireEvent.mouseEnter(trigger);
|
|
938
|
+
fireEvent.mouseMove(trigger);
|
|
939
|
+
|
|
940
|
+
clock.tick(OPEN_DELAY);
|
|
941
|
+
|
|
942
|
+
await flushMicrotasks();
|
|
943
|
+
|
|
944
|
+
expect(screen.getByText('Content')).not.toBe(null);
|
|
945
|
+
|
|
946
|
+
fireEvent.click(trigger);
|
|
947
|
+
|
|
948
|
+
expect(screen.getByText('Content')).not.toBe(null);
|
|
949
|
+
});
|
|
950
|
+
|
|
951
|
+
it('reopens on hover after the trigger is clicked closed', async () => {
|
|
952
|
+
await render(<TestTooltip triggerProps={{ delay: 100 }} />);
|
|
953
|
+
|
|
954
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
955
|
+
|
|
956
|
+
fireEvent.pointerDown(trigger, { pointerType: 'mouse' });
|
|
957
|
+
fireEvent.mouseEnter(trigger);
|
|
958
|
+
fireEvent.mouseMove(trigger);
|
|
959
|
+
|
|
960
|
+
clock.tick(100);
|
|
961
|
+
await flushMicrotasks();
|
|
962
|
+
|
|
963
|
+
expect(screen.getByText('Content')).not.toBe(null);
|
|
964
|
+
|
|
965
|
+
fireEvent.click(trigger);
|
|
966
|
+
await flushMicrotasks();
|
|
967
|
+
|
|
968
|
+
expect(screen.queryByText('Content')).toBe(null);
|
|
969
|
+
|
|
970
|
+
// Re-enter with mouse events only. A fresh pointerenter can be missed
|
|
971
|
+
// after the click-driven close, but hover should still work.
|
|
972
|
+
fireEvent.mouseEnter(trigger);
|
|
973
|
+
fireEvent.mouseMove(trigger);
|
|
974
|
+
|
|
975
|
+
clock.tick(100);
|
|
976
|
+
await flushMicrotasks();
|
|
977
|
+
|
|
978
|
+
expect(screen.getByText('Content')).not.toBe(null);
|
|
979
|
+
});
|
|
980
|
+
});
|
|
981
|
+
});
|
|
982
|
+
|
|
983
|
+
describe('preventUnmountOnClose()', () => {
|
|
984
|
+
it('unmounts on a normal close after a prevented close and initially open remount', async () => {
|
|
985
|
+
const tooltip = Tooltip.createHandle();
|
|
986
|
+
|
|
987
|
+
function App() {
|
|
988
|
+
const [showRoot, setShowRoot] = React.useState(true);
|
|
989
|
+
const [remountOpen, setRemountOpen] = React.useState(false);
|
|
990
|
+
const preventNextUnmountRef = React.useRef(true);
|
|
991
|
+
|
|
992
|
+
return (
|
|
993
|
+
<React.Fragment>
|
|
994
|
+
<Tooltip.Trigger handle={tooltip} id="trigger" delay={0}>
|
|
995
|
+
Toggle
|
|
996
|
+
</Tooltip.Trigger>
|
|
997
|
+
<button type="button" onClick={() => tooltip.open('trigger')}>
|
|
998
|
+
Open tooltip
|
|
999
|
+
</button>
|
|
1000
|
+
<button type="button" onClick={() => tooltip.close()}>
|
|
1001
|
+
Close tooltip
|
|
1002
|
+
</button>
|
|
1003
|
+
<button type="button" onClick={() => setShowRoot(false)}>
|
|
1004
|
+
Unmount root
|
|
1005
|
+
</button>
|
|
1006
|
+
<button
|
|
1007
|
+
type="button"
|
|
1008
|
+
onClick={() => {
|
|
1009
|
+
setRemountOpen(true);
|
|
1010
|
+
setShowRoot(true);
|
|
1011
|
+
}}
|
|
1012
|
+
>
|
|
1013
|
+
Remount open
|
|
1014
|
+
</button>
|
|
1015
|
+
{showRoot && (
|
|
1016
|
+
<Tooltip.Root
|
|
1017
|
+
handle={tooltip}
|
|
1018
|
+
defaultOpen={remountOpen}
|
|
1019
|
+
defaultTriggerId="trigger"
|
|
1020
|
+
onOpenChange={(open, details) => {
|
|
1021
|
+
if (!open && preventNextUnmountRef.current) {
|
|
1022
|
+
preventNextUnmountRef.current = false;
|
|
1023
|
+
details.preventUnmountOnClose();
|
|
1024
|
+
}
|
|
1025
|
+
}}
|
|
1026
|
+
>
|
|
1027
|
+
<Tooltip.Portal>
|
|
1028
|
+
<Tooltip.Positioner data-testid="positioner">
|
|
1029
|
+
<Tooltip.Popup>Content</Tooltip.Popup>
|
|
1030
|
+
</Tooltip.Positioner>
|
|
1031
|
+
</Tooltip.Portal>
|
|
1032
|
+
</Tooltip.Root>
|
|
1033
|
+
)}
|
|
1034
|
+
</React.Fragment>
|
|
1035
|
+
);
|
|
1036
|
+
}
|
|
1037
|
+
|
|
1038
|
+
const { user } = await render(<App />);
|
|
1039
|
+
const trigger = screen.getByRole('button', { name: 'Toggle' });
|
|
1040
|
+
|
|
1041
|
+
await user.click(screen.getByRole('button', { name: 'Open tooltip' }));
|
|
1042
|
+
await waitFor(() => {
|
|
1043
|
+
expect(screen.queryByTestId('positioner')).not.toBe(null);
|
|
1044
|
+
});
|
|
1045
|
+
|
|
1046
|
+
await user.click(screen.getByRole('button', { name: 'Close tooltip' }));
|
|
1047
|
+
await waitFor(() => {
|
|
1048
|
+
expect(trigger).not.toHaveAttribute('data-popup-open');
|
|
1049
|
+
});
|
|
1050
|
+
expect(screen.queryByTestId('positioner')).not.toBe(null);
|
|
1051
|
+
|
|
1052
|
+
await user.click(screen.getByRole('button', { name: 'Unmount root' }));
|
|
1053
|
+
expect(screen.queryByTestId('positioner')).toBe(null);
|
|
1054
|
+
|
|
1055
|
+
await user.click(screen.getByRole('button', { name: 'Remount open' }));
|
|
1056
|
+
await waitFor(() => {
|
|
1057
|
+
expect(screen.getByRole('button', { name: 'Toggle' })).toHaveAttribute('data-popup-open');
|
|
1058
|
+
});
|
|
1059
|
+
expect(screen.queryByTestId('positioner')).not.toBe(null);
|
|
1060
|
+
|
|
1061
|
+
await user.click(screen.getByRole('button', { name: 'Close tooltip' }));
|
|
1062
|
+
await waitFor(() => {
|
|
1063
|
+
expect(screen.queryByTestId('positioner')).toBe(null);
|
|
1064
|
+
});
|
|
1065
|
+
});
|
|
1066
|
+
});
|
|
1067
|
+
|
|
1068
|
+
it.skipIf(isJSDOM)(
|
|
1069
|
+
'tracks the cursor on the first delayed hover when trackCursorAxis is x',
|
|
1070
|
+
async () => {
|
|
1071
|
+
await render(
|
|
1072
|
+
<div style={{ paddingTop: 100, paddingLeft: 40 }}>
|
|
1073
|
+
<Tooltip.Root trackCursorAxis="x">
|
|
1074
|
+
<Tooltip.Trigger delay={100} style={{ width: 300, height: 40 }}>
|
|
1075
|
+
Trigger
|
|
1076
|
+
</Tooltip.Trigger>
|
|
1077
|
+
<Tooltip.Portal>
|
|
1078
|
+
<Tooltip.Positioner data-testid="positioner" side="bottom">
|
|
1079
|
+
<Tooltip.Popup style={{ width: 40, height: 20 }}>Tooltip</Tooltip.Popup>
|
|
1080
|
+
</Tooltip.Positioner>
|
|
1081
|
+
</Tooltip.Portal>
|
|
1082
|
+
</Tooltip.Root>
|
|
1083
|
+
</div>,
|
|
1084
|
+
);
|
|
1085
|
+
|
|
1086
|
+
const trigger = screen.getByRole('button', { name: 'Trigger' });
|
|
1087
|
+
const triggerRect = trigger.getBoundingClientRect();
|
|
1088
|
+
const cursorX = triggerRect.left + 240;
|
|
1089
|
+
const cursorY = triggerRect.top + 20;
|
|
1090
|
+
|
|
1091
|
+
fireEvent.pointerDown(trigger, { pointerType: 'mouse', clientX: cursorX, clientY: cursorY });
|
|
1092
|
+
fireEvent.mouseEnter(trigger, { clientX: cursorX, clientY: cursorY });
|
|
1093
|
+
fireEvent.mouseMove(trigger, { clientX: cursorX, clientY: cursorY });
|
|
1094
|
+
|
|
1095
|
+
const positioner = await screen.findByTestId('positioner');
|
|
1096
|
+
|
|
1097
|
+
await waitFor(() => {
|
|
1098
|
+
const positionerRect = positioner.getBoundingClientRect();
|
|
1099
|
+
const positionerCenterX = positionerRect.left + positionerRect.width / 2;
|
|
1100
|
+
expect(Math.abs(positionerCenterX - cursorX)).toBeLessThanOrEqual(2);
|
|
1101
|
+
});
|
|
1102
|
+
},
|
|
1103
|
+
);
|
|
1104
|
+
|
|
1105
|
+
it.skipIf(isJSDOM)(
|
|
1106
|
+
'stops tracking the cursor after trackCursorAxis is disabled while closed',
|
|
1107
|
+
async () => {
|
|
1108
|
+
function App() {
|
|
1109
|
+
const [trackCursorAxis, setTrackCursorAxis] = React.useState<'none' | 'x'>('x');
|
|
1110
|
+
|
|
1111
|
+
return (
|
|
1112
|
+
<div style={{ paddingTop: 100, paddingLeft: 40 }}>
|
|
1113
|
+
<button onClick={() => setTrackCursorAxis('none')}>Disable tracking</button>
|
|
1114
|
+
<Tooltip.Root trackCursorAxis={trackCursorAxis}>
|
|
1115
|
+
<Tooltip.Trigger delay={100} style={{ width: 300, height: 40 }}>
|
|
1116
|
+
Trigger
|
|
1117
|
+
</Tooltip.Trigger>
|
|
1118
|
+
<Tooltip.Portal>
|
|
1119
|
+
<Tooltip.Positioner data-testid="positioner" side="bottom">
|
|
1120
|
+
<Tooltip.Popup style={{ width: 40, height: 20 }}>Tooltip</Tooltip.Popup>
|
|
1121
|
+
</Tooltip.Positioner>
|
|
1122
|
+
</Tooltip.Portal>
|
|
1123
|
+
</Tooltip.Root>
|
|
1124
|
+
</div>
|
|
1125
|
+
);
|
|
1126
|
+
}
|
|
1127
|
+
|
|
1128
|
+
const { user } = await render(<App />);
|
|
1129
|
+
|
|
1130
|
+
const trigger = screen.getByRole('button', { name: 'Trigger' });
|
|
1131
|
+
const triggerRect = trigger.getBoundingClientRect();
|
|
1132
|
+
const cursorX = triggerRect.left + 240;
|
|
1133
|
+
const cursorY = triggerRect.top + 20;
|
|
1134
|
+
|
|
1135
|
+
fireEvent.pointerDown(trigger, { pointerType: 'mouse', clientX: cursorX, clientY: cursorY });
|
|
1136
|
+
fireEvent.mouseEnter(trigger, { clientX: cursorX, clientY: cursorY });
|
|
1137
|
+
fireEvent.mouseMove(trigger, { clientX: cursorX, clientY: cursorY });
|
|
1138
|
+
|
|
1139
|
+
const trackedPositioner = await screen.findByTestId('positioner');
|
|
1140
|
+
|
|
1141
|
+
await waitFor(() => {
|
|
1142
|
+
const positionerRect = trackedPositioner.getBoundingClientRect();
|
|
1143
|
+
const positionerCenterX = positionerRect.left + positionerRect.width / 2;
|
|
1144
|
+
expect(Math.abs(positionerCenterX - cursorX)).toBeLessThanOrEqual(2);
|
|
1145
|
+
});
|
|
1146
|
+
|
|
1147
|
+
fireEvent.mouseLeave(trigger);
|
|
1148
|
+
await waitFor(() => {
|
|
1149
|
+
expect(screen.queryByTestId('positioner')).toBe(null);
|
|
1150
|
+
});
|
|
1151
|
+
|
|
1152
|
+
await user.click(screen.getByRole('button', { name: 'Disable tracking' }));
|
|
1153
|
+
|
|
1154
|
+
fireEvent.mouseEnter(trigger, { clientX: cursorX, clientY: cursorY });
|
|
1155
|
+
fireEvent.mouseMove(trigger, { clientX: cursorX, clientY: cursorY });
|
|
1156
|
+
|
|
1157
|
+
const untrackedPositioner = await screen.findByTestId('positioner');
|
|
1158
|
+
|
|
1159
|
+
await waitFor(() => {
|
|
1160
|
+
const positionerRect = untrackedPositioner.getBoundingClientRect();
|
|
1161
|
+
const positionerCenterX = positionerRect.left + positionerRect.width / 2;
|
|
1162
|
+
const triggerCenterX = triggerRect.left + triggerRect.width / 2;
|
|
1163
|
+
|
|
1164
|
+
expect(Math.abs(positionerCenterX - triggerCenterX)).toBeLessThanOrEqual(2);
|
|
1165
|
+
});
|
|
1166
|
+
},
|
|
1167
|
+
);
|
|
1168
|
+
|
|
1169
|
+
it.skipIf(isJSDOM)(
|
|
1170
|
+
'updates the tracked cursor position after closing and reopening',
|
|
1171
|
+
async () => {
|
|
1172
|
+
await render(
|
|
1173
|
+
<div style={{ paddingTop: 100, paddingLeft: 40 }}>
|
|
1174
|
+
<Tooltip.Root trackCursorAxis="x">
|
|
1175
|
+
<Tooltip.Trigger delay={100} style={{ width: 300, height: 40 }}>
|
|
1176
|
+
Trigger
|
|
1177
|
+
</Tooltip.Trigger>
|
|
1178
|
+
<Tooltip.Portal>
|
|
1179
|
+
<Tooltip.Positioner data-testid="positioner" side="bottom">
|
|
1180
|
+
<Tooltip.Popup style={{ width: 40, height: 20 }}>Tooltip</Tooltip.Popup>
|
|
1181
|
+
</Tooltip.Positioner>
|
|
1182
|
+
</Tooltip.Portal>
|
|
1183
|
+
</Tooltip.Root>
|
|
1184
|
+
</div>,
|
|
1185
|
+
);
|
|
1186
|
+
|
|
1187
|
+
const trigger = screen.getByRole('button', { name: 'Trigger' });
|
|
1188
|
+
const triggerRect = trigger.getBoundingClientRect();
|
|
1189
|
+
const firstCursorX = triggerRect.left + 240;
|
|
1190
|
+
const secondCursorX = triggerRect.left + 60;
|
|
1191
|
+
const cursorY = triggerRect.top + 20;
|
|
1192
|
+
|
|
1193
|
+
fireEvent.pointerDown(trigger, {
|
|
1194
|
+
pointerType: 'mouse',
|
|
1195
|
+
clientX: firstCursorX,
|
|
1196
|
+
clientY: cursorY,
|
|
1197
|
+
});
|
|
1198
|
+
fireEvent.mouseEnter(trigger, { clientX: firstCursorX, clientY: cursorY });
|
|
1199
|
+
fireEvent.mouseMove(trigger, { clientX: firstCursorX, clientY: cursorY });
|
|
1200
|
+
|
|
1201
|
+
const firstPositioner = await screen.findByTestId('positioner');
|
|
1202
|
+
|
|
1203
|
+
await waitFor(() => {
|
|
1204
|
+
const positionerRect = firstPositioner.getBoundingClientRect();
|
|
1205
|
+
const positionerCenterX = positionerRect.left + positionerRect.width / 2;
|
|
1206
|
+
expect(Math.abs(positionerCenterX - firstCursorX)).toBeLessThanOrEqual(2);
|
|
1207
|
+
});
|
|
1208
|
+
|
|
1209
|
+
fireEvent.mouseLeave(trigger);
|
|
1210
|
+
await waitFor(() => {
|
|
1211
|
+
expect(screen.queryByTestId('positioner')).toBe(null);
|
|
1212
|
+
});
|
|
1213
|
+
|
|
1214
|
+
fireEvent.mouseEnter(trigger, { clientX: secondCursorX, clientY: cursorY });
|
|
1215
|
+
fireEvent.mouseMove(trigger, { clientX: secondCursorX, clientY: cursorY });
|
|
1216
|
+
|
|
1217
|
+
const secondPositioner = await screen.findByTestId('positioner');
|
|
1218
|
+
|
|
1219
|
+
await waitFor(() => {
|
|
1220
|
+
const positionerRect = secondPositioner.getBoundingClientRect();
|
|
1221
|
+
const positionerCenterX = positionerRect.left + positionerRect.width / 2;
|
|
1222
|
+
expect(Math.abs(positionerCenterX - secondCursorX)).toBeLessThanOrEqual(2);
|
|
1223
|
+
});
|
|
1224
|
+
},
|
|
1225
|
+
);
|
|
1226
|
+
|
|
1227
|
+
it('keeps the tooltip open when moving across spaced triggers without a closeDelay', async () => {
|
|
1228
|
+
const testTooltip = Tooltip.createHandle();
|
|
1229
|
+
const { user } = await render(
|
|
1230
|
+
<Tooltip.Provider timeout={400}>
|
|
1231
|
+
<div style={{ display: 'flex', gap: 32 }}>
|
|
1232
|
+
<Tooltip.Trigger handle={testTooltip} delay={0}>
|
|
1233
|
+
Trigger 1
|
|
1234
|
+
</Tooltip.Trigger>
|
|
1235
|
+
<Tooltip.Trigger handle={testTooltip} delay={0}>
|
|
1236
|
+
Trigger 2
|
|
1237
|
+
</Tooltip.Trigger>
|
|
1238
|
+
<Tooltip.Trigger handle={testTooltip} delay={0}>
|
|
1239
|
+
Trigger 3
|
|
1240
|
+
</Tooltip.Trigger>
|
|
1241
|
+
</div>
|
|
1242
|
+
|
|
1243
|
+
<Tooltip.Root handle={testTooltip}>
|
|
1244
|
+
<Tooltip.Portal>
|
|
1245
|
+
<Tooltip.Positioner>
|
|
1246
|
+
<Tooltip.Popup data-testid="popup">Tooltip Content</Tooltip.Popup>
|
|
1247
|
+
</Tooltip.Positioner>
|
|
1248
|
+
</Tooltip.Portal>
|
|
1249
|
+
</Tooltip.Root>
|
|
1250
|
+
</Tooltip.Provider>,
|
|
1251
|
+
);
|
|
1252
|
+
|
|
1253
|
+
const [trigger1, trigger2, trigger3] = screen.getAllByRole('button');
|
|
1254
|
+
|
|
1255
|
+
await user.hover(trigger1);
|
|
1256
|
+
await waitFor(() => {
|
|
1257
|
+
expect(screen.getByTestId('popup')).toBeVisible();
|
|
1258
|
+
});
|
|
1259
|
+
|
|
1260
|
+
await user.unhover(trigger1);
|
|
1261
|
+
await user.hover(trigger2);
|
|
1262
|
+
await waitFor(() => {
|
|
1263
|
+
expect(screen.getByTestId('popup')).toBeVisible();
|
|
1264
|
+
});
|
|
1265
|
+
|
|
1266
|
+
fireEvent.mouseLeave(trigger2, { relatedTarget: document.body, clientX: 120, clientY: 0 });
|
|
1267
|
+
await user.hover(trigger3);
|
|
1268
|
+
|
|
1269
|
+
await waitFor(() => {
|
|
1270
|
+
expect(screen.getByTestId('popup')).toBeVisible();
|
|
1271
|
+
});
|
|
1272
|
+
|
|
1273
|
+
fireEvent.mouseMove(document.body, { clientX: 300, clientY: 0 });
|
|
1274
|
+
|
|
1275
|
+
await waitFor(() => {
|
|
1276
|
+
expect(screen.getByTestId('popup')).toBeVisible();
|
|
1277
|
+
});
|
|
1278
|
+
});
|
|
1279
|
+
});
|
|
1280
|
+
|
|
1281
|
+
describe('nested tooltips', () => {
|
|
1282
|
+
const { render, clock } = createRenderer();
|
|
1283
|
+
clock.withFakeTimers();
|
|
1284
|
+
|
|
1285
|
+
it('should not open the outer tooltip when hovering over a nested tooltip trigger', async () => {
|
|
1286
|
+
await render(
|
|
1287
|
+
<Tooltip.Root>
|
|
1288
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />}>
|
|
1289
|
+
Outer
|
|
1290
|
+
<Tooltip.Root>
|
|
1291
|
+
<Tooltip.Trigger data-testid="inner-trigger">Inner</Tooltip.Trigger>
|
|
1292
|
+
<Tooltip.Portal>
|
|
1293
|
+
<Tooltip.Positioner>
|
|
1294
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
1295
|
+
</Tooltip.Positioner>
|
|
1296
|
+
</Tooltip.Portal>
|
|
1297
|
+
</Tooltip.Root>
|
|
1298
|
+
</Tooltip.Trigger>
|
|
1299
|
+
<Tooltip.Portal>
|
|
1300
|
+
<Tooltip.Positioner>
|
|
1301
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
1302
|
+
</Tooltip.Positioner>
|
|
1303
|
+
</Tooltip.Portal>
|
|
1304
|
+
</Tooltip.Root>,
|
|
1305
|
+
);
|
|
1306
|
+
|
|
1307
|
+
const outerTrigger = screen.getByTestId('outer-trigger');
|
|
1308
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
1309
|
+
|
|
1310
|
+
fireEvent.pointerEnter(outerTrigger, { pointerType: 'mouse', clientX: 10, clientY: 10 });
|
|
1311
|
+
fireEvent.mouseEnter(outerTrigger);
|
|
1312
|
+
fireEvent.pointerDown(innerTrigger, { pointerType: 'mouse' });
|
|
1313
|
+
fireEvent.pointerEnter(innerTrigger, { clientX: 10, clientY: 10 });
|
|
1314
|
+
fireEvent.mouseOver(innerTrigger);
|
|
1315
|
+
fireEvent.mouseEnter(innerTrigger);
|
|
1316
|
+
fireEvent.mouseMove(innerTrigger, { clientX: 10, clientY: 10 });
|
|
1317
|
+
|
|
1318
|
+
clock.tick(OPEN_DELAY);
|
|
1319
|
+
await flushMicrotasks();
|
|
1320
|
+
|
|
1321
|
+
expect(screen.getByTestId('inner-popup')).not.toBe(null);
|
|
1322
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
1323
|
+
});
|
|
1324
|
+
|
|
1325
|
+
it('should not open the outer tooltip when moving between sibling nested triggers', async () => {
|
|
1326
|
+
await render(
|
|
1327
|
+
<Tooltip.Root>
|
|
1328
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />}>
|
|
1329
|
+
Outer
|
|
1330
|
+
<Tooltip.Root>
|
|
1331
|
+
<Tooltip.Trigger data-testid="inner-a-trigger">Inner A</Tooltip.Trigger>
|
|
1332
|
+
<Tooltip.Portal>
|
|
1333
|
+
<Tooltip.Positioner>
|
|
1334
|
+
<Tooltip.Popup data-testid="inner-a-popup">Inner A tooltip</Tooltip.Popup>
|
|
1335
|
+
</Tooltip.Positioner>
|
|
1336
|
+
</Tooltip.Portal>
|
|
1337
|
+
</Tooltip.Root>
|
|
1338
|
+
<Tooltip.Root>
|
|
1339
|
+
<Tooltip.Trigger data-testid="inner-b-trigger">Inner B</Tooltip.Trigger>
|
|
1340
|
+
<Tooltip.Portal>
|
|
1341
|
+
<Tooltip.Positioner>
|
|
1342
|
+
<Tooltip.Popup data-testid="inner-b-popup">Inner B tooltip</Tooltip.Popup>
|
|
1343
|
+
</Tooltip.Positioner>
|
|
1344
|
+
</Tooltip.Portal>
|
|
1345
|
+
</Tooltip.Root>
|
|
1346
|
+
</Tooltip.Trigger>
|
|
1347
|
+
<Tooltip.Portal>
|
|
1348
|
+
<Tooltip.Positioner>
|
|
1349
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
1350
|
+
</Tooltip.Positioner>
|
|
1351
|
+
</Tooltip.Portal>
|
|
1352
|
+
</Tooltip.Root>,
|
|
1353
|
+
);
|
|
1354
|
+
|
|
1355
|
+
const outerTrigger = screen.getByTestId('outer-trigger');
|
|
1356
|
+
const innerATrigger = screen.getByTestId('inner-a-trigger');
|
|
1357
|
+
const innerBTrigger = screen.getByTestId('inner-b-trigger');
|
|
1358
|
+
|
|
1359
|
+
fireEvent.pointerEnter(outerTrigger, { pointerType: 'mouse', clientX: 10, clientY: 10 });
|
|
1360
|
+
fireEvent.mouseEnter(outerTrigger);
|
|
1361
|
+
fireEvent.pointerEnter(innerATrigger, { pointerType: 'mouse', clientX: 30, clientY: 10 });
|
|
1362
|
+
fireEvent.mouseEnter(innerATrigger);
|
|
1363
|
+
fireEvent.mouseOver(innerATrigger);
|
|
1364
|
+
fireEvent.mouseMove(innerATrigger, { clientX: 30, clientY: 10 });
|
|
1365
|
+
|
|
1366
|
+
clock.tick(OPEN_DELAY);
|
|
1367
|
+
await flushMicrotasks();
|
|
1368
|
+
|
|
1369
|
+
expect(screen.getByTestId('inner-a-popup')).not.toBe(null);
|
|
1370
|
+
expect(screen.queryByTestId('inner-b-popup')).toBe(null);
|
|
1371
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
1372
|
+
|
|
1373
|
+
fireEvent.mouseOut(innerATrigger, { relatedTarget: innerBTrigger });
|
|
1374
|
+
fireEvent.pointerEnter(innerBTrigger, { pointerType: 'mouse', clientX: 50, clientY: 10 });
|
|
1375
|
+
fireEvent.mouseEnter(innerBTrigger);
|
|
1376
|
+
fireEvent.mouseOver(innerBTrigger);
|
|
1377
|
+
fireEvent.mouseMove(innerBTrigger, { clientX: 50, clientY: 10 });
|
|
1378
|
+
|
|
1379
|
+
clock.tick(OPEN_DELAY);
|
|
1380
|
+
await flushMicrotasks();
|
|
1381
|
+
|
|
1382
|
+
expect(screen.queryByTestId('inner-a-popup')).toBe(null);
|
|
1383
|
+
expect(screen.getByTestId('inner-b-popup')).not.toBe(null);
|
|
1384
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
1385
|
+
});
|
|
1386
|
+
|
|
1387
|
+
it('should not open ancestor tooltips when hovering over a third-level nested trigger', async () => {
|
|
1388
|
+
await render(
|
|
1389
|
+
<Tooltip.Root>
|
|
1390
|
+
<Tooltip.Trigger data-testid="grandparent-trigger" render={<span />}>
|
|
1391
|
+
Grandparent
|
|
1392
|
+
<Tooltip.Root>
|
|
1393
|
+
<Tooltip.Trigger data-testid="parent-trigger" render={<span />}>
|
|
1394
|
+
Parent
|
|
1395
|
+
<Tooltip.Root>
|
|
1396
|
+
<Tooltip.Trigger data-testid="child-trigger">Child</Tooltip.Trigger>
|
|
1397
|
+
<Tooltip.Portal>
|
|
1398
|
+
<Tooltip.Positioner>
|
|
1399
|
+
<Tooltip.Popup data-testid="child-popup">Child tooltip</Tooltip.Popup>
|
|
1400
|
+
</Tooltip.Positioner>
|
|
1401
|
+
</Tooltip.Portal>
|
|
1402
|
+
</Tooltip.Root>
|
|
1403
|
+
</Tooltip.Trigger>
|
|
1404
|
+
<Tooltip.Portal>
|
|
1405
|
+
<Tooltip.Positioner>
|
|
1406
|
+
<Tooltip.Popup data-testid="parent-popup">Parent tooltip</Tooltip.Popup>
|
|
1407
|
+
</Tooltip.Positioner>
|
|
1408
|
+
</Tooltip.Portal>
|
|
1409
|
+
</Tooltip.Root>
|
|
1410
|
+
</Tooltip.Trigger>
|
|
1411
|
+
<Tooltip.Portal>
|
|
1412
|
+
<Tooltip.Positioner>
|
|
1413
|
+
<Tooltip.Popup data-testid="grandparent-popup">Grandparent tooltip</Tooltip.Popup>
|
|
1414
|
+
</Tooltip.Positioner>
|
|
1415
|
+
</Tooltip.Portal>
|
|
1416
|
+
</Tooltip.Root>,
|
|
1417
|
+
);
|
|
1418
|
+
|
|
1419
|
+
const grandparentTrigger = screen.getByTestId('grandparent-trigger');
|
|
1420
|
+
const parentTrigger = screen.getByTestId('parent-trigger');
|
|
1421
|
+
const childTrigger = screen.getByTestId('child-trigger');
|
|
1422
|
+
|
|
1423
|
+
fireEvent.pointerEnter(grandparentTrigger, {
|
|
1424
|
+
pointerType: 'mouse',
|
|
1425
|
+
clientX: 10,
|
|
1426
|
+
clientY: 10,
|
|
1427
|
+
});
|
|
1428
|
+
fireEvent.mouseEnter(grandparentTrigger);
|
|
1429
|
+
fireEvent.pointerEnter(parentTrigger, { pointerType: 'mouse', clientX: 30, clientY: 10 });
|
|
1430
|
+
fireEvent.mouseEnter(parentTrigger);
|
|
1431
|
+
fireEvent.pointerEnter(childTrigger, { pointerType: 'mouse', clientX: 50, clientY: 10 });
|
|
1432
|
+
fireEvent.mouseEnter(childTrigger);
|
|
1433
|
+
fireEvent.mouseOver(childTrigger);
|
|
1434
|
+
fireEvent.mouseMove(childTrigger, { clientX: 50, clientY: 10 });
|
|
1435
|
+
|
|
1436
|
+
clock.tick(OPEN_DELAY);
|
|
1437
|
+
await flushMicrotasks();
|
|
1438
|
+
|
|
1439
|
+
expect(screen.getByTestId('child-popup')).not.toBe(null);
|
|
1440
|
+
expect(screen.queryByTestId('parent-popup')).toBe(null);
|
|
1441
|
+
expect(screen.queryByTestId('grandparent-popup')).toBe(null);
|
|
1442
|
+
});
|
|
1443
|
+
|
|
1444
|
+
it('should open the outer tooltip when moving from a nested trigger to the parent area with zero delay', async () => {
|
|
1445
|
+
await render(
|
|
1446
|
+
<Tooltip.Root>
|
|
1447
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />} delay={0}>
|
|
1448
|
+
<span data-testid="outer-area">Outer</span>
|
|
1449
|
+
<Tooltip.Root>
|
|
1450
|
+
<Tooltip.Trigger data-testid="inner-trigger">Inner</Tooltip.Trigger>
|
|
1451
|
+
<Tooltip.Portal>
|
|
1452
|
+
<Tooltip.Positioner>
|
|
1453
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
1454
|
+
</Tooltip.Positioner>
|
|
1455
|
+
</Tooltip.Portal>
|
|
1456
|
+
</Tooltip.Root>
|
|
1457
|
+
</Tooltip.Trigger>
|
|
1458
|
+
<Tooltip.Portal>
|
|
1459
|
+
<Tooltip.Positioner>
|
|
1460
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
1461
|
+
</Tooltip.Positioner>
|
|
1462
|
+
</Tooltip.Portal>
|
|
1463
|
+
</Tooltip.Root>,
|
|
1464
|
+
);
|
|
1465
|
+
|
|
1466
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
1467
|
+
const outerArea = screen.getByTestId('outer-area');
|
|
1468
|
+
|
|
1469
|
+
fireEvent.pointerDown(innerTrigger, { pointerType: 'mouse' });
|
|
1470
|
+
fireEvent.pointerEnter(innerTrigger, { clientX: 50, clientY: 10 });
|
|
1471
|
+
fireEvent.mouseEnter(innerTrigger);
|
|
1472
|
+
fireEvent.mouseOver(innerTrigger);
|
|
1473
|
+
|
|
1474
|
+
await flushMicrotasks();
|
|
1475
|
+
|
|
1476
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
1477
|
+
|
|
1478
|
+
fireEvent.mouseOut(innerTrigger, { relatedTarget: outerArea });
|
|
1479
|
+
fireEvent.mouseOver(outerArea);
|
|
1480
|
+
|
|
1481
|
+
await flushMicrotasks();
|
|
1482
|
+
|
|
1483
|
+
expect(screen.getByTestId('outer-popup')).not.toBe(null);
|
|
1484
|
+
});
|
|
1485
|
+
|
|
1486
|
+
it('should not open a disabled outer tooltip when moving from a nested trigger to the parent area with zero delay', async () => {
|
|
1487
|
+
await render(
|
|
1488
|
+
<Tooltip.Root>
|
|
1489
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />} delay={0} disabled>
|
|
1490
|
+
<span data-testid="outer-area">Outer</span>
|
|
1491
|
+
<Tooltip.Root>
|
|
1492
|
+
<Tooltip.Trigger data-testid="inner-trigger">Inner</Tooltip.Trigger>
|
|
1493
|
+
<Tooltip.Portal>
|
|
1494
|
+
<Tooltip.Positioner>
|
|
1495
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
1496
|
+
</Tooltip.Positioner>
|
|
1497
|
+
</Tooltip.Portal>
|
|
1498
|
+
</Tooltip.Root>
|
|
1499
|
+
</Tooltip.Trigger>
|
|
1500
|
+
<Tooltip.Portal>
|
|
1501
|
+
<Tooltip.Positioner>
|
|
1502
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
1503
|
+
</Tooltip.Positioner>
|
|
1504
|
+
</Tooltip.Portal>
|
|
1505
|
+
</Tooltip.Root>,
|
|
1506
|
+
);
|
|
1507
|
+
|
|
1508
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
1509
|
+
const outerArea = screen.getByTestId('outer-area');
|
|
1510
|
+
|
|
1511
|
+
fireEvent.pointerDown(innerTrigger, { pointerType: 'mouse' });
|
|
1512
|
+
fireEvent.pointerEnter(innerTrigger, { clientX: 50, clientY: 10 });
|
|
1513
|
+
fireEvent.mouseEnter(innerTrigger);
|
|
1514
|
+
fireEvent.mouseOver(innerTrigger);
|
|
1515
|
+
|
|
1516
|
+
await flushMicrotasks();
|
|
1517
|
+
|
|
1518
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
1519
|
+
|
|
1520
|
+
fireEvent.mouseOut(innerTrigger, { relatedTarget: outerArea });
|
|
1521
|
+
fireEvent.mouseOver(outerArea);
|
|
1522
|
+
|
|
1523
|
+
await flushMicrotasks();
|
|
1524
|
+
|
|
1525
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
1526
|
+
});
|
|
1527
|
+
|
|
1528
|
+
it('should reopen the delayed outer tooltip when moving from a nested trigger to the parent area', async () => {
|
|
1529
|
+
const delay = 100;
|
|
1530
|
+
|
|
1531
|
+
await render(
|
|
1532
|
+
<Tooltip.Provider delay={delay}>
|
|
1533
|
+
<Tooltip.Root>
|
|
1534
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />}>
|
|
1535
|
+
<span data-testid="outer-area">Outer</span>
|
|
1536
|
+
<Tooltip.Root>
|
|
1537
|
+
<Tooltip.Trigger data-testid="inner-trigger" delay={delay * 10}>
|
|
1538
|
+
Inner
|
|
1539
|
+
</Tooltip.Trigger>
|
|
1540
|
+
<Tooltip.Portal>
|
|
1541
|
+
<Tooltip.Positioner>
|
|
1542
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
1543
|
+
</Tooltip.Positioner>
|
|
1544
|
+
</Tooltip.Portal>
|
|
1545
|
+
</Tooltip.Root>
|
|
1546
|
+
</Tooltip.Trigger>
|
|
1547
|
+
<Tooltip.Portal>
|
|
1548
|
+
<Tooltip.Positioner>
|
|
1549
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
1550
|
+
</Tooltip.Positioner>
|
|
1551
|
+
</Tooltip.Portal>
|
|
1552
|
+
</Tooltip.Root>
|
|
1553
|
+
</Tooltip.Provider>,
|
|
1554
|
+
);
|
|
1555
|
+
|
|
1556
|
+
const outerTrigger = screen.getByTestId('outer-trigger');
|
|
1557
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
1558
|
+
const outerArea = screen.getByTestId('outer-area');
|
|
1559
|
+
|
|
1560
|
+
fireEvent.pointerEnter(outerTrigger, { pointerType: 'mouse', clientX: 10, clientY: 10 });
|
|
1561
|
+
fireEvent.mouseEnter(outerTrigger);
|
|
1562
|
+
fireEvent.pointerEnter(innerTrigger, { pointerType: 'mouse', clientX: 50, clientY: 10 });
|
|
1563
|
+
fireEvent.mouseEnter(innerTrigger);
|
|
1564
|
+
fireEvent.mouseOver(innerTrigger);
|
|
1565
|
+
fireEvent.mouseMove(innerTrigger, { clientX: 50, clientY: 10 });
|
|
1566
|
+
|
|
1567
|
+
clock.tick(delay);
|
|
1568
|
+
await flushMicrotasks();
|
|
1569
|
+
|
|
1570
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
1571
|
+
|
|
1572
|
+
fireEvent.mouseOut(innerTrigger, { relatedTarget: outerArea });
|
|
1573
|
+
fireEvent.mouseOver(outerArea);
|
|
1574
|
+
|
|
1575
|
+
clock.tick(delay);
|
|
1576
|
+
await flushMicrotasks();
|
|
1577
|
+
|
|
1578
|
+
expect(screen.getByTestId('outer-popup')).not.toBe(null);
|
|
1579
|
+
});
|
|
1580
|
+
|
|
1581
|
+
it('should support nested triggers inside a detached parent trigger', async () => {
|
|
1582
|
+
const delay = 100;
|
|
1583
|
+
const rowHandle = Tooltip.createHandle<string>();
|
|
1584
|
+
|
|
1585
|
+
await render(
|
|
1586
|
+
<Tooltip.Provider delay={delay}>
|
|
1587
|
+
<Tooltip.Trigger
|
|
1588
|
+
handle={rowHandle}
|
|
1589
|
+
payload="Row"
|
|
1590
|
+
data-testid="outer-trigger"
|
|
1591
|
+
render={<div />}
|
|
1592
|
+
>
|
|
1593
|
+
<span data-testid="outer-area">Row</span>
|
|
1594
|
+
<Tooltip.Root>
|
|
1595
|
+
<Tooltip.Trigger data-testid="inner-trigger" delay={0}>
|
|
1596
|
+
Inner
|
|
1597
|
+
</Tooltip.Trigger>
|
|
1598
|
+
<Tooltip.Portal>
|
|
1599
|
+
<Tooltip.Positioner>
|
|
1600
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
1601
|
+
</Tooltip.Positioner>
|
|
1602
|
+
</Tooltip.Portal>
|
|
1603
|
+
</Tooltip.Root>
|
|
1604
|
+
</Tooltip.Trigger>
|
|
1605
|
+
|
|
1606
|
+
<Tooltip.Root handle={rowHandle}>
|
|
1607
|
+
{({ payload }) => (
|
|
1608
|
+
<Tooltip.Portal>
|
|
1609
|
+
<Tooltip.Positioner>
|
|
1610
|
+
<Tooltip.Popup data-testid="outer-popup">{payload} tooltip</Tooltip.Popup>
|
|
1611
|
+
</Tooltip.Positioner>
|
|
1612
|
+
</Tooltip.Portal>
|
|
1613
|
+
)}
|
|
1614
|
+
</Tooltip.Root>
|
|
1615
|
+
</Tooltip.Provider>,
|
|
1616
|
+
);
|
|
1617
|
+
|
|
1618
|
+
const outerTrigger = screen.getByTestId('outer-trigger');
|
|
1619
|
+
const outerArea = screen.getByTestId('outer-area');
|
|
1620
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
1621
|
+
|
|
1622
|
+
fireEvent.pointerEnter(outerTrigger, { pointerType: 'mouse', clientX: 10, clientY: 10 });
|
|
1623
|
+
fireEvent.mouseEnter(outerTrigger);
|
|
1624
|
+
fireEvent.pointerEnter(innerTrigger, { pointerType: 'mouse', clientX: 50, clientY: 10 });
|
|
1625
|
+
fireEvent.mouseEnter(innerTrigger);
|
|
1626
|
+
fireEvent.mouseOver(innerTrigger);
|
|
1627
|
+
fireEvent.mouseMove(innerTrigger, { clientX: 50, clientY: 10 });
|
|
1628
|
+
|
|
1629
|
+
clock.tick(delay);
|
|
1630
|
+
await flushMicrotasks();
|
|
1631
|
+
|
|
1632
|
+
expect(screen.getByTestId('inner-popup')).not.toBe(null);
|
|
1633
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
1634
|
+
|
|
1635
|
+
fireEvent.mouseOut(innerTrigger, { relatedTarget: outerArea });
|
|
1636
|
+
fireEvent.mouseOver(outerArea);
|
|
1637
|
+
|
|
1638
|
+
clock.tick(delay);
|
|
1639
|
+
await flushMicrotasks();
|
|
1640
|
+
|
|
1641
|
+
expect(screen.getByTestId('outer-popup')).toHaveTextContent('Row tooltip');
|
|
1642
|
+
});
|
|
1643
|
+
|
|
1644
|
+
it('should not reopen the outer tooltip when rapidly moving back to a nested trigger', async () => {
|
|
1645
|
+
const delay = 100;
|
|
1646
|
+
|
|
1647
|
+
await render(
|
|
1648
|
+
<Tooltip.Root>
|
|
1649
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />} delay={delay}>
|
|
1650
|
+
<span data-testid="outer-area">Outer</span>
|
|
1651
|
+
<Tooltip.Root>
|
|
1652
|
+
<Tooltip.Trigger data-testid="inner-trigger">Inner</Tooltip.Trigger>
|
|
1653
|
+
<Tooltip.Portal>
|
|
1654
|
+
<Tooltip.Positioner>
|
|
1655
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
1656
|
+
</Tooltip.Positioner>
|
|
1657
|
+
</Tooltip.Portal>
|
|
1658
|
+
</Tooltip.Root>
|
|
1659
|
+
</Tooltip.Trigger>
|
|
1660
|
+
<Tooltip.Portal>
|
|
1661
|
+
<Tooltip.Positioner>
|
|
1662
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
1663
|
+
</Tooltip.Positioner>
|
|
1664
|
+
</Tooltip.Portal>
|
|
1665
|
+
</Tooltip.Root>,
|
|
1666
|
+
);
|
|
1667
|
+
|
|
1668
|
+
const outerTrigger = screen.getByTestId('outer-trigger');
|
|
1669
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
1670
|
+
const outerArea = screen.getByTestId('outer-area');
|
|
1671
|
+
|
|
1672
|
+
fireEvent.pointerEnter(outerTrigger, { pointerType: 'mouse', clientX: 10, clientY: 10 });
|
|
1673
|
+
fireEvent.mouseEnter(outerTrigger);
|
|
1674
|
+
fireEvent.pointerEnter(innerTrigger, { pointerType: 'mouse', clientX: 50, clientY: 10 });
|
|
1675
|
+
fireEvent.mouseEnter(innerTrigger);
|
|
1676
|
+
fireEvent.mouseOver(innerTrigger);
|
|
1677
|
+
fireEvent.mouseMove(innerTrigger, { clientX: 50, clientY: 10 });
|
|
1678
|
+
|
|
1679
|
+
clock.tick(delay);
|
|
1680
|
+
await flushMicrotasks();
|
|
1681
|
+
|
|
1682
|
+
fireEvent.mouseOut(innerTrigger, { relatedTarget: outerArea });
|
|
1683
|
+
fireEvent.mouseOver(outerArea);
|
|
1684
|
+
|
|
1685
|
+
clock.tick(delay / 2);
|
|
1686
|
+
|
|
1687
|
+
fireEvent.mouseOut(outerArea, { relatedTarget: innerTrigger });
|
|
1688
|
+
fireEvent.mouseOver(innerTrigger);
|
|
1689
|
+
|
|
1690
|
+
clock.tick(delay / 2);
|
|
1691
|
+
await flushMicrotasks();
|
|
1692
|
+
|
|
1693
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
1694
|
+
});
|
|
1695
|
+
|
|
1696
|
+
it('should not reopen the outer tooltip when hovering the nested tooltip popup', async () => {
|
|
1697
|
+
const delay = 100;
|
|
1698
|
+
|
|
1699
|
+
await render(
|
|
1700
|
+
<Tooltip.Root>
|
|
1701
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />} delay={delay}>
|
|
1702
|
+
<span data-testid="outer-area">Outer</span>
|
|
1703
|
+
<Tooltip.Root>
|
|
1704
|
+
<Tooltip.Trigger data-testid="inner-trigger" delay={0}>
|
|
1705
|
+
Inner
|
|
1706
|
+
</Tooltip.Trigger>
|
|
1707
|
+
<Tooltip.Portal>
|
|
1708
|
+
<Tooltip.Positioner>
|
|
1709
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
1710
|
+
</Tooltip.Positioner>
|
|
1711
|
+
</Tooltip.Portal>
|
|
1712
|
+
</Tooltip.Root>
|
|
1713
|
+
</Tooltip.Trigger>
|
|
1714
|
+
<Tooltip.Portal>
|
|
1715
|
+
<Tooltip.Positioner>
|
|
1716
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
1717
|
+
</Tooltip.Positioner>
|
|
1718
|
+
</Tooltip.Portal>
|
|
1719
|
+
</Tooltip.Root>,
|
|
1720
|
+
);
|
|
1721
|
+
|
|
1722
|
+
const outerTrigger = screen.getByTestId('outer-trigger');
|
|
1723
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
1724
|
+
|
|
1725
|
+
fireEvent.pointerEnter(outerTrigger, { pointerType: 'mouse', clientX: 10, clientY: 10 });
|
|
1726
|
+
fireEvent.mouseEnter(outerTrigger);
|
|
1727
|
+
fireEvent.pointerEnter(innerTrigger, { pointerType: 'mouse', clientX: 50, clientY: 10 });
|
|
1728
|
+
fireEvent.mouseEnter(innerTrigger);
|
|
1729
|
+
fireEvent.mouseOver(innerTrigger);
|
|
1730
|
+
fireEvent.mouseMove(innerTrigger, { clientX: 50, clientY: 10 });
|
|
1731
|
+
|
|
1732
|
+
clock.tick(delay);
|
|
1733
|
+
await flushMicrotasks();
|
|
1734
|
+
|
|
1735
|
+
const innerPopup = screen.getByTestId('inner-popup');
|
|
1736
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
1737
|
+
|
|
1738
|
+
fireEvent.mouseOver(innerPopup);
|
|
1739
|
+
|
|
1740
|
+
clock.tick(delay);
|
|
1741
|
+
await flushMicrotasks();
|
|
1742
|
+
|
|
1743
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
1744
|
+
});
|
|
1745
|
+
|
|
1746
|
+
it('should cancel the pending parent reopen when the pointer leaves the parent trigger', async () => {
|
|
1747
|
+
const delay = 100;
|
|
1748
|
+
|
|
1749
|
+
await render(
|
|
1750
|
+
<Tooltip.Root>
|
|
1751
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />} delay={delay}>
|
|
1752
|
+
<span data-testid="outer-area">Outer</span>
|
|
1753
|
+
<Tooltip.Root>
|
|
1754
|
+
<Tooltip.Trigger data-testid="inner-trigger">Inner</Tooltip.Trigger>
|
|
1755
|
+
<Tooltip.Portal>
|
|
1756
|
+
<Tooltip.Positioner>
|
|
1757
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
1758
|
+
</Tooltip.Positioner>
|
|
1759
|
+
</Tooltip.Portal>
|
|
1760
|
+
</Tooltip.Root>
|
|
1761
|
+
</Tooltip.Trigger>
|
|
1762
|
+
<Tooltip.Portal>
|
|
1763
|
+
<Tooltip.Positioner>
|
|
1764
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
1765
|
+
</Tooltip.Positioner>
|
|
1766
|
+
</Tooltip.Portal>
|
|
1767
|
+
</Tooltip.Root>,
|
|
1768
|
+
);
|
|
1769
|
+
|
|
1770
|
+
const outerTrigger = screen.getByTestId('outer-trigger');
|
|
1771
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
1772
|
+
const outerArea = screen.getByTestId('outer-area');
|
|
1773
|
+
|
|
1774
|
+
fireEvent.pointerEnter(outerTrigger, { pointerType: 'mouse', clientX: 10, clientY: 10 });
|
|
1775
|
+
fireEvent.mouseEnter(outerTrigger);
|
|
1776
|
+
fireEvent.pointerEnter(innerTrigger, { pointerType: 'mouse', clientX: 50, clientY: 10 });
|
|
1777
|
+
fireEvent.mouseEnter(innerTrigger);
|
|
1778
|
+
fireEvent.mouseOver(innerTrigger);
|
|
1779
|
+
fireEvent.mouseMove(innerTrigger, { clientX: 50, clientY: 10 });
|
|
1780
|
+
|
|
1781
|
+
clock.tick(delay);
|
|
1782
|
+
await flushMicrotasks();
|
|
1783
|
+
|
|
1784
|
+
fireEvent.mouseOut(innerTrigger, { relatedTarget: outerArea });
|
|
1785
|
+
fireEvent.mouseOver(outerArea);
|
|
1786
|
+
|
|
1787
|
+
clock.tick(delay / 2);
|
|
1788
|
+
|
|
1789
|
+
fireEvent.mouseLeave(outerTrigger, { relatedTarget: document.body });
|
|
1790
|
+
|
|
1791
|
+
clock.tick(delay);
|
|
1792
|
+
await flushMicrotasks();
|
|
1793
|
+
|
|
1794
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
1795
|
+
});
|
|
1796
|
+
|
|
1797
|
+
it('should not open the outer tooltip when the pointer moves onto a nested trigger before the delay expires', async () => {
|
|
1798
|
+
await render(
|
|
1799
|
+
<Tooltip.Root>
|
|
1800
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />}>
|
|
1801
|
+
<span data-testid="outer-area">Outer</span>
|
|
1802
|
+
<Tooltip.Root>
|
|
1803
|
+
<Tooltip.Trigger data-testid="inner-trigger">Inner</Tooltip.Trigger>
|
|
1804
|
+
<Tooltip.Portal>
|
|
1805
|
+
<Tooltip.Positioner>
|
|
1806
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
1807
|
+
</Tooltip.Positioner>
|
|
1808
|
+
</Tooltip.Portal>
|
|
1809
|
+
</Tooltip.Root>
|
|
1810
|
+
</Tooltip.Trigger>
|
|
1811
|
+
<Tooltip.Portal>
|
|
1812
|
+
<Tooltip.Positioner>
|
|
1813
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
1814
|
+
</Tooltip.Positioner>
|
|
1815
|
+
</Tooltip.Portal>
|
|
1816
|
+
</Tooltip.Root>,
|
|
1817
|
+
);
|
|
1818
|
+
|
|
1819
|
+
const outerTrigger = screen.getByTestId('outer-trigger');
|
|
1820
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
1821
|
+
|
|
1822
|
+
fireEvent.pointerDown(outerTrigger, { pointerType: 'mouse' });
|
|
1823
|
+
fireEvent.pointerEnter(outerTrigger, { clientX: 10, clientY: 10 });
|
|
1824
|
+
fireEvent.mouseEnter(outerTrigger);
|
|
1825
|
+
fireEvent.mouseMove(outerTrigger, { clientX: 10, clientY: 10 });
|
|
1826
|
+
|
|
1827
|
+
clock.tick(OPEN_DELAY / 2);
|
|
1828
|
+
|
|
1829
|
+
fireEvent.pointerEnter(innerTrigger, { clientX: 50, clientY: 10 });
|
|
1830
|
+
fireEvent.pointerMove(innerTrigger, { clientX: 50, clientY: 10 });
|
|
1831
|
+
fireEvent.mouseOver(innerTrigger);
|
|
1832
|
+
fireEvent.mouseEnter(innerTrigger);
|
|
1833
|
+
fireEvent.mouseMove(innerTrigger, { clientX: 50, clientY: 10 });
|
|
1834
|
+
|
|
1835
|
+
clock.tick(OPEN_DELAY);
|
|
1836
|
+
await flushMicrotasks();
|
|
1837
|
+
|
|
1838
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
1839
|
+
});
|
|
1840
|
+
|
|
1841
|
+
it('should restart the parent delay when moving from a nested trigger to the parent area', async () => {
|
|
1842
|
+
const delay = 100;
|
|
1843
|
+
|
|
1844
|
+
await render(
|
|
1845
|
+
<Tooltip.Root>
|
|
1846
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />} delay={delay}>
|
|
1847
|
+
<span data-testid="outer-area">Outer</span>
|
|
1848
|
+
<Tooltip.Root>
|
|
1849
|
+
<Tooltip.Trigger data-testid="inner-trigger" delay={delay * 10}>
|
|
1850
|
+
Inner
|
|
1851
|
+
</Tooltip.Trigger>
|
|
1852
|
+
<Tooltip.Portal>
|
|
1853
|
+
<Tooltip.Positioner>
|
|
1854
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
1855
|
+
</Tooltip.Positioner>
|
|
1856
|
+
</Tooltip.Portal>
|
|
1857
|
+
</Tooltip.Root>
|
|
1858
|
+
</Tooltip.Trigger>
|
|
1859
|
+
<Tooltip.Portal>
|
|
1860
|
+
<Tooltip.Positioner>
|
|
1861
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
1862
|
+
</Tooltip.Positioner>
|
|
1863
|
+
</Tooltip.Portal>
|
|
1864
|
+
</Tooltip.Root>,
|
|
1865
|
+
);
|
|
1866
|
+
|
|
1867
|
+
const outerTrigger = screen.getByTestId('outer-trigger');
|
|
1868
|
+
const outerArea = screen.getByTestId('outer-area');
|
|
1869
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
1870
|
+
|
|
1871
|
+
fireEvent.pointerEnter(outerTrigger, { pointerType: 'mouse', clientX: 10, clientY: 10 });
|
|
1872
|
+
fireEvent.mouseEnter(outerTrigger);
|
|
1873
|
+
fireEvent.mouseMove(outerTrigger, { clientX: 10, clientY: 10 });
|
|
1874
|
+
|
|
1875
|
+
clock.tick(delay / 2);
|
|
1876
|
+
|
|
1877
|
+
fireEvent.pointerEnter(innerTrigger, { pointerType: 'mouse', clientX: 50, clientY: 10 });
|
|
1878
|
+
fireEvent.mouseEnter(innerTrigger);
|
|
1879
|
+
fireEvent.mouseOver(innerTrigger);
|
|
1880
|
+
|
|
1881
|
+
await flushMicrotasks();
|
|
1882
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
1883
|
+
|
|
1884
|
+
fireEvent.mouseOut(innerTrigger, { relatedTarget: outerArea });
|
|
1885
|
+
fireEvent.mouseOver(outerArea);
|
|
1886
|
+
|
|
1887
|
+
clock.tick(delay / 2);
|
|
1888
|
+
await flushMicrotasks();
|
|
1889
|
+
|
|
1890
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
1891
|
+
|
|
1892
|
+
clock.tick(delay / 2);
|
|
1893
|
+
await flushMicrotasks();
|
|
1894
|
+
|
|
1895
|
+
expect(screen.getByTestId('outer-popup')).not.toBe(null);
|
|
1896
|
+
});
|
|
1897
|
+
|
|
1898
|
+
it('should close the outer tooltip when the pointer moves from outer area onto a nested trigger', async () => {
|
|
1899
|
+
await render(
|
|
1900
|
+
<Tooltip.Root>
|
|
1901
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />}>
|
|
1902
|
+
<span data-testid="outer-area">Outer</span>
|
|
1903
|
+
<Tooltip.Root>
|
|
1904
|
+
<Tooltip.Trigger data-testid="inner-trigger">Inner</Tooltip.Trigger>
|
|
1905
|
+
<Tooltip.Portal>
|
|
1906
|
+
<Tooltip.Positioner>
|
|
1907
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
1908
|
+
</Tooltip.Positioner>
|
|
1909
|
+
</Tooltip.Portal>
|
|
1910
|
+
</Tooltip.Root>
|
|
1911
|
+
</Tooltip.Trigger>
|
|
1912
|
+
<Tooltip.Portal>
|
|
1913
|
+
<Tooltip.Positioner>
|
|
1914
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
1915
|
+
</Tooltip.Positioner>
|
|
1916
|
+
</Tooltip.Portal>
|
|
1917
|
+
</Tooltip.Root>,
|
|
1918
|
+
);
|
|
1919
|
+
|
|
1920
|
+
const outerTrigger = screen.getByTestId('outer-trigger');
|
|
1921
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
1922
|
+
|
|
1923
|
+
// First open the outer tooltip by hovering the outer area
|
|
1924
|
+
fireEvent.pointerDown(outerTrigger, { pointerType: 'mouse' });
|
|
1925
|
+
fireEvent.pointerEnter(outerTrigger, { clientX: 10, clientY: 10 });
|
|
1926
|
+
fireEvent.mouseEnter(outerTrigger);
|
|
1927
|
+
fireEvent.mouseMove(outerTrigger, { clientX: 10, clientY: 10 });
|
|
1928
|
+
|
|
1929
|
+
clock.tick(OPEN_DELAY);
|
|
1930
|
+
await flushMicrotasks();
|
|
1931
|
+
|
|
1932
|
+
expect(screen.getByTestId('outer-popup')).not.toBe(null);
|
|
1933
|
+
|
|
1934
|
+
// Now move onto the inner trigger — mouseover bubbles to the outer trigger,
|
|
1935
|
+
// which detects the nested trigger and closes itself.
|
|
1936
|
+
fireEvent.pointerEnter(innerTrigger, { clientX: 50, clientY: 10 });
|
|
1937
|
+
fireEvent.mouseEnter(innerTrigger);
|
|
1938
|
+
fireEvent.mouseOver(innerTrigger);
|
|
1939
|
+
|
|
1940
|
+
await flushMicrotasks();
|
|
1941
|
+
|
|
1942
|
+
// The outer tooltip should close
|
|
1943
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
1944
|
+
});
|
|
1945
|
+
|
|
1946
|
+
it('should keep a focus-opened outer tooltip open when hovering over a nested trigger', async () => {
|
|
1947
|
+
await render(
|
|
1948
|
+
<Tooltip.Root>
|
|
1949
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span tabIndex={0} />}>
|
|
1950
|
+
<span>Outer</span>
|
|
1951
|
+
<Tooltip.Root>
|
|
1952
|
+
<Tooltip.Trigger data-testid="inner-trigger" delay={OPEN_DELAY * 10}>
|
|
1953
|
+
Inner
|
|
1954
|
+
</Tooltip.Trigger>
|
|
1955
|
+
<Tooltip.Portal>
|
|
1956
|
+
<Tooltip.Positioner>
|
|
1957
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
1958
|
+
</Tooltip.Positioner>
|
|
1959
|
+
</Tooltip.Portal>
|
|
1960
|
+
</Tooltip.Root>
|
|
1961
|
+
</Tooltip.Trigger>
|
|
1962
|
+
<Tooltip.Portal>
|
|
1963
|
+
<Tooltip.Positioner>
|
|
1964
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
1965
|
+
</Tooltip.Positioner>
|
|
1966
|
+
</Tooltip.Portal>
|
|
1967
|
+
</Tooltip.Root>,
|
|
1968
|
+
);
|
|
1969
|
+
|
|
1970
|
+
const outerTrigger = screen.getByTestId('outer-trigger');
|
|
1971
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
1972
|
+
|
|
1973
|
+
await act(async () => {
|
|
1974
|
+
outerTrigger.focus();
|
|
1975
|
+
});
|
|
1976
|
+
await flushMicrotasks();
|
|
1977
|
+
|
|
1978
|
+
expect(screen.getByTestId('outer-popup')).not.toBe(null);
|
|
1979
|
+
|
|
1980
|
+
fireEvent.pointerEnter(innerTrigger, { pointerType: 'mouse', clientX: 50, clientY: 10 });
|
|
1981
|
+
fireEvent.mouseEnter(innerTrigger);
|
|
1982
|
+
fireEvent.mouseOver(innerTrigger);
|
|
1983
|
+
fireEvent.mouseMove(innerTrigger, { clientX: 50, clientY: 10 });
|
|
1984
|
+
|
|
1985
|
+
clock.tick(OPEN_DELAY);
|
|
1986
|
+
await flushMicrotasks();
|
|
1987
|
+
|
|
1988
|
+
expect(screen.getByTestId('outer-popup')).not.toBe(null);
|
|
1989
|
+
});
|
|
1990
|
+
|
|
1991
|
+
it('should keep a controlled-open outer tooltip open when hovering over a nested trigger', async () => {
|
|
1992
|
+
const onOpenChange = vi.fn();
|
|
1993
|
+
|
|
1994
|
+
await render(
|
|
1995
|
+
<Tooltip.Root open onOpenChange={onOpenChange}>
|
|
1996
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />}>
|
|
1997
|
+
<span>Outer</span>
|
|
1998
|
+
<Tooltip.Root>
|
|
1999
|
+
<Tooltip.Trigger data-testid="inner-trigger" delay={OPEN_DELAY * 10}>
|
|
2000
|
+
Inner
|
|
2001
|
+
</Tooltip.Trigger>
|
|
2002
|
+
<Tooltip.Portal>
|
|
2003
|
+
<Tooltip.Positioner>
|
|
2004
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
2005
|
+
</Tooltip.Positioner>
|
|
2006
|
+
</Tooltip.Portal>
|
|
2007
|
+
</Tooltip.Root>
|
|
2008
|
+
</Tooltip.Trigger>
|
|
2009
|
+
<Tooltip.Portal>
|
|
2010
|
+
<Tooltip.Positioner>
|
|
2011
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
2012
|
+
</Tooltip.Positioner>
|
|
2013
|
+
</Tooltip.Portal>
|
|
2014
|
+
</Tooltip.Root>,
|
|
2015
|
+
);
|
|
2016
|
+
|
|
2017
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
2018
|
+
|
|
2019
|
+
expect(screen.getByTestId('outer-popup')).not.toBe(null);
|
|
2020
|
+
|
|
2021
|
+
fireEvent.pointerEnter(innerTrigger, { pointerType: 'mouse', clientX: 50, clientY: 10 });
|
|
2022
|
+
fireEvent.mouseEnter(innerTrigger);
|
|
2023
|
+
fireEvent.mouseOver(innerTrigger);
|
|
2024
|
+
fireEvent.mouseMove(innerTrigger, { clientX: 50, clientY: 10 });
|
|
2025
|
+
|
|
2026
|
+
clock.tick(OPEN_DELAY);
|
|
2027
|
+
await flushMicrotasks();
|
|
2028
|
+
|
|
2029
|
+
expect(screen.getByTestId('outer-popup')).not.toBe(null);
|
|
2030
|
+
expect(onOpenChange).not.toHaveBeenCalled();
|
|
2031
|
+
});
|
|
2032
|
+
|
|
2033
|
+
it('should not open the outer tooltip when focusing a nested tooltip trigger', async () => {
|
|
2034
|
+
await render(
|
|
2035
|
+
<Tooltip.Provider delay={0}>
|
|
2036
|
+
<Tooltip.Root>
|
|
2037
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<div />}>
|
|
2038
|
+
row label
|
|
2039
|
+
<Tooltip.Root>
|
|
2040
|
+
<Tooltip.Trigger data-testid="inner-trigger">button with tooltip</Tooltip.Trigger>
|
|
2041
|
+
<Tooltip.Portal>
|
|
2042
|
+
<Tooltip.Positioner>
|
|
2043
|
+
<Tooltip.Popup data-testid="inner-popup">inner popup</Tooltip.Popup>
|
|
2044
|
+
</Tooltip.Positioner>
|
|
2045
|
+
</Tooltip.Portal>
|
|
2046
|
+
</Tooltip.Root>
|
|
2047
|
+
</Tooltip.Trigger>
|
|
2048
|
+
<Tooltip.Portal>
|
|
2049
|
+
<Tooltip.Positioner>
|
|
2050
|
+
<Tooltip.Popup data-testid="outer-popup">outer popup</Tooltip.Popup>
|
|
2051
|
+
</Tooltip.Positioner>
|
|
2052
|
+
</Tooltip.Portal>
|
|
2053
|
+
</Tooltip.Root>
|
|
2054
|
+
</Tooltip.Provider>,
|
|
2055
|
+
);
|
|
2056
|
+
|
|
2057
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
2058
|
+
|
|
2059
|
+
await act(async () => {
|
|
2060
|
+
innerTrigger.focus();
|
|
2061
|
+
});
|
|
2062
|
+
await flushMicrotasks();
|
|
2063
|
+
|
|
2064
|
+
expect(screen.getByTestId('inner-popup')).not.toBe(null);
|
|
2065
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
2066
|
+
});
|
|
2067
|
+
|
|
2068
|
+
it('should close a focus-opened inner tooltip when the inner trigger loses focus', async () => {
|
|
2069
|
+
await render(
|
|
2070
|
+
<Tooltip.Provider delay={0}>
|
|
2071
|
+
<Tooltip.Root open={false}>
|
|
2072
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<div />}>
|
|
2073
|
+
row label
|
|
2074
|
+
<Tooltip.Root>
|
|
2075
|
+
<Tooltip.Trigger data-testid="inner-trigger">button with tooltip</Tooltip.Trigger>
|
|
2076
|
+
<Tooltip.Portal>
|
|
2077
|
+
<Tooltip.Positioner>
|
|
2078
|
+
<Tooltip.Popup data-testid="inner-popup">inner popup</Tooltip.Popup>
|
|
2079
|
+
</Tooltip.Positioner>
|
|
2080
|
+
</Tooltip.Portal>
|
|
2081
|
+
</Tooltip.Root>
|
|
2082
|
+
<button data-testid="after">button</button>
|
|
2083
|
+
</Tooltip.Trigger>
|
|
2084
|
+
<Tooltip.Portal>
|
|
2085
|
+
<Tooltip.Positioner>
|
|
2086
|
+
<Tooltip.Popup data-testid="outer-popup">outer popup</Tooltip.Popup>
|
|
2087
|
+
</Tooltip.Positioner>
|
|
2088
|
+
</Tooltip.Portal>
|
|
2089
|
+
</Tooltip.Root>
|
|
2090
|
+
</Tooltip.Provider>,
|
|
2091
|
+
);
|
|
2092
|
+
|
|
2093
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
2094
|
+
const after = screen.getByTestId('after');
|
|
2095
|
+
|
|
2096
|
+
await act(async () => {
|
|
2097
|
+
innerTrigger.focus();
|
|
2098
|
+
});
|
|
2099
|
+
await flushMicrotasks();
|
|
2100
|
+
|
|
2101
|
+
expect(screen.getByTestId('inner-popup')).not.toBe(null);
|
|
2102
|
+
|
|
2103
|
+
await act(async () => {
|
|
2104
|
+
after.focus();
|
|
2105
|
+
});
|
|
2106
|
+
clock.tick(OPEN_DELAY);
|
|
2107
|
+
await flushMicrotasks();
|
|
2108
|
+
|
|
2109
|
+
expect(screen.queryByTestId('inner-popup')).toBe(null);
|
|
2110
|
+
});
|
|
2111
|
+
|
|
2112
|
+
it('should allow the parent tooltip to open when a nested trigger is disabled', async () => {
|
|
2113
|
+
await render(
|
|
2114
|
+
<Tooltip.Root>
|
|
2115
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />}>
|
|
2116
|
+
Outer
|
|
2117
|
+
<Tooltip.Root>
|
|
2118
|
+
<Tooltip.Trigger data-testid="inner-trigger" disabled>
|
|
2119
|
+
Inner (disabled)
|
|
2120
|
+
</Tooltip.Trigger>
|
|
2121
|
+
<Tooltip.Portal>
|
|
2122
|
+
<Tooltip.Positioner>
|
|
2123
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
2124
|
+
</Tooltip.Positioner>
|
|
2125
|
+
</Tooltip.Portal>
|
|
2126
|
+
</Tooltip.Root>
|
|
2127
|
+
</Tooltip.Trigger>
|
|
2128
|
+
<Tooltip.Portal>
|
|
2129
|
+
<Tooltip.Positioner>
|
|
2130
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
2131
|
+
</Tooltip.Positioner>
|
|
2132
|
+
</Tooltip.Portal>
|
|
2133
|
+
</Tooltip.Root>,
|
|
2134
|
+
);
|
|
2135
|
+
|
|
2136
|
+
const outerTrigger = screen.getByTestId('outer-trigger');
|
|
2137
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
2138
|
+
|
|
2139
|
+
fireEvent.pointerDown(outerTrigger, { pointerType: 'mouse' });
|
|
2140
|
+
fireEvent.pointerEnter(outerTrigger, { clientX: 10, clientY: 10 });
|
|
2141
|
+
fireEvent.mouseEnter(outerTrigger);
|
|
2142
|
+
fireEvent.pointerEnter(innerTrigger, { pointerType: 'mouse', clientX: 50, clientY: 10 });
|
|
2143
|
+
fireEvent.mouseEnter(innerTrigger);
|
|
2144
|
+
fireEvent.mouseOver(innerTrigger);
|
|
2145
|
+
fireEvent.mouseMove(innerTrigger, { clientX: 50, clientY: 10 });
|
|
2146
|
+
|
|
2147
|
+
clock.tick(OPEN_DELAY);
|
|
2148
|
+
await flushMicrotasks();
|
|
2149
|
+
|
|
2150
|
+
// The outer tooltip should open since the nested trigger is disabled
|
|
2151
|
+
expect(screen.getByTestId('outer-popup')).not.toBe(null);
|
|
2152
|
+
expect(screen.queryByTestId('inner-popup')).toBe(null);
|
|
2153
|
+
});
|
|
2154
|
+
|
|
2155
|
+
it('should not open the outer tooltip when hovering over a nested trigger inside a shadow root', async () => {
|
|
2156
|
+
const host = document.body.appendChild(document.createElement('div'));
|
|
2157
|
+
const shadowRoot = host.attachShadow({ mode: 'open' });
|
|
2158
|
+
const container = document.createElement('div');
|
|
2159
|
+
shadowRoot.appendChild(container);
|
|
2160
|
+
|
|
2161
|
+
try {
|
|
2162
|
+
await render(
|
|
2163
|
+
<Tooltip.Root>
|
|
2164
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />}>
|
|
2165
|
+
Outer
|
|
2166
|
+
<Tooltip.Root>
|
|
2167
|
+
<Tooltip.Trigger data-testid="inner-trigger" render={<div />}>
|
|
2168
|
+
Inner
|
|
2169
|
+
</Tooltip.Trigger>
|
|
2170
|
+
<Tooltip.Portal>
|
|
2171
|
+
<Tooltip.Positioner>
|
|
2172
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
2173
|
+
</Tooltip.Positioner>
|
|
2174
|
+
</Tooltip.Portal>
|
|
2175
|
+
</Tooltip.Root>
|
|
2176
|
+
</Tooltip.Trigger>
|
|
2177
|
+
<Tooltip.Portal>
|
|
2178
|
+
<Tooltip.Positioner>
|
|
2179
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
2180
|
+
</Tooltip.Positioner>
|
|
2181
|
+
</Tooltip.Portal>
|
|
2182
|
+
</Tooltip.Root>,
|
|
2183
|
+
{ container },
|
|
2184
|
+
);
|
|
2185
|
+
|
|
2186
|
+
const outerTrigger = shadowRoot.querySelector('[data-testid="outer-trigger"]') as HTMLElement;
|
|
2187
|
+
const innerTrigger = shadowRoot.querySelector('[data-testid="inner-trigger"]') as HTMLElement;
|
|
2188
|
+
const innerShadowRoot = innerTrigger.attachShadow({ mode: 'open' });
|
|
2189
|
+
const innerShadowTarget = document.createElement('span');
|
|
2190
|
+
innerShadowTarget.textContent = 'Inner shadow target';
|
|
2191
|
+
innerShadowRoot.appendChild(innerShadowTarget);
|
|
2192
|
+
|
|
2193
|
+
// Hover the outer trigger first so the outer tooltip starts its open delay.
|
|
2194
|
+
fireEvent.pointerDown(outerTrigger, { pointerType: 'mouse' });
|
|
2195
|
+
fireEvent.pointerEnter(outerTrigger, { clientX: 10, clientY: 10 });
|
|
2196
|
+
fireEvent.mouseEnter(outerTrigger);
|
|
2197
|
+
fireEvent.mouseMove(outerTrigger, { clientX: 10, clientY: 10 });
|
|
2198
|
+
|
|
2199
|
+
// Move onto a target inside the inner trigger's shadow root before the delay expires.
|
|
2200
|
+
// The composed mouseover bubbles to the outer trigger, and the target
|
|
2201
|
+
// traversal walks out of the shadow tree to find the private marker on
|
|
2202
|
+
// the inner trigger, suppressing the outer tooltip.
|
|
2203
|
+
fireEvent.pointerEnter(innerTrigger, { clientX: 50, clientY: 10 });
|
|
2204
|
+
fireEvent.mouseEnter(innerTrigger);
|
|
2205
|
+
innerShadowTarget.dispatchEvent(
|
|
2206
|
+
new MouseEvent('mouseover', {
|
|
2207
|
+
bubbles: true,
|
|
2208
|
+
composed: true,
|
|
2209
|
+
clientX: 50,
|
|
2210
|
+
clientY: 10,
|
|
2211
|
+
}),
|
|
2212
|
+
);
|
|
2213
|
+
fireEvent.mouseMove(innerTrigger, { clientX: 50, clientY: 10 });
|
|
2214
|
+
|
|
2215
|
+
clock.tick(OPEN_DELAY);
|
|
2216
|
+
await flushMicrotasks();
|
|
2217
|
+
|
|
2218
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
2219
|
+
} finally {
|
|
2220
|
+
await act(async () => {
|
|
2221
|
+
host.remove();
|
|
2222
|
+
});
|
|
2223
|
+
}
|
|
2224
|
+
});
|
|
2225
|
+
|
|
2226
|
+
it('should open the outer tooltip when hovering over the non-nested area', async () => {
|
|
2227
|
+
await render(
|
|
2228
|
+
<Tooltip.Root>
|
|
2229
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />}>
|
|
2230
|
+
<span data-testid="outer-area">Outer</span>
|
|
2231
|
+
<Tooltip.Root>
|
|
2232
|
+
<Tooltip.Trigger data-testid="inner-trigger">Inner</Tooltip.Trigger>
|
|
2233
|
+
<Tooltip.Portal>
|
|
2234
|
+
<Tooltip.Positioner>
|
|
2235
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
2236
|
+
</Tooltip.Positioner>
|
|
2237
|
+
</Tooltip.Portal>
|
|
2238
|
+
</Tooltip.Root>
|
|
2239
|
+
</Tooltip.Trigger>
|
|
2240
|
+
<Tooltip.Portal>
|
|
2241
|
+
<Tooltip.Positioner>
|
|
2242
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
2243
|
+
</Tooltip.Positioner>
|
|
2244
|
+
</Tooltip.Portal>
|
|
2245
|
+
</Tooltip.Root>,
|
|
2246
|
+
);
|
|
2247
|
+
|
|
2248
|
+
const outerTrigger = screen.getByTestId('outer-trigger');
|
|
2249
|
+
|
|
2250
|
+
fireEvent.pointerDown(outerTrigger, { pointerType: 'mouse' });
|
|
2251
|
+
fireEvent.pointerEnter(outerTrigger, { clientX: 10, clientY: 10 });
|
|
2252
|
+
fireEvent.mouseEnter(outerTrigger);
|
|
2253
|
+
fireEvent.mouseMove(outerTrigger, { clientX: 10, clientY: 10 });
|
|
2254
|
+
|
|
2255
|
+
clock.tick(OPEN_DELAY);
|
|
2256
|
+
await flushMicrotasks();
|
|
2257
|
+
|
|
2258
|
+
expect(screen.getByTestId('outer-popup')).not.toBe(null);
|
|
2259
|
+
expect(screen.queryByTestId('inner-popup')).toBe(null);
|
|
2260
|
+
});
|
|
2261
|
+
|
|
2262
|
+
it('should not reopen the outer tooltip via the local reopen path for touch pointers', async () => {
|
|
2263
|
+
await render(
|
|
2264
|
+
<Tooltip.Root>
|
|
2265
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />} delay={0}>
|
|
2266
|
+
<span data-testid="outer-area">Outer</span>
|
|
2267
|
+
<Tooltip.Root>
|
|
2268
|
+
<Tooltip.Trigger data-testid="inner-trigger">Inner</Tooltip.Trigger>
|
|
2269
|
+
<Tooltip.Portal>
|
|
2270
|
+
<Tooltip.Positioner>
|
|
2271
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
2272
|
+
</Tooltip.Positioner>
|
|
2273
|
+
</Tooltip.Portal>
|
|
2274
|
+
</Tooltip.Root>
|
|
2275
|
+
</Tooltip.Trigger>
|
|
2276
|
+
<Tooltip.Portal>
|
|
2277
|
+
<Tooltip.Positioner>
|
|
2278
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
2279
|
+
</Tooltip.Positioner>
|
|
2280
|
+
</Tooltip.Portal>
|
|
2281
|
+
</Tooltip.Root>,
|
|
2282
|
+
);
|
|
2283
|
+
|
|
2284
|
+
const outerTrigger = screen.getByTestId('outer-trigger');
|
|
2285
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
2286
|
+
const outerArea = screen.getByTestId('outer-area');
|
|
2287
|
+
|
|
2288
|
+
// A touch interaction sets pointerTypeRef to 'touch'.
|
|
2289
|
+
fireEvent.pointerEnter(outerTrigger, { pointerType: 'touch', clientX: 10, clientY: 10 });
|
|
2290
|
+
fireEvent.pointerEnter(innerTrigger, { pointerType: 'touch', clientX: 50, clientY: 10 });
|
|
2291
|
+
fireEvent.mouseOver(innerTrigger);
|
|
2292
|
+
|
|
2293
|
+
await flushMicrotasks();
|
|
2294
|
+
|
|
2295
|
+
// Move from the inner trigger back to the outer area; the local reopen
|
|
2296
|
+
// path is gated on `isMouseLikePointerType`, so a touch pointer must not
|
|
2297
|
+
// queue or fire a reopen.
|
|
2298
|
+
fireEvent.mouseOut(innerTrigger, { relatedTarget: outerArea });
|
|
2299
|
+
fireEvent.mouseOver(outerArea);
|
|
2300
|
+
|
|
2301
|
+
await flushMicrotasks();
|
|
2302
|
+
|
|
2303
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
2304
|
+
});
|
|
2305
|
+
|
|
2306
|
+
it('should allow mouse hover after leaving a touch interaction', async () => {
|
|
2307
|
+
await render(
|
|
2308
|
+
<Tooltip.Root>
|
|
2309
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />} delay={0}>
|
|
2310
|
+
<span data-testid="outer-area">Outer</span>
|
|
2311
|
+
<Tooltip.Root>
|
|
2312
|
+
<Tooltip.Trigger data-testid="inner-trigger">Inner</Tooltip.Trigger>
|
|
2313
|
+
<Tooltip.Portal>
|
|
2314
|
+
<Tooltip.Positioner>
|
|
2315
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
2316
|
+
</Tooltip.Positioner>
|
|
2317
|
+
</Tooltip.Portal>
|
|
2318
|
+
</Tooltip.Root>
|
|
2319
|
+
</Tooltip.Trigger>
|
|
2320
|
+
<Tooltip.Portal>
|
|
2321
|
+
<Tooltip.Positioner>
|
|
2322
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
2323
|
+
</Tooltip.Positioner>
|
|
2324
|
+
</Tooltip.Portal>
|
|
2325
|
+
</Tooltip.Root>,
|
|
2326
|
+
);
|
|
2327
|
+
|
|
2328
|
+
const outerTrigger = screen.getByTestId('outer-trigger');
|
|
2329
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
2330
|
+
const outerArea = screen.getByTestId('outer-area');
|
|
2331
|
+
|
|
2332
|
+
// Start with a touch interaction, then leave the trigger before the next hover.
|
|
2333
|
+
fireEvent.pointerEnter(outerTrigger, { pointerType: 'touch', clientX: 10, clientY: 10 });
|
|
2334
|
+
fireEvent.mouseLeave(outerTrigger, { relatedTarget: document.body });
|
|
2335
|
+
|
|
2336
|
+
// A later mouse-only hover should not be suppressed by the previous touch input.
|
|
2337
|
+
fireEvent.mouseOver(innerTrigger);
|
|
2338
|
+
fireEvent.mouseOut(innerTrigger, { relatedTarget: outerArea });
|
|
2339
|
+
fireEvent.mouseOver(outerArea);
|
|
2340
|
+
|
|
2341
|
+
await flushMicrotasks();
|
|
2342
|
+
|
|
2343
|
+
expect(screen.getByTestId('outer-popup')).not.toBe(null);
|
|
2344
|
+
});
|
|
2345
|
+
|
|
2346
|
+
it('should not open the outer tooltip when moving from the outer popup to a nested trigger', async () => {
|
|
2347
|
+
await render(
|
|
2348
|
+
<Tooltip.Root>
|
|
2349
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />}>
|
|
2350
|
+
<span data-testid="outer-area">Outer</span>
|
|
2351
|
+
<Tooltip.Root>
|
|
2352
|
+
<Tooltip.Trigger data-testid="inner-trigger" delay={OPEN_DELAY * 10}>
|
|
2353
|
+
Inner
|
|
2354
|
+
</Tooltip.Trigger>
|
|
2355
|
+
<Tooltip.Portal>
|
|
2356
|
+
<Tooltip.Positioner>
|
|
2357
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
2358
|
+
</Tooltip.Positioner>
|
|
2359
|
+
</Tooltip.Portal>
|
|
2360
|
+
</Tooltip.Root>
|
|
2361
|
+
</Tooltip.Trigger>
|
|
2362
|
+
<Tooltip.Portal>
|
|
2363
|
+
<Tooltip.Positioner>
|
|
2364
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
2365
|
+
</Tooltip.Positioner>
|
|
2366
|
+
</Tooltip.Portal>
|
|
2367
|
+
</Tooltip.Root>,
|
|
2368
|
+
);
|
|
2369
|
+
|
|
2370
|
+
const outerTrigger = screen.getByTestId('outer-trigger');
|
|
2371
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
2372
|
+
|
|
2373
|
+
// Open the outer tooltip via hover.
|
|
2374
|
+
fireEvent.pointerDown(outerTrigger, { pointerType: 'mouse' });
|
|
2375
|
+
fireEvent.pointerEnter(outerTrigger, { clientX: 10, clientY: 10 });
|
|
2376
|
+
fireEvent.mouseEnter(outerTrigger);
|
|
2377
|
+
fireEvent.mouseMove(outerTrigger, { clientX: 10, clientY: 10 });
|
|
2378
|
+
|
|
2379
|
+
clock.tick(OPEN_DELAY);
|
|
2380
|
+
await flushMicrotasks();
|
|
2381
|
+
|
|
2382
|
+
const outerPopup = screen.getByTestId('outer-popup');
|
|
2383
|
+
expect(outerPopup).not.toBe(null);
|
|
2384
|
+
|
|
2385
|
+
// Hover the outer popup (it's portaled outside the trigger).
|
|
2386
|
+
fireEvent.pointerEnter(outerPopup, { pointerType: 'mouse', clientX: 200, clientY: 200 });
|
|
2387
|
+
fireEvent.mouseOver(outerPopup);
|
|
2388
|
+
|
|
2389
|
+
await flushMicrotasks();
|
|
2390
|
+
|
|
2391
|
+
// Move back onto the nested trigger. The bubbling mouseover hits the
|
|
2392
|
+
// outer trigger and the close-on-nested-hover branch runs.
|
|
2393
|
+
fireEvent.pointerEnter(innerTrigger, { pointerType: 'mouse', clientX: 50, clientY: 10 });
|
|
2394
|
+
fireEvent.mouseEnter(innerTrigger);
|
|
2395
|
+
fireEvent.mouseOver(innerTrigger);
|
|
2396
|
+
|
|
2397
|
+
await flushMicrotasks();
|
|
2398
|
+
|
|
2399
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
2400
|
+
});
|
|
2401
|
+
|
|
2402
|
+
it('should suppress the safePolygon-driven open while a nested trigger is hovered', async () => {
|
|
2403
|
+
await render(
|
|
2404
|
+
<Tooltip.Root>
|
|
2405
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />}>
|
|
2406
|
+
<span data-testid="outer-area">Outer</span>
|
|
2407
|
+
<Tooltip.Root>
|
|
2408
|
+
<Tooltip.Trigger data-testid="inner-trigger" delay={OPEN_DELAY * 10}>
|
|
2409
|
+
Inner
|
|
2410
|
+
</Tooltip.Trigger>
|
|
2411
|
+
<Tooltip.Portal>
|
|
2412
|
+
<Tooltip.Positioner>
|
|
2413
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
2414
|
+
</Tooltip.Positioner>
|
|
2415
|
+
</Tooltip.Portal>
|
|
2416
|
+
</Tooltip.Root>
|
|
2417
|
+
</Tooltip.Trigger>
|
|
2418
|
+
<Tooltip.Portal>
|
|
2419
|
+
<Tooltip.Positioner>
|
|
2420
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
2421
|
+
</Tooltip.Positioner>
|
|
2422
|
+
</Tooltip.Portal>
|
|
2423
|
+
</Tooltip.Root>,
|
|
2424
|
+
);
|
|
2425
|
+
|
|
2426
|
+
const outerTrigger = screen.getByTestId('outer-trigger');
|
|
2427
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
2428
|
+
|
|
2429
|
+
fireEvent.pointerDown(outerTrigger, { pointerType: 'mouse' });
|
|
2430
|
+
fireEvent.pointerEnter(outerTrigger, { clientX: 10, clientY: 10 });
|
|
2431
|
+
fireEvent.mouseEnter(outerTrigger);
|
|
2432
|
+
fireEvent.mouseMove(outerTrigger, { clientX: 10, clientY: 10 });
|
|
2433
|
+
fireEvent.pointerEnter(innerTrigger, { pointerType: 'mouse', clientX: 50, clientY: 10 });
|
|
2434
|
+
fireEvent.mouseEnter(innerTrigger);
|
|
2435
|
+
fireEvent.mouseOver(innerTrigger);
|
|
2436
|
+
// Repeated mouseMoves keep the safePolygon / mouseover path active, which
|
|
2437
|
+
// calls `setOpen(true)` via `useHoverReferenceInteraction`'s onMouseMove
|
|
2438
|
+
// handler — that path is now gated by `checkShouldOpen()`.
|
|
2439
|
+
fireEvent.mouseMove(innerTrigger, { clientX: 50, clientY: 10 });
|
|
2440
|
+
fireEvent.mouseMove(innerTrigger, { clientX: 51, clientY: 10 });
|
|
2441
|
+
|
|
2442
|
+
clock.tick(OPEN_DELAY);
|
|
2443
|
+
await flushMicrotasks();
|
|
2444
|
+
|
|
2445
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
2446
|
+
});
|
|
2447
|
+
|
|
2448
|
+
it('should support nested triggers with a Provider delay={0}', async () => {
|
|
2449
|
+
await render(
|
|
2450
|
+
<Tooltip.Provider delay={0}>
|
|
2451
|
+
<Tooltip.Root>
|
|
2452
|
+
<Tooltip.Trigger data-testid="outer-trigger" render={<span />}>
|
|
2453
|
+
<span data-testid="outer-area">Outer</span>
|
|
2454
|
+
<Tooltip.Root>
|
|
2455
|
+
<Tooltip.Trigger data-testid="inner-trigger">Inner</Tooltip.Trigger>
|
|
2456
|
+
<Tooltip.Portal>
|
|
2457
|
+
<Tooltip.Positioner>
|
|
2458
|
+
<Tooltip.Popup data-testid="inner-popup">Inner tooltip</Tooltip.Popup>
|
|
2459
|
+
</Tooltip.Positioner>
|
|
2460
|
+
</Tooltip.Portal>
|
|
2461
|
+
</Tooltip.Root>
|
|
2462
|
+
</Tooltip.Trigger>
|
|
2463
|
+
<Tooltip.Portal>
|
|
2464
|
+
<Tooltip.Positioner>
|
|
2465
|
+
<Tooltip.Popup data-testid="outer-popup">Outer tooltip</Tooltip.Popup>
|
|
2466
|
+
</Tooltip.Positioner>
|
|
2467
|
+
</Tooltip.Portal>
|
|
2468
|
+
</Tooltip.Root>
|
|
2469
|
+
</Tooltip.Provider>,
|
|
2470
|
+
);
|
|
2471
|
+
|
|
2472
|
+
const outerTrigger = screen.getByTestId('outer-trigger');
|
|
2473
|
+
const innerTrigger = screen.getByTestId('inner-trigger');
|
|
2474
|
+
const outerArea = screen.getByTestId('outer-area');
|
|
2475
|
+
|
|
2476
|
+
fireEvent.pointerEnter(outerTrigger, { pointerType: 'mouse', clientX: 10, clientY: 10 });
|
|
2477
|
+
fireEvent.mouseEnter(outerTrigger);
|
|
2478
|
+
fireEvent.pointerEnter(innerTrigger, { pointerType: 'mouse', clientX: 50, clientY: 10 });
|
|
2479
|
+
fireEvent.mouseEnter(innerTrigger);
|
|
2480
|
+
fireEvent.mouseOver(innerTrigger);
|
|
2481
|
+
|
|
2482
|
+
await flushMicrotasks();
|
|
2483
|
+
|
|
2484
|
+
expect(screen.queryByTestId('outer-popup')).toBe(null);
|
|
2485
|
+
expect(screen.getByTestId('inner-popup')).not.toBe(null);
|
|
2486
|
+
|
|
2487
|
+
fireEvent.mouseOut(innerTrigger, { relatedTarget: outerArea });
|
|
2488
|
+
fireEvent.mouseOver(outerArea);
|
|
2489
|
+
|
|
2490
|
+
await flushMicrotasks();
|
|
2491
|
+
|
|
2492
|
+
expect(screen.getByTestId('outer-popup')).not.toBe(null);
|
|
2493
|
+
});
|
|
2494
|
+
});
|
|
2495
|
+
|
|
2496
|
+
type TestTooltipProps = {
|
|
2497
|
+
rootProps?: Tooltip.Root.Props;
|
|
2498
|
+
triggerProps?: Tooltip.Trigger.Props;
|
|
2499
|
+
portalProps?: Tooltip.Portal.Props;
|
|
2500
|
+
positionerProps?: Tooltip.Positioner.Props;
|
|
2501
|
+
popupProps?: Tooltip.Popup.Props;
|
|
2502
|
+
portalChildren?: React.ReactNode;
|
|
2503
|
+
beforeTrigger?: React.ReactNode;
|
|
2504
|
+
betweenTriggerAndPortal?: React.ReactNode;
|
|
2505
|
+
afterPortal?: React.ReactNode;
|
|
2506
|
+
};
|
|
2507
|
+
|
|
2508
|
+
function ContainedTriggerTooltip(props: TestTooltipProps) {
|
|
2509
|
+
const {
|
|
2510
|
+
rootProps,
|
|
2511
|
+
triggerProps,
|
|
2512
|
+
portalProps,
|
|
2513
|
+
positionerProps,
|
|
2514
|
+
popupProps,
|
|
2515
|
+
beforeTrigger,
|
|
2516
|
+
betweenTriggerAndPortal,
|
|
2517
|
+
afterPortal,
|
|
2518
|
+
} = props;
|
|
2519
|
+
|
|
2520
|
+
const { children: triggerChildren, ...restTriggerProps } = triggerProps ?? {};
|
|
2521
|
+
const { children: popupChildren, ...restPopupProps } = popupProps ?? {};
|
|
2522
|
+
const { children: portalChildren, ...restPortalProps } = portalProps ?? {};
|
|
2523
|
+
|
|
2524
|
+
const triggerContent = triggerChildren ?? 'Toggle';
|
|
2525
|
+
const popupContent = popupChildren ?? 'Content';
|
|
2526
|
+
|
|
2527
|
+
return (
|
|
2528
|
+
<Tooltip.Root {...rootProps}>
|
|
2529
|
+
{beforeTrigger}
|
|
2530
|
+
<Tooltip.Trigger data-testid="trigger" {...restTriggerProps}>
|
|
2531
|
+
{triggerContent}
|
|
2532
|
+
</Tooltip.Trigger>
|
|
2533
|
+
{betweenTriggerAndPortal}
|
|
2534
|
+
<Tooltip.Portal {...restPortalProps}>
|
|
2535
|
+
{portalChildren}
|
|
2536
|
+
<Tooltip.Positioner data-testid="positioner" {...positionerProps}>
|
|
2537
|
+
<Tooltip.Popup data-testid="popup" {...restPopupProps}>
|
|
2538
|
+
{popupContent}
|
|
2539
|
+
</Tooltip.Popup>
|
|
2540
|
+
</Tooltip.Positioner>
|
|
2541
|
+
</Tooltip.Portal>
|
|
2542
|
+
{afterPortal}
|
|
2543
|
+
</Tooltip.Root>
|
|
2544
|
+
);
|
|
2545
|
+
}
|
|
2546
|
+
|
|
2547
|
+
function DetachedTriggerTooltip(props: TestTooltipProps) {
|
|
2548
|
+
const {
|
|
2549
|
+
rootProps,
|
|
2550
|
+
triggerProps,
|
|
2551
|
+
portalProps,
|
|
2552
|
+
positionerProps,
|
|
2553
|
+
popupProps,
|
|
2554
|
+
beforeTrigger,
|
|
2555
|
+
betweenTriggerAndPortal,
|
|
2556
|
+
afterPortal,
|
|
2557
|
+
} = props;
|
|
2558
|
+
|
|
2559
|
+
const { children: triggerChildren, ...restTriggerProps } = triggerProps ?? {};
|
|
2560
|
+
const { children: popupChildren, ...restPopupProps } = popupProps ?? {};
|
|
2561
|
+
const { children: portalChildren, ...restPortalProps } = portalProps ?? {};
|
|
2562
|
+
|
|
2563
|
+
const triggerContent = triggerChildren ?? 'Toggle';
|
|
2564
|
+
const popupContent = popupChildren ?? 'Content';
|
|
2565
|
+
|
|
2566
|
+
const tooltipHandle = useRefWithInit(() => Tooltip.createHandle()).current;
|
|
2567
|
+
|
|
2568
|
+
return (
|
|
2569
|
+
<React.Fragment>
|
|
2570
|
+
{beforeTrigger}
|
|
2571
|
+
<Tooltip.Trigger data-testid="trigger" handle={tooltipHandle} {...restTriggerProps}>
|
|
2572
|
+
{triggerContent}
|
|
2573
|
+
</Tooltip.Trigger>
|
|
2574
|
+
{betweenTriggerAndPortal}
|
|
2575
|
+
<Tooltip.Root handle={tooltipHandle} {...rootProps}>
|
|
2576
|
+
<Tooltip.Portal {...restPortalProps}>
|
|
2577
|
+
{portalChildren}
|
|
2578
|
+
<Tooltip.Positioner data-testid="positioner" {...positionerProps}>
|
|
2579
|
+
<Tooltip.Popup data-testid="popup" {...restPopupProps}>
|
|
2580
|
+
{popupContent}
|
|
2581
|
+
</Tooltip.Popup>
|
|
2582
|
+
</Tooltip.Positioner>
|
|
2583
|
+
</Tooltip.Portal>
|
|
2584
|
+
{afterPortal}
|
|
2585
|
+
</Tooltip.Root>
|
|
2586
|
+
</React.Fragment>
|
|
2587
|
+
);
|
|
2588
|
+
}
|
|
2589
|
+
|
|
2590
|
+
function MultipleDetachedTriggersTooltip(props: TestTooltipProps) {
|
|
2591
|
+
const {
|
|
2592
|
+
rootProps,
|
|
2593
|
+
triggerProps,
|
|
2594
|
+
portalProps,
|
|
2595
|
+
positionerProps,
|
|
2596
|
+
popupProps,
|
|
2597
|
+
beforeTrigger,
|
|
2598
|
+
betweenTriggerAndPortal,
|
|
2599
|
+
afterPortal,
|
|
2600
|
+
} = props;
|
|
2601
|
+
|
|
2602
|
+
const { children: triggerChildren, ...restTriggerProps } = triggerProps ?? {};
|
|
2603
|
+
const { children: popupChildren, ...restPopupProps } = popupProps ?? {};
|
|
2604
|
+
const { children: portalChildren, ...restPortalProps } = portalProps ?? {};
|
|
2605
|
+
|
|
2606
|
+
const triggerContent = triggerChildren ?? 'Toggle';
|
|
2607
|
+
const popupContent = popupChildren ?? 'Content';
|
|
2608
|
+
|
|
2609
|
+
const tooltipHandle = useRefWithInit(() => Tooltip.createHandle()).current;
|
|
2610
|
+
|
|
2611
|
+
return (
|
|
2612
|
+
<React.Fragment>
|
|
2613
|
+
{beforeTrigger}
|
|
2614
|
+
<Tooltip.Trigger data-testid="trigger" handle={tooltipHandle} {...restTriggerProps}>
|
|
2615
|
+
{triggerContent}
|
|
2616
|
+
</Tooltip.Trigger>
|
|
2617
|
+
<Tooltip.Trigger data-testid="trigger-2" handle={tooltipHandle}>
|
|
2618
|
+
Toggle another
|
|
2619
|
+
</Tooltip.Trigger>
|
|
2620
|
+
{betweenTriggerAndPortal}
|
|
2621
|
+
<Tooltip.Root handle={tooltipHandle} {...rootProps}>
|
|
2622
|
+
<Tooltip.Portal {...restPortalProps}>
|
|
2623
|
+
{portalChildren}
|
|
2624
|
+
<Tooltip.Positioner data-testid="positioner" {...positionerProps}>
|
|
2625
|
+
<Tooltip.Popup data-testid="popup" {...restPopupProps}>
|
|
2626
|
+
{popupContent}
|
|
2627
|
+
</Tooltip.Popup>
|
|
2628
|
+
</Tooltip.Positioner>
|
|
2629
|
+
</Tooltip.Portal>
|
|
2630
|
+
{afterPortal}
|
|
2631
|
+
</Tooltip.Root>
|
|
2632
|
+
</React.Fragment>
|
|
2633
|
+
);
|
|
2634
|
+
}
|