aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authordec05eba <dec05eba@protonmail.com>2020-10-23 07:42:13 +0200
committerdec05eba <dec05eba@protonmail.com>2020-10-23 07:42:13 +0200
commitaa9a861c662f7c65cde92fbf133deaca3692bbd2 (patch)
tree37c8b2eddfc6315a45607325ca4abe6fca13ca76 /src
parent261b0263f34ffcbe439d68b2e901fd3abbfc1eaf (diff)
Mangadex: implement pagination
Diffstat (limited to 'src')
-rw-r--r--src/QuickMedia.cpp1
-rw-r--r--src/plugins/Mangadex.cpp14
2 files changed, 10 insertions, 5 deletions
diff --git a/src/QuickMedia.cpp b/src/QuickMedia.cpp
index c9950a0..6d8f493 100644
--- a/src/QuickMedia.cpp
+++ b/src/QuickMedia.cpp
@@ -1249,7 +1249,6 @@ namespace QuickMedia {
if(associated_data.search_text_updated && associated_data.fetch_status == FetchStatus::NONE && !associated_data.fetching_next_page_running) {
std::string update_search_text = associated_data.update_search_text;
- associated_data.update_search_text.clear();
associated_data.search_text_updated = false;
associated_data.fetch_status = FetchStatus::LOADING;
associated_data.fetch_type = FetchType::SEARCH;
diff --git a/src/plugins/Mangadex.cpp b/src/plugins/Mangadex.cpp
index e798b60..a52788d 100644
--- a/src/plugins/Mangadex.cpp
+++ b/src/plugins/Mangadex.cpp
@@ -55,14 +55,12 @@ namespace QuickMedia {
bool *is_last_page;
};
- // TODO: Implement pagination (go to next page and get all results as well)
- SearchResult MangadexSearchPage::search(const std::string &str, BodyItems &result_items) {
+ SearchResult MangadexSearchPage::search(const std::string &str, int page, BodyItems &result_items) {
std::string rememberme_token;
if(!get_rememberme_token(rememberme_token))
return SearchResult::ERR;
- std::string url = "https://mangadex.org/search?title=";
- url += url_param_encode(str);
+ std::string url = "https://mangadex.org/search?s=0&p=" + std::to_string(page) + "&tag_mode_inc=all&tag_mode_exc=any&title=" + url_param_encode(str) +"#listing";
CommandArg cookie_arg = { "-H", "cookie: mangadex_rememberme_token=" + rememberme_token };
std::string website_data;
@@ -111,6 +109,14 @@ namespace QuickMedia {
return result == 0 ? SearchResult::OK : SearchResult::ERR;
}
+ SearchResult MangadexSearchPage::search(const std::string &str, BodyItems &result_items) {
+ return search(str, 1, result_items);
+ }
+
+ PluginResult MangadexSearchPage::get_page(const std::string &str, int page, BodyItems &result_items) {
+ return search_result_to_plugin_result(search(str, 1 + page, result_items));
+ }
+
PluginResult MangadexSearchPage::submit(const std::string &title, const std::string &url, std::vector<Tab> &result_tabs) {
std::string request_url = "https://mangadex.org/api/?id=" + title_url_extract_manga_id(url) + "&type=manga";