26 lines
1.1 KiB
TypeScript
26 lines
1.1 KiB
TypeScript
import * as React from "react";
|
|
import { cn } from "@/lib/utils";
|
|
|
|
interface BadgeProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
variant?: "default" | "secondary" | "destructive" | "outline" | "success";
|
|
}
|
|
|
|
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",
|
|
variant === "default" && "border-transparent bg-primary text-primary-foreground hover:bg-primary/80",
|
|
variant === "secondary" && "border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80",
|
|
variant === "destructive" && "border-transparent bg-destructive text-destructive-foreground hover:bg-destructive/80",
|
|
variant === "outline" && "text-foreground",
|
|
variant === "success" && "border-transparent bg-green-100 text-green-800 hover:bg-green-200",
|
|
className
|
|
)}
|
|
{...props}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export { Badge };
|