aboutsummaryrefslogtreecommitdiff
path: root/src/lib/anime.ts
diff options
context:
space:
mode:
authorFuwn <[email protected]>2023-09-10 02:01:23 -0700
committerFuwn <[email protected]>2023-09-10 02:01:23 -0700
commite5bb4dd56192cf74b018ba8259e90df4a6d9e41d (patch)
tree2c6edbecf07c6651449a269e0f45bed44138c5b1 /src/lib/anime.ts
parentfeat(settings): add feedback message (diff)
downloaddue.moe-e5bb4dd56192cf74b018ba8259e90df4a6d9e41d.tar.xz
due.moe-e5bb4dd56192cf74b018ba8259e90df4a6d9e41d.zip
refactor(anime): generalise airing time
Diffstat (limited to 'src/lib/anime.ts')
-rw-r--r--src/lib/anime.ts48
1 files changed, 48 insertions, 0 deletions
diff --git a/src/lib/anime.ts b/src/lib/anime.ts
new file mode 100644
index 00000000..5431a230
--- /dev/null
+++ b/src/lib/anime.ts
@@ -0,0 +1,48 @@
+import type { Media } from './AniList/media';
+
+const totalEpisodes = (anime: Media) => {
+ return anime.episodes === null ? '' : `<span style="opacity: 50%">/${anime.episodes}</span>`;
+};
+
+export const airingTime = (anime: Media, upcoming = false) => {
+ const untilAiring = anime.nextAiringEpisode?.timeUntilAiring;
+ let timeFrame;
+
+ if (untilAiring !== undefined) {
+ let minutes = untilAiring / 60;
+
+ if (minutes >= 30) {
+ let hours = minutes / 60;
+
+ if (hours >= 24) {
+ let weeks = Math.floor(Math.floor(hours / 24) / 7);
+
+ if (weeks >= 1) {
+ weeks = Math.round(weeks);
+
+ timeFrame = `${weeks} week${weeks === 1 ? '' : 's'}`;
+ } else {
+ const days = Math.round(Math.floor(hours / 24));
+
+ timeFrame = `${days} day${days === 1 ? '' : 's'}`;
+ }
+ } else {
+ hours = Math.round(hours);
+
+ timeFrame = `${hours} hour${hours === 1 ? '' : 's'}`;
+ }
+ } else {
+ minutes = Math.round(minutes);
+
+ timeFrame = `${minutes} minute${minutes === 1 ? '' : 's'}`;
+ }
+
+ if (upcoming) {
+ return `${anime.nextAiringEpisode?.episode}${totalEpisodes(anime)} in ${timeFrame}`;
+ } else {
+ return `<span style="opacity: 50%">${anime.nextAiringEpisode?.episode} in ${timeFrame}</span>`;
+ }
+ }
+
+ return '';
+};