aboutsummaryrefslogtreecommitdiff
path: root/src/routes/+layout.svelte
blob: 856c6569758c283da5e6217a900ab12bbeb37bf3 (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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
<script>
	import { env } from '$env/dynamic/public';
	import { userIdentity as getUserIdentity } from '$lib/AniList/identity';
	import { onMount } from 'svelte';
	import userIdentity from '../stores/userIdentity';
	import settings from '../stores/settings';

	export let data;

	let currentUserIdentity = { name: '...', id: -1 };

	onMount(async () => {
		settings.get();

		if (data.user !== undefined) {
			if ($userIdentity === '') {
				userIdentity.set(JSON.stringify(await getUserIdentity(data.user)));
			}

			currentUserIdentity = JSON.parse($userIdentity);
			currentUserIdentity.name = currentUserIdentity.name;

			// document.getElementsByTagName('html')[0].classList.add('limit-height');
			// document.getElementsByTagName('body')[0].classList.add('limit-height');
		}
	});
</script>

<div id="container">
	<div id="header">
		<p id={$settings.displayHoverNavigation ? 'hover-header' : ''}>
			「 <a href="/">Home</a> • <a href="/completed">Completed</a> •
			<a href="/schedule">Anime Schedule</a> •
			<a href="/updates">Manga & WN Updates</a> •
			<a href="/tools">Tools</a> • {#if data.user}
				<a href={`/user/${currentUserIdentity.name}`}>Profile</a> •
			{/if} <a href="/settings">Settings</a> 」

			{#if data.user === undefined}
				<a
					href={`https://anilist.co/api/v2/oauth/authorize?client_id=${env.PUBLIC_ANILIST_CLIENT_ID}&redirect_uri=${env.PUBLIC_ANILIST_REDIRECT_URI}&response_type=code`}
				>
					Log in with AniList
				</a>
			{:else}
				<a href="/api/authentication/log-out">Log out ({currentUserIdentity.name})</a>
			{/if}
		</p>

		{#if !$settings.displayHoverNavigation}
			<hr />
		{:else}
			<hr id="separator" />
		{/if}
	</div>

	<slot />
</div>

<style>
	/* Kosugi, M PLUS 1 Code */
	@import url('https://fonts.googleapis.com/css2?family=Kosugi:wght@300;400;500;700;800&display=swap');

	:global(body) {
		font-family: 'Kosugi', monospace;
	}

	:global(html.light-theme) {
		filter: invert(0);
	}

	:global(html.light-theme img) {
		filter: invert(0);
	}

	:global(.limit-height) {
		height: 100%;
	}

	#container {
		height: 100%;
		display: flex;
		flex-direction: column;
	}

	#hover-header {
		position: fixed;
		top: 0;
		left: 0;
		padding: 0.5% 0.25% 0.25% 0;
		z-index: 1000;
		transition: 0.25s;
		opacity: 0;
		background-color: var(--base00);
		width: 100%;
	}

	#separator {
		display: none;
	}

	@media (max-width: 640px) {
		#hover-header {
			opacity: 1;
			position: unset;
			padding: 0;
			/* font-size: 5vw; */
		}

		#separator {
			display: block;
		}
	}

	#hover-header:hover {
		opacity: 1;
	}
</style>