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-05-26 23:18:54 +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>
|
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
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
2014-07-12 23:02:52 +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 "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
|
|
|
class ModFolderPage : public ExternalResourcesPage {
|
2018-07-15 14:51:05 +02:00
|
|
|
Q_OBJECT
|
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
|
|
|
public:
|
|
|
|
explicit ModFolderPage(BaseInstance* inst, std::shared_ptr<ModFolderModel> mods, QWidget* parent = nullptr);
|
|
|
|
virtual ~ModFolderPage() = default;
|
2015-05-12 23:43:11 +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
|
|
|
void setFilter(const QString& filter) { m_fileSelectionFilter = filter; }
|
2014-07-12 17:58:23 +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
|
|
|
virtual QString displayName() const override { return tr("Mods"); }
|
|
|
|
virtual QIcon icon() const override { return APPLICATION->getThemedIcon("loadermods"); }
|
|
|
|
virtual QString id() const override { return "mods"; }
|
|
|
|
virtual QString helpPage() const override { return "Loader-mods"; }
|
2014-07-12 17:58:23 +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
|
|
|
virtual bool shouldDisplay() const override;
|
2014-06-02 00:49:53 +02:00
|
|
|
|
2022-08-10 14:48:34 -03:00
|
|
|
public slots:
|
|
|
|
bool onSelectionChanged(const QModelIndex& current, const QModelIndex& previous) override;
|
|
|
|
|
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
|
|
|
private slots:
|
2022-11-27 23:10:32 +01:00
|
|
|
void runningStateChanged(bool running);
|
2022-12-14 15:02:04 +00:00
|
|
|
void removeItems(const QItemSelection &selection) override;
|
2022-09-03 13:27:27 -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
|
|
|
void installMods();
|
2022-06-04 21:18:51 -03:00
|
|
|
void updateMods();
|
2023-06-07 01:23:53 +03:00
|
|
|
void visitModPages();
|
2022-08-10 14:48:34 -03:00
|
|
|
|
|
|
|
protected:
|
|
|
|
std::shared_ptr<ModFolderModel> m_model;
|
2014-06-02 00:49:53 +02:00
|
|
|
};
|
2014-07-10 00:47:08 +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
|
|
|
class CoreModFolderPage : public ModFolderPage {
|
|
|
|
public:
|
|
|
|
explicit CoreModFolderPage(BaseInstance* inst, std::shared_ptr<ModFolderModel> mods, QWidget* parent = 0);
|
|
|
|
virtual ~CoreModFolderPage() = default;
|
2022-08-08 23:40:25 +02:00
|
|
|
|
|
|
|
virtual QString displayName() const override { return tr("Core mods"); }
|
|
|
|
virtual QIcon icon() const override { return APPLICATION->getThemedIcon("coremods"); }
|
|
|
|
virtual QString id() const override { return "coremods"; }
|
|
|
|
virtual QString helpPage() const override { return "Core-mods"; }
|
|
|
|
|
|
|
|
virtual bool shouldDisplay() const override;
|
2014-07-10 00:47:08 +02:00
|
|
|
};
|
2023-02-11 17:36:06 -05:00
|
|
|
|
|
|
|
class NilModFolderPage : public ModFolderPage {
|
|
|
|
public:
|
|
|
|
explicit NilModFolderPage(BaseInstance* inst, std::shared_ptr<ModFolderModel> mods, QWidget* parent = 0);
|
|
|
|
virtual ~NilModFolderPage() = default;
|
|
|
|
|
|
|
|
virtual QString displayName() const override { return tr("Nilmods"); }
|
|
|
|
virtual QIcon icon() const override { return APPLICATION->getThemedIcon("coremods"); }
|
|
|
|
virtual QString id() const override { return "nilmods"; }
|
2023-02-13 01:45:23 -05:00
|
|
|
virtual QString helpPage() const override { return "Nilmods"; }
|
2023-02-11 17:36:06 -05:00
|
|
|
|
|
|
|
virtual bool shouldDisplay() const override;
|
|
|
|
};
|