Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.

index.tsx 2.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  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, OpenaiTale, OpenaiViolet, OpenaiYellow } from '@/app/components/base/icons/src/public/llm'
  9. import cn from '@/utils/classnames'
  10. import { renderI18nObject } from '@/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 && ['openai', 'langgenius/openai/openai'].includes(provider.provider) && modelName?.startsWith('o'))
  25. return <div className='flex items-center justify-center'><OpenaiYellow className={cn('h-5 w-5', className)} /></div>
  26. if (provider?.provider && ['openai', 'langgenius/openai/openai'].includes(provider.provider) && modelName?.includes('gpt-4.1'))
  27. return <div className='flex items-center justify-center'><OpenaiTale className={cn('h-5 w-5', className)} /></div>
  28. if (provider?.provider && ['openai', 'langgenius/openai/openai'].includes(provider.provider) && modelName?.includes('gpt-4o'))
  29. return <div className='flex items-center justify-center'><OpenaiBlue className={cn('h-5 w-5', className)} /></div>
  30. if (provider?.provider && ['openai', 'langgenius/openai/openai'].includes(provider.provider) && modelName?.startsWith('gpt-4'))
  31. return <div className='flex items-center justify-center'><OpenaiViolet className={cn('h-5 w-5', className)} /></div>
  32. if (provider?.icon_small) {
  33. return (
  34. <div className={cn('flex h-5 w-5 items-center justify-center', isDeprecated && 'opacity-50', className)}>
  35. <img alt='model-icon' src={renderI18nObject(provider.icon_small, language)}/>
  36. </div>
  37. )
  38. }
  39. return (
  40. <div className={cn(
  41. 'flex h-5 w-5 items-center justify-center rounded-md border-[0.5px] border-components-panel-border-subtle bg-background-default-subtle',
  42. className,
  43. )}>
  44. <div className='flex h-5 w-5 items-center justify-center opacity-35'>
  45. <Group className='h-3 w-3 text-text-tertiary' />
  46. </div>
  47. </div>
  48. )
  49. }
  50. export default ModelIcon