29 lines
1.0 KiB
TypeScript
Executable File
29 lines
1.0 KiB
TypeScript
Executable File
import * as React from "react"
|
|
import { cn } from "../../lib/utils"
|
|
|
|
export interface BadgeProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
children?: React.ReactNode
|
|
className?: string
|
|
variant?: "default" | "secondary" | "destructive" | "outline"
|
|
}
|
|
|
|
function Badge({ className, variant = "default", ...props }: BadgeProps) {
|
|
return (
|
|
<div
|
|
className={cn(
|
|
"inline-flex items-center rounded-full 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",
|
|
{
|
|
"border-transparent bg-primary text-primary-foreground hover:bg-primary/80": variant === "default",
|
|
"border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80": variant === "secondary",
|
|
"border-transparent bg-destructive text-destructive-foreground hover:bg-destructive/80": variant === "destructive",
|
|
"text-foreground": variant === "outline",
|
|
},
|
|
className
|
|
)}
|
|
{...props}
|
|
/>
|
|
)
|
|
}
|
|
|
|
export { Badge }
|