NOISSUE Added FTB Pack logos to chooser and fixed some missing includes

This commit is contained in:
Janrupf 2018-04-01 20:24:28 +02:00
parent 67d2f283da
commit bbd523acb8
14 changed files with 306 additions and 191 deletions

View File

@ -421,10 +421,6 @@ set(META_SOURCES
) )
set(FTB_SOURCES set(FTB_SOURCES
# Modplatform sources
modplatform/ftb/FtbPackDownloader.h
modplatform/ftb/FtbPackDownloader.cpp
modplatform/ftb/FtbPackFetchTask.h modplatform/ftb/FtbPackFetchTask.h
modplatform/ftb/FtbPackFetchTask.cpp modplatform/ftb/FtbPackFetchTask.cpp
modplatform/ftb/FtbPackInstallTask.h modplatform/ftb/FtbPackInstallTask.h

View File

@ -1,4 +1,6 @@
#pragma once #pragma once
#include <QWriteLocker>
#include <QReadLocker>
template <typename K, typename V> template <typename K, typename V>
class RWStorage class RWStorage
{ {

View File

@ -1,57 +0,0 @@
#include "FtbPackDownloader.h"
#include "PackHelpers.h"
#include "FtbPackFetchTask.h"
#include "Env.h"
FtbPackDownloader::FtbPackDownloader()
{
done = false;
fetching = false;
}
FtbPackDownloader::~FtbPackDownloader()
{
}
FtbModpackList FtbPackDownloader::getModpacks()
{
return static_cast<FtbModpackList>(fetchedPacks.values());
}
void FtbPackDownloader::fetchModpacks(bool force = false)
{
if(fetching || (!force && done))
{
qDebug() << "Skipping modpack refetch because done or already fetching [done =>" << done << "| fetching =>" << fetching << "]";
return;
}
fetching = true;
fetchTask = new FtbPackFetchTask();
connect(fetchTask, &FtbPackFetchTask::finished, this, &FtbPackDownloader::fetchSuccess);
connect(fetchTask, &FtbPackFetchTask::failed, this, &FtbPackDownloader::fetchFailed);
fetchTask->fetch();
}
void FtbPackDownloader::fetchSuccess(FtbModpackList modpacks)
{
for(int i = 0; i < modpacks.size(); i++)
{
fetchedPacks.insert(modpacks.at(i).name, modpacks.at(i));
}
fetching = false;
done = true;
emit ready();
fetchTask->deleteLater();
}
void FtbPackDownloader::fetchFailed(QString reason)
{
qWarning() << "Failed to fetch FtbData" << reason;
fetching = false;
emit packFetchFailed();
fetchTask->deleteLater();
}

View File

@ -1,39 +0,0 @@
#include <QString>
#include <QUrl>
#include <QList>
#include <QObject>
#include "FtbPackFetchTask.h"
#include "tasks/Task.h"
#include "net/NetJob.h"
#include "PackHelpers.h"
#include "Env.h"
#pragma once
class MULTIMC_LOGIC_EXPORT FtbPackDownloader : public QObject
{
Q_OBJECT
public:
FtbPackDownloader();
virtual ~FtbPackDownloader();
void fetchModpacks(bool force);
FtbModpackList getModpacks();
signals:
void ready();
void packFetchFailed();
private slots:
void fetchSuccess(FtbModpackList modlist);
void fetchFailed(QString reason);
private:
QMap<QString, FtbModpack> fetchedPacks;
bool fetching = false;
bool done = false;
FtbPackFetchTask *fetchTask = 0;
};

View File

@ -1,21 +1,25 @@
#include "FtbPackFetchTask.h" #include "FtbPackFetchTask.h"
#include <QDomDocument> #include <QDomDocument>
FtbPackFetchTask::FtbPackFetchTask() { FtbPackFetchTask::FtbPackFetchTask()
{
} }
FtbPackFetchTask::~FtbPackFetchTask() { FtbPackFetchTask::~FtbPackFetchTask()
{
} }
void FtbPackFetchTask::fetch() { void FtbPackFetchTask::fetch()
{
NetJob *netJob = new NetJob("FtbModpackFetch"); NetJob *netJob = new NetJob("FtbModpackFetch");
QUrl url = QUrl("https://ftb.cursecdn.com/FTB2/static/modpacks.xml"); QUrl publicPacksUrl = QUrl("https://ftb.cursecdn.com/FTB2/static/modpacks.xml");
qDebug() << "Downloading version info from " << url.toString(); qDebug() << "Downloading public version info from" << publicPacksUrl.toString();
netJob->addNetAction(Net::Download::makeByteArray(publicPacksUrl, &publicModpacksXmlFileData));
netJob->addNetAction(downloadPtr = Net::Download::makeByteArray(url, &modpacksXmlFileData)); QUrl thirdPartyUrl = QUrl("https://ftb.cursecdn.com/FTB2/static/thirdparty.xml");
qDebug() << "Downloading thirdparty version info from" << thirdPartyUrl.toString();
netJob->addNetAction(Net::Download::makeByteArray(thirdPartyUrl, &thirdPartyModpacksXmlFileData));
QObject::connect(netJob, &NetJob::succeeded, this, &FtbPackFetchTask::fileDownloadFinished); QObject::connect(netJob, &NetJob::succeeded, this, &FtbPackFetchTask::fileDownloadFinished);
QObject::connect(netJob, &NetJob::failed, this, &FtbPackFetchTask::fileDownloadFailed); QObject::connect(netJob, &NetJob::failed, this, &FtbPackFetchTask::fileDownloadFailed);
@ -24,28 +28,42 @@ void FtbPackFetchTask::fetch() {
netJob->start(); netJob->start();
} }
void FtbPackFetchTask::fileDownloadFinished(){ void FtbPackFetchTask::fileDownloadFinished()
{
jobPtr.reset(); jobPtr.reset();
QStringList failedLists;
if(!parseAndAddPacks(publicModpacksXmlFileData, FtbPackType::Public, publicPacks)) {
failedLists.append(tr("Public Packs"));
}
if(!parseAndAddPacks(thirdPartyModpacksXmlFileData, FtbPackType::ThirdParty, thirdPartyPacks)) {
failedLists.append(tr("Third Party Packs"));
}
if(failedLists.size() > 0) {
emit failed(QString("Failed to download some pack lists:%1").arg(failedLists.join("\n- ")));
} else {
emit finished(publicPacks, thirdPartyPacks);
}
}
bool FtbPackFetchTask::parseAndAddPacks(QByteArray &data, FtbPackType packType, FtbModpackList &list)
{
QDomDocument doc; QDomDocument doc;
QString errorMsg = "Unknown error."; QString errorMsg = "Unknown error.";
int errorLine = -1; int errorLine = -1;
int errorCol = -1; int errorCol = -1;
if(!doc.setContent(modpacksXmlFileData, false, &errorMsg, &errorLine, &errorCol)){ if(!doc.setContent(data, false, &errorMsg, &errorLine, &errorCol)){
auto fullErrMsg = QString("Failed to fetch modpack data: %s %d:%d!").arg(errorMsg, errorLine, errorCol); auto fullErrMsg = QString("Failed to fetch modpack data: %s %d:%d!").arg(errorMsg, errorLine, errorCol);
qWarning() << fullErrMsg; qWarning() << fullErrMsg;
emit failed(fullErrMsg); data.clear();
modpacksXmlFileData.clear(); return false;
return;
} }
modpacksXmlFileData.clear();
FtbModpackList modpackList;
QDomNodeList nodes = doc.elementsByTagName("modpack"); QDomNodeList nodes = doc.elementsByTagName("modpack");
for(int i = 0; i < nodes.length(); i++) { for(int i = 0; i < nodes.length(); i++) {
QDomElement element = nodes.at(i).toElement(); QDomElement element = nodes.at(i).toElement();
@ -56,7 +74,7 @@ void FtbPackFetchTask::fileDownloadFinished(){
modpack.mcVersion = element.attribute("mcVersion"); modpack.mcVersion = element.attribute("mcVersion");
modpack.description = element.attribute("description"); modpack.description = element.attribute("description");
modpack.mods = element.attribute("mods"); modpack.mods = element.attribute("mods");
modpack.image = element.attribute("image"); modpack.logo = element.attribute("logo");
modpack.oldVersions = element.attribute("oldVersions").split(";"); modpack.oldVersions = element.attribute("oldVersions").split(";");
modpack.broken = false; modpack.broken = false;
modpack.bugged = false; modpack.bugged = false;
@ -85,11 +103,12 @@ void FtbPackFetchTask::fileDownloadFinished(){
modpack.dir = element.attribute("dir"); modpack.dir = element.attribute("dir");
modpack.file = element.attribute("url"); modpack.file = element.attribute("url");
modpackList.append(modpack); modpack.type = packType;
list.append(modpack);
} }
return true;
emit finished(modpackList);
} }
void FtbPackFetchTask::fileDownloadFailed(QString reason){ void FtbPackFetchTask::fileDownloadFailed(QString reason){

View File

@ -18,16 +18,20 @@ public:
private: private:
NetJobPtr jobPtr; NetJobPtr jobPtr;
Net::Download::Ptr downloadPtr;
QByteArray modpacksXmlFileData; QByteArray publicModpacksXmlFileData;
QByteArray thirdPartyModpacksXmlFileData;
bool parseAndAddPacks(QByteArray &data, FtbPackType packType, FtbModpackList &list);
FtbModpackList publicPacks;
FtbModpackList thirdPartyPacks;
protected slots: protected slots:
void fileDownloadFinished(); void fileDownloadFinished();
void fileDownloadFailed(QString reason); void fileDownloadFailed(QString reason);
signals: signals:
void finished(FtbModpackList list); void finished(FtbModpackList publicPacks, FtbModpackList thirdPartyPacks);
void failed(QString reason); void failed(QString reason);
}; };

View File

@ -1,6 +1,5 @@
#pragma once #pragma once
#include "InstanceTask.h" #include "InstanceTask.h"
#include "modplatform/ftb/FtbPackDownloader.h"
#include "BaseInstanceProvider.h" #include "BaseInstanceProvider.h"
#include "net/NetJob.h" #include "net/NetJob.h"
#include "quazip.h" #include "quazip.h"
@ -8,6 +7,7 @@
#include "meta/Index.h" #include "meta/Index.h"
#include "meta/Version.h" #include "meta/Version.h"
#include "meta/VersionList.h" #include "meta/VersionList.h"
#include "modplatform/ftb/PackHelpers.h"
class MULTIMC_LOGIC_EXPORT FtbPackInstallTask : public InstanceTask { class MULTIMC_LOGIC_EXPORT FtbPackInstallTask : public InstanceTask {

View File

@ -3,6 +3,12 @@
#include "qmetatype.h" #include "qmetatype.h"
//Header for structs etc... //Header for structs etc...
enum FtbPackType {
Public,
ThirdParty,
Private
};
struct FtbModpack { struct FtbModpack {
QString name; QString name;
QString description; QString description;
@ -11,15 +17,18 @@ struct FtbModpack {
QString currentVersion; QString currentVersion;
QString mcVersion; QString mcVersion;
QString mods; QString mods;
QString image; QString logo;
//Technical data //Technical data
QString dir; QString dir;
QString file; //<- Url in the xml, but doesn't make much sense QString file; //<- Url in the xml, but doesn't make much sense
bool bugged = true; bool bugged = false;
bool broken = true; bool broken = false;
FtbPackType type;
}; };
//We need it for the proxy model //We need it for the proxy model
Q_DECLARE_METATYPE(FtbModpack) Q_DECLARE_METATYPE(FtbModpack)

View File

@ -5,12 +5,16 @@
#include <Version.h> #include <Version.h>
#include <QtMath> #include <QtMath>
#include <QLabel>
#include <RWStorage.h>
#include <Env.h>
FtbFilterModel::FtbFilterModel(QObject *parent) : QSortFilterProxyModel(parent) FtbFilterModel::FtbFilterModel(QObject *parent) : QSortFilterProxyModel(parent)
{ {
currentSorting = Sorting::ByGameVersion; currentSorting = Sorting::ByGameVersion;
sortings.insert("Sort by name", Sorting::ByName); sortings.insert(tr("Sort by name"), Sorting::ByName);
sortings.insert("Sort by game version", Sorting::ByGameVersion); sortings.insert(tr("Sort by game version"), Sorting::ByGameVersion);
} }
bool FtbFilterModel::lessThan(const QModelIndex &left, const QModelIndex &right) const bool FtbFilterModel::lessThan(const QModelIndex &left, const QModelIndex &right) const
@ -42,6 +46,11 @@ const QMap<QString, FtbFilterModel::Sorting> FtbFilterModel::getAvailableSorting
return sortings; return sortings;
} }
QString FtbFilterModel::translateCurrentSorting()
{
return sortings.key(currentSorting);
}
void FtbFilterModel::setSorting(Sorting s) void FtbFilterModel::setSorting(Sorting s)
{ {
currentSorting = s; currentSorting = s;
@ -55,6 +64,27 @@ FtbFilterModel::Sorting FtbFilterModel::getCurrentSorting()
FtbListModel::FtbListModel(QObject *parent) : QAbstractListModel(parent) FtbListModel::FtbListModel(QObject *parent) : QAbstractListModel(parent)
{ {
m_logoPool = new QThreadPool(this);
m_logoPool->setMaxThreadCount(4);
}
FtbListModel::~FtbListModel()
{
m_logoPool->waitForDone(500);
m_logoPool->deleteLater();
}
QString FtbListModel::translatePackType(FtbPackType type) const
{
if(type == FtbPackType::Public) {
return tr("Public Modpack");
} else if(type == FtbPackType::ThirdParty) {
return tr("Third Party Modpack");
} else if(type == FtbPackType::Private) {
return tr("Private Modpack");
} else {
return tr("Unknown Type");
}
} }
int FtbListModel::rowCount(const QModelIndex &parent) const int FtbListModel::rowCount(const QModelIndex &parent) const
@ -70,14 +100,13 @@ int FtbListModel::columnCount(const QModelIndex &parent) const
QVariant FtbListModel::data(const QModelIndex &index, int role) const QVariant FtbListModel::data(const QModelIndex &index, int role) const
{ {
int pos = index.row(); int pos = index.row();
if(modpacks.size() <= pos || pos < 0) { if(modpacks.size() <= pos || pos < 0 || !index.isValid()) {
return QString("INVALID INDEX %1").arg(pos); return QString("INVALID INDEX %1").arg(pos);
} }
FtbModpack pack = modpacks.at(pos); FtbModpack pack = modpacks.at(pos);
if(role == Qt::DisplayRole) { if(role == Qt::DisplayRole) {
return pack.name; return pack.name + "\n" + translatePackType(pack.type);
} else if (role == Qt::ToolTipRole) { } else if (role == Qt::ToolTipRole) {
if(pack.description.length() > 100) { if(pack.description.length() > 100) {
//some magic to prevent to long tooltips and replace html linebreaks //some magic to prevent to long tooltips and replace html linebreaks
@ -88,7 +117,12 @@ QVariant FtbListModel::data(const QModelIndex &index, int role) const
} }
return pack.description; return pack.description;
} else if(role == Qt::DecorationRole) { } else if(role == Qt::DecorationRole) {
//TODO: Add pack logos or something... but they have a weird size. This needs some design hacks if(m_logoMap.contains(pack.logo)) {
return (m_logoMap.value(pack.logo));
}
QPixmap pixmap = MMC->getThemedIcon("screenshot-placeholder").pixmap(QSize(42, 42));
((FtbListModel *)this)->requestLogo(pack.logo);
return pixmap;
} else if(role == Qt::TextColorRole) { } else if(role == Qt::TextColorRole) {
if(pack.broken) { if(pack.broken) {
//FIXME: Hardcoded color //FIXME: Hardcoded color
@ -103,6 +137,7 @@ QVariant FtbListModel::data(const QModelIndex &index, int role) const
v.setValue(pack); v.setValue(pack);
return v; return v;
} }
return QVariant(); return QVariant();
} }
@ -117,3 +152,47 @@ FtbModpack FtbListModel::at(int row)
{ {
return modpacks.at(row); return modpacks.at(row);
} }
void FtbListModel::logoLoaded(QString logo, QPixmap out)
{
m_loadingLogos.removeAll(logo);
m_logoMap.insert(logo, out);
emit dataChanged(createIndex(0, 0), createIndex(modpacks.size(), 0));
}
void FtbListModel::logoFailed(QString logo)
{
m_failedLogos.append(logo);
m_loadingLogos.removeAll(logo);
}
void FtbListModel::requestLogo(QString file)
{
if(m_loadingLogos.contains(file) || m_failedLogos.contains(file)) {
return;
}
MetaEntryPtr entry = ENV.metacache()->resolveEntry("FTBPacks", QString("logos/%1").arg(file));
NetJob *job = new NetJob(QString("FTB Icon Download for %1").arg(file));
job->addNetAction(Net::Download::makeCached(QUrl(QString("https://ftb.cursecdn.com/FTB2/static/%1").arg(file)), entry));
QString *_file = new QString(file);
MetaEntry *_entry = entry.get();
QObject::connect(job, &NetJob::finished, this, [this, _file, _entry]{
QPixmap pixmap;
pixmap.load(_entry->getFullPath());
pixmap = pixmap.scaled(QSize(42, 42));
emit logoLoaded(*_file, pixmap);
});
QObject::connect(job, &NetJob::failed, this, [this, _file]{
emit logoFailed(*_file);
});
job->start();
m_loadingLogos.append(file);
}
#include "FtbListModel.moc"

View File

@ -3,6 +3,13 @@
#include <QAbstractListModel> #include <QAbstractListModel>
#include <QSortFilterProxyModel> #include <QSortFilterProxyModel>
#include <modplatform/ftb/PackHelpers.h> #include <modplatform/ftb/PackHelpers.h>
#include <QThreadPool>
#include <RWStorage.h>
#include <QPixmap>
typedef QMap<QString, QPixmap> FtbLogoMap;
class FtbFilterModel : public QSortFilterProxyModel class FtbFilterModel : public QSortFilterProxyModel
{ {
@ -13,8 +20,9 @@ public:
ByGameVersion ByGameVersion
}; };
const QMap<QString, Sorting> getAvailableSortings(); const QMap<QString, Sorting> getAvailableSortings();
Sorting getCurrentSorting(); QString translateCurrentSorting();
void setSorting(Sorting sorting); void setSorting(Sorting sorting);
Sorting getCurrentSorting();
protected: protected:
bool filterAcceptsRow(int sourceRow, const QModelIndex &sourceParent) const override; bool filterAcceptsRow(int sourceRow, const QModelIndex &sourceParent) const override;
@ -31,9 +39,22 @@ class FtbListModel : public QAbstractListModel
Q_OBJECT Q_OBJECT
private: private:
FtbModpackList modpacks; FtbModpackList modpacks;
QThreadPool *m_logoPool;
QStringList m_failedLogos;
QStringList m_loadingLogos;
FtbLogoMap m_logoMap;
void requestLogo(QString file);
QString translatePackType(FtbPackType type) const;
private slots:
void logoFailed(QString logo);
void logoLoaded(QString logo, QPixmap out);
public: public:
FtbListModel(QObject *parent); FtbListModel(QObject *parent);
~FtbListModel();
int rowCount(const QModelIndex &parent) const override; int rowCount(const QModelIndex &parent) const override;
int columnCount(const QModelIndex &parent) const override; int columnCount(const QModelIndex &parent) const override;
QVariant data(const QModelIndex &index, int role) const override; QVariant data(const QModelIndex &index, int role) const override;

View File

@ -25,7 +25,6 @@
#include "minecraft/auth/MojangAccount.h" #include "minecraft/auth/MojangAccount.h"
#include "net/NetJob.h" #include "net/NetJob.h"
#include "updater/GoUpdate.h" #include "updater/GoUpdate.h"
#include <modplatform/ftb/FtbPackDownloader.h>
class LaunchController; class LaunchController;
class NewsChecker; class NewsChecker;

View File

@ -5,41 +5,53 @@
#include "FolderInstanceProvider.h" #include "FolderInstanceProvider.h"
#include "dialogs/CustomMessageBox.h" #include "dialogs/CustomMessageBox.h"
#include "dialogs/NewInstanceDialog.h" #include "dialogs/NewInstanceDialog.h"
#include "modplatform/ftb/FtbPackDownloader.h" #include "modplatform/ftb/FtbPackFetchTask.h"
#include "modplatform/ftb/FtbPackInstallTask.h" #include "modplatform/ftb/FtbPackInstallTask.h"
#include <FtbListModel.h> #include <FtbListModel.h>
FTBPage::FTBPage(NewInstanceDialog* dialog, QWidget *parent) FTBPage::FTBPage(NewInstanceDialog* dialog, QWidget *parent)
: QWidget(parent), dialog(dialog), ui(new Ui::FTBPage) : QWidget(parent), dialog(dialog), ui(new Ui::FTBPage)
{ {
ftbFetchTask = new FtbPackFetchTask();
ui->setupUi(this); ui->setupUi(this);
ui->tabWidget->tabBar()->hide(); ui->tabWidget->tabBar()->hide();
ftbPackDownloader = new FtbPackDownloader();
connect(ftbPackDownloader, &FtbPackDownloader::ready, this, &FTBPage::ftbPackDataDownloadSuccessfully);
connect(ftbPackDownloader, &FtbPackDownloader::packFetchFailed, this, &FTBPage::ftbPackDataDownloadFailed);
filterModel = new FtbFilterModel(this);
listModel = new FtbListModel(this);
filterModel->setSourceModel(listModel);
ui->packList->setModel(filterModel);
ui->packList->setSortingEnabled(true);
ui->packList->header()->hide();
ui->packList->setIndentation(0);
filterModel->setSorting(FtbFilterModel::Sorting::ByName);
for(int i = 0; i < filterModel->getAvailableSortings().size(); i++)
{ {
ui->sortByBox->addItem(filterModel->getAvailableSortings().keys().at(i)); publicFilterModel = new FtbFilterModel(this);
publicListModel = new FtbListModel(this);
publicFilterModel->setSourceModel(publicListModel);
ui->publicPackList->setModel(publicFilterModel);
ui->publicPackList->setSortingEnabled(true);
ui->publicPackList->header()->hide();
ui->publicPackList->setIndentation(0);
for(int i = 0; i < publicFilterModel->getAvailableSortings().size(); i++)
{
ui->sortByBox->addItem(publicFilterModel->getAvailableSortings().keys().at(i));
} }
ui->sortByBox->setCurrentText(filterModel->getAvailableSortings().key(filterModel->getCurrentSorting())); ui->sortByBox->setCurrentText(publicFilterModel->translateCurrentSorting());
}
{
thirdPartyFilterModel = new FtbFilterModel(this);
thirdPartyModel = new FtbListModel(this);
thirdPartyFilterModel->setSourceModel(thirdPartyModel);
ui->thirdPartyPackList->setModel(thirdPartyFilterModel);
ui->thirdPartyPackList->setSortingEnabled(true);
ui->thirdPartyPackList->header()->hide();
ui->thirdPartyPackList->setIndentation(0);
thirdPartyFilterModel->setSorting(publicFilterModel->getCurrentSorting());
}
connect(ui->sortByBox, &QComboBox::currentTextChanged, this, &FTBPage::onSortingSelectionChanged); connect(ui->sortByBox, &QComboBox::currentTextChanged, this, &FTBPage::onSortingSelectionChanged);
connect(ui->packVersionSelection, &QComboBox::currentTextChanged, this, &FTBPage::onVersionSelectionItemChanged); connect(ui->packVersionSelection, &QComboBox::currentTextChanged, this, &FTBPage::onVersionSelectionItemChanged);
connect(ui->packList->selectionModel(), &QItemSelectionModel::currentChanged, this, &FTBPage::onPackSelectionChanged);
connect(ui->publicPackList->selectionModel(), &QItemSelectionModel::currentChanged, this, &FTBPage::onPublicPackSelectionChanged);
connect(ui->thirdPartyPackList->selectionModel(), &QItemSelectionModel::currentChanged, this, &FTBPage::onThirdPartyPackSelectionChanged);
ui->modpackInfo->setOpenExternalLinks(true); ui->modpackInfo->setOpenExternalLinks(true);
} }
@ -47,9 +59,8 @@ FTBPage::FTBPage(NewInstanceDialog* dialog, QWidget *parent)
FTBPage::~FTBPage() FTBPage::~FTBPage()
{ {
delete ui; delete ui;
if(ftbPackDownloader) if(ftbFetchTask) {
{ ftbFetchTask->deleteLater();
ftbPackDownloader->deleteLater();
} }
} }
@ -62,7 +73,9 @@ void FTBPage::openedImpl()
{ {
if(!initialized) if(!initialized)
{ {
ftbPackDownloader->fetchModpacks(false); connect(ftbFetchTask, &FtbPackFetchTask::finished, this, &FTBPage::ftbPackDataDownloadSuccessfully);
connect(ftbFetchTask, &FtbPackFetchTask::failed, this, &FTBPage::ftbPackDataDownloadFailed);
ftbFetchTask->fetch();
initialized = true; initialized = true;
} }
suggestCurrent(); suggestCurrent();
@ -83,25 +96,31 @@ void FTBPage::suggestCurrent()
} }
} }
FtbPackDownloader *FTBPage::getFtbPackDownloader() void FTBPage::ftbPackDataDownloadSuccessfully(FtbModpackList publicPacks, FtbModpackList thirdPartyPacks)
{ {
return ftbPackDownloader; publicListModel->fill(publicPacks);
thirdPartyModel->fill(thirdPartyPacks);
} }
void FTBPage::ftbPackDataDownloadSuccessfully() void FTBPage::ftbPackDataDownloadFailed(QString reason)
{ {
listModel->fill(ftbPackDownloader->getModpacks()); //TODO: Display the error
} }
void FTBPage::ftbPackDataDownloadFailed() void FTBPage::onPublicPackSelectionChanged(QModelIndex first, QModelIndex second)
{ {
qDebug() << "Stuff went missing while grabbing FTB pack list or something..."; onPackSelectionChanged(first, second, publicFilterModel);
} }
void FTBPage::onPackSelectionChanged(QModelIndex now, QModelIndex prev) void FTBPage::onThirdPartyPackSelectionChanged(QModelIndex first, QModelIndex second)
{
onPackSelectionChanged(first, second, thirdPartyFilterModel);
}
void FTBPage::onPackSelectionChanged(QModelIndex now, QModelIndex prev, FtbFilterModel *model)
{ {
ui->packVersionSelection->clear(); ui->packVersionSelection->clear();
FtbModpack selectedPack = filterModel->data(now, Qt::UserRole).value<FtbModpack>(); FtbModpack selectedPack = model->data(now, Qt::UserRole).value<FtbModpack>();
ui->modpackInfo->setHtml("Pack by <b>" + selectedPack.author + "</b>" + "<br>Minecraft " + selectedPack.mcVersion + "<br>" ui->modpackInfo->setHtml("Pack by <b>" + selectedPack.author + "</b>" + "<br>Minecraft " + selectedPack.mcVersion + "<br>"
"<br>" + selectedPack.description + "<ul><li>" + selectedPack.mods.replace(";", "</li><li>") + "</li></ul>"); "<br>" + selectedPack.description + "<ul><li>" + selectedPack.mods.replace(";", "</li><li>") + "</li></ul>");
@ -149,5 +168,7 @@ QString FTBPage::getSelectedVersion()
void FTBPage::onSortingSelectionChanged(QString data) void FTBPage::onSortingSelectionChanged(QString data)
{ {
filterModel->setSorting(filterModel->getAvailableSortings().value(data)); FtbFilterModel::Sorting toSet = publicFilterModel->getAvailableSortings().value(data);
publicFilterModel->setSorting(toSet);
thirdPartyFilterModel->setSorting(toSet);
} }

View File

@ -21,6 +21,7 @@
#include <MultiMC.h> #include <MultiMC.h>
#include "tasks/Task.h" #include "tasks/Task.h"
#include "modplatform/ftb/PackHelpers.h" #include "modplatform/ftb/PackHelpers.h"
#include "modplatform/ftb/FtbPackFetchTask.h"
namespace Ui namespace Ui
{ {
@ -29,7 +30,6 @@ class FTBPage;
class FtbListModel; class FtbListModel;
class FtbFilterModel; class FtbFilterModel;
class FtbPackDownloader;
class NewInstanceDialog; class NewInstanceDialog;
class FTBPage : public QWidget, public BasePage class FTBPage : public QWidget, public BasePage
@ -58,28 +58,36 @@ public:
bool shouldDisplay() const override; bool shouldDisplay() const override;
void openedImpl() override; void openedImpl() override;
FtbPackDownloader* getFtbPackDownloader();
FtbModpack getSelectedModpack(); FtbModpack getSelectedModpack();
QString getSelectedVersion(); QString getSelectedVersion();
private: private:
void suggestCurrent(); void suggestCurrent();
void onPackSelectionChanged(QModelIndex first, QModelIndex second, FtbFilterModel *model);
private slots: private slots:
void ftbPackDataDownloadSuccessfully(); void ftbPackDataDownloadSuccessfully(FtbModpackList publicPacks, FtbModpackList thirdPartyPacks);
void ftbPackDataDownloadFailed(); void ftbPackDataDownloadFailed(QString reason);
void onSortingSelectionChanged(QString data); void onSortingSelectionChanged(QString data);
void onVersionSelectionItemChanged(QString data); void onVersionSelectionItemChanged(QString data);
void onPackSelectionChanged(QModelIndex first, QModelIndex second);
void onPublicPackSelectionChanged(QModelIndex first, QModelIndex second);
void onThirdPartyPackSelectionChanged(QModelIndex first, QModelIndex second);
private: private:
bool initialized = false; bool initialized = false;
FtbPackDownloader* ftbPackDownloader = nullptr;
FtbModpack selectedPack; FtbModpack selectedPack;
FtbModpack selected; FtbModpack selected;
QString selectedVersion; QString selectedVersion;
FtbListModel* listModel = nullptr;
FtbFilterModel* filterModel = nullptr; FtbListModel* publicListModel = nullptr;
FtbFilterModel* publicFilterModel = nullptr;
FtbListModel *thirdPartyModel = nullptr;
FtbFilterModel *thirdPartyFilterModel = nullptr;
FtbPackFetchTask *ftbFetchTask;
NewInstanceDialog* dialog = nullptr; NewInstanceDialog* dialog = nullptr;
Ui::FTBPage *ui = nullptr; Ui::FTBPage *ui = nullptr;

View File

@ -10,7 +10,7 @@
<height>602</height> <height>602</height>
</rect> </rect>
</property> </property>
<layout class="QVBoxLayout" name="verticalLayout"> <layout class="QGridLayout" name="gridLayout_2">
<property name="leftMargin"> <property name="leftMargin">
<number>0</number> <number>0</number>
</property> </property>
@ -23,7 +23,7 @@
<property name="bottomMargin"> <property name="bottomMargin">
<number>0</number> <number>0</number>
</property> </property>
<item> <item row="0" column="0">
<widget class="QTabWidget" name="tabWidget"> <widget class="QTabWidget" name="tabWidget">
<property name="currentIndex"> <property name="currentIndex">
<number>0</number> <number>0</number>
@ -32,17 +32,15 @@
<attribute name="title"> <attribute name="title">
<string notr="true"/> <string notr="true"/>
</attribute> </attribute>
<layout class="QGridLayout" name="gridLayout" columnstretch="0,0,4,4"> <layout class="QGridLayout" name="gridLayout" columnstretch="0,0,0,0">
<item row="0" column="0" colspan="2"> <item row="1" column="2" colspan="2">
<widget class="QTreeView" name="packList"/> <widget class="QTextBrowser" name="modpackInfo">
<property name="verticalScrollBarPolicy">
<enum>Qt::ScrollBarAsNeeded</enum>
</property>
</widget>
</item> </item>
<item row="0" column="2" colspan="2"> <item row="2" column="2">
<widget class="QTextBrowser" name="modpackInfo"/>
</item>
<item row="1" column="3">
<widget class="QComboBox" name="packVersionSelection"/>
</item>
<item row="1" column="2">
<widget class="QLabel" name="selectedVersionLabel"> <widget class="QLabel" name="selectedVersionLabel">
<property name="text"> <property name="text">
<string>Version selected:</string> <string>Version selected:</string>
@ -52,9 +50,64 @@
</property> </property>
</widget> </widget>
</item> </item>
<item row="1" column="0" colspan="2"> <item row="2" column="3">
<widget class="QComboBox" name="packVersionSelection"/>
</item>
<item row="2" column="0">
<widget class="QComboBox" name="sortByBox"/> <widget class="QComboBox" name="sortByBox"/>
</item> </item>
<item row="0" column="0" rowspan="2">
<widget class="QTabWidget" name="tabWidget_2">
<property name="sizePolicy">
<sizepolicy hsizetype="Preferred" vsizetype="Expanding">
<horstretch>0</horstretch>
<verstretch>0</verstretch>
</sizepolicy>
</property>
<property name="tabShape">
<enum>QTabWidget::Rounded</enum>
</property>
<property name="currentIndex">
<number>0</number>
</property>
<widget class="QWidget" name="tab_2">
<attribute name="title">
<string>Public Packs</string>
</attribute>
<widget class="QTreeView" name="publicPackList">
<property name="geometry">
<rect>
<x>0</x>
<y>0</y>
<width>221</width>
<height>491</height>
</rect>
</property>
<property name="verticalScrollBarPolicy">
<enum>Qt::ScrollBarAlwaysOn</enum>
</property>
</widget>
</widget>
<widget class="QWidget" name="tab_3">
<attribute name="title">
<string>3rd Party Packs</string>
</attribute>
<widget class="QTreeView" name="thirdPartyPackList">
<property name="geometry">
<rect>
<x>0</x>
<y>0</y>
<width>221</width>
<height>491</height>
</rect>
</property>
<property name="verticalScrollBarPolicy">
<enum>Qt::ScrollBarAlwaysOn</enum>
</property>
</widget>
</widget>
</widget>
</item>
</layout> </layout>
</widget> </widget>
</widget> </widget>