| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  | import type { FC } from 'react' | 
					
						
							|  |  |  | import React from 'react' | 
					
						
							|  |  |  | import { useTranslation } from 'react-i18next' | 
					
						
							|  |  |  | import MemoryConfig from '../_base/components/memory-config' | 
					
						
							|  |  |  | import VarReferencePicker from '../_base/components/variable/var-reference-picker' | 
					
						
							|  |  |  | import Editor from '../_base/components/prompt/editor' | 
					
						
							|  |  |  | import ResultPanel from '../../run/result-panel' | 
					
						
							| 
									
										
										
										
											2024-10-21 10:32:37 +08:00
										 |  |  | import ConfigVision from '../_base/components/config-vision' | 
					
						
							| 
									
										
										
										
											2025-03-03 13:29:59 +08:00
										 |  |  | import { findVariableWhenOnLLMVision } from '../utils' | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  | import useConfig from './use-config' | 
					
						
							|  |  |  | import type { ParameterExtractorNodeType } from './types' | 
					
						
							|  |  |  | import ExtractParameter from './components/extract-parameter/list' | 
					
						
							|  |  |  | import ImportFromTool from './components/extract-parameter/import-from-tool' | 
					
						
							|  |  |  | import AddExtractParameter from './components/extract-parameter/update' | 
					
						
							|  |  |  | import ReasoningModePicker from './components/reasoning-mode-picker' | 
					
						
							|  |  |  | import Field from '@/app/components/workflow/nodes/_base/components/field' | 
					
						
							|  |  |  | import Split from '@/app/components/workflow/nodes/_base/components/split' | 
					
						
							|  |  |  | import ModelParameterModal from '@/app/components/header/account-setting/model-provider-page/model-parameter-modal' | 
					
						
							|  |  |  | import OutputVars, { VarItem } from '@/app/components/workflow/nodes/_base/components/output-vars' | 
					
						
							|  |  |  | import { InputVarType, type NodePanelProps } from '@/app/components/workflow/types' | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  | import Tooltip from '@/app/components/base/tooltip' | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  | import BeforeRunForm from '@/app/components/workflow/nodes/_base/components/before-run-form' | 
					
						
							|  |  |  | import { VarType } from '@/app/components/workflow/types' | 
					
						
							| 
									
										
										
										
											2024-12-11 14:21:38 +08:00
										 |  |  | import { FieldCollapse } from '@/app/components/workflow/nodes/_base/components/collapse' | 
					
						
							| 
									
										
										
										
											2025-03-03 13:29:59 +08:00
										 |  |  | import type { Props as FormProps } from '@/app/components/workflow/nodes/_base/components/before-run-form/form' | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | const i18nPrefix = 'workflow.nodes.parameterExtractor' | 
					
						
							|  |  |  | const i18nCommonPrefix = 'workflow.common' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const Panel: FC<NodePanelProps<ParameterExtractorNodeType>> = ({ | 
					
						
							|  |  |  |   id, | 
					
						
							|  |  |  |   data, | 
					
						
							|  |  |  | }) => { | 
					
						
							|  |  |  |   const { t } = useTranslation() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const { | 
					
						
							|  |  |  |     readOnly, | 
					
						
							|  |  |  |     inputs, | 
					
						
							|  |  |  |     handleInputVarChange, | 
					
						
							|  |  |  |     filterVar, | 
					
						
							|  |  |  |     isChatModel, | 
					
						
							|  |  |  |     isChatMode, | 
					
						
							|  |  |  |     isCompletionModel, | 
					
						
							|  |  |  |     handleModelChanged, | 
					
						
							|  |  |  |     handleImportFromTool, | 
					
						
							|  |  |  |     handleCompletionParamsChange, | 
					
						
							|  |  |  |     addExtractParameter, | 
					
						
							|  |  |  |     handleExactParamsChange, | 
					
						
							|  |  |  |     handleInstructionChange, | 
					
						
							|  |  |  |     hasSetBlockStatus, | 
					
						
							|  |  |  |     handleMemoryChange, | 
					
						
							|  |  |  |     isSupportFunctionCall, | 
					
						
							|  |  |  |     handleReasoningModeChange, | 
					
						
							|  |  |  |     availableVars, | 
					
						
							|  |  |  |     availableNodesWithParent, | 
					
						
							| 
									
										
										
										
											2025-03-03 13:29:59 +08:00
										 |  |  |     availableVisionVars, | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |     inputVarValues, | 
					
						
							|  |  |  |     varInputs, | 
					
						
							| 
									
										
										
										
											2024-10-21 10:32:37 +08:00
										 |  |  |     isVisionModel, | 
					
						
							|  |  |  |     handleVisionResolutionChange, | 
					
						
							|  |  |  |     handleVisionResolutionEnabledChange, | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |     isShowSingleRun, | 
					
						
							|  |  |  |     hideSingleRun, | 
					
						
							|  |  |  |     runningStatus, | 
					
						
							|  |  |  |     handleRun, | 
					
						
							|  |  |  |     handleStop, | 
					
						
							|  |  |  |     runResult, | 
					
						
							|  |  |  |     setInputVarValues, | 
					
						
							| 
									
										
										
										
											2025-03-03 13:29:59 +08:00
										 |  |  |     visionFiles, | 
					
						
							|  |  |  |     setVisionFiles, | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |   } = useConfig(id, data) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const model = inputs.model | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-03 13:29:59 +08:00
										 |  |  |   const singleRunForms = (() => { | 
					
						
							|  |  |  |     const forms: FormProps[] = [] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     forms.push( | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  |         label: t('workflow.nodes.llm.singleRun.variable')!, | 
					
						
							|  |  |  |         inputs: [{ | 
					
						
							|  |  |  |           label: t(`${i18nPrefix}.inputVar`)!, | 
					
						
							|  |  |  |           variable: 'query', | 
					
						
							|  |  |  |           type: InputVarType.paragraph, | 
					
						
							|  |  |  |           required: true, | 
					
						
							|  |  |  |         }, ...varInputs], | 
					
						
							|  |  |  |         values: inputVarValues, | 
					
						
							|  |  |  |         onChange: setInputVarValues, | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-16 08:54:18 +08:00
										 |  |  |     if (isVisionModel && data.vision?.enabled && data.vision?.configs?.variable_selector) { | 
					
						
							| 
									
										
										
										
											2025-03-03 13:29:59 +08:00
										 |  |  |       const currentVariable = findVariableWhenOnLLMVision(data.vision.configs.variable_selector, availableVisionVars) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       forms.push( | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |           label: t('workflow.nodes.llm.vision')!, | 
					
						
							|  |  |  |           inputs: [{ | 
					
						
							|  |  |  |             label: currentVariable?.variable as any, | 
					
						
							|  |  |  |             variable: '#files#', | 
					
						
							|  |  |  |             type: currentVariable?.formType as any, | 
					
						
							|  |  |  |             required: false, | 
					
						
							|  |  |  |           }], | 
					
						
							|  |  |  |           values: { '#files#': visionFiles }, | 
					
						
							|  |  |  |           onChange: keyValue => setVisionFiles((keyValue as any)['#files#']), | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |       ) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return forms | 
					
						
							|  |  |  |   })() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |   return ( | 
					
						
							| 
									
										
										
										
											2024-12-11 14:21:38 +08:00
										 |  |  |     <div className='pt-2'> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |       <div className='space-y-4 px-4'> | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |         <Field | 
					
						
							|  |  |  |           title={t(`${i18nCommonPrefix}.model`)} | 
					
						
							| 
									
										
										
										
											2025-04-27 16:12:02 +08:00
										 |  |  |           required | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |         > | 
					
						
							|  |  |  |           <ModelParameterModal | 
					
						
							|  |  |  |             popupClassName='!w-[387px]' | 
					
						
							|  |  |  |             isInWorkflow | 
					
						
							|  |  |  |             isAdvancedMode={true} | 
					
						
							|  |  |  |             mode={model?.mode} | 
					
						
							|  |  |  |             provider={model?.provider} | 
					
						
							|  |  |  |             completionParams={model?.completion_params} | 
					
						
							|  |  |  |             modelId={model?.name} | 
					
						
							|  |  |  |             setModel={handleModelChanged} | 
					
						
							|  |  |  |             onCompletionParamsChange={handleCompletionParamsChange} | 
					
						
							|  |  |  |             hideDebugWithMultipleModel | 
					
						
							|  |  |  |             debugWithMultipleModel={false} | 
					
						
							|  |  |  |             readonly={readOnly} | 
					
						
							|  |  |  |           /> | 
					
						
							|  |  |  |         </Field> | 
					
						
							| 
									
										
										
										
											2024-10-21 10:32:37 +08:00
										 |  |  |         <Field | 
					
						
							|  |  |  |           title={t(`${i18nPrefix}.inputVar`)} | 
					
						
							| 
									
										
										
										
											2025-04-27 16:12:02 +08:00
										 |  |  |           required | 
					
						
							| 
									
										
										
										
											2024-10-21 10:32:37 +08:00
										 |  |  |         > | 
					
						
							|  |  |  |           <> | 
					
						
							|  |  |  |             <VarReferencePicker | 
					
						
							|  |  |  |               readonly={readOnly} | 
					
						
							|  |  |  |               nodeId={id} | 
					
						
							|  |  |  |               isShowNodeName | 
					
						
							|  |  |  |               value={inputs.query || []} | 
					
						
							|  |  |  |               onChange={handleInputVarChange} | 
					
						
							|  |  |  |               filterVar={filterVar} | 
					
						
							|  |  |  |             /> | 
					
						
							|  |  |  |           </> | 
					
						
							|  |  |  |         </Field> | 
					
						
							|  |  |  |         <Split /> | 
					
						
							|  |  |  |         <ConfigVision | 
					
						
							|  |  |  |           nodeId={id} | 
					
						
							|  |  |  |           readOnly={readOnly} | 
					
						
							|  |  |  |           isVisionModel={isVisionModel} | 
					
						
							|  |  |  |           enabled={inputs.vision?.enabled} | 
					
						
							|  |  |  |           onEnabledChange={handleVisionResolutionEnabledChange} | 
					
						
							|  |  |  |           config={inputs.vision?.configs} | 
					
						
							|  |  |  |           onConfigChange={handleVisionResolutionChange} | 
					
						
							|  |  |  |         /> | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |         <Field | 
					
						
							|  |  |  |           title={t(`${i18nPrefix}.extractParameters`)} | 
					
						
							| 
									
										
										
										
											2025-04-27 16:12:02 +08:00
										 |  |  |           required | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |           operations={ | 
					
						
							|  |  |  |             !readOnly | 
					
						
							|  |  |  |               ? ( | 
					
						
							|  |  |  |                 <div className='flex items-center space-x-1'> | 
					
						
							|  |  |  |                   {!readOnly && ( | 
					
						
							|  |  |  |                     <ImportFromTool onImport={handleImportFromTool} /> | 
					
						
							|  |  |  |                   )} | 
					
						
							| 
									
										
										
										
											2025-04-10 17:15:48 +08:00
										 |  |  |                   {!readOnly && (<div className='h-3 w-px bg-divider-regular'></div>)} | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |                   <AddExtractParameter type='add' onSave={addExtractParameter} /> | 
					
						
							|  |  |  |                 </div> | 
					
						
							|  |  |  |               ) | 
					
						
							|  |  |  |               : undefined | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         > | 
					
						
							|  |  |  |           <ExtractParameter | 
					
						
							|  |  |  |             readonly={readOnly} | 
					
						
							|  |  |  |             list={inputs.parameters || []} | 
					
						
							|  |  |  |             onChange={handleExactParamsChange} | 
					
						
							|  |  |  |           /> | 
					
						
							|  |  |  |         </Field> | 
					
						
							|  |  |  |         <Editor | 
					
						
							|  |  |  |           title={ | 
					
						
							|  |  |  |             <div className='flex items-center space-x-1'> | 
					
						
							|  |  |  |               <span className='uppercase'>{t(`${i18nPrefix}.instruction`)}</span> | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  |               <Tooltip | 
					
						
							|  |  |  |                 popupContent={ | 
					
						
							|  |  |  |                   <div className='w-[120px]'> | 
					
						
							|  |  |  |                     {t(`${i18nPrefix}.instructionTip`)} | 
					
						
							|  |  |  |                   </div> | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 triggerClassName='w-3.5 h-3.5 ml-0.5' | 
					
						
							|  |  |  |               /> | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |             </div> | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           value={inputs.instruction} | 
					
						
							|  |  |  |           onChange={handleInstructionChange} | 
					
						
							|  |  |  |           readOnly={readOnly} | 
					
						
							|  |  |  |           isChatModel={isChatModel} | 
					
						
							|  |  |  |           isChatApp={isChatMode} | 
					
						
							|  |  |  |           isShowContext={false} | 
					
						
							|  |  |  |           hasSetBlockStatus={hasSetBlockStatus} | 
					
						
							|  |  |  |           nodesOutputVars={availableVars} | 
					
						
							|  |  |  |           availableNodes={availableNodesWithParent} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |       </div> | 
					
						
							| 
									
										
										
										
											2024-12-11 14:21:38 +08:00
										 |  |  |       <FieldCollapse title={t(`${i18nPrefix}.advancedSetting`)}> | 
					
						
							|  |  |  |         <> | 
					
						
							|  |  |  |           {/* Memory */} | 
					
						
							|  |  |  |           {isChatMode && ( | 
					
						
							|  |  |  |             <div className='mt-4'> | 
					
						
							|  |  |  |               <MemoryConfig | 
					
						
							|  |  |  |                 readonly={readOnly} | 
					
						
							|  |  |  |                 config={{ data: inputs.memory }} | 
					
						
							|  |  |  |                 onChange={handleMemoryChange} | 
					
						
							|  |  |  |                 canSetRoleName={isCompletionModel} | 
					
						
							|  |  |  |               /> | 
					
						
							|  |  |  |             </div> | 
					
						
							|  |  |  |           )} | 
					
						
							|  |  |  |           {isSupportFunctionCall && ( | 
					
						
							|  |  |  |             <div className='mt-2'> | 
					
						
							|  |  |  |               <ReasoningModePicker | 
					
						
							|  |  |  |                 type={inputs.reasoning_mode} | 
					
						
							|  |  |  |                 onChange={handleReasoningModeChange} | 
					
						
							|  |  |  |               /> | 
					
						
							|  |  |  |             </div> | 
					
						
							|  |  |  |           )} | 
					
						
							|  |  |  |         </> | 
					
						
							|  |  |  |       </FieldCollapse> | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |       {inputs.parameters?.length > 0 && (<> | 
					
						
							|  |  |  |         <Split /> | 
					
						
							| 
									
										
										
										
											2024-12-11 14:21:38 +08:00
										 |  |  |         <div> | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |           <OutputVars> | 
					
						
							|  |  |  |             <> | 
					
						
							| 
									
										
										
										
											2024-05-30 10:53:02 +08:00
										 |  |  |               {inputs.parameters.map((param, index) => ( | 
					
						
							|  |  |  |                 <VarItem | 
					
						
							|  |  |  |                   key={index} | 
					
						
							|  |  |  |                   name={param.name} | 
					
						
							|  |  |  |                   type={param.type} | 
					
						
							|  |  |  |                   description={param.description} | 
					
						
							|  |  |  |                 /> | 
					
						
							|  |  |  |               ))} | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |               <VarItem | 
					
						
							|  |  |  |                 name='__is_success' | 
					
						
							|  |  |  |                 type={VarType.number} | 
					
						
							|  |  |  |                 description={t(`${i18nPrefix}.isSuccess`)} | 
					
						
							|  |  |  |               /> | 
					
						
							|  |  |  |               <VarItem | 
					
						
							|  |  |  |                 name='__reason' | 
					
						
							|  |  |  |                 type={VarType.string} | 
					
						
							|  |  |  |                 description={t(`${i18nPrefix}.errorReason`)} | 
					
						
							|  |  |  |               /> | 
					
						
							|  |  |  |             </> | 
					
						
							|  |  |  |           </OutputVars> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       </>)} | 
					
						
							|  |  |  |       {isShowSingleRun && ( | 
					
						
							|  |  |  |         <BeforeRunForm | 
					
						
							|  |  |  |           nodeName={inputs.title} | 
					
						
							|  |  |  |           onHide={hideSingleRun} | 
					
						
							| 
									
										
										
										
											2025-03-03 13:29:59 +08:00
										 |  |  |           forms={singleRunForms} | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |           runningStatus={runningStatus} | 
					
						
							|  |  |  |           onRun={handleRun} | 
					
						
							|  |  |  |           onStop={handleStop} | 
					
						
							|  |  |  |           result={<ResultPanel {...runResult} showSteps={false} />} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |       )} | 
					
						
							|  |  |  |     </div> | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default React.memo(Panel) |