diff options
author | Petr Mrázek <peterix@users.noreply.github.com> | 2021-03-26 00:38:58 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-03-26 00:38:58 +0000 |
commit | 369a243f1f04b6c2e18309fbcddc7389fc7f6ce4 (patch) | |
tree | f30aa799d5b728af4fff6074af1eeecb28385c10 /application/pages/modplatform/flame/FlameModel.h | |
parent | 1db6985be269680c4e0277e698790164241bf604 (diff) | |
parent | a0cb1a0d427087c84690224b37c2c9d0fba4f6cb (diff) | |
download | PrismLauncher-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.h | 75 |
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; +}; + +} |