Merge pull request #1120 from Trial97/visit_mod_page
This commit is contained in:
commit
1131038fdb
@ -169,6 +169,13 @@ auto Mod::homeurl() const -> QString
|
|||||||
return details().homeurl;
|
return details().homeurl;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
auto Mod::metaurl() const -> QString
|
||||||
|
{
|
||||||
|
if (metadata() == nullptr)
|
||||||
|
return homeurl();
|
||||||
|
return ModPlatform::getMetaURL(metadata()->provider, metadata()->project_id);
|
||||||
|
}
|
||||||
|
|
||||||
auto Mod::description() const -> QString
|
auto Mod::description() const -> QString
|
||||||
{
|
{
|
||||||
return details().description;
|
return details().description;
|
||||||
|
@ -70,6 +70,7 @@ public:
|
|||||||
auto provider() const -> std::optional<QString>;
|
auto provider() const -> std::optional<QString>;
|
||||||
auto licenses() const -> const QList<ModLicense>&;
|
auto licenses() const -> const QList<ModLicense>&;
|
||||||
auto issueTracker() const -> QString;
|
auto issueTracker() const -> QString;
|
||||||
|
auto metaurl() const -> QString;
|
||||||
|
|
||||||
/** Get the intneral path to the mod's icon file*/
|
/** Get the intneral path to the mod's icon file*/
|
||||||
QString iconPath() const { return m_local_details.icon_file; };
|
QString iconPath() const { return m_local_details.icon_file; };
|
||||||
|
@ -70,11 +70,17 @@ auto ProviderCapabilities::hash(ResourceProvider p, QIODevice* device, QString t
|
|||||||
}
|
}
|
||||||
|
|
||||||
QCryptographicHash hash(algo);
|
QCryptographicHash hash(algo);
|
||||||
if(!hash.addData(device))
|
if (!hash.addData(device))
|
||||||
qCritical() << "Failed to read JAR to create hash!";
|
qCritical() << "Failed to read JAR to create hash!";
|
||||||
|
|
||||||
Q_ASSERT(hash.result().length() == hash.hashLength(algo));
|
Q_ASSERT(hash.result().length() == hash.hashLength(algo));
|
||||||
return { hash.result().toHex() };
|
return { hash.result().toHex() };
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QString getMetaURL(ResourceProvider provider, QVariant projectID)
|
||||||
|
{
|
||||||
|
return ((provider == ModPlatform::ResourceProvider::FLAME) ? "https://www.curseforge.com/projects/" : "https://modrinth.com/mod/") +
|
||||||
|
projectID.toString();
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace ModPlatform
|
} // namespace ModPlatform
|
||||||
|
@ -144,6 +144,7 @@ inline auto getOverrideDeps() -> QList<OverrideDep>
|
|||||||
{ "qvIfYCYJ", "P7dR8mSH", "API", ModPlatform::ResourceProvider::MODRINTH },
|
{ "qvIfYCYJ", "P7dR8mSH", "API", ModPlatform::ResourceProvider::MODRINTH },
|
||||||
{ "lwVhp9o5", "Ha28R6CL", "KotlinLibraries", ModPlatform::ResourceProvider::MODRINTH } };
|
{ "lwVhp9o5", "Ha28R6CL", "KotlinLibraries", ModPlatform::ResourceProvider::MODRINTH } };
|
||||||
};
|
};
|
||||||
|
QString getMetaURL(ResourceProvider provider, QVariant projectID);
|
||||||
|
|
||||||
} // namespace ModPlatform
|
} // namespace ModPlatform
|
||||||
|
|
||||||
|
@ -157,6 +157,17 @@
|
|||||||
<string>Try to check or update all selected resources (all resources if none are selected)</string>
|
<string>Try to check or update all selected resources (all resources if none are selected)</string>
|
||||||
</property>
|
</property>
|
||||||
</action>
|
</action>
|
||||||
|
<action name="actionVisitItemPage">
|
||||||
|
<property name="enabled">
|
||||||
|
<bool>false</bool>
|
||||||
|
</property>
|
||||||
|
<property name="text">
|
||||||
|
<string>Visit mod's page</string>
|
||||||
|
</property>
|
||||||
|
<property name="toolTip">
|
||||||
|
<string>Go to mods home page</string>
|
||||||
|
</property>
|
||||||
|
</action>
|
||||||
</widget>
|
</widget>
|
||||||
<customwidgets>
|
<customwidgets>
|
||||||
<customwidget>
|
<customwidget>
|
||||||
|
@ -45,6 +45,7 @@
|
|||||||
#include <QMenu>
|
#include <QMenu>
|
||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
#include <QSortFilterProxyModel>
|
#include <QSortFilterProxyModel>
|
||||||
|
#include <algorithm>
|
||||||
|
|
||||||
#include "Application.h"
|
#include "Application.h"
|
||||||
|
|
||||||
@ -60,6 +61,7 @@
|
|||||||
#include "minecraft/mod/Mod.h"
|
#include "minecraft/mod/Mod.h"
|
||||||
#include "minecraft/mod/ModFolderModel.h"
|
#include "minecraft/mod/ModFolderModel.h"
|
||||||
|
|
||||||
|
#include "modplatform/ModIndex.h"
|
||||||
#include "modplatform/ResourceAPI.h"
|
#include "modplatform/ResourceAPI.h"
|
||||||
|
|
||||||
#include "Version.h"
|
#include "Version.h"
|
||||||
@ -86,12 +88,30 @@ ModFolderPage::ModFolderPage(BaseInstance* inst, std::shared_ptr<ModFolderModel>
|
|||||||
ui->actionsToolbar->insertActionAfter(ui->actionAddItem, ui->actionUpdateItem);
|
ui->actionsToolbar->insertActionAfter(ui->actionAddItem, ui->actionUpdateItem);
|
||||||
connect(ui->actionUpdateItem, &QAction::triggered, this, &ModFolderPage::updateMods);
|
connect(ui->actionUpdateItem, &QAction::triggered, this, &ModFolderPage::updateMods);
|
||||||
|
|
||||||
|
ui->actionVisitItemPage->setToolTip(tr("Go to mod's home page"));
|
||||||
|
ui->actionsToolbar->insertActionAfter(ui->actionViewFolder, ui->actionVisitItemPage);
|
||||||
|
connect(ui->actionVisitItemPage, &QAction::triggered, this, &ModFolderPage::visitModPages);
|
||||||
|
|
||||||
auto check_allow_update = [this] {
|
auto check_allow_update = [this] {
|
||||||
return (!m_instance || !m_instance->isRunning()) && (ui->treeView->selectionModel()->hasSelection() || !m_model->empty());
|
return (!m_instance || !m_instance->isRunning()) && (ui->treeView->selectionModel()->hasSelection() || !m_model->empty());
|
||||||
};
|
};
|
||||||
|
|
||||||
connect(ui->treeView->selectionModel(), &QItemSelectionModel::selectionChanged, this,
|
connect(ui->treeView->selectionModel(), &QItemSelectionModel::selectionChanged, this, [this, check_allow_update] {
|
||||||
[this, check_allow_update] { ui->actionUpdateItem->setEnabled(check_allow_update()); });
|
ui->actionUpdateItem->setEnabled(check_allow_update());
|
||||||
|
|
||||||
|
auto selection = m_filterModel->mapSelectionToSource(ui->treeView->selectionModel()->selection()).indexes();
|
||||||
|
auto mods_list = m_model->selectedMods(selection);
|
||||||
|
auto selected = std::count_if(mods_list.cbegin(), mods_list.cend(),
|
||||||
|
[](Mod* v) { return v->metadata() != nullptr || v->homeurl().size() != 0; });
|
||||||
|
if (selected <= 1) {
|
||||||
|
ui->actionVisitItemPage->setText(tr("Visit mod's page"));
|
||||||
|
ui->actionVisitItemPage->setToolTip(tr("Go to mod's home page"));
|
||||||
|
} else {
|
||||||
|
ui->actionVisitItemPage->setText(tr("Visit mods' pages"));
|
||||||
|
ui->actionVisitItemPage->setToolTip(tr("Go to the pages of the selected mods"));
|
||||||
|
}
|
||||||
|
ui->actionVisitItemPage->setEnabled(selected != 0);
|
||||||
|
});
|
||||||
|
|
||||||
connect(mods.get(), &ModFolderModel::rowsInserted, this,
|
connect(mods.get(), &ModFolderModel::rowsInserted, this,
|
||||||
[this, check_allow_update] { ui->actionUpdateItem->setEnabled(check_allow_update()); });
|
[this, check_allow_update] { ui->actionUpdateItem->setEnabled(check_allow_update()); });
|
||||||
@ -133,7 +153,7 @@ bool ModFolderPage::onSelectionChanged(const QModelIndex& current, const QModelI
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ModFolderPage::removeItems(const QItemSelection &selection)
|
void ModFolderPage::removeItems(const QItemSelection& selection)
|
||||||
{
|
{
|
||||||
m_model->deleteMods(selection.indexes());
|
m_model->deleteMods(selection.indexes());
|
||||||
}
|
}
|
||||||
@ -207,8 +227,7 @@ void ModFolderPage::updateMods()
|
|||||||
message = tr("All selected mods are up-to-date! :)");
|
message = tr("All selected mods are up-to-date! :)");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
CustomMessageBox::selectable(this, tr("Update checker"), message)
|
CustomMessageBox::selectable(this, tr("Update checker"), message)->exec();
|
||||||
->exec();
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -275,3 +294,13 @@ bool NilModFolderPage::shouldDisplay() const
|
|||||||
{
|
{
|
||||||
return m_model->dir().exists();
|
return m_model->dir().exists();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ModFolderPage::visitModPages()
|
||||||
|
{
|
||||||
|
auto selection = m_filterModel->mapSelectionToSource(ui->treeView->selectionModel()->selection()).indexes();
|
||||||
|
for (auto mod : m_model->selectedMods(selection)) {
|
||||||
|
auto url = mod->metaurl();
|
||||||
|
if (!url.isEmpty())
|
||||||
|
DesktopServices::openUrl(url);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
* Copyright (c) 2022 Jamie Mansfield <jmansfield@cadixdev.org>
|
* Copyright (c) 2022 Jamie Mansfield <jmansfield@cadixdev.org>
|
||||||
* Copyright (C) 2022 Sefa Eyeoglu <contact@scrumplex.net>
|
* Copyright (C) 2022 Sefa Eyeoglu <contact@scrumplex.net>
|
||||||
* Copyright (C) 2022 TheKodeToad <TheKodeToad@proton.me>
|
* Copyright (C) 2022 TheKodeToad <TheKodeToad@proton.me>
|
||||||
|
* Copyright (c) 2023 Trial97 <alexandru.tripon97@gmail.com>
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
@ -60,10 +61,11 @@ class ModFolderPage : public ExternalResourcesPage {
|
|||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void runningStateChanged(bool running);
|
void runningStateChanged(bool running);
|
||||||
void removeItems(const QItemSelection &selection) override;
|
void removeItems(const QItemSelection& selection) override;
|
||||||
|
|
||||||
void installMods();
|
void installMods();
|
||||||
void updateMods();
|
void updateMods();
|
||||||
|
void visitModPages();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
std::shared_ptr<ModFolderModel> m_model;
|
std::shared_ptr<ModFolderModel> m_model;
|
||||||
|
@ -1,54 +1,70 @@
|
|||||||
// SPDX-License-Identifier: GPL-3.0-only
|
// SPDX-License-Identifier: GPL-3.0-only
|
||||||
/*
|
/*
|
||||||
* PolyMC - Minecraft Launcher
|
* Prism Launcher - Minecraft Launcher
|
||||||
* Copyright (c) 2022 flowln <flowlnlnln@gmail.com>
|
* Copyright (c) 2022 flowln <flowlnlnln@gmail.com>
|
||||||
*
|
* Copyright (c) 2023 Trial97 <alexandru.tripon97@gmail.com>
|
||||||
* 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
|
* This program is free software: you can redistribute it and/or modify
|
||||||
* the Free Software Foundation, version 3.
|
* 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
|
* This program is distributed in the hope that it will be useful,
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
* GNU General Public License for more details.
|
* 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/>.
|
* 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:
|
* This file incorporates work covered by the following copyright and
|
||||||
*
|
* permission notice:
|
||||||
* Copyright 2013-2021 MultiMC Contributors
|
*
|
||||||
*
|
* 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.
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* You may obtain a copy of the License at
|
* 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
|
*
|
||||||
*
|
* 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,
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
* See the License for the specific language governing permissions and
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
* limitations under the License.
|
* See the License for the specific language governing permissions and
|
||||||
*/
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <QLabel>
|
||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
|
#include <QToolTip>
|
||||||
|
|
||||||
#include "InfoFrame.h"
|
#include "InfoFrame.h"
|
||||||
#include "ui_InfoFrame.h"
|
#include "ui_InfoFrame.h"
|
||||||
|
|
||||||
#include "ui/dialogs/CustomMessageBox.h"
|
#include "ui/dialogs/CustomMessageBox.h"
|
||||||
|
|
||||||
InfoFrame::InfoFrame(QWidget *parent) :
|
void setupLinkToolTip(QLabel* label)
|
||||||
QFrame(parent),
|
{
|
||||||
ui(new Ui::InfoFrame)
|
QObject::connect(label, &QLabel::linkHovered, [label](const QString& link) {
|
||||||
|
if (auto url = QUrl(link); !url.isValid() || (url.scheme() != "http" && url.scheme() != "https"))
|
||||||
|
return;
|
||||||
|
label->setToolTip(link);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
InfoFrame::InfoFrame(QWidget* parent) : QFrame(parent), ui(new Ui::InfoFrame)
|
||||||
{
|
{
|
||||||
ui->setupUi(this);
|
ui->setupUi(this);
|
||||||
ui->descriptionLabel->setHidden(true);
|
ui->descriptionLabel->setHidden(true);
|
||||||
ui->nameLabel->setHidden(true);
|
ui->nameLabel->setHidden(true);
|
||||||
ui->licenseLabel->setHidden(true);
|
ui->licenseLabel->setHidden(true);
|
||||||
ui->issueTrackerLabel->setHidden(true);
|
ui->issueTrackerLabel->setHidden(true);
|
||||||
|
|
||||||
|
setupLinkToolTip(ui->iconLabel);
|
||||||
|
setupLinkToolTip(ui->descriptionLabel);
|
||||||
|
setupLinkToolTip(ui->nameLabel);
|
||||||
|
setupLinkToolTip(ui->licenseLabel);
|
||||||
|
setupLinkToolTip(ui->issueTrackerLabel);
|
||||||
updateHiddenState();
|
updateHiddenState();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -59,38 +75,36 @@ InfoFrame::~InfoFrame()
|
|||||||
|
|
||||||
void InfoFrame::updateWithMod(Mod const& m)
|
void InfoFrame::updateWithMod(Mod const& m)
|
||||||
{
|
{
|
||||||
if (m.type() == ResourceType::FOLDER)
|
if (m.type() == ResourceType::FOLDER) {
|
||||||
{
|
|
||||||
clear();
|
clear();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
QString text = "";
|
QString text = "";
|
||||||
QString name = "";
|
QString name = "";
|
||||||
|
QString link = m.metaurl();
|
||||||
if (m.name().isEmpty())
|
if (m.name().isEmpty())
|
||||||
name = m.internal_id();
|
name = m.internal_id();
|
||||||
else
|
else
|
||||||
name = m.name();
|
name = m.name();
|
||||||
|
|
||||||
if (m.homeurl().isEmpty())
|
if (link.isEmpty())
|
||||||
text = name;
|
text = name;
|
||||||
else
|
else {
|
||||||
text = "<a href=\"" + m.homeurl() + "\">" + name + "</a>";
|
text = "<a href=\"" + link + "\">" + name + "</a>";
|
||||||
|
}
|
||||||
if (!m.authors().isEmpty())
|
if (!m.authors().isEmpty())
|
||||||
text += " by " + m.authors().join(", ");
|
text += " by " + m.authors().join(", ");
|
||||||
|
|
||||||
setName(text);
|
setName(text);
|
||||||
|
|
||||||
if (m.description().isEmpty())
|
if (m.description().isEmpty()) {
|
||||||
{
|
|
||||||
setDescription(QString());
|
setDescription(QString());
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
setDescription(m.description());
|
setDescription(m.description());
|
||||||
}
|
}
|
||||||
|
|
||||||
setImage(m.icon({64,64}));
|
setImage(m.icon({ 64, 64 }));
|
||||||
|
|
||||||
auto licenses = m.licenses();
|
auto licenses = m.licenses();
|
||||||
QString licenseText = "";
|
QString licenseText = "";
|
||||||
@ -133,7 +147,8 @@ void InfoFrame::updateWithResource(const Resource& resource)
|
|||||||
setImage();
|
setImage();
|
||||||
}
|
}
|
||||||
|
|
||||||
QString InfoFrame::renderColorCodes(QString input) {
|
QString InfoFrame::renderColorCodes(QString input)
|
||||||
|
{
|
||||||
// We have to manually set the colors for use.
|
// We have to manually set the colors for use.
|
||||||
//
|
//
|
||||||
// A color is set using §x, with x = a hex number from 0 to f.
|
// A color is set using §x, with x = a hex number from 0 to f.
|
||||||
@ -144,16 +159,12 @@ QString InfoFrame::renderColorCodes(QString input) {
|
|||||||
// TODO: Wrap links inside <a> tags
|
// TODO: Wrap links inside <a> tags
|
||||||
|
|
||||||
// https://minecraft.fandom.com/wiki/Formatting_codes#Color_codes
|
// https://minecraft.fandom.com/wiki/Formatting_codes#Color_codes
|
||||||
const QMap<QChar, QString> color_codes_map = {
|
const QMap<QChar, QString> color_codes_map = { { '0', "#000000" }, { '1', "#0000AA" }, { '2', "#00AA00" }, { '3', "#00AAAA" },
|
||||||
{'0', "#000000"}, {'1', "#0000AA"}, {'2', "#00AA00"}, {'3', "#00AAAA"}, {'4', "#AA0000"},
|
{ '4', "#AA0000" }, { '5', "#AA00AA" }, { '6', "#FFAA00" }, { '7', "#AAAAAA" },
|
||||||
{'5', "#AA00AA"}, {'6', "#FFAA00"}, {'7', "#AAAAAA"}, {'8', "#555555"}, {'9', "#5555FF"},
|
{ '8', "#555555" }, { '9', "#5555FF" }, { 'a', "#55FF55" }, { 'b', "#55FFFF" },
|
||||||
{'a', "#55FF55"}, {'b', "#55FFFF"}, {'c', "#FF5555"}, {'d', "#FF55FF"}, {'e', "#FFFF55"},
|
{ 'c', "#FF5555" }, { 'd', "#FF55FF" }, { 'e', "#FFFF55" }, { 'f', "#FFFFFF" } };
|
||||||
{'f', "#FFFFFF"}
|
|
||||||
};
|
|
||||||
// https://minecraft.fandom.com/wiki/Formatting_codes#Formatting_codes
|
// https://minecraft.fandom.com/wiki/Formatting_codes#Formatting_codes
|
||||||
const QMap<QChar, QString> formatting_codes_map = {
|
const QMap<QChar, QString> formatting_codes_map = { { 'l', "b" }, { 'm', "s" }, { 'n', "u" }, { 'o', "i" } };
|
||||||
{'l', "b"}, {'m', "s"}, {'n', "u"}, {'o', "i"}
|
|
||||||
};
|
|
||||||
|
|
||||||
QString html("<html>");
|
QString html("<html>");
|
||||||
QList<QString> tags{};
|
QList<QString> tags{};
|
||||||
@ -198,14 +209,14 @@ void InfoFrame::updateWithResourcePack(ResourcePack& resource_pack)
|
|||||||
{
|
{
|
||||||
setName(renderColorCodes(resource_pack.name()));
|
setName(renderColorCodes(resource_pack.name()));
|
||||||
setDescription(renderColorCodes(resource_pack.description()));
|
setDescription(renderColorCodes(resource_pack.description()));
|
||||||
setImage(resource_pack.image({64, 64}));
|
setImage(resource_pack.image({ 64, 64 }));
|
||||||
}
|
}
|
||||||
|
|
||||||
void InfoFrame::updateWithTexturePack(TexturePack& texture_pack)
|
void InfoFrame::updateWithTexturePack(TexturePack& texture_pack)
|
||||||
{
|
{
|
||||||
setName(renderColorCodes(texture_pack.name()));
|
setName(renderColorCodes(texture_pack.name()));
|
||||||
setDescription(renderColorCodes(texture_pack.description()));
|
setDescription(renderColorCodes(texture_pack.description()));
|
||||||
setImage(texture_pack.image({64, 64}));
|
setImage(texture_pack.image({ 64, 64 }));
|
||||||
}
|
}
|
||||||
|
|
||||||
void InfoFrame::clear()
|
void InfoFrame::clear()
|
||||||
@ -229,12 +240,9 @@ void InfoFrame::updateHiddenState()
|
|||||||
|
|
||||||
void InfoFrame::setName(QString text)
|
void InfoFrame::setName(QString text)
|
||||||
{
|
{
|
||||||
if(text.isEmpty())
|
if (text.isEmpty()) {
|
||||||
{
|
|
||||||
ui->nameLabel->setHidden(true);
|
ui->nameLabel->setHidden(true);
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
ui->nameLabel->setText(text);
|
ui->nameLabel->setText(text);
|
||||||
ui->nameLabel->setHidden(false);
|
ui->nameLabel->setHidden(false);
|
||||||
}
|
}
|
||||||
@ -243,14 +251,11 @@ void InfoFrame::setName(QString text)
|
|||||||
|
|
||||||
void InfoFrame::setDescription(QString text)
|
void InfoFrame::setDescription(QString text)
|
||||||
{
|
{
|
||||||
if(text.isEmpty())
|
if (text.isEmpty()) {
|
||||||
{
|
|
||||||
ui->descriptionLabel->setHidden(true);
|
ui->descriptionLabel->setHidden(true);
|
||||||
updateHiddenState();
|
updateHiddenState();
|
||||||
return;
|
return;
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
ui->descriptionLabel->setHidden(false);
|
ui->descriptionLabel->setHidden(false);
|
||||||
updateHiddenState();
|
updateHiddenState();
|
||||||
}
|
}
|
||||||
@ -260,9 +265,8 @@ void InfoFrame::setDescription(QString text)
|
|||||||
QChar rem('\n');
|
QChar rem('\n');
|
||||||
QString finaltext;
|
QString finaltext;
|
||||||
finaltext.reserve(intermediatetext.size());
|
finaltext.reserve(intermediatetext.size());
|
||||||
foreach(const QChar& c, intermediatetext)
|
foreach (const QChar& c, intermediatetext) {
|
||||||
{
|
if (c == rem && prev) {
|
||||||
if(c == rem && prev){
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
prev = c == rem;
|
prev = c == rem;
|
||||||
@ -270,17 +274,14 @@ void InfoFrame::setDescription(QString text)
|
|||||||
}
|
}
|
||||||
QString labeltext;
|
QString labeltext;
|
||||||
labeltext.reserve(300);
|
labeltext.reserve(300);
|
||||||
if(finaltext.length() > 290)
|
if (finaltext.length() > 290) {
|
||||||
{
|
|
||||||
ui->descriptionLabel->setOpenExternalLinks(false);
|
ui->descriptionLabel->setOpenExternalLinks(false);
|
||||||
ui->descriptionLabel->setTextFormat(Qt::TextFormat::RichText);
|
ui->descriptionLabel->setTextFormat(Qt::TextFormat::RichText);
|
||||||
m_description = text;
|
m_description = text;
|
||||||
// This allows injecting HTML here.
|
// This allows injecting HTML here.
|
||||||
labeltext.append("<html><body>" + finaltext.left(287) + "<a href=\"#mod_desc\">...</a></body></html>");
|
labeltext.append("<html><body>" + finaltext.left(287) + "<a href=\"#mod_desc\">...</a></body></html>");
|
||||||
QObject::connect(ui->descriptionLabel, &QLabel::linkActivated, this, &InfoFrame::descriptionEllipsisHandler);
|
QObject::connect(ui->descriptionLabel, &QLabel::linkActivated, this, &InfoFrame::descriptionEllipsisHandler);
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
ui->descriptionLabel->setTextFormat(Qt::TextFormat::AutoText);
|
ui->descriptionLabel->setTextFormat(Qt::TextFormat::AutoText);
|
||||||
labeltext.append(finaltext);
|
labeltext.append(finaltext);
|
||||||
}
|
}
|
||||||
@ -289,14 +290,11 @@ void InfoFrame::setDescription(QString text)
|
|||||||
|
|
||||||
void InfoFrame::setLicense(QString text)
|
void InfoFrame::setLicense(QString text)
|
||||||
{
|
{
|
||||||
if(text.isEmpty())
|
if (text.isEmpty()) {
|
||||||
{
|
|
||||||
ui->licenseLabel->setHidden(true);
|
ui->licenseLabel->setHidden(true);
|
||||||
updateHiddenState();
|
updateHiddenState();
|
||||||
return;
|
return;
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
ui->licenseLabel->setHidden(false);
|
ui->licenseLabel->setHidden(false);
|
||||||
updateHiddenState();
|
updateHiddenState();
|
||||||
}
|
}
|
||||||
@ -306,9 +304,8 @@ void InfoFrame::setLicense(QString text)
|
|||||||
QChar rem('\n');
|
QChar rem('\n');
|
||||||
QString finaltext;
|
QString finaltext;
|
||||||
finaltext.reserve(intermediatetext.size());
|
finaltext.reserve(intermediatetext.size());
|
||||||
foreach(const QChar& c, intermediatetext)
|
foreach (const QChar& c, intermediatetext) {
|
||||||
{
|
if (c == rem && prev) {
|
||||||
if(c == rem && prev){
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
prev = c == rem;
|
prev = c == rem;
|
||||||
@ -316,17 +313,14 @@ void InfoFrame::setLicense(QString text)
|
|||||||
}
|
}
|
||||||
QString labeltext;
|
QString labeltext;
|
||||||
labeltext.reserve(300);
|
labeltext.reserve(300);
|
||||||
if(finaltext.length() > 290)
|
if (finaltext.length() > 290) {
|
||||||
{
|
|
||||||
ui->licenseLabel->setOpenExternalLinks(false);
|
ui->licenseLabel->setOpenExternalLinks(false);
|
||||||
ui->licenseLabel->setTextFormat(Qt::TextFormat::RichText);
|
ui->licenseLabel->setTextFormat(Qt::TextFormat::RichText);
|
||||||
m_description = text;
|
m_description = text;
|
||||||
// This allows injecting HTML here.
|
// This allows injecting HTML here.
|
||||||
labeltext.append("<html><body>" + finaltext.left(287) + "<a href=\"#mod_desc\">...</a></body></html>");
|
labeltext.append("<html><body>" + finaltext.left(287) + "<a href=\"#mod_desc\">...</a></body></html>");
|
||||||
QObject::connect(ui->licenseLabel, &QLabel::linkActivated, this, &InfoFrame::licenseEllipsisHandler);
|
QObject::connect(ui->licenseLabel, &QLabel::linkActivated, this, &InfoFrame::licenseEllipsisHandler);
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
ui->licenseLabel->setTextFormat(Qt::TextFormat::AutoText);
|
ui->licenseLabel->setTextFormat(Qt::TextFormat::AutoText);
|
||||||
labeltext.append(finaltext);
|
labeltext.append(finaltext);
|
||||||
}
|
}
|
||||||
@ -335,12 +329,9 @@ void InfoFrame::setLicense(QString text)
|
|||||||
|
|
||||||
void InfoFrame::setIssueTracker(QString text)
|
void InfoFrame::setIssueTracker(QString text)
|
||||||
{
|
{
|
||||||
if(text.isEmpty())
|
if (text.isEmpty()) {
|
||||||
{
|
|
||||||
ui->issueTrackerLabel->setHidden(true);
|
ui->issueTrackerLabel->setHidden(true);
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
ui->issueTrackerLabel->setText(text);
|
ui->issueTrackerLabel->setText(text);
|
||||||
ui->issueTrackerLabel->setHidden(false);
|
ui->issueTrackerLabel->setHidden(false);
|
||||||
}
|
}
|
||||||
@ -359,28 +350,22 @@ void InfoFrame::setImage(QPixmap img)
|
|||||||
|
|
||||||
void InfoFrame::descriptionEllipsisHandler(QString link)
|
void InfoFrame::descriptionEllipsisHandler(QString link)
|
||||||
{
|
{
|
||||||
if(!m_current_box)
|
if (!m_current_box) {
|
||||||
{
|
|
||||||
m_current_box = CustomMessageBox::selectable(this, "", m_description);
|
m_current_box = CustomMessageBox::selectable(this, "", m_description);
|
||||||
connect(m_current_box, &QMessageBox::finished, this, &InfoFrame::boxClosed);
|
connect(m_current_box, &QMessageBox::finished, this, &InfoFrame::boxClosed);
|
||||||
m_current_box->show();
|
m_current_box->show();
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
m_current_box->setText(m_description);
|
m_current_box->setText(m_description);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void InfoFrame::licenseEllipsisHandler(QString link)
|
void InfoFrame::licenseEllipsisHandler(QString link)
|
||||||
{
|
{
|
||||||
if(!m_current_box)
|
if (!m_current_box) {
|
||||||
{
|
|
||||||
m_current_box = CustomMessageBox::selectable(this, "", m_license);
|
m_current_box = CustomMessageBox::selectable(this, "", m_license);
|
||||||
connect(m_current_box, &QMessageBox::finished, this, &InfoFrame::boxClosed);
|
connect(m_current_box, &QMessageBox::finished, this, &InfoFrame::boxClosed);
|
||||||
m_current_box->show();
|
m_current_box->show();
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
m_current_box->setText(m_license);
|
m_current_box->setText(m_license);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,24 @@
|
|||||||
/* Copyright 2013-2021 MultiMC Contributors
|
// SPDX-License-Identifier: GPL-3.0-only
|
||||||
|
/*
|
||||||
|
* Prism Launcher - Minecraft Launcher
|
||||||
|
* Copyright (c) 2023 Trial97 <alexandru.tripon97@gmail.com>
|
||||||
|
*
|
||||||
|
* 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");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
@ -21,8 +41,7 @@
|
|||||||
#include "minecraft/mod/ResourcePack.h"
|
#include "minecraft/mod/ResourcePack.h"
|
||||||
#include "minecraft/mod/TexturePack.h"
|
#include "minecraft/mod/TexturePack.h"
|
||||||
|
|
||||||
namespace Ui
|
namespace Ui {
|
||||||
{
|
|
||||||
class InfoFrame;
|
class InfoFrame;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user