aboutsummaryrefslogtreecommitdiff
path: root/src/routes/tools/+page.svelte
blob: dc850ec434ef9f59a8e5e2fc9ebbd94eb3e72cb5 (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
<script lang="ts">
	import ActivityHistory from '$lib/Tools/ActivityHistory/Tool.svelte';
	import Wrapped from '$lib/Tools/Wrapped.svelte';
	import { browser } from '$app/environment';
	import EpisodeDiscussionCollector from '$lib/Tools/EpisodeDiscussionCollector.svelte';
	import CharacterBirthdays from '$lib/Tools/Birthdays.svelte';
	import { page } from '$app/stores';
	import SequelSpy from '$lib/Tools/SequelSpy.svelte';
	import { closest } from '$lib/Error/path';
	import HeadTitle from '$lib/HeadTitle.svelte';

	export let data;

	let tool =
		browser && $page.url.searchParams.size !== 0
			? $page.url.searchParams.get('tool') || 'default'
			: 'default';
	const tools: { [key: string]: string } = {
		default: 'Tools',
		birthdays: "Today's Character Birthdays",
		activity_history: 'Activity History',
		wrapped: 'Wrapped',
		episode_discussion_collector: 'Episode Discussion Collector (Beta)',
		sequel_spy: 'Sequel Spy'
	};

	$: {
		if (browser) {
			$page.url.searchParams.set('tool', tool);
			history.replaceState(null, '', `?${$page.url.searchParams.toString()}`);
		}
	}
	$: suggestion = closest(browser ? tool : '...', Object.keys(tools));
</script>

<blockquote>
	<select bind:value={tool}>
		<option value="default" selected disabled hidden>Tool</option>
		<option value="birthdays">Today's Character Birthdays</option>
		<option value="activity_history">Activity History</option>
		<option value="wrapped">Wrapped</option>
		<option value="episode_discussion_collector">Episode Discussion Collector (Beta)</option>
		<option value="sequel_spy">Sequel Spy</option>
	</select>
</blockquote>

{#if !Object.keys(tools).includes(tool)}
	<HeadTitle route="Tools" path="/tools" />

	<p>Tool not found.</p>

	<blockquote>
		Did you mean "<a
			href={`?tool=${suggestion}`}
			style={suggestion === '...' ? 'pointer-events: none; color: inherit;' : ''}
		>
			{suggestion === '...' ? '...' : tools[suggestion]}</a
		>"?
	</blockquote>
{:else}
	<HeadTitle route={tools[tool]} path={`/tools?tool=${tool}`} />

	{#if tool === 'default'}
		Select a tool to continue.
	{:else if tool === 'activity_history'}
		<ActivityHistory user={data.user} />
	{:else if tool === 'wrapped'}
		<Wrapped user={data.user} />
	{:else if tool === 'episode_discussion_collector'}
		<EpisodeDiscussionCollector />
	{:else if tool === 'birthdays'}
		<CharacterBirthdays />
	{:else if tool === 'sequel_spy'}
		<SequelSpy user={data.user} />
	{/if}
{/if}