| gio | d002661 | 2025-05-08 13:00:36 +0000 | [diff] [blame] | 1 | import * as React from "react"; |
| 2 | import { cva, type VariantProps } from "class-variance-authority"; |
| gio | 5f2f100 | 2025-03-20 18:38:48 +0400 | [diff] [blame] | 3 | |
| gio | d002661 | 2025-05-08 13:00:36 +0000 | [diff] [blame] | 4 | import { cn } from "@/lib/utils"; |
| gio | 5f2f100 | 2025-03-20 18:38:48 +0400 | [diff] [blame] | 5 | |
| 6 | const badgeVariants = cva( |
| gio | d002661 | 2025-05-08 13:00:36 +0000 | [diff] [blame] | 7 | "inline-flex items-center rounded-md 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", |
| 8 | { |
| 9 | variants: { |
| 10 | variant: { |
| 11 | default: "border-transparent bg-primary text-primary-foreground shadow hover:bg-primary/80", |
| 12 | secondary: "border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80", |
| 13 | destructive: |
| 14 | "border-transparent bg-destructive text-destructive-foreground shadow hover:bg-destructive/80", |
| 15 | outline: "text-foreground", |
| 16 | }, |
| 17 | }, |
| 18 | defaultVariants: { |
| 19 | variant: "default", |
| 20 | }, |
| 21 | }, |
| 22 | ); |
| gio | 5f2f100 | 2025-03-20 18:38:48 +0400 | [diff] [blame] | 23 | |
| gio | d002661 | 2025-05-08 13:00:36 +0000 | [diff] [blame] | 24 | export interface BadgeProps extends React.HTMLAttributes<HTMLDivElement>, VariantProps<typeof badgeVariants> {} |
| gio | 5f2f100 | 2025-03-20 18:38:48 +0400 | [diff] [blame] | 25 | |
| 26 | function Badge({ className, variant, ...props }: BadgeProps) { |
| gio | d002661 | 2025-05-08 13:00:36 +0000 | [diff] [blame] | 27 | return <div className={cn(badgeVariants({ variant }), className)} {...props} />; |
| gio | 5f2f100 | 2025-03-20 18:38:48 +0400 | [diff] [blame] | 28 | } |
| 29 | |
| gio | d002661 | 2025-05-08 13:00:36 +0000 | [diff] [blame] | 30 | export { Badge, badgeVariants }; |