- import {
- LlmModelType,
- ModelVariableType,
- settledModelVariableMap,
- } from '@/constants/knowledge';
- import { Divider, Flex, Form, InputNumber, Select, Slider, Switch } from 'antd';
- import camelCase from 'lodash/camelCase';
-
- import { useTranslate } from '@/hooks/common-hooks';
- import { useSelectLlmOptionsByModelType } from '@/hooks/llm-hooks';
- import { useCallback, useMemo } from 'react';
- import styles from './index.less';
-
- interface IProps {
- prefix?: string;
- formItemLayout?: any;
- handleParametersChange?(value: ModelVariableType): void;
- }
-
- const LlmSettingItems = ({ prefix, formItemLayout = {} }: IProps) => {
- const form = Form.useFormInstance();
- const { t } = useTranslate('chat');
- const parameterOptions = Object.values(ModelVariableType).map((x) => ({
- label: t(camelCase(x)),
- value: x,
- }));
-
- const handleParametersChange = useCallback(
- (value: ModelVariableType) => {
- const variable = settledModelVariableMap[value];
- form?.setFieldsValue(variable);
- },
- [form],
- );
-
- const memorizedPrefix = useMemo(() => (prefix ? [prefix] : []), [prefix]);
-
- const modelOptions = useSelectLlmOptionsByModelType();
-
- return (
- <>
- <Form.Item
- label={t('model')}
- name="llm_id"
- tooltip={t('modelTip')}
- {...formItemLayout}
- rules={[{ required: true, message: t('modelMessage') }]}
- >
- <Select options={modelOptions[LlmModelType.Chat]} showSearch />
- </Form.Item>
- <Divider></Divider>
- <Form.Item
- label={t('freedom')}
- name="parameter"
- tooltip={t('freedomTip')}
- {...formItemLayout}
- initialValue={ModelVariableType.Precise}
- >
- <Select<ModelVariableType>
- options={parameterOptions}
- onChange={handleParametersChange}
- />
- </Form.Item>
- <Form.Item
- label={t('temperature')}
- tooltip={t('temperatureTip')}
- {...formItemLayout}
- >
- <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={[...memorizedPrefix, 'temperature']}
- noStyle
- >
- <Slider
- className={styles.variableSlider}
- max={1}
- step={0.01}
- disabled={disabled}
- />
- </Form.Item>
- </Flex>
- <Form.Item name={[...memorizedPrefix, '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')} {...formItemLayout}>
- <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={[...memorizedPrefix, 'top_p']} noStyle>
- <Slider
- className={styles.variableSlider}
- max={1}
- step={0.01}
- disabled={disabled}
- />
- </Form.Item>
- </Flex>
- <Form.Item name={[...memorizedPrefix, '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')}
- {...formItemLayout}
- >
- <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={[...memorizedPrefix, 'presence_penalty']}
- noStyle
- >
- <Slider
- className={styles.variableSlider}
- max={1}
- step={0.01}
- disabled={disabled}
- />
- </Form.Item>
- </Flex>
- <Form.Item
- name={[...memorizedPrefix, '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')}
- {...formItemLayout}
- >
- <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={[...memorizedPrefix, 'frequency_penalty']}
- noStyle
- >
- <Slider
- className={styles.variableSlider}
- max={1}
- step={0.01}
- disabled={disabled}
- />
- </Form.Item>
- </Flex>
- <Form.Item
- name={[...memorizedPrefix, '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')}
- {...formItemLayout}
- >
- <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={[...memorizedPrefix, 'max_tokens']}
- noStyle
- >
- <Slider
- className={styles.variableSlider}
- max={2048}
- disabled={disabled}
- />
- </Form.Item>
- </Flex>
- <Form.Item name={[...memorizedPrefix, 'max_tokens']} noStyle>
- <InputNumber
- disabled={disabled}
- className={styles.sliderInputNumber}
- max={2048}
- min={0}
- />
- </Form.Item>
- </>
- );
- }}
- </Form.Item>
- </Flex>
- </Form.Item>
- </>
- );
- };
-
- export default LlmSettingItems;
|