import * as React from "react"; import { Slot } from "@radix-ui/react-slot"; import { cva, type VariantProps } from "class-variance-authority"; import { cn } from "@/lib/utils"; const buttonVariants = cva( "inline-flex items-center justify-center gap-2 whitespace-nowrap text-sm font-medium ring-offset-background transition-all duration-300 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0 font-display uppercase tracking-wider", { variants: { variant: { default: "bg-primary text-primary-foreground hover:bg-primary/90 hover:shadow-[0_0_20px_hsl(166_100%_50%/0.5)]", destructive: "bg-destructive text-destructive-foreground hover:bg-destructive/90 hover:shadow-[0_0_20px_hsl(0_85%_55%/0.5)]", outline: "border border-primary/50 bg-transparent text-primary hover:bg-primary/10 hover:border-primary hover:shadow-[0_0_20px_hsl(166_100%_50%/0.3)]", secondary: "bg-secondary text-secondary-foreground hover:bg-secondary/80", ghost: "text-foreground hover:bg-secondary hover:text-foreground", link: "text-primary underline-offset-4 hover:underline", cyber: "relative bg-transparent border-2 border-primary text-primary overflow-hidden hover:text-primary-foreground before:absolute before:inset-0 before:bg-primary before:scale-x-0 before:origin-right before:transition-transform before:duration-300 hover:before:scale-x-100 hover:before:origin-left [&>*]:relative [&>*]:z-10", alert: "bg-destructive/20 border border-destructive text-destructive hover:bg-destructive hover:text-destructive-foreground", }, size: { default: "h-10 px-6 py-2", sm: "h-9 px-4", lg: "h-12 px-8 text-base", icon: "h-10 w-10", }, }, defaultVariants: { variant: "default", size: "default", }, }, ); export interface ButtonProps extends React.ButtonHTMLAttributes, VariantProps { asChild?: boolean; } const Button = React.forwardRef( ({ className, variant, size, asChild = false, ...props }, ref) => { const Comp = asChild ? Slot : "button"; return ; }, ); Button.displayName = "Button"; export { Button, buttonVariants };