Folders, Persistent Import Progress Tracking & UX Enhancements (#3841)
Co-authored-by: Jonathan Dobson <jon.m.dobson@gmail.com>
This commit is contained in:
@@ -0,0 +1,118 @@
|
||||
import { GarbageIcon } from "@/components/icons/GarbageIcon";
|
||||
import { Button } from "@/components/ui/button";
|
||||
import {
|
||||
Dialog,
|
||||
DialogClose,
|
||||
DialogContent,
|
||||
DialogDescription,
|
||||
DialogFooter,
|
||||
DialogHeader,
|
||||
DialogTitle,
|
||||
DialogTrigger,
|
||||
} from "@/components/ui/dialog";
|
||||
import {
|
||||
Tooltip,
|
||||
TooltipContent,
|
||||
TooltipProvider,
|
||||
TooltipTrigger,
|
||||
} from "@/components/ui/tooltip";
|
||||
import { Label } from "@/components/ui/label";
|
||||
import { RadioGroup, RadioGroupItem } from "@/components/ui/radio-group";
|
||||
import { ReloadIcon } from "@radix-ui/react-icons";
|
||||
import { useEffect, useState } from "react";
|
||||
import { useDeleteFolderMutation } from "../hooks/useFolderMutations";
|
||||
|
||||
type Props = {
|
||||
folderId: string;
|
||||
folderTitle: string;
|
||||
};
|
||||
|
||||
function DeleteFolderButton({ folderId, folderTitle }: Props) {
|
||||
const [deleteOption, setDeleteOption] = useState<
|
||||
"folder_only" | "folder_and_workflows"
|
||||
>("folder_only");
|
||||
const [isDialogOpen, setIsDialogOpen] = useState(false);
|
||||
const {
|
||||
mutate: deleteFolder,
|
||||
isPending: isDeleteFolderPending,
|
||||
isSuccess: isDeleteFolderSuccess,
|
||||
} = useDeleteFolderMutation();
|
||||
|
||||
// Close dialog when deletion succeeds
|
||||
useEffect(() => {
|
||||
if (isDeleteFolderSuccess) setIsDialogOpen(false);
|
||||
}, [isDeleteFolderSuccess]);
|
||||
|
||||
const handleDelete = () => {
|
||||
const deleteWorkflows = deleteOption === "folder_and_workflows";
|
||||
deleteFolder({ folderId, folderTitle, deleteWorkflows });
|
||||
};
|
||||
|
||||
return (
|
||||
<Dialog open={isDialogOpen} onOpenChange={setIsDialogOpen}>
|
||||
<TooltipProvider>
|
||||
<Tooltip>
|
||||
<TooltipTrigger asChild>
|
||||
<DialogTrigger asChild>
|
||||
<button
|
||||
onClick={(e) => e.stopPropagation()}
|
||||
className="rounded p-1.5 text-red-400 transition-colors hover:bg-red-500/20 hover:text-red-300"
|
||||
aria-label="Delete folder"
|
||||
>
|
||||
<GarbageIcon className="h-4 w-4" />
|
||||
</button>
|
||||
</DialogTrigger>
|
||||
</TooltipTrigger>
|
||||
<TooltipContent>Delete Folder</TooltipContent>
|
||||
</Tooltip>
|
||||
</TooltipProvider>
|
||||
<DialogContent onCloseAutoFocus={(e) => e.preventDefault()}>
|
||||
<DialogHeader>
|
||||
<DialogTitle>Delete Folder: {folderTitle}</DialogTitle>
|
||||
<DialogDescription>
|
||||
Choose how you want to delete this folder.
|
||||
</DialogDescription>
|
||||
</DialogHeader>
|
||||
<RadioGroup
|
||||
value={deleteOption}
|
||||
onValueChange={(value) =>
|
||||
setDeleteOption(value as typeof deleteOption)
|
||||
}
|
||||
>
|
||||
<div className="flex items-center space-x-2">
|
||||
<RadioGroupItem value="folder_only" id="folder_only" />
|
||||
<Label htmlFor="folder_only" className="font-normal">
|
||||
Delete folder only (workflows will be unassigned)
|
||||
</Label>
|
||||
</div>
|
||||
<div className="flex items-center space-x-2">
|
||||
<RadioGroupItem
|
||||
value="folder_and_workflows"
|
||||
id="folder_and_workflows"
|
||||
/>
|
||||
<Label htmlFor="folder_and_workflows" className="font-normal">
|
||||
Delete folder and all workflows inside it
|
||||
</Label>
|
||||
</div>
|
||||
</RadioGroup>
|
||||
<DialogFooter>
|
||||
<DialogClose asChild>
|
||||
<Button variant="secondary">Cancel</Button>
|
||||
</DialogClose>
|
||||
<Button
|
||||
variant="destructive"
|
||||
onClick={handleDelete}
|
||||
disabled={isDeleteFolderPending}
|
||||
>
|
||||
{isDeleteFolderPending && (
|
||||
<ReloadIcon className="mr-2 h-4 w-4 animate-spin" />
|
||||
)}
|
||||
Delete
|
||||
</Button>
|
||||
</DialogFooter>
|
||||
</DialogContent>
|
||||
</Dialog>
|
||||
);
|
||||
}
|
||||
|
||||
export { DeleteFolderButton };
|
||||
Reference in New Issue
Block a user