import React, { useEffect, useState, useCallback } from "react"; // react hook form import { useForm } from "react-hook-form"; // services import authenticationService from "services/authentication.service"; // hooks import useToast from "hooks/use-toast"; import useTimer from "hooks/use-timer"; // ui import { Button, Input } from "@plane/ui"; // types type EmailCodeFormValues = { email: string; key?: string; token?: string; }; export const EmailCodeForm = ({ handleSignIn }: any) => { const [codeSent, setCodeSent] = useState(false); const [codeResent, setCodeResent] = useState(false); const [isCodeResending, setIsCodeResending] = useState(false); const [errorResendingCode, setErrorResendingCode] = useState(false); const [isLoading, setIsLoading] = useState(false); const { setToastAlert } = useToast(); const { timer: resendCodeTimer, setTimer: setResendCodeTimer } = useTimer(); const { register, handleSubmit, setError, setValue, getValues, watch, formState: { errors, isSubmitting, isValid, isDirty }, } = useForm({ defaultValues: { email: "", key: "", token: "", }, mode: "onChange", reValidateMode: "onChange", }); const isResendDisabled = resendCodeTimer > 0 || isCodeResending || isSubmitting || errorResendingCode; const onSubmit = useCallback( async ({ email }: EmailCodeFormValues) => { setErrorResendingCode(false); await authenticationService .emailCode({ email }) .then((res) => { setValue("key", res.key); setCodeSent(true); }) .catch((err) => { setErrorResendingCode(true); setToastAlert({ title: "Oops!", type: "error", message: err?.error, }); }); }, [setToastAlert, setValue] ); const handleSignin = async (formData: EmailCodeFormValues) => { setIsLoading(true); await authenticationService .magicSignIn(formData) .then((response) => { setIsLoading(false); handleSignIn(response); }) .catch((error) => { setIsLoading(false); setToastAlert({ title: "Oops!", type: "error", message: error?.response?.data?.error ?? "Enter the correct code to sign in", }); setError("token" as keyof EmailCodeFormValues, { type: "manual", message: error?.error, }); }); }; const emailOld = getValues("email"); useEffect(() => { setErrorResendingCode(false); }, [emailOld]); useEffect(() => { const submitForm = (e: KeyboardEvent) => { if (!codeSent && e.key === "Enter") { e.preventDefault(); handleSubmit(onSubmit)().then(() => { setResendCodeTimer(30); }); } }; if (!codeSent) { window.addEventListener("keydown", submitForm); } return () => { window.removeEventListener("keydown", submitForm); }; }, [handleSubmit, codeSent, onSubmit, setResendCodeTimer]); return ( <> {(codeSent || codeResent) && (

We have sent the sign in code.
Please check your inbox at {watch("email")}

)}
/^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|(\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/.test( value ) || "Email address is not valid", })} /> {errors.email &&
{errors.email.message}
}
{codeSent && ( <> {errors.token &&
{errors.token.message}
} )} {codeSent ? ( ) : ( )}
); };