Unverified Commit 562a5712 authored by leo's avatar leo Committed by GitHub

fix: Improved fallback solution for avatar image loading failure (#1172)

parent fc68c817
'use client' 'use client'
import cn from 'classnames' import cn from 'classnames'
import { useState } from 'react'
type AvatarProps = { type AvatarProps = {
name: string name: string
...@@ -17,14 +18,20 @@ const Avatar = ({ ...@@ -17,14 +18,20 @@ const Avatar = ({
}: AvatarProps) => { }: AvatarProps) => {
const avatarClassName = 'shrink-0 flex items-center rounded-full bg-primary-600' const avatarClassName = 'shrink-0 flex items-center rounded-full bg-primary-600'
const style = { width: `${size}px`, height: `${size}px`, fontSize: `${size}px`, lineHeight: `${size}px` } const style = { width: `${size}px`, height: `${size}px`, fontSize: `${size}px`, lineHeight: `${size}px` }
const [imgError, setImgError] = useState(false)
if (avatar) { const handleError = () => {
setImgError(true)
}
if (avatar && !imgError) {
return ( return (
<img <img
className={cn(avatarClassName, className)} className={cn(avatarClassName, className)}
style={style} style={style}
alt={name} alt={name}
src={avatar} src={avatar}
onError={handleError}
/> />
) )
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment