NOISSUE recognize curseforge URLs dropped on top of MultiMC

This commit is contained in:
Petr Mrázek 2019-07-09 22:04:52 +02:00
parent 739a86f171
commit 725ec35635
5 changed files with 30 additions and 7 deletions

View File

@ -21,6 +21,11 @@ void Flame::UrlResolvingTask::resolveUrl()
{ {
setStatus(tr("Resolving URL...")); setStatus(tr("Resolving URL..."));
setProgress(0, 1); setProgress(0, 1);
QUrl actualUrl(m_url);
if(actualUrl.host() != "www.curseforge.com") {
emitFailed(tr("Not a Twitch URL."));
return;
}
m_dljob.reset(new NetJob("URL resolver")); m_dljob.reset(new NetJob("URL resolver"));
bool weAreDigging = false; bool weAreDigging = false;

View File

@ -39,6 +39,8 @@
#include <pages/modplatform/ImportPage.h> #include <pages/modplatform/ImportPage.h>
#include <pages/modplatform/TechnicPage.h> #include <pages/modplatform/TechnicPage.h>
NewInstanceDialog::NewInstanceDialog(const QString & initialGroup, const QString & url, QWidget *parent) NewInstanceDialog::NewInstanceDialog(const QString & initialGroup, const QString & url, QWidget *parent)
: QDialog(parent), ui(new Ui::NewInstanceDialog) : QDialog(parent), ui(new Ui::NewInstanceDialog)
{ {
@ -94,8 +96,15 @@ NewInstanceDialog::NewInstanceDialog(const QString & initialGroup, const QString
if(!url.isEmpty()) if(!url.isEmpty())
{ {
m_container->selectPage("import"); QUrl actualUrl(url);
importPage->setUrl(url); if(actualUrl.host() == "www.curseforge.com") {
m_container->selectPage("twitch");
twitchPage->setUrl(url);
}
else {
m_container->selectPage("import");
importPage->setUrl(url);
}
} }
updateDialogState(); updateDialogState();
@ -119,13 +128,13 @@ void NewInstanceDialog::accept()
QList<BasePage *> NewInstanceDialog::getPages() QList<BasePage *> NewInstanceDialog::getPages()
{ {
importPage = new ImportPage(this); importPage = new ImportPage(this);
twitchPage = new TwitchPage(this);
return return
{ {
new VanillaPage(this), new VanillaPage(this),
new FTBPage(this),
importPage, importPage,
new TwitchPage(this), twitchPage,
new TechnicPage(this) new FTBPage(this)
}; };
} }

View File

@ -29,6 +29,7 @@ class NewInstanceDialog;
class PageContainer; class PageContainer;
class QDialogButtonBox; class QDialogButtonBox;
class ImportPage; class ImportPage;
class TwitchPage;
class NewInstanceDialog : public QDialog, public BasePageProvider class NewInstanceDialog : public QDialog, public BasePageProvider
{ {
@ -67,6 +68,7 @@ private:
QString InstIconKey; QString InstIconKey;
ImportPage *importPage = nullptr; ImportPage *importPage = nullptr;
TwitchPage *twitchPage = nullptr;
std::unique_ptr<InstanceTask> creationTask; std::unique_ptr<InstanceTask> creationTask;
bool importIcon = false; bool importIcon = false;

View File

@ -30,7 +30,6 @@ void TwitchPage::openedImpl()
void TwitchPage::triggerCheck(bool) void TwitchPage::triggerCheck(bool)
{ {
if(m_modIdResolver) { if(m_modIdResolver) {
qDebug() << "Click!";
return; return;
} }
auto task = new Flame::UrlResolvingTask(ui->lineEdit->text()); auto task = new Flame::UrlResolvingTask(ui->lineEdit->text());
@ -39,6 +38,12 @@ void TwitchPage::triggerCheck(bool)
task->start(); task->start();
} }
void TwitchPage::setUrl(const QString& url)
{
ui->lineEdit->setText(url);
triggerCheck(true);
}
void TwitchPage::checkDone() void TwitchPage::checkDone()
{ {
auto result = m_modIdResolver->getResults(); auto result = m_modIdResolver->getResults();

View File

@ -38,7 +38,7 @@ public:
virtual ~TwitchPage(); virtual ~TwitchPage();
virtual QString displayName() const override virtual QString displayName() const override
{ {
return tr("Twitch"); return tr("Twitch URL");
} }
virtual QIcon icon() const override virtual QIcon icon() const override
{ {
@ -56,6 +56,8 @@ public:
void openedImpl() override; void openedImpl() override;
void setUrl(const QString & url);
private slots: private slots:
void triggerCheck(bool checked); void triggerCheck(bool checked);
void checkDone(); void checkDone();