import { FC, ReactNode } from "react"; import { useRouter } from "next/router"; import Link from "next/link"; import useSWR from "swr"; import { observer } from "mobx-react-lite"; // icons import { Spinner, PrimaryButton, SecondaryButton } from "components/ui"; // hooks import { useMobxStore } from "lib/mobx/store-provider"; export interface IWorkspaceAuthWrapper { children: ReactNode; } const HIGHER_ROLES = [20, 15]; export const WorkspaceAuthWrapper: FC = observer((props) => { const { children } = props; // store const { user: userStore, project: projectStore, workspace: workspaceStore } = useMobxStore(); // router const router = useRouter(); const { workspaceSlug } = router.query; // fetching all workspaces useSWR(`USER_WORKSPACES_LIST`, () => workspaceStore.fetchWorkspaces()); // fetching user workspace information const { data: workspaceMemberInfo } = useSWR( workspaceSlug ? `WORKSPACE_MEMBERS_ME_${workspaceSlug}` : null, workspaceSlug ? () => userStore.fetchUserWorkspaceInfo(workspaceSlug.toString()) : null ); // fetching workspace projects useSWR( workspaceSlug ? `WORKSPACE_PROJECTS_${workspaceSlug}` : null, workspaceSlug ? () => projectStore.fetchProjects(workspaceSlug.toString()) : null ); // fetch workspace members useSWR( workspaceSlug && workspaceMemberInfo && HIGHER_ROLES.includes(workspaceMemberInfo.role) ? `WORKSPACE_MEMBERS_${workspaceSlug}` : null, workspaceSlug && workspaceMemberInfo && HIGHER_ROLES.includes(workspaceMemberInfo.role) ? () => workspaceStore.fetchWorkspaceMembers(workspaceSlug.toString()) : null ); // fetch workspace labels useSWR( workspaceSlug ? `WORKSPACE_LABELS_${workspaceSlug}` : null, workspaceSlug ? () => workspaceStore.fetchWorkspaceLabels(workspaceSlug.toString()) : null ); // while data is being loaded if (!userStore.workspaceMemberInfo && userStore.hasPermissionToWorkspace === null) { return (
); } // while user does not have access to view that workspace if (userStore.hasPermissionToWorkspace !== null && userStore.hasPermissionToWorkspace === false) { return (

Not Authorized!

You{"'"}re not a member of this workspace. Please contact the workspace admin to get an invitation or check your pending invitations.

Check pending invites Create new workspace
); } return <>{children}; });