From fdeb82815db468ac7e99e9646f57bed2bf1832de Mon Sep 17 00:00:00 2001 From: dec05eba Date: Wed, 22 Sep 2021 20:10:48 +0200 Subject: Sort anilist recommendations by best match, show episode duration, show titles differently --- src/plugins/AniList.cpp | 25 ++++++++++++++++++------- 1 file changed, 18 insertions(+), 7 deletions(-) (limited to 'src/plugins/AniList.cpp') 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())); } -- cgit v1.2.3