aboutsummaryrefslogtreecommitdiff
path: root/src/graphql/anime/resolvers.ts
diff options
context:
space:
mode:
Diffstat (limited to 'src/graphql/anime/resolvers.ts')
-rw-r--r--src/graphql/anime/resolvers.ts30
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 } };
},
},
};