import { FC, Fragment } from "react"; import { useRouter } from "next/router"; import { Controller, useForm } from "react-hook-form"; import { Dialog, Transition } from "@headlessui/react"; import { ExclamationTriangleIcon } from "@heroicons/react/24/outline"; import { observer } from "mobx-react-lite"; // ui import { DangerButton, Input, SecondaryButton } from "components/ui"; // fetch-keys import { PROJECTS_LIST } from "constants/fetch-keys"; // mobx react lite // mobx store import { useMobxStore } from "lib/mobx/store-provider"; import { RootStore } from "store/root"; // hooks import useToast from "hooks/use-toast"; import useUser from "hooks/use-user"; import useProjects from "hooks/use-projects"; // types import { IProject } from "types"; type FormData = { projectName: string; confirmLeave: string; }; const defaultValues: FormData = { projectName: "", confirmLeave: "", }; export interface ILeaveProjectModal { project: IProject; isOpen: boolean; onClose: () => void; } export const LeaveProjectModal: FC = observer((props) => { const { project, isOpen, onClose } = props; // router const router = useRouter(); const { workspaceSlug } = router.query; // store const { project: projectStore } = useMobxStore(); // user const { user } = useUser(); // project const { mutateProjects } = useProjects(); // toast const { setToastAlert } = useToast(); const { control, formState: { isSubmitting }, handleSubmit, reset, } = useForm({ defaultValues }); const handleClose = () => { reset({ ...defaultValues }); }; const onSubmit = async (data: any) => { if (!workspaceSlug) return; if (data) { if (data.projectName === project?.name) { if (data.confirmLeave === "Leave Project") { return projectStore .leaveProject(workspaceSlug.toString(), project.id) .then((res) => { handleClose(); router.push(`/${workspaceSlug}/projects`); }) .catch((err) => { setToastAlert({ type: "error", title: "Error!", message: "Something went wrong please try again later.", }); }); } else { setToastAlert({ type: "error", title: "Error!", message: "Please confirm leaving the project by typing the 'Leave Project'.", }); } } else { setToastAlert({ type: "error", title: "Error!", message: "Please enter the project name as shown in the description.", }); } } else { setToastAlert({ type: "error", title: "Error!", message: "Please fill all fields.", }); } }; return (

Leave Project

Are you sure you want to leave the project - {` "${project?.name}" `}? All of the issues associated with you will become inaccessible.

Enter the project name {project?.name}{" "} to continue:

( )} />

To confirm, type Leave Project below:

( )} />
Cancel {isSubmitting ? "Leaving..." : "Leave Project"}
); });