Made custom url function

Signed-off-by: Trial97 <alexandru.tripon97@gmail.com>
This commit is contained in:
Trial97 2023-06-25 10:41:29 +03:00
parent 54d7477679
commit ce4a86fbcd
No known key found for this signature in database
GPG Key ID: 55EF5DA53DB36318
6 changed files with 24 additions and 32 deletions

View File

@ -166,6 +166,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;

View File

@ -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; };

View File

@ -77,4 +77,10 @@ auto ProviderCapabilities::hash(ResourceProvider p, QIODevice* device, QString t
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

View File

@ -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

View File

@ -298,17 +298,9 @@ bool NilModFolderPage::shouldDisplay() const
void ModFolderPage::visitModPages() void ModFolderPage::visitModPages()
{ {
auto selection = m_filterModel->mapSelectionToSource(ui->treeView->selectionModel()->selection()).indexes(); auto selection = m_filterModel->mapSelectionToSource(ui->treeView->selectionModel()->selection()).indexes();
for (auto mod : m_model->selectedMods(selection)) for (auto mod : m_model->selectedMods(selection)) {
if (auto meta = mod->metadata(); meta != nullptr) { auto url = mod->metaurl();
auto slug = meta->slug.remove(".pw.toml"); if (!url.isEmpty())
switch (meta->provider) { DesktopServices::openUrl(url);
case ModPlatform::ResourceProvider::MODRINTH:
DesktopServices::openUrl(QString("https://modrinth.com/mod/%1").arg(slug));
break;
case ModPlatform::ResourceProvider::FLAME:
DesktopServices::openUrl(QString("https://www.curseforge.com/minecraft/mc-mods/%1").arg(slug));
break;
} }
} else if (mod->homeurl().size() != 0)
DesktopServices::openUrl(mod->homeurl());
} }

View File

@ -41,9 +41,7 @@
#include "ui/dialogs/CustomMessageBox.h" #include "ui/dialogs/CustomMessageBox.h"
InfoFrame::InfoFrame(QWidget *parent) : InfoFrame::InfoFrame(QWidget* parent) : QFrame(parent), ui(new Ui::InfoFrame)
QFrame(parent),
ui(new Ui::InfoFrame)
{ {
ui->setupUi(this); ui->setupUi(this);
ui->descriptionLabel->setHidden(true); ui->descriptionLabel->setHidden(true);
@ -67,31 +65,18 @@ void InfoFrame::updateWithMod(Mod const& m)
QString text = ""; QString text = "";
QString name = ""; QString name = "";
QString link = ""; QString link = m.metaurl();
QString toolTip = ""; QString toolTip = "";
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 (auto meta = m.metadata(); meta != nullptr) {
auto slug = meta->slug.remove(".pw.toml");
switch (meta->provider) {
case ModPlatform::ResourceProvider::MODRINTH:
link = QString("https://modrinth.com/mod/%1").arg(slug);
break;
case ModPlatform::ResourceProvider::FLAME:
link = QString("https://www.curseforge.com/minecraft/mc-mods/%1").arg(slug);
break;
}
} else if (!m.homeurl().isEmpty())
link = m.homeurl();
if (link.isEmpty()) if (link.isEmpty())
text = name; text = name;
else { else {
text = "<a href=\"" + link + "\">" + name + "</a>"; text = "<a href=\"" + link + "\">" + name + "</a>";
toolTip = tr("Go to mod's home page"); toolTip = link;
} }
if (!m.authors().isEmpty()) if (!m.authors().isEmpty())
text += " by " + m.authors().join(", "); text += " by " + m.authors().join(", ");