chore: onboarding workflow in authentication (#1281)

This commit is contained in:
guru_sainath 2023-06-13 14:37:25 +05:30 committed by GitHub
parent 15b5db0cae
commit f774603b7f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 159 additions and 129 deletions

View File

@ -16,7 +16,7 @@ type EmailCodeFormValues = {
token?: string; token?: string;
}; };
export const EmailCodeForm = ({ onSuccess }: any) => { export const EmailCodeForm = ({ handleSignIn }: any) => {
const [codeSent, setCodeSent] = useState(false); const [codeSent, setCodeSent] = useState(false);
const [codeResent, setCodeResent] = useState(false); const [codeResent, setCodeResent] = useState(false);
const [isCodeResending, setIsCodeResending] = useState(false); const [isCodeResending, setIsCodeResending] = useState(false);
@ -66,7 +66,12 @@ export const EmailCodeForm = ({ onSuccess }: any) => {
const handleSignin = async (formData: EmailCodeFormValues) => { const handleSignin = async (formData: EmailCodeFormValues) => {
setIsLoading(true); setIsLoading(true);
await authenticationService.magicSignIn(formData).catch((error) => { await authenticationService
.magicSignIn(formData)
.then((response) => {
handleSignIn(response);
})
.catch((error) => {
setIsLoading(false); setIsLoading(false);
setToastAlert({ setToastAlert({
title: "Oops!", title: "Oops!",
@ -75,7 +80,7 @@ export const EmailCodeForm = ({ onSuccess }: any) => {
}); });
setError("token" as keyof EmailCodeFormValues, { setError("token" as keyof EmailCodeFormValues, {
type: "manual", type: "manual",
message: error.error, message: error?.error,
}); });
}); });
}; };

View File

@ -35,12 +35,12 @@ export const GithubLoginButton: FC<GithubLoginButtonProps> = (props) => {
}, []); }, []);
return ( return (
<div className="w-full px-1"> <div className="w-full flex justify-center items-center px-[3px]">
<Link <Link
href={`https://github.com/login/oauth/authorize?client_id=${NEXT_PUBLIC_GITHUB_ID}&redirect_uri=${loginCallBackURL}&scope=read:user,user:email`} href={`https://github.com/login/oauth/authorize?client_id=${NEXT_PUBLIC_GITHUB_ID}&redirect_uri=${loginCallBackURL}&scope=read:user,user:email`}
> >
<button className="flex w-full items-center justify-center gap-3 rounded-md border border-brand-base p-2 text-sm font-medium text-brand-secondary duration-300 hover:bg-brand-surface-2"> <button className="flex w-full items-center justify-center gap-3 rounded border border-brand-base p-2 text-sm font-medium text-brand-secondary duration-300 hover:bg-brand-surface-2">
<Image src={githubImage} height={22} width={22} color="#000" alt="GitHub Logo" /> <Image src={githubImage} height={20} width={20} color="#000" alt="GitHub Logo" />
<span>Sign In with Github</span> <span>Sign In with Github</span>
</button> </button>
</Link> </Link>

View File

@ -47,7 +47,11 @@ export const GoogleLoginButton: FC<IGoogleLoginButton> = (props) => {
return ( return (
<> <>
<Script src="https://accounts.google.com/gsi/client" async defer onLoad={loadScript} /> <Script src="https://accounts.google.com/gsi/client" async defer onLoad={loadScript} />
<div className="overflow-hidden rounded" id="googleSignInButton" ref={googleSignInButton} /> <div
className="overflow-hidden rounded w-full flex justify-center items-center"
id="googleSignInButton"
ref={googleSignInButton}
/>
</> </>
); );
}; };

View File

@ -40,12 +40,14 @@ const HomePage: NextPage = () => {
} else { } else {
throw Error("Cant find credentials"); throw Error("Cant find credentials");
} }
} catch (error) { } catch (error: any) {
console.log(error); console.log(error);
setToastAlert({ setToastAlert({
title: "Error signing in!", title: "Error signing in!",
type: "error", type: "error",
message: "Something went wrong. Please try again later or contact the support team.", message:
error?.error ||
"Something went wrong. Please try again later or contact the support team.",
}); });
} }
}; };
@ -63,27 +65,44 @@ const HomePage: NextPage = () => {
} else { } else {
throw Error("Cant find credentials"); throw Error("Cant find credentials");
} }
} catch (error) { } catch (error: any) {
console.log(error); console.log(error);
setToastAlert({ setToastAlert({
title: "Error signing in!", title: "Error signing in!",
type: "error", type: "error",
message: "Something went wrong. Please try again later or contact the support team.", message:
error?.error ||
"Something went wrong. Please try again later or contact the support team.",
}); });
} }
}; };
const handleEmailPasswordSignIn = async (response: any) => { const handleEmailPasswordSignIn = async (response: any) => {
try { try {
if (response) { if (response) mutateUser();
mutateUser(); } catch (error: any) {
}
} catch (error) {
console.log(error); console.log(error);
setToastAlert({ setToastAlert({
title: "Error signing in!", title: "Error signing in!",
type: "error", type: "error",
message: "Something went wrong. Please try again later or contact the support team.", message:
error?.error ||
"Something went wrong. Please try again later or contact the support team.",
});
}
};
const handleEmailCodeSignIn = async (response: any) => {
try {
if (response) mutateUser();
} catch (error: any) {
console.log(error);
setToastAlert({
title: "Error signing in!",
type: "error",
message:
error?.error ||
"Something went wrong. Please try again later or contact the support team.",
}); });
} }
}; };
@ -91,9 +110,12 @@ const HomePage: NextPage = () => {
return ( return (
<DefaultLayout> <DefaultLayout>
{isLoading ? ( {isLoading ? (
<div className="grid h-screen place-items-center"> <div className="flex flex-col gap-3 w-full h-screen justify-center items-center">
<div>
<Spinner /> <Spinner />
</div> </div>
{/* <div className="text-gray-500">Validating authentication</div> */}
</div>
) : ( ) : (
<div className="flex h-screen w-full items-center justify-center overflow-auto"> <div className="flex h-screen w-full items-center justify-center overflow-auto">
<div className="flex min-h-full w-full flex-col justify-center py-12 px-6 lg:px-8"> <div className="flex min-h-full w-full flex-col justify-center py-12 px-6 lg:px-8">
@ -108,16 +130,14 @@ const HomePage: NextPage = () => {
<div className="flex flex-col rounded-[10px] bg-brand-base shadow-md"> <div className="flex flex-col rounded-[10px] bg-brand-base shadow-md">
{parseInt(process.env.NEXT_PUBLIC_ENABLE_OAUTH || "0") ? ( {parseInt(process.env.NEXT_PUBLIC_ENABLE_OAUTH || "0") ? (
<> <>
<EmailCodeForm /> <EmailCodeForm handleSignIn={handleEmailCodeSignIn} />
<div className="flex flex-col items-center justify-center gap-3 border-t border-brand-base py-5 px-5"> <div className="flex flex-col items-center justify-center gap-3 border-t border-brand-base py-5 px-5">
<GoogleLoginButton handleSignIn={handleGoogleSignIn} /> <GoogleLoginButton handleSignIn={handleGoogleSignIn} />
<GithubLoginButton handleSignIn={handleGithubSignIn} /> <GithubLoginButton handleSignIn={handleGithubSignIn} />
</div> </div>
</> </>
) : ( ) : (
<>
<EmailPasswordForm handleSignIn={handleEmailPasswordSignIn} /> <EmailPasswordForm handleSignIn={handleEmailPasswordSignIn} />
</>
)} )}
</div> </div>
</div> </div>

View File

@ -1,9 +1,6 @@
import { useState } from "react"; import { useState } from "react";
// next imports
import Router from "next/router"; import Router from "next/router";
import { mutate } from "swr";
// services // services
import userService from "services/user.service"; import userService from "services/user.service";
import workspaceService from "services/workspace.service"; import workspaceService from "services/workspace.service";
@ -11,7 +8,6 @@ import workspaceService from "services/workspace.service";
import useUserAuth from "hooks/use-user-auth"; import useUserAuth from "hooks/use-user-auth";
// layouts // layouts
import DefaultLayout from "layouts/default-layout"; import DefaultLayout from "layouts/default-layout";
import { UserAuthorizationLayout } from "layouts/auth-layout/user-authorization-wrapper";
// components // components
import { import {
InviteMembers, InviteMembers,
@ -26,9 +22,6 @@ import { PrimaryButton, Spinner } from "components/ui";
import { ONBOARDING_CARDS } from "constants/workspace"; import { ONBOARDING_CARDS } from "constants/workspace";
// types // types
import type { NextPage } from "next"; import type { NextPage } from "next";
import { ICurrentUserResponse } from "types";
// fetch-keys
import { CURRENT_USER } from "constants/fetch-keys";
const Onboarding: NextPage = () => { const Onboarding: NextPage = () => {
const [step, setStep] = useState(1); const [step, setStep] = useState(1);
@ -37,11 +30,16 @@ const Onboarding: NextPage = () => {
const [workspace, setWorkspace] = useState(); const [workspace, setWorkspace] = useState();
const { user, mutateUser } = useUserAuth("onboarding"); const { user, isLoading: userLoading, mutateUser } = useUserAuth("onboarding");
return ( return (
<UserAuthorizationLayout>
<DefaultLayout> <DefaultLayout>
{userLoading ? (
<div className="grid h-screen place-items-center">
<Spinner />
</div>
) : (
<>
{isLoading ? ( {isLoading ? (
<div className="grid h-screen place-items-center"> <div className="grid h-screen place-items-center">
<Spinner /> <Spinner />
@ -58,7 +56,9 @@ const Onboarding: NextPage = () => {
) : step === 2 ? ( ) : step === 2 ? (
<Workspace setStep={setStep} setWorkspace={setWorkspace} user={user} /> <Workspace setStep={setStep} setWorkspace={setWorkspace} user={user} />
) : ( ) : (
step === 3 && (
<InviteMembers setStep={setStep} workspace={workspace} user={user} /> <InviteMembers setStep={setStep} workspace={workspace} user={user} />
)
)} )}
</div> </div>
) : ( ) : (
@ -73,7 +73,7 @@ const Onboarding: NextPage = () => {
) : step === 7 ? ( ) : step === 7 ? (
<OnboardingCard data={ONBOARDING_CARDS.module} gradient /> <OnboardingCard data={ONBOARDING_CARDS.module} gradient />
) : ( ) : (
<OnboardingCard data={ONBOARDING_CARDS.commandMenu} /> step === 8 && <OnboardingCard data={ONBOARDING_CARDS.commandMenu} />
)} )}
<div className="mx-auto flex h-1/4 items-end lg:w-1/2"> <div className="mx-auto flex h-1/4 items-end lg:w-1/2">
<PrimaryButton <PrimaryButton
@ -138,8 +138,9 @@ const Onboarding: NextPage = () => {
</div> </div>
</div> </div>
)} )}
</>
)}
</DefaultLayout> </DefaultLayout>
</UserAuthorizationLayout>
); );
}; };