plane/apps/app/pages/index.tsx
2023-04-12 19:03:08 +05:30

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;