50 lines
1.1 KiB
Svelte
50 lines
1.1 KiB
Svelte
<script lang="ts">
|
|
import { page } from '$app/stores';
|
|
import { routes } from "$lib/sitemap.ts"
|
|
import { name } from '$content/metadata.json';
|
|
import ThemeSwitch from "$lib/components/ThemeSwitch.svelte"
|
|
import { Rss } from "lucide-svelte";
|
|
|
|
function isCurrentLink(pathname, route) {
|
|
return route != "/" && pathname.startsWith(route)
|
|
|| route == "/post" && pathname.startsWith("/page");
|
|
}
|
|
</script>
|
|
|
|
<div id="navbar" class="h-5 space-x-4">
|
|
<p id="bio-name">{name}</p>
|
|
{#each routes as item}
|
|
<a
|
|
class="nav-link"
|
|
class:disabled-link={item.disabled}
|
|
class:current-link={isCurrentLink($page.url.pathname, item.route)}
|
|
href={item.route}>{item.name}</a>
|
|
{/each}
|
|
<a class="nav-link icon" href="/rss.xml"><Rss /></a>
|
|
<div><ThemeSwitch /></div>
|
|
</div>
|
|
|
|
<style>
|
|
#bio-name {
|
|
font-family: serif;
|
|
font-size: 3rem;
|
|
font-weight: normal;
|
|
color: var(--name);
|
|
}
|
|
#navbar {
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: flex-end;
|
|
justify-content: between;
|
|
}
|
|
@media (max-width: 700px) {
|
|
#navbar {
|
|
display: inline-block;
|
|
white-space: pre-wrap;
|
|
}
|
|
#navbar .nav-link {
|
|
display: inline-block;
|
|
}
|
|
}
|
|
</style>
|