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",
  },
  presets: {
    default: {
      border: "solid",
      background: "default",
      decoration: "none",
      size: "md",
    },
    ghost: {
      border: "none",
      background: "ghost",
      decoration: "none",
      size: "md",
    },
    link: {
      border: "none",
      background: "link",
      decoration: "link",
      size: "md",
    },
  },
});

export interface ButtonProps
  extends Omit<React.ComponentPropsWithoutRef<"button">, "className">,
    VariantProps<typeof buttonVariants> {}

const Button = React.forwardRef<HTMLButtonElement, ButtonProps>(
  (props, ref) => {
    const [variantProps, otherProps] = resolveVariants(props);
    return (
      <button
        ref={ref}
        {...otherProps}
        className={buttonVariants(variantProps)}
      />
    );
  }
);

export { Button };