import React from "react"; import { vcn, VariantProps } from "../shared"; const [buttonVariants, resolveVariants] = vcn({ base: "flex flex-row items-center justify-between rounded-md outline outline-1 outline-transparent outline-offset-2 focus-visible:outline-black/50 dark:focus-visible:outline-white/50 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", }, border: { none: "outline-none", solid: "border border-black/20 dark:border-white/20", outline: "outline outline-1 outline-black/20 dark:outline-white/20", }, background: { default: "bg-white dark:bg-black hover:bg-gray-100 dark:hover:bg-gray-800", ghost: "bg-black/0 dark:bg-white/0 hover:bg-black/20 dark:hover:bg-white/20", link: "bg-transparent hover:bg-transparent", }, decoration: { none: "no-underline", link: "underline decoration-1 underline-offset-2 hover:underline-offset-4 decoration-black/100 dark:decoration-white/100", }, }, defaults: { size: "md", border: "solid", background: "default", decoration: "none", }, }); export interface ButtonProps extends Omit, "className">, VariantProps {} const Button = React.forwardRef( (props, ref) => { const [variantProps, otherProps] = resolveVariants(props); return (