aboutsummaryrefslogtreecommitdiff
path: root/src/plugins/AniList.cpp
diff options
context:
space:
mode:
authordec05eba <dec05eba@protonmail.com>2021-09-22 20:10:48 +0200
committerdec05eba <dec05eba@protonmail.com>2021-09-22 20:10:48 +0200
commitfdeb82815db468ac7e99e9646f57bed2bf1832de (patch)
treeffc1ca95e05f47e26c21cce29f5510275e01787e /src/plugins/AniList.cpp
parent7934864d58ec39b237e2b45d0180aa567b29b944 (diff)
Sort anilist recommendations by best match, show episode duration, show titles differently
Diffstat (limited to 'src/plugins/AniList.cpp')
-rw-r--r--src/plugins/AniList.cpp25
1 files changed, 18 insertions, 7 deletions
diff --git a/src/plugins/AniList.cpp b/src/plugins/AniList.cpp
index 0c7229f..5043eb7 100644
--- a/src/plugins/AniList.cpp
+++ b/src/plugins/AniList.cpp
@@ -28,6 +28,7 @@ query ($page: Int, $perPage: Int, $search: String) {
averageScore
episodes
chapters
+ duration
genres
coverImage {
medium
@@ -62,6 +63,7 @@ query ($id: Int) {
averageScore
episodes
chapters
+ duration
genres
description (asHtml: false)
coverImage {
@@ -99,6 +101,7 @@ query ($id: Int) {
averageScore
episodes
chapters
+ duration
genres
coverImage {
medium
@@ -117,7 +120,7 @@ query ($id: Int) {
static const std::string recommendations_query_graphql = R"END(
query ($id: Int, $page: Int, $perPage: Int) {
Media (id: $id) {
- recommendations (page: $page, perPage: $perPage) {
+ recommendations (page: $page, perPage: $perPage, sort: RATING_DESC) {
nodes {
mediaRecommendation {
id
@@ -137,6 +140,7 @@ query ($id: Int, $page: Int, $perPage: Int) {
averageScore
episodes
chapters
+ duration
genres
coverImage {
medium
@@ -288,6 +292,7 @@ query ($id: Int, $page: Int, $perPage: Int) {
const Json::Value &status_json = media_json["status"];
const Json::Value &episodes_json = media_json["episodes"];
const Json::Value &chapters_json = media_json["chapters"];
+ const Json::Value &duration_json = media_json["duration"];
const Json::Value &genres_json = media_json["genres"];
const Json::Value &description_json = media_json["description"];
@@ -356,6 +361,12 @@ query ($id: Int, $page: Int, $perPage: Int) {
description += "Chapters: " + std::to_string(chapters_json.asInt());
}
+ if(duration_json.isInt()) {
+ if(!description.empty())
+ description += '\n';
+ description += "Episode duration: " + std::to_string(duration_json.asInt()) + " minute" + (duration_json.asInt() == 1 ? "" : "s");
+ }
+
if(status_json.isString()) {
if(!description.empty())
description += '\n';
@@ -598,8 +609,8 @@ query ($id: Int, $page: Int, $perPage: Int) {
if(it.second.empty())
continue;
- auto anime_title_item = BodyItem::create("");
- anime_title_item->set_author("------------------------ " + it.first + " ------------------------");
+ auto anime_title_item = BodyItem::create("", false);
+ anime_title_item->set_author(it.first);
result_items.push_back(std::move(anime_title_item));
result_items.insert(result_items.end(), std::move_iterator(it.second.begin()), std::move_iterator(it.second.end()));
}
@@ -754,15 +765,15 @@ query ($id: Int, $page: Int, $perPage: Int) {
}
if(!anime_items.empty()) {
- auto anime_title_item = BodyItem::create("");
- anime_title_item->set_author("------------------------ Anime ------------------------");
+ auto anime_title_item = BodyItem::create("", false);
+ anime_title_item->set_author("Anime");
result_items.push_back(std::move(anime_title_item));
result_items.insert(result_items.end(), std::move_iterator(anime_items.begin()), std::move_iterator(anime_items.end()));
}
if(!manga_items.empty()) {
- auto manga_title_item = BodyItem::create("");
- manga_title_item->set_author("------------------------ Manga ------------------------");
+ auto manga_title_item = BodyItem::create("", false);
+ manga_title_item->set_author("Manga");
result_items.push_back(std::move(manga_title_item));
result_items.insert(result_items.end(), std::move_iterator(manga_items.begin()), std::move_iterator(manga_items.end()));
}