From 3ba77d58cd99f9e0142eedb7229b0bf5e90dd295 Mon Sep 17 00:00:00 2001 From: Fuwn Date: Fri, 22 Dec 2023 20:53:50 -0800 Subject: fix(anime): call subsplease once --- src/lib/List/Anime/AnimeListTemplate.svelte | 55 +++++++++++----------- src/lib/List/Anime/CleanAnimeList.svelte | 72 +++++++++++++---------------- 2 files changed, 61 insertions(+), 66 deletions(-) diff --git a/src/lib/List/Anime/AnimeListTemplate.svelte b/src/lib/List/Anime/AnimeListTemplate.svelte index 9b02fa53..957376a1 100644 --- a/src/lib/List/Anime/AnimeListTemplate.svelte +++ b/src/lib/List/Anime/AnimeListTemplate.svelte @@ -28,31 +28,31 @@ let pendingUpdate: number | null = null; -{#await animeLists} - {#if previousAnimeList} - - {:else} - +{#await fetch(`/api/subsplease?tz=${Intl.DateTimeFormat().resolvedOptions().timeZone}`).then( (r) => r.json() )} + -
  • Loading ...
- {/if} -{:then media} - {#await fetch(`/api/subsplease?tz=${Intl.DateTimeFormat().resolvedOptions().timeZone}`).then( (r) => r.json() )} - +
  • Loading ...
+{:then subsPlease} + {#await animeLists} + {#if previousAnimeList} + + {:else} + -
  • Loading ...
- {:then subsPlease} +
  • Loading ...
+ {/if} + {:then media} + {:catch} + + + {/await} {:catch} - - - + {/await} diff --git a/src/lib/List/Anime/CleanAnimeList.svelte b/src/lib/List/Anime/CleanAnimeList.svelte index 64af9ddd..67d6797e 100644 --- a/src/lib/List/Anime/CleanAnimeList.svelte +++ b/src/lib/List/Anime/CleanAnimeList.svelte @@ -11,6 +11,7 @@ import MediaTitle from '../MediaTitleDisplay.svelte'; import { outboundLink } from '$lib/Media/links'; import { onDestroy } from 'svelte'; + import type { SubsPlease } from '$lib/Media/Anime/Airing/Subtitled/subsPlease'; export let media: Media[]; export let title: string; @@ -22,6 +23,7 @@ export let completed = false; export let previousAnimeList: Media[]; export let pendingUpdate: number | null; + export let subsPlease: SubsPlease | null = null; const keyCacher = setInterval( () => (media = media), @@ -75,52 +77,42 @@ {#if title !== 'Upcoming Episodes' || !$settings.displayCountdownRightAligned} | {/if} - {#await fetch(`/api/subsplease?tz=${Intl.DateTimeFormat().resolvedOptions().timeZone}`).then( (r) => r.json() )} - - ... - - {:then subsPlease} - {#if title !== 'Upcoming Episodes'} - - {pendingUpdate === anime.id ? progress + 1 : progress}{@html totalEpisodes(anime)} - { - if (pendingUpdate !== anime.id) { - lastUpdatedMedia = anime.id; - pendingUpdate = anime.id; + {#if title !== 'Upcoming Episodes'} + + {pendingUpdate === anime.id ? progress + 1 : progress}{@html totalEpisodes(anime)} + { + if (pendingUpdate !== anime.id) { + lastUpdatedMedia = anime.id; + pendingUpdate = anime.id; - updateMedia(anime.id, anime.mediaListEntry?.progress, () => { - const mediaListEntry = media.find((m) => m.id === anime.id)?.mediaListEntry; + updateMedia(anime.id, anime.mediaListEntry?.progress, () => { + const mediaListEntry = media.find((m) => m.id === anime.id)?.mediaListEntry; - if (mediaListEntry) mediaListEntry.progress = progress + 1; + if (mediaListEntry) mediaListEntry.progress = progress + 1; - previousAnimeList = media; - animeLists = cleanCache(user, identity); - pendingUpdate = null; - }); - } - }}>+ - {#if !completed} - [{anime.nextAiringEpisode?.episode === -1 - ? '?' - : (anime.nextAiringEpisode?.episode || 1) - 1}] - - {@html airingTime(anime, subsPlease)} - - {/if} - {:else} + previousAnimeList = media; + animeLists = cleanCache(user, identity); + pendingUpdate = null; + }); + } + }}>+ + {#if !completed} + [{anime.nextAiringEpisode?.episode === -1 + ? '?' + : (anime.nextAiringEpisode?.episode || 1) - 1}] - {@html airingTime(anime, subsPlease, true)} + {@html airingTime(anime, subsPlease)} {/if} - {/await} + {:else} + + {@html airingTime(anime, subsPlease, true)} + + {/if} {/if} -- cgit v1.2.3