# HG changeset patch # User Paper # Date 1695696582 14400 # Node ID 0c4138de2ea7200e38c6ecf6c9af1c906b695978 # Parent 75c804f713b2f5643f931aeec31e574b06b4e9ee anime list: we are finally read-write diff -r 75c804f713b2 -r 0c4138de2ea7 include/services/services.h --- a/include/services/services.h Mon Sep 25 20:29:26 2023 -0400 +++ b/include/services/services.h Mon Sep 25 22:49:42 2023 -0400 @@ -4,6 +4,7 @@ namespace Services { void Synchronize(); +void UpdateAnimeEntry(int id); bool Authorize(); }; // namespace Services diff -r 75c804f713b2 -r 0c4138de2ea7 src/gui/dialog/about.cpp --- a/src/gui/dialog/about.cpp Mon Sep 25 20:29:26 2023 -0400 +++ b/src/gui/dialog/about.cpp Mon Sep 25 22:49:42 2023 -0400 @@ -74,6 +74,9 @@ QTextCharFormat format; QTextBrowser* paragraph = new QTextBrowser(this); paragraph->setOpenExternalLinks(true); + paragraph->setFrameShape(QFrame::NoFrame); + paragraph->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff); + paragraph->setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOff); QTextCursor cursor = paragraph->textCursor(); SET_TITLE_FONT(font, format, cursor); SET_FONT_BOLD(font, format, cursor); diff -r 75c804f713b2 -r 0c4138de2ea7 src/gui/pages/anime_list.cpp --- a/src/gui/pages/anime_list.cpp Mon Sep 25 20:29:26 2023 -0400 +++ b/src/gui/pages/anime_list.cpp Mon Sep 25 22:49:42 2023 -0400 @@ -16,7 +16,7 @@ #include "core/time.h" #include "gui/dialog/information.h" #include "gui/translate/anime.h" -#include "services/anilist.h" +#include "services/services.h" #include #include #include @@ -315,7 +315,8 @@ return; } - InformationDialog* dialog = new InformationDialog(*anime, [this] { + InformationDialog* dialog = new InformationDialog(*anime, [this, anime] { + Services::UpdateAnimeEntry(anime->GetId()); Refresh(); }, this); @@ -339,7 +340,8 @@ Anime::Anime* anime = ((AnimeListWidgetModel*)sort_models[tab_bar->currentIndex()]->sourceModel())->GetAnimeFromIndex(index); - InformationDialog* dialog = new InformationDialog(*anime, [this] { + InformationDialog* dialog = new InformationDialog(*anime, [this, anime] { + Services::UpdateAnimeEntry(anime->GetId()); Refresh(); }, this); diff -r 75c804f713b2 -r 0c4138de2ea7 src/services/anilist.cpp --- a/src/services/anilist.cpp Mon Sep 25 20:29:26 2023 -0400 +++ b/src/services/anilist.cpp Mon Sep 25 22:49:42 2023 -0400 @@ -8,6 +8,7 @@ #include "gui/translate/anilist.h" #include #include +#include #include #include #include @@ -260,7 +261,7 @@ return 1; } -int UpdateAnimeEntry(const Anime::Anime& anime) { +int UpdateAnimeEntry(int id) { /** * possible values: * @@ -280,11 +281,9 @@ * Date startedAt, * Date completedAt **/ - const std::string query = "mutation ($media_id: Int, $progress: Int, $status: MediaListStatus, " - "$score: Int, $notes: String) {\n" - " SaveMediaListEntry (mediaId: $media_id, progress: $progress, " - "status: $status, scoreRaw: $score, notes: " - "$notes) {\n" + Anime::Anime& anime = Anime::db.items[id]; + const std::string query = "mutation ($media_id: Int, $progress: Int, $status: MediaListStatus, $score: Int, $notes: String) {\n" + " SaveMediaListEntry (mediaId: $media_id, progress: $progress, status: $status, scoreRaw: $score, notes: $notes) {\n" " id\n" " }\n" "}\n"; @@ -300,8 +299,8 @@ }} }; // clang-format on - SendRequest(json.dump()); - return 1; + auto ret = nlohmann::json::parse(SendRequest(json.dump())); + return JSON::GetInt(ret, "/data/SaveMediaListEntry/id"_json_pointer); } int ParseUser(const nlohmann::json& json) { diff -r 75c804f713b2 -r 0c4138de2ea7 src/services/services.cpp --- a/src/services/services.cpp Mon Sep 25 20:29:26 2023 -0400 +++ b/src/services/services.cpp Mon Sep 25 22:49:42 2023 -0400 @@ -25,6 +25,13 @@ } } +void UpdateAnimeEntry(int id) { + switch (session.config.service) { + case Anime::Services::ANILIST: AniList::UpdateAnimeEntry(id); break; + default: break; + } +} + bool Authorize() { switch (session.config.service) { case Anime::Services::ANILIST: