You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

index.tsx 1.8KB

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