mirror of
				https://github.com/langgenius/dify.git
				synced 2025-10-26 16:39:19 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			95 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			95 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import React, { useState } from 'react'
 | |
| import type { FC } from 'react'
 | |
| import { useTranslation } from 'react-i18next'
 | |
| import { RiBookOpenLine } from '@remixicon/react'
 | |
| import type { CreateExternalAPIReq, FormSchema } from '../declarations'
 | |
| import Input from '@/app/components/base/input'
 | |
| import cn from '@/utils/classnames'
 | |
| import { useDocLink } from '@/context/i18n'
 | |
| 
 | |
| type FormProps = {
 | |
|   className?: string
 | |
|   itemClassName?: string
 | |
|   fieldLabelClassName?: string
 | |
|   value: CreateExternalAPIReq
 | |
|   onChange: (val: CreateExternalAPIReq) => void
 | |
|   formSchemas: FormSchema[]
 | |
|   inputClassName?: string
 | |
| }
 | |
| 
 | |
| const Form: FC<FormProps> = React.memo(({
 | |
|   className,
 | |
|   itemClassName,
 | |
|   fieldLabelClassName,
 | |
|   value,
 | |
|   onChange,
 | |
|   formSchemas,
 | |
|   inputClassName,
 | |
| }) => {
 | |
|   const { t, i18n } = useTranslation()
 | |
|   const docLink = useDocLink()
 | |
|   const [changeKey, setChangeKey] = useState('')
 | |
| 
 | |
|   const handleFormChange = (key: string, val: string) => {
 | |
|     setChangeKey(key)
 | |
|     if (key === 'name') {
 | |
|       onChange({ ...value, [key]: val })
 | |
|     }
 | |
|     else {
 | |
|       onChange({
 | |
|         ...value,
 | |
|         settings: {
 | |
|           ...value.settings,
 | |
|           [key]: val,
 | |
|         },
 | |
|       })
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   const renderField = (formSchema: FormSchema) => {
 | |
|     const { variable, type, label, required } = formSchema
 | |
|     const fieldValue = variable === 'name' ? value[variable] : (value.settings[variable as keyof typeof value.settings] || '')
 | |
| 
 | |
|     return (
 | |
|       <div key={variable} className={cn(itemClassName, 'flex flex-col items-start gap-1 self-stretch')}>
 | |
|         <div className="flex w-full items-center justify-between">
 | |
|           <label className={cn(fieldLabelClassName, 'system-sm-semibold text-text-secondary')} htmlFor={variable}>
 | |
|             {label[i18n.language] || label.en_US}
 | |
|             {required && <span className='ml-1 text-red-500'>*</span>}
 | |
|           </label>
 | |
|           {variable === 'endpoint' && (
 | |
|             <a
 | |
|               href={docLink('/guides/knowledge-base/connect-external-knowledge-base') || '/'}
 | |
|               target='_blank'
 | |
|               rel='noopener noreferrer'
 | |
|               className='body-xs-regular flex items-center text-text-accent'
 | |
|             >
 | |
|               <RiBookOpenLine className='mr-1 h-3 w-3 text-text-accent' />
 | |
|               {t('dataset.externalAPIPanelDocumentation')}
 | |
|             </a>
 | |
|           )}
 | |
|         </div>
 | |
|         <Input
 | |
|           type={type === 'secret' ? 'password' : 'text'}
 | |
|           id={variable}
 | |
|           name={variable}
 | |
|           value={fieldValue}
 | |
|           onChange={val => handleFormChange(variable, val.target.value)}
 | |
|           required={required}
 | |
|           className={cn(inputClassName)}
 | |
|         />
 | |
|       </div>
 | |
|     )
 | |
|   }
 | |
| 
 | |
|   return (
 | |
|     <form className={cn('flex flex-col items-start justify-center gap-4 self-stretch', className)}>
 | |
|       {formSchemas.map(formSchema => renderField(formSchema))}
 | |
|     </form>
 | |
|   )
 | |
| })
 | |
| 
 | |
| Form.displayName = 'Form'
 | |
| 
 | |
| export default Form
 | 
