send blocked mod info to dialog & prototype UI
Signed-off-by: Rachel Powers <508861+Ryex@users.noreply.github.com>
This commit is contained in:
parent
04b39294ba
commit
028e086960
@ -372,13 +372,20 @@ void FlameCreationTask::idResolverSucceeded(QEventLoop& loop)
|
|||||||
auto results = m_mod_id_resolver->getResults();
|
auto results = m_mod_id_resolver->getResults();
|
||||||
|
|
||||||
// first check for blocked mods
|
// first check for blocked mods
|
||||||
QString text;
|
QList<BlockedMod> blocked_mods;
|
||||||
QList<QUrl> urls;
|
|
||||||
auto anyBlocked = false;
|
auto anyBlocked = false;
|
||||||
for (const auto& result : results.files.values()) {
|
for (const auto& result : results.files.values()) {
|
||||||
if (!result.resolved || result.url.isEmpty()) {
|
if (!result.resolved || result.url.isEmpty()) {
|
||||||
text += QString("%1: <a href='%2'>%2</a><br/>").arg(result.fileName, result.websiteUrl);
|
|
||||||
urls.append(QUrl(result.websiteUrl));
|
BlockedMod blocked_mod;
|
||||||
|
blocked_mod.name = result.fileName;
|
||||||
|
blocked_mod.websiteUrl = result.websiteUrl;
|
||||||
|
blocked_mod.hash = result.hash;
|
||||||
|
blocked_mod.matched = false;
|
||||||
|
blocked_mod.localPath = "";
|
||||||
|
|
||||||
|
blocked_mods.append(blocked_mod);
|
||||||
|
|
||||||
anyBlocked = true;
|
anyBlocked = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -388,8 +395,7 @@ void FlameCreationTask::idResolverSucceeded(QEventLoop& loop)
|
|||||||
auto message_dialog = new BlockedModsDialog(m_parent, tr("Blocked mods found"),
|
auto message_dialog = new BlockedModsDialog(m_parent, tr("Blocked mods found"),
|
||||||
tr("The following mods were blocked on third party launchers.<br/>"
|
tr("The following mods were blocked on third party launchers.<br/>"
|
||||||
"You will need to manually download them and add them to the modpack"),
|
"You will need to manually download them and add them to the modpack"),
|
||||||
text,
|
blocked_mods);
|
||||||
urls);
|
|
||||||
message_dialog->setModal(true);
|
message_dialog->setModal(true);
|
||||||
|
|
||||||
if (message_dialog->exec()) {
|
if (message_dialog->exec()) {
|
||||||
|
@ -176,8 +176,7 @@ void PackInstallTask::resolveMods()
|
|||||||
|
|
||||||
void PackInstallTask::onResolveModsSucceeded()
|
void PackInstallTask::onResolveModsSucceeded()
|
||||||
{
|
{
|
||||||
QString text;
|
QList<BlockedMod> blocked_mods;
|
||||||
QList<QUrl> urls;
|
|
||||||
auto anyBlocked = false;
|
auto anyBlocked = false;
|
||||||
|
|
||||||
Flame::Manifest results = m_mod_id_resolver_task->getResults();
|
Flame::Manifest results = m_mod_id_resolver_task->getResults();
|
||||||
@ -191,11 +190,19 @@ void PackInstallTask::onResolveModsSucceeded()
|
|||||||
|
|
||||||
// First check for blocked mods
|
// First check for blocked mods
|
||||||
if (!results_file.resolved || results_file.url.isEmpty()) {
|
if (!results_file.resolved || results_file.url.isEmpty()) {
|
||||||
QString type(local_file.type);
|
// QString type(local_file.type);
|
||||||
|
|
||||||
|
// type[0] = type[0].toUpper();
|
||||||
|
|
||||||
|
BlockedMod blocked_mod;
|
||||||
|
blocked_mod.name = local_file.name;
|
||||||
|
blocked_mod.websiteUrl = results_file.websiteUrl;
|
||||||
|
blocked_mod.hash = results_file.hash;
|
||||||
|
blocked_mod.matched = false;
|
||||||
|
blocked_mod.localPath = "";
|
||||||
|
|
||||||
|
blocked_mods.append(blocked_mod);
|
||||||
|
|
||||||
type[0] = type[0].toUpper();
|
|
||||||
text += QString("%1: %2 - <a href='%3'>%3</a><br/>").arg(type, local_file.name, results_file.websiteUrl);
|
|
||||||
urls.append(QUrl(results_file.websiteUrl));
|
|
||||||
anyBlocked = true;
|
anyBlocked = true;
|
||||||
} else {
|
} else {
|
||||||
local_file.url = results_file.url.toString();
|
local_file.url = results_file.url.toString();
|
||||||
@ -210,8 +217,7 @@ void PackInstallTask::onResolveModsSucceeded()
|
|||||||
auto message_dialog = new BlockedModsDialog(m_parent, tr("Blocked files found"),
|
auto message_dialog = new BlockedModsDialog(m_parent, tr("Blocked files found"),
|
||||||
tr("The following files are not available for download in third party launchers.<br/>"
|
tr("The following files are not available for download in third party launchers.<br/>"
|
||||||
"You will need to manually download them and add them to the instance."),
|
"You will need to manually download them and add them to the instance."),
|
||||||
text,
|
blocked_mods);
|
||||||
urls);
|
|
||||||
|
|
||||||
if (message_dialog->exec() == QDialog::Accepted)
|
if (message_dialog->exec() == QDialog::Accepted)
|
||||||
createInstance();
|
createInstance();
|
||||||
|
@ -4,17 +4,22 @@
|
|||||||
#include <QDialogButtonBox>
|
#include <QDialogButtonBox>
|
||||||
#include <QDesktopServices>
|
#include <QDesktopServices>
|
||||||
|
|
||||||
|
#include <QDebug>
|
||||||
|
|
||||||
BlockedModsDialog::BlockedModsDialog(QWidget *parent, const QString &title, const QString &text, const QString &body, const QList<QUrl> &urls) :
|
|
||||||
QDialog(parent), ui(new Ui::BlockedModsDialog), urls(urls) {
|
BlockedModsDialog::BlockedModsDialog(QWidget *parent, const QString &title, const QString &text, const QList<BlockedMod> &mods) :
|
||||||
|
QDialog(parent), ui(new Ui::BlockedModsDialog), mods(mods) {
|
||||||
ui->setupUi(this);
|
ui->setupUi(this);
|
||||||
|
|
||||||
auto openAllButton = ui->buttonBox->addButton(tr("Open All"), QDialogButtonBox::ActionRole);
|
auto openAllButton = ui->buttonBox->addButton(tr("Open All"), QDialogButtonBox::ActionRole);
|
||||||
connect(openAllButton, &QPushButton::clicked, this, &BlockedModsDialog::openAll);
|
connect(openAllButton, &QPushButton::clicked, this, &BlockedModsDialog::openAll);
|
||||||
|
|
||||||
|
qDebug() << "Mods List: " << mods;
|
||||||
|
|
||||||
this->setWindowTitle(title);
|
this->setWindowTitle(title);
|
||||||
ui->label->setText(text);
|
ui->label->setText(text);
|
||||||
ui->textBrowser->setText(body);
|
ui->textBrowser->setText(body);
|
||||||
|
update();
|
||||||
}
|
}
|
||||||
|
|
||||||
BlockedModsDialog::~BlockedModsDialog() {
|
BlockedModsDialog::~BlockedModsDialog() {
|
||||||
@ -22,7 +27,36 @@ BlockedModsDialog::~BlockedModsDialog() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void BlockedModsDialog::openAll() {
|
void BlockedModsDialog::openAll() {
|
||||||
for(auto &url : urls) {
|
for(auto &mod : mods) {
|
||||||
QDesktopServices::openUrl(url);
|
QDesktopServices::openUrl(mod.websiteUrl);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void BlockedModsDialog::update() {
|
||||||
|
QString text;
|
||||||
|
QString span;
|
||||||
|
|
||||||
|
for (auto &mod : mods) {
|
||||||
|
if (mod.matched) {
|
||||||
|
// ✔ -> html for HEAVY CHECK MARK : ✔
|
||||||
|
span = QString("<span style=\"color:green\"> ✔ Found at %1 </span>").arg(mod.localPath);
|
||||||
|
} else {
|
||||||
|
// ✘ -> html for HEAVY BALLOT X : ✘
|
||||||
|
span = QString("<span style=\"color:red\"> ✘ Not Found </span>");
|
||||||
|
}
|
||||||
|
text += QString("%1: <a href='%2'>%2</a> <p>Hash: %3 %4</p> <br/>").arg(mod.name, mod.websiteUrl, mod.hash, span);
|
||||||
|
}
|
||||||
|
|
||||||
|
ui->textBrowser->setText(text);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
QDebug operator<<(QDebug debug, const BlockedMod &m) {
|
||||||
|
QDebugStateSaver saver(debug);
|
||||||
|
|
||||||
|
debug.nospace() << "{ name: " << m.name << ", websiteUrl: " << m.websiteUrl
|
||||||
|
<< ", hash: " << m.hash << ", matched: " << m.matched
|
||||||
|
<< ", localPath: " << m.localPath <<"}";
|
||||||
|
|
||||||
|
return debug;
|
||||||
|
}
|
@ -3,6 +3,15 @@
|
|||||||
#include <QDialog>
|
#include <QDialog>
|
||||||
|
|
||||||
|
|
||||||
|
struct BlockedMod {
|
||||||
|
QString name;
|
||||||
|
QString websiteUrl;
|
||||||
|
QString hash;
|
||||||
|
bool matched;
|
||||||
|
QString localPath;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
QT_BEGIN_NAMESPACE
|
QT_BEGIN_NAMESPACE
|
||||||
namespace Ui { class BlockedModsDialog; }
|
namespace Ui { class BlockedModsDialog; }
|
||||||
QT_END_NAMESPACE
|
QT_END_NAMESPACE
|
||||||
@ -11,12 +20,15 @@ class BlockedModsDialog : public QDialog {
|
|||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
BlockedModsDialog(QWidget *parent, const QString &title, const QString &text, const QString &body, const QList<QUrl> &urls);
|
BlockedModsDialog(QWidget *parent, const QString &title, const QString &text, const QList<BlockedMod> &mods);
|
||||||
|
|
||||||
~BlockedModsDialog() override;
|
~BlockedModsDialog() override;
|
||||||
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Ui::BlockedModsDialog *ui;
|
Ui::BlockedModsDialog *ui;
|
||||||
const QList<QUrl> &urls;
|
const QList<BlockedMod> &mods;
|
||||||
void openAll();
|
void openAll();
|
||||||
|
void update();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user