From 77ed51898157d99112be7550471ec06e32344c9e Mon Sep 17 00:00:00 2001 From: dec05eba Date: Sun, 11 Oct 2020 21:35:37 +0200 Subject: Refactor plugin into seperate pages TODO: Readd 4chan login page, manganelo creators page, autocomplete --- plugins/Mangadex.hpp | 43 ++++++++++++++++++++++++------------------- 1 file changed, 24 insertions(+), 19 deletions(-) (limited to 'plugins/Mangadex.hpp') 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 -#include 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 &result_tabs) override; + private: + bool get_rememberme_token(std::string &rememberme_token); + std::optional 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 &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 last_chapter_image_urls; - std::mutex image_urls_mutex; - std::optional rememberme_token; }; } \ No newline at end of file -- cgit v1.2.3