mirror of
https://github.com/infiniflow/ragflow.git
synced 2025-12-08 20:42:30 +08:00
### What problem does this PR solve? Feat: Upload document #3221 ### Type of change - [x] New Feature (non-breaking change which adds functionality)
This commit is contained in:
@ -8,15 +8,16 @@ import {
|
||||
} from '@/components/ui/dialog';
|
||||
import { Tabs, TabsContent, TabsList, TabsTrigger } from '@/components/ui/tabs';
|
||||
import { IModalProps } from '@/interfaces/common';
|
||||
import { useState } from 'react';
|
||||
import { Dispatch, SetStateAction, useCallback, useState } from 'react';
|
||||
import { useTranslation } from 'react-i18next';
|
||||
import { FileUploader } from '../file-uploader';
|
||||
|
||||
export function UploaderTabs() {
|
||||
const { t } = useTranslation();
|
||||
type UploaderTabsProps = {
|
||||
setFiles: Dispatch<SetStateAction<File[]>>;
|
||||
};
|
||||
|
||||
const [files, setFiles] = useState<File[]>([]);
|
||||
console.log('🚀 ~ TabsDemo ~ files:', files);
|
||||
export function UploaderTabs({ setFiles }: UploaderTabsProps) {
|
||||
const { t } = useTranslation();
|
||||
|
||||
return (
|
||||
<Tabs defaultValue="account">
|
||||
@ -36,8 +37,13 @@ export function UploaderTabs() {
|
||||
);
|
||||
}
|
||||
|
||||
export function FileUploadDialog({ hideModal }: IModalProps<any>) {
|
||||
export function FileUploadDialog({ hideModal, onOk }: IModalProps<File[]>) {
|
||||
const { t } = useTranslation();
|
||||
const [files, setFiles] = useState<File[]>([]);
|
||||
|
||||
const handleOk = useCallback(() => {
|
||||
onOk?.(files);
|
||||
}, [files, onOk]);
|
||||
|
||||
return (
|
||||
<Dialog open onOpenChange={hideModal}>
|
||||
@ -45,9 +51,14 @@ export function FileUploadDialog({ hideModal }: IModalProps<any>) {
|
||||
<DialogHeader>
|
||||
<DialogTitle>{t('fileManager.uploadFile')}</DialogTitle>
|
||||
</DialogHeader>
|
||||
<UploaderTabs></UploaderTabs>
|
||||
<UploaderTabs setFiles={setFiles}></UploaderTabs>
|
||||
<DialogFooter>
|
||||
<Button type="submit" variant={'tertiary'} size={'sm'}>
|
||||
<Button
|
||||
type="submit"
|
||||
variant={'tertiary'}
|
||||
size={'sm'}
|
||||
onClick={handleOk}
|
||||
>
|
||||
{t('common.save')}
|
||||
</Button>
|
||||
</DialogFooter>
|
||||
|
||||
Reference in New Issue
Block a user