| @@ -40,39 +40,28 @@ | ||||
|  | ||||
| #include <QIcon> | ||||
|  | ||||
| Technic::ListModel::ListModel(QObject *parent) : QAbstractListModel(parent) | ||||
| { | ||||
| } | ||||
| Technic::ListModel::ListModel(QObject* parent) : QAbstractListModel(parent) {} | ||||
|  | ||||
| Technic::ListModel::~ListModel() | ||||
| { | ||||
| } | ||||
| Technic::ListModel::~ListModel() {} | ||||
|  | ||||
| QVariant Technic::ListModel::data(const QModelIndex& index, int role) const | ||||
| { | ||||
|     int pos = index.row(); | ||||
|     if(pos >= modpacks.size() || pos < 0 || !index.isValid()) | ||||
|     { | ||||
|     if (pos >= modpacks.size() || pos < 0 || !index.isValid()) { | ||||
|         return QString("INVALID INDEX %1").arg(pos); | ||||
|     } | ||||
|  | ||||
|     Modpack pack = modpacks.at(pos); | ||||
|     if(role == Qt::DisplayRole) | ||||
|     { | ||||
|     if (role == Qt::DisplayRole) { | ||||
|         return pack.name; | ||||
|     } | ||||
|     else if(role == Qt::DecorationRole) | ||||
|     { | ||||
|         if(m_logoMap.contains(pack.logoName)) | ||||
|         { | ||||
|     } else if (role == Qt::DecorationRole) { | ||||
|         if (m_logoMap.contains(pack.logoName)) { | ||||
|             return (m_logoMap.value(pack.logoName)); | ||||
|         } | ||||
|         QIcon icon = APPLICATION->getThemedIcon("screenshot-placeholder"); | ||||
|         ((ListModel *)this)->requestLogo(pack.logoName, pack.logoUrl); | ||||
|         ((ListModel*)this)->requestLogo(pack.logoName, pack.logoUrl); | ||||
|         return icon; | ||||
|     } | ||||
|     else if(role == Qt::UserRole) | ||||
|     { | ||||
|     } else if (role == Qt::UserRole) { | ||||
|         QVariant v; | ||||
|         v.setValue(pack); | ||||
|         return v; | ||||
| @@ -92,16 +81,15 @@ int Technic::ListModel::rowCount(const QModelIndex& parent) const | ||||
|  | ||||
| void Technic::ListModel::searchWithTerm(const QString& term) | ||||
| { | ||||
|     if(currentSearchTerm == term && currentSearchTerm.isNull() == term.isNull()) { | ||||
|     if (currentSearchTerm == term && currentSearchTerm.isNull() == term.isNull()) { | ||||
|         return; | ||||
|     } | ||||
|     currentSearchTerm = term; | ||||
|     if(jobPtr) { | ||||
|     if (jobPtr) { | ||||
|         jobPtr->abort(); | ||||
|         searchState = ResetRequested; | ||||
|         return; | ||||
|     } | ||||
|     else { | ||||
|     } else { | ||||
|         beginResetModel(); | ||||
|         modpacks.clear(); | ||||
|         endResetModel(); | ||||
| @@ -115,23 +103,17 @@ void Technic::ListModel::performSearch() | ||||
|     auto netJob = makeShared<NetJob>("Technic::Search", APPLICATION->network()); | ||||
|     QString searchUrl = ""; | ||||
|     if (currentSearchTerm.isEmpty()) { | ||||
|         searchUrl = QString("%1trending?build=%2") | ||||
|                 .arg(BuildConfig.TECHNIC_API_BASE_URL, BuildConfig.TECHNIC_API_BUILD); | ||||
|         searchUrl = QString("%1trending?build=%2").arg(BuildConfig.TECHNIC_API_BASE_URL, BuildConfig.TECHNIC_API_BUILD); | ||||
|         searchMode = List; | ||||
|     } | ||||
|     else if (currentSearchTerm.startsWith("http://api.technicpack.net/modpack/")) { | ||||
|         searchUrl = QString("https://%1?build=%2") | ||||
|                 .arg(currentSearchTerm.mid(7), BuildConfig.TECHNIC_API_BUILD); | ||||
|     } else if (currentSearchTerm.startsWith("http://api.technicpack.net/modpack/")) { | ||||
|         searchUrl = QString("https://%1?build=%2").arg(currentSearchTerm.mid(7), BuildConfig.TECHNIC_API_BUILD); | ||||
|         searchMode = Single; | ||||
|     } | ||||
|     else if (currentSearchTerm.startsWith("https://api.technicpack.net/modpack/")) { | ||||
|     } else if (currentSearchTerm.startsWith("https://api.technicpack.net/modpack/")) { | ||||
|         searchUrl = QString("%1?build=%2").arg(currentSearchTerm, BuildConfig.TECHNIC_API_BUILD); | ||||
|         searchMode = Single; | ||||
|     } | ||||
|     else { | ||||
|         searchUrl = QString( | ||||
|             "%1search?build=%2&q=%3" | ||||
|         ).arg(BuildConfig.TECHNIC_API_BASE_URL, BuildConfig.TECHNIC_API_BUILD, currentSearchTerm); | ||||
|     } else { | ||||
|         searchUrl = | ||||
|             QString("%1search?build=%2&q=%3").arg(BuildConfig.TECHNIC_API_BASE_URL, BuildConfig.TECHNIC_API_BUILD, currentSearchTerm); | ||||
|         searchMode = List; | ||||
|     } | ||||
|     netJob->addNetAction(Net::Download::makeByteArray(QUrl(searchUrl), response)); | ||||
| @@ -161,7 +143,7 @@ void Technic::ListModel::searchRequestFinished() | ||||
|         switch (searchMode) { | ||||
|             case List: { | ||||
|                 auto objs = Json::requireArray(root, "modpacks"); | ||||
|                 for (auto technicPack: objs) { | ||||
|                 for (auto technicPack : objs) { | ||||
|                     Modpack pack; | ||||
|                     auto technicPackObject = Json::requireObject(technicPack); | ||||
|                     pack.name = Json::requireString(technicPackObject, "name"); | ||||
| @@ -170,11 +152,10 @@ void Technic::ListModel::searchRequestFinished() | ||||
|                         continue; | ||||
|  | ||||
|                     auto rawURL = Json::ensureString(technicPackObject, "iconUrl", "null"); | ||||
|                     if(rawURL == "null") { | ||||
|                     if (rawURL == "null") { | ||||
|                         pack.logoUrl = "null"; | ||||
|                         pack.logoName = "null"; | ||||
|                     } | ||||
|                     else { | ||||
|                     } else { | ||||
|                         pack.logoUrl = rawURL; | ||||
|                         pack.logoName = rawURL.section(QLatin1Char('/'), -1).section(QLatin1Char('.'), 0, 0); | ||||
|                     } | ||||
| @@ -199,8 +180,7 @@ void Technic::ListModel::searchRequestFinished() | ||||
|  | ||||
|                     pack.logoUrl = iconUrl; | ||||
|                     pack.logoName = iconUrl.section(QLatin1Char('/'), -1).section(QLatin1Char('.'), 0, 0); | ||||
|                 } | ||||
|                 else { | ||||
|                 } else { | ||||
|                     pack.logoUrl = "null"; | ||||
|                     pack.logoName = "null"; | ||||
|                 } | ||||
| @@ -210,10 +190,8 @@ void Technic::ListModel::searchRequestFinished() | ||||
|                 break; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     catch (const JSONValidationError &err) | ||||
|     { | ||||
|         qCritical() << "Couldn't parse technic search results:" << err.cause() ; | ||||
|     } catch (const JSONValidationError& err) { | ||||
|         qCritical() << "Couldn't parse technic search results:" << err.cause(); | ||||
|         return; | ||||
|     } | ||||
|     searchState = Finished; | ||||
| @@ -229,12 +207,9 @@ void Technic::ListModel::searchRequestFinished() | ||||
|  | ||||
| void Technic::ListModel::getLogo(const QString& logo, const QString& logoUrl, Technic::LogoCallback callback) | ||||
| { | ||||
|     if(m_logoMap.contains(logo)) | ||||
|     { | ||||
|     if (m_logoMap.contains(logo)) { | ||||
|         callback(APPLICATION->metacache()->resolveEntry("TechnicPacks", QString("logos/%1").arg(logo))->getFullPath()); | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|     } else { | ||||
|         requestLogo(logo, logoUrl); | ||||
|     } | ||||
| } | ||||
| @@ -243,30 +218,24 @@ void Technic::ListModel::searchRequestFailed() | ||||
| { | ||||
|     jobPtr.reset(); | ||||
|  | ||||
|     if(searchState == ResetRequested) | ||||
|     { | ||||
|     if (searchState == ResetRequested) { | ||||
|         beginResetModel(); | ||||
|         modpacks.clear(); | ||||
|         endResetModel(); | ||||
|  | ||||
|         performSearch(); | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|     } else { | ||||
|         searchState = Finished; | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| void Technic::ListModel::logoLoaded(QString logo, QString out) | ||||
| { | ||||
|     m_loadingLogos.removeAll(logo); | ||||
|     m_logoMap.insert(logo, QIcon(out)); | ||||
|     for(int i = 0; i < modpacks.size(); i++) | ||||
|     { | ||||
|         if(modpacks[i].logoName == logo) | ||||
|         { | ||||
|             emit dataChanged(createIndex(i, 0), createIndex(i, 0), {Qt::DecorationRole}); | ||||
|     for (int i = 0; i < modpacks.size(); i++) { | ||||
|         if (modpacks[i].logoName == logo) { | ||||
|             emit dataChanged(createIndex(i, 0), createIndex(i, 0), { Qt::DecorationRole }); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -279,24 +248,23 @@ void Technic::ListModel::logoFailed(QString logo) | ||||
|  | ||||
| void Technic::ListModel::requestLogo(QString logo, QString url) | ||||
| { | ||||
|     if(m_loadingLogos.contains(logo) || m_failedLogos.contains(logo) || logo == "null") | ||||
|     { | ||||
|     if (m_loadingLogos.contains(logo) || m_failedLogos.contains(logo) || logo == "null") { | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|     MetaEntryPtr entry = APPLICATION->metacache()->resolveEntry("TechnicPacks", QString("logos/%1").arg(logo)); | ||||
|     NetJob *job = new NetJob(QString("Technic Icon Download %1").arg(logo), APPLICATION->network()); | ||||
|     auto job = new NetJob(QString("Technic Icon Download %1").arg(logo), APPLICATION->network()); | ||||
|     job->addNetAction(Net::Download::makeCached(QUrl(url), entry)); | ||||
|  | ||||
|     auto fullPath = entry->getFullPath(); | ||||
|  | ||||
|     QObject::connect(job, &NetJob::succeeded, this, [this, logo, fullPath] | ||||
|     { | ||||
|     QObject::connect(job, &NetJob::succeeded, this, [this, logo, fullPath, job] { | ||||
|         job->deleteLater(); | ||||
|         logoLoaded(logo, fullPath); | ||||
|     }); | ||||
|  | ||||
|     QObject::connect(job, &NetJob::failed, this, [this, logo] | ||||
|     { | ||||
|     QObject::connect(job, &NetJob::failed, this, [this, logo, job] { | ||||
|         job->deleteLater(); | ||||
|         logoFailed(logo); | ||||
|     }); | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Trial97
					Trial97