Files
Netcatty/components/ui/badge.tsx
2025-12-07 03:25:07 +08:00

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 }