From 21e32ce863413e9a848a50bfd6580736c8bee77b Mon Sep 17 00:00:00 2001 From: Anmol Singh Bhatia <121005188+anmolsinghbhatia@users.noreply.github.com> Date: Mon, 27 Nov 2023 17:16:46 +0530 Subject: [PATCH] [FED-1054] fix: join project mutation (#2892) * fix: join project mutation * chore: code refactor --- .../auth-screens/project/join-project.tsx | 14 ++++++++++---- web/components/project/join-project-modal.tsx | 5 ++++- 2 files changed, 14 insertions(+), 5 deletions(-) diff --git a/web/components/auth-screens/project/join-project.tsx b/web/components/auth-screens/project/join-project.tsx index d5841e43b..7ee4feacd 100644 --- a/web/components/auth-screens/project/join-project.tsx +++ b/web/components/auth-screens/project/join-project.tsx @@ -3,6 +3,7 @@ import Image from "next/image"; import { useRouter } from "next/router"; // mobx store import { useMobxStore } from "lib/mobx/store-provider"; +import { RootStore } from "store/root"; // ui import { Button } from "@plane/ui"; // icons @@ -14,8 +15,9 @@ export const JoinProject: React.FC = () => { const [isJoiningProject, setIsJoiningProject] = useState(false); const { + project: projectStore, user: { joinProject }, - } = useMobxStore(); + }: RootStore = useMobxStore(); const router = useRouter(); const { workspaceSlug, projectId } = router.query; @@ -25,9 +27,13 @@ export const JoinProject: React.FC = () => { setIsJoiningProject(true); - joinProject(workspaceSlug.toString(), [projectId.toString()]).finally(() => { - setIsJoiningProject(false); - }); + joinProject(workspaceSlug.toString(), [projectId.toString()]) + .then(() => { + projectStore.fetchProjects(workspaceSlug.toString()); + }) + .finally(() => { + setIsJoiningProject(false); + }); }; return ( diff --git a/web/components/project/join-project-modal.tsx b/web/components/project/join-project-modal.tsx index 8a4e6304d..4a3cad425 100644 --- a/web/components/project/join-project-modal.tsx +++ b/web/components/project/join-project-modal.tsx @@ -7,6 +7,7 @@ import { Button } from "@plane/ui"; import type { IProject } from "types"; // lib import { useMobxStore } from "lib/mobx/store-provider"; +import { RootStore } from "store/root"; // type type TJoinProjectModalProps = { @@ -22,8 +23,9 @@ export const JoinProjectModal: React.FC = (props) => { const [isJoiningLoading, setIsJoiningLoading] = useState(false); // store const { + project: projectStore, user: { joinProject }, - } = useMobxStore(); + }: RootStore = useMobxStore(); // router const router = useRouter(); @@ -33,6 +35,7 @@ export const JoinProjectModal: React.FC = (props) => { joinProject(workspaceSlug, [project.id]) .then(() => { router.push(`/${workspaceSlug}/projects/${project.id}/issues`); + projectStore.fetchProjects(workspaceSlug); handleClose(); }) .finally(() => {