blob: 688673b47bcef3eea673bd58b055d5349e72b1c4 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
<script lang="ts">
import "../app.pcss";
import {afterNavigate, beforeNavigate, goto} from "$app/navigation";
import {is_active} from "$lib/session";
import type {Navigation} from "@sveltejs/kit";
import {setLocale} from "$lib/i18n/i18n-svelte";
import {onMount} from "svelte";
import type {LayoutData} from "./$types";
export let data: LayoutData;
onMount(() => setLocale(data.locale));
async function redirect_if_necessary(ticket: Navigation) {
const sessionIsValid = await is_active();
const isPublicRoute = ticket.to?.routeId?.startsWith("(public)");
if (sessionIsValid && isPublicRoute) {
await goto("/home");
} else if (!sessionIsValid && !isPublicRoute) {
await goto("/login");
}
}
// This should probably be removed in favor of the logic in layout.server.ts.
// That requires a more sophisticated server side implementation of session handling,
// and i don't want that tbh, i want to stay as much in the browser as possible.
afterNavigate(redirect_if_necessary);
beforeNavigate(redirect_if_necessary);
</script>
<slot></slot>
|