import clsx from "clsx"; import React, { ButtonHTMLAttributes, DetailedHTMLProps, ReactNode, forwardRef, } from "react"; export enum ButtonSizes { Small = "Small", Large = "Large", } export enum ButtonVariants { Primary = "Primary", Secondary = "Secondary", Destructive = "Destructive", } export enum ButtonColors { Neutral = "Neutral", Primary = "Primary", Warn = "Warn", } export type ButtonProps = DetailedHTMLProps< ButtonHTMLAttributes, HTMLButtonElement > & { size?: ButtonSizes; variant?: ButtonVariants; color?: ButtonColors; }; export const getButtonClasses = ( size: ButtonSizes, variant: ButtonVariants, color: ButtonColors ) => clsx({ "box-border font-normal leading-36px text-14px inline-flex items-center rounded-md focus:outline-none transition-colors transition-shadow duration-300": true, "shadow hover:shadow-xl active:shadow-xl disabled:border-none disabled:bg-gray-300 disabled:text-gray-600 disabled:shadow-none disabled:cursor-not-allowed disabled:dark:bg-gray-800 disabled:dark:text-gray-900": variant === ButtonVariants.Primary, "bg-primary-light-500 dark:bg-primary-dark-500 hover:bg-primary-light-400 hover:dark:bg-primary-dark-400 text-primary-light-contrast-500 dark:text-primary-dark-contrast-500": variant === ButtonVariants.Primary && color !== ButtonColors.Warn, "bg-warn-light-500 dark:bg-warn-dark-500 hover:bg-warn-light-400 hover:dark:bg-warn-dark-400 text-white dark:text-white": variant === ButtonVariants.Primary && color === ButtonColors.Warn, "border border-button-light-border dark:border-button-dark-border text-gray-950 hover:bg-gray-500 hover:bg-opacity-20 hover:dark:bg-white hover:dark:bg-opacity-10 focus:bg-gray-500 focus:bg-opacity-20 focus:dark:bg-white focus:dark:bg-opacity-10 dark:text-white disabled:text-gray-600 disabled:hover:bg-transparent disabled:dark:hover:bg-transparent disabled:cursor-not-allowed disabled:dark:text-gray-900": variant === ButtonVariants.Secondary, "border border-button-light-border dark:border-button-dark-border text-warn-light-500 dark:text-warn-dark-500 hover:bg-warn-light-500 hover:bg-opacity-10 dark:hover:bg-warn-light-500 dark:hover:bg-opacity-10 focus:bg-warn-light-500 focus:bg-opacity-20 dark:focus:bg-warn-light-500 dark:focus:bg-opacity-20": color === ButtonColors.Warn && variant !== ButtonVariants.Primary, "px-16 py-2": size === ButtonSizes.Large, "px-4 h-[36px]": size === ButtonSizes.Small, }); // eslint-disable-next-line react/display-name export const Button = forwardRef( ( { children, className = "", variant = ButtonVariants.Primary, size = ButtonSizes.Small, color = ButtonColors.Primary, ...props }, ref ) => ( ) );