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/Manganelo.hpp | 49 +++++++++++++++++++++++++++++++------------------ 1 file changed, 31 insertions(+), 18 deletions(-) (limited to 'plugins/Manganelo.hpp') diff --git a/plugins/Manganelo.hpp b/plugins/Manganelo.hpp index c2ad693..d79f814 100644 --- a/plugins/Manganelo.hpp +++ b/plugins/Manganelo.hpp @@ -2,31 +2,44 @@ #include "Manga.hpp" #include -#include namespace QuickMedia { - class Manganelo : public Manga { + class ManganeloSearchPage : public Page { public: - Manganelo() : Manga("manganelo") {} - 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 200; } - Page get_page_after_search() const override { return Page::EPISODE_LIST; } + ManganeloSearchPage(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 extract_id_from_url(const std::string &url, std::string &manga_id) const; + }; - ImageResult for_each_page_in_chapter(const std::string &chapter_url, PageCallback callback) override; + class ManganeloChaptersPage : public MangaChaptersPage { + public: + ManganeloChaptersPage(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; + }; - bool extract_id_from_url(const std::string &url, std::string &manga_id) override; + class ManganeloCreatorPage : public Page { + public: + ManganeloCreatorPage(Program *program, Creator creator) : Page(program), creator(std::move(creator)) {} + const char* get_title() const override { return creator.name.c_str(); } + PluginResult submit(const std::string &title, const std::string &url, std::vector &result_tabs) override; + private: + Creator creator; + }; + + class ManganeloImagesPage : public MangaImagesPage { + public: + ManganeloImagesPage(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)) {} - PluginResult get_creators_manga_list(const std::string &url, BodyItems &result_items) override; + ImageResult get_number_of_images(int &num_images) override; + ImageResult for_each_page_in_chapter(PageCallback callback) override; + + const char* get_service_name() const override { return "manganelo"; } 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); - private: - std::string last_chapter_url; - std::vector last_chapter_image_urls; - std::mutex image_urls_mutex; }; } \ No newline at end of file -- cgit v1.2.3