From d63ecd8d299e8cda5aecd01d5c98f8ce5f0a854a Mon Sep 17 00:00:00 2001 From: sion123 <450702724@qq.com> Date: Thu, 7 May 2026 02:21:21 +0800 Subject: [PATCH] feat(web): add shadcn/ui base components (Button, Input, ScrollArea) Co-Authored-By: Claude Opus 4.7 --- web/client/src/components/ui/button.tsx | 39 ++++++++++++++++++++ web/client/src/components/ui/input.tsx | 21 +++++++++++ web/client/src/components/ui/scroll-area.tsx | 16 ++++++++ web/components.json | 16 ++++++++ 4 files changed, 92 insertions(+) create mode 100644 web/client/src/components/ui/button.tsx create mode 100644 web/client/src/components/ui/input.tsx create mode 100644 web/client/src/components/ui/scroll-area.tsx create mode 100644 web/components.json diff --git a/web/client/src/components/ui/button.tsx b/web/client/src/components/ui/button.tsx new file mode 100644 index 0000000..7f319d2 --- /dev/null +++ b/web/client/src/components/ui/button.tsx @@ -0,0 +1,39 @@ +import * as React from 'react'; +import { cva, type VariantProps } from 'class-variance-authority'; +import { cn } from '@/lib/utils'; + +const buttonVariants = cva( + 'inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50', + { + variants: { + variant: { + default: 'bg-primary text-primary-foreground hover:bg-primary/90', + destructive: 'bg-destructive text-destructive-foreground hover:bg-destructive/90', + outline: 'border border-input bg-background hover:bg-accent hover:text-accent-foreground', + secondary: 'bg-secondary text-secondary-foreground hover:bg-secondary/80', + ghost: 'hover:bg-accent hover:text-accent-foreground', + link: 'text-primary underline-offset-4 hover:underline', + }, + size: { + default: 'h-10 px-4 py-2', + sm: 'h-9 rounded-md px-3', + lg: 'h-11 rounded-md px-8', + icon: 'h-10 w-10', + }, + }, + defaultVariants: { variant: 'default', size: 'default' }, + } +); + +export interface ButtonProps + extends React.ButtonHTMLAttributes, + VariantProps {} + +const Button = React.forwardRef( + ({ className, variant, size, ...props }, ref) => ( +