* feat: add file manager module - Complete file manager implementation with UI/UX - Add drive management functionality - Add file upload/download with progress tracking - Add stamp integration and handling - Add bulk operations and context menus Co-authored-by: Roland Seres <roland.seres90@gmail.com> Co-authored-by: nidishk <nidishkrishnan45@gmail.com>
This commit is contained in:
+121
@@ -0,0 +1,121 @@
|
||||
import { ContextMenu } from '../../ContextMenu/ContextMenu'
|
||||
import { ReactElement } from 'react'
|
||||
import '../FileBrowser.scss'
|
||||
import { ViewType } from '../../../constants/transfers'
|
||||
import { DriveInfo } from '@solarpunkltd/file-manager-lib'
|
||||
import { Tooltip } from '../../Tooltip/Tooltip'
|
||||
|
||||
interface FileBrowserContextMenuProps {
|
||||
drives: DriveInfo[]
|
||||
view: ViewType
|
||||
selectedFilesCount: number
|
||||
onRefresh: () => void
|
||||
onUploadFile: () => void
|
||||
onBulkDownload: () => void
|
||||
onBulkRestore: () => void
|
||||
onBulkDelete: () => void
|
||||
onBulkDestroy: () => void
|
||||
onBulkForget: () => void
|
||||
enableRefresh?: boolean
|
||||
}
|
||||
|
||||
export function FileBrowserContextMenu({
|
||||
drives,
|
||||
view,
|
||||
selectedFilesCount,
|
||||
onRefresh,
|
||||
onUploadFile,
|
||||
onBulkDownload,
|
||||
onBulkRestore,
|
||||
onBulkDelete,
|
||||
onBulkDestroy,
|
||||
onBulkForget,
|
||||
enableRefresh,
|
||||
}: FileBrowserContextMenuProps): ReactElement {
|
||||
if (drives.length === 0) {
|
||||
if (!enableRefresh) {
|
||||
return <></>
|
||||
}
|
||||
|
||||
return (
|
||||
<ContextMenu>
|
||||
<div className="fm-context-item" onClick={onRefresh}>
|
||||
Refresh
|
||||
</div>
|
||||
</ContextMenu>
|
||||
)
|
||||
}
|
||||
|
||||
if (selectedFilesCount > 1) {
|
||||
return (
|
||||
<ContextMenu>
|
||||
<div className="fm-context-item" onClick={onBulkDownload}>
|
||||
Download
|
||||
</div>
|
||||
{view === ViewType.File ? (
|
||||
<div className="fm-context-item red" onClick={onBulkDelete}>
|
||||
Delete…
|
||||
</div>
|
||||
) : (
|
||||
<>
|
||||
<div className="fm-context-item" onClick={onBulkRestore}>
|
||||
Restore
|
||||
</div>
|
||||
<div className="fm-context-item red" onClick={onBulkDestroy}>
|
||||
Destroy
|
||||
</div>
|
||||
<div className="fm-context-item red" onClick={onBulkForget}>
|
||||
Forget permanently
|
||||
</div>
|
||||
</>
|
||||
)}
|
||||
</ContextMenu>
|
||||
)
|
||||
}
|
||||
|
||||
if (view === ViewType.Trash) {
|
||||
return (
|
||||
<ContextMenu>
|
||||
<div className="fm-context-item" onClick={onRefresh}>
|
||||
Refresh
|
||||
</div>
|
||||
</ContextMenu>
|
||||
)
|
||||
}
|
||||
|
||||
return (
|
||||
<ContextMenu>
|
||||
<div className="fm-context-item" style={{ display: 'none' }}>
|
||||
New folder
|
||||
</div>
|
||||
<div className="fm-context-item" onClick={onUploadFile}>
|
||||
Upload file(s)
|
||||
</div>
|
||||
<div className="fm-context-item" style={{ display: 'none' }}>
|
||||
Upload folder
|
||||
</div>
|
||||
<div className="fm-context-item-border" />
|
||||
<div
|
||||
className="fm-context-item"
|
||||
role="menuitem"
|
||||
aria-disabled="true"
|
||||
tabIndex={-1}
|
||||
onMouseDown={e => e.stopPropagation()}
|
||||
onClick={e => {
|
||||
e.preventDefault()
|
||||
e.stopPropagation()
|
||||
}}
|
||||
>
|
||||
<span>
|
||||
<Tooltip label="Tip: Use ⌘V / Ctrl+V or Browser → Edit → Paste." iconSize="14px" gapPx={6} disableMargin>
|
||||
Paste
|
||||
</Tooltip>
|
||||
</span>
|
||||
</div>
|
||||
<div className="fm-context-item-border" />
|
||||
<div className="fm-context-item" onClick={onRefresh}>
|
||||
Refresh
|
||||
</div>
|
||||
</ContextMenu>
|
||||
)
|
||||
}
|
||||
Reference in New Issue
Block a user