aboutsummaryrefslogtreecommitdiff
path: root/plugins/Manganelo.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/Manganelo.hpp
parentda89ec98fb34757f0c46dc8cb2dd87ae78d317ce (diff)
Refactor plugin into seperate pages
TODO: Readd 4chan login page, manganelo creators page, autocomplete
Diffstat (limited to 'plugins/Manganelo.hpp')
-rw-r--r--plugins/Manganelo.hpp49
1 files changed, 31 insertions, 18 deletions
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 <functional>
-#include <mutex>
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<Tab> &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<Tab> &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<Tab> &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<std::string> last_chapter_image_urls;
- std::mutex image_urls_mutex;
};
} \ No newline at end of file