@irfanshadikrishad/anilist 1.3.2-forbidden.1 → 1.3.3-forbidden.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -171,9 +171,9 @@ interface Myself {
171
171
  }[];
172
172
  }
173
173
  interface DateMonthYear {
174
- day?: string;
175
- month?: string;
176
- year?: string;
174
+ day?: number;
175
+ month?: number;
176
+ year?: number;
177
177
  }
178
178
  interface AnimeDetails {
179
179
  data?: {
@@ -237,4 +237,123 @@ interface TheActivity {
237
237
  progress?: string | null;
238
238
  status?: string;
239
239
  }
240
- export { AniListMediaStatus, AnimeDetails, AnimeList, DateMonthYear, DeleteMangaResponse, List, MALAnimeStatus, MALAnimeXML, MALMangaStatus, MalIdToAnilistIdResponse, MediaEntry, MediaList, MediaListEntry, MediaTitle, MediaWithProgress, Myself, TheActivity, saveAnimeWithProgressResponse, };
240
+ type UserActivitiesResponse = {
241
+ data?: {
242
+ Page: {
243
+ activities: {
244
+ status: string;
245
+ progress: number;
246
+ createdAt: number;
247
+ media: {
248
+ title: MediaTitle;
249
+ };
250
+ }[];
251
+ };
252
+ };
253
+ errors?: {
254
+ message: string;
255
+ }[];
256
+ };
257
+ type UserResponse = {
258
+ data?: {
259
+ User: {
260
+ id: number;
261
+ name: string;
262
+ siteUrl: string;
263
+ donatorTier: string;
264
+ donatorBadge: string;
265
+ createdAt: number;
266
+ updatedAt: number;
267
+ isBlocked: boolean;
268
+ isFollower: boolean;
269
+ isFollowing: boolean;
270
+ options: {
271
+ profileColor: string;
272
+ timezone: string;
273
+ };
274
+ statistics: {
275
+ anime: {
276
+ count: number;
277
+ episodesWatched: number;
278
+ minutesWatched: number;
279
+ };
280
+ manga: {
281
+ count: number;
282
+ chaptersRead: number;
283
+ volumesRead: number;
284
+ };
285
+ };
286
+ };
287
+ };
288
+ errors?: {
289
+ message: string;
290
+ }[];
291
+ };
292
+ type UserFollower = {
293
+ data?: {
294
+ Page: {
295
+ pageInfo: {
296
+ total: number;
297
+ perPage: number;
298
+ currentPage: number;
299
+ lastPage: number;
300
+ hasNextPage: boolean;
301
+ };
302
+ followers: {
303
+ id: number;
304
+ name: string;
305
+ avatar: {
306
+ large: string;
307
+ medium: string;
308
+ };
309
+ bannerImage: string;
310
+ }[];
311
+ };
312
+ };
313
+ errors?: {
314
+ message: string;
315
+ }[];
316
+ };
317
+ type UserFollowing = {
318
+ data?: {
319
+ Page: {
320
+ pageInfo: {
321
+ total: number;
322
+ perPage: number;
323
+ currentPage: number;
324
+ lastPage: number;
325
+ hasNextPage: boolean;
326
+ };
327
+ following: {
328
+ id: number;
329
+ name: string;
330
+ avatar: {
331
+ large: string;
332
+ medium: string;
333
+ };
334
+ bannerImage: string;
335
+ }[];
336
+ };
337
+ };
338
+ errors?: {
339
+ message: string;
340
+ }[];
341
+ };
342
+ type AnimeSearchResponse = {
343
+ data?: {
344
+ Page: {
345
+ media: {
346
+ id: number;
347
+ title: MediaTitle;
348
+ startDate: DateMonthYear;
349
+ episodes: number;
350
+ status: string;
351
+ description: string;
352
+ }[];
353
+ };
354
+ };
355
+ errors?: {
356
+ message: string;
357
+ }[];
358
+ };
359
+ export { AniListMediaStatus, AnimeDetails, AnimeList, AnimeSearchResponse, DateMonthYear, DeleteMangaResponse, List, MALAnimeStatus, MALAnimeXML, MALMangaStatus, MalIdToAnilistIdResponse, MediaEntry, MediaList, MediaListEntry, MediaTitle, MediaWithProgress, Myself, TheActivity, UserActivitiesResponse, UserFollower, UserFollowing, UserResponse, saveAnimeWithProgressResponse, };
@@ -6,9 +6,9 @@ declare function getTitle(title: {
6
6
  romaji?: string;
7
7
  }): string;
8
8
  declare function formatDateObject(dateObj: {
9
- day?: string;
10
- month?: string;
11
- year?: string;
9
+ day?: number;
10
+ month?: number;
11
+ year?: number;
12
12
  } | null): string;
13
13
  declare function getNextSeasonAndYear(): {
14
14
  nextSeason: string;
@@ -37,4 +37,5 @@ declare function createMangaListXML(mediaWithProgress: MediaWithProgress[]): Pro
37
37
  declare function getCurrentPackageVersion(): string | null;
38
38
  declare function timestampToTimeAgo(timestamp: number): string;
39
39
  declare function activityBy(activity: TheActivity): string;
40
- export { activityBy, aniListEndpoint, createAnimeListXML, createAnimeXML, createMangaListXML, createMangaXML, formatDateObject, getCurrentPackageVersion, getDownloadFolderPath, getFormattedDate, getNextSeasonAndYear, getTitle, redirectUri, removeHtmlAndMarkdown, saveJSONasCSV, saveJSONasJSON, selectFile, timestampToTimeAgo, };
40
+ declare const anidbToanilistMapper: (romanjiName: string, year: number, englishName?: string) => Promise<number | null>;
41
+ export { activityBy, anidbToanilistMapper, aniListEndpoint, createAnimeListXML, createAnimeXML, createMangaListXML, createMangaXML, formatDateObject, getCurrentPackageVersion, getDownloadFolderPath, getFormattedDate, getNextSeasonAndYear, getTitle, redirectUri, removeHtmlAndMarkdown, saveJSONasCSV, saveJSONasJSON, selectFile, timestampToTimeAgo, };
@@ -17,6 +17,8 @@ import { homedir } from "os";
17
17
  import { join } from "path";
18
18
  import process from "process";
19
19
  import { Auth } from "./auth.js";
20
+ import { fetcher } from "./fetcher.js";
21
+ import { animeSearchQuery } from "./queries.js";
20
22
  import { MALAnimeStatus, MALMangaStatus, } from "./types.js";
21
23
  const aniListEndpoint = `https://graphql.anilist.co`;
22
24
  const redirectUri = "https://anilist.co/api/v2/oauth/pin";
@@ -170,49 +172,49 @@ function selectFile(fileType) {
170
172
  });
171
173
  }
172
174
  function createAnimeXML(malId, progress, status, episodes, title) {
173
- return `
174
- <anime>
175
- <series_animedb_id>${malId}</series_animedb_id>
176
- <series_title><![CDATA[${title}]]></series_title>
177
- <series_type>""</series_type>
178
- <series_episodes>${episodes}</series_episodes>
179
- <my_id>0</my_id>
180
- <my_watched_episodes>${progress}</my_watched_episodes>
181
- <my_start_date>0000-00-00</my_start_date>
182
- <my_finish_date>0000-00-00</my_finish_date>
183
- <my_score>0</my_score>
184
- <my_storage_value>0.00</my_storage_value>
185
- <my_status>${status}</my_status>
186
- <my_comments><![CDATA[]]></my_comments>
187
- <my_times_watched>0</my_times_watched>
188
- <my_rewatch_value></my_rewatch_value>
189
- <my_priority>LOW</my_priority>
190
- <my_tags><![CDATA[]]></my_tags>
191
- <my_rewatching>0</my_rewatching>
192
- <my_rewatching_ep>0</my_rewatching_ep>
193
- <my_discuss>0</my_discuss>
194
- <my_sns>default</my_sns>
195
- <update_on_import>1</update_on_import>
175
+ return `
176
+ <anime>
177
+ <series_animedb_id>${malId}</series_animedb_id>
178
+ <series_title><![CDATA[${title}]]></series_title>
179
+ <series_type>""</series_type>
180
+ <series_episodes>${episodes}</series_episodes>
181
+ <my_id>0</my_id>
182
+ <my_watched_episodes>${progress}</my_watched_episodes>
183
+ <my_start_date>0000-00-00</my_start_date>
184
+ <my_finish_date>0000-00-00</my_finish_date>
185
+ <my_score>0</my_score>
186
+ <my_storage_value>0.00</my_storage_value>
187
+ <my_status>${status}</my_status>
188
+ <my_comments><![CDATA[]]></my_comments>
189
+ <my_times_watched>0</my_times_watched>
190
+ <my_rewatch_value></my_rewatch_value>
191
+ <my_priority>LOW</my_priority>
192
+ <my_tags><![CDATA[]]></my_tags>
193
+ <my_rewatching>0</my_rewatching>
194
+ <my_rewatching_ep>0</my_rewatching_ep>
195
+ <my_discuss>0</my_discuss>
196
+ <my_sns>default</my_sns>
197
+ <update_on_import>1</update_on_import>
196
198
  </anime>`;
197
199
  }
198
200
  function createMangaXML(malId, progress, status, chapters, title) {
199
- return `
200
- <manga>
201
- <manga_mangadb_id>${malId}</manga_mangadb_id>
202
- <manga_title><![CDATA[${title ? title : "unknown"}]]></manga_title>
203
- <manga_volumes>0</manga_volumes>
204
- <manga_chapters>${chapters ? chapters : 0}</manga_chapters>
205
- <my_id>0</my_id>
206
- <my_read_chapters>${progress}</my_read_chapters>
207
- <my_start_date>0000-00-00</my_start_date>
208
- <my_finish_date>0000-00-00</my_finish_date>
209
- <my_score>0</my_score>
210
- <my_status>${status}</my_status>
211
- <my_reread_value></my_reread_value>
212
- <my_priority>LOW</my_priority>
213
- <my_rereading>0</my_rereading>
214
- <my_discuss>0</my_discuss>
215
- <update_on_import>1</update_on_import>
201
+ return `
202
+ <manga>
203
+ <manga_mangadb_id>${malId}</manga_mangadb_id>
204
+ <manga_title><![CDATA[${title ? title : "unknown"}]]></manga_title>
205
+ <manga_volumes>0</manga_volumes>
206
+ <manga_chapters>${chapters ? chapters : 0}</manga_chapters>
207
+ <my_id>0</my_id>
208
+ <my_read_chapters>${progress}</my_read_chapters>
209
+ <my_start_date>0000-00-00</my_start_date>
210
+ <my_finish_date>0000-00-00</my_finish_date>
211
+ <my_score>0</my_score>
212
+ <my_status>${status}</my_status>
213
+ <my_reread_value></my_reread_value>
214
+ <my_priority>LOW</my_priority>
215
+ <my_rereading>0</my_rereading>
216
+ <my_discuss>0</my_discuss>
217
+ <update_on_import>1</update_on_import>
216
218
  </manga>`;
217
219
  }
218
220
  function createAnimeListXML(mediaWithProgress) {
@@ -232,19 +234,19 @@ function createAnimeListXML(mediaWithProgress) {
232
234
  const status = statusMap[anime.status];
233
235
  return createAnimeXML(malId, progress, status, episodes, title);
234
236
  });
235
- return `<myanimelist>
236
- <myinfo>
237
- <user_id/>
238
- <user_name>${yield Auth.MyUserName()}</user_name>
239
- <user_export_type>1</user_export_type>
240
- <user_total_anime>0</user_total_anime>
241
- <user_total_watching>0</user_total_watching>
242
- <user_total_completed>0</user_total_completed>
243
- <user_total_onhold>0</user_total_onhold>
244
- <user_total_dropped>0</user_total_dropped>
245
- <user_total_plantowatch>0</user_total_plantowatch>
246
- </myinfo>
247
- \n${xmlEntries.join("\n")}\n
237
+ return `<myanimelist>
238
+ <myinfo>
239
+ <user_id/>
240
+ <user_name>${yield Auth.MyUserName()}</user_name>
241
+ <user_export_type>1</user_export_type>
242
+ <user_total_anime>0</user_total_anime>
243
+ <user_total_watching>0</user_total_watching>
244
+ <user_total_completed>0</user_total_completed>
245
+ <user_total_onhold>0</user_total_onhold>
246
+ <user_total_dropped>0</user_total_dropped>
247
+ <user_total_plantowatch>0</user_total_plantowatch>
248
+ </myinfo>
249
+ \n${xmlEntries.join("\n")}\n
248
250
  </myanimelist>`;
249
251
  });
250
252
  }
@@ -265,19 +267,19 @@ function createMangaListXML(mediaWithProgress) {
265
267
  const status = statusMap[manga.status];
266
268
  return createMangaXML(malId, progress, status, chapters, title);
267
269
  });
268
- return `<myanimelist>
269
- <myinfo>
270
- <user_id/>
271
- <user_name>${yield Auth.MyUserName()}</user_name>
272
- <user_export_type>2</user_export_type>
273
- <user_total_manga>5</user_total_manga>
274
- <user_total_reading>1</user_total_reading>
275
- <user_total_completed>1</user_total_completed>
276
- <user_total_onhold>1</user_total_onhold>
277
- <user_total_dropped>1</user_total_dropped>
278
- <user_total_plantoread>1</user_total_plantoread>
279
- </myinfo>
280
- \n${xmlEntries.join("\n")}\n
270
+ return `<myanimelist>
271
+ <myinfo>
272
+ <user_id/>
273
+ <user_name>${yield Auth.MyUserName()}</user_name>
274
+ <user_export_type>2</user_export_type>
275
+ <user_total_manga>5</user_total_manga>
276
+ <user_total_reading>1</user_total_reading>
277
+ <user_total_completed>1</user_total_completed>
278
+ <user_total_onhold>1</user_total_onhold>
279
+ <user_total_dropped>1</user_total_dropped>
280
+ <user_total_plantoread>1</user_total_plantoread>
281
+ </myinfo>
282
+ \n${xmlEntries.join("\n")}\n
281
283
  </myanimelist>`;
282
284
  });
