mirror of
				https://github.com/langgenius/dify.git
				synced 2025-10-26 16:39:19 +00:00 
			
		
		
		
	 7709d9df20
			
		
	
	
		7709d9df20
		
			
		
	
	
	
	
		
			
			Co-authored-by: NFish <douxc512@gmail.com> Co-authored-by: zxhlyh <jasonapring2015@outlook.com> Co-authored-by: twwu <twwu@dify.ai> Co-authored-by: jZonG <jzongcode@gmail.com>
		
			
				
	
	
		
			42 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			42 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {
 | |
|   memo,
 | |
|   useCallback,
 | |
| } from 'react'
 | |
| import {
 | |
|   RiAttachmentLine,
 | |
| } from '@remixicon/react'
 | |
| import FileFromLinkOrLocal from '../file-from-link-or-local'
 | |
| import ActionButton from '@/app/components/base/action-button'
 | |
| import cn from '@/utils/classnames'
 | |
| import type { FileUpload } from '@/app/components/base/features/types'
 | |
| import { TransferMethod } from '@/types/app'
 | |
| 
 | |
| type FileUploaderInChatInputProps = {
 | |
|   fileConfig: FileUpload
 | |
| }
 | |
| const FileUploaderInChatInput = ({
 | |
|   fileConfig,
 | |
| }: FileUploaderInChatInputProps) => {
 | |
|   const renderTrigger = useCallback((open: boolean) => {
 | |
|     return (
 | |
|       <ActionButton
 | |
|         size='l'
 | |
|         className={cn(open && 'bg-state-base-hover')}
 | |
|       >
 | |
|         <RiAttachmentLine className='h-5 w-5' />
 | |
|       </ActionButton>
 | |
|     )
 | |
|   }, [])
 | |
| 
 | |
|   return (
 | |
|     <FileFromLinkOrLocal
 | |
|       trigger={renderTrigger}
 | |
|       fileConfig={fileConfig}
 | |
|       showFromLocal={fileConfig?.allowed_file_upload_methods?.includes(TransferMethod.local_file)}
 | |
|       showFromLink={fileConfig?.allowed_file_upload_methods?.includes(TransferMethod.remote_url)}
 | |
|     />
 | |
|   )
 | |
| }
 | |
| 
 | |
| export default memo(FileUploaderInChatInput)
 |