diff options
author | Petr Mrázek <peterix@users.noreply.github.com> | 2020-11-30 00:13:41 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-11-30 00:13:41 +0100 |
commit | 58d168bda2fecb42debfb1ce047d6985f64d475d (patch) | |
tree | 8091a6268745cf0228ef1739a6e9172fcfd3e040 /application/pages/modplatform/ftb/FtbListModel.h | |
parent | ed11d33054307be9a8f52689e2706085c3742420 (diff) | |
parent | 5eace10d51d862efa944418c4473fb053b5b04b4 (diff) | |
download | PrismLauncher-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.h | 68 |
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; +}; + +} |