@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.
- package/LICENSE.md +382 -382
- package/README.md +243 -240
- package/bin/helpers/auth.js +43 -27
- package/bin/helpers/lists.d.ts +4 -1
- package/bin/helpers/lists.js +110 -9
- package/bin/helpers/mutations.js +35 -35
- package/bin/helpers/queries.d.ts +4 -2
- package/bin/helpers/queries.js +168 -154
- package/bin/helpers/types.d.ts +123 -4
- package/bin/helpers/workers.d.ts +5 -4
- package/bin/helpers/workers.js +98 -67
- package/package.json +81 -80
package/bin/helpers/types.d.ts
CHANGED
|
@@ -171,9 +171,9 @@ interface Myself {
|
|
|
171
171
|
}[];
|
|
172
172
|
}
|
|
173
173
|
interface DateMonthYear {
|
|
174
|
-
day?:
|
|
175
|
-
month?:
|
|
176
|
-
year?:
|
|
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
|
-
|
|
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, };
|
package/bin/helpers/workers.d.ts
CHANGED
|
@@ -6,9 +6,9 @@ declare function getTitle(title: {
|
|
|
6
6
|
romaji?: string;
|
|
7
7
|
}): string;
|
|
8
8
|
declare function formatDateObject(dateObj: {
|
|
9
|
-
day?:
|
|
10
|
-
month?:
|
|
11
|
-
year?:
|
|
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
|
-
|
|
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, };
|
package/bin/helpers/workers.js
CHANGED
|
@@ -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
|
-
|
|
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.
|
|
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
|
-
"@
|
|
58
|
-
"@
|
|
59
|
-
"@types/
|
|
60
|
-
"@types/
|
|
61
|
-
"
|
|
62
|
-
"
|
|
63
|
-
"
|
|
64
|
-
"
|
|
65
|
-
"
|
|
66
|
-
"
|
|
67
|
-
"
|
|
68
|
-
"
|
|
69
|
-
"
|
|
70
|
-
"
|
|
71
|
-
},
|
|
72
|
-
"dependencies": {
|
|
73
|
-
"commander": "^13.0.0",
|
|
74
|
-
"fast-xml-parser": "^4.5.1",
|
|
75
|
-
"inquirer": "^12.3.
|
|
76
|
-
"json2csv": "^6.0.0-alpha.2",
|
|
77
|
-
"
|
|
78
|
-
"
|
|
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
|
+
}
|