Bin
2025-12-16 9e0b2ba2c317b1a86212f24cbae3195ad1f3dbfa
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
import type * as React from "react";
import { cva, type VariantProps } from "class-variance-authority";
 
import { cn } from "@humansignal/shad/utils";
 
const badgeVariants = cva(
  "inline-flex items-center 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",
  {
    variants: {
      variant: {
        default: "border-transparent bg-primary text-primary-foreground hover:bg-primary/80",
        secondary: "border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80",
        destructive: "border-transparent bg-destructive text-destructive-foreground hover:bg-destructive/80",
        success: "border-transparent bg-positive-background text-positive-content hover:bg-positive-background/80",
        info: "bg-primary-background border-primary-emphasis text-accent-grape-dark font-normal",
        outline: "text-neutral-content border-neutral-border",
        beta: "bg-accent-plum-subtle text-accent-plum-dark font-medium border-transparent",
      },
      shape: {
        rounded: "rounded-full",
        squared: "rounded-sm",
      },
    },
    defaultVariants: {
      variant: "default",
      shape: "rounded",
    },
  },
);
 
export interface BadgeProps extends React.HTMLAttributes<HTMLDivElement>, VariantProps<typeof badgeVariants> {}
 
function Badge({ className, variant, shape, ...props }: BadgeProps) {
  return <div className={cn(badgeVariants({ variant, shape }), className)} {...props} />;
}
 
export { Badge, badgeVariants };