gaojintao01
Add files using Git LFS
f8b5d42
import { useTranslation } from "react-i18next";
export default function AzureAiOptions({ settings }) {
const { t } = useTranslation();
return (
<div className="w-full flex flex-col gap-y-7 mt-1.5">
<div className="w-full flex items-center gap-[36px]">
<div className="flex flex-col w-60">
<label className="text-white text-sm font-semibold block mb-3">
{t("llm.providers.azure_openai.azure_service_endpoint")}
</label>
<input
type="url"
name="AzureOpenAiEndpoint"
className="border-none bg-theme-settings-input-bg text-white placeholder:text-theme-settings-input-placeholder text-sm rounded-lg focus:outline-primary-button active:outline-primary-button outline-none block w-full p-2.5"
placeholder="https://my-azure.openai.azure.com"
defaultValue={settings?.AzureOpenAiEndpoint}
required={true}
autoComplete="off"
spellCheck={false}
/>
</div>
<div className="flex flex-col w-60">
<label className="text-white text-sm font-semibold block mb-3">
{t("llm.providers.azure_openai.api_key")}
</label>
<input
type="password"
name="AzureOpenAiKey"
className="border-none bg-theme-settings-input-bg text-white placeholder:text-theme-settings-input-placeholder text-sm rounded-lg focus:outline-primary-button active:outline-primary-button outline-none block w-full p-2.5"
placeholder="Azure OpenAI API Key"
defaultValue={settings?.AzureOpenAiKey ? "*".repeat(20) : ""}
required={true}
autoComplete="off"
spellCheck={false}
/>
</div>
<div className="flex flex-col w-60">
<label className="text-white text-sm font-semibold block mb-3">
{t("llm.providers.azure_openai.chat_deployment_name")}
</label>
<input
type="text"
name="AzureOpenAiModelPref"
className="border-none bg-theme-settings-input-bg text-white placeholder:text-theme-settings-input-placeholder text-sm rounded-lg focus:outline-primary-button active:outline-primary-button outline-none block w-full p-2.5"
placeholder="Azure OpenAI chat model deployment name"
defaultValue={settings?.AzureOpenAiModelPref}
required={true}
autoComplete="off"
spellCheck={false}
/>
</div>
</div>
<div className="w-full flex items-center gap-[36px]">
<div className="flex flex-col w-60">
<label className="text-white text-sm font-semibold block mb-3">
{t("llm.providers.azure_openai.chat_model_token_limit")}
</label>
<select
name="AzureOpenAiTokenLimit"
defaultValue={settings?.AzureOpenAiTokenLimit || 4096}
className="border-none bg-theme-settings-input-bg text-white placeholder:text-theme-settings-input-placeholder text-sm rounded-lg focus:outline-primary-button active:outline-primary-button outline-none block w-full p-2.5"
required={true}
>
<option value={4096}>4,096 (gpt-3.5-turbo)</option>
<option value={16384}>16,384 (gpt-3.5-16k)</option>
<option value={8192}>8,192 (gpt-4)</option>
<option value={32768}>32,768 (gpt-4-32k)</option>
<option value={128000}>
128,000 (gpt-4-turbo,gpt-4o,gpt-4o-mini,o1-mini)
</option>
<option value={200000}>200,000 (o1,o1-pro,o3-mini)</option>
<option value={1047576}>1,047,576 (gpt-4.1)</option>
</select>
</div>
<div className="flex flex-col w-60">
<label className="text-white text-sm font-semibold block mb-3">
{t("llm.providers.azure_openai.model_type")}
</label>
<select
name="AzureOpenAiModelType"
defaultValue={settings?.AzureOpenAiModelType || "default"}
className="border-none bg-theme-settings-input-bg text-white placeholder:text-theme-settings-input-placeholder text-sm rounded-lg focus:outline-primary-button active:outline-primary-button outline-none block w-full p-2.5"
required={true}
>
<option value="default">
{t("llm.providers.azure_openai.default")}
</option>
<option value="reasoning">
{t("llm.providers.azure_openai.reasoning")}
</option>
</select>
</div>
</div>
</div>
);
}