Files
freeCodeCamp/client/src/components/helpers/avatar-renderer.tsx

44 lines
1.2 KiB
TypeScript
Raw Normal View History

2020-09-03 14:21:16 +03:00
import React from 'react';
import { Image } from '@freecodecamp/react-bootstrap';
import DefaultAvatar from '../../assets/icons/DefaultAvatar';
import { defaultUserImage } from '../../../../config/misc';
import { borderColorPicker } from '.';
import { useTranslation } from 'react-i18next';
2020-09-03 14:21:16 +03:00
interface AvatarRendererProps {
isDonating?: boolean;
isTopContributor?: boolean;
picture: string;
userName: string;
}
2020-09-03 14:21:16 +03:00
function AvatarRenderer({
picture,
userName,
isDonating,
isTopContributor
}: AvatarRendererProps): JSX.Element {
const { t } = useTranslation();
const borderColor: string = borderColorPicker(isDonating, isTopContributor);
const isPlaceHolderImage =
2020-09-03 14:21:16 +03:00
/example.com|identicon.org/.test(picture) || picture === defaultUserImage;
return (
<div className={`avatar-container ${borderColor}`}>
{isPlaceHolderImage ? (
<DefaultAvatar className='avatar default-avatar' />
) : (
<Image
alt={t('profile.avatar', { username: userName })}
2020-09-03 14:21:16 +03:00
className='avatar'
responsive={true}
src={picture}
/>
)}
</div>
);
}
AvatarRenderer.displayName = 'AvatarRenderer';
export default AvatarRenderer;