Button
ctafrom shadcn/ui Essentials
Button
AI Usage Rules
Use the Button component for all clickable actions. Choose variant based on importance: default for primary actions, outline for secondary, ghost for tertiary. Use the asChild prop to render as a link with <a> tag.
Code Template
import * as React from "react"
import { cva, type VariantProps } from "class-variance-authority"
import { Slot } from "radix-ui"
import { cn } from "@/lib/utils"
const buttonVariants = cva(
"inline-flex shrink-0 items-center justify-center gap-2 rounded-md text-sm font-medium whitespace-nowrap transition-all outline-none focus-visible:border-ring focus-visible:ring-[3px] focus-visible:ring-ring/50 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
{
variants: {
variant: {
default: "bg-primary text-primary-foreground hover:bg-primary/90",
destructive: "bg-destructive text-white hover:bg-destructive/90 focus-visible:ring-destructive/20",
outline: "border bg-background shadow-xs 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-9 px-4 py-2 has-[>svg]:px-3",
xs: "h-6 gap-1 rounded-md px-2 text-xs",
sm: "h-8 gap-1.5 rounded-md px-3",
lg: "h-10 rounded-md px-6",
icon: "size-9",
},
},
defaultVariants: { variant: "default", size: "default" },
}
)
function Button({ className, variant, size, asChild = false, ...props }: React.ComponentProps<"button"> & VariantProps<typeof buttonVariants> & { asChild?: boolean }) {
const Comp = asChild ? Slot.Root : "button"
return <Comp data-slot="button" className={cn(buttonVariants({ variant, size, className }))} {...props} />
}
export { Button, buttonVariants }Props Schema
| Property | Type | Default | Description |
|---|---|---|---|
| size | string | — | |
| variant | string | — | |
| children | string | — |
View raw JSON schema
{
"type": "object",
"properties": {
"size": {
"enum": [
"default",
"xs",
"sm",
"lg",
"icon"
],
"type": "string"
},
"variant": {
"enum": [
"default",
"destructive",
"outline",
"secondary",
"ghost",
"link"
],
"type": "string"
},
"children": {
"type": "string"
}
}
}