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) { const whitelist = ["/auth/login", "/auth/register", "/users/me/confirm"]; 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 (
}>
{props.children}
); }