import classnames from 'classnames'; import type { HTMLAttributes } from 'react'; import { forwardRef, memo, useMemo } from 'react'; import { Link } from 'react-router-dom'; import { Icon } from './Icon'; const colorStyles = { custom: 'ring-blue-500/50', default: 'text-gray-700 enabled:hocus:bg-gray-700/10 enabled:hocus:text-gray-1000 ring-blue-500/50', gray: 'text-gray-800 bg-highlight enabled:hocus:bg-gray-500/20 enabled:hocus:text-gray-1000 ring-blue-500/50', primary: 'bg-blue-400 text-white enabled:hocus:bg-blue-500 ring-blue-500/50', secondary: 'bg-violet-400 text-white enabled:hocus:bg-violet-500 ring-violet-500/50', warning: 'bg-orange-400 text-white enabled:hocus:bg-orange-500 ring-orange-500/50', danger: 'bg-red-400 text-white enabled:hocus:bg-red-500 ring-red-500/50', }; export type ButtonProps = HTMLAttributes & { to?: string; color?: keyof typeof colorStyles; size?: 'sm' | 'md' | 'xs'; justify?: 'start' | 'center'; type?: 'button' | 'submit'; forDropdown?: boolean; disabled?: boolean; title?: string; }; // eslint-disable-next-line @typescript-eslint/no-explicit-any const _Button = forwardRef(function Button( { to, className, children, forDropdown, color, justify = 'center', size = 'md', ...props }: ButtonProps, ref, ) { const classes = useMemo( () => classnames( className, 'opacity-90 hover:opacity-100', 'outline-none whitespace-nowrap', 'focus-visible-or-class:ring', 'rounded-md flex items-center', colorStyles[color || 'default'], justify === 'start' && 'justify-start', justify === 'center' && 'justify-center', size === 'md' && 'h-md px-3', size === 'sm' && 'h-sm px-2.5 text-sm', size === 'xs' && 'h-xs px-2 text-sm', ), [color, size, justify, className], ); if (typeof to === 'string') { return ( {children} {forDropdown && } ); } else { return ( ); } }); export const Button = memo(_Button);