mirror of
https://github.com/colanode/colanode.git
synced 2025-12-23 06:59:25 +01:00
Implement file dialog and context menu
This commit is contained in:
56
desktop/src/renderer/components/files/file-context-menu.tsx
Normal file
56
desktop/src/renderer/components/files/file-context-menu.tsx
Normal file
@@ -0,0 +1,56 @@
|
||||
import React from 'react';
|
||||
import { FileDeleteDialog } from '@/renderer/components/files/file-delete-dialog';
|
||||
import {
|
||||
ContextMenu,
|
||||
ContextMenuContent,
|
||||
ContextMenuItem,
|
||||
ContextMenuShortcut,
|
||||
ContextMenuTrigger,
|
||||
} from '@/renderer/components/ui/context-menu';
|
||||
import { Icon } from '@/renderer/components/ui/icon';
|
||||
import { useWorkspace } from '@/renderer/contexts/workspace';
|
||||
|
||||
interface FileContextMenuProps {
|
||||
id: string;
|
||||
children: React.ReactNode;
|
||||
}
|
||||
|
||||
export const FileContextMenu = ({ id, children }: FileContextMenuProps) => {
|
||||
const workspace = useWorkspace();
|
||||
const [openDelete, setOpenDelete] = React.useState(false);
|
||||
|
||||
return (
|
||||
<React.Fragment>
|
||||
<ContextMenu>
|
||||
<ContextMenuTrigger asChild>{children}</ContextMenuTrigger>
|
||||
<ContextMenuContent className="w-64">
|
||||
<ContextMenuItem
|
||||
onSelect={() => {
|
||||
workspace.openModal(id);
|
||||
}}
|
||||
className="pl-2"
|
||||
>
|
||||
<ContextMenuShortcut className="ml-0">
|
||||
<Icon name="folder-line" className="mr-2 h-4 w-4" />
|
||||
</ContextMenuShortcut>
|
||||
Open
|
||||
</ContextMenuItem>
|
||||
<ContextMenuItem
|
||||
onClick={() => setOpenDelete(true)}
|
||||
className="flex items-center gap-x-2 pl-2 text-red-500"
|
||||
>
|
||||
<ContextMenuShortcut className="ml-0">
|
||||
<Icon name="delete-bin-line" className="h-4 w-4 text-red-500" />
|
||||
</ContextMenuShortcut>
|
||||
<span className="text-red-500">Delete</span>
|
||||
</ContextMenuItem>
|
||||
</ContextMenuContent>
|
||||
</ContextMenu>
|
||||
<FileDeleteDialog
|
||||
id={id}
|
||||
open={openDelete}
|
||||
onOpenChange={setOpenDelete}
|
||||
/>
|
||||
</React.Fragment>
|
||||
);
|
||||
};
|
||||
Reference in New Issue
Block a user