Merge pull request #894 from flowln/update_from_external_source
epic PR
This commit is contained in:
		| @@ -1656,6 +1656,10 @@ void MainWindow::runModalTask(Task *task) | ||||
|                 CustomMessageBox::selectable(this, tr("Warnings"), warnings.join('\n'), QMessageBox::Warning)->show(); | ||||
|             } | ||||
|         }); | ||||
|     connect(task, &Task::aborted, [this] | ||||
|         { | ||||
|             CustomMessageBox::selectable(this, tr("Task aborted"), tr("The task has been aborted by the user."), QMessageBox::Information)->show(); | ||||
|         }); | ||||
|     ProgressDialog loadDialog(this); | ||||
|     loadDialog.setSkipButton(true, tr("Abort")); | ||||
|     loadDialog.execWithTask(task); | ||||
|   | ||||
| @@ -51,6 +51,7 @@ | ||||
| #include <QFileDialog> | ||||
| #include <QValidator> | ||||
| #include <QDialogButtonBox> | ||||
| #include <utility> | ||||
|  | ||||
| #include "ui/widgets/PageContainer.h" | ||||
| #include "ui/pages/modplatform/VanillaPage.h" | ||||
| @@ -180,10 +181,27 @@ NewInstanceDialog::~NewInstanceDialog() | ||||
| void NewInstanceDialog::setSuggestedPack(const QString& name, InstanceTask* task) | ||||
| { | ||||
|     creationTask.reset(task); | ||||
|     ui->instNameTextBox->setPlaceholderText(name); | ||||
|  | ||||
|     if(!task) | ||||
|     { | ||||
|     ui->instNameTextBox->setPlaceholderText(name); | ||||
|     importVersion.clear(); | ||||
|  | ||||
|     if (!task) { | ||||
|         ui->iconButton->setIcon(APPLICATION->icons()->getIcon("default")); | ||||
|         importIcon = false; | ||||
|     } | ||||
|  | ||||
|     auto allowOK = task && !instName().isEmpty(); | ||||
|     m_buttons->button(QDialogButtonBox::Ok)->setEnabled(allowOK); | ||||
| } | ||||
|  | ||||
| void NewInstanceDialog::setSuggestedPack(const QString& name, QString version, InstanceTask* task) | ||||
| { | ||||
|     creationTask.reset(task); | ||||
|  | ||||
|     ui->instNameTextBox->setPlaceholderText(name); | ||||
|     importVersion = std::move(version); | ||||
|  | ||||
|     if (!task) { | ||||
|         ui->iconButton->setIcon(APPLICATION->icons()->getIcon("default")); | ||||
|         importIcon = false; | ||||
|     } | ||||
| @@ -214,7 +232,11 @@ InstanceTask * NewInstanceDialog::extractTask() | ||||
| { | ||||
|     InstanceTask * extracted = creationTask.get(); | ||||
|     creationTask.release(); | ||||
|     extracted->setName(instName()); | ||||
|  | ||||
|     InstanceName inst_name(ui->instNameTextBox->placeholderText().trimmed(), importVersion); | ||||
|     inst_name.setName(ui->instNameTextBox->text().trimmed()); | ||||
|     extracted->setName(inst_name); | ||||
|  | ||||
|     extracted->setGroup(instGroup()); | ||||
|     extracted->setIcon(iconKey()); | ||||
|     return extracted; | ||||
|   | ||||
| @@ -37,7 +37,6 @@ | ||||
|  | ||||
| #include <QDialog> | ||||
|  | ||||
| #include "BaseVersion.h" | ||||
| #include "ui/pages/BasePageProvider.h" | ||||
| #include "InstanceTask.h" | ||||
|  | ||||
| @@ -61,7 +60,8 @@ public: | ||||
|  | ||||
|     void updateDialogState(); | ||||
|  | ||||
|     void setSuggestedPack(const QString & name = QString(), InstanceTask * task = nullptr); | ||||
|     void setSuggestedPack(const QString& name = QString(), InstanceTask * task = nullptr); | ||||
|     void setSuggestedPack(const QString& name, QString version, InstanceTask * task = nullptr); | ||||
|     void setSuggestedIconFromFile(const QString &path, const QString &name); | ||||
|     void setSuggestedIcon(const QString &key); | ||||
|  | ||||
| @@ -95,5 +95,7 @@ private: | ||||
|     QString importIconPath; | ||||
|     QString importIconName; | ||||
|  | ||||
|     QString importVersion; | ||||
|  | ||||
|     void importIconNow(); | ||||
| }; | ||||
|   | ||||
| @@ -43,8 +43,7 @@ void ProgressDialog::setSkipButton(bool present, QString label) | ||||
| void ProgressDialog::on_skipButton_clicked(bool checked) | ||||
| { | ||||
|     Q_UNUSED(checked); | ||||
|     if (task->abort()) | ||||
|         QDialog::reject(); | ||||
|     task->abort(); | ||||
| } | ||||
|  | ||||
| ProgressDialog::~ProgressDialog() | ||||
| @@ -81,7 +80,8 @@ int ProgressDialog::execWithTask(Task* task) | ||||
|     connect(task, &Task::stepStatus, this, &ProgressDialog::changeStatus); | ||||
|     connect(task, &Task::progress, this, &ProgressDialog::changeProgress); | ||||
|  | ||||
|     connect(task, &Task::aborted, [this] { onTaskFailed(tr("Aborted by user")); }); | ||||
|     connect(task, &Task::aborted, [this] { QDialog::reject(); }); | ||||
|     connect(task, &Task::abortStatusChanged, ui->skipButton, &QPushButton::setEnabled); | ||||
|  | ||||
|     m_is_multi_step = task->isMultiStep(); | ||||
|     if (!m_is_multi_step) { | ||||
|   | ||||
| @@ -39,12 +39,12 @@ | ||||
| #include <QTabBar> | ||||
|  | ||||
| #include "Application.h" | ||||
| #include "Filter.h" | ||||
| #include "Version.h" | ||||
| #include "meta/Index.h" | ||||
| #include "meta/VersionList.h" | ||||
| #include "minecraft/VanillaInstanceCreationTask.h" | ||||
| #include "ui/dialogs/NewInstanceDialog.h" | ||||
| #include "Filter.h" | ||||
| #include "InstanceCreationTask.h" | ||||
| #include "Version.h" | ||||
|  | ||||
| VanillaPage::VanillaPage(NewInstanceDialog *dialog, QWidget *parent) | ||||
|     : QWidget(parent), dialog(dialog), ui(new Ui::VanillaPage) | ||||
| @@ -217,11 +217,11 @@ void VanillaPage::suggestCurrent() | ||||
|  | ||||
|     // There isn't a selected version if the version list is empty | ||||
|     if(ui->loaderVersionList->selectedVersion() == nullptr) | ||||
|         dialog->setSuggestedPack(m_selectedVersion->descriptor(), new InstanceCreationTask(m_selectedVersion)); | ||||
|         dialog->setSuggestedPack(m_selectedVersion->descriptor(), new VanillaCreationTask(m_selectedVersion)); | ||||
|     else | ||||
|     { | ||||
|         dialog->setSuggestedPack(m_selectedVersion->descriptor(), | ||||
|                                  new InstanceCreationTask(m_selectedVersion, m_selectedLoader, | ||||
|                                  new VanillaCreationTask(m_selectedVersion, m_selectedLoader, | ||||
|                                                           m_selectedLoaderVersion)); | ||||
|     } | ||||
|     dialog->setSuggestedIcon("default"); | ||||
|   | ||||
| @@ -117,7 +117,7 @@ void AtlPage::suggestCurrent() | ||||
|     } | ||||
|  | ||||
|     auto uiSupport = new AtlUserInteractionSupportImpl(this); | ||||
|     dialog->setSuggestedPack(selected.name + " " + selectedVersion, new ATLauncher::PackInstallTask(uiSupport, selected.name, selectedVersion)); | ||||
|     dialog->setSuggestedPack(selected.name, selectedVersion, new ATLauncher::PackInstallTask(uiSupport, selected.name, selectedVersion)); | ||||
|  | ||||
|     auto editedLogoName = selected.safeName; | ||||
|     auto url = QString(BuildConfig.ATL_DOWNLOAD_SERVER_URL + "launcher/images/%1.png").arg(selected.safeName.toLower()); | ||||
|   | ||||
| @@ -127,7 +127,7 @@ void FtbPage::suggestCurrent() | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|     dialog->setSuggestedPack(selected.name + " " + selectedVersion, new ModpacksCH::PackInstallTask(selected, selectedVersion, this)); | ||||
|     dialog->setSuggestedPack(selected.name, selectedVersion, new ModpacksCH::PackInstallTask(selected, selectedVersion, this)); | ||||
|     for(auto art : selected.art) { | ||||
|         if(art.type == "square") { | ||||
|             QString editedLogoName; | ||||
|   | ||||
| @@ -146,6 +146,7 @@ void Page::openedImpl() | ||||
|     { | ||||
|         connect(ftbFetchTask.get(), &PackFetchTask::finished, this, &Page::ftbPackDataDownloadSuccessfully); | ||||
|         connect(ftbFetchTask.get(), &PackFetchTask::failed, this, &Page::ftbPackDataDownloadFailed); | ||||
|         connect(ftbFetchTask.get(), &PackFetchTask::aborted, this, &Page::ftbPackDataDownloadAborted); | ||||
|  | ||||
|         connect(ftbFetchTask.get(), &PackFetchTask::privateFileDownloadFinished, this, &Page::ftbPrivatePackDataDownloadSuccessfully); | ||||
|         connect(ftbFetchTask.get(), &PackFetchTask::privateFileDownloadFailed, this, &Page::ftbPrivatePackDataDownloadFailed); | ||||
| @@ -176,7 +177,7 @@ void Page::suggestCurrent() | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|     dialog->setSuggestedPack(selected.name + " " + selectedVersion, new PackInstallTask(APPLICATION->network(), selected, selectedVersion)); | ||||
|     dialog->setSuggestedPack(selected.name, selectedVersion, new PackInstallTask(APPLICATION->network(), selected, selectedVersion)); | ||||
|     QString editedLogoName; | ||||
|     if(selected.logo.toLower().startsWith("ftb")) | ||||
|     { | ||||
| @@ -220,7 +221,12 @@ void Page::ftbPackDataDownloadSuccessfully(ModpackList publicPacks, ModpackList | ||||
|  | ||||
| void Page::ftbPackDataDownloadFailed(QString reason) | ||||
| { | ||||
|     //TODO: Display the error | ||||
|     CustomMessageBox::selectable(this, tr("Error"), reason, QMessageBox::Critical)->show(); | ||||
| } | ||||
|  | ||||
| void Page::ftbPackDataDownloadAborted() | ||||
| { | ||||
|     CustomMessageBox::selectable(this, tr("Task aborted"), tr("The task has been aborted by the user."), QMessageBox::Information)->show(); | ||||
| } | ||||
|  | ||||
| void Page::ftbPrivatePackDataDownloadSuccessfully(Modpack pack) | ||||
|   | ||||
| @@ -95,6 +95,7 @@ private: | ||||
| private slots: | ||||
|     void ftbPackDataDownloadSuccessfully(ModpackList publicPacks, ModpackList thirdPartyPacks); | ||||
|     void ftbPackDataDownloadFailed(QString reason); | ||||
|     void ftbPackDataDownloadAborted(); | ||||
|  | ||||
|     void ftbPrivatePackDataDownloadSuccessfully(Modpack pack); | ||||
|     void ftbPrivatePackDataDownloadFailed(QString reason, QString packCode); | ||||
|   | ||||
| @@ -294,7 +294,7 @@ void ModrinthPage::suggestCurrent() | ||||
|  | ||||
|     for (auto& ver : current.versions) { | ||||
|         if (ver.id == selectedVersion) { | ||||
|             dialog->setSuggestedPack(current.name + " " + ver.version, new InstanceImportTask(ver.download_url, this)); | ||||
|             dialog->setSuggestedPack(current.name, ver.version, new InstanceImportTask(ver.download_url, this)); | ||||
|             auto iconName = current.iconName; | ||||
|             m_model->getLogo(iconName, current.iconUrl.toString(), | ||||
|                              [this, iconName](QString logo) { dialog->setSuggestedIconFromFile(logo, iconName); }); | ||||
|   | ||||
| @@ -271,11 +271,11 @@ void TechnicPage::selectVersion() { | ||||
|  | ||||
|     if (!current.isSolder) | ||||
|     { | ||||
|         dialog->setSuggestedPack(current.name + " " + selectedVersion, new Technic::SingleZipPackInstallTask(current.url, current.minecraftVersion)); | ||||
|         dialog->setSuggestedPack(current.name, selectedVersion, new Technic::SingleZipPackInstallTask(current.url, current.minecraftVersion)); | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|         dialog->setSuggestedPack(current.name + " " + selectedVersion, new Technic::SolderPackInstallTask(APPLICATION->network(), current.url, current.slug, selectedVersion, current.minecraftVersion)); | ||||
|         dialog->setSuggestedPack(current.name, selectedVersion, new Technic::SolderPackInstallTask(APPLICATION->network(), current.url, current.slug, selectedVersion, current.minecraftVersion)); | ||||
|     } | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 flow
					flow