mirror of
https://github.com/labring/FastGPT.git
synced 2025-12-25 20:02:47 +00:00
* chat log soft delete * perf: history api * add history test * Update packages/web/i18n/en/app.json Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * zod parse error * fix: ts --------- Co-authored-by: archer <545436317@qq.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
36 lines
873 B
TypeScript
36 lines
873 B
TypeScript
import React from 'react';
|
|
import { Box } from '@chakra-ui/react';
|
|
import type { ImageProps } from '@chakra-ui/react';
|
|
import { LOGO_ICON } from '@fastgpt/global/common/system/constants';
|
|
import MyIcon from '../Icon';
|
|
import { iconPaths } from '../Icon/constants';
|
|
import MyImage from '../Image/MyImage';
|
|
|
|
const Avatar = ({
|
|
w = '30px',
|
|
src,
|
|
...props
|
|
}: Omit<ImageProps, 'src'> & { src?: string | null }) => {
|
|
// @ts-ignore
|
|
const isIcon = !!iconPaths[src as any];
|
|
|
|
return isIcon ? (
|
|
<Box display={'inline-flex'} {...props}>
|
|
<MyIcon name={src as any} w={w} borderRadius={props.borderRadius} />
|
|
</Box>
|
|
) : (
|
|
<MyImage
|
|
fallbackSrc={LOGO_ICON}
|
|
fallbackStrategy={'onError'}
|
|
objectFit={'contain'}
|
|
alt=""
|
|
w={w}
|
|
h={w}
|
|
src={src || LOGO_ICON}
|
|
{...props}
|
|
/>
|
|
);
|
|
};
|
|
|
|
export default React.memo(Avatar);
|