Mercurial > minori
changeset 52:0c4138de2ea7
anime list: we are finally read-write
author | Paper <mrpapersonic@gmail.com> |
---|---|
date | Mon, 25 Sep 2023 22:49:42 -0400 (15 months ago) |
parents | 75c804f713b2 |
children | a6e51a03112e |
files | include/services/services.h src/gui/dialog/about.cpp src/gui/pages/anime_list.cpp src/services/anilist.cpp src/services/services.cpp |
diffstat | 5 files changed, 23 insertions(+), 11 deletions(-) [+] |
line wrap: on
line diff
--- 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
--- 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);
--- 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 <QDebug> #include <QHBoxLayout> #include <QHeaderView> @@ -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);
--- 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 <QDesktopServices> #include <QInputDialog> +#include <QDebug> #include <QLineEdit> #include <QMessageBox> #include <QUrl> @@ -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) {
--- 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: