| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289 |
- import {
- LlmModelType,
- ModelVariableType,
- settledModelVariableMap,
- } from '@/constants/knowledge';
- import { Divider, Flex, Form, InputNumber, Select, Slider, Switch } from 'antd';
- import classNames from 'classnames';
- import camelCase from 'lodash/camelCase';
- import { useEffect } from 'react';
- import { ISegmentedContentProps } from '../interface';
-
- import { useTranslate } from '@/hooks/commonHooks';
- import { useFetchLlmList, useSelectLlmOptions } from '@/hooks/llmHooks';
- import { Variable } from '@/interfaces/database/chat';
- import { variableEnabledFieldMap } from '../constants';
- import styles from './index.less';
-
- const ModelSetting = ({
- show,
- form,
- initialLlmSetting,
- visible,
- }: ISegmentedContentProps & {
- initialLlmSetting?: Variable;
- visible?: boolean;
- }) => {
- const { t } = useTranslate('chat');
- const parameterOptions = Object.values(ModelVariableType).map((x) => ({
- label: t(camelCase(x)),
- value: x,
- }));
-
- const modelOptions = useSelectLlmOptions();
-
- const handleParametersChange = (value: ModelVariableType) => {
- const variable = settledModelVariableMap[value];
- form.setFieldsValue({ llm_setting: variable });
- };
-
- useEffect(() => {
- if (visible) {
- const values = Object.keys(variableEnabledFieldMap).reduce<
- Record<string, boolean>
- >((pre, field) => {
- pre[field] =
- initialLlmSetting === undefined
- ? true
- : !!initialLlmSetting[
- variableEnabledFieldMap[
- field as keyof typeof variableEnabledFieldMap
- ] as keyof Variable
- ];
- return pre;
- }, {});
- form.setFieldsValue(values);
- }
- }, [form, initialLlmSetting, visible]);
-
- useFetchLlmList(LlmModelType.Chat);
-
- return (
- <section
- className={classNames({
- [styles.segmentedHidden]: !show,
- })}
- >
- <Form.Item
- label={t('model')}
- name="llm_id"
- tooltip={t('modelTip')}
- rules={[{ required: true, message: t('modelMessage') }]}
- >
- <Select options={modelOptions} showSearch />
- </Form.Item>
- <Divider></Divider>
- <Form.Item
- label={t('freedom')}
- name="parameters"
- tooltip={t('freedomTip')}
- initialValue={ModelVariableType.Precise}
- >
- <Select<ModelVariableType>
- options={parameterOptions}
- onChange={handleParametersChange}
- />
- </Form.Item>
- <Form.Item label={t('temperature')} tooltip={t('temperatureTip')}>
- <Flex gap={20} align="center">
- <Form.Item
- name={'temperatureEnabled'}
- valuePropName="checked"
- noStyle
- >
- <Switch size="small" />
- </Form.Item>
- <Form.Item noStyle dependencies={['temperatureEnabled']}>
- {({ getFieldValue }) => {
- const disabled = !getFieldValue('temperatureEnabled');
- return (
- <>
- <Flex flex={1}>
- <Form.Item name={['llm_setting', 'temperature']} noStyle>
- <Slider
- className={styles.variableSlider}
- max={1}
- step={0.01}
- disabled={disabled}
- />
- </Form.Item>
- </Flex>
- <Form.Item name={['llm_setting', 'temperature']} noStyle>
- <InputNumber
- className={styles.sliderInputNumber}
- max={1}
- min={0}
- step={0.01}
- disabled={disabled}
- />
- </Form.Item>
- </>
- );
- }}
- </Form.Item>
- </Flex>
- </Form.Item>
- <Form.Item label={t('topP')} tooltip={t('topPTip')}>
- <Flex gap={20} align="center">
- <Form.Item name={'topPEnabled'} valuePropName="checked" noStyle>
- <Switch size="small" />
- </Form.Item>
- <Form.Item noStyle dependencies={['topPEnabled']}>
- {({ getFieldValue }) => {
- const disabled = !getFieldValue('topPEnabled');
- return (
- <>
- <Flex flex={1}>
- <Form.Item name={['llm_setting', 'top_p']} noStyle>
- <Slider
- className={styles.variableSlider}
- max={1}
- step={0.01}
- disabled={disabled}
- />
- </Form.Item>
- </Flex>
- <Form.Item name={['llm_setting', 'top_p']} noStyle>
- <InputNumber
- className={styles.sliderInputNumber}
- max={1}
- min={0}
- step={0.01}
- disabled={disabled}
- />
- </Form.Item>
- </>
- );
- }}
- </Form.Item>
- </Flex>
- </Form.Item>
- <Form.Item label={t('presencePenalty')} tooltip={t('presencePenaltyTip')}>
- <Flex gap={20} align="center">
- <Form.Item
- name={'presencePenaltyEnabled'}
- valuePropName="checked"
- noStyle
- >
- <Switch size="small" />
- </Form.Item>
- <Form.Item noStyle dependencies={['presencePenaltyEnabled']}>
- {({ getFieldValue }) => {
- const disabled = !getFieldValue('presencePenaltyEnabled');
- return (
- <>
- <Flex flex={1}>
- <Form.Item
- name={['llm_setting', 'presence_penalty']}
- noStyle
- >
- <Slider
- className={styles.variableSlider}
- max={1}
- step={0.01}
- disabled={disabled}
- />
- </Form.Item>
- </Flex>
- <Form.Item name={['llm_setting', 'presence_penalty']} noStyle>
- <InputNumber
- className={styles.sliderInputNumber}
- max={1}
- min={0}
- step={0.01}
- disabled={disabled}
- />
- </Form.Item>
- </>
- );
- }}
- </Form.Item>
- </Flex>
- </Form.Item>
- <Form.Item
- label={t('frequencyPenalty')}
- tooltip={t('frequencyPenaltyTip')}
- >
- <Flex gap={20} align="center">
- <Form.Item
- name={'frequencyPenaltyEnabled'}
- valuePropName="checked"
- noStyle
- >
- <Switch size="small" />
- </Form.Item>
- <Form.Item noStyle dependencies={['frequencyPenaltyEnabled']}>
- {({ getFieldValue }) => {
- const disabled = !getFieldValue('frequencyPenaltyEnabled');
- return (
- <>
- <Flex flex={1}>
- <Form.Item
- name={['llm_setting', 'frequency_penalty']}
- noStyle
- >
- <Slider
- className={styles.variableSlider}
- max={1}
- step={0.01}
- disabled={disabled}
- />
- </Form.Item>
- </Flex>
- <Form.Item
- name={['llm_setting', 'frequency_penalty']}
- noStyle
- >
- <InputNumber
- className={styles.sliderInputNumber}
- max={1}
- min={0}
- step={0.01}
- disabled={disabled}
- />
- </Form.Item>
- </>
- );
- }}
- </Form.Item>
- </Flex>
- </Form.Item>
- <Form.Item label={t('maxTokens')} tooltip={t('maxTokensTip')}>
- <Flex gap={20} align="center">
- <Form.Item name={'maxTokensEnabled'} valuePropName="checked" noStyle>
- <Switch size="small" />
- </Form.Item>
- <Form.Item noStyle dependencies={['maxTokensEnabled']}>
- {({ getFieldValue }) => {
- const disabled = !getFieldValue('maxTokensEnabled');
-
- return (
- <>
- <Flex flex={1}>
- <Form.Item name={['llm_setting', 'max_tokens']} noStyle>
- <Slider
- className={styles.variableSlider}
- max={2048}
- disabled={disabled}
- />
- </Form.Item>
- </Flex>
- <Form.Item name={['llm_setting', 'max_tokens']} noStyle>
- <InputNumber
- disabled={disabled}
- className={styles.sliderInputNumber}
- max={2048}
- min={0}
- />
- </Form.Item>
- </>
- );
- }}
- </Form.Item>
- </Flex>
- </Form.Item>
- </section>
- );
- };
-
- export default ModelSetting;
|