File size: 1,816 Bytes
b9fe2b4
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
import { Button } from '@/components/ui/button';
import { zodResolver } from '@hookform/resolvers/zod';
import { FormProvider, useForm } from 'react-hook-form';
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';

export function AppSettings() {
  const formSchema = useChatSettingSchema();
  const form = useForm<z.infer<typeof formSchema>>({
    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,
    },
  });

  function onSubmit(values: z.infer<typeof formSchema>) {
    console.log(values);
  }

  return (
    <section className="py-6 w-[500px] max-w-[25%] ">
      <div className="text-2xl font-bold mb-4 text-colors-text-neutral-strong px-6">
        App settings
      </div>
      <div className="overflow-auto max-h-[81vh] px-6 ">
        <FormProvider {...form}>
          <form onSubmit={form.handleSubmit(onSubmit)} className="space-y-6">
            <ChatBasicSetting></ChatBasicSetting>
            <ChatPromptEngine></ChatPromptEngine>
            <ChatModelSettings></ChatModelSettings>
          </form>
        </FormProvider>
      </div>
      <div className="p-6 text-center">
        <p className="text-colors-text-neutral-weak mb-1">
          There are unsaved changes
        </p>
        <Button variant={'tertiary'} className="w-full">
          Update
        </Button>
      </div>
    </section>
  );
}