import classnames from 'classnames'; import type { ComponentChildren } from 'preact'; import { Link } from 'preact-router'; import { forwardRef } from 'preact/compat'; import { Icon } from './Icon'; const colorStyles = { custom: '', default: 'text-gray-700 enabled:hover:bg-gray-700/10 enabled:hover:text-gray-1000', gray: 'text-gray-800 bg-gray-100 enabled:hover:bg-gray-500/20 enabled:hover:text-gray-1000', primary: 'bg-blue-400 text-white hover:bg-blue-500', secondary: 'bg-violet-400 text-white hover:bg-violet-500', warning: 'bg-orange-400 text-white hover:bg-orange-500', danger: 'bg-red-400 text-white hover:bg-red-500', }; export type ButtonProps = { href?: string; color?: keyof typeof colorStyles; size?: 'sm' | 'md'; justify?: 'start' | 'center'; type?: 'button' | 'submit'; onClick?: (event: MouseEvent) => void; onDoubleClick?: (event: MouseEvent) => void; contentEditable?: boolean; onKeyDown?: (event: KeyboardEvent) => void; forDropdown?: boolean; className?: string; children?: ComponentChildren; disabled?: boolean; title?: string; tabIndex?: number; }; // eslint-disable-next-line @typescript-eslint/no-explicit-any export const Button = forwardRef(function Button( { href, className, children, forDropdown, color, justify = 'center', size = 'md', ...props }, ref, ) { // const Component = 'button'; const Component = typeof href === 'string' ? Link : 'button'; return ( {children} {forDropdown && } ); });