diff --git a/packages/client/components/Avatar/Avatar.tsx b/packages/client/components/Avatar/Avatar.tsx index 99b6dd0fb29..8b1329a6253 100644 --- a/packages/client/components/Avatar/Avatar.tsx +++ b/packages/client/components/Avatar/Avatar.tsx @@ -1,5 +1,5 @@ import styled from '@emotion/styled' -import React, {forwardRef} from 'react' +import React, {forwardRef, useState} from 'react' import defaultUserAvatar from '../../styles/theme/images/avatar-user.svg' import AvatarBadge from '../AvatarBadge/AvatarBadge' @@ -7,7 +7,7 @@ type ImageBlockProps = Pick( ({sansRadius, sansShadow, picture, size, onClick}) => ({ - backgroundImage: `url(${picture ?? defaultUserAvatar})`, + backgroundImage: `url(${picture})`, backgroundPosition: 'center center', backgroundRepeat: 'no-repeat', backgroundSize: 'cover', @@ -62,7 +62,10 @@ const Avatar = forwardRef((props: Props, ref: any) => { sansShadow, size } = props - + const [imageUrl, setImageUrl] = useState(picture || defaultUserAvatar) + const onError = () => { + setImageUrl(defaultUserAvatar) + } return ( { onMouseEnter={onMouseEnter} sansRadius={sansRadius} sansShadow={sansShadow} - picture={picture} + picture={imageUrl} size={size} > + {hasBadge && (