fix: azure-openai key validate (#164)
parent
f3219ff107
commit
1c5f63de7e
@ -1,52 +0,0 @@
|
|||||||
import type { Provider } from '@/models/common'
|
|
||||||
import { useState } from 'react'
|
|
||||||
import { useTranslation } from 'react-i18next'
|
|
||||||
import { ProviderValidateTokenInput } from '../provider-input'
|
|
||||||
import Link from 'next/link'
|
|
||||||
import { ArrowTopRightOnSquareIcon } from '@heroicons/react/24/outline'
|
|
||||||
import { ValidatedStatus } from '../provider-input/useValidateToken'
|
|
||||||
|
|
||||||
interface IOpenaiProviderProps {
|
|
||||||
provider: Provider
|
|
||||||
onValidatedStatus: (status?: ValidatedStatus) => void
|
|
||||||
onTokenChange: (token: string) => void
|
|
||||||
}
|
|
||||||
|
|
||||||
const OpenaiProvider = ({
|
|
||||||
provider,
|
|
||||||
onValidatedStatus,
|
|
||||||
onTokenChange
|
|
||||||
}: IOpenaiProviderProps) => {
|
|
||||||
const { t } = useTranslation()
|
|
||||||
const [token, setToken] = useState(provider.token as string || '')
|
|
||||||
const handleFocus = () => {
|
|
||||||
if (token === provider.token) {
|
|
||||||
setToken('')
|
|
||||||
onTokenChange('')
|
|
||||||
}
|
|
||||||
}
|
|
||||||
const handleChange = (v: string) => {
|
|
||||||
setToken(v)
|
|
||||||
onTokenChange(v)
|
|
||||||
}
|
|
||||||
|
|
||||||
return (
|
|
||||||
<div className='px-4 pt-3 pb-4'>
|
|
||||||
<ProviderValidateTokenInput
|
|
||||||
value={token}
|
|
||||||
name={t('common.provider.apiKey')}
|
|
||||||
placeholder={t('common.provider.enterYourKey')}
|
|
||||||
onChange={handleChange}
|
|
||||||
onFocus={handleFocus}
|
|
||||||
onValidatedStatus={onValidatedStatus}
|
|
||||||
providerName={provider.provider_name}
|
|
||||||
/>
|
|
||||||
<Link className="inline-flex items-center mt-3 text-xs font-normal cursor-pointer text-primary-600 w-fit" href="https://platform.openai.com/account/api-keys" target={'_blank'}>
|
|
||||||
{t('appOverview.welcome.getKeyTip')}
|
|
||||||
<ArrowTopRightOnSquareIcon className='w-3 h-3 ml-1 text-primary-600' aria-hidden="true" />
|
|
||||||
</Link>
|
|
||||||
</div>
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
export default OpenaiProvider
|
|
||||||
@ -0,0 +1,59 @@
|
|||||||
|
import Link from 'next/link'
|
||||||
|
import { CheckCircleIcon, ExclamationCircleIcon } from '@heroicons/react/24/solid'
|
||||||
|
import { useTranslation } from 'react-i18next'
|
||||||
|
import { useContext } from 'use-context-selector'
|
||||||
|
import I18n from '@/context/i18n'
|
||||||
|
|
||||||
|
export const ValidatedErrorIcon = () => {
|
||||||
|
return <ExclamationCircleIcon className='w-4 h-4 text-[#D92D20]' />
|
||||||
|
}
|
||||||
|
|
||||||
|
export const ValidatedSuccessIcon = () => {
|
||||||
|
return <CheckCircleIcon className='w-4 h-4 text-[#039855]' />
|
||||||
|
}
|
||||||
|
|
||||||
|
export const ValidatingTip = () => {
|
||||||
|
const { t } = useTranslation()
|
||||||
|
return (
|
||||||
|
<div className={`mt-2 text-primary-600 text-xs font-normal`}>
|
||||||
|
{t('common.provider.validating')}
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export const ValidatedExceedOnOpenaiTip = () => {
|
||||||
|
const { t } = useTranslation()
|
||||||
|
const { locale } = useContext(I18n)
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div className={`mt-2 text-[#D92D20] text-xs font-normal`}>
|
||||||
|
{t('common.provider.apiKeyExceedBill')}
|
||||||
|
<Link
|
||||||
|
className='underline'
|
||||||
|
href="https://platform.openai.com/account/api-keys"
|
||||||
|
target={'_blank'}>
|
||||||
|
{locale === 'en' ? 'this link' : '这篇文档'}
|
||||||
|
</Link>
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export const ValidatedErrorOnOpenaiTip = () => {
|
||||||
|
const { t } = useTranslation()
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div className={`mt-2 text-[#D92D20] text-xs font-normal`}>
|
||||||
|
{t('common.provider.invalidKey')}
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export const ValidatedErrorOnAzureOpenaiTip = () => {
|
||||||
|
const { t } = useTranslation()
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div className={`mt-2 text-[#D92D20] text-xs font-normal`}>
|
||||||
|
{t('common.provider.invalidApiKey')}
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue