bigbuffet-rw/app/soapbox/components/ui/avatar/avatar.tsx

57 lines
1.3 KiB
TypeScript
Raw Normal View History

2023-02-06 10:01:03 -08:00
import clsx from 'clsx';
import React, { useState } from 'react';
2022-03-21 11:09:01 -07:00
import StillImage, { IStillImage } from 'soapbox/components/still-image';
import Icon from '../icon/icon';
2022-03-21 11:09:01 -07:00
const AVATAR_SIZE = 42;
interface IAvatar extends Pick<IStillImage, 'src' | 'onError' | 'className'> {
/** Width and height of the avatar in pixels. */
size?: number
2022-03-21 11:09:01 -07:00
}
/** Round profile avatar for accounts. */
2022-03-21 11:09:01 -07:00
const Avatar = (props: IAvatar) => {
const { src, size = AVATAR_SIZE, className } = props;
const [isAvatarMissing, setIsAvatarMissing] = useState<boolean>(false);
const handleLoadFailure = () => setIsAvatarMissing(true);
2022-03-21 11:09:01 -07:00
const style: React.CSSProperties = React.useMemo(() => ({
width: size,
height: size,
}), [size]);
if (isAvatarMissing) {
return (
<div
style={{
width: size,
height: size,
}}
className={clsx('flex items-center justify-center rounded-full bg-gray-200 dark:bg-gray-900', className)}
>
<Icon
src={require('@tabler/icons/photo-off.svg')}
className='h-4 w-4 text-gray-500 dark:text-gray-700'
/>
</div>
);
}
2022-03-21 11:09:01 -07:00
return (
<StillImage
2023-02-06 10:01:03 -08:00
className={clsx('rounded-full', className)}
2022-03-21 11:09:01 -07:00
style={style}
src={src}
alt='Avatar'
onError={handleLoadFailure}
2022-03-21 11:09:01 -07:00
/>
);
};
export { Avatar as default, AVATAR_SIZE };