2023-01-23 11:03:55 -03:00
|
|
|
// SPDX-FileCopyrightText: 2023 flowln <flowlnlnln@gmail.com>
|
|
|
|
//
|
|
|
|
// SPDX-License-Identifier: GPL-3.0-only AND Apache-2.0
|
2022-03-20 20:45:58 +01:00
|
|
|
/*
|
2022-11-06 10:08:54 +00:00
|
|
|
* Prism Launcher - Minecraft Launcher
|
2022-05-26 23:18:54 +02:00
|
|
|
* Copyright (C) 2022 Sefa Eyeoglu <contact@scrumplex.net>
|
2022-11-01 17:02:24 +00:00
|
|
|
* Copyright (C) 2022 TheKodeToad <TheKodeToad@proton.me>
|
2022-03-20 20:45:58 +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.
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2022-11-25 09:23:46 -03:00
|
|
|
#include "FlameResourcePages.h"
|
|
|
|
#include "ui_ResourcePage.h"
|
2022-01-16 11:20:21 +01:00
|
|
|
|
2022-11-25 09:23:46 -03:00
|
|
|
#include "FlameResourceModels.h"
|
2022-12-16 21:44:21 -03:00
|
|
|
#include "ui/dialogs/ResourceDownloadDialog.h"
|
2022-01-16 11:20:21 +01:00
|
|
|
|
2022-12-16 19:03:52 -03:00
|
|
|
namespace ResourceDownload {
|
|
|
|
|
2022-12-16 20:26:10 -03:00
|
|
|
static bool isOptedOut(ModPlatform::IndexedVersion const& ver)
|
|
|
|
{
|
|
|
|
return ver.downloadUrl.isEmpty();
|
|
|
|
}
|
|
|
|
|
2023-08-02 18:35:35 +02:00
|
|
|
FlameModPage::FlameModPage(ModDownloadDialog* dialog, BaseInstance& instance) : ModPage(dialog, instance)
|
2022-03-02 21:17:10 -03:00
|
|
|
{
|
2022-12-18 15:41:46 -03:00
|
|
|
m_model = new FlameModModel(instance);
|
2022-11-25 09:23:46 -03:00
|
|
|
m_ui->packView->setModel(m_model);
|
2022-03-02 21:17:10 -03:00
|
|
|
|
2022-12-20 12:15:17 -03:00
|
|
|
addSortings();
|
2022-03-02 21:17:10 -03:00
|
|
|
|
2022-11-01 16:58:22 +00:00
|
|
|
// sometimes Qt just ignores virtual slots and doesn't work as intended it seems,
|
2022-03-02 21:17:10 -03:00
|
|
|
// so it's best not to connect them in the parent's contructor...
|
2022-11-25 09:23:46 -03:00
|
|
|
connect(m_ui->sortByBox, SIGNAL(currentIndexChanged(int)), this, SLOT(triggerSearch()));
|
|
|
|
connect(m_ui->packView->selectionModel(), &QItemSelectionModel::currentChanged, this, &FlameModPage::onSelectionChanged);
|
|
|
|
connect(m_ui->versionSelectionBox, &QComboBox::currentTextChanged, this, &FlameModPage::onVersionSelectionChanged);
|
|
|
|
connect(m_ui->resourceSelectionButton, &QPushButton::clicked, this, &FlameModPage::onResourceSelected);
|
2022-09-10 18:49:00 -03:00
|
|
|
|
2022-11-25 09:23:46 -03:00
|
|
|
m_ui->packDescription->setMetaEntry(metaEntryBase());
|
2022-01-16 11:20:21 +01:00
|
|
|
}
|
|
|
|
|
2023-08-02 18:35:35 +02:00
|
|
|
auto FlameModPage::validateVersion(ModPlatform::IndexedVersion& ver,
|
|
|
|
QString mineVer,
|
2023-08-23 10:26:57 +03:00
|
|
|
std::optional<ModPlatform::ModLoaderTypes> loaders) const -> bool
|
2022-03-02 21:17:10 -03:00
|
|
|
{
|
2023-08-25 09:05:04 +03:00
|
|
|
return ver.mcVersion.contains(mineVer) && !ver.downloadUrl.isEmpty() &&
|
|
|
|
(!loaders.has_value() || !ver.loaders || loaders.value() & ver.loaders);
|
2022-01-16 11:20:21 +01:00
|
|
|
}
|
2022-03-07 19:29:59 -03:00
|
|
|
|
2022-10-12 10:26:14 -03:00
|
|
|
bool FlameModPage::optedOut(ModPlatform::IndexedVersion& ver) const
|
|
|
|
{
|
2022-12-16 20:26:10 -03:00
|
|
|
return isOptedOut(ver);
|
2022-10-12 10:26:14 -03:00
|
|
|
}
|
|
|
|
|
2022-11-01 16:58:22 +00:00
|
|
|
void FlameModPage::openUrl(const QUrl& url)
|
|
|
|
{
|
|
|
|
if (url.scheme().isEmpty()) {
|
|
|
|
QString query = url.query(QUrl::FullyDecoded);
|
2022-11-06 10:08:54 +00:00
|
|
|
|
2022-11-01 16:58:22 +00:00
|
|
|
if (query.startsWith("remoteUrl=")) {
|
|
|
|
// attempt to resolve url from warning page
|
|
|
|
query.remove(0, 10);
|
2023-08-02 18:35:35 +02:00
|
|
|
ModPage::openUrl({ QUrl::fromPercentEncoding(query.toUtf8()) }); // double decoding is necessary
|
2022-11-01 16:58:22 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
ModPage::openUrl(url);
|
2022-11-06 10:08:54 +00:00
|
|
|
}
|
2022-12-16 19:03:52 -03:00
|
|
|
|
2022-12-16 20:26:10 -03:00
|
|
|
FlameResourcePackPage::FlameResourcePackPage(ResourcePackDownloadDialog* dialog, BaseInstance& instance)
|
|
|
|
: ResourcePackResourcePage(dialog, instance)
|
|
|
|
{
|
|
|
|
m_model = new FlameResourcePackModel(instance);
|
|
|
|
m_ui->packView->setModel(m_model);
|
|
|
|
|
|
|
|
addSortings();
|
|
|
|
|
|
|
|
// sometimes Qt just ignores virtual slots and doesn't work as intended it seems,
|
|
|
|
// so it's best not to connect them in the parent's contructor...
|
|
|
|
connect(m_ui->sortByBox, SIGNAL(currentIndexChanged(int)), this, SLOT(triggerSearch()));
|
|
|
|
connect(m_ui->packView->selectionModel(), &QItemSelectionModel::currentChanged, this, &FlameResourcePackPage::onSelectionChanged);
|
|
|
|
connect(m_ui->versionSelectionBox, &QComboBox::currentTextChanged, this, &FlameResourcePackPage::onVersionSelectionChanged);
|
|
|
|
connect(m_ui->resourceSelectionButton, &QPushButton::clicked, this, &FlameResourcePackPage::onResourceSelected);
|
|
|
|
|
|
|
|
m_ui->packDescription->setMetaEntry(metaEntryBase());
|
|
|
|
}
|
|
|
|
|
|
|
|
bool FlameResourcePackPage::optedOut(ModPlatform::IndexedVersion& ver) const
|
|
|
|
{
|
|
|
|
return isOptedOut(ver);
|
|
|
|
}
|
|
|
|
|
|
|
|
void FlameResourcePackPage::openUrl(const QUrl& url)
|
|
|
|
{
|
|
|
|
if (url.scheme().isEmpty()) {
|
|
|
|
QString query = url.query(QUrl::FullyDecoded);
|
|
|
|
|
|
|
|
if (query.startsWith("remoteUrl=")) {
|
|
|
|
// attempt to resolve url from warning page
|
|
|
|
query.remove(0, 10);
|
2023-08-02 18:35:35 +02:00
|
|
|
ResourcePackResourcePage::openUrl({ QUrl::fromPercentEncoding(query.toUtf8()) }); // double decoding is necessary
|
2022-12-16 20:26:10 -03:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
ResourcePackResourcePage::openUrl(url);
|
|
|
|
}
|
|
|
|
|
2023-01-29 18:07:49 -03:00
|
|
|
FlameTexturePackPage::FlameTexturePackPage(TexturePackDownloadDialog* dialog, BaseInstance& instance)
|
|
|
|
: TexturePackResourcePage(dialog, instance)
|
|
|
|
{
|
|
|
|
m_model = new FlameTexturePackModel(instance);
|
|
|
|
m_ui->packView->setModel(m_model);
|
|
|
|
|
|
|
|
addSortings();
|
|
|
|
|
|
|
|
// sometimes Qt just ignores virtual slots and doesn't work as intended it seems,
|
|
|
|
// so it's best not to connect them in the parent's contructor...
|
|
|
|
connect(m_ui->sortByBox, SIGNAL(currentIndexChanged(int)), this, SLOT(triggerSearch()));
|
|
|
|
connect(m_ui->packView->selectionModel(), &QItemSelectionModel::currentChanged, this, &FlameTexturePackPage::onSelectionChanged);
|
|
|
|
connect(m_ui->versionSelectionBox, &QComboBox::currentTextChanged, this, &FlameTexturePackPage::onVersionSelectionChanged);
|
|
|
|
connect(m_ui->resourceSelectionButton, &QPushButton::clicked, this, &FlameTexturePackPage::onResourceSelected);
|
|
|
|
|
|
|
|
m_ui->packDescription->setMetaEntry(metaEntryBase());
|
|
|
|
}
|
|
|
|
|
|
|
|
bool FlameTexturePackPage::optedOut(ModPlatform::IndexedVersion& ver) const
|
|
|
|
{
|
|
|
|
return isOptedOut(ver);
|
|
|
|
}
|
|
|
|
|
|
|
|
void FlameTexturePackPage::openUrl(const QUrl& url)
|
|
|
|
{
|
|
|
|
if (url.scheme().isEmpty()) {
|
|
|
|
QString query = url.query(QUrl::FullyDecoded);
|
|
|
|
|
|
|
|
if (query.startsWith("remoteUrl=")) {
|
|
|
|
// attempt to resolve url from warning page
|
|
|
|
query.remove(0, 10);
|
2023-08-02 18:35:35 +02:00
|
|
|
ResourcePackResourcePage::openUrl({ QUrl::fromPercentEncoding(query.toUtf8()) }); // double decoding is necessary
|
2023-01-29 18:07:49 -03:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TexturePackResourcePage::openUrl(url);
|
|
|
|
}
|
|
|
|
|
2023-09-04 14:13:44 +01:00
|
|
|
FlameShaderPackPage::FlameShaderPackPage(ShaderPackDownloadDialog* dialog, BaseInstance& instance)
|
|
|
|
: ShaderPackResourcePage(dialog, instance)
|
|
|
|
{
|
|
|
|
m_model = new FlameShaderPackModel(instance);
|
|
|
|
m_ui->packView->setModel(m_model);
|
|
|
|
|
|
|
|
addSortings();
|
|
|
|
|
|
|
|
// sometimes Qt just ignores virtual slots and doesn't work as intended it seems,
|
|
|
|
// so it's best not to connect them in the parent's constructor...
|
|
|
|
connect(m_ui->sortByBox, SIGNAL(currentIndexChanged(int)), this, SLOT(triggerSearch()));
|
|
|
|
connect(m_ui->packView->selectionModel(), &QItemSelectionModel::currentChanged, this, &FlameShaderPackPage::onSelectionChanged);
|
|
|
|
connect(m_ui->versionSelectionBox, &QComboBox::currentTextChanged, this, &FlameShaderPackPage::onVersionSelectionChanged);
|
|
|
|
connect(m_ui->resourceSelectionButton, &QPushButton::clicked, this, &FlameShaderPackPage::onResourceSelected);
|
|
|
|
|
|
|
|
m_ui->packDescription->setMetaEntry(metaEntryBase());
|
|
|
|
}
|
|
|
|
|
|
|
|
bool FlameShaderPackPage::optedOut(ModPlatform::IndexedVersion& ver) const
|
|
|
|
{
|
|
|
|
return isOptedOut(ver);
|
|
|
|
}
|
|
|
|
|
|
|
|
void FlameShaderPackPage::openUrl(const QUrl& url)
|
|
|
|
{
|
|
|
|
if (url.scheme().isEmpty()) {
|
|
|
|
QString query = url.query(QUrl::FullyDecoded);
|
|
|
|
|
|
|
|
if (query.startsWith("remoteUrl=")) {
|
|
|
|
// attempt to resolve url from warning page
|
|
|
|
query.remove(0, 10);
|
|
|
|
ShaderPackResourcePage::openUrl({ QUrl::fromPercentEncoding(query.toUtf8()) }); // double decoding is necessary
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
ShaderPackResourcePage::openUrl(url);
|
|
|
|
}
|
|
|
|
|
2022-12-16 20:26:10 -03:00
|
|
|
// I don't know why, but doing this on the parent class makes it so that
|
|
|
|
// other mod providers start loading before being selected, at least with
|
|
|
|
// my Qt, so we need to implement this in every derived class...
|
2023-08-02 18:35:35 +02:00
|
|
|
auto FlameModPage::shouldDisplay() const -> bool
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
auto FlameResourcePackPage::shouldDisplay() const -> bool
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
auto FlameTexturePackPage::shouldDisplay() const -> bool
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
2023-09-04 14:13:44 +01:00
|
|
|
auto FlameShaderPackPage::shouldDisplay() const -> bool
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
2022-12-16 20:26:10 -03:00
|
|
|
|
2022-12-16 19:03:52 -03:00
|
|
|
} // namespace ResourceDownload
|