feat: display release type
Signed-off-by: Rachel Powers <508861+Ryex@users.noreply.github.com>
This commit is contained in:
parent
c156034069
commit
cf4df19986
@ -1,8 +1,8 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "minecraft/mod/Mod.h"
|
#include "minecraft/mod/Mod.h"
|
||||||
#include "modplatform/ResourceAPI.h"
|
|
||||||
#include "modplatform/ModIndex.h"
|
#include "modplatform/ModIndex.h"
|
||||||
|
#include "modplatform/ResourceAPI.h"
|
||||||
#include "tasks/Task.h"
|
#include "tasks/Task.h"
|
||||||
|
|
||||||
class ResourceDownloadTask;
|
class ResourceDownloadTask;
|
||||||
@ -12,21 +12,39 @@ class CheckUpdateTask : public Task {
|
|||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
CheckUpdateTask(QList<Mod*>& mods, std::list<Version>& mcVersions, std::optional<ResourceAPI::ModLoaderTypes> loaders, std::shared_ptr<ModFolderModel> mods_folder)
|
CheckUpdateTask(QList<Mod*>& mods,
|
||||||
: Task(nullptr), m_mods(mods), m_game_versions(mcVersions), m_loaders(loaders), m_mods_folder(mods_folder) {};
|
std::list<Version>& mcVersions,
|
||||||
|
std::optional<ResourceAPI::ModLoaderTypes> loaders,
|
||||||
|
std::shared_ptr<ModFolderModel> mods_folder)
|
||||||
|
: Task(nullptr), m_mods(mods), m_game_versions(mcVersions), m_loaders(loaders), m_mods_folder(mods_folder){};
|
||||||
|
|
||||||
struct UpdatableMod {
|
struct UpdatableMod {
|
||||||
QString name;
|
QString name;
|
||||||
QString old_hash;
|
QString old_hash;
|
||||||
QString old_version;
|
QString old_version;
|
||||||
QString new_version;
|
QString new_version;
|
||||||
|
std::optional<ModPlatform::IndexedVersionType> new_verison_type;
|
||||||
QString changelog;
|
QString changelog;
|
||||||
ModPlatform::ResourceProvider provider;
|
ModPlatform::ResourceProvider provider;
|
||||||
shared_qobject_ptr<ResourceDownloadTask> download;
|
shared_qobject_ptr<ResourceDownloadTask> download;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
UpdatableMod(QString name, QString old_h, QString old_v, QString new_v, QString changelog, ModPlatform::ResourceProvider p, shared_qobject_ptr<ResourceDownloadTask> t)
|
UpdatableMod(QString name,
|
||||||
: name(name), old_hash(old_h), old_version(old_v), new_version(new_v), changelog(changelog), provider(p), download(t)
|
QString old_h,
|
||||||
|
QString old_v,
|
||||||
|
QString new_v,
|
||||||
|
std::optional<ModPlatform::IndexedVersionType> new_v_type,
|
||||||
|
QString changelog,
|
||||||
|
ModPlatform::ResourceProvider p,
|
||||||
|
shared_qobject_ptr<ResourceDownloadTask> t)
|
||||||
|
: name(name)
|
||||||
|
, old_hash(old_h)
|
||||||
|
, old_version(old_v)
|
||||||
|
, new_version(new_v)
|
||||||
|
, new_verison_type(new_v_type)
|
||||||
|
, changelog(changelog)
|
||||||
|
, provider(p)
|
||||||
|
, download(t)
|
||||||
{}
|
{}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -35,7 +35,19 @@ IndexedVersionType::IndexedVersionType(const QString& type): IndexedVersionType(
|
|||||||
|
|
||||||
IndexedVersionType::IndexedVersionType(int type)
|
IndexedVersionType::IndexedVersionType(int type)
|
||||||
{
|
{
|
||||||
m_type = static_cast<IndexedVersionType::Enum>(type);
|
switch (type) {
|
||||||
|
case 1:
|
||||||
|
m_type = IndexedVersionType::Enum::Release;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
m_type = IndexedVersionType::Enum::Beta;
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
m_type = IndexedVersionType::Enum::Alpha;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
m_type = IndexedVersionType::Enum::UNKNOWN;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
IndexedVersionType::IndexedVersionType(const IndexedVersionType::Enum& type)
|
IndexedVersionType::IndexedVersionType(const IndexedVersionType::Enum& type)
|
||||||
|
@ -63,6 +63,7 @@ struct IndexedVersionType {
|
|||||||
IndexedVersionType(int type);
|
IndexedVersionType(int type);
|
||||||
IndexedVersionType(const IndexedVersionType::Enum& type);
|
IndexedVersionType(const IndexedVersionType::Enum& type);
|
||||||
IndexedVersionType(const IndexedVersionType& type);
|
IndexedVersionType(const IndexedVersionType& type);
|
||||||
|
IndexedVersionType() : IndexedVersionType(IndexedVersionType::Enum::UNKNOWN) {}
|
||||||
static const QString toString (const IndexedVersionType::Enum& type);
|
static const QString toString (const IndexedVersionType::Enum& type);
|
||||||
static const IndexedVersionType::Enum enumFromString(const QString& type);
|
static const IndexedVersionType::Enum enumFromString(const QString& type);
|
||||||
bool isValid() const {return m_type != IndexedVersionType::Enum::UNKNOWN; }
|
bool isValid() const {return m_type != IndexedVersionType::Enum::UNKNOWN; }
|
||||||
@ -70,6 +71,7 @@ struct IndexedVersionType {
|
|||||||
bool operator==(const IndexedVersionType::Enum& type) const { return m_type == type; }
|
bool operator==(const IndexedVersionType::Enum& type) const { return m_type == type; }
|
||||||
bool operator<(const IndexedVersionType& other) const { return m_type < other.m_type; }
|
bool operator<(const IndexedVersionType& other) const { return m_type < other.m_type; }
|
||||||
bool operator<(const IndexedVersionType::Enum& type) const { return m_type < type; }
|
bool operator<(const IndexedVersionType::Enum& type) const { return m_type < type; }
|
||||||
|
QString toString() const { return toString(m_type); }
|
||||||
|
|
||||||
IndexedVersionType::Enum m_type;
|
IndexedVersionType::Enum m_type;
|
||||||
};
|
};
|
||||||
@ -79,7 +81,7 @@ struct IndexedVersion {
|
|||||||
QVariant fileId;
|
QVariant fileId;
|
||||||
QString version;
|
QString version;
|
||||||
QString version_number = {};
|
QString version_number = {};
|
||||||
std::optional<IndexedVersionType> verison_type = {};
|
IndexedVersionType verison_type;
|
||||||
QStringList mcVersion;
|
QStringList mcVersion;
|
||||||
QString downloadUrl;
|
QString downloadUrl;
|
||||||
QString date;
|
QString date;
|
||||||
|
@ -144,9 +144,7 @@ auto FlameAPI::getLatestVersion(VersionSearchArgs&& args) -> ModPlatform::Indexe
|
|||||||
for (auto file : arr) {
|
for (auto file : arr) {
|
||||||
auto file_obj = Json::requireObject(file);
|
auto file_obj = Json::requireObject(file);
|
||||||
auto file_tmp = FlameMod::loadIndexedPackVersion(file_obj);
|
auto file_tmp = FlameMod::loadIndexedPackVersion(file_obj);
|
||||||
bool better_release = true;
|
bool better_release = file_tmp.verison_type < ver_tmp.verison_type;
|
||||||
if (file_tmp.verison_type.has_value() && ver_tmp.verison_type.has_value())
|
|
||||||
better_release = file_tmp.verison_type.value() < ver_tmp.verison_type.value();
|
|
||||||
if(file_tmp.date > ver_tmp.date && better_release) {
|
if(file_tmp.date > ver_tmp.date && better_release) {
|
||||||
ver_tmp = file_tmp;
|
ver_tmp = file_tmp;
|
||||||
latest_file_obj = file_obj;
|
latest_file_obj = file_obj;
|
||||||
|
@ -173,7 +173,7 @@ void FlameCheckUpdate::executeTask()
|
|||||||
}
|
}
|
||||||
|
|
||||||
auto download_task = makeShared<ResourceDownloadTask>(pack, latest_ver, m_mods_folder);
|
auto download_task = makeShared<ResourceDownloadTask>(pack, latest_ver, m_mods_folder);
|
||||||
m_updatable.emplace_back(pack.name, mod->metadata()->hash, old_version, latest_ver.version,
|
m_updatable.emplace_back(pack.name, mod->metadata()->hash, old_version, latest_ver.version, latest_ver.verison_type,
|
||||||
api.getModFileChangelog(latest_ver.addonId.toInt(), latest_ver.fileId.toInt()),
|
api.getModFileChangelog(latest_ver.addonId.toInt(), latest_ver.fileId.toInt()),
|
||||||
ModPlatform::ResourceProvider::FLAME, download_task);
|
ModPlatform::ResourceProvider::FLAME, download_task);
|
||||||
}
|
}
|
||||||
|
@ -94,9 +94,7 @@ void FlameMod::loadIndexedPackVersions(ModPlatform::IndexedPack& pack,
|
|||||||
}
|
}
|
||||||
|
|
||||||
auto orderSortPredicate = [](const ModPlatform::IndexedVersion& a, const ModPlatform::IndexedVersion& b) -> bool {
|
auto orderSortPredicate = [](const ModPlatform::IndexedVersion& a, const ModPlatform::IndexedVersion& b) -> bool {
|
||||||
bool a_better_release = true;
|
bool a_better_release = a.verison_type < b.verison_type;
|
||||||
if (a.verison_type.has_value() && b.verison_type.has_value())
|
|
||||||
a_better_release = a.verison_type.value() < b.verison_type.value();
|
|
||||||
// dates are in RFC 3339 format
|
// dates are in RFC 3339 format
|
||||||
return a.date > b.date && a_better_release;
|
return a.date > b.date && a_better_release;
|
||||||
};
|
};
|
||||||
@ -126,9 +124,7 @@ auto FlameMod::loadIndexedPackVersion(QJsonObject& obj, bool load_changelog) ->
|
|||||||
file.version = Json::requireString(obj, "displayName");
|
file.version = Json::requireString(obj, "displayName");
|
||||||
file.downloadUrl = Json::ensureString(obj, "downloadUrl");
|
file.downloadUrl = Json::ensureString(obj, "downloadUrl");
|
||||||
file.fileName = Json::requireString(obj, "fileName");
|
file.fileName = Json::requireString(obj, "fileName");
|
||||||
auto version_type = ModPlatform::IndexedVersionType(Json::requireInteger(obj, "releaseType"));
|
file.verison_type = ModPlatform::IndexedVersionType(Json::requireInteger(obj, "releaseType"));
|
||||||
if (version_type.isValid())
|
|
||||||
file.verison_type = version_type;
|
|
||||||
|
|
||||||
auto hash_list = Json::ensureArray(obj, "hashes");
|
auto hash_list = Json::ensureArray(obj, "hashes");
|
||||||
for (auto h : hash_list) {
|
for (auto h : hash_list) {
|
||||||
|
@ -90,6 +90,7 @@ void Flame::loadIndexedPackVersions(Flame::IndexedPack& pack, QJsonArray& arr)
|
|||||||
// pick the latest version supported
|
// pick the latest version supported
|
||||||
file.mcVersion = versionArray[0].toString();
|
file.mcVersion = versionArray[0].toString();
|
||||||
file.version = Json::requireString(version, "displayName");
|
file.version = Json::requireString(version, "displayName");
|
||||||
|
file.version_type = ModPlatform::IndexedVersionType(Json::requireInteger(version, "releaseType"));
|
||||||
file.downloadUrl = Json::ensureString(version, "downloadUrl");
|
file.downloadUrl = Json::ensureString(version, "downloadUrl");
|
||||||
|
|
||||||
// only add if we have a download URL (third party distribution is enabled)
|
// only add if we have a download URL (third party distribution is enabled)
|
||||||
|
@ -5,6 +5,8 @@
|
|||||||
#include <QString>
|
#include <QString>
|
||||||
#include <QVector>
|
#include <QVector>
|
||||||
|
|
||||||
|
#include "modplatform/ModIndex.h"
|
||||||
|
|
||||||
namespace Flame {
|
namespace Flame {
|
||||||
|
|
||||||
struct ModpackAuthor {
|
struct ModpackAuthor {
|
||||||
@ -16,6 +18,7 @@ struct IndexedVersion {
|
|||||||
int addonId;
|
int addonId;
|
||||||
int fileId;
|
int fileId;
|
||||||
QString version;
|
QString version;
|
||||||
|
ModPlatform::IndexedVersionType version_type;
|
||||||
QString mcVersion;
|
QString mcVersion;
|
||||||
QString downloadUrl;
|
QString downloadUrl;
|
||||||
};
|
};
|
||||||
|
@ -161,8 +161,8 @@ void ModrinthCheckUpdate::executeTask()
|
|||||||
|
|
||||||
auto download_task = makeShared<ResourceDownloadTask>(pack, project_ver, m_mods_folder);
|
auto download_task = makeShared<ResourceDownloadTask>(pack, project_ver, m_mods_folder);
|
||||||
|
|
||||||
m_updatable.emplace_back(pack.name, hash, mod->version(), project_ver.version_number, project_ver.changelog,
|
m_updatable.emplace_back(pack.name, hash, mod->version(), project_ver.version_number, project_ver.verison_type,
|
||||||
ModPlatform::ResourceProvider::MODRINTH, download_task);
|
project_ver.changelog, ModPlatform::ResourceProvider::MODRINTH, download_task);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch (Json::JsonException& e) {
|
} catch (Json::JsonException& e) {
|
||||||
|
@ -109,9 +109,7 @@ void Modrinth::loadIndexedPackVersions(ModPlatform::IndexedPack& pack,
|
|||||||
unsortedVersions.append(file);
|
unsortedVersions.append(file);
|
||||||
}
|
}
|
||||||
auto orderSortPredicate = [](const ModPlatform::IndexedVersion& a, const ModPlatform::IndexedVersion& b) -> bool {
|
auto orderSortPredicate = [](const ModPlatform::IndexedVersion& a, const ModPlatform::IndexedVersion& b) -> bool {
|
||||||
bool a_better_release = true;
|
bool a_better_release = a.verison_type < b.verison_type;
|
||||||
if (a.verison_type.has_value() && b.verison_type.has_value())
|
|
||||||
a_better_release = a.verison_type.value() < b.verison_type.value();
|
|
||||||
// dates are in RFC 3339 format
|
// dates are in RFC 3339 format
|
||||||
return a.date > b.date && a_better_release;
|
return a.date > b.date && a_better_release;
|
||||||
};
|
};
|
||||||
@ -141,9 +139,7 @@ auto Modrinth::loadIndexedPackVersion(QJsonObject& obj, QString preferred_hash_t
|
|||||||
}
|
}
|
||||||
file.version = Json::requireString(obj, "name");
|
file.version = Json::requireString(obj, "name");
|
||||||
file.version_number = Json::requireString(obj, "version_number");
|
file.version_number = Json::requireString(obj, "version_number");
|
||||||
auto verison_type = ModPlatform::IndexedVersionType(Json::requireString(obj, "version_type"));
|
file.verison_type = ModPlatform::IndexedVersionType(Json::requireString(obj, "version_type"));
|
||||||
if (verison_type.isValid())
|
|
||||||
file.verison_type = verison_type;
|
|
||||||
|
|
||||||
file.changelog = Json::requireString(obj, "changelog");
|
file.changelog = Json::requireString(obj, "changelog");
|
||||||
|
|
||||||
|
@ -111,8 +111,9 @@ void loadIndexedVersions(Modpack& pack, QJsonDocument& doc)
|
|||||||
unsortedVersions.append(file);
|
unsortedVersions.append(file);
|
||||||
}
|
}
|
||||||
auto orderSortPredicate = [](const ModpackVersion& a, const ModpackVersion& b) -> bool {
|
auto orderSortPredicate = [](const ModpackVersion& a, const ModpackVersion& b) -> bool {
|
||||||
|
bool a_better_release = a.version_type < b.version_type;
|
||||||
// dates are in RFC 3339 format
|
// dates are in RFC 3339 format
|
||||||
return a.date > b.date;
|
return a.date > b.date && a_better_release;
|
||||||
};
|
};
|
||||||
|
|
||||||
std::sort(unsortedVersions.begin(), unsortedVersions.end(), orderSortPredicate);
|
std::sort(unsortedVersions.begin(), unsortedVersions.end(), orderSortPredicate);
|
||||||
@ -128,6 +129,7 @@ auto loadIndexedVersion(QJsonObject &obj) -> ModpackVersion
|
|||||||
|
|
||||||
file.name = Json::requireString(obj, "name");
|
file.name = Json::requireString(obj, "name");
|
||||||
file.version = Json::requireString(obj, "version_number");
|
file.version = Json::requireString(obj, "version_number");
|
||||||
|
file.version_type = ModPlatform::IndexedVersionType(Json::requireString(obj, "version_type"));
|
||||||
file.changelog = Json::ensureString(obj, "changelog");
|
file.changelog = Json::ensureString(obj, "changelog");
|
||||||
|
|
||||||
file.id = Json::requireString(obj, "id");
|
file.id = Json::requireString(obj, "id");
|
||||||
|
@ -45,6 +45,8 @@
|
|||||||
#include <QUrl>
|
#include <QUrl>
|
||||||
#include <QVector>
|
#include <QVector>
|
||||||
|
|
||||||
|
#include "modplatform/ModIndex.h"
|
||||||
|
|
||||||
class MinecraftInstance;
|
class MinecraftInstance;
|
||||||
|
|
||||||
namespace Modrinth {
|
namespace Modrinth {
|
||||||
@ -80,6 +82,7 @@ struct ModpackExtra {
|
|||||||
struct ModpackVersion {
|
struct ModpackVersion {
|
||||||
QString name;
|
QString name;
|
||||||
QString version;
|
QString version;
|
||||||
|
ModPlatform::IndexedVersionType version_type;
|
||||||
QString changelog;
|
QString changelog;
|
||||||
|
|
||||||
QString id;
|
QString id;
|
||||||
|
@ -362,6 +362,11 @@ void ModUpdateDialog::appendMod(CheckUpdateTask::UpdatableMod const& info)
|
|||||||
auto new_version_item = new QTreeWidgetItem(item_top);
|
auto new_version_item = new QTreeWidgetItem(item_top);
|
||||||
new_version_item->setText(0, tr("New version: %1").arg(info.new_version));
|
new_version_item->setText(0, tr("New version: %1").arg(info.new_version));
|
||||||
|
|
||||||
|
if (info.new_verison_type.has_value()) {
|
||||||
|
auto new_version_type_itme = new QTreeWidgetItem(item_top);
|
||||||
|
new_version_type_itme->setText(0, tr("New Version Type: %1").arg(info.new_verison_type.value().toString()));
|
||||||
|
}
|
||||||
|
|
||||||
auto changelog_item = new QTreeWidgetItem(item_top);
|
auto changelog_item = new QTreeWidgetItem(item_top);
|
||||||
changelog_item->setText(0, tr("Changelog of the latest version"));
|
changelog_item->setText(0, tr("Changelog of the latest version"));
|
||||||
|
|
||||||
|
@ -137,8 +137,10 @@ void ModPage::updateVersionList()
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Only add the version if it's valid or using the 'Any' filter, but never if the version is opted out
|
// Only add the version if it's valid or using the 'Any' filter, but never if the version is opted out
|
||||||
if ((valid || m_filter->versions.empty()) && !optedOut(version))
|
if ((valid || m_filter->versions.empty()) && !optedOut(version)) {
|
||||||
m_ui->versionSelectionBox->addItem(version.version, QVariant(i));
|
auto release_type = version.verison_type.isValid() ? QString(" : %1").arg(version.verison_type.toString()) : "";
|
||||||
|
m_ui->versionSelectionBox->addItem(QString("%1%2").arg(version.version, release_type), QVariant(i));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (m_ui->versionSelectionBox->count() == 0) {
|
if (m_ui->versionSelectionBox->count() == 0) {
|
||||||
m_ui->versionSelectionBox->addItem(tr("No valid version found!"), QVariant(-1));
|
m_ui->versionSelectionBox->addItem(tr("No valid version found!"), QVariant(-1));
|
||||||
|
@ -256,8 +256,8 @@ void ResourcePage::updateVersionList()
|
|||||||
auto& version = current_pack.versions[i];
|
auto& version = current_pack.versions[i];
|
||||||
if (optedOut(version))
|
if (optedOut(version))
|
||||||
continue;
|
continue;
|
||||||
|
auto release_type = current_pack.versions[i].verison_type.isValid() ? QString(" : %1").arg(current_pack.versions[i].verison_type.toString()) : "";
|
||||||
m_ui->versionSelectionBox->addItem(current_pack.versions[i].version, QVariant(i));
|
m_ui->versionSelectionBox->addItem(QString("%1%2").arg(current_pack.versions[i].version, release_type), QVariant(i));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_ui->versionSelectionBox->count() == 0) {
|
if (m_ui->versionSelectionBox->count() == 0) {
|
||||||
|
@ -155,7 +155,8 @@ void FlamePage::onSelectionChanged(QModelIndex curr, QModelIndex prev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (auto version : current.versions) {
|
for (auto version : current.versions) {
|
||||||
ui->versionSelectionBox->addItem(version.version, QVariant(version.downloadUrl));
|
auto release_type = version.version_type.isValid() ? QString(" : %1").arg(version.version_type.toString()) : "";
|
||||||
|
ui->versionSelectionBox->addItem(QString("%1%2").arg(version.version, release_type), QVariant(version.downloadUrl));
|
||||||
}
|
}
|
||||||
|
|
||||||
QVariant current_updated;
|
QVariant current_updated;
|
||||||
|
@ -201,12 +201,12 @@ void ModrinthPage::onSelectionChanged(QModelIndex curr, QModelIndex prev)
|
|||||||
qDebug() << *response;
|
qDebug() << *response;
|
||||||
qWarning() << "Error while reading modrinth modpack version: " << e.cause();
|
qWarning() << "Error while reading modrinth modpack version: " << e.cause();
|
||||||
}
|
}
|
||||||
|
|
||||||
for (auto version : current.versions) {
|
for (auto version : current.versions) {
|
||||||
|
auto release_type = version.version_type.isValid() ? QString(" : %1").arg(version.version_type.toString()) : "";
|
||||||
if (!version.name.contains(version.version))
|
if (!version.name.contains(version.version))
|
||||||
ui->versionSelectionBox->addItem(QString("%1 — %2").arg(version.name, version.version), QVariant(version.id));
|
ui->versionSelectionBox->addItem(QString("%1 — %2%3").arg(version.name, version.version, release_type), QVariant(version.id));
|
||||||
else
|
else
|
||||||
ui->versionSelectionBox->addItem(version.name, QVariant(version.id));
|
ui->versionSelectionBox->addItem(QString("%1%2").arg(version.name, release_type), QVariant(version.id));
|
||||||
}
|
}
|
||||||
|
|
||||||
QVariant current_updated;
|
QVariant current_updated;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user