summaryrefslogtreecommitdiffstats
path: root/application/FtbListModel.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'application/FtbListModel.cpp')
-rw-r--r--application/FtbListModel.cpp19
1 files changed, 6 insertions, 13 deletions
diff --git a/application/FtbListModel.cpp b/application/FtbListModel.cpp
index 41e49b65..7bf0a601 100644
--- a/application/FtbListModel.cpp
+++ b/application/FtbListModel.cpp
@@ -64,14 +64,10 @@ FtbFilterModel::Sorting FtbFilterModel::getCurrentSorting()
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
@@ -100,7 +96,7 @@ int FtbListModel::columnCount(const QModelIndex &parent) const
QVariant FtbListModel::data(const QModelIndex &index, int role) const
{
int pos = index.row();
- if(modpacks.size() <= pos || pos < 0 || !index.isValid()) {
+ if(pos >= modpacks.size() || pos < 0 || !index.isValid()) {
return QString("INVALID INDEX %1").arg(pos);
}
@@ -120,9 +116,9 @@ QVariant FtbListModel::data(const QModelIndex &index, int role) const
if(m_logoMap.contains(pack.logo)) {
return (m_logoMap.value(pack.logo));
}
- QPixmap pixmap = MMC->getThemedIcon("screenshot-placeholder").pixmap(QSize(42, 42));
+ QIcon icon = MMC->getThemedIcon("screenshot-placeholder");
((FtbListModel *)this)->requestLogo(pack.logo);
- return pixmap;
+ return icon;
} else if(role == Qt::TextColorRole) {
if(pack.broken) {
//FIXME: Hardcoded color
@@ -153,11 +149,11 @@ FtbModpack FtbListModel::at(int row)
return modpacks.at(row);
}
-void FtbListModel::logoLoaded(QString logo, QPixmap out)
+void FtbListModel::logoLoaded(QString logo, QIcon out)
{
m_loadingLogos.removeAll(logo);
m_logoMap.insert(logo, out);
- emit dataChanged(createIndex(0, 0), createIndex(modpacks.size(), 0));
+ emit dataChanged(createIndex(0, 0), createIndex(1, 0));
}
void FtbListModel::logoFailed(QString logo)
@@ -178,10 +174,7 @@ void FtbListModel::requestLogo(QString file)
auto fullPath = entry->getFullPath();
QObject::connect(job, &NetJob::finished, this, [this, file, fullPath]{
- QPixmap pixmap;
- pixmap.load(fullPath);
- pixmap = pixmap.scaled(QSize(42, 42));
- emit logoLoaded(file, pixmap);
+ emit logoLoaded(file, QIcon(fullPath));
});
QObject::connect(job, &NetJob::failed, this, [this, file]{