index.tsx 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. import type { FC } from 'react'
  2. import type {
  3. Model,
  4. ModelProvider,
  5. } from '../declarations'
  6. import { useLanguage } from '../hooks'
  7. import { Group } from '@/app/components/base/icons/src/vender/other'
  8. import { OpenaiBlue, OpenaiViolet } from '@/app/components/base/icons/src/public/llm'
  9. import cn from '@/utils/classnames'
  10. import { renderI18nObject } from '@/hooks/use-i18n'
  11. type ModelIconProps = {
  12. provider?: Model | ModelProvider
  13. modelName?: string
  14. className?: string
  15. isDeprecated?: boolean
  16. }
  17. const ModelIcon: FC<ModelIconProps> = ({
  18. provider,
  19. className,
  20. modelName,
  21. isDeprecated = false,
  22. }) => {
  23. const language = useLanguage()
  24. if (provider?.provider.includes('openai') && modelName?.includes('gpt-4o'))
  25. return <div className='flex items-center justify-center'><OpenaiBlue className={cn('w-5 h-5', className)} /></div>
  26. if (provider?.provider.includes('openai') && modelName?.startsWith('gpt-4'))
  27. return <div className='flex items-center justify-center'><OpenaiViolet className={cn('w-5 h-5', className)} /></div>
  28. if (provider?.icon_small) {
  29. return (
  30. <div className={cn('flex items-center justify-center w-5 h-5', isDeprecated && 'opacity-50', className)}>
  31. <img alt='model-icon' src={renderI18nObject(provider.icon_small, language)}/>
  32. </div>
  33. )
  34. }
  35. return (
  36. <div className={cn(
  37. 'flex items-center justify-center rounded-md border-[0.5px] w-5 h-5 border-components-panel-border-subtle bg-background-default-subtle',
  38. className,
  39. )}>
  40. <div className='flex w-5 h-5 items-center justify-center opacity-35'>
  41. <Group className='text-text-tertiary w-3 h-3' />
  42. </div>
  43. </div>
  44. )
  45. }
  46. export default ModelIcon