import { FC, ReactNode } from "react"; import useSWR from "swr"; import { IWorkspaceMemberInvitation } from "@plane/types"; // components import { LogoSpinner } from "@/components/common"; import { WorkspaceLogo } from "@/components/workspace/logo"; // helpers import { EAuthModes, EAuthSteps } from "@/helpers/authentication.helper"; // services import { WorkspaceService } from "@/services/workspace.service"; type TAuthHeader = { workspaceSlug: string | undefined; invitationId: string | undefined; invitationEmail: string | undefined; authMode: EAuthModes; currentAuthStep: EAuthSteps; children: ReactNode; }; const Titles = { [EAuthModes.SIGN_IN]: { [EAuthSteps.EMAIL]: { header: "Log in or Sign up", subHeader: "", }, [EAuthSteps.PASSWORD]: { header: "Log in or Sign up", subHeader: "Log in using your password.", }, [EAuthSteps.UNIQUE_CODE]: { header: "Log in or Sign up", subHeader: "Log in using your unique code.", }, }, [EAuthModes.SIGN_UP]: { [EAuthSteps.EMAIL]: { header: "Sign up or Log in", subHeader: "", }, [EAuthSteps.PASSWORD]: { header: "Sign up or Log in", subHeader: "Sign up using your password", }, [EAuthSteps.UNIQUE_CODE]: { header: "Sign up or Log in", subHeader: "Sign up using your unique code", }, }, }; const workSpaceService = new WorkspaceService(); export const AuthHeader: FC = (props) => { const { workspaceSlug, invitationId, invitationEmail, authMode, currentAuthStep, children } = props; const { data: invitation, isLoading } = useSWR( workspaceSlug && invitationId ? `WORKSPACE_INVITATION_${workspaceSlug}_${invitationId}` : null, async () => workspaceSlug && invitationId && workSpaceService.getWorkspaceInvitation(workspaceSlug, invitationId), { revalidateOnFocus: false, shouldRetryOnError: false, } ); const getHeaderSubHeader = ( step: EAuthSteps, mode: EAuthModes, invitation: IWorkspaceMemberInvitation | undefined, email: string | undefined ) => { if (invitation && email && invitation.email === email && invitation.workspace) { const workspace = invitation.workspace; return { header: (
Join {" "} {workspace.name}
), subHeader: `${ mode == EAuthModes.SIGN_UP ? "Create an account" : "Sign in" } to start managing work with your team.`, }; } return Titles[mode][step]; }; const { header, subHeader } = getHeaderSubHeader(currentAuthStep, authMode, invitation || undefined, invitationEmail); if (isLoading) return (
); return ( <>

{header}

{subHeader}

{children} ); };