2024-06-26 20:33:01 +02:00
|
|
|
<script lang="ts">
|
2024-04-08 17:12:39 +02:00
|
|
|
import '../app.pcss';
|
2024-07-25 23:32:59 +02:00
|
|
|
import { ModeWatcher } from 'mode-watcher';
|
|
|
|
import { isLoading, locale, _ } from 'svelte-i18n';
|
|
|
|
import { page } from '$app/stores';
|
|
|
|
import Head from '$lib/components/Head.svelte';
|
|
|
|
import Nav from '$lib/components/Nav.svelte';
|
|
|
|
import Footer from '$lib/components/Footer.svelte';
|
2024-07-26 00:03:29 +02:00
|
|
|
import { languages } from '$lib/languages';
|
|
|
|
import { browser } from '$app/environment';
|
|
|
|
import { goto } from '$app/navigation';
|
2024-07-25 23:32:59 +02:00
|
|
|
|
|
|
|
$: if ($page.params.language === '' && $locale !== 'en') {
|
|
|
|
locale.set('en');
|
2024-07-26 00:03:29 +02:00
|
|
|
} else if ($page.params.language) {
|
|
|
|
let lang = $page.params.language.replace('/', '');
|
|
|
|
if ($locale !== lang) {
|
|
|
|
if (languages.hasOwnProperty(lang)) {
|
|
|
|
locale.set(lang);
|
|
|
|
} else if (browser) {
|
|
|
|
goto('/404');
|
|
|
|
}
|
|
|
|
}
|
2024-07-25 23:32:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
const appRoutes = ['/[...language]/app', '/[...language]/embed'];
|
|
|
|
|
|
|
|
$: showNavAndFooter = $page.route.id === null || !appRoutes.includes($page.route.id);
|
2024-04-05 17:53:42 +02:00
|
|
|
</script>
|
|
|
|
|
2024-07-25 23:32:59 +02:00
|
|
|
<Head />
|
|
|
|
<ModeWatcher />
|
|
|
|
|
|
|
|
<div class="flex flex-col min-h-screen">
|
|
|
|
{#if !$isLoading}
|
|
|
|
{#if showNavAndFooter}
|
|
|
|
<Nav />
|
|
|
|
{/if}
|
|
|
|
<main class="grow flex flex-col">
|
|
|
|
<slot />
|
|
|
|
</main>
|
|
|
|
{#if showNavAndFooter}
|
|
|
|
<Footer />
|
|
|
|
{/if}
|
|
|
|
{/if}
|
|
|
|
</div>
|