aboutsummaryrefslogtreecommitdiff
path: root/application/pages/modplatform/flame/FlameModel.h
diff options
context:
space:
mode:
authorPetr Mrázek <peterix@users.noreply.github.com>2021-03-26 00:38:58 +0000
committerGitHub <noreply@github.com>2021-03-26 00:38:58 +0000
commit369a243f1f04b6c2e18309fbcddc7389fc7f6ce4 (patch)
treef30aa799d5b728af4fff6074af1eeecb28385c10 /application/pages/modplatform/flame/FlameModel.h
parent1db6985be269680c4e0277e698790164241bf604 (diff)
parenta0cb1a0d427087c84690224b37c2c9d0fba4f6cb (diff)
downloadPrismLauncher-369a243f1f04b6c2e18309fbcddc7389fc7f6ce4.tar.gz
PrismLauncher-369a243f1f04b6c2e18309fbcddc7389fc7f6ce4.tar.bz2
PrismLauncher-369a243f1f04b6c2e18309fbcddc7389fc7f6ce4.zip
Merge pull request #3682 from kb-1000/rename-twitch-curseforge
NOISSUE rename Twitch to flame internally for consistency and to CurseForge for user displayed strings
Diffstat (limited to 'application/pages/modplatform/flame/FlameModel.h')
-rw-r--r--application/pages/modplatform/flame/FlameModel.h75
1 files changed, 75 insertions, 0 deletions
diff --git a/application/pages/modplatform/flame/FlameModel.h b/application/pages/modplatform/flame/FlameModel.h
new file mode 100644
index 00000000..b4dded76
--- /dev/null
+++ b/application/pages/modplatform/flame/FlameModel.h
@@ -0,0 +1,75 @@
+#pragma once
+
+#include <RWStorage.h>
+
+#include <QAbstractListModel>
+#include <QSortFilterProxyModel>
+#include <QThreadPool>
+#include <QIcon>
+#include <QStyledItemDelegate>
+#include <QList>
+#include <QString>
+#include <QStringList>
+#include <QMetaType>
+
+#include <functional>
+#include <net/NetJob.h>
+
+#include "FlameData.h"
+
+namespace Flame {
+
+
+typedef QMap<QString, QIcon> 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;
+ Qt::ItemFlags flags(const QModelIndex &index) const override;
+ bool canFetchMore(const QModelIndex & parent) const override;
+ void fetchMore(const QModelIndex & parent) override;
+
+ void getLogo(const QString &logo, const QString &logoUrl, LogoCallback callback);
+ void searchWithTerm(const QString & term);
+
+private slots:
+ void performPaginatedSearch();
+
+ void logoFailed(QString logo);
+ void logoLoaded(QString logo, QIcon out);
+
+ void searchRequestFinished();
+ void searchRequestFailed(QString reason);
+
+private:
+ void requestLogo(QString file, QString url);
+
+private:
+ QList<Modpack> modpacks;
+ QStringList m_failedLogos;
+ QStringList m_loadingLogos;
+ LogoMap m_logoMap;
+ QMap<QString, LogoCallback> waitingCallbacks;
+
+ QString currentSearchTerm;
+ int nextSearchOffset = 0;
+ enum SearchState {
+ None,
+ CanPossiblyFetchMore,
+ ResetRequested,
+ Finished
+ } searchState = None;
+ NetJobPtr jobPtr;
+ QByteArray response;
+};
+
+}