From b018bd62213b1a72114ecf47c6676204e33bd429 Mon Sep 17 00:00:00 2001 From: Fuwn Date: Sat, 16 Dec 2023 18:50:51 -0800 Subject: feat(anime): subtitle countdown --- src/lib/List/Anime/CleanAnimeList.svelte | 67 +++++++++++++++++--------------- 1 file changed, 36 insertions(+), 31 deletions(-) (limited to 'src/lib/List/Anime/CleanAnimeList.svelte') diff --git a/src/lib/List/Anime/CleanAnimeList.svelte b/src/lib/List/Anime/CleanAnimeList.svelte index 0b130d15..fd31963c 100644 --- a/src/lib/List/Anime/CleanAnimeList.svelte +++ b/src/lib/List/Anime/CleanAnimeList.svelte @@ -8,7 +8,8 @@ import ListTitle from '../ListTitle.svelte'; import MediaTitle from '../MediaTitleDisplay.svelte'; import { outboundLink } from '$lib/Media/media'; - import { onDestroy } from 'svelte'; + import { onDestroy, onMount } from 'svelte'; + import type { SubsPlease } from '$lib/subsPlease'; export let media: Media[]; export let title: string; @@ -73,42 +74,46 @@ {#if title !== 'Upcoming Episodes' || !$settings.displayCountdownRightAligned} | {/if} - {#if title !== 'Upcoming Episodes'} - - {pendingUpdate === anime.id ? progress + 1 : progress}{@html totalEpisodes(anime)} - { - if (pendingUpdate !== anime.id) { - lastUpdatedMedia = anime.id; - pendingUpdate = anime.id; + {#await fetch(`/api/subsplease?tz=${Intl.DateTimeFormat().resolvedOptions().timeZone}`).then( (r) => r.json() )} + Loading ... + {: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; - 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}] + 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} - {@html airingTime(anime)} + {@html airingTime(anime, subsPlease, true)} {/if} - {:else} - - {@html airingTime(anime, true)} - - {/if} + {/await} {/if} -- cgit v1.2.3