website/src/routes/+layout.svelte

166 lines
5.1 KiB
Svelte
Raw Normal View History

2024-08-08 04:46:38 +03:00
<script lang="ts">
2024-09-19 16:52:29 +03:00
import { PUBLIC_BASE_URL } from '$env/static/public';
import getTitle from '$lib/getTitle';
2024-08-15 00:43:18 +03:00
import NavButton from '../components/navButton.svelte';
import '../styles/app.css';
export let data;
interface MenuItem {
href: string;
name: string;
iconUri: string;
}
let menuItems: MenuItem[] = [
{ href: '', name: 'home', iconUri: '/icons/home.png' },
{ href: 'entries', name: 'entries', iconUri: '/icons/entries.png' },
2024-08-22 23:54:03 +03:00
{ href: 'guestbook', name: 'guestbook', iconUri: '/icons/guestbook.png' },
{ href: 'about', name: 'about', iconUri: '/icons/about.png' }
2024-08-15 00:43:18 +03:00
];
const routeComponents = data.route.split('/');
2024-08-15 14:43:07 +03:00
const doAddPostItem = routeComponents.length > 3 && routeComponents[1] === 'entries';
2024-08-15 00:43:18 +03:00
const isRoute = (_route: string) => {
if (doAddPostItem) {
if (_route === 'entries') {
return false;
} else if (_route.startsWith('entries/')) {
return true;
}
}
2024-08-15 14:43:07 +03:00
return _route === routeComponents[1];
2024-08-15 00:43:18 +03:00
};
if (doAddPostItem) {
menuItems.splice(2, 0, {
href: data.route.slice(1),
2024-08-15 14:43:07 +03:00
name: routeComponents[2],
2024-08-15 14:36:48 +03:00
iconUri: '/icons/entry.png'
2024-08-15 00:43:18 +03:00
});
}
const title = getTitle(data.route);
2024-08-24 22:52:04 +03:00
const svgSquiggles = [[2], [3], [2], [3], [1]];
</script>
2024-08-15 00:43:18 +03:00
<svelte:head>
<title>{title}</title>
2024-08-15 00:43:18 +03:00
<meta property="og:title" content={title} />
<meta property="og:site_name" content="gaze.systems" />
<meta property="og:url" content="https://gaze.systems/" />
2024-08-15 00:43:18 +03:00
<meta property="og:image" content="https://gaze.systems/icons/gaze_website.png" />
</svelte:head>
<div
class="
app-grid-background motion-safe:app-grid-background-anim
fixed -z-10 w-full h-full top-0 left-0
"
/>
<div
class="
app-grid-background-second-layer motion-safe:app-grid-background-second-layer-anim
fixed -z-20 w-full h-full top-0 left-0
"
/>
<svg
xmlns="http://www.w3.org/2000/svg"
version="1.1"
class="absolute -z-50"
image-rendering="optimizeSpeed"
>
<defs>
2024-08-24 22:52:04 +03:00
{#each svgSquiggles as [scale], index}
<filter id="squiggly-{index}">
<feTurbulence
id="turbulence"
baseFrequency="0.02"
numOctaves="3"
result="noise"
seed={index}
/>
<feDisplacementMap in="SourceGraphic" in2="noise" {scale} />
</filter>
2024-08-24 22:52:04 +03:00
{/each}
<filter id="pixelate" color-interpolation-filters="linearRGB" x="0" y="0">
<feFlood x="4" y="4" height="2" width="2" />
<feComposite width="10" height="10" />
<feTile result="a" />
<feComposite in="SourceGraphic" in2="a" operator="in" />
<feMorphology operator="dilate" radius="5" />
</filter>
<filter id="dither" color-interpolation-filters="sRGB" x="0" y="0" width="100%" height="100%">
<feImage
width="4"
height="4"
xlink:href=""
/>
<feTile />
<feComposite operator="arithmetic" k1="0" k2="1" k3="1" k4="-0.5" in="SourceGraphic" />
<feComponentTransfer>
<feFuncR type="discrete" tableValues="0 1" />
<feFuncG type="discrete" tableValues="0 1" />
<feFuncB type="discrete" tableValues="0 1" />
</feComponentTransfer>
</filter>
<filter
id="dither-red"
color-interpolation-filters="sRGB"
x="0"
y="0"
width="100%"
height="100%"
>
<feFlood flood-color="#000000" flood-opacity="0.50" x="0%" y="0%" result="flood" />
<feBlend mode="normal" x="0%" y="0%" in="SourceGraphic" in2="flood" result="blend1" />
<feImage
class="ditherImage"
xlink:href=""
x="0"
y="0"
width="4"
height="4"
crossOrigin="anonymous"
result="image1"
/>
<feTile x="0" y="0" in="image1" result="tile" />
<feBlend mode="overlay" x="0%" y="0%" in="blend1" in2="tile" result="blend2" />
<feColorMatrix type="saturate" values="0" />
<feComponentTransfer>
<feFuncR type="discrete" tableValues="0 0" />
<feFuncG type="discrete" tableValues="0 1" />
<feFuncB type="discrete" tableValues="0 1" />
</feComponentTransfer>
</filter>
</defs>
</svg>
<div class="md:h-[96vh] pb-[7vh] lg:px-[4vw] 2xl:px-[8vw] lg:py-[4vh]">
<slot />
</div>
2024-08-24 22:52:04 +03:00
<nav class="w-full min-h-[5vh] max-h-[6vh] fixed bottom-0 z-10 bg-ralsei-black">
2024-08-15 00:43:18 +03:00
<div
class="
max-w-full max-h-fit p-1
border-ralsei-white border-8
bg-gradient-to-r to-ralsei-pink-neon/30 from-ralsei-pink-regular/20 from-30%
"
2024-08-15 00:43:18 +03:00
style="border-style: ridge hidden hidden hidden;"
>
2024-09-19 16:52:29 +03:00
<div class="flex flex-row flex-nowrap gap-2 justify-start overflow-x-auto">
{#each menuItems as item}
{@const highlight = isRoute(item.href)}
<NavButton {highlight} {...item} />
{/each}
2024-09-19 16:52:29 +03:00
<div class="hidden md:block grow"/>
<a class="align-middle" href="/entries/_rss">
<img class="min-w-fit" src="/valid-rss.png" alt="rss feed"/>
</a>
</div>
2024-08-15 00:43:18 +03:00
</div>
</nav>