Files
linkwarden/apps/web/pages/confirmation.tsx
2025-06-24 14:52:09 -04:00

67 lines
1.8 KiB
TypeScript

import CenteredForm from "@/layouts/CenteredForm";
import { signIn } from "next-auth/react";
import { useRouter } from "next/router";
import { useState } from "react";
import toast from "react-hot-toast";
import { useTranslation } from "next-i18next";
import getServerSideProps from "@/lib/client/getServerSideProps";
import { Button } from "@/components/ui/button";
import { Separator } from "@/components/ui/separator";
export default function EmailConfirmaion() {
const router = useRouter();
const { t } = useTranslation();
const [submitLoader, setSubmitLoader] = useState(false);
const resend = async () => {
if (submitLoader) return;
else if (!router.query.email) return;
setSubmitLoader(true);
const load = toast.loading(t("authenticating"));
const res = await signIn("email", {
email: decodeURIComponent(router.query.email as string),
callbackUrl: "/",
redirect: false,
});
toast.dismiss(load);
setSubmitLoader(false);
toast.success(t("verification_email_sent"));
};
return (
<CenteredForm>
<div className="p-4 max-w-[30rem] min-w-80 w-full rounded-xl shadow-md mx-auto border border-neutral-content bg-base-200">
<p className="text-center text-xl sm:text-3xl font-extralight mb-2 ">
{t("check_your_email")}
</p>
<Separator className="my-3" />
{router.query.email && typeof router.query.email === "string" && (
<p className="text-center font-bold mb-3 break-all">
{decodeURIComponent(router.query.email)}
</p>
)}
<p>{t("verification_email_sent_desc")}</p>
<div className="mx-auto w-fit mt-3">
<Button onClick={resend} variant="ghost" size="sm">
{t("resend_email")}
</Button>
</div>
</div>
</CenteredForm>
);
}
export { getServerSideProps };