mirror of
https://github.com/willchen96/mike.git
synced 2026-06-24 21:38:06 +02:00
feat: enhance user profile management and MFA login flow
- Refactor user profile loading and updating logic to improve state management and reduce unnecessary checks. - Update MFA login gate to streamline verification checks and improve user experience. - Ensure consistent handling of user ID across profile context and components. - Improve error handling and loading states in user-related API calls.
This commit is contained in:
parent
3a10943200
commit
444d1d38e4
3 changed files with 576 additions and 474 deletions
|
|
@ -20,20 +20,30 @@ export function MfaLoginGate({ children }: { children: ReactNode }) {
|
|||
const isVerifyPage = pathname === "/verify-mfa";
|
||||
|
||||
useEffect(() => {
|
||||
if (!user || loading || !profile?.mfaOnLogin) {
|
||||
if (!user) {
|
||||
setGateState("idle");
|
||||
return;
|
||||
}
|
||||
if (loading) {
|
||||
return;
|
||||
}
|
||||
if (!profile?.mfaOnLogin) {
|
||||
setGateState("idle");
|
||||
return;
|
||||
}
|
||||
|
||||
if (hasRecentMfaVerification()) {
|
||||
setGateState("verified");
|
||||
return;
|
||||
}
|
||||
|
||||
let cancelled = false;
|
||||
setGateState("checking");
|
||||
setGateState((previous) =>
|
||||
previous === "verified" ? "verified" : "checking",
|
||||
);
|
||||
|
||||
async function checkLoginMfa() {
|
||||
try {
|
||||
if (hasRecentMfaVerification()) {
|
||||
if (!cancelled) setGateState("verified");
|
||||
return;
|
||||
}
|
||||
const required = await needsMfaVerification();
|
||||
if (cancelled) return;
|
||||
setGateState(required ? "required" : "verified");
|
||||
|
|
@ -47,7 +57,7 @@ export function MfaLoginGate({ children }: { children: ReactNode }) {
|
|||
return () => {
|
||||
cancelled = true;
|
||||
};
|
||||
}, [loading, profile?.mfaOnLogin, user]);
|
||||
}, [loading, profile?.mfaOnLogin, user?.id]);
|
||||
|
||||
useEffect(() => {
|
||||
if (!user || loading || !profile?.mfaOnLogin) return;
|
||||
|
|
@ -75,7 +85,13 @@ export function MfaLoginGate({ children }: { children: ReactNode }) {
|
|||
user,
|
||||
]);
|
||||
|
||||
if (user && loading) return <FullScreenGateLoader />;
|
||||
if (user && loading) {
|
||||
return gateState === "verified" ? (
|
||||
<>{children}</>
|
||||
) : (
|
||||
<FullScreenGateLoader />
|
||||
);
|
||||
}
|
||||
|
||||
if (user && profile?.mfaOnLogin) {
|
||||
if (gateState === "required" && isVerifyPage) {
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue