mirror of
https://github.com/infiniflow/ragflow.git
synced 2025-12-08 20:42:30 +08:00
### What problem does this PR solve? Feat: Delete or filter conversations #3221 ### Type of change - [x] New Feature (non-breaking change which adds functionality)
97 lines
2.9 KiB
TypeScript
97 lines
2.9 KiB
TypeScript
import { ButtonLoading } from '@/components/ui/button';
|
|
import { Form } from '@/components/ui/form';
|
|
import { Separator } from '@/components/ui/separator';
|
|
import { useFetchDialog, useSetDialog } from '@/hooks/use-chat-request';
|
|
import { transformBase64ToFile, transformFile2Base64 } from '@/utils/file-util';
|
|
import { zodResolver } from '@hookform/resolvers/zod';
|
|
import { X } from 'lucide-react';
|
|
import { useEffect } from 'react';
|
|
import { useForm } from 'react-hook-form';
|
|
import { useParams } from 'umi';
|
|
import { z } from 'zod';
|
|
import ChatBasicSetting from './chat-basic-settings';
|
|
import { ChatModelSettings } from './chat-model-settings';
|
|
import { ChatPromptEngine } from './chat-prompt-engine';
|
|
import { useChatSettingSchema } from './use-chat-setting-schema';
|
|
|
|
type ChatSettingsProps = { switchSettingVisible(): void };
|
|
export function ChatSettings({ switchSettingVisible }: ChatSettingsProps) {
|
|
const formSchema = useChatSettingSchema();
|
|
const { data } = useFetchDialog();
|
|
const { setDialog, loading } = useSetDialog();
|
|
const { id } = useParams();
|
|
|
|
type FormSchemaType = z.infer<typeof formSchema>;
|
|
|
|
const form = useForm<FormSchemaType>({
|
|
resolver: zodResolver(formSchema),
|
|
defaultValues: {
|
|
name: '',
|
|
language: 'English',
|
|
prompt_config: {
|
|
quote: true,
|
|
keyword: false,
|
|
tts: false,
|
|
use_kg: false,
|
|
refine_multiturn: true,
|
|
},
|
|
top_n: 8,
|
|
vector_similarity_weight: 0.2,
|
|
top_k: 1024,
|
|
},
|
|
});
|
|
|
|
async function onSubmit(values: FormSchemaType) {
|
|
const icon = values.icon;
|
|
const avatar =
|
|
Array.isArray(icon) && icon.length > 0
|
|
? await transformFile2Base64(icon[0])
|
|
: '';
|
|
setDialog({
|
|
...data,
|
|
...values,
|
|
icon: avatar,
|
|
dialog_id: id,
|
|
});
|
|
}
|
|
|
|
function onInvalid(errors: any) {
|
|
console.log('Form validation failed:', errors);
|
|
}
|
|
|
|
useEffect(() => {
|
|
const nextData = {
|
|
...data,
|
|
icon: data.icon ? [transformBase64ToFile(data.icon)] : [],
|
|
};
|
|
form.reset(nextData as FormSchemaType);
|
|
}, [data, form]);
|
|
|
|
return (
|
|
<section className="p-5 w-[440px] border-l">
|
|
<div className="flex justify-between items-center text-base pb-2">
|
|
Chat Settings
|
|
<X className="size-4 cursor-pointer" onClick={switchSettingVisible} />
|
|
</div>
|
|
<Form {...form}>
|
|
<form onSubmit={form.handleSubmit(onSubmit, onInvalid)}>
|
|
<section className="space-y-6 overflow-auto max-h-[85vh] pr-4">
|
|
<ChatBasicSetting></ChatBasicSetting>
|
|
<Separator />
|
|
<ChatPromptEngine></ChatPromptEngine>
|
|
<Separator />
|
|
<ChatModelSettings></ChatModelSettings>
|
|
</section>
|
|
<ButtonLoading
|
|
className="w-full my-4"
|
|
type="submit"
|
|
loading={loading}
|
|
>
|
|
Update
|
|
</ButtonLoading>
|
|
</form>
|
|
</Form>
|
|
</section>
|
|
);
|
|
}
|