@gv-tech/design-system 2.3.0 → 2.5.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/.agent/skills/dogfood-components/SKILL.md +6 -6
- package/.agent/skills/maintain-component/SKILL.md +59 -24
- package/.agent/workflows/native-playground.md +93 -0
- package/.github/workflows/ci.yml +19 -1
- package/.github/workflows/release-please.yml +32 -6
- package/.release-please-manifest.json +7 -1
- package/.tool-versions +1 -1
- package/CHANGELOG.md +15 -0
- package/apps/.gitkeep +0 -0
- package/apps/native-playground/CHANGELOG.md +8 -0
- package/apps/native-playground/app.json +37 -0
- package/apps/native-playground/assets/fonts/.gitkeep +0 -0
- package/apps/native-playground/assets/images/adaptive-icon.png +0 -0
- package/apps/native-playground/assets/images/favicon.png +0 -0
- package/apps/native-playground/assets/images/icon.png +0 -0
- package/apps/native-playground/assets/images/splash-icon.png +0 -0
- package/apps/native-playground/babel.config.js +6 -0
- package/apps/native-playground/eas.json +25 -0
- package/apps/native-playground/index.js +8 -0
- package/apps/native-playground/metro.config.js +26 -0
- package/apps/native-playground/nativewind-env.d.ts +1 -0
- package/apps/native-playground/package.json +23 -0
- package/apps/native-playground/project.json +15 -0
- package/apps/native-playground/src/app/App.tsx +842 -0
- package/apps/native-playground/src/global.css +49 -0
- package/apps/native-playground/tailwind.config.js +49 -0
- package/apps/native-playground/tsconfig.app.json +24 -0
- package/apps/native-playground/tsconfig.json +23 -0
- package/apps/native-playground/tsconfig.spec.json +24 -0
- package/apps/playground-web/CHANGELOG.md +8 -0
- package/apps/playground-web/package.json +31 -0
- package/apps/playground-web/src/App.tsx +179 -0
- package/apps/playground-web/src/components/docs/CodeBlock.tsx +34 -0
- package/apps/playground-web/src/components/docs/CombinedDocsLayout.tsx +103 -0
- package/apps/playground-web/src/components/docs/ComponentShowcase.tsx +96 -0
- package/apps/playground-web/src/components/docs/ErrorBoundary.tsx +55 -0
- package/apps/playground-web/src/components/docs/Footer.tsx +146 -0
- package/apps/playground-web/src/components/docs/PropsTable.tsx +43 -0
- package/apps/playground-web/src/components/docs/Search.tsx +75 -0
- package/apps/playground-web/src/components/docs/Sidebar.tsx +77 -0
- package/apps/playground-web/src/components/docs/ThemeToggle.tsx +19 -0
- package/apps/playground-web/src/components/docs/index.ts +9 -0
- package/apps/playground-web/src/config/docs.ts +293 -0
- package/apps/playground-web/src/globals.css +148 -0
- package/apps/playground-web/src/hooks/useDocMetadata.ts +34 -0
- package/apps/playground-web/src/hooks/usePackageManager.tsx +42 -0
- package/apps/playground-web/src/lib/react-native-shim.js +34 -0
- package/apps/playground-web/src/main.tsx +11 -0
- package/apps/playground-web/src/pages/index.ts +4 -0
- package/apps/playground-web/src/pages/native/AccordionDocs.tsx +85 -0
- package/apps/playground-web/src/pages/native/AlertDialogDocs.tsx +128 -0
- package/apps/playground-web/src/pages/native/AlertDocs.tsx +89 -0
- package/apps/playground-web/src/pages/native/AspectRatioDocs.tsx +52 -0
- package/apps/playground-web/src/pages/native/AvatarDocs.tsx +92 -0
- package/apps/playground-web/src/pages/native/BadgeDocs.tsx +63 -0
- package/apps/playground-web/src/pages/native/BreadcrumbDocs.tsx +71 -0
- package/apps/playground-web/src/pages/native/ButtonDocs.tsx +103 -0
- package/apps/playground-web/src/pages/native/CalendarDocs.tsx +74 -0
- package/apps/playground-web/src/pages/native/CardDocs.tsx +75 -0
- package/apps/playground-web/src/pages/native/CarouselDocs.tsx +113 -0
- package/apps/playground-web/src/pages/native/ChartDocs.tsx +115 -0
- package/apps/playground-web/src/pages/native/CheckboxDocs.tsx +38 -0
- package/apps/playground-web/src/pages/native/CollapsibleDocs.tsx +89 -0
- package/apps/playground-web/src/pages/native/CommandDocs.tsx +170 -0
- package/apps/playground-web/src/pages/native/ContextMenuDocs.tsx +121 -0
- package/apps/playground-web/src/pages/native/DialogDocs.tsx +132 -0
- package/apps/playground-web/src/pages/native/DrawerDocs.tsx +158 -0
- package/apps/playground-web/src/pages/native/DropdownMenuDocs.tsx +168 -0
- package/apps/playground-web/src/pages/native/HoverCardDocs.tsx +119 -0
- package/apps/playground-web/src/pages/native/InputDocs.tsx +86 -0
- package/apps/playground-web/src/pages/native/LabelDocs.tsx +55 -0
- package/apps/playground-web/src/pages/native/MenubarDocs.tsx +197 -0
- package/apps/playground-web/src/pages/native/NavigationMenuDocs.tsx +190 -0
- package/apps/playground-web/src/pages/native/PaginationDocs.tsx +70 -0
- package/apps/playground-web/src/pages/native/PopoverDocs.tsx +156 -0
- package/apps/playground-web/src/pages/native/ProgressDocs.tsx +61 -0
- package/apps/playground-web/src/pages/native/RadioGroupDocs.tsx +125 -0
- package/apps/playground-web/src/pages/native/ResizableDocs.tsx +118 -0
- package/apps/playground-web/src/pages/native/ScrollAreaDocs.tsx +92 -0
- package/apps/playground-web/src/pages/native/SearchDocs.tsx +150 -0
- package/apps/playground-web/src/pages/native/SelectDocs.tsx +141 -0
- package/apps/playground-web/src/pages/native/SeparatorDocs.tsx +72 -0
- package/apps/playground-web/src/pages/native/SheetDocs.tsx +140 -0
- package/apps/playground-web/src/pages/native/SkeletonDocs.tsx +44 -0
- package/apps/playground-web/src/pages/native/SliderDocs.tsx +118 -0
- package/apps/playground-web/src/pages/native/SonnerDocs.tsx +111 -0
- package/apps/playground-web/src/pages/native/SwitchDocs.tsx +87 -0
- package/apps/playground-web/src/pages/native/TableDocs.tsx +67 -0
- package/apps/playground-web/src/pages/native/TabsDocs.tsx +175 -0
- package/apps/playground-web/src/pages/native/TextareaDocs.tsx +61 -0
- package/apps/playground-web/src/pages/native/ThemeToggleDocs.tsx +288 -0
- package/apps/playground-web/src/pages/native/ToastDocs.tsx +124 -0
- package/apps/playground-web/src/pages/native/ToggleDocs.tsx +81 -0
- package/apps/playground-web/src/pages/native/ToggleGroupDocs.tsx +128 -0
- package/apps/playground-web/src/pages/native/TooltipDocs.tsx +140 -0
- package/apps/playground-web/src/pages/native/index.ts +47 -0
- package/apps/playground-web/src/pages/shared/ColorTokensDocs.tsx +234 -0
- package/apps/playground-web/src/pages/shared/GettingStarted.tsx +413 -0
- package/apps/playground-web/src/pages/web/AccordionDocs.tsx +194 -0
- package/apps/playground-web/src/pages/web/AlertDialogDocs.tsx +157 -0
- package/apps/playground-web/src/pages/web/AlertDocs.tsx +110 -0
- package/apps/playground-web/src/pages/web/AspectRatioDocs.tsx +94 -0
- package/apps/playground-web/src/pages/web/AvatarDocs.tsx +81 -0
- package/apps/playground-web/src/pages/web/BadgeDocs.tsx +66 -0
- package/apps/playground-web/src/pages/web/BreadcrumbDocs.tsx +93 -0
- package/apps/playground-web/src/pages/web/ButtonDocs.tsx +129 -0
- package/apps/playground-web/src/pages/web/CalendarDocs.tsx +78 -0
- package/apps/playground-web/src/pages/web/CardDocs.tsx +115 -0
- package/apps/playground-web/src/pages/web/CarouselDocs.tsx +176 -0
- package/apps/playground-web/src/pages/web/ChartDocs.tsx +151 -0
- package/apps/playground-web/src/pages/web/CheckboxDocs.tsx +95 -0
- package/apps/playground-web/src/pages/web/CollapsibleDocs.tsx +111 -0
- package/apps/playground-web/src/pages/web/CommandDocs.tsx +219 -0
- package/apps/playground-web/src/pages/web/ContextMenuDocs.tsx +164 -0
- package/apps/playground-web/src/pages/web/DialogDocs.tsx +175 -0
- package/apps/playground-web/src/pages/web/DrawerDocs.tsx +283 -0
- package/apps/playground-web/src/pages/web/DropdownMenuDocs.tsx +319 -0
- package/apps/playground-web/src/pages/web/FormDocs.tsx +175 -0
- package/apps/playground-web/src/pages/web/HoverCardDocs.tsx +151 -0
- package/apps/playground-web/src/pages/web/InputDocs.tsx +118 -0
- package/apps/playground-web/src/pages/web/LabelDocs.tsx +59 -0
- package/apps/playground-web/src/pages/web/MenubarDocs.tsx +296 -0
- package/apps/playground-web/src/pages/web/NavigationMenuDocs.tsx +263 -0
- package/apps/playground-web/src/pages/web/PaginationDocs.tsx +102 -0
- package/apps/playground-web/src/pages/web/PopoverDocs.tsx +189 -0
- package/apps/playground-web/src/pages/web/ProgressDocs.tsx +70 -0
- package/apps/playground-web/src/pages/web/RadioGroupDocs.tsx +137 -0
- package/apps/playground-web/src/pages/web/ResizableDocs.tsx +143 -0
- package/apps/playground-web/src/pages/web/ScrollAreaDocs.tsx +107 -0
- package/apps/playground-web/src/pages/web/SearchDocs.tsx +203 -0
- package/apps/playground-web/src/pages/web/SelectDocs.tsx +164 -0
- package/apps/playground-web/src/pages/web/SeparatorDocs.tsx +88 -0
- package/apps/playground-web/src/pages/web/SheetDocs.tsx +186 -0
- package/apps/playground-web/src/pages/web/SkeletonDocs.tsx +53 -0
- package/apps/playground-web/src/pages/web/SliderDocs.tsx +119 -0
- package/apps/playground-web/src/pages/web/SonnerDocs.tsx +126 -0
- package/apps/playground-web/src/pages/web/SwitchDocs.tsx +91 -0
- package/apps/playground-web/src/pages/web/TableDocs.tsx +148 -0
- package/apps/playground-web/src/pages/web/TabsDocs.tsx +241 -0
- package/apps/playground-web/src/pages/web/TextareaDocs.tsx +65 -0
- package/apps/playground-web/src/pages/web/ThemeToggleDocs.tsx +303 -0
- package/apps/playground-web/src/pages/web/ToastDocs.tsx +149 -0
- package/apps/playground-web/src/pages/web/ToggleDocs.tsx +85 -0
- package/apps/playground-web/src/pages/web/ToggleGroupDocs.tsx +140 -0
- package/apps/playground-web/src/pages/web/TooltipDocs.tsx +150 -0
- package/apps/playground-web/src/pages/web/index.ts +47 -0
- package/apps/playground-web/src/routes/doc-routes.tsx +363 -0
- package/apps/playground-web/tailwind.config.js +47 -0
- package/apps/playground-web/tsconfig.app.json +16 -0
- package/apps/playground-web/tsconfig.json +4 -0
- package/apps/playground-web/tsconfig.node.json +13 -0
- package/apps/playground-web/vite.config.ts +41 -0
- package/dist/accordion.cjs.js +2 -0
- package/dist/accordion.cjs.js.map +1 -0
- package/dist/accordion.es.js +38 -0
- package/dist/accordion.es.js.map +1 -0
- package/dist/alert-dialog.cjs.js +2 -0
- package/dist/alert-dialog.cjs.js.map +1 -0
- package/dist/alert-dialog.es.js +70 -0
- package/dist/alert-dialog.es.js.map +1 -0
- package/dist/alert.cjs.js +2 -0
- package/dist/alert.cjs.js.map +1 -0
- package/dist/alert.es.js +32 -0
- package/dist/alert.es.js.map +1 -0
- package/dist/aspect-ratio.cjs.js +2 -0
- package/dist/aspect-ratio.cjs.js.map +1 -0
- package/dist/aspect-ratio.es.js +6 -0
- package/dist/aspect-ratio.es.js.map +1 -0
- package/dist/avatar.cjs.js +2 -0
- package/dist/avatar.cjs.js.map +1 -0
- package/dist/avatar.es.js +29 -0
- package/dist/avatar.es.js.map +1 -0
- package/dist/badge.cjs.js +2 -0
- package/dist/badge.cjs.js.map +1 -0
- package/dist/badge.es.js +26 -0
- package/dist/badge.es.js.map +1 -0
- package/dist/breadcrumb.cjs.js +2 -0
- package/dist/breadcrumb.cjs.js.map +1 -0
- package/dist/breadcrumb.es.js +68 -0
- package/dist/breadcrumb.es.js.map +1 -0
- package/dist/button.cjs.js +2 -0
- package/dist/button.cjs.js.map +1 -0
- package/dist/button.es.js +39 -0
- package/dist/button.es.js.map +1 -0
- package/dist/calendar.cjs.js +2 -0
- package/dist/calendar.cjs.js.map +1 -0
- package/dist/calendar.es.js +132 -0
- package/dist/calendar.es.js.map +1 -0
- package/dist/card.cjs.js +2 -0
- package/dist/card.cjs.js.map +1 -0
- package/dist/card.es.js +34 -0
- package/dist/card.es.js.map +1 -0
- package/dist/carousel.cjs.js +2 -0
- package/dist/carousel.cjs.js.map +1 -0
- package/dist/carousel.es.js +154 -0
- package/dist/carousel.es.js.map +1 -0
- package/dist/chart.cjs.js +8 -0
- package/dist/chart.cjs.js.map +1 -0
- package/dist/chart.es.js +187 -0
- package/dist/chart.es.js.map +1 -0
- package/dist/checkbox.cjs.js +2 -0
- package/dist/checkbox.cjs.js.map +1 -0
- package/dist/checkbox.es.js +22 -0
- package/dist/checkbox.es.js.map +1 -0
- package/dist/collapsible.cjs.js +2 -0
- package/dist/collapsible.cjs.js.map +1 -0
- package/dist/collapsible.es.js +8 -0
- package/dist/collapsible.es.js.map +1 -0
- package/dist/command.cjs.js +2 -0
- package/dist/command.cjs.js.map +1 -0
- package/dist/command.es.js +86 -0
- package/dist/command.es.js.map +1 -0
- package/dist/context-menu.cjs.js +2 -0
- package/dist/context-menu.cjs.js.map +1 -0
- package/dist/context-menu.es.js +124 -0
- package/dist/context-menu.es.js.map +1 -0
- package/dist/design-system.css +1 -1
- package/dist/dialog.cjs.js +2 -0
- package/dist/dialog.cjs.js.map +1 -0
- package/dist/dialog.es.js +65 -0
- package/dist/dialog.es.js.map +1 -0
- package/dist/drawer.cjs.js +2 -0
- package/dist/drawer.cjs.js.map +1 -0
- package/dist/drawer.es.js +54 -0
- package/dist/drawer.es.js.map +1 -0
- package/dist/dropdown-menu.cjs.js +2 -0
- package/dist/dropdown-menu.cjs.js.map +1 -0
- package/dist/dropdown-menu.es.js +126 -0
- package/dist/dropdown-menu.es.js.map +1 -0
- package/dist/form.cjs.js +2 -0
- package/dist/form.cjs.js.map +1 -0
- package/dist/form.es.js +70 -0
- package/dist/form.es.js.map +1 -0
- package/dist/hover-card.cjs.js +2 -0
- package/dist/hover-card.cjs.js.map +1 -0
- package/dist/hover-card.es.js +23 -0
- package/dist/hover-card.es.js.map +1 -0
- package/dist/index.cjs.js +1 -7
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.es.js +418 -2449
- package/dist/index.es.js.map +1 -1
- package/dist/input.cjs.js +2 -0
- package/dist/input.cjs.js.map +1 -0
- package/dist/input.es.js +20 -0
- package/dist/input.es.js.map +1 -0
- package/dist/label.cjs.js +2 -0
- package/dist/label.cjs.js.map +1 -0
- package/dist/label.es.js +9 -0
- package/dist/label.es.js.map +1 -0
- package/dist/menubar.cjs.js +2 -0
- package/dist/menubar.cjs.js.map +1 -0
- package/dist/menubar.es.js +161 -0
- package/dist/menubar.es.js.map +1 -0
- package/dist/navigation-menu.cjs.js +2 -0
- package/dist/navigation-menu.cjs.js.map +1 -0
- package/dist/navigation-menu.es.js +96 -0
- package/dist/navigation-menu.es.js.map +1 -0
- package/dist/packages/design-tokens/src/index.d.ts +91 -0
- package/dist/packages/design-tokens/src/index.d.ts.map +1 -0
- package/dist/packages/design-tokens/src/index.js +21 -0
- package/dist/packages/design-tokens/src/palette.d.ts +32 -0
- package/dist/packages/design-tokens/src/palette.d.ts.map +1 -0
- package/dist/packages/design-tokens/src/palette.js +33 -0
- package/dist/packages/design-tokens/src/radii.d.ts +21 -0
- package/dist/packages/design-tokens/src/radii.d.ts.map +1 -0
- package/dist/packages/design-tokens/src/radii.js +21 -0
- package/dist/packages/design-tokens/src/shadows.d.ts +12 -0
- package/dist/packages/design-tokens/src/shadows.d.ts.map +1 -0
- package/dist/packages/design-tokens/src/shadows.js +13 -0
- package/dist/packages/design-tokens/src/spacing.d.ts +30 -0
- package/dist/packages/design-tokens/src/spacing.d.ts.map +1 -0
- package/dist/packages/design-tokens/src/spacing.js +30 -0
- package/dist/packages/design-tokens/src/theme.d.ts +48 -0
- package/dist/packages/design-tokens/src/theme.d.ts.map +1 -0
- package/dist/packages/design-tokens/src/theme.js +50 -0
- package/dist/packages/design-tokens/src/typography.d.ts +33 -0
- package/dist/packages/design-tokens/src/typography.d.ts.map +1 -0
- package/dist/packages/design-tokens/src/typography.js +33 -0
- package/dist/packages/ui-core/src/contracts/accordion.d.ts +20 -0
- package/dist/packages/ui-core/src/contracts/accordion.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/accordion.js +1 -0
- package/dist/packages/ui-core/src/contracts/alert-dialog.d.ts +40 -0
- package/dist/packages/ui-core/src/contracts/alert-dialog.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/alert-dialog.js +1 -0
- package/dist/packages/ui-core/src/contracts/alert.d.ts +15 -0
- package/dist/packages/ui-core/src/contracts/alert.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/alert.js +1 -0
- package/dist/packages/ui-core/src/contracts/aspect-ratio.d.ts +7 -0
- package/dist/packages/ui-core/src/contracts/aspect-ratio.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/aspect-ratio.js +1 -0
- package/dist/packages/ui-core/src/contracts/avatar.d.ts +15 -0
- package/dist/packages/ui-core/src/contracts/avatar.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/avatar.js +1 -0
- package/dist/packages/ui-core/src/contracts/badge.d.ts +7 -0
- package/dist/packages/ui-core/src/contracts/badge.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/badge.js +1 -0
- package/dist/packages/ui-core/src/contracts/breadcrumb.d.ts +31 -0
- package/dist/packages/ui-core/src/contracts/breadcrumb.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/breadcrumb.js +1 -0
- package/dist/packages/ui-core/src/contracts/button.d.ts +10 -0
- package/dist/packages/ui-core/src/contracts/button.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/button.js +4 -0
- package/dist/packages/ui-core/src/contracts/calendar.d.ts +5 -0
- package/dist/packages/ui-core/src/contracts/calendar.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/calendar.js +1 -0
- package/dist/packages/ui-core/src/contracts/card.d.ts +6 -0
- package/dist/packages/ui-core/src/contracts/card.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/card.js +3 -0
- package/dist/packages/ui-core/src/contracts/carousel.d.ts +25 -0
- package/dist/packages/ui-core/src/contracts/carousel.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/carousel.js +1 -0
- package/dist/packages/ui-core/src/contracts/chart.d.ts +34 -0
- package/dist/packages/ui-core/src/contracts/chart.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/chart.js +1 -0
- package/dist/packages/ui-core/src/contracts/checkbox.d.ts +8 -0
- package/dist/packages/ui-core/src/contracts/checkbox.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/checkbox.js +3 -0
- package/dist/packages/ui-core/src/contracts/collapsible.d.ts +19 -0
- package/dist/packages/ui-core/src/contracts/collapsible.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/collapsible.js +1 -0
- package/dist/packages/ui-core/src/contracts/command.d.ts +36 -0
- package/dist/packages/ui-core/src/contracts/command.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/command.js +1 -0
- package/dist/packages/ui-core/src/contracts/context-menu.d.ts +65 -0
- package/dist/packages/ui-core/src/contracts/context-menu.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/context-menu.js +1 -0
- package/dist/packages/ui-core/src/contracts/dialog.d.ts +14 -0
- package/dist/packages/ui-core/src/contracts/dialog.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/dialog.js +3 -0
- package/dist/packages/ui-core/src/contracts/drawer.d.ts +32 -0
- package/dist/packages/ui-core/src/contracts/drawer.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/drawer.js +1 -0
- package/dist/packages/ui-core/src/contracts/dropdown-menu.d.ts +74 -0
- package/dist/packages/ui-core/src/contracts/dropdown-menu.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/dropdown-menu.js +1 -0
- package/dist/packages/ui-core/src/contracts/form.d.ts +24 -0
- package/dist/packages/ui-core/src/contracts/form.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/form.js +1 -0
- package/dist/packages/ui-core/src/contracts/hover-card.d.ts +19 -0
- package/dist/packages/ui-core/src/contracts/hover-card.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/hover-card.js +1 -0
- package/dist/packages/ui-core/src/contracts/input.d.ts +6 -0
- package/dist/packages/ui-core/src/contracts/input.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/input.js +3 -0
- package/dist/packages/ui-core/src/contracts/label.d.ts +7 -0
- package/dist/packages/ui-core/src/contracts/label.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/label.js +1 -0
- package/dist/packages/ui-core/src/contracts/menubar.d.ts +74 -0
- package/dist/packages/ui-core/src/contracts/menubar.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/menubar.js +1 -0
- package/dist/packages/ui-core/src/contracts/navigation-menu.d.ts +48 -0
- package/dist/packages/ui-core/src/contracts/navigation-menu.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/navigation-menu.js +1 -0
- package/dist/packages/ui-core/src/contracts/pagination.d.ts +32 -0
- package/dist/packages/ui-core/src/contracts/pagination.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/pagination.js +1 -0
- package/dist/packages/ui-core/src/contracts/popover.d.ts +25 -0
- package/dist/packages/ui-core/src/contracts/popover.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/popover.js +1 -0
- package/dist/packages/ui-core/src/contracts/progress.d.ts +5 -0
- package/dist/packages/ui-core/src/contracts/progress.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/progress.js +1 -0
- package/dist/packages/ui-core/src/contracts/radio.d.ts +10 -0
- package/dist/packages/ui-core/src/contracts/radio.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/radio.js +3 -0
- package/dist/packages/ui-core/src/contracts/resizable.d.ts +39 -0
- package/dist/packages/ui-core/src/contracts/resizable.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/resizable.js +1 -0
- package/dist/packages/ui-core/src/contracts/scroll-area.d.ts +14 -0
- package/dist/packages/ui-core/src/contracts/scroll-area.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/scroll-area.js +1 -0
- package/dist/packages/ui-core/src/contracts/search.d.ts +12 -0
- package/dist/packages/ui-core/src/contracts/search.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/search.js +1 -0
- package/dist/packages/ui-core/src/contracts/select.d.ts +55 -0
- package/dist/packages/ui-core/src/contracts/select.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/select.js +1 -0
- package/dist/packages/ui-core/src/contracts/separator.d.ts +6 -0
- package/dist/packages/ui-core/src/contracts/separator.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/separator.js +1 -0
- package/dist/packages/ui-core/src/contracts/sheet.d.ts +49 -0
- package/dist/packages/ui-core/src/contracts/sheet.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/sheet.js +1 -0
- package/dist/packages/ui-core/src/contracts/skeleton.d.ts +6 -0
- package/dist/packages/ui-core/src/contracts/skeleton.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/skeleton.js +1 -0
- package/dist/packages/ui-core/src/contracts/slider.d.ts +16 -0
- package/dist/packages/ui-core/src/contracts/slider.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/slider.js +1 -0
- package/dist/packages/ui-core/src/contracts/sonner.d.ts +16 -0
- package/dist/packages/ui-core/src/contracts/sonner.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/sonner.js +1 -0
- package/dist/packages/ui-core/src/contracts/switch.d.ts +12 -0
- package/dist/packages/ui-core/src/contracts/switch.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/switch.js +1 -0
- package/dist/packages/ui-core/src/contracts/table.d.ts +34 -0
- package/dist/packages/ui-core/src/contracts/table.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/table.js +1 -0
- package/dist/packages/ui-core/src/contracts/tabs.d.ts +28 -0
- package/dist/packages/ui-core/src/contracts/tabs.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/tabs.js +1 -0
- package/dist/packages/ui-core/src/contracts/text.d.ts +7 -0
- package/dist/packages/ui-core/src/contracts/text.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/text.js +3 -0
- package/dist/packages/ui-core/src/contracts/textarea.d.ts +8 -0
- package/dist/packages/ui-core/src/contracts/textarea.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/textarea.js +1 -0
- package/dist/packages/ui-core/src/contracts/theme-provider.d.ts +14 -0
- package/dist/packages/ui-core/src/contracts/theme-provider.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/theme-provider.js +1 -0
- package/dist/packages/ui-core/src/contracts/theme-toggle.d.ts +16 -0
- package/dist/packages/ui-core/src/contracts/theme-toggle.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/theme-toggle.js +1 -0
- package/dist/packages/ui-core/src/contracts/toast.d.ts +11 -0
- package/dist/packages/ui-core/src/contracts/toast.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/toast.js +3 -0
- package/dist/packages/ui-core/src/contracts/toaster.d.ts +4 -0
- package/dist/packages/ui-core/src/contracts/toaster.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/toaster.js +1 -0
- package/dist/packages/ui-core/src/contracts/toggle-group.d.ts +22 -0
- package/dist/packages/ui-core/src/contracts/toggle-group.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/toggle-group.js +1 -0
- package/dist/packages/ui-core/src/contracts/toggle.d.ts +29 -0
- package/dist/packages/ui-core/src/contracts/toggle.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/toggle.js +29 -0
- package/dist/packages/ui-core/src/contracts/tooltip.d.ts +25 -0
- package/dist/packages/ui-core/src/contracts/tooltip.d.ts.map +1 -0
- package/dist/packages/ui-core/src/contracts/tooltip.js +1 -0
- package/dist/packages/ui-core/src/index.d.ts +55 -0
- package/dist/packages/ui-core/src/index.d.ts.map +1 -0
- package/dist/packages/ui-core/src/index.js +12 -0
- package/dist/packages/ui-native/src/accordion.d.ts +46 -0
- package/dist/packages/ui-native/src/accordion.d.ts.map +1 -0
- package/dist/packages/ui-native/src/accordion.js +34 -0
- package/dist/packages/ui-native/src/alert-dialog.d.ts +59 -0
- package/dist/packages/ui-native/src/alert-dialog.d.ts.map +1 -0
- package/dist/packages/ui-native/src/alert-dialog.js +31 -0
- package/dist/packages/ui-native/src/alert.d.ts +10 -0
- package/dist/packages/ui-native/src/alert.d.ts.map +1 -0
- package/dist/packages/ui-native/src/alert.js +26 -0
- package/dist/packages/ui-native/src/aspect-ratio.d.ts +2 -0
- package/dist/packages/ui-native/src/aspect-ratio.d.ts.map +1 -0
- package/dist/packages/ui-native/src/aspect-ratio.js +5 -0
- package/dist/packages/ui-native/src/avatar.d.ts +15 -0
- package/dist/packages/ui-native/src/avatar.d.ts.map +1 -0
- package/dist/packages/ui-native/src/avatar.js +11 -0
- package/dist/packages/ui-native/src/badge.d.ts +12 -0
- package/dist/packages/ui-native/src/badge.d.ts.map +1 -0
- package/dist/packages/ui-native/src/badge.js +37 -0
- package/dist/packages/ui-native/src/breadcrumb.d.ts +2 -0
- package/dist/packages/ui-native/src/breadcrumb.d.ts.map +1 -0
- package/dist/packages/ui-native/src/breadcrumb.js +5 -0
- package/dist/packages/ui-native/src/button.d.ts +14 -0
- package/dist/packages/ui-native/src/button.d.ts.map +1 -0
- package/dist/packages/ui-native/src/button.js +50 -0
- package/dist/packages/ui-native/src/calendar.d.ts +2 -0
- package/dist/packages/ui-native/src/calendar.d.ts.map +1 -0
- package/dist/packages/ui-native/src/calendar.js +5 -0
- package/dist/packages/ui-native/src/card.d.ts +13 -0
- package/dist/packages/ui-native/src/card.d.ts.map +1 -0
- package/dist/packages/ui-native/src/card.js +18 -0
- package/dist/packages/ui-native/src/carousel.d.ts +2 -0
- package/dist/packages/ui-native/src/carousel.d.ts.map +1 -0
- package/dist/packages/ui-native/src/carousel.js +5 -0
- package/dist/packages/ui-native/src/chart.d.ts +2 -0
- package/dist/packages/ui-native/src/chart.d.ts.map +1 -0
- package/dist/packages/ui-native/src/chart.js +5 -0
- package/dist/packages/ui-native/src/checkbox.d.ts +15 -0
- package/dist/packages/ui-native/src/checkbox.d.ts.map +1 -0
- package/dist/packages/ui-native/src/checkbox.js +11 -0
- package/dist/packages/ui-native/src/collapsible.d.ts +21 -0
- package/dist/packages/ui-native/src/collapsible.d.ts.map +1 -0
- package/dist/packages/ui-native/src/collapsible.js +5 -0
- package/dist/packages/ui-native/src/command.d.ts +2 -0
- package/dist/packages/ui-native/src/command.d.ts.map +1 -0
- package/dist/packages/ui-native/src/command.js +5 -0
- package/dist/packages/ui-native/src/context-menu.d.ts +2 -0
- package/dist/packages/ui-native/src/context-menu.d.ts.map +1 -0
- package/dist/packages/ui-native/src/context-menu.js +5 -0
- package/dist/packages/ui-native/src/dialog.d.ts +56 -0
- package/dist/packages/ui-native/src/dialog.d.ts.map +1 -0
- package/dist/packages/ui-native/src/dialog.js +28 -0
- package/dist/packages/ui-native/src/drawer.d.ts +2 -0
- package/dist/packages/ui-native/src/drawer.d.ts.map +1 -0
- package/dist/packages/ui-native/src/drawer.js +5 -0
- package/dist/packages/ui-native/src/dropdown-menu.d.ts +2 -0
- package/dist/packages/ui-native/src/dropdown-menu.d.ts.map +1 -0
- package/dist/packages/ui-native/src/dropdown-menu.js +5 -0
- package/dist/packages/ui-native/src/form.d.ts +2 -0
- package/dist/packages/ui-native/src/form.d.ts.map +1 -0
- package/dist/packages/ui-native/src/form.js +5 -0
- package/dist/packages/ui-native/src/hover-card.d.ts +2 -0
- package/dist/packages/ui-native/src/hover-card.d.ts.map +1 -0
- package/dist/packages/ui-native/src/hover-card.js +5 -0
- package/dist/packages/ui-native/src/index.d.ts +61 -0
- package/dist/packages/ui-native/src/index.d.ts.map +1 -0
- package/dist/packages/ui-native/src/index.js +107 -0
- package/dist/packages/ui-native/src/input.d.ts +8 -0
- package/dist/packages/ui-native/src/input.d.ts.map +1 -0
- package/dist/packages/ui-native/src/input.js +9 -0
- package/dist/packages/ui-native/src/label.d.ts +9 -0
- package/dist/packages/ui-native/src/label.d.ts.map +1 -0
- package/dist/packages/ui-native/src/label.js +7 -0
- package/dist/packages/ui-native/src/lib/render-native.d.ts +4 -0
- package/dist/packages/ui-native/src/lib/render-native.d.ts.map +1 -0
- package/dist/packages/ui-native/src/lib/render-native.js +13 -0
- package/dist/packages/ui-native/src/lib/utils.d.ts.map +1 -0
- package/dist/packages/ui-native/src/lib/utils.js +5 -0
- package/dist/packages/ui-native/src/menubar.d.ts +2 -0
- package/dist/packages/ui-native/src/menubar.d.ts.map +1 -0
- package/dist/packages/ui-native/src/menubar.js +5 -0
- package/dist/packages/ui-native/src/navigation-menu.d.ts +2 -0
- package/dist/packages/ui-native/src/navigation-menu.d.ts.map +1 -0
- package/dist/packages/ui-native/src/navigation-menu.js +5 -0
- package/dist/packages/ui-native/src/pagination.d.ts +2 -0
- package/dist/packages/ui-native/src/pagination.d.ts.map +1 -0
- package/dist/packages/ui-native/src/pagination.js +5 -0
- package/dist/packages/ui-native/src/popover.d.ts +2 -0
- package/dist/packages/ui-native/src/popover.d.ts.map +1 -0
- package/dist/packages/ui-native/src/popover.js +5 -0
- package/dist/packages/ui-native/src/progress.d.ts +2 -0
- package/dist/packages/ui-native/src/progress.d.ts.map +1 -0
- package/dist/packages/ui-native/src/progress.js +5 -0
- package/dist/packages/ui-native/src/radio-group.d.ts +11 -0
- package/dist/packages/ui-native/src/radio-group.d.ts.map +1 -0
- package/dist/packages/ui-native/src/radio-group.js +14 -0
- package/dist/packages/ui-native/src/resizable.d.ts +4 -0
- package/dist/packages/ui-native/src/resizable.d.ts.map +1 -0
- package/dist/packages/ui-native/src/resizable.js +11 -0
- package/dist/packages/ui-native/src/scroll-area.d.ts +2 -0
- package/dist/packages/ui-native/src/scroll-area.d.ts.map +1 -0
- package/dist/packages/ui-native/src/scroll-area.js +5 -0
- package/dist/packages/ui-native/src/search.d.ts +3 -0
- package/dist/packages/ui-native/src/search.d.ts.map +1 -0
- package/dist/packages/ui-native/src/search.js +8 -0
- package/dist/packages/ui-native/src/select.d.ts +57 -0
- package/dist/packages/ui-native/src/select.d.ts.map +1 -0
- package/dist/packages/ui-native/src/select.js +45 -0
- package/dist/packages/ui-native/src/separator.d.ts +9 -0
- package/dist/packages/ui-native/src/separator.d.ts.map +1 -0
- package/dist/packages/ui-native/src/separator.js +7 -0
- package/dist/packages/ui-native/src/sheet.d.ts +53 -0
- package/dist/packages/ui-native/src/sheet.d.ts.map +1 -0
- package/dist/packages/ui-native/src/sheet.js +37 -0
- package/dist/packages/ui-native/src/skeleton.d.ts +5 -0
- package/dist/packages/ui-native/src/skeleton.d.ts.map +1 -0
- package/dist/packages/ui-native/src/skeleton.js +15 -0
- package/dist/packages/ui-native/src/slider.d.ts +2 -0
- package/dist/packages/ui-native/src/slider.d.ts.map +1 -0
- package/dist/packages/ui-native/src/slider.js +5 -0
- package/dist/packages/ui-native/src/sonner.d.ts +2 -0
- package/dist/packages/ui-native/src/sonner.d.ts.map +1 -0
- package/dist/packages/ui-native/src/sonner.js +5 -0
- package/dist/packages/ui-native/src/switch.d.ts +8 -0
- package/dist/packages/ui-native/src/switch.d.ts.map +1 -0
- package/dist/packages/ui-native/src/switch.js +7 -0
- package/dist/packages/ui-native/src/table.d.ts +12 -0
- package/dist/packages/ui-native/src/table.d.ts.map +1 -0
- package/dist/packages/ui-native/src/table.js +22 -0
- package/dist/packages/ui-native/src/tabs.d.ts +25 -0
- package/dist/packages/ui-native/src/tabs.d.ts.map +1 -0
- package/dist/packages/ui-native/src/tabs.js +16 -0
- package/dist/packages/ui-native/src/text.d.ts +13 -0
- package/dist/packages/ui-native/src/text.d.ts.map +1 -0
- package/dist/packages/ui-native/src/text.js +29 -0
- package/dist/packages/ui-native/src/textarea.d.ts +6 -0
- package/dist/packages/ui-native/src/textarea.d.ts.map +1 -0
- package/dist/packages/ui-native/src/textarea.js +9 -0
- package/dist/packages/ui-native/src/theme-provider.d.ts +5 -0
- package/dist/packages/ui-native/src/theme-provider.d.ts.map +1 -0
- package/dist/packages/ui-native/src/theme-provider.js +5 -0
- package/dist/packages/ui-native/src/theme-toggle.d.ts +2 -0
- package/dist/packages/ui-native/src/theme-toggle.d.ts.map +1 -0
- package/dist/packages/ui-native/src/theme-toggle.js +5 -0
- package/dist/packages/ui-native/src/toast.d.ts +35 -0
- package/dist/packages/ui-native/src/toast.d.ts.map +1 -0
- package/dist/packages/ui-native/src/toast.js +23 -0
- package/dist/packages/ui-native/src/toaster.d.ts.map +1 -0
- package/dist/packages/ui-native/src/toaster.js +5 -0
- package/dist/packages/ui-native/src/toggle-group.d.ts +11 -0
- package/dist/packages/ui-native/src/toggle-group.d.ts.map +1 -0
- package/dist/packages/ui-native/src/toggle-group.js +25 -0
- package/dist/packages/ui-native/src/toggle.d.ts +8 -0
- package/dist/packages/ui-native/src/toggle.d.ts.map +1 -0
- package/dist/packages/ui-native/src/toggle.js +9 -0
- package/dist/packages/ui-native/src/tooltip.d.ts +27 -0
- package/dist/packages/ui-native/src/tooltip.d.ts.map +1 -0
- package/dist/packages/ui-native/src/tooltip.js +15 -0
- package/dist/packages/ui-web/src/accordion.d.ts +10 -0
- package/dist/packages/ui-web/src/accordion.d.ts.map +1 -0
- package/dist/packages/ui-web/src/accordion.js +13 -0
- package/dist/packages/ui-web/src/alert-dialog.d.ts +23 -0
- package/dist/packages/ui-web/src/alert-dialog.d.ts.map +1 -0
- package/dist/packages/ui-web/src/alert-dialog.js +25 -0
- package/dist/packages/ui-web/src/alert.d.ts +11 -0
- package/dist/packages/ui-web/src/alert.d.ts.map +1 -0
- package/dist/packages/ui-web/src/alert.js +24 -0
- package/dist/packages/ui-web/src/aspect-ratio.d.ts +6 -0
- package/dist/packages/ui-web/src/aspect-ratio.d.ts.map +1 -0
- package/dist/packages/ui-web/src/aspect-ratio.js +3 -0
- package/dist/packages/ui-web/src/avatar.d.ts +9 -0
- package/dist/packages/ui-web/src/avatar.d.ts.map +1 -0
- package/dist/packages/ui-web/src/avatar.js +11 -0
- package/dist/packages/ui-web/src/badge.d.ts +11 -0
- package/dist/packages/ui-web/src/badge.d.ts.map +1 -0
- package/dist/packages/ui-web/src/badge.js +20 -0
- package/dist/packages/ui-web/src/breadcrumb.d.ts +20 -0
- package/dist/packages/ui-web/src/breadcrumb.d.ts.map +1 -0
- package/dist/packages/ui-web/src/breadcrumb.js +23 -0
- package/dist/packages/ui-web/src/button.d.ts +13 -0
- package/dist/packages/ui-web/src/button.d.ts.map +1 -0
- package/dist/packages/ui-web/src/button.js +33 -0
- package/dist/packages/ui-web/src/calendar.d.ts +11 -0
- package/dist/packages/ui-web/src/calendar.d.ts.map +1 -0
- package/dist/packages/ui-web/src/calendar.js +70 -0
- package/dist/packages/ui-web/src/card.d.ts +12 -0
- package/dist/packages/ui-web/src/card.d.ts.map +1 -0
- package/dist/packages/ui-web/src/card.js +16 -0
- package/dist/packages/ui-web/src/carousel.d.ts +24 -0
- package/dist/packages/ui-web/src/carousel.d.ts.map +1 -0
- package/dist/packages/ui-web/src/carousel.js +98 -0
- package/dist/packages/ui-web/src/chart.d.ts +39 -0
- package/dist/packages/ui-web/src/chart.d.ts.map +1 -0
- package/dist/packages/ui-web/src/chart.js +120 -0
- package/dist/packages/ui-web/src/checkbox.d.ts +8 -0
- package/dist/packages/ui-web/src/checkbox.d.ts.map +1 -0
- package/dist/packages/ui-web/src/checkbox.js +8 -0
- package/dist/packages/ui-web/src/collapsible.d.ts +8 -0
- package/dist/packages/ui-web/src/collapsible.d.ts.map +1 -0
- package/dist/packages/ui-web/src/collapsible.js +5 -0
- package/dist/packages/ui-web/src/command.d.ts +83 -0
- package/dist/packages/ui-web/src/command.d.ts.map +1 -0
- package/dist/packages/ui-web/src/command.js +29 -0
- package/dist/packages/ui-web/src/context-menu.d.ts +24 -0
- package/dist/packages/ui-web/src/context-menu.d.ts.map +1 -0
- package/dist/packages/ui-web/src/context-menu.js +32 -0
- package/dist/packages/ui-web/src/dialog.d.ts.map +1 -0
- package/dist/packages/ui-web/src/dialog.js +22 -0
- package/dist/packages/ui-web/src/drawer.d.ts +25 -0
- package/dist/packages/ui-web/src/drawer.d.ts.map +1 -0
- package/dist/packages/ui-web/src/drawer.js +23 -0
- package/dist/packages/ui-web/src/dropdown-menu.d.ts +24 -0
- package/dist/packages/ui-web/src/dropdown-menu.d.ts.map +1 -0
- package/dist/packages/ui-web/src/dropdown-menu.js +33 -0
- package/dist/packages/ui-web/src/form.d.ts +26 -0
- package/dist/packages/ui-web/src/form.d.ts.map +1 -0
- package/dist/packages/ui-web/src/form.js +64 -0
- package/dist/packages/ui-web/src/hooks/use-theme.d.ts.map +1 -0
- package/dist/packages/ui-web/src/hooks/use-theme.js +12 -0
- package/dist/packages/ui-web/src/hooks/use-toast.d.ts +45 -0
- package/dist/packages/ui-web/src/hooks/use-toast.d.ts.map +1 -0
- package/dist/packages/ui-web/src/hooks/use-toast.js +128 -0
- package/dist/packages/ui-web/src/hover-card.d.ts +9 -0
- package/dist/packages/ui-web/src/hover-card.d.ts.map +1 -0
- package/dist/packages/ui-web/src/hover-card.js +10 -0
- package/dist/packages/ui-web/src/index.d.ts +101 -0
- package/dist/packages/ui-web/src/index.d.ts.map +1 -0
- package/dist/packages/ui-web/src/index.js +106 -0
- package/dist/packages/ui-web/src/input.d.ts +7 -0
- package/dist/packages/ui-web/src/input.d.ts.map +1 -0
- package/dist/packages/ui-web/src/input.js +8 -0
- package/dist/packages/ui-web/src/label.d.ts +8 -0
- package/dist/packages/ui-web/src/label.d.ts.map +1 -0
- package/dist/packages/ui-web/src/label.js +10 -0
- package/dist/packages/ui-web/src/lib/utils.d.ts +3 -0
- package/dist/packages/ui-web/src/lib/utils.d.ts.map +1 -0
- package/dist/packages/ui-web/src/lib/utils.js +5 -0
- package/dist/packages/ui-web/src/menubar.d.ts +25 -0
- package/dist/packages/ui-web/src/menubar.d.ts.map +1 -0
- package/dist/packages/ui-web/src/menubar.js +46 -0
- package/dist/packages/ui-web/src/navigation-menu.d.ts +15 -0
- package/dist/packages/ui-web/src/navigation-menu.d.ts.map +1 -0
- package/dist/packages/ui-web/src/navigation-menu.js +23 -0
- package/dist/packages/ui-web/src/pagination.d.ts +31 -0
- package/dist/packages/ui-web/src/pagination.d.ts.map +1 -0
- package/dist/packages/ui-web/src/pagination.js +23 -0
- package/dist/packages/ui-web/src/popover.d.ts +10 -0
- package/dist/packages/ui-web/src/popover.d.ts.map +1 -0
- package/dist/packages/ui-web/src/popover.js +11 -0
- package/dist/packages/ui-web/src/progress.d.ts +7 -0
- package/dist/packages/ui-web/src/progress.d.ts.map +1 -0
- package/dist/packages/ui-web/src/progress.js +8 -0
- package/dist/packages/ui-web/src/radio-group.d.ts +11 -0
- package/dist/packages/ui-web/src/radio-group.d.ts.map +1 -0
- package/dist/packages/ui-web/src/radio-group.js +14 -0
- package/dist/packages/ui-web/src/resizable.d.ts +9 -0
- package/dist/packages/ui-web/src/resizable.d.ts.map +1 -0
- package/dist/packages/ui-web/src/resizable.js +17 -0
- package/dist/packages/ui-web/src/scroll-area.d.ts +8 -0
- package/dist/packages/ui-web/src/scroll-area.d.ts.map +1 -0
- package/dist/packages/ui-web/src/scroll-area.js +10 -0
- package/dist/packages/ui-web/src/search.d.ts +8 -0
- package/dist/packages/ui-web/src/search.d.ts.map +1 -0
- package/dist/packages/ui-web/src/search.js +48 -0
- package/dist/packages/ui-web/src/select.d.ts +16 -0
- package/dist/packages/ui-web/src/select.d.ts.map +1 -0
- package/dist/packages/ui-web/src/select.js +26 -0
- package/dist/packages/ui-web/src/separator.d.ts +7 -0
- package/dist/packages/ui-web/src/separator.d.ts.map +1 -0
- package/dist/packages/ui-web/src/separator.js +8 -0
- package/dist/packages/ui-web/src/sheet.d.ts +28 -0
- package/dist/packages/ui-web/src/sheet.d.ts.map +1 -0
- package/dist/packages/ui-web/src/sheet.js +37 -0
- package/dist/packages/ui-web/src/skeleton.d.ts +6 -0
- package/dist/packages/ui-web/src/skeleton.d.ts.map +1 -0
- package/dist/packages/ui-web/src/skeleton.js +6 -0
- package/dist/packages/ui-web/src/slider.d.ts +7 -0
- package/dist/packages/ui-web/src/slider.d.ts.map +1 -0
- package/dist/packages/ui-web/src/slider.js +8 -0
- package/dist/packages/ui-web/src/sonner.d.ts +8 -0
- package/dist/packages/ui-web/src/sonner.d.ts.map +1 -0
- package/dist/packages/ui-web/src/sonner.js +16 -0
- package/dist/packages/ui-web/src/switch.d.ts +7 -0
- package/dist/packages/ui-web/src/switch.d.ts.map +1 -0
- package/dist/packages/ui-web/src/switch.js +8 -0
- package/dist/packages/ui-web/src/table.d.ts +13 -0
- package/dist/packages/ui-web/src/table.d.ts.map +1 -0
- package/dist/packages/ui-web/src/table.js +21 -0
- package/dist/packages/ui-web/src/tabs.d.ts +10 -0
- package/dist/packages/ui-web/src/tabs.d.ts.map +1 -0
- package/dist/packages/ui-web/src/tabs.js +13 -0
- package/dist/packages/ui-web/src/text.d.ts +12 -0
- package/dist/packages/ui-web/src/text.d.ts.map +1 -0
- package/dist/packages/ui-web/src/text.js +40 -0
- package/dist/packages/ui-web/src/textarea.d.ts +7 -0
- package/dist/packages/ui-web/src/textarea.d.ts.map +1 -0
- package/dist/packages/ui-web/src/textarea.js +9 -0
- package/dist/packages/ui-web/src/theme-provider.d.ts +5 -0
- package/dist/packages/ui-web/src/theme-provider.d.ts.map +1 -0
- package/dist/packages/ui-web/src/theme-provider.js +6 -0
- package/dist/packages/ui-web/src/theme-toggle.d.ts +4 -0
- package/dist/packages/ui-web/src/theme-toggle.d.ts.map +1 -0
- package/dist/packages/ui-web/src/theme-toggle.js +29 -0
- package/dist/packages/ui-web/src/toast.d.ts.map +1 -0
- package/dist/packages/ui-web/src/toast.js +33 -0
- package/dist/packages/ui-web/src/toaster.d.ts +3 -0
- package/dist/packages/ui-web/src/toaster.d.ts.map +1 -0
- package/dist/packages/ui-web/src/toaster.js +10 -0
- package/dist/packages/ui-web/src/toggle-group.d.ts +13 -0
- package/dist/packages/ui-web/src/toggle-group.d.ts.map +1 -0
- package/dist/packages/ui-web/src/toggle-group.js +21 -0
- package/dist/packages/ui-web/src/toggle.d.ts +9 -0
- package/dist/packages/ui-web/src/toggle.d.ts.map +1 -0
- package/dist/packages/ui-web/src/toggle.js +9 -0
- package/dist/packages/ui-web/src/tooltip.d.ts +13 -0
- package/dist/packages/ui-web/src/tooltip.d.ts.map +1 -0
- package/dist/packages/ui-web/src/tooltip.js +12 -0
- package/dist/pagination.cjs.js +2 -0
- package/dist/pagination.cjs.js.map +1 -0
- package/dist/pagination.es.js +68 -0
- package/dist/pagination.es.js.map +1 -0
- package/dist/popover.cjs.js +2 -0
- package/dist/popover.cjs.js.map +1 -0
- package/dist/popover.es.js +24 -0
- package/dist/popover.es.js.map +1 -0
- package/dist/progress.cjs.js +2 -0
- package/dist/progress.cjs.js.map +1 -0
- package/dist/progress.es.js +24 -0
- package/dist/progress.es.js.map +1 -0
- package/dist/radio-group.cjs.js +2 -0
- package/dist/radio-group.cjs.js.map +1 -0
- package/dist/radio-group.es.js +27 -0
- package/dist/radio-group.es.js.map +1 -0
- package/dist/resizable.cjs.js +2 -0
- package/dist/resizable.cjs.js.map +1 -0
- package/dist/resizable.es.js +34 -0
- package/dist/resizable.es.js.map +1 -0
- package/dist/scroll-area.cjs.js +2 -0
- package/dist/scroll-area.cjs.js.map +1 -0
- package/dist/scroll-area.es.js +30 -0
- package/dist/scroll-area.es.js.map +1 -0
- package/dist/search.cjs.js +2 -0
- package/dist/search.cjs.js.map +1 -0
- package/dist/search.es.js +51 -0
- package/dist/search.es.js.map +1 -0
- package/dist/select.cjs.js +2 -0
- package/dist/select.cjs.js.map +1 -0
- package/dist/select.es.js +100 -0
- package/dist/select.es.js.map +1 -0
- package/dist/separator.cjs.js +2 -0
- package/dist/separator.cjs.js.map +1 -0
- package/dist/separator.es.js +18 -0
- package/dist/separator.es.js.map +1 -0
- package/dist/sheet.cjs.js +2 -0
- package/dist/sheet.cjs.js.map +1 -0
- package/dist/sheet.es.js +64 -0
- package/dist/sheet.es.js.map +1 -0
- package/dist/skeleton.cjs.js +2 -0
- package/dist/skeleton.cjs.js.map +1 -0
- package/dist/skeleton.es.js +9 -0
- package/dist/skeleton.es.js.map +1 -0
- package/dist/slider.cjs.js +2 -0
- package/dist/slider.cjs.js.map +1 -0
- package/dist/slider.es.js +20 -0
- package/dist/slider.es.js.map +1 -0
- package/dist/sonner.cjs.js +2 -0
- package/dist/sonner.cjs.js.map +1 -0
- package/dist/sonner.es.js +25 -0
- package/dist/sonner.es.js.map +1 -0
- package/dist/src/index.d.ts +4 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +3 -0
- package/dist/switch.cjs.js +2 -0
- package/dist/switch.cjs.js.map +1 -0
- package/dist/switch.es.js +27 -0
- package/dist/switch.es.js.map +1 -0
- package/dist/table.cjs.js +2 -0
- package/dist/table.cjs.js.map +1 -0
- package/dist/table.es.js +58 -0
- package/dist/table.es.js.map +1 -0
- package/dist/tabs.cjs.js +2 -0
- package/dist/tabs.cjs.js.map +1 -0
- package/dist/tabs.es.js +46 -0
- package/dist/tabs.es.js.map +1 -0
- package/dist/text.cjs.js +2 -0
- package/dist/text.cjs.js.map +1 -0
- package/dist/text.es.js +42 -0
- package/dist/text.es.js.map +1 -0
- package/dist/textarea.cjs.js +2 -0
- package/dist/textarea.cjs.js.map +1 -0
- package/dist/textarea.es.js +19 -0
- package/dist/textarea.es.js.map +1 -0
- package/dist/theme-provider.cjs.js +2 -0
- package/dist/theme-provider.cjs.js.map +1 -0
- package/dist/theme-provider.es.js +9 -0
- package/dist/theme-provider.es.js.map +1 -0
- package/dist/theme-toggle-BTT5z37-.js +2 -0
- package/dist/theme-toggle-BTT5z37-.js.map +1 -0
- package/dist/theme-toggle-Dhc53hqa.mjs +176 -0
- package/dist/theme-toggle-Dhc53hqa.mjs.map +1 -0
- package/dist/theme-toggle.cjs.js +2 -0
- package/dist/theme-toggle.cjs.js.map +1 -0
- package/dist/theme-toggle.es.js +9 -0
- package/dist/theme-toggle.es.js.map +1 -0
- package/dist/toast.cjs.js +2 -0
- package/dist/toast.cjs.js.map +1 -0
- package/dist/toast.es.js +70 -0
- package/dist/toast.es.js.map +1 -0
- package/dist/toaster-BOqCGbZ6.js +2 -0
- package/dist/toaster-BOqCGbZ6.js.map +1 -0
- package/dist/toaster-CmNmQ6jI.mjs +119 -0
- package/dist/toaster-CmNmQ6jI.mjs.map +1 -0
- package/dist/toaster.cjs.js +2 -0
- package/dist/toaster.cjs.js.map +1 -0
- package/dist/toaster.es.js +7 -0
- package/dist/toaster.es.js.map +1 -0
- package/dist/toggle-CYawMoye.mjs +25 -0
- package/dist/toggle-CYawMoye.mjs.map +1 -0
- package/dist/toggle-Dmzk_m4r.js +2 -0
- package/dist/toggle-Dmzk_m4r.js.map +1 -0
- package/dist/toggle-group.cjs.js +2 -0
- package/dist/toggle-group.cjs.js.map +1 -0
- package/dist/toggle-group.es.js +37 -0
- package/dist/toggle-group.es.js.map +1 -0
- package/dist/toggle.cjs.js +2 -0
- package/dist/toggle.cjs.js.map +1 -0
- package/dist/toggle.es.js +13 -0
- package/dist/toggle.es.js.map +1 -0
- package/dist/tooltip.cjs.js +2 -0
- package/dist/tooltip.cjs.js.map +1 -0
- package/dist/tooltip.es.js +29 -0
- package/dist/tooltip.es.js.map +1 -0
- package/dist/utils-5NfNUIaP.js +2 -0
- package/dist/utils-5NfNUIaP.js.map +1 -0
- package/dist/utils-BfGqxkzX.mjs +8 -0
- package/dist/utils-BfGqxkzX.mjs.map +1 -0
- package/dist/vendor-B8N-rYkV.mjs +25431 -0
- package/dist/vendor-B8N-rYkV.mjs.map +1 -0
- package/dist/vendor-D51Wvbw-.js +68 -0
- package/dist/vendor-D51Wvbw-.js.map +1 -0
- package/docs/architecture-pivot.md +165 -0
- package/docs/native-setup-decision.md +57 -0
- package/docs/phase-1-tracker.md +144 -0
- package/docs/release-tooling-evaluation.md +67 -0
- package/docs/universal-implementation.md +195 -0
- package/docs/update-plan.md +268 -0
- package/eslint.config.mjs +1 -1
- package/nx.json +50 -0
- package/package.json +68 -60
- package/packages/.gitkeep +0 -0
- package/packages/design-tokens/CHANGELOG.md +8 -0
- package/packages/design-tokens/package.json +20 -0
- package/packages/design-tokens/src/index.ts +35 -0
- package/packages/design-tokens/src/palette.ts +36 -0
- package/packages/design-tokens/src/radii.ts +26 -0
- package/packages/design-tokens/src/shadows.ts +16 -0
- package/packages/design-tokens/src/spacing.ts +33 -0
- package/packages/design-tokens/src/theme.ts +54 -0
- package/packages/design-tokens/src/typography.ts +36 -0
- package/packages/design-tokens/tsconfig.json +17 -0
- package/packages/ui-core/CHANGELOG.md +8 -0
- package/packages/ui-core/package.json +40 -0
- package/packages/ui-core/src/contracts/accordion.ts +23 -0
- package/packages/ui-core/src/contracts/alert-dialog.ts +48 -0
- package/packages/ui-core/src/contracts/alert.ts +17 -0
- package/packages/ui-core/src/contracts/aspect-ratio.ts +7 -0
- package/packages/ui-core/src/contracts/avatar.ts +17 -0
- package/packages/ui-core/src/contracts/badge.ts +7 -0
- package/packages/ui-core/src/contracts/breadcrumb.ts +37 -0
- package/packages/ui-core/src/contracts/button.ts +17 -0
- package/packages/ui-core/src/contracts/calendar.ts +4 -0
- package/packages/ui-core/src/contracts/card.ts +11 -0
- package/packages/ui-core/src/contracts/carousel.ts +29 -0
- package/packages/ui-core/src/contracts/chart.ts +31 -0
- package/packages/ui-core/src/contracts/checkbox.ts +11 -0
- package/packages/ui-core/src/contracts/collapsible.ts +21 -0
- package/packages/ui-core/src/contracts/command.ts +43 -0
- package/packages/ui-core/src/contracts/context-menu.ts +78 -0
- package/packages/ui-core/src/contracts/dialog.ts +29 -0
- package/packages/ui-core/src/contracts/drawer.ts +39 -0
- package/packages/ui-core/src/contracts/dropdown-menu.ts +87 -0
- package/packages/ui-core/src/contracts/form.ts +29 -0
- package/packages/ui-core/src/contracts/hover-card.ts +21 -0
- package/packages/ui-core/src/contracts/input.ts +11 -0
- package/packages/ui-core/src/contracts/label.ts +7 -0
- package/packages/ui-core/src/contracts/menubar.ts +86 -0
- package/packages/ui-core/src/contracts/navigation-menu.ts +55 -0
- package/packages/ui-core/src/contracts/pagination.ts +38 -0
- package/packages/ui-core/src/contracts/popover.ts +28 -0
- package/packages/ui-core/src/contracts/progress.ts +4 -0
- package/packages/ui-core/src/contracts/radio.ts +16 -0
- package/packages/ui-core/src/contracts/resizable.ts +36 -0
- package/packages/ui-core/src/contracts/scroll-area.ts +15 -0
- package/packages/ui-core/src/contracts/search.ts +13 -0
- package/packages/ui-core/src/contracts/select.ts +64 -0
- package/packages/ui-core/src/contracts/separator.ts +5 -0
- package/packages/ui-core/src/contracts/sheet.ts +58 -0
- package/packages/ui-core/src/contracts/skeleton.ts +6 -0
- package/packages/ui-core/src/contracts/slider.ts +15 -0
- package/packages/ui-core/src/contracts/sonner.ts +15 -0
- package/packages/ui-core/src/contracts/switch.ts +11 -0
- package/packages/ui-core/src/contracts/table.ts +41 -0
- package/packages/ui-core/src/contracts/tabs.ts +31 -0
- package/packages/ui-core/src/contracts/text.ts +12 -0
- package/packages/ui-core/src/contracts/textarea.ts +7 -0
- package/packages/ui-core/src/contracts/theme-provider.ts +14 -0
- package/packages/ui-core/src/contracts/theme-toggle.ts +15 -0
- package/packages/ui-core/src/contracts/toast.ts +15 -0
- package/packages/ui-core/src/contracts/toaster.ts +3 -0
- package/packages/ui-core/src/contracts/toggle-group.ts +23 -0
- package/packages/ui-core/src/contracts/toggle.ts +49 -0
- package/packages/ui-core/src/contracts/tooltip.ts +28 -0
- package/packages/ui-core/src/index.ts +327 -0
- package/packages/ui-core/tsconfig.json +18 -0
- package/packages/ui-native/CHANGELOG.md +8 -0
- package/packages/ui-native/package.json +76 -0
- package/packages/ui-native/src/accordion.tsx +93 -0
- package/packages/ui-native/src/alert-dialog.tsx +123 -0
- package/packages/ui-native/src/alert.tsx +50 -0
- package/packages/ui-native/src/aspect-ratio.tsx +9 -0
- package/packages/ui-native/src/avatar.tsx +38 -0
- package/packages/ui-native/src/badge.tsx +51 -0
- package/packages/ui-native/src/breadcrumb.tsx +9 -0
- package/packages/ui-native/src/button.test.tsx +27 -0
- package/packages/ui-native/src/button.tsx +75 -0
- package/packages/ui-native/src/calendar.tsx +9 -0
- package/packages/ui-native/src/card.test.tsx +33 -0
- package/packages/ui-native/src/card.tsx +56 -0
- package/packages/ui-native/src/carousel.tsx +9 -0
- package/packages/ui-native/src/chart.tsx +9 -0
- package/packages/ui-native/src/checkbox.test.tsx +58 -0
- package/packages/ui-native/src/checkbox.tsx +31 -0
- package/packages/ui-native/src/collapsible.test.tsx +50 -0
- package/packages/ui-native/src/collapsible.tsx +15 -0
- package/packages/ui-native/src/command.tsx +9 -0
- package/packages/ui-native/src/context-menu.tsx +9 -0
- package/packages/ui-native/src/dialog.test.tsx +91 -0
- package/packages/ui-native/src/dialog.tsx +121 -0
- package/packages/ui-native/src/drawer.tsx +9 -0
- package/packages/ui-native/src/dropdown-menu.tsx +9 -0
- package/packages/ui-native/src/form.tsx +9 -0
- package/packages/ui-native/src/hover-card.tsx +9 -0
- package/packages/ui-native/src/index.ts +209 -0
- package/packages/ui-native/src/input.test.tsx +27 -0
- package/packages/ui-native/src/input.tsx +27 -0
- package/packages/ui-native/src/label.tsx +29 -0
- package/packages/ui-native/src/lib/render-native.tsx +17 -0
- package/packages/ui-native/src/menubar.tsx +9 -0
- package/packages/ui-native/src/nativewind-env.d.ts +1 -0
- package/packages/ui-native/src/navigation-menu.tsx +9 -0
- package/packages/ui-native/src/pagination.tsx +9 -0
- package/packages/ui-native/src/popover.tsx +9 -0
- package/packages/ui-native/src/progress.tsx +9 -0
- package/packages/ui-native/src/radio-group.test.tsx +77 -0
- package/packages/ui-native/src/radio-group.tsx +42 -0
- package/packages/ui-native/src/resizable.tsx +25 -0
- package/packages/ui-native/src/scroll-area.tsx +9 -0
- package/packages/ui-native/src/search.tsx +17 -0
- package/packages/ui-native/src/select.tsx +229 -0
- package/packages/ui-native/src/separator.tsx +20 -0
- package/packages/ui-native/src/sheet.test.tsx +93 -0
- package/packages/ui-native/src/sheet.tsx +127 -0
- package/packages/ui-native/src/skeleton.test.tsx +29 -0
- package/packages/ui-native/src/skeleton.tsx +31 -0
- package/packages/ui-native/src/slider.tsx +9 -0
- package/packages/ui-native/src/sonner.tsx +9 -0
- package/packages/ui-native/src/switch.tsx +34 -0
- package/packages/ui-native/src/table.tsx +73 -0
- package/packages/ui-native/src/tabs.tsx +74 -0
- package/packages/ui-native/src/text.test.tsx +24 -0
- package/packages/ui-native/src/text.tsx +43 -0
- package/packages/ui-native/src/textarea.test.tsx +27 -0
- package/packages/ui-native/src/textarea.tsx +29 -0
- package/packages/ui-native/src/theme-provider.tsx +6 -0
- package/packages/ui-native/src/theme-toggle.tsx +11 -0
- package/packages/ui-native/src/toast.test.tsx +61 -0
- package/packages/ui-native/src/toast.tsx +88 -0
- package/packages/ui-native/src/toaster.tsx +9 -0
- package/packages/ui-native/src/toggle-group.tsx +78 -0
- package/packages/ui-native/src/toggle.tsx +35 -0
- package/packages/ui-native/src/tooltip.tsx +44 -0
- package/packages/ui-native/tsconfig.json +23 -0
- package/packages/ui-native/vite.config.ts +17 -0
- package/packages/ui-web/CHANGELOG.md +8 -0
- package/packages/ui-web/package.json +84 -0
- package/packages/ui-web/src/accordion.tsx +58 -0
- package/packages/ui-web/src/alert-dialog.test.tsx +91 -0
- package/packages/ui-web/src/alert-dialog.tsx +121 -0
- package/packages/ui-web/src/alert.test.tsx +47 -0
- package/packages/ui-web/src/alert.tsx +49 -0
- package/packages/ui-web/src/aspect-ratio.test.tsx +34 -0
- package/packages/ui-web/src/aspect-ratio.tsx +7 -0
- package/packages/ui-web/src/avatar.tsx +40 -0
- package/packages/ui-web/src/badge.tsx +34 -0
- package/packages/ui-web/src/breadcrumb.tsx +105 -0
- package/packages/ui-web/src/button.test.tsx +62 -0
- package/packages/ui-web/src/button.tsx +47 -0
- package/packages/ui-web/src/calendar.test.tsx +23 -0
- package/packages/ui-web/src/calendar.tsx +163 -0
- package/packages/ui-web/src/card.test.tsx +35 -0
- package/packages/ui-web/src/card.tsx +46 -0
- package/packages/ui-web/src/carousel.test.tsx +37 -0
- package/packages/ui-web/src/carousel.tsx +234 -0
- package/packages/ui-web/src/chart.test.tsx +62 -0
- package/packages/ui-web/src/chart.tsx +296 -0
- package/packages/ui-web/src/checkbox.test.tsx +30 -0
- package/packages/ui-web/src/checkbox.tsx +31 -0
- package/packages/ui-web/src/collapsible.test.tsx +51 -0
- package/packages/ui-web/src/collapsible.tsx +15 -0
- package/packages/ui-web/src/command.test.tsx +79 -0
- package/packages/ui-web/src/command.tsx +154 -0
- package/packages/ui-web/src/context-menu.test.tsx +37 -0
- package/packages/ui-web/src/context-menu.tsx +208 -0
- package/packages/ui-web/src/dialog.test.tsx +66 -0
- package/packages/ui-web/src/dialog.tsx +95 -0
- package/packages/ui-web/src/drawer.test.tsx +68 -0
- package/packages/ui-web/src/drawer.tsx +110 -0
- package/packages/ui-web/src/dropdown-menu.test.tsx +93 -0
- package/packages/ui-web/src/dropdown-menu.tsx +212 -0
- package/packages/ui-web/src/form.test.tsx +84 -0
- package/packages/ui-web/src/form.tsx +160 -0
- package/packages/ui-web/src/hooks/use-theme.ts +15 -0
- package/packages/ui-web/src/hooks/use-toast.ts +189 -0
- package/packages/ui-web/src/hover-card.test.tsx +48 -0
- package/packages/ui-web/src/hover-card.tsx +35 -0
- package/packages/ui-web/src/index.ts +474 -0
- package/packages/ui-web/src/input.test.tsx +33 -0
- package/packages/ui-web/src/input.tsx +23 -0
- package/packages/ui-web/src/label.tsx +21 -0
- package/packages/ui-web/src/lib/utils.ts +6 -0
- package/packages/ui-web/src/menubar.test.tsx +92 -0
- package/packages/ui-web/src/menubar.tsx +244 -0
- package/packages/ui-web/src/navigation-menu.test.tsx +53 -0
- package/packages/ui-web/src/navigation-menu.tsx +143 -0
- package/packages/ui-web/src/pagination.test.tsx +57 -0
- package/packages/ui-web/src/pagination.tsx +107 -0
- package/packages/ui-web/src/popover.test.tsx +31 -0
- package/packages/ui-web/src/popover.tsx +45 -0
- package/packages/ui-web/src/progress.test.tsx +18 -0
- package/packages/ui-web/src/progress.tsx +28 -0
- package/packages/ui-web/src/radio-group.test.tsx +39 -0
- package/packages/ui-web/src/radio-group.tsx +41 -0
- package/packages/ui-web/src/resizable.test.tsx +23 -0
- package/packages/ui-web/src/resizable.tsx +59 -0
- package/packages/ui-web/src/scroll-area.test.tsx +15 -0
- package/packages/ui-web/src/scroll-area.tsx +42 -0
- package/packages/ui-web/src/search.test.tsx +81 -0
- package/packages/ui-web/src/search.tsx +87 -0
- package/packages/ui-web/src/select.test.tsx +42 -0
- package/packages/ui-web/src/select.tsx +169 -0
- package/packages/ui-web/src/separator.test.tsx +16 -0
- package/packages/ui-web/src/separator.tsx +24 -0
- package/packages/ui-web/src/setupTests.ts +114 -0
- package/packages/ui-web/src/sheet.test.tsx +48 -0
- package/packages/ui-web/src/sheet.tsx +136 -0
- package/packages/ui-web/src/skeleton.test.tsx +13 -0
- package/packages/ui-web/src/skeleton.tsx +10 -0
- package/packages/ui-web/src/slider.test.tsx +18 -0
- package/packages/ui-web/src/slider.tsx +27 -0
- package/packages/ui-web/src/sonner.test.tsx +13 -0
- package/packages/ui-web/src/sonner.tsx +32 -0
- package/packages/ui-web/src/switch.test.tsx +22 -0
- package/packages/ui-web/src/switch.tsx +31 -0
- package/packages/ui-web/src/table.test.tsx +29 -0
- package/packages/ui-web/src/table.tsx +104 -0
- package/packages/ui-web/src/tabs.test.tsx +43 -0
- package/packages/ui-web/src/tabs.tsx +62 -0
- package/packages/ui-web/src/text.test.tsx +34 -0
- package/packages/ui-web/src/text.tsx +55 -0
- package/packages/ui-web/src/textarea.test.tsx +21 -0
- package/packages/ui-web/src/textarea.tsx +25 -0
- package/packages/ui-web/src/theme-provider.tsx +15 -0
- package/packages/ui-web/src/theme-toggle.test.tsx +49 -0
- package/packages/ui-web/src/theme-toggle.tsx +92 -0
- package/packages/ui-web/src/toast.test.tsx +42 -0
- package/packages/ui-web/src/toast.tsx +111 -0
- package/packages/ui-web/src/toaster.tsx +27 -0
- package/packages/ui-web/src/toggle-group.test.tsx +40 -0
- package/packages/ui-web/src/toggle-group.tsx +55 -0
- package/packages/ui-web/src/toggle.test.tsx +21 -0
- package/packages/ui-web/src/toggle.tsx +24 -0
- package/packages/ui-web/src/tooltip.tsx +51 -0
- package/packages/ui-web/tsconfig.json +24 -0
- package/packages/ui-web/vite.config.ts +21 -0
- package/release-please-config.json +25 -1
- package/scripts/build-registry.ts +60 -27
- package/scripts/sync-tokens.ts +86 -0
- package/scripts/validate.ts +74 -0
- package/src/globals.css +22 -0
- package/src/index.ts +2 -56
- package/src/types/nativewind.d.ts +19 -0
- package/tailwind.config.js +48 -0
- package/tsconfig.build.json +13 -3
- package/tsconfig.json +8 -2
- package/vite.config.ts +61 -5
- package/vitest.config.ts +7 -1
- package/wrangler.toml +1 -1
- package/.yarn/releases/yarn-4.12.0.cjs +0 -942
- package/dist/App.d.ts +0 -3
- package/dist/App.d.ts.map +0 -1
- package/dist/components/docs/CodeBlock.d.ts +0 -8
- package/dist/components/docs/CodeBlock.d.ts.map +0 -1
- package/dist/components/docs/ComponentShowcase.d.ts +0 -17
- package/dist/components/docs/ComponentShowcase.d.ts.map +0 -1
- package/dist/components/docs/Footer.d.ts +0 -2
- package/dist/components/docs/Footer.d.ts.map +0 -1
- package/dist/components/docs/PropsTable.d.ts +0 -13
- package/dist/components/docs/PropsTable.d.ts.map +0 -1
- package/dist/components/docs/Sidebar.d.ts +0 -14
- package/dist/components/docs/Sidebar.d.ts.map +0 -1
- package/dist/components/docs/ThemeToggle.d.ts +0 -2
- package/dist/components/docs/ThemeToggle.d.ts.map +0 -1
- package/dist/components/docs/index.d.ts +0 -7
- package/dist/components/docs/index.d.ts.map +0 -1
- package/dist/components/ui/accordion.d.ts +0 -8
- package/dist/components/ui/accordion.d.ts.map +0 -1
- package/dist/components/ui/accordion.test.d.ts +0 -2
- package/dist/components/ui/accordion.test.d.ts.map +0 -1
- package/dist/components/ui/alert-dialog.d.ts +0 -21
- package/dist/components/ui/alert-dialog.d.ts.map +0 -1
- package/dist/components/ui/alert-dialog.test.d.ts +0 -2
- package/dist/components/ui/alert-dialog.test.d.ts.map +0 -1
- package/dist/components/ui/alert.d.ts +0 -9
- package/dist/components/ui/alert.d.ts.map +0 -1
- package/dist/components/ui/alert.test.d.ts +0 -2
- package/dist/components/ui/alert.test.d.ts.map +0 -1
- package/dist/components/ui/aspect-ratio.d.ts +0 -4
- package/dist/components/ui/aspect-ratio.d.ts.map +0 -1
- package/dist/components/ui/aspect-ratio.test.d.ts +0 -2
- package/dist/components/ui/aspect-ratio.test.d.ts.map +0 -1
- package/dist/components/ui/avatar.d.ts +0 -7
- package/dist/components/ui/avatar.d.ts.map +0 -1
- package/dist/components/ui/avatar.test.d.ts +0 -2
- package/dist/components/ui/avatar.test.d.ts.map +0 -1
- package/dist/components/ui/badge.d.ts +0 -10
- package/dist/components/ui/badge.d.ts.map +0 -1
- package/dist/components/ui/badge.test.d.ts +0 -2
- package/dist/components/ui/badge.test.d.ts.map +0 -1
- package/dist/components/ui/breadcrumb.d.ts +0 -20
- package/dist/components/ui/breadcrumb.d.ts.map +0 -1
- package/dist/components/ui/breadcrumb.test.d.ts +0 -2
- package/dist/components/ui/breadcrumb.test.d.ts.map +0 -1
- package/dist/components/ui/button.d.ts +0 -12
- package/dist/components/ui/button.d.ts.map +0 -1
- package/dist/components/ui/button.test.d.ts +0 -2
- package/dist/components/ui/button.test.d.ts.map +0 -1
- package/dist/components/ui/calendar.d.ts +0 -9
- package/dist/components/ui/calendar.d.ts.map +0 -1
- package/dist/components/ui/calendar.test.d.ts +0 -2
- package/dist/components/ui/calendar.test.d.ts.map +0 -1
- package/dist/components/ui/card.d.ts +0 -9
- package/dist/components/ui/card.d.ts.map +0 -1
- package/dist/components/ui/card.test.d.ts +0 -2
- package/dist/components/ui/card.test.d.ts.map +0 -1
- package/dist/components/ui/carousel.d.ts +0 -19
- package/dist/components/ui/carousel.d.ts.map +0 -1
- package/dist/components/ui/carousel.test.d.ts +0 -2
- package/dist/components/ui/carousel.test.d.ts.map +0 -1
- package/dist/components/ui/chart.d.ts +0 -63
- package/dist/components/ui/chart.d.ts.map +0 -1
- package/dist/components/ui/chart.test.d.ts +0 -2
- package/dist/components/ui/chart.test.d.ts.map +0 -1
- package/dist/components/ui/checkbox.d.ts +0 -5
- package/dist/components/ui/checkbox.d.ts.map +0 -1
- package/dist/components/ui/checkbox.test.d.ts +0 -2
- package/dist/components/ui/checkbox.test.d.ts.map +0 -1
- package/dist/components/ui/collapsible.d.ts +0 -6
- package/dist/components/ui/collapsible.d.ts.map +0 -1
- package/dist/components/ui/collapsible.test.d.ts +0 -2
- package/dist/components/ui/collapsible.test.d.ts.map +0 -1
- package/dist/components/ui/command.d.ts +0 -81
- package/dist/components/ui/command.d.ts.map +0 -1
- package/dist/components/ui/command.test.d.ts +0 -2
- package/dist/components/ui/command.test.d.ts.map +0 -1
- package/dist/components/ui/context-menu.d.ts +0 -28
- package/dist/components/ui/context-menu.d.ts.map +0 -1
- package/dist/components/ui/context-menu.test.d.ts +0 -2
- package/dist/components/ui/context-menu.test.d.ts.map +0 -1
- package/dist/components/ui/dialog.d.ts.map +0 -1
- package/dist/components/ui/dialog.test.d.ts +0 -2
- package/dist/components/ui/dialog.test.d.ts.map +0 -1
- package/dist/components/ui/drawer.d.ts +0 -23
- package/dist/components/ui/drawer.d.ts.map +0 -1
- package/dist/components/ui/drawer.test.d.ts +0 -2
- package/dist/components/ui/drawer.test.d.ts.map +0 -1
- package/dist/components/ui/dropdown-menu.d.ts +0 -28
- package/dist/components/ui/dropdown-menu.d.ts.map +0 -1
- package/dist/components/ui/dropdown-menu.test.d.ts +0 -2
- package/dist/components/ui/dropdown-menu.test.d.ts.map +0 -1
- package/dist/components/ui/form.d.ts +0 -24
- package/dist/components/ui/form.d.ts.map +0 -1
- package/dist/components/ui/form.test.d.ts +0 -2
- package/dist/components/ui/form.test.d.ts.map +0 -1
- package/dist/components/ui/hover-card.d.ts +0 -7
- package/dist/components/ui/hover-card.d.ts.map +0 -1
- package/dist/components/ui/hover-card.test.d.ts +0 -2
- package/dist/components/ui/hover-card.test.d.ts.map +0 -1
- package/dist/components/ui/input.d.ts +0 -4
- package/dist/components/ui/input.d.ts.map +0 -1
- package/dist/components/ui/input.test.d.ts +0 -2
- package/dist/components/ui/input.test.d.ts.map +0 -1
- package/dist/components/ui/label.d.ts +0 -6
- package/dist/components/ui/label.d.ts.map +0 -1
- package/dist/components/ui/label.test.d.ts +0 -2
- package/dist/components/ui/label.test.d.ts.map +0 -1
- package/dist/components/ui/menubar.d.ts +0 -29
- package/dist/components/ui/menubar.d.ts.map +0 -1
- package/dist/components/ui/menubar.test.d.ts +0 -2
- package/dist/components/ui/menubar.test.d.ts.map +0 -1
- package/dist/components/ui/navigation-menu.d.ts +0 -13
- package/dist/components/ui/navigation-menu.d.ts.map +0 -1
- package/dist/components/ui/navigation-menu.test.d.ts +0 -2
- package/dist/components/ui/navigation-menu.test.d.ts.map +0 -1
- package/dist/components/ui/pagination.d.ts +0 -29
- package/dist/components/ui/pagination.d.ts.map +0 -1
- package/dist/components/ui/pagination.test.d.ts +0 -2
- package/dist/components/ui/pagination.test.d.ts.map +0 -1
- package/dist/components/ui/popover.d.ts +0 -8
- package/dist/components/ui/popover.d.ts.map +0 -1
- package/dist/components/ui/popover.test.d.ts +0 -2
- package/dist/components/ui/popover.test.d.ts.map +0 -1
- package/dist/components/ui/progress.d.ts +0 -5
- package/dist/components/ui/progress.d.ts.map +0 -1
- package/dist/components/ui/progress.test.d.ts +0 -2
- package/dist/components/ui/progress.test.d.ts.map +0 -1
- package/dist/components/ui/radio-group.d.ts +0 -6
- package/dist/components/ui/radio-group.d.ts.map +0 -1
- package/dist/components/ui/radio-group.test.d.ts +0 -2
- package/dist/components/ui/radio-group.test.d.ts.map +0 -1
- package/dist/components/ui/resizable.d.ts +0 -11
- package/dist/components/ui/resizable.d.ts.map +0 -1
- package/dist/components/ui/resizable.test.d.ts +0 -2
- package/dist/components/ui/resizable.test.d.ts.map +0 -1
- package/dist/components/ui/scroll-area.d.ts +0 -6
- package/dist/components/ui/scroll-area.d.ts.map +0 -1
- package/dist/components/ui/scroll-area.test.d.ts +0 -2
- package/dist/components/ui/scroll-area.test.d.ts.map +0 -1
- package/dist/components/ui/search.d.ts +0 -16
- package/dist/components/ui/search.d.ts.map +0 -1
- package/dist/components/ui/search.test.d.ts +0 -2
- package/dist/components/ui/search.test.d.ts.map +0 -1
- package/dist/components/ui/select.d.ts +0 -14
- package/dist/components/ui/select.d.ts.map +0 -1
- package/dist/components/ui/select.test.d.ts +0 -2
- package/dist/components/ui/select.test.d.ts.map +0 -1
- package/dist/components/ui/separator.d.ts +0 -5
- package/dist/components/ui/separator.d.ts.map +0 -1
- package/dist/components/ui/separator.test.d.ts +0 -2
- package/dist/components/ui/separator.test.d.ts.map +0 -1
- package/dist/components/ui/sheet.d.ts +0 -26
- package/dist/components/ui/sheet.d.ts.map +0 -1
- package/dist/components/ui/sheet.test.d.ts +0 -2
- package/dist/components/ui/sheet.test.d.ts.map +0 -1
- package/dist/components/ui/skeleton.d.ts +0 -4
- package/dist/components/ui/skeleton.d.ts.map +0 -1
- package/dist/components/ui/skeleton.test.d.ts +0 -2
- package/dist/components/ui/skeleton.test.d.ts.map +0 -1
- package/dist/components/ui/slider.d.ts +0 -5
- package/dist/components/ui/slider.d.ts.map +0 -1
- package/dist/components/ui/slider.test.d.ts +0 -2
- package/dist/components/ui/slider.test.d.ts.map +0 -1
- package/dist/components/ui/sonner.d.ts +0 -6
- package/dist/components/ui/sonner.d.ts.map +0 -1
- package/dist/components/ui/sonner.test.d.ts +0 -2
- package/dist/components/ui/sonner.test.d.ts.map +0 -1
- package/dist/components/ui/switch.d.ts +0 -5
- package/dist/components/ui/switch.d.ts.map +0 -1
- package/dist/components/ui/switch.test.d.ts +0 -2
- package/dist/components/ui/switch.test.d.ts.map +0 -1
- package/dist/components/ui/table.d.ts +0 -11
- package/dist/components/ui/table.d.ts.map +0 -1
- package/dist/components/ui/table.test.d.ts +0 -2
- package/dist/components/ui/table.test.d.ts.map +0 -1
- package/dist/components/ui/tabs.d.ts +0 -8
- package/dist/components/ui/tabs.d.ts.map +0 -1
- package/dist/components/ui/tabs.test.d.ts +0 -2
- package/dist/components/ui/tabs.test.d.ts.map +0 -1
- package/dist/components/ui/textarea.d.ts +0 -4
- package/dist/components/ui/textarea.d.ts.map +0 -1
- package/dist/components/ui/textarea.test.d.ts +0 -2
- package/dist/components/ui/textarea.test.d.ts.map +0 -1
- package/dist/components/ui/theme-provider.d.ts +0 -4
- package/dist/components/ui/theme-provider.d.ts.map +0 -1
- package/dist/components/ui/theme-provider.test.d.ts +0 -2
- package/dist/components/ui/theme-provider.test.d.ts.map +0 -1
- package/dist/components/ui/theme-toggle.d.ts +0 -17
- package/dist/components/ui/theme-toggle.d.ts.map +0 -1
- package/dist/components/ui/theme-toggle.test.d.ts +0 -2
- package/dist/components/ui/theme-toggle.test.d.ts.map +0 -1
- package/dist/components/ui/toast.d.ts.map +0 -1
- package/dist/components/ui/toast.test.d.ts +0 -2
- package/dist/components/ui/toast.test.d.ts.map +0 -1
- package/dist/components/ui/toaster.d.ts.map +0 -1
- package/dist/components/ui/toggle-group.d.ts +0 -13
- package/dist/components/ui/toggle-group.d.ts.map +0 -1
- package/dist/components/ui/toggle-group.test.d.ts +0 -2
- package/dist/components/ui/toggle-group.test.d.ts.map +0 -1
- package/dist/components/ui/toggle.d.ts +0 -13
- package/dist/components/ui/toggle.d.ts.map +0 -1
- package/dist/components/ui/toggle.test.d.ts +0 -2
- package/dist/components/ui/toggle.test.d.ts.map +0 -1
- package/dist/components/ui/tooltip.d.ts +0 -8
- package/dist/components/ui/tooltip.d.ts.map +0 -1
- package/dist/components/ui/tooltip.test.d.ts +0 -2
- package/dist/components/ui/tooltip.test.d.ts.map +0 -1
- package/dist/hooks/use-theme.d.ts.map +0 -1
- package/dist/hooks/use-theme.test.d.ts +0 -2
- package/dist/hooks/use-theme.test.d.ts.map +0 -1
- package/dist/hooks/use-toast.d.ts +0 -45
- package/dist/hooks/use-toast.d.ts.map +0 -1
- package/dist/index.d.ts +0 -54
- package/dist/index.d.ts.map +0 -1
- package/dist/lib/utils.d.ts.map +0 -1
- package/dist/main.d.ts +0 -2
- package/dist/main.d.ts.map +0 -1
- package/dist/pages/ColorTokensDocs.d.ts +0 -2
- package/dist/pages/ColorTokensDocs.d.ts.map +0 -1
- package/dist/pages/GettingStarted.d.ts +0 -3
- package/dist/pages/GettingStarted.d.ts.map +0 -1
- package/dist/pages/components/AccordionDocs.d.ts +0 -2
- package/dist/pages/components/AccordionDocs.d.ts.map +0 -1
- package/dist/pages/components/AlertDialogDocs.d.ts +0 -2
- package/dist/pages/components/AlertDialogDocs.d.ts.map +0 -1
- package/dist/pages/components/AlertDocs.d.ts +0 -2
- package/dist/pages/components/AlertDocs.d.ts.map +0 -1
- package/dist/pages/components/AspectRatioDocs.d.ts +0 -2
- package/dist/pages/components/AspectRatioDocs.d.ts.map +0 -1
- package/dist/pages/components/AvatarDocs.d.ts +0 -2
- package/dist/pages/components/AvatarDocs.d.ts.map +0 -1
- package/dist/pages/components/BadgeDocs.d.ts +0 -2
- package/dist/pages/components/BadgeDocs.d.ts.map +0 -1
- package/dist/pages/components/BreadcrumbDocs.d.ts +0 -2
- package/dist/pages/components/BreadcrumbDocs.d.ts.map +0 -1
- package/dist/pages/components/ButtonDocs.d.ts +0 -2
- package/dist/pages/components/ButtonDocs.d.ts.map +0 -1
- package/dist/pages/components/CalendarDocs.d.ts +0 -2
- package/dist/pages/components/CalendarDocs.d.ts.map +0 -1
- package/dist/pages/components/CardDocs.d.ts +0 -2
- package/dist/pages/components/CardDocs.d.ts.map +0 -1
- package/dist/pages/components/CarouselDocs.d.ts +0 -2
- package/dist/pages/components/CarouselDocs.d.ts.map +0 -1
- package/dist/pages/components/ChartDocs.d.ts +0 -2
- package/dist/pages/components/ChartDocs.d.ts.map +0 -1
- package/dist/pages/components/CheckboxDocs.d.ts +0 -2
- package/dist/pages/components/CheckboxDocs.d.ts.map +0 -1
- package/dist/pages/components/CollapsibleDocs.d.ts +0 -2
- package/dist/pages/components/CollapsibleDocs.d.ts.map +0 -1
- package/dist/pages/components/CommandDocs.d.ts +0 -2
- package/dist/pages/components/CommandDocs.d.ts.map +0 -1
- package/dist/pages/components/ContextMenuDocs.d.ts +0 -2
- package/dist/pages/components/ContextMenuDocs.d.ts.map +0 -1
- package/dist/pages/components/DialogDocs.d.ts +0 -2
- package/dist/pages/components/DialogDocs.d.ts.map +0 -1
- package/dist/pages/components/DrawerDocs.d.ts +0 -2
- package/dist/pages/components/DrawerDocs.d.ts.map +0 -1
- package/dist/pages/components/DropdownMenuDocs.d.ts +0 -2
- package/dist/pages/components/DropdownMenuDocs.d.ts.map +0 -1
- package/dist/pages/components/FormDocs.d.ts +0 -2
- package/dist/pages/components/FormDocs.d.ts.map +0 -1
- package/dist/pages/components/HoverCardDocs.d.ts +0 -2
- package/dist/pages/components/HoverCardDocs.d.ts.map +0 -1
- package/dist/pages/components/InputDocs.d.ts +0 -2
- package/dist/pages/components/InputDocs.d.ts.map +0 -1
- package/dist/pages/components/LabelDocs.d.ts +0 -2
- package/dist/pages/components/LabelDocs.d.ts.map +0 -1
- package/dist/pages/components/MenubarDocs.d.ts +0 -2
- package/dist/pages/components/MenubarDocs.d.ts.map +0 -1
- package/dist/pages/components/NavigationMenuDocs.d.ts +0 -2
- package/dist/pages/components/NavigationMenuDocs.d.ts.map +0 -1
- package/dist/pages/components/PaginationDocs.d.ts +0 -2
- package/dist/pages/components/PaginationDocs.d.ts.map +0 -1
- package/dist/pages/components/PopoverDocs.d.ts +0 -2
- package/dist/pages/components/PopoverDocs.d.ts.map +0 -1
- package/dist/pages/components/ProgressDocs.d.ts +0 -2
- package/dist/pages/components/ProgressDocs.d.ts.map +0 -1
- package/dist/pages/components/RadioGroupDocs.d.ts +0 -2
- package/dist/pages/components/RadioGroupDocs.d.ts.map +0 -1
- package/dist/pages/components/ResizableDocs.d.ts +0 -2
- package/dist/pages/components/ResizableDocs.d.ts.map +0 -1
- package/dist/pages/components/ScrollAreaDocs.d.ts +0 -2
- package/dist/pages/components/ScrollAreaDocs.d.ts.map +0 -1
- package/dist/pages/components/SearchDocs.d.ts +0 -2
- package/dist/pages/components/SearchDocs.d.ts.map +0 -1
- package/dist/pages/components/SelectDocs.d.ts +0 -2
- package/dist/pages/components/SelectDocs.d.ts.map +0 -1
- package/dist/pages/components/SeparatorDocs.d.ts +0 -2
- package/dist/pages/components/SeparatorDocs.d.ts.map +0 -1
- package/dist/pages/components/SheetDocs.d.ts +0 -2
- package/dist/pages/components/SheetDocs.d.ts.map +0 -1
- package/dist/pages/components/SkeletonDocs.d.ts +0 -2
- package/dist/pages/components/SkeletonDocs.d.ts.map +0 -1
- package/dist/pages/components/SliderDocs.d.ts +0 -2
- package/dist/pages/components/SliderDocs.d.ts.map +0 -1
- package/dist/pages/components/SonnerDocs.d.ts +0 -2
- package/dist/pages/components/SonnerDocs.d.ts.map +0 -1
- package/dist/pages/components/SwitchDocs.d.ts +0 -2
- package/dist/pages/components/SwitchDocs.d.ts.map +0 -1
- package/dist/pages/components/TableDocs.d.ts +0 -2
- package/dist/pages/components/TableDocs.d.ts.map +0 -1
- package/dist/pages/components/TabsDocs.d.ts +0 -2
- package/dist/pages/components/TabsDocs.d.ts.map +0 -1
- package/dist/pages/components/TextareaDocs.d.ts +0 -2
- package/dist/pages/components/TextareaDocs.d.ts.map +0 -1
- package/dist/pages/components/ThemeToggleDocs.d.ts +0 -2
- package/dist/pages/components/ThemeToggleDocs.d.ts.map +0 -1
- package/dist/pages/components/ToastDocs.d.ts +0 -2
- package/dist/pages/components/ToastDocs.d.ts.map +0 -1
- package/dist/pages/components/ToggleDocs.d.ts +0 -2
- package/dist/pages/components/ToggleDocs.d.ts.map +0 -1
- package/dist/pages/components/ToggleGroupDocs.d.ts +0 -2
- package/dist/pages/components/ToggleGroupDocs.d.ts.map +0 -1
- package/dist/pages/components/TooltipDocs.d.ts +0 -2
- package/dist/pages/components/TooltipDocs.d.ts.map +0 -1
- package/dist/pages/index.d.ts +0 -50
- package/dist/pages/index.d.ts.map +0 -1
- package/dist/registry/accordion.json +0 -13
- package/dist/registry/accordion.test.json +0 -13
- package/dist/registry/alert-dialog.json +0 -13
- package/dist/registry/alert-dialog.test.json +0 -13
- package/dist/registry/alert.json +0 -13
- package/dist/registry/alert.test.json +0 -13
- package/dist/registry/aspect-ratio.json +0 -13
- package/dist/registry/aspect-ratio.test.json +0 -13
- package/dist/registry/avatar.json +0 -13
- package/dist/registry/avatar.test.json +0 -13
- package/dist/registry/badge.json +0 -13
- package/dist/registry/badge.test.json +0 -13
- package/dist/registry/breadcrumb.json +0 -13
- package/dist/registry/breadcrumb.test.json +0 -13
- package/dist/registry/button.json +0 -13
- package/dist/registry/button.test.json +0 -13
- package/dist/registry/calendar.json +0 -13
- package/dist/registry/calendar.test.json +0 -13
- package/dist/registry/card.json +0 -13
- package/dist/registry/card.test.json +0 -13
- package/dist/registry/carousel.json +0 -13
- package/dist/registry/carousel.test.json +0 -13
- package/dist/registry/chart.json +0 -13
- package/dist/registry/chart.test.json +0 -13
- package/dist/registry/checkbox.json +0 -13
- package/dist/registry/checkbox.test.json +0 -13
- package/dist/registry/collapsible.json +0 -13
- package/dist/registry/collapsible.test.json +0 -13
- package/dist/registry/command.json +0 -13
- package/dist/registry/command.test.json +0 -13
- package/dist/registry/context-menu.json +0 -13
- package/dist/registry/context-menu.test.json +0 -13
- package/dist/registry/dialog.json +0 -13
- package/dist/registry/dialog.test.json +0 -13
- package/dist/registry/drawer.json +0 -13
- package/dist/registry/drawer.test.json +0 -13
- package/dist/registry/dropdown-menu.json +0 -13
- package/dist/registry/dropdown-menu.test.json +0 -13
- package/dist/registry/form.json +0 -13
- package/dist/registry/form.test.json +0 -13
- package/dist/registry/hover-card.json +0 -13
- package/dist/registry/hover-card.test.json +0 -13
- package/dist/registry/index.json +0 -681
- package/dist/registry/input.json +0 -13
- package/dist/registry/input.test.json +0 -13
- package/dist/registry/label.json +0 -13
- package/dist/registry/label.test.json +0 -13
- package/dist/registry/menubar.json +0 -13
- package/dist/registry/menubar.test.json +0 -13
- package/dist/registry/navigation-menu.json +0 -13
- package/dist/registry/navigation-menu.test.json +0 -13
- package/dist/registry/pagination.json +0 -13
- package/dist/registry/pagination.test.json +0 -13
- package/dist/registry/popover.json +0 -13
- package/dist/registry/popover.test.json +0 -13
- package/dist/registry/progress.json +0 -13
- package/dist/registry/progress.test.json +0 -13
- package/dist/registry/radio-group.json +0 -13
- package/dist/registry/radio-group.test.json +0 -13
- package/dist/registry/resizable.json +0 -13
- package/dist/registry/resizable.test.json +0 -13
- package/dist/registry/scroll-area.json +0 -13
- package/dist/registry/scroll-area.test.json +0 -13
- package/dist/registry/search.json +0 -13
- package/dist/registry/search.test.json +0 -13
- package/dist/registry/select.json +0 -13
- package/dist/registry/select.test.json +0 -13
- package/dist/registry/separator.json +0 -13
- package/dist/registry/separator.test.json +0 -13
- package/dist/registry/sheet.json +0 -13
- package/dist/registry/sheet.test.json +0 -13
- package/dist/registry/skeleton.json +0 -13
- package/dist/registry/skeleton.test.json +0 -13
- package/dist/registry/slider.json +0 -13
- package/dist/registry/slider.test.json +0 -13
- package/dist/registry/sonner.json +0 -13
- package/dist/registry/sonner.test.json +0 -13
- package/dist/registry/switch.json +0 -13
- package/dist/registry/switch.test.json +0 -13
- package/dist/registry/table.json +0 -13
- package/dist/registry/table.test.json +0 -13
- package/dist/registry/tabs.json +0 -13
- package/dist/registry/tabs.test.json +0 -13
- package/dist/registry/textarea.json +0 -13
- package/dist/registry/textarea.test.json +0 -13
- package/dist/registry/theme-provider.json +0 -13
- package/dist/registry/theme-provider.test.json +0 -13
- package/dist/registry/theme-toggle.json +0 -13
- package/dist/registry/theme-toggle.test.json +0 -13
- package/dist/registry/toast.json +0 -13
- package/dist/registry/toast.test.json +0 -13
- package/dist/registry/toaster.json +0 -13
- package/dist/registry/toggle-group.json +0 -13
- package/dist/registry/toggle-group.test.json +0 -13
- package/dist/registry/toggle.json +0 -13
- package/dist/registry/toggle.test.json +0 -13
- package/dist/registry/tooltip.json +0 -13
- package/dist/registry/tooltip.test.json +0 -13
- package/dist/setupTests.d.ts +0 -2
- package/dist/setupTests.d.ts.map +0 -1
- package/dist/theme/tokens.d.ts +0 -115
- package/dist/theme/tokens.d.ts.map +0 -1
- package/dist/vendor-Bcg_ARLM.mjs +0 -25810
- package/dist/vendor-Bcg_ARLM.mjs.map +0 -1
- package/dist/vendor-BrqPND3G.js +0 -73
- package/dist/vendor-BrqPND3G.js.map +0 -1
- package/docs/MIGRATE_TO_GVTECH_SCOPE.md +0 -74
- package/public/favicon.png +0 -0
- package/public/index.demo.html +0 -40
- package/public/logo192.png +0 -0
- package/public/logo512.png +0 -0
- package/public/manifest.json +0 -25
- package/public/robots.txt +0 -2
- package/scripts/import-all-shadcn.ts +0 -68
- package/scripts/validate.js +0 -55
- package/src/App.tsx +0 -274
- package/src/components/docs/CodeBlock.tsx +0 -34
- package/src/components/docs/ComponentShowcase.tsx +0 -68
- package/src/components/docs/Footer.tsx +0 -138
- package/src/components/docs/PropsTable.tsx +0 -43
- package/src/components/docs/Sidebar.tsx +0 -175
- package/src/components/docs/ThemeToggle.tsx +0 -19
- package/src/components/docs/index.ts +0 -6
- package/src/components/ui/accordion.tsx +0 -51
- package/src/components/ui/alert-dialog.test.tsx +0 -91
- package/src/components/ui/alert-dialog.tsx +0 -104
- package/src/components/ui/alert.test.tsx +0 -33
- package/src/components/ui/alert.tsx +0 -43
- package/src/components/ui/aspect-ratio.test.tsx +0 -34
- package/src/components/ui/aspect-ratio.tsx +0 -5
- package/src/components/ui/avatar.tsx +0 -38
- package/src/components/ui/badge.tsx +0 -29
- package/src/components/ui/breadcrumb.test.tsx +0 -55
- package/src/components/ui/breadcrumb.tsx +0 -90
- package/src/components/ui/button.test.tsx +0 -62
- package/src/components/ui/button.tsx +0 -46
- package/src/components/ui/calendar.test.tsx +0 -23
- package/src/components/ui/calendar.tsx +0 -160
- package/src/components/ui/card.test.tsx +0 -35
- package/src/components/ui/card.tsx +0 -43
- package/src/components/ui/carousel.test.tsx +0 -37
- package/src/components/ui/carousel.tsx +0 -224
- package/src/components/ui/chart.test.tsx +0 -62
- package/src/components/ui/chart.tsx +0 -307
- package/src/components/ui/checkbox.test.tsx +0 -30
- package/src/components/ui/checkbox.tsx +0 -26
- package/src/components/ui/collapsible.test.tsx +0 -51
- package/src/components/ui/collapsible.tsx +0 -9
- package/src/components/ui/command.test.tsx +0 -79
- package/src/components/ui/command.tsx +0 -132
- package/src/components/ui/context-menu.test.tsx +0 -37
- package/src/components/ui/context-menu.tsx +0 -178
- package/src/components/ui/dialog.test.tsx +0 -66
- package/src/components/ui/dialog.tsx +0 -95
- package/src/components/ui/drawer.test.tsx +0 -68
- package/src/components/ui/drawer.tsx +0 -87
- package/src/components/ui/dropdown-menu.test.tsx +0 -93
- package/src/components/ui/dropdown-menu.tsx +0 -180
- package/src/components/ui/form.test.tsx +0 -85
- package/src/components/ui/form.tsx +0 -149
- package/src/components/ui/hover-card.test.tsx +0 -48
- package/src/components/ui/hover-card.tsx +0 -27
- package/src/components/ui/input.test.tsx +0 -33
- package/src/components/ui/input.tsx +0 -22
- package/src/components/ui/label.tsx +0 -17
- package/src/components/ui/menubar.test.tsx +0 -92
- package/src/components/ui/menubar.tsx +0 -217
- package/src/components/ui/navigation-menu.test.tsx +0 -53
- package/src/components/ui/navigation-menu.tsx +0 -120
- package/src/components/ui/pagination.test.tsx +0 -57
- package/src/components/ui/pagination.tsx +0 -81
- package/src/components/ui/popover.test.tsx +0 -31
- package/src/components/ui/popover.tsx +0 -31
- package/src/components/ui/progress.test.tsx +0 -18
- package/src/components/ui/progress.tsx +0 -24
- package/src/components/ui/radio-group.test.tsx +0 -39
- package/src/components/ui/radio-group.tsx +0 -36
- package/src/components/ui/resizable.test.tsx +0 -23
- package/src/components/ui/resizable.tsx +0 -45
- package/src/components/ui/scroll-area.test.tsx +0 -15
- package/src/components/ui/scroll-area.tsx +0 -38
- package/src/components/ui/search.test.tsx +0 -75
- package/src/components/ui/search.tsx +0 -93
- package/src/components/ui/select.test.tsx +0 -42
- package/src/components/ui/select.tsx +0 -142
- package/src/components/ui/separator.test.tsx +0 -16
- package/src/components/ui/separator.tsx +0 -20
- package/src/components/ui/sheet.test.tsx +0 -48
- package/src/components/ui/sheet.tsx +0 -106
- package/src/components/ui/skeleton.test.tsx +0 -13
- package/src/components/ui/skeleton.tsx +0 -8
- package/src/components/ui/slider.test.tsx +0 -18
- package/src/components/ui/slider.tsx +0 -23
- package/src/components/ui/sonner.test.tsx +0 -13
- package/src/components/ui/sonner.tsx +0 -28
- package/src/components/ui/switch.test.tsx +0 -22
- package/src/components/ui/switch.tsx +0 -27
- package/src/components/ui/table.test.tsx +0 -29
- package/src/components/ui/table.tsx +0 -76
- package/src/components/ui/tabs.test.tsx +0 -43
- package/src/components/ui/tabs.tsx +0 -53
- package/src/components/ui/textarea.test.tsx +0 -21
- package/src/components/ui/textarea.tsx +0 -21
- package/src/components/ui/theme-provider.test.tsx +0 -47
- package/src/components/ui/theme-provider.tsx +0 -12
- package/src/components/ui/theme-toggle.test.tsx +0 -49
- package/src/components/ui/theme-toggle.tsx +0 -108
- package/src/components/ui/toast.test.tsx +0 -42
- package/src/components/ui/toast.tsx +0 -111
- package/src/components/ui/toaster.tsx +0 -24
- package/src/components/ui/toggle-group.test.tsx +0 -40
- package/src/components/ui/toggle-group.tsx +0 -51
- package/src/components/ui/toggle.test.tsx +0 -21
- package/src/components/ui/toggle.tsx +0 -37
- package/src/components/ui/tooltip.test.tsx +0 -25
- package/src/components/ui/tooltip.tsx +0 -30
- package/src/hooks/use-theme.test.tsx +0 -27
- package/src/hooks/use-theme.ts +0 -15
- package/src/hooks/use-toast.ts +0 -189
- package/src/main.tsx +0 -10
- package/src/pages/ColorTokensDocs.tsx +0 -218
- package/src/pages/GettingStarted.tsx +0 -302
- package/src/pages/components/AccordionDocs.tsx +0 -164
- package/src/pages/components/AlertDialogDocs.tsx +0 -151
- package/src/pages/components/AlertDocs.tsx +0 -65
- package/src/pages/components/AspectRatioDocs.tsx +0 -85
- package/src/pages/components/AvatarDocs.tsx +0 -82
- package/src/pages/components/BadgeDocs.tsx +0 -56
- package/src/pages/components/BreadcrumbDocs.tsx +0 -87
- package/src/pages/components/ButtonDocs.tsx +0 -120
- package/src/pages/components/CalendarDocs.tsx +0 -72
- package/src/pages/components/CardDocs.tsx +0 -101
- package/src/pages/components/CarouselDocs.tsx +0 -163
- package/src/pages/components/ChartDocs.tsx +0 -145
- package/src/pages/components/CheckboxDocs.tsx +0 -107
- package/src/pages/components/CollapsibleDocs.tsx +0 -103
- package/src/pages/components/CommandDocs.tsx +0 -209
- package/src/pages/components/ContextMenuDocs.tsx +0 -158
- package/src/pages/components/DialogDocs.tsx +0 -167
- package/src/pages/components/DrawerDocs.tsx +0 -274
- package/src/pages/components/DropdownMenuDocs.tsx +0 -313
- package/src/pages/components/FormDocs.tsx +0 -163
- package/src/pages/components/HoverCardDocs.tsx +0 -136
- package/src/pages/components/InputDocs.tsx +0 -99
- package/src/pages/components/LabelDocs.tsx +0 -54
- package/src/pages/components/MenubarDocs.tsx +0 -290
- package/src/pages/components/NavigationMenuDocs.tsx +0 -254
- package/src/pages/components/PaginationDocs.tsx +0 -93
- package/src/pages/components/PopoverDocs.tsx +0 -183
- package/src/pages/components/ProgressDocs.tsx +0 -64
- package/src/pages/components/RadioGroupDocs.tsx +0 -132
- package/src/pages/components/ResizableDocs.tsx +0 -137
- package/src/pages/components/ScrollAreaDocs.tsx +0 -102
- package/src/pages/components/SearchDocs.tsx +0 -194
- package/src/pages/components/SelectDocs.tsx +0 -158
- package/src/pages/components/SeparatorDocs.tsx +0 -79
- package/src/pages/components/SheetDocs.tsx +0 -178
- package/src/pages/components/SkeletonDocs.tsx +0 -44
- package/src/pages/components/SliderDocs.tsx +0 -110
- package/src/pages/components/SonnerDocs.tsx +0 -117
- package/src/pages/components/SwitchDocs.tsx +0 -86
- package/src/pages/components/TableDocs.tsx +0 -139
- package/src/pages/components/TabsDocs.tsx +0 -223
- package/src/pages/components/TextareaDocs.tsx +0 -60
- package/src/pages/components/ThemeToggleDocs.tsx +0 -296
- package/src/pages/components/ToastDocs.tsx +0 -141
- package/src/pages/components/ToggleDocs.tsx +0 -76
- package/src/pages/components/ToggleGroupDocs.tsx +0 -131
- package/src/pages/components/TooltipDocs.tsx +0 -147
- package/src/pages/index.ts +0 -52
- package/src/theme/tokens.ts +0 -68
- /package/{index.html → apps/playground-web/index.html} +0 -0
- /package/{dist → apps/playground-web/public}/favicon.png +0 -0
- /package/{dist → apps/playground-web/public}/index.demo.html +0 -0
- /package/{dist → apps/playground-web/public}/logo192.png +0 -0
- /package/{dist → apps/playground-web/public}/logo512.png +0 -0
- /package/{dist → apps/playground-web/public}/manifest.json +0 -0
- /package/{dist → apps/playground-web/public}/robots.txt +0 -0
- /package/dist/{lib → packages/ui-native/src/lib}/utils.d.ts +0 -0
- /package/dist/{components/ui → packages/ui-native/src}/toaster.d.ts +0 -0
- /package/dist/{components/ui → packages/ui-web/src}/dialog.d.ts +0 -0
- /package/dist/{hooks → packages/ui-web/src/hooks}/use-theme.d.ts +0 -0
- /package/dist/{components/ui → packages/ui-web/src}/toast.d.ts +0 -0
- /package/{src → packages/ui-native/src}/lib/utils.ts +0 -0
- /package/{src/components/ui → packages/ui-web/src}/accordion.test.tsx +0 -0
- /package/{src/components/ui → packages/ui-web/src}/avatar.test.tsx +0 -0
- /package/{src/components/ui → packages/ui-web/src}/badge.test.tsx +0 -0
- /package/{src/components/ui → packages/ui-web/src}/label.test.tsx +0 -0
package/dist/registry/badge.json
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "badge",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/badge.tsx",
|
|
9
|
-
"content": "import { cva, type VariantProps } from 'class-variance-authority';\nimport * as React from 'react';\n\nimport { cn } from '@/lib/utils';\n\nconst badgeVariants = cva(\n 'inline-flex items-center rounded-md border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2',\n {\n variants: {\n variant: {\n default: 'border-transparent bg-primary text-primary-foreground shadow hover:bg-primary/80',\n secondary: 'border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80',\n destructive: 'border-transparent bg-destructive text-destructive-foreground shadow hover:bg-destructive/80',\n outline: 'text-foreground',\n },\n },\n defaultVariants: {\n variant: 'default',\n },\n },\n);\n\nexport interface BadgeProps extends React.HTMLAttributes<HTMLDivElement>, VariantProps<typeof badgeVariants> {}\n\nfunction Badge({ className, variant, ...props }: BadgeProps) {\n return <div className={cn(badgeVariants({ variant }), className)} {...props} />;\n}\n\nexport { Badge, badgeVariants };\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "badge.test",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/badge.test.tsx",
|
|
9
|
-
"content": "import { render, screen } from '@testing-library/react';\nimport { describe, expect, it } from 'vitest';\nimport { Badge } from './badge';\n\ndescribe('Badge', () => {\n it('renders correctly', () => {\n render(<Badge>Test Badge</Badge>);\n expect(screen.getByText('Test Badge')).toBeInTheDocument();\n });\n\n it('renders variants', () => {\n const { rerender, getByText } = render(<Badge variant=\"default\">Default</Badge>);\n expect(getByText('Default')).toHaveClass('bg-primary');\n\n rerender(<Badge variant=\"secondary\">Secondary</Badge>);\n expect(getByText('Secondary')).toHaveClass('bg-secondary');\n\n rerender(<Badge variant=\"destructive\">Destructive</Badge>);\n expect(getByText('Destructive')).toHaveClass('bg-destructive');\n\n rerender(<Badge variant=\"outline\">Outline</Badge>);\n expect(getByText('Outline')).toHaveClass('text-foreground');\n });\n});\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "breadcrumb",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/breadcrumb.tsx",
|
|
9
|
-
"content": "import { Slot } from '@radix-ui/react-slot';\nimport { ChevronRight, MoreHorizontal } from 'lucide-react';\nimport * as React from 'react';\n\nimport { cn } from '@/lib/utils';\n\nconst Breadcrumb = React.forwardRef<\n HTMLElement,\n React.ComponentPropsWithoutRef<'nav'> & {\n separator?: React.ReactNode;\n }\n>(({ ...props }, ref) => <nav ref={ref} aria-label=\"breadcrumb\" {...props} />);\nBreadcrumb.displayName = 'Breadcrumb';\n\nconst BreadcrumbList = React.forwardRef<HTMLOListElement, React.ComponentPropsWithoutRef<'ol'>>(\n ({ className, ...props }, ref) => (\n <ol\n ref={ref}\n className={cn(\n 'flex flex-wrap items-center gap-1.5 break-words text-sm text-muted-foreground sm:gap-2.5',\n className,\n )}\n {...props}\n />\n ),\n);\nBreadcrumbList.displayName = 'BreadcrumbList';\n\nconst BreadcrumbItem = React.forwardRef<HTMLLIElement, React.ComponentPropsWithoutRef<'li'>>(\n ({ className, ...props }, ref) => (\n <li ref={ref} className={cn('inline-flex items-center gap-1.5', className)} {...props} />\n ),\n);\nBreadcrumbItem.displayName = 'BreadcrumbItem';\n\nconst BreadcrumbLink = React.forwardRef<\n HTMLAnchorElement,\n React.ComponentPropsWithoutRef<'a'> & {\n asChild?: boolean;\n }\n>(({ asChild, className, ...props }, ref) => {\n const Comp = asChild ? Slot : 'a';\n\n return <Comp ref={ref} className={cn('transition-colors hover:text-foreground', className)} {...props} />;\n});\nBreadcrumbLink.displayName = 'BreadcrumbLink';\n\nconst BreadcrumbPage = React.forwardRef<HTMLSpanElement, React.ComponentPropsWithoutRef<'span'>>(\n ({ className, ...props }, ref) => (\n <span\n ref={ref}\n role=\"link\"\n aria-disabled=\"true\"\n aria-current=\"page\"\n className={cn('font-normal text-foreground', className)}\n {...props}\n />\n ),\n);\nBreadcrumbPage.displayName = 'BreadcrumbPage';\n\nconst BreadcrumbSeparator = ({ children, className, ...props }: React.ComponentProps<'li'>) => (\n <li role=\"presentation\" aria-hidden=\"true\" className={cn('[&>svg]:w-3.5 [&>svg]:h-3.5', className)} {...props}>\n {children ?? <ChevronRight />}\n </li>\n);\nBreadcrumbSeparator.displayName = 'BreadcrumbSeparator';\n\nconst BreadcrumbEllipsis = ({ className, ...props }: React.ComponentProps<'span'>) => (\n <span\n role=\"presentation\"\n aria-hidden=\"true\"\n className={cn('flex h-9 w-9 items-center justify-center', className)}\n {...props}\n >\n <MoreHorizontal className=\"h-4 w-4\" />\n <span className=\"sr-only\">More</span>\n </span>\n);\nBreadcrumbEllipsis.displayName = 'BreadcrumbElipssis';\n\nexport {\n Breadcrumb,\n BreadcrumbEllipsis,\n BreadcrumbItem,\n BreadcrumbLink,\n BreadcrumbList,\n BreadcrumbPage,\n BreadcrumbSeparator,\n};\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "breadcrumb.test",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/breadcrumb.test.tsx",
|
|
9
|
-
"content": "import { render, screen } from '@testing-library/react';\nimport { describe, expect, it } from 'vitest';\nimport {\n Breadcrumb,\n BreadcrumbItem,\n BreadcrumbLink,\n BreadcrumbList,\n BreadcrumbPage,\n BreadcrumbSeparator,\n} from './breadcrumb';\n\ndescribe('Breadcrumb', () => {\n it('renders correctly', () => {\n render(\n <Breadcrumb>\n <BreadcrumbList>\n <BreadcrumbItem>\n <BreadcrumbLink href=\"/\">Home</BreadcrumbLink>\n </BreadcrumbItem>\n <BreadcrumbSeparator />\n <BreadcrumbItem>\n <BreadcrumbPage>Page</BreadcrumbPage>\n </BreadcrumbItem>\n </BreadcrumbList>\n </Breadcrumb>,\n );\n\n const nav = screen.getByRole('navigation');\n expect(nav).toBeInTheDocument();\n expect(nav).toHaveAttribute('aria-label', 'breadcrumb');\n\n const links = screen.getAllByRole('link');\n expect(links).toHaveLength(2); // Link and Page (span role=\"link\")\n expect(links[0]).toHaveAttribute('href', '/');\n expect(links[1]).toHaveTextContent('Page');\n });\n\n it('renders custom separator', () => {\n render(\n <Breadcrumb>\n <BreadcrumbList>\n <BreadcrumbItem>\n <BreadcrumbLink>Home</BreadcrumbLink>\n </BreadcrumbItem>\n <BreadcrumbSeparator>/</BreadcrumbSeparator>\n <BreadcrumbItem>\n <BreadcrumbPage>Page</BreadcrumbPage>\n </BreadcrumbItem>\n </BreadcrumbList>\n </Breadcrumb>,\n );\n\n expect(screen.getByText('/')).toBeInTheDocument();\n });\n});\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "button",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/button.tsx",
|
|
9
|
-
"content": "import { Slot } from '@radix-ui/react-slot';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport * as React from 'react';\n\nimport { cn } from '@/lib/utils';\n\nconst buttonVariants = cva(\n 'inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-colors focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0',\n {\n variants: {\n variant: {\n default: 'bg-primary text-primary-foreground shadow hover:bg-primary/90',\n destructive: 'bg-destructive text-destructive-foreground shadow-sm hover:bg-destructive/90',\n outline: 'border border-input bg-background shadow-sm hover:bg-accent hover:text-accent-foreground',\n secondary: 'bg-secondary text-secondary-foreground shadow-sm hover:bg-secondary/80',\n ghost: 'hover:bg-accent hover:text-accent-foreground',\n link: 'text-primary underline-offset-4 hover:underline',\n },\n size: {\n default: 'h-9 px-4 py-2',\n sm: 'h-8 rounded-md px-3 text-xs',\n lg: 'h-10 rounded-md px-8',\n icon: 'h-9 w-9',\n },\n },\n defaultVariants: {\n variant: 'default',\n size: 'default',\n },\n },\n);\n\nexport interface ButtonProps\n extends React.ButtonHTMLAttributes<HTMLButtonElement>, VariantProps<typeof buttonVariants> {\n asChild?: boolean;\n}\n\nconst Button = React.forwardRef<HTMLButtonElement, ButtonProps>(\n ({ className, variant, size, asChild = false, ...props }, ref) => {\n const Comp = asChild ? Slot : 'button';\n return <Comp className={cn(buttonVariants({ variant, size, className }))} ref={ref} {...props} />;\n },\n);\nButton.displayName = 'Button';\n\nexport { Button, buttonVariants };\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "button.test",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/button.test.tsx",
|
|
9
|
-
"content": "import { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport { describe, expect, it, vi } from 'vitest';\nimport { Button } from './button';\n\ndescribe('Button', () => {\n it('renders correctly', () => {\n render(<Button>Click me</Button>);\n expect(screen.getByRole('button', { name: /click me/i })).toBeInTheDocument();\n });\n\n it('handles click events', async () => {\n const handleClick = vi.fn();\n render(<Button onClick={handleClick}>Click me</Button>);\n\n await userEvent.click(screen.getByRole('button', { name: /click me/i }));\n expect(handleClick).toHaveBeenCalledTimes(1);\n });\n\n it('can be disabled', () => {\n render(<Button disabled>Click me</Button>);\n expect(screen.getByRole('button', { name: /click me/i })).toBeDisabled();\n });\n\n it('supports asChild prop', () => {\n render(\n <Button asChild>\n <a href=\"/test\">Link Button</a>\n </Button>,\n );\n\n const link = screen.getByRole('link', { name: /link button/i });\n expect(link).toBeInTheDocument();\n expect(link).toHaveAttribute('href', '/test');\n });\n\n describe('Variants', () => {\n const variants = ['default', 'destructive', 'outline', 'secondary', 'ghost', 'link'] as const;\n\n variants.forEach((variant) => {\n it(`renders ${variant} variant`, () => {\n render(<Button variant={variant}>{variant}</Button>);\n const button = screen.getByRole('button', { name: variant });\n expect(button).toBeInTheDocument();\n // We could check for specific classes here, but that might make tests too brittle\n // checking the role and content presence is a good baseline\n });\n });\n });\n\n describe('Sizes', () => {\n const sizes = ['default', 'sm', 'lg', 'icon'] as const;\n\n sizes.forEach((size) => {\n it(`renders ${size} size`, () => {\n render(<Button size={size}>{size}</Button>);\n const button = screen.getByRole('button', { name: size });\n expect(button).toBeInTheDocument();\n });\n });\n });\n});\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "calendar",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/calendar.tsx",
|
|
9
|
-
"content": "import { ChevronDownIcon, ChevronLeftIcon, ChevronRightIcon } from 'lucide-react';\nimport * as React from 'react';\nimport { DayButton, DayPicker, getDefaultClassNames } from 'react-day-picker';\n\nimport { Button, buttonVariants } from '@/components/ui/button';\nimport { cn } from '@/lib/utils';\n\nfunction Calendar({\n className,\n classNames,\n showOutsideDays = true,\n captionLayout = 'label',\n buttonVariant = 'ghost',\n formatters,\n components,\n ...props\n}: React.ComponentProps<typeof DayPicker> & {\n buttonVariant?: React.ComponentProps<typeof Button>['variant'];\n}) {\n const defaultClassNames = getDefaultClassNames();\n\n return (\n <DayPicker\n showOutsideDays={showOutsideDays}\n className={cn(\n 'bg-background group/calendar p-3 [--cell-size:2.5rem] [[data-slot=card-content]_&]:bg-transparent [[data-slot=popover-content]_&]:bg-transparent',\n String.raw`rtl:**:[.rdp-button\\_next>svg]:rotate-180`,\n String.raw`rtl:**:[.rdp-button\\_previous>svg]:rotate-180`,\n 'relative',\n className,\n )}\n captionLayout={captionLayout}\n formatters={{\n formatMonthDropdown: (date) => date.toLocaleString('default', { month: 'short' }),\n ...formatters,\n }}\n classNames={{\n root: cn('w-fit', defaultClassNames.root),\n months: cn('relative flex flex-col gap-4 md:flex-row', defaultClassNames.months),\n month: cn('flex w-full flex-col gap-4', defaultClassNames.month),\n nav: cn(\n 'absolute inset-x-0 top-2 flex items-center justify-between pointer-events-none px-2',\n defaultClassNames.nav,\n ),\n button_previous: cn(\n buttonVariants({ variant: buttonVariant }),\n 'h-7 w-7 select-none p-0 aria-disabled:opacity-50 pointer-events-auto',\n defaultClassNames.button_previous,\n ),\n button_next: cn(\n buttonVariants({ variant: buttonVariant }),\n 'h-7 w-7 select-none p-0 aria-disabled:opacity-50 pointer-events-auto',\n defaultClassNames.button_next,\n ),\n month_caption: cn(\n 'flex h-[--cell-size] w-full items-center justify-center text-sm font-medium',\n defaultClassNames.month_caption,\n ),\n dropdowns: cn(\n 'flex h-[--cell-size] w-full items-center justify-center gap-1.5 text-sm font-medium',\n defaultClassNames.dropdowns,\n ),\n dropdown_root: cn(\n 'has-focus:border-ring border-input shadow-xs has-focus:ring-ring/50 has-focus:ring-[3px] relative rounded-md border',\n defaultClassNames.dropdown_root,\n ),\n dropdown: cn('bg-popover absolute inset-0 opacity-0', defaultClassNames.dropdown),\n caption_label: cn(\n 'select-none font-medium',\n captionLayout === 'label'\n ? 'text-sm'\n : '[&>svg]:text-muted-foreground flex h-8 items-center gap-1 rounded-md pl-2 pr-1 text-sm [&>svg]:size-3.5',\n defaultClassNames.caption_label,\n ),\n table: 'w-full border-collapse grow',\n weekdays: cn('flex', defaultClassNames.weekdays),\n weekday: cn(\n 'text-muted-foreground pt-1 flex-1 select-none rounded-md text-[0.8rem] font-normal uppercase',\n defaultClassNames.weekday,\n ),\n week: cn('flex w-full mt-2', defaultClassNames.week),\n week_number_header: cn('w-[--cell-size] select-none', defaultClassNames.week_number_header),\n week_number: cn('text-muted-foreground select-none text-[0.8rem]', defaultClassNames.week_number),\n day: cn(\n 'group/day relative flex aspect-square h-10 w-10 select-none items-center justify-center p-0 text-center [&:first-child[data-selected=true]_button]:rounded-l-md [&:last-child[data-selected=true]_button]:rounded-r-md',\n defaultClassNames.day,\n ),\n range_start: cn('bg-accent rounded-l-md', defaultClassNames.range_start),\n range_middle: cn('rounded-none', defaultClassNames.range_middle),\n range_end: cn('bg-accent rounded-r-md', defaultClassNames.range_end),\n today: cn(\n 'bg-accent text-accent-foreground rounded-md data-[selected=true]:rounded-none',\n defaultClassNames.today,\n ),\n outside: cn('text-muted-foreground aria-selected:text-muted-foreground', defaultClassNames.outside),\n disabled: cn('text-muted-foreground opacity-50', defaultClassNames.disabled),\n hidden: cn('invisible', defaultClassNames.hidden),\n ...classNames,\n }}\n components={{\n Root: ({ className, rootRef, ...props }) => {\n return <div data-slot=\"calendar\" ref={rootRef} className={cn(className)} {...props} />;\n },\n Chevron: ({ className, orientation, ...props }) => {\n if (orientation === 'left') {\n return <ChevronLeftIcon className={cn('size-4', className)} {...props} />;\n }\n\n if (orientation === 'right') {\n return <ChevronRightIcon className={cn('size-4', className)} {...props} />;\n }\n\n return <ChevronDownIcon className={cn('size-4', className)} {...props} />;\n },\n DayButton: CalendarDayButton,\n WeekNumber: ({ children, ...props }) => {\n return (\n <td {...props}>\n <div className=\"flex size-[--cell-size] items-center justify-center text-center\">{children}</div>\n </td>\n );\n },\n ...components,\n }}\n {...props}\n />\n );\n}\n\nfunction CalendarDayButton({ className, day, modifiers, ...props }: React.ComponentProps<typeof DayButton>) {\n const defaultClassNames = getDefaultClassNames();\n\n const ref = React.useRef<HTMLButtonElement>(null);\n React.useEffect(() => {\n if (modifiers.focused) ref.current?.focus();\n }, [modifiers.focused]);\n\n return (\n <Button\n ref={ref}\n variant=\"ghost\"\n size=\"icon\"\n data-day={day.date.toLocaleDateString()}\n data-selected-single={\n modifiers.selected && !modifiers.range_start && !modifiers.range_end && !modifiers.range_middle\n }\n data-range-start={modifiers.range_start}\n data-range-end={modifiers.range_end}\n data-range-middle={modifiers.range_middle}\n className={cn(\n 'data-[selected-single=true]:bg-primary data-[selected-single=true]:text-primary-foreground data-[range-middle=true]:bg-accent data-[range-middle=true]:text-accent-foreground data-[range-start=true]:bg-primary data-[range-start=true]:text-primary-foreground data-[range-end=true]:bg-primary data-[range-end=true]:text-primary-foreground group-data-[focused=true]/day:border-ring group-data-[focused=true]/day:ring-ring/50 flex aspect-square h-full w-full min-w-[--cell-size] items-center justify-center font-normal leading-none data-[range-end=true]:rounded-md data-[range-middle=true]:rounded-none data-[range-start=true]:rounded-md group-data-[focused=true]/day:relative group-data-[focused=true]/day:z-10 group-data-[focused=true]/day:ring-[3px] [&>span]:text-xs [&>span]:opacity-70',\n defaultClassNames.day,\n className,\n )}\n {...props}\n />\n );\n}\n\nexport { Calendar, CalendarDayButton };\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "calendar.test",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/calendar.test.tsx",
|
|
9
|
-
"content": "import { render, screen } from '@testing-library/react';\nimport { describe, expect, it } from 'vitest';\nimport { Calendar } from './calendar';\n\ndescribe('Calendar', () => {\n it('renders correctly', () => {\n // Mock date to consistent rendering\n const date = new Date(2023, 0, 1); // Jan 1, 2023\n\n render(<Calendar mode=\"single\" selected={date} month={date} />);\n\n expect(screen.getByText('January 2023')).toBeInTheDocument();\n const days = screen.getAllByText('1');\n expect(days.length).toBeGreaterThan(0);\n expect(screen.getByText('Su')).toBeInTheDocument(); // Sunday header\n });\n\n it('renders with class name', () => {\n const { container } = render(<Calendar className=\"test-class\" />);\n // DayPicker renders a div with the class\n expect(container.firstChild).toHaveClass('test-class');\n });\n});\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
package/dist/registry/card.json
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "card",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/card.tsx",
|
|
9
|
-
"content": "import * as React from 'react';\n\nimport { cn } from '@/lib/utils';\n\nconst Card = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(({ className, ...props }, ref) => (\n <div ref={ref} className={cn('rounded-xl border bg-card text-card-foreground shadow', className)} {...props} />\n));\nCard.displayName = 'Card';\n\nconst CardHeader = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div ref={ref} className={cn('flex flex-col space-y-1.5 p-6', className)} {...props} />\n ),\n);\nCardHeader.displayName = 'CardHeader';\n\nconst CardTitle = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div ref={ref} className={cn('font-semibold leading-none tracking-tight', className)} {...props} />\n ),\n);\nCardTitle.displayName = 'CardTitle';\n\nconst CardDescription = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div ref={ref} className={cn('text-sm text-muted-foreground', className)} {...props} />\n ),\n);\nCardDescription.displayName = 'CardDescription';\n\nconst CardContent = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => <div ref={ref} className={cn('p-6 pt-0', className)} {...props} />,\n);\nCardContent.displayName = 'CardContent';\n\nconst CardFooter = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div ref={ref} className={cn('flex items-center p-6 pt-0', className)} {...props} />\n ),\n);\nCardFooter.displayName = 'CardFooter';\n\nexport { Card, CardContent, CardDescription, CardFooter, CardHeader, CardTitle };\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "card.test",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/card.test.tsx",
|
|
9
|
-
"content": "import { render, screen } from '@testing-library/react';\nimport { describe, expect, it } from 'vitest';\nimport { Card, CardContent, CardDescription, CardFooter, CardHeader, CardTitle } from './card';\n\ndescribe('Card', () => {\n it('renders correctly', () => {\n render(\n <Card>\n <CardHeader>\n <CardTitle>Title</CardTitle>\n <CardDescription>Description</CardDescription>\n </CardHeader>\n <CardContent>Content</CardContent>\n <CardFooter>Footer</CardFooter>\n </Card>,\n );\n\n expect(screen.getByText('Title')).toBeInTheDocument();\n expect(screen.getByText('Description')).toBeInTheDocument();\n expect(screen.getByText('Content')).toBeInTheDocument();\n expect(screen.getByText('Footer')).toBeInTheDocument();\n });\n\n it('renders with class names', () => {\n const { container } = render(<Card className=\"test-class\" />);\n expect(container.firstChild).toHaveClass(\n 'test-class',\n 'rounded-xl',\n 'border',\n 'bg-card',\n 'text-card-foreground',\n 'shadow',\n );\n });\n});\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "carousel",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/carousel.tsx",
|
|
9
|
-
"content": "import useEmblaCarousel, { type UseEmblaCarouselType } from 'embla-carousel-react';\nimport { ArrowLeft, ArrowRight } from 'lucide-react';\nimport * as React from 'react';\n\nimport { Button } from '@/components/ui/button';\nimport { cn } from '@/lib/utils';\n\ntype CarouselApi = UseEmblaCarouselType[1];\ntype UseCarouselParameters = Parameters<typeof useEmblaCarousel>;\ntype CarouselOptions = UseCarouselParameters[0];\ntype CarouselPlugin = UseCarouselParameters[1];\n\ntype CarouselProps = {\n opts?: CarouselOptions;\n plugins?: CarouselPlugin;\n orientation?: 'horizontal' | 'vertical';\n setApi?: (api: CarouselApi) => void;\n};\n\ntype CarouselContextProps = {\n carouselRef: ReturnType<typeof useEmblaCarousel>[0];\n api: ReturnType<typeof useEmblaCarousel>[1];\n scrollPrev: () => void;\n scrollNext: () => void;\n canScrollPrev: boolean;\n canScrollNext: boolean;\n} & CarouselProps;\n\nconst CarouselContext = React.createContext<CarouselContextProps | null>(null);\n\nfunction useCarousel() {\n const context = React.useContext(CarouselContext);\n\n if (!context) {\n throw new Error('useCarousel must be used within a <Carousel />');\n }\n\n return context;\n}\n\nconst Carousel = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement> & CarouselProps>(\n ({ orientation = 'horizontal', opts, setApi, plugins, className, children, ...props }, ref) => {\n const [carouselRef, api] = useEmblaCarousel(\n {\n ...opts,\n axis: orientation === 'horizontal' ? 'x' : 'y',\n },\n plugins,\n );\n const [canScrollPrev, setCanScrollPrev] = React.useState(false);\n const [canScrollNext, setCanScrollNext] = React.useState(false);\n\n const onSelect = React.useCallback((api: CarouselApi) => {\n if (!api) {\n return;\n }\n\n setCanScrollPrev(api.canScrollPrev());\n setCanScrollNext(api.canScrollNext());\n }, []);\n\n const scrollPrev = React.useCallback(() => {\n api?.scrollPrev();\n }, [api]);\n\n const scrollNext = React.useCallback(() => {\n api?.scrollNext();\n }, [api]);\n\n const handleKeyDown = React.useCallback(\n (event: React.KeyboardEvent<HTMLDivElement>) => {\n if (event.key === 'ArrowLeft') {\n event.preventDefault();\n scrollPrev();\n } else if (event.key === 'ArrowRight') {\n event.preventDefault();\n scrollNext();\n }\n },\n [scrollPrev, scrollNext],\n );\n\n React.useEffect(() => {\n if (!api || !setApi) {\n return;\n }\n\n setApi(api);\n }, [api, setApi]);\n\n React.useEffect(() => {\n if (!api) {\n return;\n }\n\n onSelect(api);\n api.on('reInit', onSelect);\n api.on('select', onSelect);\n\n return () => {\n api?.off('select', onSelect);\n };\n }, [api, onSelect]);\n\n return (\n <CarouselContext.Provider\n value={{\n carouselRef,\n api: api,\n opts,\n orientation: orientation || (opts?.axis === 'y' ? 'vertical' : 'horizontal'),\n scrollPrev,\n scrollNext,\n canScrollPrev,\n canScrollNext,\n }}\n >\n <div\n ref={ref}\n onKeyDownCapture={handleKeyDown}\n className={cn('relative', className)}\n role=\"region\"\n aria-roledescription=\"carousel\"\n {...props}\n >\n {children}\n </div>\n </CarouselContext.Provider>\n );\n },\n);\nCarousel.displayName = 'Carousel';\n\nconst CarouselContent = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => {\n const { carouselRef, orientation } = useCarousel();\n\n return (\n <div ref={carouselRef} className=\"overflow-hidden\">\n <div\n ref={ref}\n className={cn('flex', orientation === 'horizontal' ? '-ml-4' : '-mt-4 flex-col', className)}\n {...props}\n />\n </div>\n );\n },\n);\nCarouselContent.displayName = 'CarouselContent';\n\nconst CarouselItem = React.forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => {\n const { orientation } = useCarousel();\n\n return (\n <div\n ref={ref}\n role=\"group\"\n aria-roledescription=\"slide\"\n className={cn('min-w-0 shrink-0 grow-0 basis-full', orientation === 'horizontal' ? 'pl-4' : 'pt-4', className)}\n {...props}\n />\n );\n },\n);\nCarouselItem.displayName = 'CarouselItem';\n\nconst CarouselPrevious = React.forwardRef<HTMLButtonElement, React.ComponentProps<typeof Button>>(\n ({ className, variant = 'outline', size = 'icon', ...props }, ref) => {\n const { orientation, scrollPrev, canScrollPrev } = useCarousel();\n\n return (\n <Button\n ref={ref}\n variant={variant}\n size={size}\n className={cn(\n 'absolute h-8 w-8 rounded-full',\n orientation === 'horizontal'\n ? '-left-12 top-1/2 -translate-y-1/2'\n : '-top-12 left-1/2 -translate-x-1/2 rotate-90',\n className,\n )}\n disabled={!canScrollPrev}\n onClick={scrollPrev}\n {...props}\n >\n <ArrowLeft className=\"h-4 w-4\" />\n <span className=\"sr-only\">Previous slide</span>\n </Button>\n );\n },\n);\nCarouselPrevious.displayName = 'CarouselPrevious';\n\nconst CarouselNext = React.forwardRef<HTMLButtonElement, React.ComponentProps<typeof Button>>(\n ({ className, variant = 'outline', size = 'icon', ...props }, ref) => {\n const { orientation, scrollNext, canScrollNext } = useCarousel();\n\n return (\n <Button\n ref={ref}\n variant={variant}\n size={size}\n className={cn(\n 'absolute h-8 w-8 rounded-full',\n orientation === 'horizontal'\n ? '-right-12 top-1/2 -translate-y-1/2'\n : '-bottom-12 left-1/2 -translate-x-1/2 rotate-90',\n className,\n )}\n disabled={!canScrollNext}\n onClick={scrollNext}\n {...props}\n >\n <ArrowRight className=\"h-4 w-4\" />\n <span className=\"sr-only\">Next slide</span>\n </Button>\n );\n },\n);\nCarouselNext.displayName = 'CarouselNext';\n\nexport { Carousel, CarouselContent, CarouselItem, CarouselNext, CarouselPrevious, type CarouselApi };\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "carousel.test",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/carousel.test.tsx",
|
|
9
|
-
"content": "import { render, screen } from '@testing-library/react';\nimport { describe, expect, it } from 'vitest';\nimport { Carousel, CarouselContent, CarouselItem, CarouselNext, CarouselPrevious } from './carousel';\n\ndescribe('Carousel', () => {\n it('renders correctly', () => {\n render(\n <Carousel aria-label=\"carousel\">\n <CarouselContent>\n <CarouselItem>Slide 1</CarouselItem>\n <CarouselItem>Slide 2</CarouselItem>\n <CarouselItem>Slide 3</CarouselItem>\n </CarouselContent>\n <CarouselPrevious />\n <CarouselNext />\n </Carousel>,\n );\n\n expect(screen.getByRole('region', { name: 'carousel' })).toBeInTheDocument();\n expect(screen.getByText('Slide 1')).toBeInTheDocument();\n expect(screen.getByText('Slide 2')).toBeInTheDocument();\n expect(screen.getByText('Slide 3')).toBeInTheDocument();\n expect(screen.getByRole('button', { name: 'Previous slide' })).toBeInTheDocument();\n expect(screen.getByRole('button', { name: 'Next slide' })).toBeInTheDocument();\n });\n\n it('renders with orientation vertical', () => {\n render(\n <Carousel orientation=\"vertical\" aria-label=\"carousel\">\n <CarouselContent>\n <CarouselItem>Slide 1</CarouselItem>\n </CarouselContent>\n </Carousel>,\n );\n expect(screen.getByRole('region', { name: 'carousel' })).toBeInTheDocument();\n });\n});\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
package/dist/registry/chart.json
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "chart",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/chart.tsx",
|
|
9
|
-
"content": "import * as React from 'react';\nimport * as RechartsPrimitive from 'recharts';\n\nimport { cn } from '@/lib/utils';\n\n// Format: { THEME_NAME: CSS_SELECTOR }\nconst THEMES = { light: '', dark: '.dark' } as const;\n\nexport type ChartConfig = {\n [k in string]: {\n label?: React.ReactNode;\n icon?: React.ComponentType;\n } & ({ color?: string; theme?: never } | { color?: never; theme: Record<keyof typeof THEMES, string> });\n};\n\ntype ChartContextProps = {\n config: ChartConfig;\n};\n\nconst ChartContext = React.createContext<ChartContextProps | null>(null);\n\nfunction useChart() {\n const context = React.useContext(ChartContext);\n\n if (!context) {\n throw new Error('useChart must be used within a <ChartContainer />');\n }\n\n return context;\n}\n\nconst ChartContainer = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<'div'> & {\n config: ChartConfig;\n children: React.ComponentProps<typeof RechartsPrimitive.ResponsiveContainer>['children'];\n }\n>(({ id, className, children, config, ...props }, ref) => {\n const uniqueId = React.useId();\n const chartId = `chart-${id || uniqueId.replace(/:/g, '')}`;\n\n return (\n <ChartContext.Provider value={{ config }}>\n <div\n data-chart={chartId}\n ref={ref}\n className={cn(\n \"flex aspect-video justify-center text-xs [&_.recharts-cartesian-axis-tick_text]:fill-muted-foreground [&_.recharts-cartesian-grid_line[stroke='#ccc']]:stroke-border/50 [&_.recharts-curve.recharts-tooltip-cursor]:stroke-border [&_.recharts-dot[stroke='#fff']]:stroke-transparent [&_.recharts-layer]:outline-none [&_.recharts-polar-grid_[stroke='#ccc']]:stroke-border [&_.recharts-radial-bar-background-sector]:fill-muted [&_.recharts-rectangle.recharts-tooltip-cursor]:fill-muted [&_.recharts-reference-line_[stroke='#ccc']]:stroke-border [&_.recharts-sector[stroke='#fff']]:stroke-transparent [&_.recharts-sector]:outline-none [&_.recharts-surface]:outline-none\",\n className,\n )}\n {...props}\n >\n <ChartStyle id={chartId} config={config} />\n <RechartsPrimitive.ResponsiveContainer>{children}</RechartsPrimitive.ResponsiveContainer>\n </div>\n </ChartContext.Provider>\n );\n});\nChartContainer.displayName = 'Chart';\n\nconst ChartStyle = ({ id, config }: { id: string; config: ChartConfig }) => {\n const colorConfig = Object.entries(config).filter(([, config]) => config.theme || config.color);\n\n if (!colorConfig.length) {\n return null;\n }\n\n return (\n <style\n dangerouslySetInnerHTML={{\n __html: Object.entries(THEMES)\n .map(\n ([theme, prefix]) => `\n${prefix} [data-chart=${id}] {\n${colorConfig\n .map(([key, itemConfig]) => {\n const color = itemConfig.theme?.[theme as keyof typeof itemConfig.theme] || itemConfig.color;\n return color ? ` --color-${key}: ${color};` : null;\n })\n .join('\\n')}\n}\n`,\n )\n .join('\\n'),\n }}\n />\n );\n};\n\nconst ChartTooltip = RechartsPrimitive.Tooltip;\n\nconst ChartTooltipContent = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<typeof RechartsPrimitive.Tooltip> &\n React.ComponentProps<'div'> & {\n hideLabel?: boolean;\n hideIndicator?: boolean;\n indicator?: 'line' | 'dot' | 'dashed';\n nameKey?: string;\n labelKey?: string;\n }\n>(\n (\n {\n active,\n payload,\n className,\n indicator = 'dot',\n hideLabel = false,\n hideIndicator = false,\n label,\n labelFormatter,\n labelClassName,\n formatter,\n color,\n nameKey,\n labelKey,\n },\n ref,\n ) => {\n const { config } = useChart();\n\n const tooltipLabel = React.useMemo(() => {\n if (hideLabel || !payload?.length) {\n return null;\n }\n\n const [item] = payload;\n const key = `${labelKey || item?.dataKey || item?.name || 'value'}`;\n const itemConfig = getPayloadConfigFromPayload(config, item, key);\n const value =\n !labelKey && typeof label === 'string'\n ? config[label as keyof typeof config]?.label || label\n : itemConfig?.label;\n\n if (labelFormatter) {\n return <div className={cn('font-medium', labelClassName)}>{labelFormatter(value, payload)}</div>;\n }\n\n if (!value) {\n return null;\n }\n\n return <div className={cn('font-medium', labelClassName)}>{value}</div>;\n }, [label, labelFormatter, payload, hideLabel, labelClassName, config, labelKey]);\n\n if (!active || !payload?.length) {\n return null;\n }\n\n const nestLabel = payload.length === 1 && indicator !== 'dot';\n\n return (\n <div\n ref={ref}\n className={cn(\n 'grid min-w-[8rem] items-start gap-1.5 rounded-lg border border-border/50 bg-background px-2.5 py-1.5 text-xs shadow-xl',\n className,\n )}\n >\n {!nestLabel ? tooltipLabel : null}\n <div className=\"grid gap-1.5\">\n {payload\n .filter((item) => item.type !== 'none')\n .map((item, index) => {\n const key = `${nameKey || item.name || item.dataKey || 'value'}`;\n const itemConfig = getPayloadConfigFromPayload(config, item, key);\n const indicatorColor = color || item.payload.fill || item.color;\n\n return (\n <div\n key={item.dataKey}\n className={cn(\n 'flex w-full flex-wrap items-stretch gap-2 [&>svg]:h-2.5 [&>svg]:w-2.5 [&>svg]:text-muted-foreground',\n indicator === 'dot' && 'items-center',\n )}\n >\n {formatter && item?.value !== undefined && item.name ? (\n formatter(item.value, item.name, item, index, item.payload)\n ) : (\n <>\n {itemConfig?.icon ? (\n <itemConfig.icon />\n ) : (\n !hideIndicator && (\n <div\n className={cn('shrink-0 rounded-[2px] border-[--color-border] bg-[--color-bg]', {\n 'h-2.5 w-2.5': indicator === 'dot',\n 'w-1': indicator === 'line',\n 'w-0 border-[1.5px] border-dashed bg-transparent': indicator === 'dashed',\n 'my-0.5': nestLabel && indicator === 'dashed',\n })}\n style={\n {\n '--color-bg': indicatorColor,\n '--color-border': indicatorColor,\n } as React.CSSProperties\n }\n />\n )\n )}\n <div\n className={cn(\n 'flex flex-1 justify-between leading-none',\n nestLabel ? 'items-end' : 'items-center',\n )}\n >\n <div className=\"grid gap-1.5\">\n {nestLabel ? tooltipLabel : null}\n <span className=\"text-muted-foreground\">{itemConfig?.label || item.name}</span>\n </div>\n {item.value && (\n <span className=\"font-mono font-medium tabular-nums text-foreground\">\n {item.value.toLocaleString()}\n </span>\n )}\n </div>\n </>\n )}\n </div>\n );\n })}\n </div>\n </div>\n );\n },\n);\nChartTooltipContent.displayName = 'ChartTooltip';\n\nconst ChartLegend = RechartsPrimitive.Legend;\n\nconst ChartLegendContent = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<'div'> &\n Pick<RechartsPrimitive.LegendProps, 'payload' | 'verticalAlign'> & {\n hideIcon?: boolean;\n nameKey?: string;\n }\n>(({ className, hideIcon = false, payload, verticalAlign = 'bottom', nameKey }, ref) => {\n const { config } = useChart();\n\n if (!payload?.length) {\n return null;\n }\n\n return (\n <div\n ref={ref}\n className={cn('flex items-center justify-center gap-4', verticalAlign === 'top' ? 'pb-3' : 'pt-3', className)}\n >\n {payload\n .filter((item) => item.type !== 'none')\n .map((item) => {\n const key = `${nameKey || item.dataKey || 'value'}`;\n const itemConfig = getPayloadConfigFromPayload(config, item, key);\n\n return (\n <div\n key={item.value}\n className={cn('flex items-center gap-1.5 [&>svg]:h-3 [&>svg]:w-3 [&>svg]:text-muted-foreground')}\n >\n {itemConfig?.icon && !hideIcon ? (\n <itemConfig.icon />\n ) : (\n <div\n className=\"h-2 w-2 shrink-0 rounded-[2px]\"\n style={{\n backgroundColor: item.color,\n }}\n />\n )}\n {itemConfig?.label}\n </div>\n );\n })}\n </div>\n );\n});\nChartLegendContent.displayName = 'ChartLegend';\n\n// Helper to extract item config from a payload.\nfunction getPayloadConfigFromPayload(config: ChartConfig, payload: unknown, key: string) {\n if (typeof payload !== 'object' || payload === null) {\n return undefined;\n }\n\n const payloadPayload =\n 'payload' in payload && typeof payload.payload === 'object' && payload.payload !== null\n ? payload.payload\n : undefined;\n\n let configLabelKey: string = key;\n\n if (key in payload && typeof payload[key as keyof typeof payload] === 'string') {\n configLabelKey = payload[key as keyof typeof payload] as string;\n } else if (\n payloadPayload &&\n key in payloadPayload &&\n typeof payloadPayload[key as keyof typeof payloadPayload] === 'string'\n ) {\n configLabelKey = payloadPayload[key as keyof typeof payloadPayload] as string;\n }\n\n return configLabelKey in config ? config[configLabelKey] : config[key as keyof typeof config];\n}\n\nexport { ChartContainer, ChartLegend, ChartLegendContent, ChartStyle, ChartTooltip, ChartTooltipContent };\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "chart.test",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/chart.test.tsx",
|
|
9
|
-
"content": "import { render, screen } from '@testing-library/react';\nimport { Bar, BarChart, CartesianGrid, XAxis } from 'recharts';\nimport { describe, expect, it, vi } from 'vitest';\nimport { ChartContainer, ChartTooltip, ChartTooltipContent } from './chart';\n\n// Mock Recharts ResponsiveContainer to avoid ResizeObserver issues and render children immediately\nvi.mock('recharts', async (importOriginal) => {\n const original = await importOriginal();\n return {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ...(original as any),\n ResponsiveContainer: ({ children }: { children: React.ReactNode }) => (\n <div style={{ width: 500, height: 300 }}>{children}</div>\n ),\n };\n});\n\nconst chartConfig = {\n desktop: {\n label: 'Desktop',\n color: '#2563eb',\n },\n mobile: {\n label: 'Mobile',\n color: '#60a5fa',\n },\n};\n\nconst chartData = [\n { month: 'January', desktop: 186, mobile: 80 },\n { month: 'February', desktop: 305, mobile: 200 },\n];\n\ndescribe('Chart', () => {\n it('renders correctly', () => {\n render(\n <ChartContainer config={chartConfig} className=\"min-h-[200px] w-full\">\n <BarChart accessibilityLayer data={chartData} width={500} height={300}>\n <CartesianGrid vertical={false} />\n <XAxis\n dataKey=\"month\"\n tickLine={false}\n tickMargin={10}\n axisLine={false}\n tickFormatter={(value) => value.slice(0, 3)}\n />\n <ChartTooltip content={<ChartTooltipContent />} />\n <Bar dataKey=\"desktop\" fill=\"var(--color-desktop)\" radius={4} />\n <Bar dataKey=\"mobile\" fill=\"var(--color-mobile)\" radius={4} />\n </BarChart>\n </ChartContainer>,\n );\n\n // Recharts renders SVGs. We can check if the container renders.\n // The accessibilityLayer prop on BarChart adds role=\"application\" or similar?\n // Let's check for the chart container.\n // The ChartContainer adds data-chart attribute.\n // But we can check for text.\n expect(screen.getByText('Jan')).toBeInTheDocument();\n expect(screen.getByText('Feb')).toBeInTheDocument();\n });\n});\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "checkbox",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/checkbox.tsx",
|
|
9
|
-
"content": "import * as CheckboxPrimitive from '@radix-ui/react-checkbox';\nimport { Check } from 'lucide-react';\nimport * as React from 'react';\n\nimport { cn } from '@/lib/utils';\n\nconst Checkbox = React.forwardRef<\n React.ElementRef<typeof CheckboxPrimitive.Root>,\n React.ComponentPropsWithoutRef<typeof CheckboxPrimitive.Root>\n>(({ className, ...props }, ref) => (\n <CheckboxPrimitive.Root\n ref={ref}\n className={cn(\n 'grid place-content-center peer h-4 w-4 shrink-0 rounded-sm border border-primary shadow focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground',\n className,\n )}\n {...props}\n >\n <CheckboxPrimitive.Indicator className={cn('grid place-content-center text-current')}>\n <Check className=\"h-4 w-4\" />\n </CheckboxPrimitive.Indicator>\n </CheckboxPrimitive.Root>\n));\nCheckbox.displayName = CheckboxPrimitive.Root.displayName;\n\nexport { Checkbox };\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "checkbox.test",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/checkbox.test.tsx",
|
|
9
|
-
"content": "import { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport { describe, expect, it } from 'vitest';\nimport { Checkbox } from './checkbox';\n\ndescribe('Checkbox', () => {\n it('renders correctly', () => {\n render(<Checkbox />);\n expect(screen.getByRole('checkbox')).toBeInTheDocument();\n });\n\n it('toggles checked state on click', async () => {\n const user = userEvent.setup();\n render(<Checkbox />);\n\n const checkbox = screen.getByRole('checkbox');\n expect(checkbox).not.toBeChecked();\n\n await user.click(checkbox);\n expect(checkbox).toBeChecked();\n\n await user.click(checkbox);\n expect(checkbox).not.toBeChecked();\n });\n\n it('renders disabled state', () => {\n render(<Checkbox disabled />);\n expect(screen.getByRole('checkbox')).toBeDisabled();\n });\n});\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "collapsible",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/collapsible.tsx",
|
|
9
|
-
"content": "import * as CollapsiblePrimitive from '@radix-ui/react-collapsible';\n\nconst Collapsible = CollapsiblePrimitive.Root;\n\nconst CollapsibleTrigger = CollapsiblePrimitive.CollapsibleTrigger;\n\nconst CollapsibleContent = CollapsiblePrimitive.CollapsibleContent;\n\nexport { Collapsible, CollapsibleContent, CollapsibleTrigger };\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "collapsible.test",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/collapsible.test.tsx",
|
|
9
|
-
"content": "import { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport { describe, expect, it } from 'vitest';\nimport { Collapsible, CollapsibleContent, CollapsibleTrigger } from './collapsible';\n\ndescribe('Collapsible', () => {\n it('renders correctly', () => {\n render(\n <Collapsible>\n <CollapsibleTrigger>Toggle</CollapsibleTrigger>\n <CollapsibleContent>Content</CollapsibleContent>\n </Collapsible>,\n );\n\n expect(screen.getByRole('button', { name: 'Toggle' })).toBeInTheDocument();\n });\n\n it('toggles content visibility', async () => {\n const user = userEvent.setup();\n render(\n <Collapsible>\n <CollapsibleTrigger>Toggle</CollapsibleTrigger>\n <CollapsibleContent>Content</CollapsibleContent>\n </Collapsible>,\n );\n\n const trigger = screen.getByRole('button', { name: 'Toggle' });\n\n // Initial state: Content might be hidden or not present depending on implementation details of Radix\n // But Radix Collapsible adds data-state attribute\n expect(trigger).toHaveAttribute('data-state', 'closed');\n\n await user.click(trigger);\n expect(trigger).toHaveAttribute('data-state', 'open');\n expect(screen.getByText('Content')).toBeVisible();\n\n await user.click(trigger);\n expect(trigger).toHaveAttribute('data-state', 'closed');\n });\n\n it('renders open by default', () => {\n render(\n <Collapsible defaultOpen>\n <CollapsibleTrigger>Toggle</CollapsibleTrigger>\n <CollapsibleContent>Content</CollapsibleContent>\n </Collapsible>,\n );\n expect(screen.getByRole('button', { name: 'Toggle' })).toHaveAttribute('data-state', 'open');\n expect(screen.getByText('Content')).toBeVisible();\n });\n});\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "command",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/command.tsx",
|
|
9
|
-
"content": "'use client';\n\nimport { type DialogProps } from '@radix-ui/react-dialog';\nimport { Command as CommandPrimitive } from 'cmdk';\nimport { Search } from 'lucide-react';\nimport * as React from 'react';\n\nimport { Dialog, DialogContent } from '@/components/ui/dialog';\nimport { cn } from '@/lib/utils';\n\nconst Command = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive\n ref={ref}\n className={cn(\n 'flex h-full w-full flex-col overflow-hidden rounded-md bg-popover text-popover-foreground',\n className,\n )}\n {...props}\n />\n));\nCommand.displayName = CommandPrimitive.displayName;\n\nconst CommandDialog = ({ children, ...props }: DialogProps) => {\n return (\n <Dialog {...props}>\n <DialogContent className=\"overflow-hidden p-0\">\n <Command className=\"[&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground [&_[cmdk-group]:not([hidden])_~[cmdk-group]]:pt-0 [&_[cmdk-group]]:px-2 [&_[cmdk-input-wrapper]_svg]:h-5 [&_[cmdk-input-wrapper]_svg]:w-5 [&_[cmdk-input]]:h-12 [&_[cmdk-item]]:px-2 [&_[cmdk-item]]:py-3 [&_[cmdk-item]_svg]:h-5 [&_[cmdk-item]_svg]:w-5\">\n {children}\n </Command>\n </DialogContent>\n </Dialog>\n );\n};\n\nconst CommandInput = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Input>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Input>\n>(({ className, ...props }, ref) => (\n <div className=\"flex items-center border-b px-3\" cmdk-input-wrapper=\"\">\n <Search className=\"mr-2 h-4 w-4 shrink-0 opacity-50\" />\n <CommandPrimitive.Input\n ref={ref}\n className={cn(\n 'flex h-10 w-full rounded-md bg-transparent py-3 text-sm outline-none placeholder:text-muted-foreground disabled:cursor-not-allowed disabled:opacity-50',\n className,\n )}\n {...props}\n />\n </div>\n));\n\nCommandInput.displayName = CommandPrimitive.Input.displayName;\n\nconst CommandList = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.List>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.List>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.List\n ref={ref}\n className={cn('max-h-[300px] overflow-y-auto overflow-x-hidden', className)}\n {...props}\n />\n));\n\nCommandList.displayName = CommandPrimitive.List.displayName;\n\nconst CommandEmpty = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Empty>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Empty>\n>((props, ref) => <CommandPrimitive.Empty ref={ref} className=\"py-6 text-center text-sm\" {...props} />);\n\nCommandEmpty.displayName = CommandPrimitive.Empty.displayName;\n\nconst CommandGroup = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Group>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Group>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.Group\n ref={ref}\n className={cn(\n 'overflow-hidden p-1 text-foreground [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground',\n className,\n )}\n {...props}\n />\n));\n\nCommandGroup.displayName = CommandPrimitive.Group.displayName;\n\nconst CommandSeparator = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Separator>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Separator>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.Separator ref={ref} className={cn('-mx-1 h-px bg-border', className)} {...props} />\n));\nCommandSeparator.displayName = CommandPrimitive.Separator.displayName;\n\nconst CommandItem = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Item>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Item>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.Item\n ref={ref}\n className={cn(\n 'relative flex cursor-default gap-2 select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none data-[disabled=true]:pointer-events-none data-[selected=true]:bg-accent data-[selected=true]:text-accent-foreground data-[disabled=true]:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0',\n className,\n )}\n {...props}\n />\n));\n\nCommandItem.displayName = CommandPrimitive.Item.displayName;\n\nconst CommandShortcut = ({ className, ...props }: React.HTMLAttributes<HTMLSpanElement>) => {\n return <span className={cn('ml-auto text-xs tracking-widest text-muted-foreground', className)} {...props} />;\n};\nCommandShortcut.displayName = 'CommandShortcut';\n\nexport {\n Command,\n CommandDialog,\n CommandEmpty,\n CommandGroup,\n CommandInput,\n CommandItem,\n CommandList,\n CommandSeparator,\n CommandShortcut,\n};\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "command.test",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/command.test.tsx",
|
|
9
|
-
"content": "import { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport { describe, expect, it } from 'vitest';\nimport { Command, CommandEmpty, CommandGroup, CommandInput, CommandItem, CommandList } from './command';\n\ndescribe('Command', () => {\n it('renders correctly', () => {\n render(\n <Command>\n <CommandInput placeholder=\"Search...\" />\n <CommandList>\n <CommandEmpty>No results found.</CommandEmpty>\n <CommandGroup heading=\"Suggestions\">\n <CommandItem>Calendar</CommandItem>\n <CommandItem>Search Emoji</CommandItem>\n <CommandItem>Calculator</CommandItem>\n </CommandGroup>\n </CommandList>\n </Command>,\n );\n\n expect(screen.getByPlaceholderText('Search...')).toBeInTheDocument();\n expect(screen.getByText('Suggestions')).toBeInTheDocument();\n expect(screen.getByText('Calendar')).toBeInTheDocument();\n });\n\n it('filters items based on input', async () => {\n const user = userEvent.setup();\n render(\n <Command>\n <CommandInput placeholder=\"Search...\" />\n <CommandList>\n <CommandGroup heading=\"Suggestions\">\n <CommandItem>Calendar</CommandItem>\n <CommandItem>Search Emoji</CommandItem>\n <CommandItem>Calculator</CommandItem>\n </CommandGroup>\n </CommandList>\n </Command>,\n );\n\n const input = screen.getByPlaceholderText('Search...');\n await user.type(input, 'Cal');\n\n expect(screen.getByText('Calendar')).toBeVisible();\n expect(screen.getByText('Calculator')).toBeVisible();\n // search emoji should be filtered out\n // Note: cmdk might just hide items, so we check if they are visible or not\n // or checks class names.\n // Let's check if Search Emoji is not visible or removed\n const emoji = screen.queryByText('Search Emoji');\n // If it's still in document but hidden, we check visibility\n if (emoji) {\n expect(emoji).not.toBeVisible();\n } else {\n expect(emoji).not.toBeInTheDocument();\n }\n });\n\n it('shows empty state when no results', async () => {\n const user = userEvent.setup();\n render(\n <Command>\n <CommandInput placeholder=\"Search...\" />\n <CommandList>\n <CommandEmpty>No results found.</CommandEmpty>\n <CommandGroup heading=\"Suggestions\">\n <CommandItem>Calendar</CommandItem>\n </CommandGroup>\n </CommandList>\n </Command>,\n );\n\n const input = screen.getByPlaceholderText('Search...');\n await user.type(input, 'XYZ');\n\n expect(screen.getByText('No results found.')).toBeVisible();\n });\n});\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "context-menu",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/context-menu.tsx",
|
|
9
|
-
"content": "import * as ContextMenuPrimitive from '@radix-ui/react-context-menu';\nimport { Check, ChevronRight, Circle } from 'lucide-react';\nimport * as React from 'react';\n\nimport { cn } from '@/lib/utils';\n\nconst ContextMenu = ContextMenuPrimitive.Root;\n\nconst ContextMenuTrigger = ContextMenuPrimitive.Trigger;\n\nconst ContextMenuGroup = ContextMenuPrimitive.Group;\n\nconst ContextMenuPortal = ContextMenuPrimitive.Portal;\n\nconst ContextMenuSub = ContextMenuPrimitive.Sub;\n\nconst ContextMenuRadioGroup = ContextMenuPrimitive.RadioGroup;\n\nconst ContextMenuSubTrigger = React.forwardRef<\n React.ElementRef<typeof ContextMenuPrimitive.SubTrigger>,\n React.ComponentPropsWithoutRef<typeof ContextMenuPrimitive.SubTrigger> & {\n inset?: boolean;\n }\n>(({ className, inset, children, ...props }, ref) => (\n <ContextMenuPrimitive.SubTrigger\n ref={ref}\n className={cn(\n 'flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[state=open]:bg-accent data-[state=open]:text-accent-foreground',\n inset && 'pl-8',\n className,\n )}\n {...props}\n >\n {children}\n <ChevronRight className=\"ml-auto h-4 w-4\" />\n </ContextMenuPrimitive.SubTrigger>\n));\nContextMenuSubTrigger.displayName = ContextMenuPrimitive.SubTrigger.displayName;\n\nconst ContextMenuSubContent = React.forwardRef<\n React.ElementRef<typeof ContextMenuPrimitive.SubContent>,\n React.ComponentPropsWithoutRef<typeof ContextMenuPrimitive.SubContent>\n>(({ className, ...props }, ref) => (\n <ContextMenuPrimitive.SubContent\n ref={ref}\n className={cn(\n 'z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-lg data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 origin-[--radix-context-menu-content-transform-origin]',\n className,\n )}\n {...props}\n />\n));\nContextMenuSubContent.displayName = ContextMenuPrimitive.SubContent.displayName;\n\nconst ContextMenuContent = React.forwardRef<\n React.ElementRef<typeof ContextMenuPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof ContextMenuPrimitive.Content>\n>(({ className, ...props }, ref) => (\n <ContextMenuPrimitive.Portal>\n <ContextMenuPrimitive.Content\n ref={ref}\n className={cn(\n 'z-50 max-h-[--radix-context-menu-content-available-height] min-w-[8rem] overflow-y-auto overflow-x-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-md data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 origin-[--radix-context-menu-content-transform-origin]',\n className,\n )}\n {...props}\n />\n </ContextMenuPrimitive.Portal>\n));\nContextMenuContent.displayName = ContextMenuPrimitive.Content.displayName;\n\nconst ContextMenuItem = React.forwardRef<\n React.ElementRef<typeof ContextMenuPrimitive.Item>,\n React.ComponentPropsWithoutRef<typeof ContextMenuPrimitive.Item> & {\n inset?: boolean;\n }\n>(({ className, inset, ...props }, ref) => (\n <ContextMenuPrimitive.Item\n ref={ref}\n className={cn(\n 'relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50',\n inset && 'pl-8',\n className,\n )}\n {...props}\n />\n));\nContextMenuItem.displayName = ContextMenuPrimitive.Item.displayName;\n\nconst ContextMenuCheckboxItem = React.forwardRef<\n React.ElementRef<typeof ContextMenuPrimitive.CheckboxItem>,\n React.ComponentPropsWithoutRef<typeof ContextMenuPrimitive.CheckboxItem>\n>(({ className, children, checked, ...props }, ref) => (\n <ContextMenuPrimitive.CheckboxItem\n ref={ref}\n className={cn(\n 'relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50',\n className,\n )}\n checked={checked}\n {...props}\n >\n <span className=\"absolute left-2 flex h-3.5 w-3.5 items-center justify-center\">\n <ContextMenuPrimitive.ItemIndicator>\n <Check className=\"h-4 w-4\" />\n </ContextMenuPrimitive.ItemIndicator>\n </span>\n {children}\n </ContextMenuPrimitive.CheckboxItem>\n));\nContextMenuCheckboxItem.displayName = ContextMenuPrimitive.CheckboxItem.displayName;\n\nconst ContextMenuRadioItem = React.forwardRef<\n React.ElementRef<typeof ContextMenuPrimitive.RadioItem>,\n React.ComponentPropsWithoutRef<typeof ContextMenuPrimitive.RadioItem>\n>(({ className, children, ...props }, ref) => (\n <ContextMenuPrimitive.RadioItem\n ref={ref}\n className={cn(\n 'relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50',\n className,\n )}\n {...props}\n >\n <span className=\"absolute left-2 flex h-3.5 w-3.5 items-center justify-center\">\n <ContextMenuPrimitive.ItemIndicator>\n <Circle className=\"h-4 w-4 fill-current\" />\n </ContextMenuPrimitive.ItemIndicator>\n </span>\n {children}\n </ContextMenuPrimitive.RadioItem>\n));\nContextMenuRadioItem.displayName = ContextMenuPrimitive.RadioItem.displayName;\n\nconst ContextMenuLabel = React.forwardRef<\n React.ElementRef<typeof ContextMenuPrimitive.Label>,\n React.ComponentPropsWithoutRef<typeof ContextMenuPrimitive.Label> & {\n inset?: boolean;\n }\n>(({ className, inset, ...props }, ref) => (\n <ContextMenuPrimitive.Label\n ref={ref}\n className={cn('px-2 py-1.5 text-sm font-semibold text-foreground', inset && 'pl-8', className)}\n {...props}\n />\n));\nContextMenuLabel.displayName = ContextMenuPrimitive.Label.displayName;\n\nconst ContextMenuSeparator = React.forwardRef<\n React.ElementRef<typeof ContextMenuPrimitive.Separator>,\n React.ComponentPropsWithoutRef<typeof ContextMenuPrimitive.Separator>\n>(({ className, ...props }, ref) => (\n <ContextMenuPrimitive.Separator ref={ref} className={cn('-mx-1 my-1 h-px bg-border', className)} {...props} />\n));\nContextMenuSeparator.displayName = ContextMenuPrimitive.Separator.displayName;\n\nconst ContextMenuShortcut = ({ className, ...props }: React.HTMLAttributes<HTMLSpanElement>) => {\n return <span className={cn('ml-auto text-xs tracking-widest text-muted-foreground', className)} {...props} />;\n};\nContextMenuShortcut.displayName = 'ContextMenuShortcut';\n\nexport {\n ContextMenu,\n ContextMenuCheckboxItem,\n ContextMenuContent,\n ContextMenuGroup,\n ContextMenuItem,\n ContextMenuLabel,\n ContextMenuPortal,\n ContextMenuRadioGroup,\n ContextMenuRadioItem,\n ContextMenuSeparator,\n ContextMenuShortcut,\n ContextMenuSub,\n ContextMenuSubContent,\n ContextMenuSubTrigger,\n ContextMenuTrigger,\n};\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "context-menu.test",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/context-menu.test.tsx",
|
|
9
|
-
"content": "import { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport { describe, expect, it } from 'vitest';\nimport { ContextMenu, ContextMenuContent, ContextMenuItem, ContextMenuTrigger } from './context-menu';\n\ndescribe('ContextMenu', () => {\n it('renders trigger', () => {\n render(\n <ContextMenu>\n <ContextMenuTrigger>Right click here</ContextMenuTrigger>\n <ContextMenuContent>\n <ContextMenuItem>Item 1</ContextMenuItem>\n </ContextMenuContent>\n </ContextMenu>,\n );\n\n expect(screen.getByText('Right click here')).toBeInTheDocument();\n });\n\n it('shows menu on right click', async () => {\n const user = userEvent.setup();\n render(\n <ContextMenu>\n <ContextMenuTrigger>Right click here</ContextMenuTrigger>\n <ContextMenuContent>\n <ContextMenuItem>Item 1</ContextMenuItem>\n </ContextMenuContent>\n </ContextMenu>,\n );\n\n const trigger = screen.getByText('Right click here');\n await user.pointer({ keys: '[MouseRight]', target: trigger });\n\n // Ensure item is visible. Radix UI ContextMenu might render it in a portal.\n expect(screen.getByText('Item 1')).toBeVisible();\n });\n});\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "dialog",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/dialog.tsx",
|
|
9
|
-
"content": "import * as DialogPrimitive from '@radix-ui/react-dialog';\nimport { X } from 'lucide-react';\nimport * as React from 'react';\n\nimport { cn } from '@/lib/utils';\n\nconst Dialog = DialogPrimitive.Root;\n\nconst DialogTrigger = DialogPrimitive.Trigger;\n\nconst DialogPortal = DialogPrimitive.Portal;\n\nconst DialogClose = DialogPrimitive.Close;\n\nconst DialogOverlay = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Overlay>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Overlay>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Overlay\n ref={ref}\n className={cn(\n 'fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0',\n className,\n )}\n {...props}\n />\n));\nDialogOverlay.displayName = DialogPrimitive.Overlay.displayName;\n\nconst DialogContent = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Content>\n>(({ className, children, ...props }, ref) => (\n <DialogPortal>\n <DialogOverlay />\n <DialogPrimitive.Content\n ref={ref}\n className={cn(\n 'fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg',\n className,\n )}\n {...props}\n >\n {children}\n <DialogPrimitive.Close className=\"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground\">\n <X className=\"h-4 w-4\" />\n <span className=\"sr-only\">Close</span>\n </DialogPrimitive.Close>\n </DialogPrimitive.Content>\n </DialogPortal>\n));\nDialogContent.displayName = DialogPrimitive.Content.displayName;\n\nconst DialogHeader = ({ className, ...props }: React.HTMLAttributes<HTMLDivElement>) => (\n <div className={cn('flex flex-col space-y-1.5 text-center sm:text-left', className)} {...props} />\n);\nDialogHeader.displayName = 'DialogHeader';\n\nconst DialogFooter = ({ className, ...props }: React.HTMLAttributes<HTMLDivElement>) => (\n <div className={cn('flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2', className)} {...props} />\n);\nDialogFooter.displayName = 'DialogFooter';\n\nconst DialogTitle = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Title>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Title>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Title\n ref={ref}\n className={cn('text-lg font-semibold leading-none tracking-tight', className)}\n {...props}\n />\n));\nDialogTitle.displayName = DialogPrimitive.Title.displayName;\n\nconst DialogDescription = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Description>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Description>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Description ref={ref} className={cn('text-sm text-muted-foreground', className)} {...props} />\n));\nDialogDescription.displayName = DialogPrimitive.Description.displayName;\n\nexport {\n Dialog,\n DialogClose,\n DialogContent,\n DialogDescription,\n DialogFooter,\n DialogHeader,\n DialogOverlay,\n DialogPortal,\n DialogTitle,\n DialogTrigger,\n};\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "dialog.test",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/dialog.test.tsx",
|
|
9
|
-
"content": "import { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport { describe, expect, it } from 'vitest';\nimport {\n Dialog,\n DialogClose,\n DialogContent,\n DialogDescription,\n DialogFooter,\n DialogHeader,\n DialogTitle,\n DialogTrigger,\n} from './dialog';\n\ndescribe('Dialog', () => {\n it('renders trigger correctly', () => {\n render(\n <Dialog>\n <DialogTrigger>Open Dialog</DialogTrigger>\n <DialogContent>\n <DialogHeader>\n <DialogTitle>Title</DialogTitle>\n <DialogDescription>Description</DialogDescription>\n </DialogHeader>\n </DialogContent>\n </Dialog>,\n );\n\n expect(screen.getByText('Open Dialog')).toBeInTheDocument();\n });\n\n it('opens and closes the dialog', async () => {\n const user = userEvent.setup();\n render(\n <Dialog>\n <DialogTrigger>Open Dialog</DialogTrigger>\n <DialogContent>\n <DialogHeader>\n <DialogTitle>Are you sure absolutely sure?</DialogTitle>\n <DialogDescription>This action cannot be undone.</DialogDescription>\n </DialogHeader>\n <DialogFooter>\n <DialogClose>Close Dialog</DialogClose>\n </DialogFooter>\n </DialogContent>\n </Dialog>,\n );\n\n // Dialog content should not be visible initially (or not in document)\n expect(screen.queryByText('Are you sure absolutely sure?')).not.toBeInTheDocument();\n\n // Open dialog\n await user.click(screen.getByText('Open Dialog'));\n\n expect(screen.getByRole('dialog')).toBeInTheDocument();\n expect(screen.getByText('Are you sure absolutely sure?')).toBeVisible();\n\n // Close dialog\n // We can use the close button we added\n await user.click(screen.getByText('Close Dialog'));\n\n // Should be closed\n // Radix UI Dialog unmounts content when closed\n expect(screen.queryByText('Are you sure absolutely sure?')).not.toBeInTheDocument();\n });\n});\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "drawer",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/drawer.tsx",
|
|
9
|
-
"content": "import * as React from 'react';\nimport { Drawer as DrawerPrimitive } from 'vaul';\n\nimport { cn } from '@/lib/utils';\n\nconst Drawer = ({ shouldScaleBackground = true, ...props }: React.ComponentProps<typeof DrawerPrimitive.Root>) => (\n <DrawerPrimitive.Root shouldScaleBackground={shouldScaleBackground} {...props} />\n);\nDrawer.displayName = 'Drawer';\n\nconst DrawerTrigger = DrawerPrimitive.Trigger;\n\nconst DrawerPortal = DrawerPrimitive.Portal;\n\nconst DrawerClose = DrawerPrimitive.Close;\n\nconst DrawerOverlay = React.forwardRef<\n React.ElementRef<typeof DrawerPrimitive.Overlay>,\n React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Overlay>\n>(({ className, ...props }, ref) => (\n <DrawerPrimitive.Overlay ref={ref} className={cn('fixed inset-0 z-50 bg-black/80', className)} {...props} />\n));\nDrawerOverlay.displayName = DrawerPrimitive.Overlay.displayName;\n\nconst DrawerContent = React.forwardRef<\n React.ElementRef<typeof DrawerPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Content>\n>(({ className, children, ...props }, ref) => (\n <DrawerPortal>\n <DrawerOverlay />\n <DrawerPrimitive.Content\n ref={ref}\n className={cn(\n 'fixed inset-x-0 bottom-0 z-50 mt-24 flex h-auto flex-col rounded-t-[10px] border bg-background',\n className,\n )}\n {...props}\n >\n <div className=\"mx-auto mt-4 h-2 w-[100px] rounded-full bg-muted\" />\n {children}\n </DrawerPrimitive.Content>\n </DrawerPortal>\n));\nDrawerContent.displayName = 'DrawerContent';\n\nconst DrawerHeader = ({ className, ...props }: React.HTMLAttributes<HTMLDivElement>) => (\n <div className={cn('grid gap-1.5 p-4 text-center sm:text-left', className)} {...props} />\n);\nDrawerHeader.displayName = 'DrawerHeader';\n\nconst DrawerFooter = ({ className, ...props }: React.HTMLAttributes<HTMLDivElement>) => (\n <div className={cn('mt-auto flex flex-col gap-2 p-4', className)} {...props} />\n);\nDrawerFooter.displayName = 'DrawerFooter';\n\nconst DrawerTitle = React.forwardRef<\n React.ElementRef<typeof DrawerPrimitive.Title>,\n React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Title>\n>(({ className, ...props }, ref) => (\n <DrawerPrimitive.Title\n ref={ref}\n className={cn('text-lg font-semibold leading-none tracking-tight', className)}\n {...props}\n />\n));\nDrawerTitle.displayName = DrawerPrimitive.Title.displayName;\n\nconst DrawerDescription = React.forwardRef<\n React.ElementRef<typeof DrawerPrimitive.Description>,\n React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Description>\n>(({ className, ...props }, ref) => (\n <DrawerPrimitive.Description ref={ref} className={cn('text-sm text-muted-foreground', className)} {...props} />\n));\nDrawerDescription.displayName = DrawerPrimitive.Description.displayName;\n\nexport {\n Drawer,\n DrawerClose,\n DrawerContent,\n DrawerDescription,\n DrawerFooter,\n DrawerHeader,\n DrawerOverlay,\n DrawerPortal,\n DrawerTitle,\n DrawerTrigger,\n};\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "drawer.test",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/drawer.test.tsx",
|
|
9
|
-
"content": "import { render, screen } from '@testing-library/react';\nimport { describe, expect, it, vi } from 'vitest';\nimport {\n Drawer,\n DrawerClose,\n DrawerContent,\n DrawerDescription,\n DrawerFooter,\n DrawerHeader,\n DrawerTitle,\n DrawerTrigger,\n} from './drawer';\n\n// Mock vaul components to avoid jsdom issues\nvi.mock('./drawer', () => {\n return {\n Drawer: ({ children }: { children: React.ReactNode }) => <div>{children}</div>,\n DrawerTrigger: ({ children }: { children: React.ReactNode }) => <button>{children}</button>,\n DrawerContent: ({ children }: { children: React.ReactNode }) => <div>{children}</div>,\n DrawerHeader: ({ children }: { children: React.ReactNode }) => <div>{children}</div>,\n DrawerTitle: ({ children }: { children: React.ReactNode }) => <h1>{children}</h1>,\n DrawerDescription: ({ children }: { children: React.ReactNode }) => <p>{children}</p>,\n DrawerFooter: ({ children }: { children: React.ReactNode }) => <footer>{children}</footer>,\n DrawerClose: ({ children }: { children: React.ReactNode }) => <button>{children}</button>,\n };\n});\n\ndescribe('Drawer', () => {\n it('renders correctly', () => {\n render(\n <Drawer>\n <DrawerTrigger>Open Drawer</DrawerTrigger>\n <DrawerContent>\n <DrawerHeader>\n <DrawerTitle>Title</DrawerTitle>\n <DrawerDescription>Description</DrawerDescription>\n </DrawerHeader>\n </DrawerContent>\n </Drawer>,\n );\n\n expect(screen.getByText('Open Drawer')).toBeInTheDocument();\n });\n\n it('opens and closes the drawer', async () => {\n // With mocked components, we just verify they render their children.\n // Real interaction testing for vaul is best done in e2e tests.\n render(\n <Drawer>\n <DrawerTrigger>Open Drawer</DrawerTrigger>\n <DrawerContent>\n <DrawerHeader>\n <DrawerTitle>Drawer Title</DrawerTitle>\n <DrawerDescription>Drawer Description</DrawerDescription>\n </DrawerHeader>\n <DrawerFooter>\n <DrawerClose>Close</DrawerClose>\n </DrawerFooter>\n </DrawerContent>\n </Drawer>,\n );\n\n expect(screen.getByText('Open Drawer')).toBeInTheDocument();\n expect(screen.getByText('Drawer Title')).toBeInTheDocument();\n expect(screen.getByText('Drawer Description')).toBeInTheDocument();\n expect(screen.getByText('Close')).toBeInTheDocument();\n });\n});\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "dropdown-menu",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/dropdown-menu.tsx",
|
|
9
|
-
"content": "import * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';\nimport { Check, ChevronRight, Circle } from 'lucide-react';\nimport * as React from 'react';\n\nimport { cn } from '@/lib/utils';\n\nconst DropdownMenu = DropdownMenuPrimitive.Root;\n\nconst DropdownMenuTrigger = DropdownMenuPrimitive.Trigger;\n\nconst DropdownMenuGroup = DropdownMenuPrimitive.Group;\n\nconst DropdownMenuPortal = DropdownMenuPrimitive.Portal;\n\nconst DropdownMenuSub = DropdownMenuPrimitive.Sub;\n\nconst DropdownMenuRadioGroup = DropdownMenuPrimitive.RadioGroup;\n\nconst DropdownMenuSubTrigger = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.SubTrigger>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.SubTrigger> & {\n inset?: boolean;\n }\n>(({ className, inset, children, ...props }, ref) => (\n <DropdownMenuPrimitive.SubTrigger\n ref={ref}\n className={cn(\n 'flex cursor-default select-none items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent data-[state=open]:bg-accent [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0',\n inset && 'pl-8',\n className,\n )}\n {...props}\n >\n {children}\n <ChevronRight className=\"ml-auto\" />\n </DropdownMenuPrimitive.SubTrigger>\n));\nDropdownMenuSubTrigger.displayName = DropdownMenuPrimitive.SubTrigger.displayName;\n\nconst DropdownMenuSubContent = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.SubContent>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.SubContent>\n>(({ className, ...props }, ref) => (\n <DropdownMenuPrimitive.SubContent\n ref={ref}\n className={cn(\n 'z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-lg data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 origin-[--radix-dropdown-menu-content-transform-origin]',\n className,\n )}\n {...props}\n />\n));\nDropdownMenuSubContent.displayName = DropdownMenuPrimitive.SubContent.displayName;\n\nconst DropdownMenuContent = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Content>\n>(({ className, sideOffset = 4, ...props }, ref) => (\n <DropdownMenuPrimitive.Portal>\n <DropdownMenuPrimitive.Content\n ref={ref}\n sideOffset={sideOffset}\n className={cn(\n 'z-50 max-h-[var(--radix-dropdown-menu-content-available-height)] min-w-[8rem] overflow-y-auto overflow-x-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-md',\n 'data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 origin-[--radix-dropdown-menu-content-transform-origin]',\n className,\n )}\n {...props}\n />\n </DropdownMenuPrimitive.Portal>\n));\nDropdownMenuContent.displayName = DropdownMenuPrimitive.Content.displayName;\n\nconst DropdownMenuItem = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.Item>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Item> & {\n inset?: boolean;\n }\n>(({ className, inset, ...props }, ref) => (\n <DropdownMenuPrimitive.Item\n ref={ref}\n className={cn(\n 'relative flex cursor-default select-none items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&>svg]:size-4 [&>svg]:shrink-0',\n inset && 'pl-8',\n className,\n )}\n {...props}\n />\n));\nDropdownMenuItem.displayName = DropdownMenuPrimitive.Item.displayName;\n\nconst DropdownMenuCheckboxItem = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.CheckboxItem>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.CheckboxItem>\n>(({ className, children, checked, ...props }, ref) => (\n <DropdownMenuPrimitive.CheckboxItem\n ref={ref}\n className={cn(\n 'relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50',\n className,\n )}\n checked={checked}\n {...props}\n >\n <span className=\"absolute left-2 flex h-3.5 w-3.5 items-center justify-center\">\n <DropdownMenuPrimitive.ItemIndicator>\n <Check className=\"h-4 w-4\" />\n </DropdownMenuPrimitive.ItemIndicator>\n </span>\n {children}\n </DropdownMenuPrimitive.CheckboxItem>\n));\nDropdownMenuCheckboxItem.displayName = DropdownMenuPrimitive.CheckboxItem.displayName;\n\nconst DropdownMenuRadioItem = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.RadioItem>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.RadioItem>\n>(({ className, children, ...props }, ref) => (\n <DropdownMenuPrimitive.RadioItem\n ref={ref}\n className={cn(\n 'relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50',\n className,\n )}\n {...props}\n >\n <span className=\"absolute left-2 flex h-3.5 w-3.5 items-center justify-center\">\n <DropdownMenuPrimitive.ItemIndicator>\n <Circle className=\"h-2 w-2 fill-current\" />\n </DropdownMenuPrimitive.ItemIndicator>\n </span>\n {children}\n </DropdownMenuPrimitive.RadioItem>\n));\nDropdownMenuRadioItem.displayName = DropdownMenuPrimitive.RadioItem.displayName;\n\nconst DropdownMenuLabel = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.Label>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Label> & {\n inset?: boolean;\n }\n>(({ className, inset, ...props }, ref) => (\n <DropdownMenuPrimitive.Label\n ref={ref}\n className={cn('px-2 py-1.5 text-sm font-semibold', inset && 'pl-8', className)}\n {...props}\n />\n));\nDropdownMenuLabel.displayName = DropdownMenuPrimitive.Label.displayName;\n\nconst DropdownMenuSeparator = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.Separator>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Separator>\n>(({ className, ...props }, ref) => (\n <DropdownMenuPrimitive.Separator ref={ref} className={cn('-mx-1 my-1 h-px bg-muted', className)} {...props} />\n));\nDropdownMenuSeparator.displayName = DropdownMenuPrimitive.Separator.displayName;\n\nconst DropdownMenuShortcut = ({ className, ...props }: React.HTMLAttributes<HTMLSpanElement>) => {\n return <span className={cn('ml-auto text-xs tracking-widest opacity-60', className)} {...props} />;\n};\nDropdownMenuShortcut.displayName = 'DropdownMenuShortcut';\n\nexport {\n DropdownMenu,\n DropdownMenuCheckboxItem,\n DropdownMenuContent,\n DropdownMenuGroup,\n DropdownMenuItem,\n DropdownMenuLabel,\n DropdownMenuPortal,\n DropdownMenuRadioGroup,\n DropdownMenuRadioItem,\n DropdownMenuSeparator,\n DropdownMenuShortcut,\n DropdownMenuSub,\n DropdownMenuSubContent,\n DropdownMenuSubTrigger,\n DropdownMenuTrigger,\n};\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "dropdown-menu.test",
|
|
3
|
-
"type": "registry:ui",
|
|
4
|
-
"dependencies": [],
|
|
5
|
-
"registryDependencies": [],
|
|
6
|
-
"files": [
|
|
7
|
-
{
|
|
8
|
-
"path": "ui/dropdown-menu.test.tsx",
|
|
9
|
-
"content": "import { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport { describe, expect, it } from 'vitest';\nimport {\n DropdownMenu,\n DropdownMenuCheckboxItem,\n DropdownMenuContent,\n DropdownMenuItem,\n DropdownMenuLabel,\n DropdownMenuRadioGroup,\n DropdownMenuRadioItem,\n DropdownMenuSeparator,\n DropdownMenuTrigger,\n} from './dropdown-menu';\n\ndescribe('DropdownMenu', () => {\n it('renders trigger correctly', () => {\n render(\n <DropdownMenu>\n <DropdownMenuTrigger>Open Menu</DropdownMenuTrigger>\n <DropdownMenuContent>\n <DropdownMenuItem>Item 1</DropdownMenuItem>\n </DropdownMenuContent>\n </DropdownMenu>,\n );\n\n expect(screen.getByText('Open Menu')).toBeInTheDocument();\n });\n\n it('opens menu on click', async () => {\n const user = userEvent.setup();\n render(\n <DropdownMenu>\n <DropdownMenuTrigger>Open Menu</DropdownMenuTrigger>\n <DropdownMenuContent>\n <DropdownMenuLabel>My Account</DropdownMenuLabel>\n <DropdownMenuSeparator />\n <DropdownMenuItem>Profile</DropdownMenuItem>\n <DropdownMenuItem>Billing</DropdownMenuItem>\n </DropdownMenuContent>\n </DropdownMenu>,\n );\n\n await user.click(screen.getByText('Open Menu'));\n\n expect(screen.getByText('My Account')).toBeVisible();\n expect(screen.getByText('Profile')).toBeVisible();\n });\n\n it('handles checkbox items', async () => {\n const user = userEvent.setup();\n render(\n <DropdownMenu>\n <DropdownMenuTrigger>Open</DropdownMenuTrigger>\n <DropdownMenuContent>\n <DropdownMenuCheckboxItem checked>Checked Item</DropdownMenuCheckboxItem>\n <DropdownMenuCheckboxItem checked={false}>Unchecked Item</DropdownMenuCheckboxItem>\n </DropdownMenuContent>\n </DropdownMenu>,\n );\n\n await user.click(screen.getByText('Open'));\n\n const checkedItem = screen.getByText('Checked Item');\n // const uncheckedItem = screen.getByText('Unchecked Item');\n\n expect(checkedItem).toBeVisible();\n // Radix UI adds data-state=\"checked\" or similar.\n // But testing-library's toBeChecked() works on roles like 'checkbox' or 'menuitemcheckbox'\n expect(screen.getByRole('menuitemcheckbox', { name: 'Checked Item' })).toBeChecked();\n expect(screen.getByRole('menuitemcheckbox', { name: 'Unchecked Item' })).not.toBeChecked();\n });\n\n it('handles radio items', async () => {\n const user = userEvent.setup();\n render(\n <DropdownMenu>\n <DropdownMenuTrigger>Open</DropdownMenuTrigger>\n <DropdownMenuContent>\n <DropdownMenuRadioGroup value=\"top\">\n <DropdownMenuRadioItem value=\"top\">Top</DropdownMenuRadioItem>\n <DropdownMenuRadioItem value=\"bottom\">Bottom</DropdownMenuRadioItem>\n </DropdownMenuRadioGroup>\n </DropdownMenuContent>\n </DropdownMenu>,\n );\n\n await user.click(screen.getByText('Open'));\n\n expect(screen.getByRole('menuitemradio', { name: 'Top' })).toBeChecked();\n expect(screen.getByRole('menuitemradio', { name: 'Bottom' })).not.toBeChecked();\n });\n});\n",
|
|
10
|
-
"type": "registry:ui"
|
|
11
|
-
}
|
|
12
|
-
]
|
|
13
|
-
}
|