|
|
|
|
@ -18,6 +18,7 @@ import { FileUploaderInAttachmentWrapper } from '@/app/components/base/file-uplo
|
|
|
|
|
import { getProcessedFiles } from '@/app/components/base/file-uploader/utils'
|
|
|
|
|
import useBreakpoints, { MediaType } from '@/hooks/use-breakpoints'
|
|
|
|
|
import cn from '@/utils/classnames'
|
|
|
|
|
import BoolInput from '@/app/components/workflow/nodes/_base/components/before-run-form/bool-input'
|
|
|
|
|
|
|
|
|
|
export type IRunOnceProps = {
|
|
|
|
|
siteInfo: SiteInfo
|
|
|
|
|
@ -82,7 +83,9 @@ const RunOnce: FC<IRunOnceProps> = ({
|
|
|
|
|
{(inputs === null || inputs === undefined || Object.keys(inputs).length === 0) ? null
|
|
|
|
|
: promptConfig.prompt_variables.map(item => (
|
|
|
|
|
<div className='mt-4 w-full' key={item.key}>
|
|
|
|
|
<label className='system-md-semibold flex h-6 items-center text-text-secondary'>{item.name}</label>
|
|
|
|
|
{item.type !== 'boolean' && (
|
|
|
|
|
<label className='system-md-semibold flex h-6 items-center text-text-secondary'>{item.name}</label>
|
|
|
|
|
)}
|
|
|
|
|
<div className='mt-1'>
|
|
|
|
|
{item.type === 'select' && (
|
|
|
|
|
<Select
|
|
|
|
|
@ -107,7 +110,7 @@ const RunOnce: FC<IRunOnceProps> = ({
|
|
|
|
|
className='h-[104px] sm:text-xs'
|
|
|
|
|
placeholder={`${item.name}${!item.required ? `(${t('appDebug.variableTable.optional')})` : ''}`}
|
|
|
|
|
value={inputs[item.key]}
|
|
|
|
|
onChange={(e: ChangeEvent<HTMLInputElement>) => { handleInputsChange({ ...inputsRef.current, [item.key]: e.target.value }) }}
|
|
|
|
|
onChange={(e: ChangeEvent<HTMLTextAreaElement>) => { handleInputsChange({ ...inputsRef.current, [item.key]: e.target.value }) }}
|
|
|
|
|
/>
|
|
|
|
|
)}
|
|
|
|
|
{item.type === 'number' && (
|
|
|
|
|
@ -118,6 +121,14 @@ const RunOnce: FC<IRunOnceProps> = ({
|
|
|
|
|
onChange={(e: ChangeEvent<HTMLInputElement>) => { handleInputsChange({ ...inputsRef.current, [item.key]: e.target.value }) }}
|
|
|
|
|
/>
|
|
|
|
|
)}
|
|
|
|
|
{item.type === 'boolean' && (
|
|
|
|
|
<BoolInput
|
|
|
|
|
name={item.name || item.key}
|
|
|
|
|
value={!!inputs[item.key]}
|
|
|
|
|
required={item.required}
|
|
|
|
|
onChange={(value) => { handleInputsChange({ ...inputsRef.current, [item.key]: value }) }}
|
|
|
|
|
/>
|
|
|
|
|
)}
|
|
|
|
|
{item.type === 'file' && (
|
|
|
|
|
<FileUploaderInAttachmentWrapper
|
|
|
|
|
onChange={(files) => { handleInputsChange({ ...inputsRef.current, [item.key]: getProcessedFiles(files)[0] }) }}
|
|
|
|
|
|