Fixes for new changes

Signed-off-by: TheKodeToad <TheKodeToad@proton.me>
This commit is contained in:
TheKodeToad 2025-04-29 12:15:58 +01:00
parent fadbcf2d04
commit 80fb1a8f4e
No known key found for this signature in database
GPG key ID: 5E39D70B4C93C38E
6 changed files with 41 additions and 20 deletions

View file

@ -17,11 +17,13 @@
*/
#include "DataPackPage.h"
#include <ui/dialogs/ResourceUpdateDialog.h>
#include "minecraft/PackProfile.h"
#include "ui_ExternalResourcesPage.h"
#include "ui/dialogs/CustomMessageBox.h"
#include "ui/dialogs/ProgressDialog.h"
#include "ui/dialogs/ResourceDownloadDialog.h"
#include "ui/dialogs/ResourceUpdateDialog.h"
DataPackPage::DataPackPage(BaseInstance* instance, std::shared_ptr<DataPackFolderModel> model, QWidget* parent)
: ExternalResourcesPage(instance, model, parent), m_model(model)
@ -65,9 +67,23 @@ void DataPackPage::downloadDataPacks()
if (m_instance->typeName() != "Minecraft")
return; // this is a null instance or a legacy instance
ResourceDownload::DataPackDownloadDialog mdownload(this, std::static_pointer_cast<DataPackFolderModel>(m_model), m_instance);
if (mdownload.exec()) {
auto tasks = new ConcurrentTask("Download Data Pack", APPLICATION->settings()->get("NumberOfConcurrentDownloads").toInt());
auto profile = static_cast<MinecraftInstance*>(m_instance)->getPackProfile();
if (!profile->getModLoaders().has_value()) {
QMessageBox::critical(this, tr("Error"), tr("Please install a mod loader first!"));
return;
}
m_downloadDialog = new ResourceDownload::DataPackDownloadDialog(this, m_model, m_instance);
connect(this, &QObject::destroyed, m_downloadDialog, &QDialog::close);
connect(m_downloadDialog, &QDialog::finished, this, &DataPackPage::downloadDialogFinished);
m_downloadDialog->open();
}
void DataPackPage::downloadDialogFinished(int result)
{
if (result) {
auto tasks = new ConcurrentTask(tr("Download Data Packs"), APPLICATION->settings()->get("NumberOfConcurrentDownloads").toInt());
connect(tasks, &Task::failed, [this, tasks](QString reason) {
CustomMessageBox::selectable(this, tr("Error"), reason, QMessageBox::Critical)->show();
tasks->deleteLater();
@ -84,8 +100,12 @@ void DataPackPage::downloadDataPacks()
tasks->deleteLater();
});
for (auto& task : mdownload.getTasks()) {
tasks->addTask(task);
if (m_downloadDialog) {
for (auto& task : m_downloadDialog->getTasks()) {
tasks->addTask(task);
}
} else {
qWarning() << "ResourceDownloadDialog vanished before we could collect tasks!";
}
ProgressDialog loadDialog(this);
@ -94,6 +114,8 @@ void DataPackPage::downloadDataPacks()
m_model->update();
}
if (m_downloadDialog)
m_downloadDialog->deleteLater();
}
void DataPackPage::updateDataPacks()

View file

@ -18,9 +18,10 @@
#pragma once
#include <QVBoxLayout>
#include "ExternalResourcesPage.h"
#include "minecraft/mod/DataPackFolderModel.h"
#include "ui_ExternalResourcesPage.h"
#include "ui/dialogs/ResourceDownloadDialog.h"
class DataPackPage : public ExternalResourcesPage {
Q_OBJECT
@ -36,13 +37,14 @@ class DataPackPage : public ExternalResourcesPage {
public slots:
void updateFrame(const QModelIndex& current, const QModelIndex& previous) override;
void downloadDataPacks();
void downloadDialogFinished(int result);
void updateDataPacks();
void deleteDataPackMetadata();
void changeDataPackVersion();
private:
std::shared_ptr<DataPackFolderModel> m_model;
QPointer<ResourceDownload::DataPackDownloadDialog> m_downloadDialog;
};
/**
@ -63,7 +65,7 @@ class GlobalDataPackPage : public QWidget, public BasePage {
void openedImpl() override;
void closedImpl() override;
void setParentContainer(BasePageContainer *container) override;
void setParentContainer(BasePageContainer* container) override;
private:
void updateContent();