aboutsummaryrefslogtreecommitdiff
path: root/plugins/Mangadex.hpp
diff options
context:
space:
mode:
authordec05eba <dec05eba@protonmail.com>2020-10-11 21:35:37 +0200
committerdec05eba <dec05eba@protonmail.com>2020-10-13 13:13:01 +0200
commit77ed51898157d99112be7550471ec06e32344c9e (patch)
tree0645274d0f13b4fa6940d4054f74a070611a8ef0 /plugins/Mangadex.hpp
parentda89ec98fb34757f0c46dc8cb2dd87ae78d317ce (diff)
Refactor plugin into seperate pages
TODO: Readd 4chan login page, manganelo creators page, autocomplete
Diffstat (limited to 'plugins/Mangadex.hpp')
-rw-r--r--plugins/Mangadex.hpp43
1 files changed, 24 insertions, 19 deletions
diff --git a/plugins/Mangadex.hpp b/plugins/Mangadex.hpp
index aaca18d..ba43498 100644
--- a/plugins/Mangadex.hpp
+++ b/plugins/Mangadex.hpp
@@ -2,32 +2,37 @@
#include "Manga.hpp"
#include <functional>
-#include <mutex>
namespace QuickMedia {
- class Mangadex : public Manga {
+ class MangadexSearchPage : public Page {
public:
- Mangadex() : Manga("mangadex") {}
- SearchResult search(const std::string &url, BodyItems &result_items) override;
- SuggestionResult update_search_suggestions(const std::string &text, BodyItems &result_items) override;
- ImageResult get_number_of_images(const std::string &url, int &num_images) override;
- bool search_suggestions_has_thumbnails() const override { return true; }
- bool search_results_has_thumbnails() const override { return false; }
- int get_search_delay() const override { return 300; }
- Page get_page_after_search() const override { return Page::EPISODE_LIST; }
+ MangadexSearchPage(Program *program) : Page(program) {}
+ const char* get_title() const override { return "All"; }
+ bool search_is_filter() override { return false; }
+ SearchResult search(const std::string &str, BodyItems &result_items) override;
+ PluginResult submit(const std::string &title, const std::string &url, std::vector<Tab> &result_tabs) override;
+ private:
+ bool get_rememberme_token(std::string &rememberme_token);
+ std::optional<std::string> rememberme_token;
+ };
+
+ class MangadexChaptersPage : public MangaChaptersPage {
+ public:
+ MangadexChaptersPage(Program *program, std::string manga_name, std::string manga_url) : MangaChaptersPage(program, std::move(manga_name), std::move(manga_url)) {}
+ PluginResult submit(const std::string &title, const std::string &url, std::vector<Tab> &result_tabs) override;
+ };
+
+ class MangadexImagesPage : public MangaImagesPage {
+ public:
+ MangadexImagesPage(Program *program, std::string manga_name, std::string chapter_name, std::string url) : MangaImagesPage(program, std::move(manga_name), std::move(chapter_name), std::move(url)) {}
- ImageResult for_each_page_in_chapter(const std::string &chapter_url, PageCallback callback) override;
+ ImageResult get_number_of_images(int &num_images) override;
+ ImageResult for_each_page_in_chapter(PageCallback callback) override;
- bool extract_id_from_url(const std::string &url, std::string &manga_id) override;
+ const char* get_service_name() const override { return "mangadex"; }
private:
- // Caches url. If the same url is requested multiple times then the cache is used
+ // Cached
ImageResult get_image_urls_for_chapter(const std::string &url);
- bool get_rememberme_token(std::string &rememberme_token);
bool save_mangadex_cookies(const std::string &url, const std::string &cookie_filepath);
- private:
- std::string last_chapter_url;
- std::vector<std::string> last_chapter_image_urls;
- std::mutex image_urls_mutex;
- std::optional<std::string> rememberme_token;
};
} \ No newline at end of file