mirror of
https://github.com/langgenius/dify.git
synced 2025-10-23 23:18:49 +00:00

Co-authored-by: NFish <douxc512@gmail.com> Co-authored-by: zxhlyh <jasonapring2015@outlook.com> Co-authored-by: twwu <twwu@dify.ai> Co-authored-by: jZonG <jzongcode@gmail.com>
48 lines
1.0 KiB
TypeScript
48 lines
1.0 KiB
TypeScript
'use client'
|
|
|
|
import type { FC } from 'react'
|
|
import { init } from 'emoji-mart'
|
|
import data from '@emoji-mart/data'
|
|
import classNames from '@/utils/classnames'
|
|
import type { AppIconType } from '@/types/app'
|
|
|
|
init({ data })
|
|
|
|
export type AnswerIconProps = {
|
|
iconType?: AppIconType | null
|
|
icon?: string | null
|
|
background?: string | null
|
|
imageUrl?: string | null
|
|
}
|
|
|
|
const AnswerIcon: FC<AnswerIconProps> = ({
|
|
iconType,
|
|
icon,
|
|
background,
|
|
imageUrl,
|
|
}) => {
|
|
const wrapperClassName = classNames(
|
|
'flex',
|
|
'items-center',
|
|
'justify-center',
|
|
'w-full',
|
|
'h-full',
|
|
'rounded-full',
|
|
'border-[0.5px]',
|
|
'border-black/5',
|
|
'text-xl',
|
|
)
|
|
const isValidImageIcon = iconType === 'image' && imageUrl
|
|
return <div
|
|
className={wrapperClassName}
|
|
style={{ background: background || '#D5F5F6' }}
|
|
>
|
|
{isValidImageIcon
|
|
? <img src={imageUrl} className="h-full w-full rounded-full" alt="answer icon" />
|
|
: (icon && icon !== '') ? <em-emoji id={icon} /> : <em-emoji id='🤖' />
|
|
}
|
|
</div>
|
|
}
|
|
|
|
export default AnswerIcon
|