pleroma/app/soapbox/components/ui/icon-button/icon-button.tsx

39 lines
1.1 KiB
TypeScript
Raw Normal View History

2022-03-21 11:09:01 -07:00
import classNames from 'classnames';
import React from 'react';
import SvgIcon from '../icon/svg-icon';
2022-03-21 11:09:01 -07:00
import Text from '../text/text';
2022-04-02 11:03:12 -07:00
interface IIconButton extends React.ButtonHTMLAttributes<HTMLButtonElement> {
2022-03-21 11:09:01 -07:00
iconClassName?: string,
src: string,
text?: string,
transparent?: boolean
}
const IconButton = React.forwardRef((props: IIconButton, ref: React.ForwardedRef<HTMLButtonElement>): JSX.Element => {
const { src, className, iconClassName, text, transparent = false, ...filteredProps } = props;
return (
<button
ref={ref}
type='button'
2022-03-23 17:18:37 -07:00
className={classNames('flex items-center space-x-2 p-1 rounded-full focus:outline-none focus:ring-2 focus:ring-offset-2 dark:ring-offset-0 focus:ring-primary-500', {
'bg-white dark:bg-transparent': !transparent,
}, className)}
2022-03-21 11:09:01 -07:00
{...filteredProps}
2022-04-07 08:01:38 -07:00
data-testid='icon-button'
2022-03-21 11:09:01 -07:00
>
<SvgIcon src={src} className={iconClassName} />
2022-03-21 11:09:01 -07:00
{text ? (
<Text tag='span' theme='muted' size='sm'>
{text}
</Text>
) : null}
</button>
);
});
export default IconButton;