2015-02-07 10:43:09 +01:00
|
|
|
#pragma once
|
2017-07-24 09:01:37 +02:00
|
|
|
#include "minecraft/MinecraftInstance.h"
|
2015-10-05 01:47:27 +02:00
|
|
|
#include <FileSystem.h>
|
2021-11-22 03:55:16 +01:00
|
|
|
#include "ui/pages/BasePage.h"
|
|
|
|
#include "ui/pages/BasePageProvider.h"
|
|
|
|
#include "ui/pages/instance/LogPage.h"
|
|
|
|
#include "ui/pages/instance/VersionPage.h"
|
2022-10-14 14:38:42 -03:00
|
|
|
#include "ui/pages/instance/ManagedPackPage.h"
|
2021-11-22 03:55:16 +01:00
|
|
|
#include "ui/pages/instance/ModFolderPage.h"
|
|
|
|
#include "ui/pages/instance/ResourcePackPage.h"
|
|
|
|
#include "ui/pages/instance/TexturePackPage.h"
|
|
|
|
#include "ui/pages/instance/ShaderPackPage.h"
|
|
|
|
#include "ui/pages/instance/NotesPage.h"
|
|
|
|
#include "ui/pages/instance/ScreenshotsPage.h"
|
|
|
|
#include "ui/pages/instance/InstanceSettingsPage.h"
|
|
|
|
#include "ui/pages/instance/OtherLogsPage.h"
|
|
|
|
#include "ui/pages/instance/WorldListPage.h"
|
|
|
|
#include "ui/pages/instance/ServersPage.h"
|
|
|
|
#include "ui/pages/instance/GameOptionsPage.h"
|
2015-02-07 10:43:09 +01:00
|
|
|
|
|
|
|
class InstancePageProvider : public QObject, public BasePageProvider
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
public:
|
|
|
|
explicit InstancePageProvider(InstancePtr parent)
|
|
|
|
{
|
|
|
|
inst = parent;
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual ~InstancePageProvider() {};
|
|
|
|
virtual QList<BasePage *> getPages() override
|
|
|
|
{
|
|
|
|
QList<BasePage *> values;
|
2016-08-06 15:39:29 +02:00
|
|
|
values.append(new LogPage(inst));
|
2017-07-24 09:01:37 +02:00
|
|
|
std::shared_ptr<MinecraftInstance> onesix = std::dynamic_pointer_cast<MinecraftInstance>(inst);
|
2022-02-21 22:30:44 +01:00
|
|
|
values.append(new VersionPage(onesix.get()));
|
2022-10-14 14:38:42 -03:00
|
|
|
values.append(ManagedPackPage::createPage(onesix.get()));
|
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 modsPage = new ModFolderPage(onesix.get(), onesix->loaderModList());
|
2023-02-11 17:35:08 -05:00
|
|
|
modsPage->setFilter("%1 (*.zip *.jar *.litemod *.nilmod)");
|
2022-02-21 22:30:44 +01:00
|
|
|
values.append(modsPage);
|
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
|
|
|
values.append(new CoreModFolderPage(onesix.get(), onesix->coreModList()));
|
2023-02-11 17:36:06 -05:00
|
|
|
values.append(new NilModFolderPage(onesix.get(), onesix->nilModList()));
|
2022-08-10 14:48:34 -03:00
|
|
|
values.append(new ResourcePackPage(onesix.get(), onesix->resourcePackList()));
|
|
|
|
values.append(new TexturePackPage(onesix.get(), onesix->texturePackList()));
|
|
|
|
values.append(new ShaderPackPage(onesix.get(), onesix->shaderPackList()));
|
2022-02-21 22:30:44 +01:00
|
|
|
values.append(new NotesPage(onesix.get()));
|
|
|
|
values.append(new WorldListPage(onesix.get(), onesix->worldList()));
|
|
|
|
values.append(new ServersPage(onesix));
|
|
|
|
// values.append(new GameOptionsPage(onesix.get()));
|
|
|
|
values.append(new ScreenshotsPage(FS::PathCombine(onesix->gameRoot(), "screenshots")));
|
|
|
|
values.append(new InstanceSettingsPage(onesix.get()));
|
2015-08-18 02:25:24 +02:00
|
|
|
auto logMatcher = inst->getLogFileMatcher();
|
|
|
|
if(logMatcher)
|
|
|
|
{
|
2015-08-19 02:04:56 +02:00
|
|
|
values.append(new OtherLogsPage(inst->getLogFileRoot(), logMatcher));
|
2015-04-05 22:00:32 +02:00
|
|
|
}
|
2015-02-07 10:43:09 +01:00
|
|
|
return values;
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual QString dialogTitle() override
|
|
|
|
{
|
|
|
|
return tr("Edit Instance (%1)").arg(inst->name());
|
|
|
|
}
|
|
|
|
protected:
|
|
|
|
InstancePtr inst;
|
|
|
|
};
|
2022-02-11 22:09:47 -05:00
|
|
|
|