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}
|