diff --git a/packages/react/components/Button.tsx b/packages/react/components/Button.tsx index 67ae603..60adb14 100644 --- a/packages/react/components/Button.tsx +++ b/packages/react/components/Button.tsx @@ -2,34 +2,51 @@ import React from "react"; import { vcn, VariantProps, Slot, AsChild } from "../shared"; const colors = { - outlineFocus: "focus-visible:outline-neutral-500", - outline: "outline-neutral-300 dark:outline-neutral-700", - border: "border-neutral-300 dark:border-neutral-700", + outline: { + focus: "dark:focus-visible:outline-white/20 focus-visible:outline-black/10", + }, + border: { + default: "border-neutral-300 dark:border-neutral-700", + success: "border-green-400 dark:border-green-600", + warning: "border-yellow-400 dark:border-yellow-600", + error: "border-red-400 dark:border-red-600", + }, background: { default: "bg-white dark:bg-black hover:bg-neutral-100 dark:hover:bg-neutral-800", ghost: "bg-black/0 dark:bg-white/0 hover:bg-black/20 dark:hover:bg-white/20", + success: + "bg-green-100 dark:bg-green-900 hover:bg-green-200 dark:hover:bg-green-800", + warning: + "bg-yellow-100 dark:bg-yellow-900 hover:bg-yellow-200 dark:hover:bg-yellow-800", + error: "bg-red-100 dark:bg-red-900 hover:bg-red-200 dark:hover:bg-red-800", }, underline: "decoration-black dark:decoration-white", }; const [buttonVariants, resolveVariants] = vcn({ - base: `w-fit flex flex-row items-center justify-between rounded-md outline outline-1 outline-transparent outline-offset-2 ${colors.outlineFocus} transition-all`, + base: `w-fit flex flex-row items-center justify-between rounded-md outline outline-1 outline-transparent outline-offset-2 ${colors.outline.focus} transition-all`, variants: { size: { sm: "px-2 py-1 text-sm", md: "px-4 py-2 text-base", lg: "px-5 py-3 text-lg", + icon: "p-2 text-base", }, border: { - none: "outline-none", - solid: `border ${colors.border}`, - outline: `outline outline-1 ${colors.outline}`, + none: "border-0", + solid: `border ${colors.border.default}`, + success: `border ${colors.border.success}`, + warning: `border ${colors.border.warning}`, + error: `border ${colors.border.error}`, }, background: { default: colors.background.default, ghost: colors.background.ghost, + success: colors.background.success, + warning: colors.background.warning, + error: colors.background.error, transparent: "bg-transparent hover:bg-transparent", }, decoration: { diff --git a/packages/react/stories/Button.stories.tsx b/packages/react/stories/Button.stories.tsx index 74faf5d..166ddea 100644 --- a/packages/react/stories/Button.stories.tsx +++ b/packages/react/stories/Button.stories.tsx @@ -11,14 +11,6 @@ export const Ghost = () => { return ; }; -export const Outline = () => { - return ( - - ); -}; - export const Link = () => { return ; };