import React, { useState } from "react"; import { useRouter } from "next/router"; import { useTheme } from "next-themes"; import { Dialog, Transition } from "@headlessui/react"; import { Trash2 } from "lucide-react"; import { mutate } from "swr"; // hooks import { useUser } from "hooks/store"; // ui import { Button } from "@plane/ui"; // hooks import useToast from "hooks/use-toast"; type Props = { isOpen: boolean; onClose: () => void; }; export const DeactivateAccountModal: React.FC = (props) => { const { isOpen, onClose } = props; // states const [isDeactivating, setIsDeactivating] = useState(false); const { deactivateAccount } = useUser(); const router = useRouter(); const { setToastAlert } = useToast(); const { setTheme } = useTheme(); const handleClose = () => { setIsDeactivating(false); onClose(); }; const handleDeleteAccount = async () => { setIsDeactivating(true); await deactivateAccount() .then(() => { setToastAlert({ type: "success", title: "Success!", message: "Account deactivated successfully.", }); mutate("CURRENT_USER_DETAILS", null); setTheme("system"); router.push("/"); handleClose(); }) .catch((err) => setToastAlert({ type: "error", title: "Error!", message: err?.error, }) ) .finally(() => setIsDeactivating(false)); }; return (
Deactivate your account?

Once deactivated, you can{"'"}t be assigned issues and be billed for your workspace.To reactivate your account, you will need an invite to a workspace at this email address.

); };