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' import { TransferMethod } from '../../base/text-generation/types' 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() 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 }) } const canRun = (() => { if (files?.some(item => (item.transfer_method as any) === TransferMethod.local_file && !item.upload_file_id)) return false return true })() return ( <>
{ variables.map((variable, index) => (
handleValueChange(variable.variable, v)} />
)) }
) } export default memo(InputsPanel)