/** * Copyright (c) 2023-present Plane Software, Inc. and contributors * SPDX-License-Identifier: AGPL-3.0-only * See the LICENSE file for details. */ import React, { useEffect, useState } from "react"; import { CircleCheck, XCircle } from "lucide-react"; // plane imports import { API_BASE_URL } from "@plane/constants"; import { Button } from "@plane/propel/button"; import { AuthService } from "@plane/services"; import { Input, Spinner } from "@plane/ui"; // hooks import useTimer from "@/hooks/use-timer"; // types import { EAuthModes } from "@/types/auth"; // services const authService = new AuthService(); type TAuthUniqueCodeForm = { mode: EAuthModes; email: string; nextPath: string | undefined; handleEmailClear: () => void; generateEmailUniqueCode: (email: string) => Promise<{ code: string } | undefined>; }; type TUniqueCodeFormValues = { email: string; code: string; }; const defaultValues: TUniqueCodeFormValues = { email: "", code: "", }; export function AuthUniqueCodeForm(props: TAuthUniqueCodeForm) { const { mode, email, nextPath, handleEmailClear, generateEmailUniqueCode } = props; // derived values const defaultResetTimerValue = 5; // states const [uniqueCodeFormData, setUniqueCodeFormData] = useState({ ...defaultValues, email }); const [isRequestingNewCode, setIsRequestingNewCode] = useState(false); const [csrfToken, setCsrfToken] = useState(undefined); const [isSubmitting, setIsSubmitting] = useState(false); // timer const { timer: resendTimerCode, setTimer: setResendCodeTimer } = useTimer(0); const handleFormChange = (key: keyof TUniqueCodeFormValues, value: string) => setUniqueCodeFormData((prev) => ({ ...prev, [key]: value })); const generateNewCode = async (email: string) => { try { setIsRequestingNewCode(true); const uniqueCode = await generateEmailUniqueCode(email); setResendCodeTimer(defaultResetTimerValue); handleFormChange("code", uniqueCode?.code || ""); setIsRequestingNewCode(false); } catch { setResendCodeTimer(0); console.error("Error while requesting new code"); setIsRequestingNewCode(false); } }; useEffect(() => { if (csrfToken === undefined) authService.requestCSRFToken().then((data) => data?.csrf_token && setCsrfToken(data.csrf_token)); }, [csrfToken]); const isRequestNewCodeDisabled = isRequestingNewCode || resendTimerCode > 0; const isButtonDisabled = isRequestingNewCode || !uniqueCodeFormData.code || isSubmitting; return (
setIsSubmitting(true)} onError={() => setIsSubmitting(false)} >
handleFormChange("email", e.target.value)} placeholder="name@company.com" className={`h-10 w-full border-0 disable-autofill-style placeholder:text-placeholder`} autoComplete="off" disabled /> {uniqueCodeFormData.email.length > 0 && ( )}
handleFormChange("code", e.target.value)} placeholder="123456" className="h-10 w-full border border-subtle !bg-surface-1 pr-12 disable-autofill-style placeholder:text-placeholder" autoComplete="off" autoFocus />

Paste the code sent to your email

); }