From fef663a59d60071a1b01269cd5a3832d6f2aa432 Mon Sep 17 00:00:00 2001 From: balibabu Date: Tue, 25 Jun 2024 19:28:24 +0800 Subject: [PATCH] feat: build categorize list from object #918 (#1276) ### What problem does this PR solve? feat: build categorize list from object #918 ### Type of change - [x] New Feature (non-breaking change which adds functionality) --- web/src/components/llm-select/index.tsx | 22 +++++- .../components/llm-setting-items/index.tsx | 45 +++++++++-- .../model-setting.tsx | 16 +--- web/src/pages/flow/categorize-form/hooks.ts | 79 +++++++++++++++++++ web/src/pages/flow/categorize-form/index.tsx | 19 ++++- web/src/pages/flow/flow-drawer/index.tsx | 1 + web/src/pages/flow/generate-form/index.tsx | 39 +-------- web/src/pages/flow/hooks.ts | 29 +++++++ web/src/pages/flow/interface.ts | 18 ++++- web/src/pages/flow/store.ts | 4 + web/src/pages/flow/utils.ts | 5 +- 11 files changed, 208 insertions(+), 69 deletions(-) diff --git a/web/src/components/llm-select/index.tsx b/web/src/components/llm-select/index.tsx index 4d730c80c..61d37b599 100644 --- a/web/src/components/llm-select/index.tsx +++ b/web/src/components/llm-select/index.tsx @@ -1,16 +1,30 @@ import { Popover, Select } from 'antd'; import LlmSettingItems from '../llm-setting-items'; -const LLMSelect = () => { +interface IProps { + id?: string; + value?: string; + onChange?: (value: string) => void; +} + +const LLMSelect = ({ id, value, onChange }: IProps) => { const content = ( -
- {}}> +
+
); return ( - ); }; diff --git a/web/src/components/llm-setting-items/index.tsx b/web/src/components/llm-setting-items/index.tsx index 398d1c4ca..8b88b8703 100644 --- a/web/src/components/llm-setting-items/index.tsx +++ b/web/src/components/llm-setting-items/index.tsx @@ -1,24 +1,38 @@ -import { LlmModelType, ModelVariableType } from '@/constants/knowledge'; +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/commonHooks'; import { useSelectLlmOptionsByModelType } from '@/hooks/llmHooks'; -import { useMemo } from 'react'; +import { useCallback, useMemo } from 'react'; import styles from './index.less'; interface IProps { prefix?: string; - handleParametersChange(value: ModelVariableType): void; + formItemLayout?: any; + handleParametersChange?(value: ModelVariableType): void; } -const LlmSettingItems = ({ prefix, handleParametersChange }: IProps) => { +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(); @@ -29,6 +43,7 @@ const LlmSettingItems = ({ prefix, handleParametersChange }: IProps) => { label={t('model')} name="llm_id" tooltip={t('modelTip')} + {...formItemLayout} rules={[{ required: true, message: t('modelMessage') }]} >