aboutsummaryrefslogtreecommitdiff
path: root/launcher/ui/pages/instance/ManagedPackPage.h
diff options
context:
space:
mode:
authorflow <flowlnlnln@gmail.com>2022-10-13 19:55:21 -0300
committerflow <flowlnlnln@gmail.com>2022-12-06 16:54:54 -0300
commite5c42f68c2429a924b22dbcfb0df5a497690b805 (patch)
tree9e4cec7c4e971d4c3555a67c8b44cac108071a5b /launcher/ui/pages/instance/ManagedPackPage.h
parent02b4468bcddcdab6c269282564a0968c6394a34f (diff)
downloadPrismLauncher-e5c42f68c2429a924b22dbcfb0df5a497690b805.tar.gz
PrismLauncher-e5c42f68c2429a924b22dbcfb0df5a497690b805.tar.bz2
PrismLauncher-e5c42f68c2429a924b22dbcfb0df5a497690b805.zip
feat: add basic ManagedPackPage classes
The idea is to have a base class that defines common behavior, and subclasses for each modpack provider, adding specific behavior. Signed-off-by: flow <flowlnlnln@gmail.com>
Diffstat (limited to 'launcher/ui/pages/instance/ManagedPackPage.h')
-rw-r--r--launcher/ui/pages/instance/ManagedPackPage.h98
1 files changed, 98 insertions, 0 deletions
diff --git a/launcher/ui/pages/instance/ManagedPackPage.h b/launcher/ui/pages/instance/ManagedPackPage.h
new file mode 100644
index 00000000..be49383c
--- /dev/null
+++ b/launcher/ui/pages/instance/ManagedPackPage.h
@@ -0,0 +1,98 @@
+#pragma once
+
+#include "BaseInstance.h"
+
+#include "modplatform/modrinth/ModrinthAPI.h"
+#include "modplatform/modrinth/ModrinthPackManifest.h"
+
+#include "ui/pages/BasePage.h"
+
+#include <QWidget>
+
+namespace Ui {
+class ManagedPackPage;
+}
+
+class ManagedPackPage : public QWidget, public BasePage {
+ Q_OBJECT
+
+ public:
+ inline static ManagedPackPage* createPage(BaseInstance* inst, QWidget* parent = nullptr)
+ {
+ return ManagedPackPage::createPage(inst, inst->getManagedPackType(), parent);
+ }
+
+ static ManagedPackPage* createPage(BaseInstance* inst, QString type, QWidget* parent = nullptr);
+ ~ManagedPackPage() override;
+
+ [[nodiscard]] QString displayName() const override;
+ [[nodiscard]] QIcon icon() const override;
+ [[nodiscard]] QString helpPage() const override;
+ [[nodiscard]] QString id() const override { return "managed_pack"; }
+ [[nodiscard]] bool shouldDisplay() const override;
+
+ void openedImpl() override;
+
+ bool apply() override { return true; }
+ void retranslate() override;
+
+ /** Gets the necessary information about the managed pack, such as
+ * available versions*/
+ virtual void parseManagedPack() {};
+
+ /** URL of the managed pack.
+ * Not the version-specific one.
+ */
+ [[nodiscard]] virtual QString url() const { return {}; };
+
+ public slots:
+ /** Gets the current version selection and update the changelog.
+ */
+ virtual void suggestVersion() {};
+
+ protected:
+ ManagedPackPage(BaseInstance* inst, QWidget* parent = nullptr);
+
+ protected:
+ Ui::ManagedPackPage* ui;
+ BaseInstance* m_inst;
+
+ bool m_loaded = false;
+};
+
+/** Simple page for when we aren't a managed pack. */
+class GenericManagedPackPage final : public ManagedPackPage {
+ Q_OBJECT
+
+ public:
+ GenericManagedPackPage(BaseInstance* inst, QWidget* parent = nullptr) : ManagedPackPage(inst, parent) {}
+ ~GenericManagedPackPage() override = default;
+};
+
+class ModrinthManagedPackPage final : public ManagedPackPage {
+ Q_OBJECT
+
+ public:
+ ModrinthManagedPackPage(BaseInstance* inst, QWidget* parent = nullptr);
+ ~ModrinthManagedPackPage() override = default;
+
+ void parseManagedPack() override;
+ [[nodiscard]] QString url() const override;
+
+ public slots:
+ void suggestVersion() override;
+};
+
+class FlameManagedPackPage final : public ManagedPackPage {
+ Q_OBJECT
+
+ public:
+ FlameManagedPackPage(BaseInstance* inst, QWidget* parent = nullptr);
+ ~FlameManagedPackPage() override = default;
+
+ void parseManagedPack() override;
+ [[nodiscard]] QString url() const override;
+
+ public slots:
+ void suggestVersion() override;
+};