From 18150eaa9b7106ffe34d761c1e2a230f7437358b Mon Sep 17 00:00:00 2001 From: dengqichen Date: Fri, 13 Dec 2024 14:00:16 +0800 Subject: [PATCH] =?UTF-8?q?=E5=A2=9E=E5=8A=A0=E5=B7=A5=E5=85=B7=E6=A0=8F?= =?UTF-8?q?=E6=8F=90=E7=A4=BA=E3=80=82?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../Design/components/NodeConfigModal.tsx | 28 ++++++++++++------- .../Workflow/Definition/Design/index.tsx | 10 +++++++ 2 files changed, 28 insertions(+), 10 deletions(-) diff --git a/frontend/src/pages/Workflow/Definition/Design/components/NodeConfigModal.tsx b/frontend/src/pages/Workflow/Definition/Design/components/NodeConfigModal.tsx index c3068f04..539fe9b8 100644 --- a/frontend/src/pages/Workflow/Definition/Design/components/NodeConfigModal.tsx +++ b/frontend/src/pages/Workflow/Definition/Design/components/NodeConfigModal.tsx @@ -32,15 +32,17 @@ const NodeConfigDrawer: React.FC = ({ useEffect(() => { if (visible && node && nodeDefinition) { - // 获取节点当前的配置 - const currentConfig = { - code: node.getProp('code'), - name: node.attr('label/text'), - description: node.getProp('description'), - ...node.getProp('config'), - }; + // 添加日志 + console.log('NodeConfigModal - nodeDefinition:', nodeDefinition); + console.log('NodeConfigModal - configSchema:', nodeDefinition.graphConfig.configSchema); - form.setFieldsValue(currentConfig); + // 获取节点配置 + const config = node.getProp('config'); + console.log('NodeConfigModal - node config:', config); + + // 设置表单值 + form.setFieldsValue(config || {}); + console.log('NodeConfigModal - form values after set:', form.getFieldsValue()); } }, [visible, node, nodeDefinition, form]); @@ -120,14 +122,20 @@ const NodeConfigDrawer: React.FC = ({ }; const renderFormItems = () => { - if (!nodeDefinition?.graphConfig.configSchema) return null; + if (!nodeDefinition?.graphConfig.configSchema) { + console.log('NodeConfigModal - No configSchema found'); + return null; + } const { configSchema } = nodeDefinition.graphConfig; + console.log('NodeConfigModal - Rendering form items with schema:', configSchema); + const formItems = []; // 根据 configSchema 生成表单项 if (configSchema.properties) { - Object.entries(configSchema.properties).forEach(([key, property]: [string, SchemaProperty]) => { + Object.entries(configSchema.properties).forEach(([key, property]) => { + console.log('NodeConfigModal - Rendering field:', key, property); const isRequired = configSchema.required?.includes(key) || false; const formItem = renderFormItem(key, property, isRequired); if (formItem) { diff --git a/frontend/src/pages/Workflow/Definition/Design/index.tsx b/frontend/src/pages/Workflow/Definition/Design/index.tsx index e38afa0e..e0b9508a 100644 --- a/frontend/src/pages/Workflow/Definition/Design/index.tsx +++ b/frontend/src/pages/Workflow/Definition/Design/index.tsx @@ -94,6 +94,13 @@ const WorkflowDesign: React.FC = () => { // 从节点定义列表中找到对应的定义 const definition = nodeDefinitions.find(def => def.type === nodeType); if (definition) { + console.log('Opening node config:', { + type: nodeType, + definition: definition, + nodeData: node.getData(), + nodeProps: node.getProp(), + config: node.getProp('config') + }); setSelectedNode(node); setSelectedNodeDefinition(definition); setConfigModalVisible(true); @@ -125,7 +132,10 @@ const WorkflowDesign: React.FC = () => { // 创建节点 response.graph.nodes.forEach((nodeData: any) => { + console.log('Creating node with data:', nodeData); // 添加日志 const node = addNodeToGraph(graphInstance, nodeData); + // 保存节点配置 + node.setProp('config', nodeData.config); nodeMap.set(nodeData.id, node); });