48 lines
928 B
TypeScript
Raw Normal View History

2023-05-15 08:51:32 +08:00
'use client'
import cn from 'classnames'
2023-07-18 16:57:14 +08:00
type AvatarProps = {
2023-05-15 08:51:32 +08:00
name: string
avatar?: string
size?: number
className?: string
2023-07-18 16:57:14 +08:00
textClassName?: string
2023-05-15 08:51:32 +08:00
}
const Avatar = ({
name,
avatar,
size = 30,
2023-07-18 16:57:14 +08:00
className,
textClassName,
}: 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` }
2023-05-15 08:51:32 +08:00
if (avatar) {
return (
2023-07-18 16:57:14 +08:00
<img
className={cn(avatarClassName, className)}
2023-05-15 08:51:32 +08:00
style={style}
2023-07-18 16:57:14 +08:00
alt={name}
2023-05-15 08:51:32 +08:00
src={avatar}
/>
)
}
return (
2023-07-18 16:57:14 +08:00
<div
className={cn(avatarClassName, className)}
2023-05-15 08:51:32 +08:00
style={style}
>
2023-07-18 16:57:14 +08:00
<div
className={cn(textClassName, 'text-center text-white scale-[0.4]')}
2023-05-15 08:51:32 +08:00
style={style}
>
{name[0].toLocaleUpperCase()}
</div>
</div>
)
}
2023-07-18 16:57:14 +08:00
export default Avatar