Files
fnx_web/svelte/src/util/TabMenu.svelte

117 lines
2.5 KiB
Svelte
Raw Normal View History

2025-10-13 16:05:50 +02:00
<script lang="ts" module>
export type Tab = {
path: string,
title: string,
icon: string,
2025-10-13 16:05:50 +02:00
component?: Component,
hidden?: boolean,
hide_background?: boolean,
hide_frame?: boolean,
subpages?: Tab[],
2025-10-09 15:48:23 +02:00
};
</script>
<script lang="ts">
2025-10-13 16:05:50 +02:00
import { onMount, type Component } from "svelte";
2025-10-09 15:48:23 +02:00
import { current_page_store } from "wrap/RouterStore";
2022-10-18 14:30:50 +02:00
2025-10-13 16:05:50 +02:00
let { title = $bindable(""), pages = $bindable([]) }: {
title?: string;
pages?: Tab[];
} = $props();
2022-10-18 14:30:50 +02:00
const get_page = () => {
2022-10-18 14:30:50 +02:00
current_page = null
current_subpage = null
for (const page of pages) {
2022-10-18 14:30:50 +02:00
if (window.location.pathname.endsWith(page.path)) {
current_page = page
}
if (page.subpages) {
page.subpages.forEach(subpage => {
if (window.location.pathname.endsWith(subpage.path)) {
current_page = page
current_subpage = subpage
}
})
}
}
2022-10-18 14:30:50 +02:00
// If no page is active, default to home
if (!current_page) {
current_page = pages[0]
}
// If no subpage is active, default to the first subpage, if there are any
2022-10-18 14:30:50 +02:00
if (!current_subpage && current_page.subpages) {
current_subpage = current_page.subpages[0]
}
title = current_subpage === null ? current_page.title : current_subpage.title
2025-10-09 15:48:23 +02:00
window.document.title = title+" / FNX"
2022-10-18 14:30:50 +02:00
}
2025-10-13 16:05:50 +02:00
let current_page: Tab = $state(null)
let current_subpage: Tab = $state(null)
2022-10-18 14:30:50 +02:00
2025-10-09 15:48:23 +02:00
onMount(() => {
get_page()
return current_page_store.subscribe(get_page)
})
2022-10-18 14:30:50 +02:00
</script>
{#if current_page !== null && current_page.hide_frame !== true}
<header>
<div class="tab_bar">
{#each pages as page}
{#if !page.hidden}
<a class="button"
href="{page.path}"
class:button_highlight={current_page && page.path === current_page.path}
2025-10-09 15:48:23 +02:00
>
<i class="icon">{page.icon}</i>
<span>{page.title}</span>
</a>
{/if}
{/each}
</div>
</header>
{/if}
2022-10-18 14:30:50 +02:00
{#if current_page !== null}
<div id="page_content" class:page_content={current_page.hide_background !== true}>
2022-10-18 14:30:50 +02:00
{#if current_page.subpages}
<div class="tab_bar submenu">
{#each current_page.subpages as page}
{#if !page.hidden}
<a class="button"
href="{page.path}"
class:button_highlight={current_subpage && page.path === current_subpage.path}
2025-10-09 15:48:23 +02:00
>
2023-11-16 12:17:36 +01:00
<i class="icon">{page.icon}</i>
<span>{page.title}</span>
2022-10-18 14:30:50 +02:00
</a>
{/if}
{/each}
</div>
{#if current_subpage}
2025-10-13 16:05:50 +02:00
<current_subpage.component />
2022-10-18 14:30:50 +02:00
{/if}
{:else}
2025-10-13 16:05:50 +02:00
<current_page.component />
2022-10-18 14:30:50 +02:00
{/if}
</div>
{/if}
2022-10-18 14:30:50 +02:00
<style>
2023-11-16 12:17:36 +01:00
.submenu {
2025-10-09 15:48:23 +02:00
border-bottom: 1px solid var(--separator);
2022-10-18 14:30:50 +02:00
}
2023-11-16 12:17:36 +01:00
.tab_bar > .button {
flex-direction: column;
gap: 0;
}
2022-10-18 14:30:50 +02:00
</style>