| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { | 
					
						
							|  |  |  |   memo, | 
					
						
							|  |  |  |   useMemo, | 
					
						
							|  |  |  | } from 'react' | 
					
						
							|  |  |  | import { useTranslation } from 'react-i18next' | 
					
						
							|  |  |  | import { useNodes } from 'reactflow' | 
					
						
							|  |  |  | import FormItem from '../nodes/_base/components/before-run-form/form-item' | 
					
						
							|  |  |  | import { | 
					
						
							|  |  |  |   BlockEnum, | 
					
						
							|  |  |  |   InputVarType, | 
					
						
							|  |  |  |   WorkflowRunningStatus, | 
					
						
							|  |  |  | } from '../types' | 
					
						
							|  |  |  | import { | 
					
						
							|  |  |  |   useStore, | 
					
						
							|  |  |  |   useWorkflowStore, | 
					
						
							|  |  |  | } from '../store' | 
					
						
							|  |  |  | import { useWorkflowRun } from '../hooks' | 
					
						
							|  |  |  | import type { StartNodeType } from '../nodes/start/types' | 
					
						
							| 
									
										
										
										
											2024-04-09 15:54:36 +08:00
										 |  |  | import { TransferMethod } from '../../base/text-generation/types' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import Button from '@/app/components/base/button' | 
					
						
							|  |  |  | import { useFeatures } from '@/app/components/base/features/hooks' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type Props = { | 
					
						
							|  |  |  |   onRun: () => void | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const InputsPanel = ({ onRun }: Props) => { | 
					
						
							|  |  |  |   const { t } = useTranslation() | 
					
						
							|  |  |  |   const workflowStore = useWorkflowStore() | 
					
						
							|  |  |  |   const fileSettings = useFeatures(s => s.features.file) | 
					
						
							|  |  |  |   const nodes = useNodes<StartNodeType>() | 
					
						
							|  |  |  |   const inputs = useStore(s => s.inputs) | 
					
						
							|  |  |  |   const files = useStore(s => s.files) | 
					
						
							|  |  |  |   const workflowRunningData = useStore(s => s.workflowRunningData) | 
					
						
							|  |  |  |   const { | 
					
						
							|  |  |  |     handleRun, | 
					
						
							|  |  |  |   } = useWorkflowRun() | 
					
						
							|  |  |  |   const startNode = nodes.find(node => node.data.type === BlockEnum.Start) | 
					
						
							|  |  |  |   const startVariables = startNode?.data.variables | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const variables = useMemo(() => { | 
					
						
							|  |  |  |     const data = startVariables || [] | 
					
						
							|  |  |  |     if (fileSettings?.image?.enabled) { | 
					
						
							|  |  |  |       return [ | 
					
						
							|  |  |  |         ...data, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |           type: InputVarType.files, | 
					
						
							|  |  |  |           variable: '__image', | 
					
						
							|  |  |  |           required: true, | 
					
						
							|  |  |  |           label: 'files', | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |       ] | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return data | 
					
						
							|  |  |  |   }, [fileSettings?.image?.enabled, startVariables]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const handleValueChange = (variable: string, v: any) => { | 
					
						
							|  |  |  |     if (variable === '__image') { | 
					
						
							|  |  |  |       workflowStore.setState({ | 
					
						
							|  |  |  |         files: v, | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |       workflowStore.getState().setInputs({ | 
					
						
							|  |  |  |         ...inputs, | 
					
						
							|  |  |  |         [variable]: v, | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const doRun = () => { | 
					
						
							|  |  |  |     onRun() | 
					
						
							|  |  |  |     handleRun({ inputs, files }) | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-09 15:54:36 +08:00
										 |  |  |   const canRun = (() => { | 
					
						
							|  |  |  |     if (files?.some(item => (item.transfer_method as any) === TransferMethod.local_file && !item.upload_file_id)) | 
					
						
							|  |  |  |       return false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return true | 
					
						
							|  |  |  |   })() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   return ( | 
					
						
							|  |  |  |     <> | 
					
						
							|  |  |  |       <div className='px-4 pb-2'> | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |           variables.map((variable, index) => ( | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |             <div | 
					
						
							|  |  |  |               key={variable.variable} | 
					
						
							|  |  |  |               className='mb-2 last-of-type:mb-0' | 
					
						
							|  |  |  |             > | 
					
						
							|  |  |  |               <FormItem | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |                 autoFocus={index === 0} | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |                 className='!block' | 
					
						
							|  |  |  |                 payload={variable} | 
					
						
							|  |  |  |                 value={inputs[variable.variable]} | 
					
						
							|  |  |  |                 onChange={v => handleValueChange(variable.variable, v)} | 
					
						
							|  |  |  |               /> | 
					
						
							|  |  |  |             </div> | 
					
						
							|  |  |  |           )) | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |       <div className='flex items-center justify-between px-4 py-2'> | 
					
						
							|  |  |  |         <Button | 
					
						
							|  |  |  |           type='primary' | 
					
						
							| 
									
										
										
										
											2024-04-09 15:54:36 +08:00
										 |  |  |           disabled={!canRun || workflowRunningData?.result?.status === WorkflowRunningStatus.Running} | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |           className='py-0 w-full h-8 rounded-lg text-[13px] font-medium' | 
					
						
							|  |  |  |           onClick={doRun} | 
					
						
							|  |  |  |         > | 
					
						
							|  |  |  |           {t('workflow.singleRun.startRun')} | 
					
						
							|  |  |  |         </Button> | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |     </> | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default memo(InputsPanel) |