From c0e2bdc01366f4a8878ffb373527d786e163a19b Mon Sep 17 00:00:00 2001 From: MohamedBassem Date: Sun, 31 Mar 2024 16:23:25 +0100 Subject: refactor: Extract the action confirming dialog into its own component --- .../dashboard/lists/DeleteListButton.tsx | 65 +++++++--------------- 1 file changed, 20 insertions(+), 45 deletions(-) (limited to 'apps/web/components/dashboard/lists') diff --git a/apps/web/components/dashboard/lists/DeleteListButton.tsx b/apps/web/components/dashboard/lists/DeleteListButton.tsx index 345c81d2..ee2a9ec7 100644 --- a/apps/web/components/dashboard/lists/DeleteListButton.tsx +++ b/apps/web/components/dashboard/lists/DeleteListButton.tsx @@ -1,18 +1,9 @@ "use client"; -import { useState } from "react"; import { useRouter } from "next/navigation"; import { ActionButton } from "@/components/ui/action-button"; +import ActionConfirmingDialog from "@/components/ui/action-confirming-dialog"; import { Button } from "@/components/ui/button"; -import { - Dialog, - DialogClose, - DialogContent, - DialogFooter, - DialogHeader, - DialogTitle, - DialogTrigger, -} from "@/components/ui/dialog"; import { toast } from "@/components/ui/use-toast"; import { api } from "@/lib/trpc"; import { Trash2 } from "lucide-react"; @@ -20,8 +11,6 @@ import { Trash2 } from "lucide-react"; import type { ZBookmarkList } from "@hoarder/trpc/types/lists"; export default function DeleteListButton({ list }: { list: ZBookmarkList }) { - const [isDialogOpen, setDialogOpen] = useState(false); - const router = useRouter(); const listsInvalidationFunction = api.useUtils().lists.list.invalidate; @@ -41,38 +30,24 @@ export default function DeleteListButton({ list }: { list: ZBookmarkList }) { }, }); return ( - - - - - - - - Delete {list.icon} {list.name}? - - - - Are you sure you want to delete {list.icon} {list.name}? - - - - - - deleteList({ listId: list.id })} - > - Delete - - - - + ( + deleteList({ listId: list.id })} + > + Delete + + )} + > + + ); } -- cgit v1.2.3-70-g09d2