mirror of
https://github.com/langgenius/dify.git
synced 2024-11-16 03:32:23 +08:00
fix: Improved fallback solution for avatar image loading failure (#1172)
This commit is contained in:
parent
fc68c81791
commit
562a571281
|
@ -1,5 +1,6 @@
|
|||
'use client'
|
||||
import cn from 'classnames'
|
||||
import { useState } from 'react'
|
||||
|
||||
type AvatarProps = {
|
||||
name: string
|
||||
|
@ -17,14 +18,20 @@ const Avatar = ({
|
|||
}: AvatarProps) => {
|
||||
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 [imgError, setImgError] = useState(false)
|
||||
|
||||
if (avatar) {
|
||||
const handleError = () => {
|
||||
setImgError(true)
|
||||
}
|
||||
|
||||
if (avatar && !imgError) {
|
||||
return (
|
||||
<img
|
||||
className={cn(avatarClassName, className)}
|
||||
style={style}
|
||||
alt={name}
|
||||
src={avatar}
|
||||
onError={handleError}
|
||||
/>
|
||||
)
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue
Block a user