import * as React from 'react'; import { Link } from 'react-router-dom'; import Icon from 'soapbox/components/icon'; import { useButtonStyles } from './useButtonStyles'; import type { ButtonSizes, ButtonThemes } from './useButtonStyles'; interface IButton { block?: boolean, children?: React.ReactNode, classNames?: string, disabled?: boolean, icon?: string, onClick?: (event: React.MouseEvent) => void, size?: ButtonSizes, style?: React.CSSProperties, text?: React.ReactNode, to?: string, theme?: ButtonThemes, type?: 'button' | 'submit', } const Button = React.forwardRef((props, ref): JSX.Element => { const { block = false, children, disabled = false, icon, onClick, size = 'md', text, theme = 'accent', to, type = 'button', } = props; const themeClass = useButtonStyles({ theme, block, disabled, size, }); const renderIcon = () => { if (!icon) { return null; } return ; }; const handleClick = React.useCallback((event) => { if (onClick && !disabled) { onClick(event); } }, [onClick, disabled]); const renderButton = () => ( ); if (to) { return ( {renderButton()} ); } return renderButton(); }); export default Button;