From 60fca6b2fff3d4f885bcc4caaa923316757b7170 Mon Sep 17 00:00:00 2001 From: pheralb Date: Mon, 25 Aug 2025 19:04:56 +0100 Subject: [PATCH] =?UTF-8?q?=F0=9F=8E=A8=20Add=20badge=20UI=20component?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/components/ui/badge/badge.svelte | 35 +++++++++++++++++++++++ src/components/ui/badge/badge.variants.ts | 34 ++++++++++++++++++++++ src/components/ui/badge/index.ts | 2 ++ 3 files changed, 71 insertions(+) create mode 100644 src/components/ui/badge/badge.svelte create mode 100644 src/components/ui/badge/badge.variants.ts create mode 100644 src/components/ui/badge/index.ts diff --git a/src/components/ui/badge/badge.svelte b/src/components/ui/badge/badge.svelte new file mode 100644 index 0000000..dac8752 --- /dev/null +++ b/src/components/ui/badge/badge.svelte @@ -0,0 +1,35 @@ + + + + + + {@render children?.()} + diff --git a/src/components/ui/badge/badge.variants.ts b/src/components/ui/badge/badge.variants.ts new file mode 100644 index 0000000..cbcf055 --- /dev/null +++ b/src/components/ui/badge/badge.variants.ts @@ -0,0 +1,34 @@ +import { tv } from "tailwind-variants"; + +const badgeVariants = tv({ + base: "inline-flex items-center cursor-default gap-1.5 font-medium rounded-full border transition-colors hover:text-black dark:hover:text-white ease-in-out", + variants: { + variant: { + default: + "bg-neutral-100 text-neutral-800 border-neutral-200 dark:bg-neutral-800 dark:text-neutral-100 dark:border-neutral-700", + primary: + "bg-neutral-800 text-neutral-50 border-neutral-700 dark:bg-neutral-700 dark:text-neutral-50 dark:border-neutral-600", + secondary: + "bg-neutral-200 text-neutral-700 border-neutral-300 dark:bg-neutral-700 dark:text-neutral-200 dark:border-neutral-600", + success: + "bg-green-100 text-green-800 border-green-200 dark:bg-green-900 dark:text-green-100 dark:border-green-800", + warning: + "bg-amber-100 text-amber-800 border-amber-200 dark:bg-amber-900 dark:text-amber-100 dark:border-amber-800", + danger: + "bg-red-100 text-red-800 border-red-200 dark:bg-red-900 dark:text-red-100 dark:border-red-800", + outline: + "bg-transparent border border-neutral-300 text-neutral-700 dark:border-neutral-700 dark:text-neutral-400", + }, + size: { + sm: "text-xs px-2 py-0.5", + md: "text-sm px-2.5 py-0.5", + lg: "text-base px-3 py-1", + }, + }, + defaultVariants: { + variant: "default", + size: "sm", + }, +}); + +export { badgeVariants }; diff --git a/src/components/ui/badge/index.ts b/src/components/ui/badge/index.ts new file mode 100644 index 0000000..36c78f7 --- /dev/null +++ b/src/components/ui/badge/index.ts @@ -0,0 +1,2 @@ +export { default as Badge } from "./badge.svelte"; +export { badgeVariants } from "./badge.variants";