2022-03-20 19:01:08 +00:00
|
|
|
// SPDX-License-Identifier: GPL-3.0-only
|
|
|
|
/*
|
|
|
|
* PolyMC - Minecraft Launcher
|
|
|
|
* Copyright (c) 2022 Jamie Mansfield <jmansfield@cadixdev.org>
|
2022-06-12 12:50:58 +01:00
|
|
|
* Copyright (C) 2022 Sefa Eyeoglu <contact@scrumplex.net>
|
2014-06-01 23:49:53 +01:00
|
|
|
*
|
2022-03-20 19:01:08 +00:00
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, version 3.
|
2014-06-01 23:49:53 +01:00
|
|
|
*
|
2022-03-20 19:01:08 +00:00
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
2014-06-01 23:49:53 +01:00
|
|
|
*
|
2022-03-20 19:01:08 +00:00
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
* This file incorporates work covered by the following copyright and
|
|
|
|
* permission notice:
|
|
|
|
*
|
|
|
|
* Copyright 2013-2021 MultiMC Contributors
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
2014-06-01 23:49:53 +01:00
|
|
|
*/
|
|
|
|
|
2014-07-12 22:02:52 +01:00
|
|
|
#include "ModFolderPage.h"
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
#include "ui_ExternalResourcesPage.h"
|
2014-06-01 23:49:53 +01:00
|
|
|
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
#include <QAbstractItemModel>
|
2014-06-01 23:49:53 +01:00
|
|
|
#include <QEvent>
|
|
|
|
#include <QKeyEvent>
|
2019-07-16 00:30:53 +01:00
|
|
|
#include <QMenu>
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
#include <QMessageBox>
|
2021-11-22 02:55:16 +00:00
|
|
|
#include <QSortFilterProxyModel>
|
2014-06-01 23:49:53 +01:00
|
|
|
|
2021-11-20 15:22:22 +00:00
|
|
|
#include "Application.h"
|
2021-11-22 02:55:16 +00:00
|
|
|
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
#include "ui/GuiUtil.h"
|
2021-11-22 02:55:16 +00:00
|
|
|
#include "ui/dialogs/CustomMessageBox.h"
|
2022-01-14 08:43:42 +00:00
|
|
|
#include "ui/dialogs/ModDownloadDialog.h"
|
2022-06-05 01:18:51 +01:00
|
|
|
#include "ui/dialogs/ModUpdateDialog.h"
|
2021-11-22 02:55:16 +00:00
|
|
|
|
|
|
|
#include "DesktopServices.h"
|
|
|
|
|
2020-06-27 11:02:31 +01:00
|
|
|
#include "minecraft/PackProfile.h"
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
#include "minecraft/VersionFilterData.h"
|
|
|
|
#include "minecraft/mod/Mod.h"
|
|
|
|
#include "minecraft/mod/ModFolderModel.h"
|
2014-06-01 23:49:53 +01:00
|
|
|
|
2022-02-20 19:55:26 +00:00
|
|
|
#include "modplatform/ModAPI.h"
|
|
|
|
|
2019-07-30 00:25:37 +01:00
|
|
|
#include "Version.h"
|
2022-06-12 17:51:19 +01:00
|
|
|
#include "tasks/ConcurrentTask.h"
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
#include "ui/dialogs/ProgressDialog.h"
|
2019-07-30 00:16:56 +01:00
|
|
|
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
ModFolderPage::ModFolderPage(BaseInstance* inst, std::shared_ptr<ModFolderModel> mods, QWidget* parent)
|
|
|
|
: ExternalResourcesPage(inst, mods, parent)
|
2018-07-15 13:51:05 +01:00
|
|
|
{
|
2022-03-03 12:51:46 +00:00
|
|
|
// This is structured like that so that these changes
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
// do not affect the Resource pack and Shader pack tabs
|
|
|
|
{
|
2022-05-30 15:36:30 +01:00
|
|
|
ui->actionDownloadItem->setText(tr("Download mods"));
|
|
|
|
ui->actionDownloadItem->setToolTip(tr("Download mods from online mod platforms"));
|
|
|
|
ui->actionDownloadItem->setEnabled(true);
|
|
|
|
ui->actionAddItem->setText(tr("Add file"));
|
|
|
|
ui->actionAddItem->setToolTip(tr("Add a locally downloaded file"));
|
2014-06-01 23:49:53 +01:00
|
|
|
|
2022-05-30 15:36:30 +01:00
|
|
|
ui->actionsToolbar->insertActionBefore(ui->actionAddItem, ui->actionDownloadItem);
|
|
|
|
|
|
|
|
connect(ui->actionDownloadItem, &QAction::triggered, this, &ModFolderPage::installMods);
|
2022-06-05 01:18:51 +01:00
|
|
|
|
2022-07-19 17:03:45 +01:00
|
|
|
ui->actionUpdateItem->setToolTip(tr("Try to check or update all selected mods (all mods if none are selected)"));
|
2022-06-05 01:18:51 +01:00
|
|
|
ui->actionsToolbar->insertActionAfter(ui->actionAddItem, ui->actionUpdateItem);
|
|
|
|
connect(ui->actionUpdateItem, &QAction::triggered, this, &ModFolderPage::updateMods);
|
|
|
|
|
|
|
|
connect(ui->treeView->selectionModel(), &QItemSelectionModel::selectionChanged, this,
|
|
|
|
[this] { ui->actionUpdateItem->setEnabled(ui->treeView->selectionModel()->hasSelection() || !m_model->empty()); });
|
|
|
|
|
|
|
|
connect(mods.get(), &ModFolderModel::rowsInserted, this,
|
|
|
|
[this] { ui->actionUpdateItem->setEnabled(ui->treeView->selectionModel()->hasSelection() || !m_model->empty()); });
|
|
|
|
|
|
|
|
connect(mods.get(), &ModFolderModel::updateFinished, this, [this, mods] {
|
|
|
|
ui->actionUpdateItem->setEnabled(ui->treeView->selectionModel()->hasSelection() || !m_model->empty());
|
|
|
|
|
|
|
|
// Prevent a weird crash when trying to open the mods page twice in a session o.O
|
|
|
|
disconnect(mods.get(), &ModFolderModel::updateFinished, this, 0);
|
|
|
|
});
|
2019-08-04 20:13:50 +01:00
|
|
|
}
|
2014-06-01 23:49:53 +01:00
|
|
|
}
|
|
|
|
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
CoreModFolderPage::CoreModFolderPage(BaseInstance* inst, std::shared_ptr<ModFolderModel> mods, QWidget* parent)
|
|
|
|
: ModFolderPage(inst, mods, parent)
|
|
|
|
{}
|
2019-07-15 00:07:21 +01:00
|
|
|
|
2014-07-12 16:58:23 +01:00
|
|
|
bool ModFolderPage::shouldDisplay() const
|
2014-06-30 01:02:57 +01:00
|
|
|
{
|
2018-07-15 13:51:05 +01:00
|
|
|
return true;
|
2014-06-30 01:02:57 +01:00
|
|
|
}
|
|
|
|
|
2014-07-12 16:58:23 +01:00
|
|
|
bool CoreModFolderPage::shouldDisplay() const
|
2014-07-09 23:47:08 +01:00
|
|
|
{
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
if (ModFolderPage::shouldDisplay()) {
|
|
|
|
auto inst = dynamic_cast<MinecraftInstance*>(m_instance);
|
2018-07-15 13:51:05 +01:00
|
|
|
if (!inst)
|
|
|
|
return true;
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
|
2020-06-27 11:02:31 +01:00
|
|
|
auto version = inst->getPackProfile();
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
|
2018-07-15 13:51:05 +01:00
|
|
|
if (!version)
|
|
|
|
return true;
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
if (!version->getComponent("net.minecraftforge"))
|
2018-07-15 13:51:05 +01:00
|
|
|
return false;
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
if (!version->getComponent("net.minecraft"))
|
2018-07-15 13:51:05 +01:00
|
|
|
return false;
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
if (version->getComponent("net.minecraft")->getReleaseDateTime() < g_VersionFilterData.legacyCutoffDate)
|
2018-07-15 13:51:05 +01:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
2014-07-09 23:47:08 +01:00
|
|
|
}
|
|
|
|
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
void ModFolderPage::installMods()
|
2014-06-01 23:49:53 +01:00
|
|
|
{
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
if (!m_controlsEnabled)
|
2019-07-15 00:07:21 +01:00
|
|
|
return;
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
if (m_instance->typeName() != "Minecraft")
|
|
|
|
return; // this is a null instance or a legacy instance
|
2022-06-05 01:18:51 +01:00
|
|
|
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
auto profile = static_cast<MinecraftInstance*>(m_instance)->getPackProfile();
|
2022-05-19 07:40:28 +01:00
|
|
|
if (profile->getModLoaders() == ModAPI::Unspecified) {
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
QMessageBox::critical(this, tr("Error"), tr("Please install a mod loader first!"));
|
2022-01-14 19:22:15 +00:00
|
|
|
return;
|
|
|
|
}
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
|
|
|
|
ModDownloadDialog mdownload(m_model, this, m_instance);
|
2022-04-01 13:10:51 +01:00
|
|
|
if (mdownload.exec()) {
|
2022-06-12 17:51:19 +01:00
|
|
|
ConcurrentTask* tasks = new ConcurrentTask(this);
|
2022-04-01 13:10:51 +01:00
|
|
|
connect(tasks, &Task::failed, [this, tasks](QString reason) {
|
|
|
|
CustomMessageBox::selectable(this, tr("Error"), reason, QMessageBox::Critical)->show();
|
|
|
|
tasks->deleteLater();
|
|
|
|
});
|
2022-05-01 15:08:00 +01:00
|
|
|
connect(tasks, &Task::aborted, [this, tasks]() {
|
|
|
|
CustomMessageBox::selectable(this, tr("Aborted"), tr("Download stopped by user."), QMessageBox::Information)->show();
|
|
|
|
tasks->deleteLater();
|
|
|
|
});
|
2022-04-01 13:10:51 +01:00
|
|
|
connect(tasks, &Task::succeeded, [this, tasks]() {
|
|
|
|
QStringList warnings = tasks->warnings();
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
if (warnings.count())
|
|
|
|
CustomMessageBox::selectable(this, tr("Warnings"), warnings.join('\n'), QMessageBox::Warning)->show();
|
2022-06-05 01:18:51 +01:00
|
|
|
|
2022-04-01 13:10:51 +01:00
|
|
|
tasks->deleteLater();
|
|
|
|
});
|
|
|
|
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
for (auto& task : mdownload.getTasks()) {
|
2022-04-01 13:10:51 +01:00
|
|
|
tasks->addTask(task);
|
2022-01-14 19:22:15 +00:00
|
|
|
}
|
2022-05-01 15:08:00 +01:00
|
|
|
|
2022-04-01 13:10:51 +01:00
|
|
|
ProgressDialog loadDialog(this);
|
|
|
|
loadDialog.setSkipButton(true, tr("Abort"));
|
|
|
|
loadDialog.execWithTask(tasks);
|
2014-06-01 23:49:53 +01:00
|
|
|
|
refactor: Create a more clear hierarchy for some instance pages
Previously, the Shaders, Texture packs and Resource packs tabs had as
parent the ModFolderPage, making it so that making changes only to the
Mods page would require checking the id of the page for the correct one.
This was hackish and error-prone.
Now, those pages all inherit from a single class, ExternalResourcesPage,
that handles the basic behaviour of all of them, while allowing for
individual modification in code.
This is still not a clear separation, since internally, all those
resources are derived from Mods, so for now there's still some awkward
common code :/
2022-03-11 21:03:21 +00:00
|
|
|
m_model->update();
|
2018-07-15 13:51:05 +01:00
|
|
|
}
|
2014-06-01 23:49:53 +01:00
|
|
|
}
|
2022-06-05 01:18:51 +01:00
|
|
|
|
|
|
|
void ModFolderPage::updateMods()
|
|
|
|
{
|
|
|
|
auto selection = m_filterModel->mapSelectionToSource(ui->treeView->selectionModel()->selection()).indexes();
|
|
|
|
|
|
|
|
auto mods_list = m_model->selectedMods(selection);
|
|
|
|
bool use_all = mods_list.empty();
|
|
|
|
if (use_all)
|
2022-07-10 19:15:25 +01:00
|
|
|
mods_list = m_model->allMods();
|
2022-06-05 01:18:51 +01:00
|
|
|
|
|
|
|
ModUpdateDialog update_dialog(this, m_instance, m_model, mods_list);
|
|
|
|
update_dialog.checkCandidates();
|
|
|
|
|
|
|
|
if (update_dialog.aborted()) {
|
|
|
|
CustomMessageBox::selectable(this, tr("Aborted"), tr("The mod updater was aborted!"), QMessageBox::Warning)->show();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (update_dialog.noUpdates()) {
|
2022-07-19 17:03:45 +01:00
|
|
|
QString message{ tr("'%1' is up-to-date! :)").arg(mods_list.front()->name()) };
|
|
|
|
if (mods_list.size() > 1) {
|
|
|
|
if (use_all) {
|
|
|
|
message = tr("All mods are up-to-date! :)");
|
|
|
|
} else {
|
|
|
|
message = tr("All selected mods are up-to-date! :)");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
CustomMessageBox::selectable(this, tr("Update checker"), message)
|
2022-06-05 01:18:51 +01:00
|
|
|
->exec();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (update_dialog.exec()) {
|
|
|
|
ConcurrentTask* tasks = new ConcurrentTask(this);
|
|
|
|
connect(tasks, &Task::failed, [this, tasks](QString reason) {
|
|
|
|
CustomMessageBox::selectable(this, tr("Error"), reason, QMessageBox::Critical)->show();
|
|
|
|
tasks->deleteLater();
|
|
|
|
});
|
|
|
|
connect(tasks, &Task::aborted, [this, tasks]() {
|
|
|
|
CustomMessageBox::selectable(this, tr("Aborted"), tr("Download stopped by user."), QMessageBox::Information)->show();
|
|
|
|
tasks->deleteLater();
|
|
|
|
});
|
|
|
|
connect(tasks, &Task::succeeded, [this, tasks]() {
|
|
|
|
QStringList warnings = tasks->warnings();
|
|
|
|
if (warnings.count()) {
|
|
|
|
CustomMessageBox::selectable(this, tr("Warnings"), warnings.join('\n'), QMessageBox::Warning)->show();
|
|
|
|
}
|
|
|
|
tasks->deleteLater();
|
|
|
|
});
|
|
|
|
|
|
|
|
for (auto task : update_dialog.getTasks()) {
|
|
|
|
tasks->addTask(task);
|
|
|
|
}
|
|
|
|
|
|
|
|
ProgressDialog loadDialog(this);
|
|
|
|
loadDialog.setSkipButton(true, tr("Abort"));
|
|
|
|
loadDialog.execWithTask(tasks);
|
|
|
|
|
|
|
|
m_model->update();
|
|
|
|
}
|
|
|
|
}
|