Files
zitadel/apps/login/ui/ChooseSecondFactorToSetup.tsx
2024-04-30 10:39:34 +02:00

72 lines
1.8 KiB
TypeScript

"use client";
import {
AuthenticationMethodType,
LoginSettings,
login,
} from "@zitadel/server";
import Link from "next/link";
import { BadgeState, StateBadge } from "./StateBadge";
import clsx from "clsx";
import { CheckIcon } from "@heroicons/react/24/outline";
import { EMAIL, SMS, TOTP, U2F } from "./AuthMethods";
type Props = {
loginName?: string;
sessionId?: string;
authRequestId?: string;
organization?: string;
loginSettings: LoginSettings;
userMethods: AuthenticationMethodType[];
checkAfter: boolean;
};
export default function ChooseSecondFactorToSetup({
loginName,
sessionId,
authRequestId,
organization,
loginSettings,
userMethods,
checkAfter,
}: Props) {
const params = new URLSearchParams({});
if (loginName) {
params.append("loginName", loginName);
}
if (sessionId) {
params.append("sessionId", sessionId);
}
if (authRequestId) {
params.append("authRequestId", authRequestId);
}
if (organization) {
params.append("organization", organization);
}
if (checkAfter) {
params.append("checkAfter", "true");
}
return (
<div className="grid grid-cols-1 gap-5 w-full pt-4">
{loginSettings.secondFactors.map((factor, i) => {
return (
<div key={"method-" + i}>
{factor === 1 &&
TOTP(
userMethods.includes(4),
userMethods.includes(4) ? "" : "/otp/time-based/set?" + params
)}
{factor === 2 && U2F(userMethods.includes(5), "/u2f/set?" + params)}
{factor === 3 &&
EMAIL(userMethods.includes(7), "/otp/email/set?" + params)}
{factor === 4 &&
SMS(userMethods.includes(6), "/otp/sms/set?" + params)}
</div>
);
})}
</div>
);
}