haixunMaster/components/ui/badge.tsx

32 lines
1.1 KiB
TypeScript

import * as React from "react";
import { cva, type VariantProps } from "class-variance-authority";
import { cn } from "@/lib/utils";
const badgeVariants = cva(
"inline-flex items-center rounded-md border px-2 py-0.5 text-[11px] font-medium",
{
variants: {
variant: {
default: "border-border bg-secondary text-foreground",
secondary: "border-transparent bg-muted text-muted-foreground",
outline: "border-border bg-transparent text-muted-foreground",
success: "border-success-border bg-success-bg text-success",
warning: "border-warning-border bg-warning-bg text-warning",
destructive: "border-danger-border bg-danger-bg text-danger",
},
},
defaultVariants: {
variant: "default",
},
}
);
export interface BadgeProps
extends React.HTMLAttributes<HTMLDivElement>,
VariantProps<typeof badgeVariants> {}
function Badge({ className, variant, ...props }: BadgeProps) {
return <div className={cn(badgeVariants({ variant }), className)} {...props} />;
}
export { Badge, badgeVariants };