Fix SuperTokens initialization timing issues
- Remove session check from home page (landing page doesn't need it) - Add delayed session check in auth page to redirect logged-in users - Handle SuperTokens not being initialized yet with proper error handling Co-authored-by: Cursor <cursoragent@cursor.com>
This commit is contained in:
@@ -2,6 +2,7 @@
|
||||
|
||||
import dynamic from "next/dynamic";
|
||||
import { useEffect, useState } from "react";
|
||||
import { useRouter } from "next/navigation";
|
||||
|
||||
// Dynamically import SuperTokens component (client-side only)
|
||||
const SuperTokensAuthComponent = dynamic(
|
||||
@@ -10,11 +11,26 @@ const SuperTokensAuthComponent = dynamic(
|
||||
);
|
||||
|
||||
export default function AuthPage() {
|
||||
const router = useRouter();
|
||||
const [mounted, setMounted] = useState(false);
|
||||
|
||||
useEffect(() => {
|
||||
setMounted(true);
|
||||
}, []);
|
||||
|
||||
// Check if already logged in after a short delay
|
||||
setTimeout(async () => {
|
||||
try {
|
||||
const { doesSessionExist } = await import("supertokens-web-js/recipe/session");
|
||||
const exists = await doesSessionExist();
|
||||
if (exists) {
|
||||
router.push("/marks-account/projects");
|
||||
}
|
||||
} catch (error) {
|
||||
// SuperTokens not initialized yet, continue to show auth page
|
||||
console.log("Session check skipped");
|
||||
}
|
||||
}, 500);
|
||||
}, [router]);
|
||||
|
||||
if (!mounted) {
|
||||
return (
|
||||
|
||||
Reference in New Issue
Block a user