import type { FC } from 'react' import { useSWRConfig } from 'swr' import { useTranslation } from 'react-i18next' import type { ModelProvider } from '../declarations' import { CustomConfigurationStatusEnum, PreferredProviderTypeEnum, QuotaUnitEnum, } from '../declarations' import { useAnthropicBuyQuota, useFreeQuota, } from '../hooks' import PriorityUseTip from './priority-use-tip' import { InfoCircle } from '@/app/components/base/icons/src/vender/line/general' import Button from '@/app/components/base/button' import TooltipPlus from '@/app/components/base/tooltip-plus' type QuotaPanelProps = { provider: ModelProvider } const QuotaPanel: FC = ({ provider, }) => { const { t } = useTranslation() const { mutate } = useSWRConfig() const handlePay = useAnthropicBuyQuota() const handleFreeQuotaSuccess = () => { mutate('/workspaces/current/model-providers') } const handleFreeQuota = useFreeQuota(handleFreeQuotaSuccess) const customConfig = provider.custom_configuration const priorityUseType = provider.preferred_provider_type const systemConfig = provider.system_configuration const currentQuota = systemConfig.enabled && systemConfig.quota_configurations.find(item => item.quota_type === systemConfig.current_quota_type) const openaiOrAnthropic = ['openai', 'anthropic'].includes(provider.provider) return (
{t('common.modelProvider.quota')}
{ currentQuota && (
{(currentQuota?.quota_limit || 0) - (currentQuota?.quota_used || 0)} { currentQuota?.quota_unit === QuotaUnitEnum.tokens && 'Tokens' } { currentQuota?.quota_unit === QuotaUnitEnum.times && t('common.modelProvider.callTimes') }
) } { !currentQuota && provider.provider === 'anthropic' && ( ) } { !currentQuota && ['minimax', 'spark', 'zhipuai'].includes(provider.provider) && ( ) } { provider.provider === 'anthropic' && systemConfig.enabled && ( ) } { priorityUseType === PreferredProviderTypeEnum.system && customConfig.status === CustomConfigurationStatusEnum.active && ( ) }
) } export default QuotaPanel