123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126 |
- import { useCallback } from 'react'
- import { useTranslation } from 'react-i18next'
- import Input from '@/app/components/base/input'
- import Textarea from '@/app/components/base/textarea'
- import { PortalSelect } from '@/app/components/base/select'
- import { InputVarType } from '@/app/components/workflow/types'
- import { FileUploaderInAttachmentWrapper } from '@/app/components/base/file-uploader'
- type Props = {
- inputsForms: any[]
- inputs: Record<string, any>
- inputsRef: any
- onFormChange: (value: Record<string, any>) => void
- }
- const AppInputsForm = ({
- inputsForms,
- inputs,
- inputsRef,
- onFormChange,
- }: Props) => {
- const { t } = useTranslation()
- const handleFormChange = useCallback((variable: string, value: any) => {
- onFormChange({
- ...inputsRef.current,
- [variable]: value,
- })
- }, [onFormChange, inputsRef])
- const renderField = (form: any) => {
- const {
- label,
- variable,
- options,
- } = form
- if (form.type === InputVarType.textInput) {
- return (
- <Input
- value={inputs[variable] || ''}
- onChange={e => handleFormChange(variable, e.target.value)}
- placeholder={label}
- />
- )
- }
- if (form.type === InputVarType.number) {
- return (
- <Input
- type="number"
- value={inputs[variable] || ''}
- onChange={e => handleFormChange(variable, e.target.value)}
- placeholder={label}
- />
- )
- }
- if (form.type === InputVarType.paragraph) {
- return (
- <Textarea
- value={inputs[variable] || ''}
- onChange={e => handleFormChange(variable, e.target.value)}
- placeholder={label}
- />
- )
- }
- if (form.type === InputVarType.select) {
- return (
- <PortalSelect
- popupClassName="w-[356px] z-[1050]"
- value={inputs[variable] || ''}
- items={options.map((option: string) => ({ value: option, name: option }))}
- onSelect={item => handleFormChange(variable, item.value as string)}
- placeholder={label}
- />
- )
- }
- if (form.type === InputVarType.singleFile) {
- return (
- <FileUploaderInAttachmentWrapper
- value={inputs[variable] ? [inputs[variable]] : []}
- onChange={files => handleFormChange(variable, files[0])}
- fileConfig={{
- allowed_file_types: form.allowed_file_types,
- allowed_file_extensions: form.allowed_file_extensions,
- allowed_file_upload_methods: form.allowed_file_upload_methods,
- number_limits: 1,
- fileUploadConfig: (form as any).fileUploadConfig,
- }}
- />
- )
- }
- if (form.type === InputVarType.multiFiles) {
- return (
- <FileUploaderInAttachmentWrapper
- value={inputs[variable]}
- onChange={files => handleFormChange(variable, files)}
- fileConfig={{
- allowed_file_types: form.allowed_file_types,
- allowed_file_extensions: form.allowed_file_extensions,
- allowed_file_upload_methods: form.allowed_file_upload_methods,
- number_limits: form.max_length,
- fileUploadConfig: (form as any).fileUploadConfig,
- }}
- />
- )
- }
- }
- if (!inputsForms.length)
- return null
- return (
- <div className='px-4 py-2 flex flex-col gap-4'>
- {inputsForms.map(form => (
- <div key={form.variable}>
- <div className='h-6 mb-1 flex items-center gap-1 text-text-secondary system-sm-semibold'>
- <div className='truncate'>{form.label}</div>
- {!form.required && <span className='text-text-tertiary system-xs-regular'>{t('workflow.panel.optional')}</span>}
- </div>
- {renderField(form)}
- </div>
- ))}
- </div>
- )
- }
- export default AppInputsForm
|