mirror of
https://github.com/infiniflow/ragflow.git
synced 2025-12-08 20:42:30 +08:00
fix(dataset, next-chats): Fix data form data acquisition logic And Optimize the chat settings interface and add language selection (#9629)
### What problem does this PR solve? fix(dataset): data form data acquisition logic fix(next-chats): Optimize the chat settings interface and add language selection - Replace form.formControl.trigger with form.trigger - Use form.getValues() instead of form.formState.values - Add language selection to support multiple languages - Add default chat settings values - Add new settings: icon, description, knowledge base ID, etc. ### Type of change - [x] 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):
This commit is contained in:
@ -187,8 +187,8 @@ export function GeneralForm() {
|
|||||||
disabled={submitLoading}
|
disabled={submitLoading}
|
||||||
onClick={() => {
|
onClick={() => {
|
||||||
(async () => {
|
(async () => {
|
||||||
let isValidate = await form.formControl.trigger('name');
|
let isValidate = await form.trigger('name');
|
||||||
const { name, description } = form.formState.values;
|
const { name, description } = form.getValues();
|
||||||
const avatar = avatarBase64Str;
|
const avatar = avatarBase64Str;
|
||||||
|
|
||||||
if (isValidate) {
|
if (isValidate) {
|
||||||
|
|||||||
@ -14,6 +14,7 @@ import {
|
|||||||
} from '@/components/ui/form';
|
} from '@/components/ui/form';
|
||||||
import { Input } from '@/components/ui/input';
|
import { Input } from '@/components/ui/input';
|
||||||
import { Textarea } from '@/components/ui/textarea';
|
import { Textarea } from '@/components/ui/textarea';
|
||||||
|
import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from '@/components/ui/select';
|
||||||
import { useTranslate } from '@/hooks/common-hooks';
|
import { useTranslate } from '@/hooks/common-hooks';
|
||||||
import { useFormContext } from 'react-hook-form';
|
import { useFormContext } from 'react-hook-form';
|
||||||
|
|
||||||
@ -21,6 +22,17 @@ export default function ChatBasicSetting() {
|
|||||||
const { t } = useTranslate('chat');
|
const { t } = useTranslate('chat');
|
||||||
const form = useFormContext();
|
const form = useFormContext();
|
||||||
|
|
||||||
|
const languageOptions = [
|
||||||
|
{ value: 'English', label: 'English' },
|
||||||
|
{ value: 'Chinese', label: 'Chinese' },
|
||||||
|
{ value: 'Spanish', label: 'Spanish' },
|
||||||
|
{ value: 'French', label: 'French' },
|
||||||
|
{ value: 'German', label: 'German' },
|
||||||
|
{ value: 'Japanese', label: 'Japanese' },
|
||||||
|
{ value: 'Korean', label: 'Korean' },
|
||||||
|
{ value: 'Vietnamese', label: 'Vietnamese' },
|
||||||
|
];
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="space-y-8">
|
<div className="space-y-8">
|
||||||
<FormField
|
<FormField
|
||||||
@ -55,6 +67,30 @@ export default function ChatBasicSetting() {
|
|||||||
</FormItem>
|
</FormItem>
|
||||||
)}
|
)}
|
||||||
/>
|
/>
|
||||||
|
<FormField
|
||||||
|
control={form.control}
|
||||||
|
name="language"
|
||||||
|
render={({ field }) => (
|
||||||
|
<FormItem>
|
||||||
|
<FormLabel>{t('language')}</FormLabel>
|
||||||
|
<Select onValueChange={field.onChange} defaultValue={field.value}>
|
||||||
|
<FormControl>
|
||||||
|
<SelectTrigger>
|
||||||
|
<SelectValue placeholder={t('common.languagePlaceholder')} />
|
||||||
|
</SelectTrigger>
|
||||||
|
</FormControl>
|
||||||
|
<SelectContent>
|
||||||
|
{languageOptions.map((option) => (
|
||||||
|
<SelectItem key={option.value} value={option.value}>
|
||||||
|
{option.label}
|
||||||
|
</SelectItem>
|
||||||
|
))}
|
||||||
|
</SelectContent>
|
||||||
|
</Select>
|
||||||
|
<FormMessage />
|
||||||
|
</FormItem>
|
||||||
|
)}
|
||||||
|
/>
|
||||||
<FormField
|
<FormField
|
||||||
control={form.control}
|
control={form.control}
|
||||||
name="description"
|
name="description"
|
||||||
|
|||||||
@ -35,13 +35,18 @@ export function ChatSettings({ switchSettingVisible }: ChatSettingsProps) {
|
|||||||
shouldUnregister: true,
|
shouldUnregister: true,
|
||||||
defaultValues: {
|
defaultValues: {
|
||||||
name: '',
|
name: '',
|
||||||
|
icon: [],
|
||||||
language: 'English',
|
language: 'English',
|
||||||
|
description: '',
|
||||||
|
kb_ids: [],
|
||||||
prompt_config: {
|
prompt_config: {
|
||||||
quote: true,
|
quote: true,
|
||||||
keyword: false,
|
keyword: false,
|
||||||
tts: false,
|
tts: false,
|
||||||
use_kg: false,
|
use_kg: false,
|
||||||
refine_multiturn: true,
|
refine_multiturn: true,
|
||||||
|
system: '',
|
||||||
|
parameters: [],
|
||||||
},
|
},
|
||||||
top_n: 8,
|
top_n: 8,
|
||||||
vector_similarity_weight: 0.2,
|
vector_similarity_weight: 0.2,
|
||||||
|
|||||||
@ -34,11 +34,11 @@ export function useChatSettingSchema() {
|
|||||||
name: z.string().min(1, { message: t('assistantNameMessage') }),
|
name: z.string().min(1, { message: t('assistantNameMessage') }),
|
||||||
icon: z.array(z.instanceof(File)),
|
icon: z.array(z.instanceof(File)),
|
||||||
language: z.string().min(1, {
|
language: z.string().min(1, {
|
||||||
message: 'Username must be at least 2 characters.',
|
message: t('languageMessage'),
|
||||||
}),
|
}),
|
||||||
description: z.string(),
|
description: z.string().optional(),
|
||||||
kb_ids: z.array(z.string()).min(0, {
|
kb_ids: z.array(z.string()).min(0, {
|
||||||
message: 'Username must be at least 1 characters.',
|
message: t('knowledgeBasesMessage'),
|
||||||
}),
|
}),
|
||||||
prompt_config: promptConfigSchema,
|
prompt_config: promptConfigSchema,
|
||||||
...rerankFormSchema,
|
...rerankFormSchema,
|
||||||
|
|||||||
Reference in New Issue
Block a user