import { cva, type VariantProps } from "class-variance-authority"; import type { ButtonHTMLAttributes } from "react"; import { cn } from "../../lib/utils"; const buttonVariants = cva( "inline-flex items-center justify-center gap-2 rounded-md text-sm font-medium transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary disabled:pointer-events-none disabled:opacity-50", { variants: { variant: { default: "bg-primary text-primary-foreground hover:bg-primary/90", outline: "border border-border bg-background/50 text-foreground hover:bg-hover-neutral-bg hover:text-hover-neutral", ghost: "text-foreground hover:bg-hover-neutral-bg hover:text-hover-neutral", }, size: { default: "h-8 px-3 text-xs", icon: "h-8 w-8", "icon-sm": "h-6 w-6", }, }, defaultVariants: { variant: "default", size: "default", }, }, ); type ButtonProps = ButtonHTMLAttributes & VariantProps; export function Button({ className, variant, size, ...props }: ButtonProps) { return (