summaryrefslogtreecommitdiffstats
path: root/application/pages/modplatform/technic/TechnicPage.h
diff options
context:
space:
mode:
authorPetr Mrázek <peterix@users.noreply.github.com>2020-10-13 21:44:20 +0200
committerGitHub <noreply@github.com>2020-10-13 21:44:20 +0200
commit4c62776044f3a7ad9efa3150ebec6150070502ed (patch)
tree81945f562b0970888b0c037bcacb95b0a8a95f0e /application/pages/modplatform/technic/TechnicPage.h
parent762ddaea6578d552dabaffefd7ea6942776f3eff (diff)
parent8021fb25d0778bbc88bbfa052fcf2572807ee0f5 (diff)
downloadMultiMC-4c62776044f3a7ad9efa3150ebec6150070502ed.tar
MultiMC-4c62776044f3a7ad9efa3150ebec6150070502ed.tar.gz
MultiMC-4c62776044f3a7ad9efa3150ebec6150070502ed.tar.lz
MultiMC-4c62776044f3a7ad9efa3150ebec6150070502ed.tar.xz
MultiMC-4c62776044f3a7ad9efa3150ebec6150070502ed.zip
Merge pull request #3195 from kb-1000/technic-import
Technic pack import
Diffstat (limited to 'application/pages/modplatform/technic/TechnicPage.h')
-rw-r--r--application/pages/modplatform/technic/TechnicPage.h78
1 files changed, 78 insertions, 0 deletions
diff --git a/application/pages/modplatform/technic/TechnicPage.h b/application/pages/modplatform/technic/TechnicPage.h
new file mode 100644
index 00000000..1a10af71
--- /dev/null
+++ b/application/pages/modplatform/technic/TechnicPage.h
@@ -0,0 +1,78 @@
+/* Copyright 2013-2020 MultiMC Contributors
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#pragma once
+
+#include <QWidget>
+
+#include "pages/BasePage.h"
+#include <MultiMC.h>
+#include "tasks/Task.h"
+#include "TechnicData.h"
+
+namespace Ui
+{
+class TechnicPage;
+}
+
+class NewInstanceDialog;
+
+namespace Technic {
+ class ListModel;
+}
+
+class TechnicPage : public QWidget, public BasePage
+{
+ Q_OBJECT
+
+public:
+ explicit TechnicPage(NewInstanceDialog* dialog, QWidget *parent = 0);
+ virtual ~TechnicPage();
+ virtual QString displayName() const override
+ {
+ return tr("Technic");
+ }
+ virtual QIcon icon() const override
+ {
+ return MMC->getThemedIcon("technic");
+ }
+ virtual QString id() const override
+ {
+ return "technic";
+ }
+ virtual QString helpPage() const override
+ {
+ return "Technic-platform";
+ }
+ virtual bool shouldDisplay() const override;
+
+ void openedImpl() override;
+
+ bool eventFilter(QObject* watched, QEvent* event) override;
+
+private:
+ void suggestCurrent();
+ void metadataLoaded();
+
+private slots:
+ void triggerSearch();
+ void onSelectionChanged(QModelIndex first, QModelIndex second);
+
+private:
+ Ui::TechnicPage *ui = nullptr;
+ NewInstanceDialog* dialog = nullptr;
+ Technic::ListModel* model = nullptr;
+ Technic::Modpack current;
+};