mirror of
				https://github.com/langgenius/dify.git
				synced 2025-10-25 16:08:45 +00:00 
			
		
		
		
	 7753ba2d37
			
		
	
	
		7753ba2d37
		
			
		
	
	
	
	
		
			
			Co-authored-by: Joel <iamjoel007@gmail.com> Co-authored-by: Yeuoly <admin@srmxy.cn> Co-authored-by: JzoNg <jzongcode@gmail.com> Co-authored-by: StyleZhang <jasonapring2015@outlook.com> Co-authored-by: jyong <jyong@dify.ai> Co-authored-by: nite-knite <nkCoding@gmail.com> Co-authored-by: jyong <718720800@qq.com>
		
			
				
	
	
		
			81 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			81 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import type { FC } from 'react'
 | |
| import { memo } from 'react'
 | |
| import { useContext } from 'use-context-selector'
 | |
| import type { CodeBasedExtensionForm } from '@/models/common'
 | |
| import I18n from '@/context/i18n'
 | |
| import { PortalSelect } from '@/app/components/base/select'
 | |
| import type { ModerationConfig } from '@/models/debug'
 | |
| 
 | |
| type FormGenerationProps = {
 | |
|   forms: CodeBasedExtensionForm[]
 | |
|   value: ModerationConfig['config']
 | |
|   onChange: (v: Record<string, string>) => void
 | |
| }
 | |
| const FormGeneration: FC<FormGenerationProps> = ({
 | |
|   forms,
 | |
|   value,
 | |
|   onChange,
 | |
| }) => {
 | |
|   const { locale } = useContext(I18n)
 | |
| 
 | |
|   const handleFormChange = (type: string, v: string) => {
 | |
|     onChange({ ...value, [type]: v })
 | |
|   }
 | |
| 
 | |
|   return (
 | |
|     <>
 | |
|       {
 | |
|         forms.map((form, index) => (
 | |
|           <div
 | |
|             key={index}
 | |
|             className='py-2'
 | |
|           >
 | |
|             <div className='flex items-center h-9 text-sm font-medium text-gray-900'>
 | |
|               {locale === 'zh-Hans' ? form.label['zh-Hans'] : form.label['en-US']}
 | |
|             </div>
 | |
|             {
 | |
|               form.type === 'text-input' && (
 | |
|                 <input
 | |
|                   value={value?.[form.variable] || ''}
 | |
|                   className='block px-3 w-full h-9 bg-gray-100 rounded-lg text-sm text-gray-900 outline-none appearance-none'
 | |
|                   placeholder={form.placeholder}
 | |
|                   onChange={e => handleFormChange(form.variable, e.target.value)}
 | |
|                 />
 | |
|               )
 | |
|             }
 | |
|             {
 | |
|               form.type === 'paragraph' && (
 | |
|                 <div className='relative px-3 py-2 h-[88px] bg-gray-100 rounded-lg'>
 | |
|                   <textarea
 | |
|                     value={value?.[form.variable] || ''}
 | |
|                     className='block w-full h-full bg-transparent text-sm outline-none appearance-none resize-none'
 | |
|                     placeholder={form.placeholder}
 | |
|                     onChange={e => handleFormChange(form.variable, e.target.value)}
 | |
|                   />
 | |
|                 </div>
 | |
|               )
 | |
|             }
 | |
|             {
 | |
|               form.type === 'select' && (
 | |
|                 <PortalSelect
 | |
|                   value={value?.[form.variable]}
 | |
|                   items={form.options.map((option) => {
 | |
|                     return {
 | |
|                       name: option.label[locale === 'zh-Hans' ? 'zh-Hans' : 'en-US'],
 | |
|                       value: option.value,
 | |
|                     }
 | |
|                   })}
 | |
|                   onSelect={item => handleFormChange(form.variable, item.value as string)}
 | |
|                   popupClassName='w-[576px] !z-[102]'
 | |
|                 />
 | |
|               )
 | |
|             }
 | |
|           </div>
 | |
|         ))
 | |
|       }
 | |
|     </>
 | |
|   )
 | |
| }
 | |
| 
 | |
| export default memo(FormGeneration)
 |