blob: bd481d9a59e78081f07a75465a256929eb8796a6 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
|
import type { AniListAuthorisation } from '$lib/AniList/identity';
import type { UserIdentity } from './identity';
export enum Type {
Anime,
Manga
}
export interface Media {
id: number;
status: string;
type: string;
episodes: number;
format: string;
title: {
romaji: string;
english: string;
native: string;
};
nextAiringEpisode?: {
episode: number;
timeUntilAiring?: number;
};
mediaListEntry?: {
progress: number;
};
startDate: {
year: number;
};
}
export const flattenLists = (lists: object[][]) => {
if (lists === undefined) {
return [];
}
let flattenedList: any[] = [];
const minimisedList: Media[] = [];
for (const list of lists) {
flattenedList = flattenedList.concat(list['entries']);
}
for (const [position, entry] of flattenedList.entries()) {
minimisedList[position] = entry['media'];
}
return minimisedList;
};
export const mediaListCollection = async (
anilistAuthorisation: AniListAuthorisation,
userIdentity: UserIdentity,
type: Type
) => {
const userIdResponse = await (
await fetch('https://graphql.anilist.co', {
method: 'POST',
headers: {
Authorization: `${anilistAuthorisation.tokenType} ${anilistAuthorisation.accessToken}`,
'Content-Type': 'application/json',
Accept: 'application/json'
},
body: JSON.stringify({
query: `{ MediaListCollection(userId: ${userIdentity.id}, type: ${
type === Type.Anime ? 'ANIME' : 'MANGA'
}, status_not_in: [ COMPLETED ]) {
lists { entries { media {
id
status
type
episodes
format
title { romaji english native }
nextAiringEpisode { episode timeUntilAiring }
mediaListEntry { progress }
startDate { year }
} } }
}
}`
})
})
).json();
return userIdResponse['data']['MediaListCollection']['lists'];
};
|