NOISSUE recognize curseforge URLs dropped on top of MultiMC
This commit is contained in:
parent
739a86f171
commit
725ec35635
@ -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;
|
||||||
|
@ -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)
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
@ -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();
|
||||||
|
@ -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();
|
||||||
|
Loading…
Reference in New Issue
Block a user