### What problem does this PR solve? feat: If the model supplier is not set, click the OK button to jump directly to the page for setting the model supplier. #3068 ### Type of change - [ ] Bug Fix (non-breaking change which fixes an issue) - [x] New Feature (non-breaking change which adds functionality) - [ ] Documentation Update - [ ] Refactoring - [ ] Performance Improvement - [ ] Other (please describe):
105 lines
2.9 KiB
TypeScript
105 lines
2.9 KiB
TypeScript
import { IModalManagerChildrenProps } from '@/components/modal-manager';
|
|
import { LlmModelType } from '@/constants/knowledge';
|
|
import { useTranslate } from '@/hooks/common-hooks';
|
|
import { ISystemModelSettingSavingParams } from '@/hooks/llm-hooks';
|
|
import { Form, Modal, Select } from 'antd';
|
|
import { useEffect } from 'react';
|
|
import { useFetchSystemModelSettingOnMount } from '../hooks';
|
|
|
|
interface IProps extends Omit<IModalManagerChildrenProps, 'showModal'> {
|
|
loading: boolean;
|
|
onOk: (
|
|
payload: Omit<ISystemModelSettingSavingParams, 'tenant_id' | 'name'>,
|
|
) => void;
|
|
}
|
|
|
|
const SystemModelSettingModal = ({
|
|
visible,
|
|
hideModal,
|
|
onOk,
|
|
loading,
|
|
}: IProps) => {
|
|
const [form] = Form.useForm();
|
|
const { systemSetting: initialValues, allOptions } =
|
|
useFetchSystemModelSettingOnMount();
|
|
const { t } = useTranslate('setting');
|
|
|
|
const handleOk = async () => {
|
|
const values = await form.validateFields();
|
|
onOk({
|
|
...values,
|
|
asr_id: values.asr_id ?? '',
|
|
embd_id: values.embd_id ?? '',
|
|
img2txt_id: values.img2txt_id ?? '',
|
|
llm_id: values.llm_id ?? '',
|
|
});
|
|
};
|
|
|
|
useEffect(() => {
|
|
if (visible) {
|
|
form.setFieldsValue(initialValues);
|
|
}
|
|
}, [form, initialValues, visible]);
|
|
|
|
const onFormLayoutChange = () => {};
|
|
|
|
return (
|
|
<Modal
|
|
title={t('systemModelSettings')}
|
|
open={visible}
|
|
onOk={handleOk}
|
|
onCancel={hideModal}
|
|
okButtonProps={{ loading }}
|
|
confirmLoading={loading}
|
|
>
|
|
<Form form={form} onValuesChange={onFormLayoutChange} layout={'vertical'}>
|
|
<Form.Item
|
|
label={t('chatModel')}
|
|
name="llm_id"
|
|
tooltip={t('chatModelTip')}
|
|
>
|
|
<Select options={allOptions[LlmModelType.Chat]} allowClear />
|
|
</Form.Item>
|
|
<Form.Item
|
|
label={t('embeddingModel')}
|
|
name="embd_id"
|
|
tooltip={t('embeddingModelTip')}
|
|
>
|
|
<Select options={allOptions[LlmModelType.Embedding]} allowClear />
|
|
</Form.Item>
|
|
<Form.Item
|
|
label={t('img2txtModel')}
|
|
name="img2txt_id"
|
|
tooltip={t('img2txtModelTip')}
|
|
>
|
|
<Select options={allOptions[LlmModelType.Image2text]} allowClear />
|
|
</Form.Item>
|
|
|
|
<Form.Item
|
|
label={t('sequence2txtModel')}
|
|
name="asr_id"
|
|
tooltip={t('sequence2txtModelTip')}
|
|
>
|
|
<Select options={allOptions[LlmModelType.Speech2text]} allowClear />
|
|
</Form.Item>
|
|
<Form.Item
|
|
label={t('rerankModel')}
|
|
name="rerank_id"
|
|
tooltip={t('rerankModelTip')}
|
|
>
|
|
<Select options={allOptions[LlmModelType.Rerank]} allowClear />
|
|
</Form.Item>
|
|
<Form.Item
|
|
label={t('ttsModel')}
|
|
name="tts_id"
|
|
tooltip={t('ttsModelTip')}
|
|
>
|
|
<Select options={allOptions[LlmModelType.TTS]} allowClear />
|
|
</Form.Item>
|
|
</Form>
|
|
</Modal>
|
|
);
|
|
};
|
|
|
|
export default SystemModelSettingModal;
|