Skip to content

Commit 7c9c7fa

Browse files
committed
fix bug where PrivatePage would try to check auth state before auth loaded
1 parent c528bad commit 7c9c7fa

File tree

3 files changed

+22
-22
lines changed

3 files changed

+22
-22
lines changed

frontend/src/app/admin/firebase/firebaseProvider.tsx

Lines changed: 8 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -2,28 +2,23 @@
22

33
import { Auth } from "firebase/auth";
44
import { FirebaseStorage } from "firebase/storage";
5-
import React, { FC, ReactNode, createContext, useContext, useEffect, useState } from "react";
5+
import React, { FC, ReactNode, createContext, useContext } from "react";
66

77
import { FirebaseServices, initFirebase } from "./firebase";
88

99
const AuthContext = createContext<Auth | undefined>(undefined);
1010
const StorageContext = createContext<FirebaseStorage | undefined>(undefined);
1111

12-
export const FirebaseProvider: FC<{ children: ReactNode }> = ({ children }) => {
13-
const [firebaseServices, setFirebaseServices] = useState<FirebaseServices | undefined>(undefined);
12+
let firebaseServices: FirebaseServices | undefined;
1413

15-
useEffect(() => {
16-
// Don't initialize Firebase if it has already been initialized
17-
if (firebaseServices === undefined) {
18-
setFirebaseServices(initFirebase());
19-
}
20-
}, []);
14+
export const FirebaseProvider: FC<{ children: ReactNode }> = ({ children }) => {
15+
if (firebaseServices === undefined) {
16+
firebaseServices = initFirebase();
17+
}
2118

2219
return (
23-
<AuthContext.Provider value={firebaseServices?.auth}>
24-
<StorageContext.Provider value={firebaseServices?.storage}>
25-
{children}
26-
</StorageContext.Provider>
20+
<AuthContext.Provider value={firebaseServices.auth}>
21+
<StorageContext.Provider value={firebaseServices.storage}>{children}</StorageContext.Provider>
2722
</AuthContext.Provider>
2823
);
2924
};

frontend/src/app/admin/layout.tsx

Lines changed: 11 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -15,11 +15,17 @@ export default function AdminLayout({ children }: { children: React.ReactNode })
1515

1616
return (
1717
<FirebaseProvider>
18-
<section>
19-
{!isLoginPage && <NavigationBar />}
20-
{!isLoginPage && <HeaderBarSpace />}
21-
{!isLoginPage ? <PrivatePage>{children}</PrivatePage> : children}
22-
</section>
18+
{!isLoginPage ? (
19+
<PrivatePage>
20+
<section>
21+
<NavigationBar />
22+
<HeaderBarSpace />
23+
{children}
24+
</section>
25+
</PrivatePage>
26+
) : (
27+
children
28+
)}
2329
</FirebaseProvider>
2430
);
2531
}

frontend/src/components/admin/PrivatePage.tsx

Lines changed: 3 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1,14 +1,13 @@
11
"use client";
22

33
import { getAuth } from "firebase/auth";
4-
import { useRouter } from "next/navigation";
4+
import { redirect } from "next/navigation";
55
import { FC, ReactNode } from "react";
66
import { useAuthState } from "react-firebase-hooks/auth";
77

88
import LoadingSpinner from "./LoadingSpinner";
99

1010
const PrivatePage: FC<{ children: ReactNode }> = ({ children }) => {
11-
const router = useRouter();
1211
const auth = getAuth();
1312

1413
const [user, loading, error] = useAuthState(auth);
@@ -21,7 +20,7 @@ const PrivatePage: FC<{ children: ReactNode }> = ({ children }) => {
2120
// firebase threw AuthError, non-critical
2221
if (error) {
2322
console.log(error);
24-
router.push("/admin");
23+
redirect("/admin");
2524
return <LoadingSpinner />;
2625
}
2726

@@ -31,7 +30,7 @@ const PrivatePage: FC<{ children: ReactNode }> = ({ children }) => {
3130
}
3231

3332
// otherwise go to login
34-
router.push("/admin");
33+
redirect("/admin");
3534
return <LoadingSpinner />;
3635
};
3736

0 commit comments

Comments
 (0)