aboutsummaryrefslogtreecommitdiff
path: root/launcher/ui/pages/modplatform/TexturePackPage.h
diff options
context:
space:
mode:
authorTheKodeToad <freezingma1l@outlook.com>2023-03-02 10:10:46 +0000
committerGitHub <noreply@github.com>2023-03-02 10:10:46 +0000
commit5c913149c84c121523a1ae403848d3e0926de244 (patch)
tree3789176d454bd988b7e572e5f411151efc2cb7e2 /launcher/ui/pages/modplatform/TexturePackPage.h
parentcbe6eff2fa917401b913a96c551429caad852b3b (diff)
parent9265c319a96b3dd5681767c196a397fbbae9164a (diff)
downloadPrismLauncher-5c913149c84c121523a1ae403848d3e0926de244.tar.gz
PrismLauncher-5c913149c84c121523a1ae403848d3e0926de244.tar.bz2
PrismLauncher-5c913149c84c121523a1ae403848d3e0926de244.zip
Merge branch 'PrismLauncher:develop' into modrinth-token
Diffstat (limited to 'launcher/ui/pages/modplatform/TexturePackPage.h')
-rw-r--r--launcher/ui/pages/modplatform/TexturePackPage.h50
1 files changed, 50 insertions, 0 deletions
diff --git a/launcher/ui/pages/modplatform/TexturePackPage.h b/launcher/ui/pages/modplatform/TexturePackPage.h
new file mode 100644
index 00000000..0bdce2f9
--- /dev/null
+++ b/launcher/ui/pages/modplatform/TexturePackPage.h
@@ -0,0 +1,50 @@
+// SPDX-FileCopyrightText: 2023 flowln <flowlnlnln@gmail.com>
+//
+// SPDX-License-Identifier: GPL-3.0-only
+
+#pragma once
+
+#include "ui_ResourcePage.h"
+#include "ui/dialogs/ResourceDownloadDialog.h"
+#include "ui/pages/modplatform/ResourcePackPage.h"
+#include "ui/pages/modplatform/TexturePackModel.h"
+
+namespace Ui {
+class ResourcePage;
+}
+
+namespace ResourceDownload {
+
+class TexturePackDownloadDialog;
+
+class TexturePackResourcePage : public ResourcePackResourcePage {
+ Q_OBJECT
+
+ public:
+ template <typename T>
+ static T* create(TexturePackDownloadDialog* dialog, BaseInstance& instance)
+ {
+ auto page = new T(dialog, instance);
+ auto model = static_cast<TexturePackResourceModel*>(page->getModel());
+
+ connect(model, &ResourceModel::versionListUpdated, page, &ResourcePage::updateVersionList);
+ connect(model, &ResourceModel::projectInfoUpdated, page, &ResourcePage::updateUi);
+
+ return page;
+ }
+
+ //: The plural version of 'texture pack'
+ [[nodiscard]] inline QString resourcesString() const override { return tr("texture packs"); }
+ //: The singular version of 'texture packs'
+ [[nodiscard]] inline QString resourceString() const override { return tr("texture pack"); }
+
+ protected:
+ TexturePackResourcePage(TexturePackDownloadDialog* dialog, BaseInstance& instance)
+ : ResourcePackResourcePage(dialog, instance)
+ {
+ connect(m_ui->searchButton, &QPushButton::clicked, this, &TexturePackResourcePage::triggerSearch);
+ connect(m_ui->packView, &QListView::doubleClicked, this, &TexturePackResourcePage::onResourceSelected);
+ }
+};
+
+} // namespace ResourceDownload