aboutsummaryrefslogtreecommitdiff
path: root/src/routes/+page.svelte
blob: 3a00a98ba4b69fe37388430b0f151df5464e82da (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
119
120
121
122
123
<script lang="ts">
	import { onDestroy, onMount } from 'svelte';
	import MangaListTemplate from '$lib/List/Manga/MangaListTemplate.svelte';
	import UpcomingAnimeList from '$lib/List/Anime/UpcomingAnimeList.svelte';
	import userIdentity from '$stores/identity.js';
	import settings from '$stores/settings';
	import ListTitle from '$lib/List/ListTitle.svelte';
	import HeadTitle from '$lib/Home/HeadTitle.svelte';
	import LastActivity from '$lib/Home/LastActivity.svelte';
	import { createHeightObserver } from '$lib/Utility/html.js';
	import Skeleton from '$lib/Loading/Skeleton.svelte';
	import locale from '$stores/locale.js';
	import Landing from '$lib/Landing.svelte';
	import IndexColumn from '$lib/List/Anime/DueIndexColumn.svelte';

	export let data;

	let heightObserver: NodeJS.Timeout;

	onMount(() => (heightObserver = setInterval(() => createHeightObserver(), 0)));

	onDestroy(() => clearInterval(heightObserver));
</script>

<HeadTitle />

<LastActivity user={data.user} />

{#if data.user === undefined}
	<div class="card">Please log in to view due media.</div>

	<p />

	<Landing />
{:else}
	<div
		class="grid-container"
		style={`
			grid-template-columns: ${
				[!$settings.disableUpcomingAnime, !$settings.disableAnime, !$settings.disableManga]
					.map(Number)
					.reduce((a, b) => a + b) > 1
					? '1fr 1fr'
					: '1fr'
			}
		`}
	>
		<div class="left-column">
			{#if !$settings.disableUpcomingAnime}
				<details open={!$settings.displayUpcomingAnimeCollapsed} class="list list-upcoming">
					{#if $userIdentity.id !== -2}
						<UpcomingAnimeList user={data.user} />
					{:else}
						<ListTitle title={$locale().lists.upcoming.episodes} />

						<Skeleton card={false} count={5} height="0.9rem" list />
					{/if}
				</details>
			{/if}

			{#if !$settings.disableAnime && !$settings.disableManga}
				<IndexColumn user={data.user} userIdentity={$userIdentity} />
			{/if}
		</div>

		<div class="right-column">
			{#if !$settings.disableAnime && $settings.disableManga}
				<IndexColumn user={data.user} userIdentity={$userIdentity} />
			{/if}

			{#if !$settings.disableManga}
				<details open={!$settings.displayMangaCollapsed} class="list list-manga">
					{#if $userIdentity.id !== -2}
						<MangaListTemplate
							user={data.user}
							displayUnresolved={$settings.displayUnresolved}
							due={true}
						/>
					{:else}
						<ListTitle title={$locale().lists.due.mangaAndLightNovels} />

						<Skeleton card={false} count={5} height="0.9rem" list />
					{/if}
				</details>
			{/if}
		</div>

		{#if $settings.disableUpcomingAnime && $settings.disableAnime && $settings.disableManga}
			<video src="https://video.twimg.com/tweet_video/Do_eDPnX0AAKV9f.mp4" autoplay loop>
				<track kind="captions" />
			</video>
		{/if}
	</div>
{/if}

<style>
	.grid-container {
		display: grid;
		gap: 1rem;
	}

	.left-column {
		display: grid;
		gap: 1rem;
		align-content: start;
	}

	.right-column {
		align-self: start;
	}

	.list {
		overflow-y: auto;
		break-inside: avoid;
		page-break-inside: avoid;
	}

	@media (max-width: 800px) {
		.grid-container {
			grid-template-columns: 1fr;
		}
	}
</style>