forked from github/plane
77 lines
1.8 KiB
TypeScript
77 lines
1.8 KiB
TypeScript
import { useEffect } from "react";
|
|
|
|
import { useRouter } from "next/router";
|
|
|
|
import useSWR from "swr";
|
|
|
|
// services
|
|
import workspaceService from "services/workspace.service";
|
|
// hooks
|
|
import useUser from "hooks/use-user";
|
|
import useWorkspaces from "hooks/use-workspaces";
|
|
// ui
|
|
import { Spinner } from "components/ui";
|
|
// types
|
|
import type { NextPage } from "next";
|
|
// fetch-keys
|
|
import { USER_WORKSPACE_INVITATIONS } from "constants/fetch-keys";
|
|
|
|
const Home: NextPage = () => {
|
|
const router = useRouter();
|
|
|
|
const { user, isUserLoading } = useUser();
|
|
const { workspaces, error: workspacesError } = useWorkspaces();
|
|
|
|
const lastActiveWorkspace =
|
|
user && workspaces.find((workspace) => workspace.id === user.last_workspace_id);
|
|
|
|
const { data: invitations, error: invitationsError } = useSWR(USER_WORKSPACE_INVITATIONS, () =>
|
|
workspaceService.userWorkspaceInvitations()
|
|
);
|
|
|
|
useEffect(() => {
|
|
if (isUserLoading) return;
|
|
|
|
if (!user) {
|
|
router.push("/signin");
|
|
return;
|
|
} else if (!user.is_onboarded) {
|
|
router.push("/onboarding");
|
|
return;
|
|
}
|
|
|
|
if (!user || (!workspaces && !workspacesError)) return;
|
|
|
|
if (lastActiveWorkspace) {
|
|
router.push(`/${lastActiveWorkspace.slug}`);
|
|
return;
|
|
} else if (workspaces.length > 0) {
|
|
router.push(`/${workspaces[0].slug}`);
|
|
return;
|
|
} else if (!invitationsError && invitations && invitations.length > 0) {
|
|
router.push("/invitations");
|
|
return;
|
|
} else {
|
|
router.push("/create-workspace");
|
|
return;
|
|
}
|
|
}, [
|
|
invitations,
|
|
invitationsError,
|
|
isUserLoading,
|
|
lastActiveWorkspace,
|
|
user,
|
|
workspaces,
|
|
router,
|
|
workspacesError,
|
|
]);
|
|
|
|
return (
|
|
<div className="grid h-screen place-items-center">
|
|
<Spinner />
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default Home;
|