2022-03-20 20:01:08 +01:00
|
|
|
// SPDX-License-Identifier: GPL-3.0-only
|
|
|
|
/*
|
2022-12-14 15:02:04 +00:00
|
|
|
* Prism Launcher - Minecraft Launcher
|
2022-03-20 20:01:08 +01:00
|
|
|
* Copyright (c) 2022 Jamie Mansfield <jmansfield@cadixdev.org>
|
2022-06-12 13:50:58 +02:00
|
|
|
* Copyright (C) 2022 Sefa Eyeoglu <contact@scrumplex.net>
|
2022-12-14 15:02:04 +00:00
|
|
|
* Copyright (C) 2022 TheKodeToad <TheKodeToad@proton.me>
|
2023-06-15 11:40:39 +03:00
|
|
|
* Copyright (c) 2023 Trial97 <alexandru.tripon97@gmail.com>
|
2014-06-02 00:49:53 +02:00
|
|
|
*
|
2022-03-20 20:01:08 +01: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-02 00:49:53 +02:00
|
|
|
*
|
2022-03-20 20:01:08 +01: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-02 00:49:53 +02:00
|
|
|
*
|
2022-03-20 20:01:08 +01: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-02 00:49:53 +02:00
|
|
|
*/
|
|
|
|
|
2014-07-12 23:02:52 +02: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 18:03:21 -03:00
|
|
|
#include "ui_ExternalResourcesPage.h"
|
2014-06-02 00:49:53 +02: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 18:03:21 -03:00
|
|
|
#include <QAbstractItemModel>
|
2014-06-02 00:49:53 +02:00
|
|
|
#include <QEvent>
|
|
|
|
#include <QKeyEvent>
|
2019-07-16 01:30:53 +02: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 18:03:21 -03:00
|
|
|
#include <QMessageBox>
|
2021-11-22 03:55:16 +01:00
|
|
|
#include <QSortFilterProxyModel>
|
2023-06-07 01:23:53 +03:00
|
|
|
#include <algorithm>
|
2014-06-02 00:49:53 +02:00
|
|
|
|
2021-11-20 16:22:22 +01:00
|
|
|
#include "Application.h"
|
2021-11-22 03:55:16 +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 18:03:21 -03:00
|
|
|
#include "ui/GuiUtil.h"
|
2021-11-22 03:55:16 +01:00
|
|
|
#include "ui/dialogs/CustomMessageBox.h"
|
2022-06-04 21:18:51 -03:00
|
|
|
#include "ui/dialogs/ModUpdateDialog.h"
|
2022-12-16 21:44:21 -03:00
|
|
|
#include "ui/dialogs/ResourceDownloadDialog.h"
|
2021-11-22 03:55:16 +01:00
|
|
|
|
|
|
|
#include "DesktopServices.h"
|
|
|
|
|
2020-06-27 12:02:31 +02: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 18:03:21 -03:00
|
|
|
#include "minecraft/VersionFilterData.h"
|
|
|
|
#include "minecraft/mod/Mod.h"
|
|
|
|
#include "minecraft/mod/ModFolderModel.h"
|
2014-06-02 00:49:53 +02:00
|
|
|
|
2023-06-07 01:23:53 +03:00
|
|
|
#include "modplatform/ModIndex.h"
|
2022-11-25 09:23:46 -03:00
|
|
|
#include "modplatform/ResourceAPI.h"
|
2022-02-20 20:55:26 +01:00
|
|
|
|
2019-07-30 01:25:37 +02:00
|
|
|
#include "Version.h"
|
2022-06-12 13:51:19 -03: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 18:03:21 -03:00
|
|
|
#include "ui/dialogs/ProgressDialog.h"
|
2019-07-30 01:16:56 +02: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 18:03:21 -03:00
|
|
|
ModFolderPage::ModFolderPage(BaseInstance* inst, std::shared_ptr<ModFolderModel> mods, QWidget* parent)
|
2022-08-10 14:48:34 -03:00
|
|
|
: ExternalResourcesPage(inst, mods, parent), m_model(mods)
|
2014-06-02 00:49:53 +02:00
|
|
|
{
|
2022-03-03 09:51:46 -03: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 18:03:21 -03:00
|
|
|
// do not affect the Resource pack and Shader pack tabs
|
|
|
|
{
|
2022-05-30 16:36:30 +02: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-02 00:49:53 +02:00
|
|
|
|
2022-05-30 16:36:30 +02:00
|
|
|
ui->actionsToolbar->insertActionBefore(ui->actionAddItem, ui->actionDownloadItem);
|
|
|
|
|
|
|
|
connect(ui->actionDownloadItem, &QAction::triggered, this, &ModFolderPage::installMods);
|
2022-06-04 21:18:51 -03:00
|
|
|
|
2022-07-19 18:03:45 +02:00
|
|
|
ui->actionUpdateItem->setToolTip(tr("Try to check or update all selected mods (all mods if none are selected)"));
|
2022-06-04 21:18:51 -03:00
|
|
|
ui->actionsToolbar->insertActionAfter(ui->actionAddItem, ui->actionUpdateItem);
|
|
|
|
connect(ui->actionUpdateItem, &QAction::triggered, this, &ModFolderPage::updateMods);
|
|
|
|
|
2023-06-07 01:38:10 +03:00
|
|
|
ui->actionVisitItemPage->setToolTip(tr("Go to mod's home page"));
|
2023-06-07 01:23:53 +03:00
|
|
|
ui->actionsToolbar->insertActionAfter(ui->actionViewFolder, ui->actionVisitItemPage);
|
|
|
|
connect(ui->actionVisitItemPage, &QAction::triggered, this, &ModFolderPage::visitModPages);
|
|
|
|
|
2022-08-03 16:39:30 +10:00
|
|
|
auto check_allow_update = [this] {
|
2023-06-07 01:23:53 +03:00
|
|
|
return (!m_instance || !m_instance->isRunning()) && (ui->treeView->selectionModel()->hasSelection() || !m_model->empty());
|
2022-08-03 16:39:30 +10:00
|
|
|
};
|
|
|
|
|
|
|
|
connect(ui->treeView->selectionModel(), &QItemSelectionModel::selectionChanged, this, [this, check_allow_update] {
|
|
|
|
ui->actionUpdateItem->setEnabled(check_allow_update());
|
2022-06-04 21:18:51 -03:00
|
|
|
|
2023-06-07 01:23:53 +03:00
|
|
|
auto selection = m_filterModel->mapSelectionToSource(ui->treeView->selectionModel()->selection()).indexes();
|
|
|
|
auto mods_list = m_model->selectedMods(selection);
|
2023-06-07 01:38:10 +03:00
|
|
|
auto selected = std::count_if(mods_list.cbegin(), mods_list.cend(),
|
2023-06-07 01:23:53 +03:00
|
|
|
[](Mod* v) { return v->metadata() != nullptr || v->homeurl().size() != 0; });
|
2023-06-07 01:38:10 +03:00
|
|
|
if (selected <= 1) {
|
2023-07-03 14:17:39 +03:00
|
|
|
ui->actionVisitItemPage->setText(tr("Visit mod's page"));
|
2023-06-07 01:38:10 +03:00
|
|
|
ui->actionVisitItemPage->setToolTip(tr("Go to mod's home page"));
|
|
|
|
} else {
|
2023-07-07 15:53:50 +01:00
|
|
|
ui->actionVisitItemPage->setText(tr("Visit mods' pages"));
|
2023-06-07 01:38:10 +03:00
|
|
|
ui->actionVisitItemPage->setToolTip(tr("Go to the pages of the selected mods"));
|
|
|
|
}
|
|
|
|
ui->actionVisitItemPage->setEnabled(selected != 0);
|
2022-08-02 14:14:45 +10:00
|
|
|
});
|
|
|
|
|
2023-06-07 01:23:53 +03:00
|
|
|
connect(mods.get(), &ModFolderModel::rowsInserted, this,
|
|
|
|
[this, check_allow_update] { ui->actionUpdateItem->setEnabled(check_allow_update()); });
|
|
|
|
|
|
|
|
connect(mods.get(), &ModFolderModel::rowsRemoved, this,
|
|
|
|
[this, check_allow_update] { ui->actionUpdateItem->setEnabled(check_allow_update()); });
|
2022-08-01 20:18:48 +10:00
|
|
|
|
2023-06-15 12:32:48 +03:00
|
|
|
connect(mods.get(), &ModFolderModel::updateFinished, this,
|
2023-06-19 12:22:22 +03:00
|
|
|
[this, check_allow_update] { ui->actionUpdateItem->setEnabled(check_allow_update()); });
|
2022-08-02 14:14:45 +10:00
|
|
|
|
2022-11-27 23:10:32 +01:00
|
|
|
connect(m_instance, &BaseInstance::runningStatusChanged, this, &ModFolderPage::runningStateChanged);
|
2022-08-02 14:14:45 +10:00
|
|
|
ModFolderPage::runningStateChanged(m_instance && m_instance->isRunning());
|
2019-08-04 21:13:50 +02:00
|
|
|
}
|
2014-06-02 00:49:53 +02:00
|
|
|
}
|
|
|
|
|
2022-08-01 20:19:20 +10:00
|
|
|
void ModFolderPage::runningStateChanged(bool running)
|
|
|
|
{
|
|
|
|
ui->actionDownloadItem->setEnabled(!running);
|
|
|
|
ui->actionUpdateItem->setEnabled(!running);
|
2022-10-18 17:28:23 +02:00
|
|
|
ui->actionAddItem->setEnabled(!running);
|
|
|
|
ui->actionEnableItem->setEnabled(!running);
|
|
|
|
ui->actionDisableItem->setEnabled(!running);
|
|
|
|
ui->actionRemoveItem->setEnabled(!running);
|
2022-08-01 20:19:20 +10:00
|
|
|
}
|
|
|
|
|
2014-07-12 17:58:23 +02:00
|
|
|
bool ModFolderPage::shouldDisplay() const
|
2014-06-30 02:02:57 +02:00
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2022-08-10 14:48:34 -03:00
|
|
|
bool ModFolderPage::onSelectionChanged(const QModelIndex& current, const QModelIndex& previous)
|
|
|
|
{
|
|
|
|
auto sourceCurrent = m_filterModel->mapToSource(current);
|
|
|
|
int row = sourceCurrent.row();
|
|
|
|
Mod const* m = m_model->at(row);
|
|
|
|
if (m)
|
|
|
|
ui->frame->updateWithMod(*m);
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2023-06-07 01:23:53 +03:00
|
|
|
void ModFolderPage::removeItems(const QItemSelection& selection)
|
2022-09-03 13:27:27 -03:00
|
|
|
{
|
|
|
|
m_model->deleteMods(selection.indexes());
|
|
|
|
}
|
|
|
|
|
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 18:03:21 -03:00
|
|
|
void ModFolderPage::installMods()
|
2014-06-02 00:49:53 +02: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 18:03:21 -03:00
|
|
|
if (!m_controlsEnabled)
|
2019-07-15 01:07:21 +02: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 18:03:21 -03:00
|
|
|
if (m_instance->typeName() != "Minecraft")
|
|
|
|
return; // this is a null instance or a legacy instance
|
2022-06-04 21:18:51 -03: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 18:03:21 -03:00
|
|
|
auto profile = static_cast<MinecraftInstance*>(m_instance)->getPackProfile();
|
2022-11-25 09:23:46 -03:00
|
|
|
if (!profile->getModLoaders().has_value()) {
|
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 18:03:21 -03:00
|
|
|
QMessageBox::critical(this, tr("Error"), tr("Please install a mod loader first!"));
|
2022-01-14 20:22:15 +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 18:03:21 -03:00
|
|
|
|
2022-12-16 19:03:52 -03:00
|
|
|
ResourceDownload::ModDownloadDialog mdownload(this, m_model, m_instance);
|
2022-04-01 09:10:51 -03:00
|
|
|
if (mdownload.exec()) {
|
2022-06-12 13:51:19 -03:00
|
|
|
ConcurrentTask* tasks = new ConcurrentTask(this);
|
2022-04-01 09:10:51 -03:00
|
|
|
connect(tasks, &Task::failed, [this, tasks](QString reason) {
|
|
|
|
CustomMessageBox::selectable(this, tr("Error"), reason, QMessageBox::Critical)->show();
|
|
|
|
tasks->deleteLater();
|
|
|
|
});
|
2022-05-01 11:08:00 -03: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 09:10:51 -03: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 18:03:21 -03:00
|
|
|
if (warnings.count())
|
|
|
|
CustomMessageBox::selectable(this, tr("Warnings"), warnings.join('\n'), QMessageBox::Warning)->show();
|
2022-06-04 21:18:51 -03:00
|
|
|
|
2022-04-01 09:10:51 -03: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 18:03:21 -03:00
|
|
|
for (auto& task : mdownload.getTasks()) {
|
2022-04-01 09:10:51 -03:00
|
|
|
tasks->addTask(task);
|
2022-01-14 20:22:15 +01:00
|
|
|
}
|
2022-05-01 11:08:00 -03:00
|
|
|
|
2022-04-01 09:10:51 -03:00
|
|
|
ProgressDialog loadDialog(this);
|
|
|
|
loadDialog.setSkipButton(true, tr("Abort"));
|
|
|
|
loadDialog.execWithTask(tasks);
|
2014-06-02 00:49:53 +02: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 18:03:21 -03:00
|
|
|
m_model->update();
|
2014-06-02 00:49:53 +02:00
|
|
|
}
|
|
|
|
}
|
2022-06-04 21:18:51 -03: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 15:15:25 -03:00
|
|
|
mods_list = m_model->allMods();
|
2022-06-04 21:18:51 -03: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 18:03:45 +02: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! :)");
|
|
|
|
}
|
|
|
|
}
|
2023-06-07 01:23:53 +03:00
|
|
|
CustomMessageBox::selectable(this, tr("Update checker"), message)->exec();
|
2022-06-04 21:18:51 -03:00
|
|
|
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();
|
|
|
|
}
|
|
|
|
}
|
2022-08-08 23:40:25 +02:00
|
|
|
|
|
|
|
CoreModFolderPage::CoreModFolderPage(BaseInstance* inst, std::shared_ptr<ModFolderModel> mods, QWidget* parent)
|
|
|
|
: ModFolderPage(inst, mods, parent)
|
|
|
|
{}
|
|
|
|
|
|
|
|
bool CoreModFolderPage::shouldDisplay() const
|
|
|
|
{
|
|
|
|
if (ModFolderPage::shouldDisplay()) {
|
|
|
|
auto inst = dynamic_cast<MinecraftInstance*>(m_instance);
|
|
|
|
if (!inst)
|
|
|
|
return true;
|
|
|
|
|
|
|
|
auto version = inst->getPackProfile();
|
|
|
|
|
|
|
|
if (!version)
|
|
|
|
return true;
|
|
|
|
if (!version->getComponent("net.minecraftforge"))
|
|
|
|
return false;
|
|
|
|
if (!version->getComponent("net.minecraft"))
|
|
|
|
return false;
|
|
|
|
if (version->getComponent("net.minecraft")->getReleaseDateTime() < g_VersionFilterData.legacyCutoffDate)
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
2023-02-11 17:36:06 -05:00
|
|
|
|
|
|
|
NilModFolderPage::NilModFolderPage(BaseInstance* inst, std::shared_ptr<ModFolderModel> mods, QWidget* parent)
|
|
|
|
: ModFolderPage(inst, mods, parent)
|
|
|
|
{}
|
|
|
|
|
|
|
|
bool NilModFolderPage::shouldDisplay() const
|
|
|
|
{
|
2023-02-13 01:45:23 -05:00
|
|
|
return m_model->dir().exists();
|
2023-02-11 17:36:06 -05:00
|
|
|
}
|
2023-06-07 01:23:53 +03:00
|
|
|
|
|
|
|
void ModFolderPage::visitModPages()
|
|
|
|
{
|
|
|
|
auto selection = m_filterModel->mapSelectionToSource(ui->treeView->selectionModel()->selection()).indexes();
|
2023-06-25 10:41:29 +03:00
|
|
|
for (auto mod : m_model->selectedMods(selection)) {
|
|
|
|
auto url = mod->metaurl();
|
|
|
|
if (!url.isEmpty())
|
|
|
|
DesktopServices::openUrl(url);
|
|
|
|
}
|
2023-07-07 15:53:50 +01:00
|
|
|
}
|