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 { useComposeLlmOptionsByModelTypes } 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]; let nextVariable: Record = variable; if (prefix) { nextVariable = { [prefix]: variable }; } form.setFieldsValue(nextVariable); }, [form, prefix], ); const memorizedPrefix = useMemo(() => (prefix ? [prefix] : []), [prefix]); const modelOptions = useComposeLlmOptionsByModelTypes([ LlmModelType.Chat, LlmModelType.Image2text, ]); return ( <>