2024-02-01 15:26:17 +00:00
|
|
|
import Navbar from "./shared/Navbar.tsx";
|
|
|
|
import { readProfiles, useUserinfo } from "../stores/userinfo.tsx";
|
|
|
|
import { createEffect, createSignal, Show } from "solid-js";
|
|
|
|
import { readWellKnown } from "../stores/wellKnown.tsx";
|
|
|
|
import { BeforeLeaveEventArgs, useBeforeLeave, useLocation, useNavigate } from "@solidjs/router";
|
|
|
|
|
|
|
|
export default function RootLayout(props: any) {
|
|
|
|
const [ready, setReady] = createSignal(false);
|
|
|
|
|
|
|
|
Promise.all([readWellKnown(), readProfiles()]).then(() => setReady(true));
|
|
|
|
|
|
|
|
const navigate = useNavigate();
|
|
|
|
const userinfo = useUserinfo();
|
|
|
|
|
|
|
|
const location = useLocation();
|
|
|
|
|
|
|
|
createEffect(() => {
|
|
|
|
if (ready()) {
|
|
|
|
keepGate(location.pathname);
|
|
|
|
}
|
|
|
|
}, [ready, userinfo]);
|
|
|
|
|
|
|
|
function keepGate(path: string, e?: BeforeLeaveEventArgs) {
|
2024-02-01 16:53:22 +00:00
|
|
|
const whitelist = ["/auth", "/auth/callback"];
|
2024-02-01 15:26:17 +00:00
|
|
|
|
|
|
|
if (!userinfo?.isLoggedIn && !whitelist.includes(path)) {
|
|
|
|
if (!e?.defaultPrevented) e?.preventDefault();
|
|
|
|
navigate(`/auth/login?redirect_uri=${path}`);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
useBeforeLeave((e: BeforeLeaveEventArgs) => keepGate(e.to.toString().split("?")[0], e));
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Show when={ready()} fallback={
|
|
|
|
<div class="h-screen w-screen flex justify-center items-center">
|
|
|
|
<div>
|
|
|
|
<span class="loading loading-lg loading-infinity"></span>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
}>
|
|
|
|
<Navbar />
|
|
|
|
<main class="h-[calc(100vh-68px)] mt-[68px]">{props.children}</main>
|
|
|
|
</Show>
|
|
|
|
);
|
|
|
|
}
|