aboutsummaryrefslogtreecommitdiff
path: root/src/lib/Tools/SequelCatcher/List.svelte
blob: 0bf087eae9e1eac73b62c7d92e2fcfb0a6600371 (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
<script lang="ts">
  import { filterRelations, type Media } from '$lib/Data/AniList/media';
  import MediaTitleDisplay from '$lib/List/MediaTitleDisplay.svelte';
  import { outboundLink } from '$lib/Media/links';
  import settings from '$stores/settings';

  export let mediaListUnchecked: Media[];

  let includeCurrent = false;
  let includeSideStories = false;

  const matchCheck = (media: Media | undefined, swap = false) =>
    (media &&
      media.mediaListEntry &&
      media.mediaListEntry?.status !== 'CURRENT' &&
      media.mediaListEntry?.status !== 'REPEATING' &&
      media.mediaListEntry?.status !== 'PAUSED') ||
    !media
      ? swap
        ? undefined
        : media
      : swap
        ? media
        : undefined;
</script>

<input type="checkbox" bind:checked={includeCurrent} /> Include current (watching, rewatching,
paused)
<br />
<input type="checkbox" bind:checked={includeSideStories} /> Include side stories (e.g., OVAs,
specials, etc.)

<p />

<ol class="media-list">
  {#each filterRelations( mediaListUnchecked.filter((media) => media.mediaListEntry?.status === 'COMPLETED'), includeSideStories ) as { media, unwatchedRelations }}
    {#if unwatchedRelations.filter( (relation) => matchCheck(mediaListUnchecked.find((media) => media.id === relation.node.id)) ).length !== 0 || includeCurrent}
      <li>
        <a href={outboundLink(media, 'anime', $settings.displayOutboundLinksTo)} target="_blank">
          <MediaTitleDisplay title={media.title} />
        </a>

        <span class="opaque">
          ({media.startDate.year})
        </span>

        <ol class="unwatched-relations-list">
          {#each unwatchedRelations as relation}
            {@const hit = matchCheck(
              mediaListUnchecked.find((media) => media.id === relation.node.id),
              true
            )}

            {#if matchCheck(mediaListUnchecked.find((media) => media.id === relation.node.id)) || includeCurrent}
              <li>
                <a
                  href={outboundLink(relation.node, 'anime', $settings.displayOutboundLinksTo)}
                  target="_blank"
                >
                  <MediaTitleDisplay title={relation.node.title} />
                </a>

                {#if hit && hit.mediaListEntry && hit.mediaListEntry.progress > 0}
                  <span class="opaque">|</span>

                  {hit.mediaListEntry.progress}/{#if hit.episodes}{hit.episodes}{:else}?{/if}
                {/if}

                <span class="opaque">
                  ({relation.node.startDate.year})
                </span>
              </li>
            {/if}
          {/each}
        </ol>
      </li>
    {/if}
  {/each}
</ol>

<style>
  .media-list li {
    margin-bottom: 1rem;
  }

  .unwatched-relations-list li:not(:last-child) {
    margin-bottom: 0 !important;
  }
</style>