mirror of
https://git.mirrors.martin98.com/https://github.com/langgenius/dify.git
synced 2025-05-18 02:16:54 +08:00

Co-authored-by: Joel <iamjoel007@gmail.com> Co-authored-by: Patryk Garstecki <patryk20120@yahoo.pl> Co-authored-by: Sebastian.W <thiner@gmail.com> Co-authored-by: 呆萌闷油瓶 <253605712@qq.com> Co-authored-by: takatost <takatost@users.noreply.github.com> Co-authored-by: rechardwang <wh_goodjob@163.com> Co-authored-by: Nite Knite <nkCoding@gmail.com> Co-authored-by: Chenhe Gu <guchenhe@gmail.com> Co-authored-by: Joshua <138381132+joshua20231026@users.noreply.github.com> Co-authored-by: Weaxs <459312872@qq.com> Co-authored-by: Ikko Eltociear Ashimine <eltociear@gmail.com> Co-authored-by: leejoo0 <81673835+leejoo0@users.noreply.github.com> Co-authored-by: JzoNg <jzongcode@gmail.com> Co-authored-by: sino <sino2322@gmail.com> Co-authored-by: Vikey Chen <vikeytk@gmail.com> Co-authored-by: wanghl <Wang-HL@users.noreply.github.com> Co-authored-by: Haolin Wang-汪皓临 <haolin.wang@atlaslovestravel.com> Co-authored-by: Zixuan Cheng <61724187+Theysua@users.noreply.github.com> Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> Co-authored-by: Bowen Liang <bowenliang@apache.org> Co-authored-by: Bowen Liang <liangbowen@gf.com.cn> Co-authored-by: fanghongtai <42790567+fanghongtai@users.noreply.github.com> Co-authored-by: wxfanghongtai <wxfanghongtai@gf.com.cn> Co-authored-by: Matri <qjp@bithuman.io> Co-authored-by: Benjamin <benjaminx@gmail.com>
119 lines
3.0 KiB
TypeScript
119 lines
3.0 KiB
TypeScript
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<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: false,
|
|
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 (
|
|
<>
|
|
<div className='px-4 pb-2'>
|
|
{
|
|
variables.map((variable, index) => (
|
|
<div
|
|
key={variable.variable}
|
|
className='mb-2 last-of-type:mb-0'
|
|
>
|
|
<FormItem
|
|
autoFocus={index === 0}
|
|
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'
|
|
disabled={!canRun || workflowRunningData?.result?.status === WorkflowRunningStatus.Running}
|
|
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)
|