283
285
  }
@@ -334,4 +336,33 @@ function activityBy(activity) {
334
336
  return `[${activity === null || activity === void 0 ? void 0 : activity.id}] ???`;
335
337
  }
336
338
  }
337
- export { activityBy, aniListEndpoint, createAnimeListXML, createAnimeXML, createMangaListXML, createMangaXML, formatDateObject, getCurrentPackageVersion, getDownloadFolderPath, getFormattedDate, getNextSeasonAndYear, getTitle, redirectUri, removeHtmlAndMarkdown, saveJSONasCSV, saveJSONasJSON, selectFile, timestampToTimeAgo, };
339
+ const anidbToanilistMapper = (romanjiName, year, englishName) => __awaiter(void 0, void 0, void 0, function* () {
340
+ const fetchAnime = (search) => __awaiter(void 0, void 0, void 0, function* () {
341
+ var _a;
342
+ try {
343
+ const response = yield fetcher(animeSearchQuery, {
344
+ search,
345
+ perPage: 50,
346
+ });
347
+ return ((_a = response.data) === null || _a === void 0 ? void 0 : _a.Page.media) || [];
348
+ }
349
+ catch (error) {
350
+ console.error("Error fetching AniList data:", error);
351
+ return [];
352
+ }
353
+ });
354
+ // Search using romanjiName first
355
+ let results = yield fetchAnime(romanjiName);
356
+ // If no results, fallback to englishName
357
+ if (!results.length && englishName) {
358
+ results = yield fetchAnime(englishName);
359
+ }
360
+ // Match using year
361
+ for (const anime of results) {
362
+ if (anime.startDate.year === year) {
363
+ return anime.id;
364
+ }
365
+ }
366
+ return null;
367
+ });
368
+ export { activityBy, anidbToanilistMapper, aniListEndpoint, createAnimeListXML, createAnimeXML, createMangaListXML, createMangaXML, formatDateObject, getCurrentPackageVersion, getDownloadFolderPath, getFormattedDate, getNextSeasonAndYear, getTitle, redirectUri, removeHtmlAndMarkdown, saveJSONasCSV, saveJSONasJSON, selectFile, timestampToTimeAgo, };
package/package.json CHANGED
@@ -1,80 +1,81 @@
1
- {
2
- "name": "@irfanshadikrishad/anilist",
3
- "description": "Minimalist unofficial AniList CLI for Anime and Manga Enthusiasts",
4
- "author": "Irfan Shadik Rishad",
5
- "version": "1.3.2-forbidden.1",
6
- "main": "./bin/index.js",
7
- "type": "module",
8
- "types": "./bin/index.d.ts",
9
- "bin": {
10
- "anilist": "./bin/index.js"
11
- },
12
- "publishConfig": {
13
- "access": "public"
14
- },
15
- "scripts": {
16
- "build": "rm -rf ./bin && tsc",
17
- "buildw": "rm -rf ./bin && tsc -w",
18
- "format": "prettier . --write",
19
- "format:check": "prettier . --check",
20
- "lint": "eslint ./dist",
21
- "lint:fix": "eslint ./dist --fix",
22
- "all": "npm run build && npm run lint && npm run lint:fix && npm run format && npm test",
23
- "test": "jest ./tests"
24
- },
25
- "keywords": [
26
- "anilist",
27
- "CLI",
28
- "anime",
29
- "manga",
30
- "anime list",
31
- "manga list",
32
- "anime tracker",
33
- "manga tracker",
34
- "anilist API",
35
- "anime progress",
36
- "manga progress",
37
- "media list",
38
- "export anime",
39
- "import anime",
40
- "export manga",
41
- "import manga",
42
- "status tracker",
43
- "watchlist",
44
- "reading list",
45
- "graphql"
46
- ],
47
- "repository": {
48
- "type": "git",
49
- "url": "https://github.com/irfanshadikrishad/anilist"
50
- },
51
- "homepage": "https://github.com/irfanshadikrishad/anilist",
52
- "bugs": {
53
- "url": "https://github.com/irfanshadikrishad/anilist/issues"
54
- },
55
- "license": "MPL-2.0",
56
- "devDependencies": {
57
- "@eslint/js": "^9.17.0",
58
- "@types/jest": "^29.5.14",
59
- "@types/json2csv": "^5.0.7",
60
- "@types/node": "^22.10.5",
61
- "eslint": "^9.17.0",
62
- "globals": "^15.14.0",
63
- "jest": "^29.7.0",
64
- "prettier": "^3.4.2",
65
- "prettier-plugin-organize-imports": "^4.1.0",
66
- "ts-jest": "^29.2.5",
67
- "ts-node": "^10.9.2",
68
- "typescript": "^5.7.3",
69
- "@babel/preset-env": "^7.26.0",
70
- "@typescript-eslint/eslint-plugin": "^8.19.1"
71
- },
72
- "dependencies": {
73
- "commander": "^13.0.0",
74
- "fast-xml-parser": "^4.5.1",
75
- "inquirer": "^12.3.0",
76
- "json2csv": "^6.0.0-alpha.2",
77
- "node-fetch": "^3.3.2",
78
- "open": "^10.1.0"
79
- }
80
- }
1
+ {
2
+ "name": "@irfanshadikrishad/anilist",
3
+ "description": "Minimalist unofficial AniList CLI for Anime and Manga Enthusiasts",
4
+ "author": "Irfan Shadik Rishad",
5
+ "version": "1.3.3-forbidden.1",
6
+ "main": "./bin/index.js",
7
+ "type": "module",
8
+ "types": "./bin/index.d.ts",
9
+ "bin": {
10
+ "anilist": "./bin/index.js"
11
+ },
12
+ "publishConfig": {
13
+ "access": "public"
14
+ },
15
+ "scripts": {
16
+ "build": "rm -rf ./bin && tsc",
17
+ "buildw": "rm -rf ./bin && tsc -w",
18
+ "format": "prettier . --write",
19
+ "format:check": "prettier . --check",
20
+ "lint": "eslint ./dist",
21
+ "lint:fix": "eslint ./dist --fix",
22
+ "all": "npm run build && npm run lint && npm run lint:fix && npm run format && npm test",
23
+ "test": "jest ./tests"
24
+ },
25
+ "keywords": [
26
+ "anilist",
27
+ "CLI",
28
+ "anime",
29
+ "manga",
30
+ "anime list",
31
+ "manga list",
32
+ "anime tracker",
33
+ "manga tracker",
34
+ "anilist API",
35
+ "anime progress",
36
+ "manga progress",
37
+ "media list",
38
+ "export anime",
39
+ "import anime",
40
+ "export manga",
41
+ "import manga",
42
+ "status tracker",
43
+ "watchlist",
44
+ "reading list",
45
+ "graphql"
46
+ ],
47
+ "repository": {
48
+ "type": "git",
49
+ "url": "https://github.com/irfanshadikrishad/anilist"
50
+ },
51
+ "homepage": "https://github.com/irfanshadikrishad/anilist",
52
+ "bugs": {
53
+ "url": "https://github.com/irfanshadikrishad/anilist/issues"
54
+ },
55
+ "license": "MPL-2.0",
56
+ "devDependencies": {
57
+ "@babel/preset-env": "^7.26.0",
58
+ "@eslint/js": "^9.18.0",
59
+ "@types/jest": "^29.5.14",
60
+ "@types/json2csv": "^5.0.7",
61
+ "@types/node": "^22.10.6",
62
+ "@typescript-eslint/eslint-plugin": "^8.20.0",
63
+ "eslint": "^9.18.0",
64
+ "globals": "^15.14.0",
65
+ "jest": "^29.7.0",
66
+ "prettier": "^3.4.2",
67
+ "prettier-plugin-organize-imports": "^4.1.0",
68
+ "ts-jest": "^29.2.5",
69
+ "ts-node": "^10.9.2",
70
+ "typescript": "^5.7.3"
71
+ },
72
+ "dependencies": {
73
+ "commander": "^13.0.0",
74
+ "fast-xml-parser": "^4.5.1",
75
+ "inquirer": "^12.3.2",
76
+ "json2csv": "^6.0.0-alpha.2",
77
+ "jsonrepair": "^3.11.2",
78
+ "node-fetch": "^3.3.2",
79
+ "open": "^10.1.0"
80
+ }
81
+ }