import { useSelectFileList } from '@/hooks/fileManagerHooks'; import { IFile } from '@/interfaces/database/file-manager'; import { formatDate } from '@/utils/date'; import { Button, Table } from 'antd'; import { ColumnsType } from 'antd/es/table'; import ActionCell from './action-cell'; import FileToolbar from './file-toolbar'; import { useGetRowSelection, useHandleConnectToKnowledge, useHandleCreateFolder, useHandleUploadFile, useNavigateToOtherFolder, useRenameCurrentFile, useSelectFileListLoading, } from './hooks'; import RenameModal from '@/components/rename-modal'; import ConnectToKnowledgeModal from './connect-to-knowledge-modal'; import FileUploadModal from './file-upload-modal'; import FolderCreateModal from './folder-create-modal'; import styles from './index.less'; const FileManager = () => { const fileList = useSelectFileList(); const rowSelection = useGetRowSelection(); const loading = useSelectFileListLoading(); const navigateToOtherFolder = useNavigateToOtherFolder(); const { fileRenameVisible, fileRenameLoading, hideFileRenameModal, showFileRenameModal, initialFileName, onFileRenameOk, } = useRenameCurrentFile(); const { folderCreateModalVisible, showFolderCreateModal, hideFolderCreateModal, folderCreateLoading, onFolderCreateOk, } = useHandleCreateFolder(); const { fileUploadVisible, hideFileUploadModal, showFileUploadModal } = useHandleUploadFile(); const { connectToKnowledgeVisible, hideConnectToKnowledgeModal, showConnectToKnowledgeModal, onConnectToKnowledgeOk, } = useHandleConnectToKnowledge(); const columns: ColumnsType = [ { title: 'Name', dataIndex: 'name', key: 'name', render(value, record) { return record.type === 'folder' ? ( ) : ( value ); }, }, { title: 'Upload Date', dataIndex: 'create_date', key: 'create_date', render(text) { return formatDate(text); }, }, { title: 'kbs_info', dataIndex: 'kbs_info', key: 'kbs_info', render(value) { console.info(value); return Array.isArray(value) ? value?.map((x) => x.kb_name).join(',') : ''; }, }, { title: 'Location', dataIndex: 'location', key: 'location', }, { title: 'Action', dataIndex: 'action', key: 'action', render: (text, record) => ( { console.info(record); }} showRenameModal={showFileRenameModal} showConnectToKnowledgeModal={showConnectToKnowledgeModal} > ), }, ]; return (
); }; export default FileManager;