diff options
author | TheKodeToad <freezingma1l@outlook.com> | 2023-03-02 10:10:46 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-03-02 10:10:46 +0000 |
commit | 5c913149c84c121523a1ae403848d3e0926de244 (patch) | |
tree | 3789176d454bd988b7e572e5f411151efc2cb7e2 /launcher/ui/pages/modplatform/ResourcePackPage.cpp | |
parent | cbe6eff2fa917401b913a96c551429caad852b3b (diff) | |
parent | 9265c319a96b3dd5681767c196a397fbbae9164a (diff) | |
download | PrismLauncher-5c913149c84c121523a1ae403848d3e0926de244.tar.gz PrismLauncher-5c913149c84c121523a1ae403848d3e0926de244.tar.bz2 PrismLauncher-5c913149c84c121523a1ae403848d3e0926de244.zip |
Merge branch 'PrismLauncher:develop' into modrinth-token
Diffstat (limited to 'launcher/ui/pages/modplatform/ResourcePackPage.cpp')
-rw-r--r-- | launcher/ui/pages/modplatform/ResourcePackPage.cpp | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/launcher/ui/pages/modplatform/ResourcePackPage.cpp b/launcher/ui/pages/modplatform/ResourcePackPage.cpp new file mode 100644 index 00000000..52fb4802 --- /dev/null +++ b/launcher/ui/pages/modplatform/ResourcePackPage.cpp @@ -0,0 +1,46 @@ +// SPDX-FileCopyrightText: 2023 flowln <flowlnlnln@gmail.com> +// +// SPDX-License-Identifier: GPL-3.0-only + +#include "ResourcePackPage.h" +#include "ui_ResourcePage.h" + +#include "ResourcePackModel.h" + +#include "ui/dialogs/ResourceDownloadDialog.h" + +#include <QRegularExpression> + +namespace ResourceDownload { + +ResourcePackResourcePage::ResourcePackResourcePage(ResourceDownloadDialog* dialog, BaseInstance& instance) + : ResourcePage(dialog, instance) +{ + connect(m_ui->searchButton, &QPushButton::clicked, this, &ResourcePackResourcePage::triggerSearch); + connect(m_ui->packView, &QListView::doubleClicked, this, &ResourcePackResourcePage::onResourceSelected); +} + +/******** Callbacks to events in the UI (set up in the derived classes) ********/ + +void ResourcePackResourcePage::triggerSearch() +{ + m_ui->packView->clearSelection(); + m_ui->packDescription->clear(); + m_ui->versionSelectionBox->clear(); + + updateSelectionButton(); + + static_cast<ResourcePackResourceModel*>(m_model)->searchWithTerm(getSearchTerm(), m_ui->sortByBox->currentData().toUInt()); + m_fetch_progress.watch(m_model->activeSearchJob().get()); +} + +QMap<QString, QString> ResourcePackResourcePage::urlHandlers() const +{ + QMap<QString, QString> map; + map.insert(QRegularExpression::anchoredPattern("(?:www\\.)?modrinth\\.com\\/resourcepack\\/([^\\/]+)\\/?"), "modrinth"); + map.insert(QRegularExpression::anchoredPattern("(?:www\\.)?curseforge\\.com\\/minecraft\\/texture-packs\\/([^\\/]+)\\/?"), "curseforge"); + map.insert(QRegularExpression::anchoredPattern("minecraft\\.curseforge\\.com\\/projects\\/([^\\/]+)\\/?"), "curseforge"); + return map; +} + +} // namespace ResourceDownload |