import { clsx } from 'clsx'; import { MouseEvent, ButtonHTMLAttributes } from 'react'; interface ButtonProps extends Omit, 'type' | 'onClick'> { children: any; variant?: 'primary' | 'secondary' | 'danger' | 'success'; size?: 'sm' | 'md' | 'lg'; disabled?: boolean; loading?: boolean; onClick?: (e?: MouseEvent) => void; type?: 'button' | 'submit' | 'reset'; className?: string; } export const Button = ({ children, variant = 'primary', size = 'md', disabled = false, loading = false, onClick, type = 'button', className = '', ...rest }: ButtonProps) => { const baseClasses = 'inline-flex items-center justify-center rounded-xl font-medium transition-all duration-200 focus:outline-none focus:ring-2 focus:ring-offset-2 shadow-sm hover:shadow-md'; const variantClasses = { primary: 'bg-primary-600 hover:bg-primary-700 text-white focus:ring-primary-500', secondary: 'bg-gray-200 hover:bg-gray-300 dark:bg-gray-700 dark:hover:bg-gray-600 text-gray-900 dark:text-gray-100 focus:ring-gray-500', danger: 'bg-red-600 hover:bg-red-700 text-white focus:ring-red-500', success: 'bg-green-600 hover:bg-green-700 text-white focus:ring-green-500', }; const sizeClasses = { sm: 'px-3 py-1.5 text-sm', md: 'px-4 py-2 text-sm', lg: 'px-6 py-3 text-base', }; const disabledClasses = disabled || loading ? 'opacity-50 cursor-not-allowed pointer-events-none' : ''; return ( ); };