Merge remote-tracking branch 'origin/feature_new_login_dialog2' into develop
This commit is contained in:
commit
e955b1c6f9
@ -303,6 +303,8 @@ gui/dialogs/CustomMessageBox.h
|
|||||||
gui/dialogs/CustomMessageBox.cpp
|
gui/dialogs/CustomMessageBox.cpp
|
||||||
gui/dialogs/EditAccountDialog.h
|
gui/dialogs/EditAccountDialog.h
|
||||||
gui/dialogs/EditAccountDialog.cpp
|
gui/dialogs/EditAccountDialog.cpp
|
||||||
|
gui/dialogs/LoginDialog.h
|
||||||
|
gui/dialogs/LoginDialog.cpp
|
||||||
gui/dialogs/AccountListDialog.h
|
gui/dialogs/AccountListDialog.h
|
||||||
gui/dialogs/AccountListDialog.cpp
|
gui/dialogs/AccountListDialog.cpp
|
||||||
gui/dialogs/AccountSelectDialog.h
|
gui/dialogs/AccountSelectDialog.h
|
||||||
@ -565,6 +567,7 @@ gui/dialogs/EditNotesDialog.ui
|
|||||||
gui/dialogs/AccountListDialog.ui
|
gui/dialogs/AccountListDialog.ui
|
||||||
gui/dialogs/AccountSelectDialog.ui
|
gui/dialogs/AccountSelectDialog.ui
|
||||||
gui/dialogs/EditAccountDialog.ui
|
gui/dialogs/EditAccountDialog.ui
|
||||||
|
gui/dialogs/LoginDialog.ui
|
||||||
gui/dialogs/UpdateDialog.ui
|
gui/dialogs/UpdateDialog.ui
|
||||||
gui/dialogs/ScreenshotDialog.ui
|
gui/dialogs/ScreenshotDialog.ui
|
||||||
gui/dialogs/NotificationDialog.ui
|
gui/dialogs/NotificationDialog.ui
|
||||||
|
@ -26,6 +26,7 @@
|
|||||||
#include <gui/dialogs/EditAccountDialog.h>
|
#include <gui/dialogs/EditAccountDialog.h>
|
||||||
#include <gui/dialogs/ProgressDialog.h>
|
#include <gui/dialogs/ProgressDialog.h>
|
||||||
#include <gui/dialogs/AccountSelectDialog.h>
|
#include <gui/dialogs/AccountSelectDialog.h>
|
||||||
|
#include <gui/dialogs/LoginDialog.h>
|
||||||
#include "CustomMessageBox.h"
|
#include "CustomMessageBox.h"
|
||||||
#include <logic/tasks/Task.h>
|
#include <logic/tasks/Task.h>
|
||||||
#include <logic/auth/YggdrasilTask.h>
|
#include <logic/auth/YggdrasilTask.h>
|
||||||
@ -48,7 +49,8 @@ AccountListDialog::AccountListDialog(QWidget *parent)
|
|||||||
QItemSelectionModel *selectionModel = ui->listView->selectionModel();
|
QItemSelectionModel *selectionModel = ui->listView->selectionModel();
|
||||||
|
|
||||||
connect(selectionModel, &QItemSelectionModel::selectionChanged,
|
connect(selectionModel, &QItemSelectionModel::selectionChanged,
|
||||||
[this] (const QItemSelection& sel, const QItemSelection& dsel) { updateButtonStates(); });
|
[this](const QItemSelection &sel, const QItemSelection &dsel)
|
||||||
|
{ updateButtonStates(); });
|
||||||
|
|
||||||
connect(m_accounts.get(), SIGNAL(listChanged()), SLOT(listChanged()));
|
connect(m_accounts.get(), SIGNAL(listChanged()), SLOT(listChanged()));
|
||||||
connect(m_accounts.get(), SIGNAL(activeAccountChanged()), SLOT(listChanged()));
|
connect(m_accounts.get(), SIGNAL(activeAccountChanged()), SLOT(listChanged()));
|
||||||
@ -68,7 +70,8 @@ void AccountListDialog::listChanged()
|
|||||||
|
|
||||||
void AccountListDialog::on_addAccountBtn_clicked()
|
void AccountListDialog::on_addAccountBtn_clicked()
|
||||||
{
|
{
|
||||||
addAccount(tr("Please enter your Mojang or Minecraft account username and password to add your account."));
|
addAccount(tr("Please enter your Mojang or Minecraft account username and password to add "
|
||||||
|
"your account."));
|
||||||
}
|
}
|
||||||
|
|
||||||
void AccountListDialog::on_rmAccountBtn_clicked()
|
void AccountListDialog::on_rmAccountBtn_clicked()
|
||||||
@ -87,7 +90,8 @@ void AccountListDialog::on_setDefaultBtn_clicked()
|
|||||||
if (selection.size() > 0)
|
if (selection.size() > 0)
|
||||||
{
|
{
|
||||||
QModelIndex selected = selection.first();
|
QModelIndex selected = selection.first();
|
||||||
MojangAccountPtr account = selected.data(MojangAccountList::PointerRole).value<MojangAccountPtr>();
|
MojangAccountPtr account =
|
||||||
|
selected.data(MojangAccountList::PointerRole).value<MojangAccountPtr>();
|
||||||
m_accounts->setActiveAccount(account->username());
|
m_accounts->setActiveAccount(account->username());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -115,20 +119,10 @@ void AccountListDialog::updateButtonStates()
|
|||||||
|
|
||||||
void AccountListDialog::addAccount(const QString &errMsg)
|
void AccountListDialog::addAccount(const QString &errMsg)
|
||||||
{
|
{
|
||||||
// TODO: We can use the login dialog for this for now, but we'll have to make something better for it eventually.
|
// TODO: The login dialog isn't quite done yet
|
||||||
EditAccountDialog loginDialog(errMsg, this, EditAccountDialog::UsernameField | EditAccountDialog::PasswordField);
|
MojangAccountPtr account = LoginDialog::newAccount(this, errMsg);
|
||||||
loginDialog.exec();
|
|
||||||
|
|
||||||
if (loginDialog.result() == QDialog::Accepted)
|
if (account != nullptr)
|
||||||
{
|
|
||||||
QString username(loginDialog.username());
|
|
||||||
QString password(loginDialog.password());
|
|
||||||
|
|
||||||
MojangAccountPtr account = MojangAccount::createFromUsername(username);
|
|
||||||
ProgressDialog progDialog(this);
|
|
||||||
auto task = account->login(nullptr, password);
|
|
||||||
progDialog.exec(task.get());
|
|
||||||
if(task->successful())
|
|
||||||
{
|
{
|
||||||
m_accounts->addAccount(account);
|
m_accounts->addAccount(account);
|
||||||
if (m_accounts->count() == 1)
|
if (m_accounts->count() == 1)
|
||||||
@ -141,20 +135,11 @@ void AccountListDialog::addAccount(const QString& errMsg)
|
|||||||
{
|
{
|
||||||
auto meta = MMC->metacache()->resolveEntry("skins", profile.name + ".png");
|
auto meta = MMC->metacache()->resolveEntry("skins", profile.name + ".png");
|
||||||
auto action = CacheDownload::make(
|
auto action = CacheDownload::make(
|
||||||
QUrl("http://" + URLConstants::SKINS_BASE + profile.name + ".png"),
|
QUrl("http://" + URLConstants::SKINS_BASE + profile.name + ".png"), meta);
|
||||||
meta);
|
|
||||||
job->addNetAction(action);
|
job->addNetAction(action);
|
||||||
meta->stale = true;
|
meta->stale = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
job->start();
|
job->start();
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
auto reason = task->failReason();
|
|
||||||
auto dlg = CustomMessageBox::selectable(this, tr("Login error."), reason, QMessageBox::Critical);
|
|
||||||
dlg->exec();
|
|
||||||
delete dlg;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
110
gui/dialogs/LoginDialog.cpp
Normal file
110
gui/dialogs/LoginDialog.cpp
Normal file
@ -0,0 +1,110 @@
|
|||||||
|
/* Copyright 2014 MultiMC Contributors
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* 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
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "LoginDialog.h"
|
||||||
|
#include "ui_LoginDialog.h"
|
||||||
|
|
||||||
|
#include "logic/auth/YggdrasilTask.h"
|
||||||
|
|
||||||
|
#include <QtWidgets/QPushButton>
|
||||||
|
|
||||||
|
LoginDialog::LoginDialog(QWidget *parent) : QDialog(parent), ui(new Ui::LoginDialog)
|
||||||
|
{
|
||||||
|
ui->setupUi(this);
|
||||||
|
ui->progressBar->setVisible(false);
|
||||||
|
ui->buttonBox->button(QDialogButtonBox::Ok)->setEnabled(false);
|
||||||
|
|
||||||
|
connect(ui->buttonBox, &QDialogButtonBox::accepted, this, &QDialog::accept);
|
||||||
|
connect(ui->buttonBox, &QDialogButtonBox::rejected, this, &QDialog::reject);
|
||||||
|
}
|
||||||
|
|
||||||
|
LoginDialog::~LoginDialog()
|
||||||
|
{
|
||||||
|
delete ui;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Stage 1: User interaction
|
||||||
|
void LoginDialog::accept()
|
||||||
|
{
|
||||||
|
setUserInputsEnabled(false);
|
||||||
|
ui->progressBar->setVisible(true);
|
||||||
|
|
||||||
|
// Setup the login task and start it
|
||||||
|
m_account = MojangAccount::createFromUsername(ui->userTextBox->text());
|
||||||
|
m_loginTask = m_account->login(nullptr, ui->passTextBox->text());
|
||||||
|
connect(m_loginTask.get(), &ProgressProvider::failed, this, &LoginDialog::onTaskFailed);
|
||||||
|
connect(m_loginTask.get(), &ProgressProvider::succeeded, this,
|
||||||
|
&LoginDialog::onTaskSucceeded);
|
||||||
|
connect(m_loginTask.get(), &ProgressProvider::status, this, &LoginDialog::onTaskStatus);
|
||||||
|
connect(m_loginTask.get(), &ProgressProvider::progress, this, &LoginDialog::onTaskProgress);
|
||||||
|
m_loginTask->start();
|
||||||
|
}
|
||||||
|
|
||||||
|
void LoginDialog::setUserInputsEnabled(bool enable)
|
||||||
|
{
|
||||||
|
ui->userTextBox->setEnabled(enable);
|
||||||
|
ui->passTextBox->setEnabled(enable);
|
||||||
|
ui->buttonBox->setEnabled(enable);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Enable the OK button only when both textboxes contain something.
|
||||||
|
void LoginDialog::on_userTextBox_textEdited(const QString &newText)
|
||||||
|
{
|
||||||
|
ui->buttonBox->button(QDialogButtonBox::Ok)
|
||||||
|
->setEnabled(!newText.isEmpty() && !ui->passTextBox->text().isEmpty());
|
||||||
|
}
|
||||||
|
void LoginDialog::on_passTextBox_textEdited(const QString &newText)
|
||||||
|
{
|
||||||
|
ui->buttonBox->button(QDialogButtonBox::Ok)
|
||||||
|
->setEnabled(!newText.isEmpty() && !ui->userTextBox->text().isEmpty());
|
||||||
|
}
|
||||||
|
|
||||||
|
void LoginDialog::onTaskFailed(const QString &reason)
|
||||||
|
{
|
||||||
|
// Set message
|
||||||
|
ui->label->setText("<span style='color:red'>" + reason + "</span>");
|
||||||
|
|
||||||
|
// Re-enable user-interaction
|
||||||
|
setUserInputsEnabled(true);
|
||||||
|
ui->progressBar->setVisible(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
void LoginDialog::onTaskSucceeded()
|
||||||
|
{
|
||||||
|
QDialog::accept();
|
||||||
|
}
|
||||||
|
|
||||||
|
void LoginDialog::onTaskStatus(const QString &status)
|
||||||
|
{
|
||||||
|
ui->label->setText(status);
|
||||||
|
}
|
||||||
|
|
||||||
|
void LoginDialog::onTaskProgress(qint64 current, qint64 total)
|
||||||
|
{
|
||||||
|
ui->progressBar->setMaximum(total);
|
||||||
|
ui->progressBar->setValue(current);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Public interface
|
||||||
|
MojangAccountPtr LoginDialog::newAccount(QWidget *parent, QString msg)
|
||||||
|
{
|
||||||
|
LoginDialog dlg(parent);
|
||||||
|
dlg.ui->label->setText(msg);
|
||||||
|
if (dlg.exec() == QDialog::Accepted)
|
||||||
|
{
|
||||||
|
return dlg.m_account;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
58
gui/dialogs/LoginDialog.h
Normal file
58
gui/dialogs/LoginDialog.h
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
/* Copyright 2014 MultiMC Contributors
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* 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
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <QtWidgets/QDialog>
|
||||||
|
#include <QtCore/QEventLoop>
|
||||||
|
|
||||||
|
#include "logic/auth/MojangAccount.h"
|
||||||
|
|
||||||
|
namespace Ui
|
||||||
|
{
|
||||||
|
class LoginDialog;
|
||||||
|
}
|
||||||
|
|
||||||
|
class LoginDialog : public QDialog
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
~LoginDialog();
|
||||||
|
|
||||||
|
static MojangAccountPtr newAccount(QWidget *parent, QString message);
|
||||||
|
|
||||||
|
private:
|
||||||
|
explicit LoginDialog(QWidget *parent = 0);
|
||||||
|
|
||||||
|
void setUserInputsEnabled(bool enable);
|
||||||
|
|
||||||
|
protected
|
||||||
|
slots:
|
||||||
|
void accept();
|
||||||
|
|
||||||
|
void onTaskFailed(const QString &reason);
|
||||||
|
void onTaskSucceeded();
|
||||||
|
void onTaskStatus(const QString &status);
|
||||||
|
void onTaskProgress(qint64 current, qint64 total);
|
||||||
|
|
||||||
|
void on_userTextBox_textEdited(const QString &newText);
|
||||||
|
void on_passTextBox_textEdited(const QString &newText);
|
||||||
|
|
||||||
|
private:
|
||||||
|
Ui::LoginDialog *ui;
|
||||||
|
MojangAccountPtr m_account;
|
||||||
|
std::shared_ptr<Task> m_loginTask;
|
||||||
|
};
|
77
gui/dialogs/LoginDialog.ui
Normal file
77
gui/dialogs/LoginDialog.ui
Normal file
@ -0,0 +1,77 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<ui version="4.0">
|
||||||
|
<class>LoginDialog</class>
|
||||||
|
<widget class="QDialog" name="LoginDialog">
|
||||||
|
<property name="geometry">
|
||||||
|
<rect>
|
||||||
|
<x>0</x>
|
||||||
|
<y>0</y>
|
||||||
|
<width>400</width>
|
||||||
|
<height>162</height>
|
||||||
|
</rect>
|
||||||
|
</property>
|
||||||
|
<property name="sizePolicy">
|
||||||
|
<sizepolicy hsizetype="Fixed" vsizetype="Fixed">
|
||||||
|
<horstretch>0</horstretch>
|
||||||
|
<verstretch>0</verstretch>
|
||||||
|
</sizepolicy>
|
||||||
|
</property>
|
||||||
|
<property name="windowTitle">
|
||||||
|
<string>Add Account</string>
|
||||||
|
</property>
|
||||||
|
<layout class="QVBoxLayout" name="verticalLayout">
|
||||||
|
<item>
|
||||||
|
<widget class="QLabel" name="label">
|
||||||
|
<property name="text">
|
||||||
|
<string>Message label placeholder.</string>
|
||||||
|
</property>
|
||||||
|
<property name="textFormat">
|
||||||
|
<enum>Qt::RichText</enum>
|
||||||
|
</property>
|
||||||
|
<property name="textInteractionFlags">
|
||||||
|
<set>Qt::LinksAccessibleByKeyboard|Qt::LinksAccessibleByMouse|Qt::TextBrowserInteraction|Qt::TextSelectableByKeyboard|Qt::TextSelectableByMouse</set>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QLineEdit" name="userTextBox">
|
||||||
|
<property name="placeholderText">
|
||||||
|
<string>Email / Username</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QLineEdit" name="passTextBox">
|
||||||
|
<property name="echoMode">
|
||||||
|
<enum>QLineEdit::Password</enum>
|
||||||
|
</property>
|
||||||
|
<property name="placeholderText">
|
||||||
|
<string>Password</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QProgressBar" name="progressBar">
|
||||||
|
<property name="value">
|
||||||
|
<number>24</number>
|
||||||
|
</property>
|
||||||
|
<property name="textVisible">
|
||||||
|
<bool>false</bool>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QDialogButtonBox" name="buttonBox">
|
||||||
|
<property name="orientation">
|
||||||
|
<enum>Qt::Horizontal</enum>
|
||||||
|
</property>
|
||||||
|
<property name="standardButtons">
|
||||||
|
<set>QDialogButtonBox::Cancel|QDialogButtonBox::Ok</set>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
</layout>
|
||||||
|
</widget>
|
||||||
|
<resources/>
|
||||||
|
<connections/>
|
||||||
|
</ui>
|
Loading…
Reference in New Issue
Block a user