diff options
Diffstat (limited to 'src/graphql/anime/resolvers.ts')
| -rw-r--r-- | src/graphql/anime/resolvers.ts | 30 |
1 files changed, 11 insertions, 19 deletions
diff --git a/src/graphql/anime/resolvers.ts b/src/graphql/anime/resolvers.ts index 577950f7..8d87eb6c 100644 --- a/src/graphql/anime/resolvers.ts +++ b/src/graphql/anime/resolvers.ts @@ -1,31 +1,23 @@ +import { env } from "$env/dynamic/private"; +import { fetchTimetables } from "$lib/Media/Anime/Airing/animeSchedule"; import type { Resolvers as RootResolvers, WithIndex } from "../$types"; type AnimeResolvers = Pick< RootResolvers, - "Query" | "Anime" | "Subtitles" | "SubtitleSchedule" | "Subtitle" + "Query" | "Anime" | "Airing" | "AiringRelease" | "Stream" >; export const resolvers: WithIndex<AnimeResolvers> = { Query: { - Anime: async (_, args) => { - const timezone = args.timezone || "Asia/Tokyo"; + Anime: async () => { + const token = env.ANIMESCHEDULE_CLIENT_TOKEN; + const generatedAt = Math.floor(Date.now() / 1000); - return { - subtitles: { - timezone, - schedule: Object.fromEntries( - Object.entries( - ( - await ( - await fetch( - `https://subsplease.org/api/?f=schedule&tz=${timezone}`, - ) - ).json() - ).schedule, - ).map(([key, value]) => [key.toLowerCase(), value]), - ), - }, - }; + if (!token) return { airing: { generatedAt, sub: [], dub: [] } }; + + const { sub, dub } = await fetchTimetables(token); + + return { airing: { generatedAt, sub, dub } }; }, }, }; |