aboutsummaryrefslogtreecommitdiff
path: root/application/pages/modplatform/ftb/FtbListModel.h
diff options
context:
space:
mode:
authorPetr Mrázek <peterix@users.noreply.github.com>2020-11-30 00:13:41 +0100
committerGitHub <noreply@github.com>2020-11-30 00:13:41 +0100
commit58d168bda2fecb42debfb1ce047d6985f64d475d (patch)
tree8091a6268745cf0228ef1739a6e9172fcfd3e040 /application/pages/modplatform/ftb/FtbListModel.h
parented11d33054307be9a8f52689e2706085c3742420 (diff)
parent5eace10d51d862efa944418c4473fb053b5b04b4 (diff)
downloadPrismLauncher-58d168bda2fecb42debfb1ce047d6985f64d475d.tar.gz
PrismLauncher-58d168bda2fecb42debfb1ce047d6985f64d475d.tar.bz2
PrismLauncher-58d168bda2fecb42debfb1ce047d6985f64d475d.zip
Merge pull request #3442 from jamierocks/ftb-sorts
NOISSUE Add sorting options to FTB pack install page
Diffstat (limited to 'application/pages/modplatform/ftb/FtbListModel.h')
-rw-r--r--application/pages/modplatform/ftb/FtbListModel.h68
1 files changed, 68 insertions, 0 deletions
diff --git a/application/pages/modplatform/ftb/FtbListModel.h b/application/pages/modplatform/ftb/FtbListModel.h
new file mode 100644
index 00000000..9c057d73
--- /dev/null
+++ b/application/pages/modplatform/ftb/FtbListModel.h
@@ -0,0 +1,68 @@
+#pragma once
+
+#include <QAbstractListModel>
+
+#include "modplatform/modpacksch/FTBPackManifest.h"
+#include "net/NetJob.h"
+#include <QIcon>
+
+namespace Ftb {
+
+struct Logo {
+ QString fullpath;
+ NetJobPtr downloadJob;
+ QIcon result;
+ bool failed = false;
+};
+
+typedef QMap<QString, Logo> LogoMap;
+typedef std::function<void(QString)> LogoCallback;
+
+class ListModel : public QAbstractListModel
+{
+ Q_OBJECT
+
+public:
+ ListModel(QObject *parent);
+ virtual ~ListModel();
+
+ int rowCount(const QModelIndex &parent) const override;
+ int columnCount(const QModelIndex &parent) const override;
+ QVariant data(const QModelIndex &index, int role) const override;
+
+ void getLogo(const QString &logo, const QString &logoUrl, LogoCallback callback);
+ void searchWithTerm(const QString & term);
+
+private slots:
+ void performSearch();
+ void searchRequestFinished();
+ void searchRequestFailed(QString reason);
+
+ void requestPack();
+ void packRequestFinished();
+ void packRequestFailed(QString reason);
+
+ void logoFailed(QString logo);
+ void logoLoaded(QString logo, bool stale);
+
+private:
+ void requestLogo(QString file, QString url);
+
+private:
+ QList<ModpacksCH::Modpack> modpacks;
+ LogoMap m_logoMap;
+
+ QString currentSearchTerm;
+ enum SearchState {
+ None,
+ CanPossiblyFetchMore,
+ ResetRequested,
+ Finished
+ } searchState = None;
+ NetJobPtr jobPtr;
+ int currentPack;
+ QList<int> remainingPacks;
+ QByteArray response;
+};
+
+}