import classNames from 'classnames'; import { useHovering } from '../hooks/useHovering'; import { autoPlayGif } from '../initial_state'; import type { Account } from '../types/resources'; interface Props { account: Account | undefined; className?: string; size: number; style?: React.CSSProperties; inline?: boolean; } export const Avatar: React.FC = ({ account, className, size = 20, inline = false, style: styleFromParent, }) => { const { hovering, handleMouseEnter, handleMouseLeave } = useHovering(autoPlayGif); const style = { ...styleFromParent, width: `${size}px`, height: `${size}px`, backgroundSize: `${size}px ${size}px`, }; if (account) { style.backgroundImage = `url(${account.get( hovering ? 'avatar' : 'avatar_static', )})`; } return (
); };