Tweak login dialog.
This commit is contained in:
parent
fcd05ca2f6
commit
aa8766581e
@ -16,12 +16,15 @@
|
|||||||
#include "logindialog.h"
|
#include "logindialog.h"
|
||||||
#include "ui_logindialog.h"
|
#include "ui_logindialog.h"
|
||||||
#include "keyring.h"
|
#include "keyring.h"
|
||||||
|
#include <QDebug>
|
||||||
|
|
||||||
LoginDialog::LoginDialog(QWidget *parent, const QString& loginErrMsg) :
|
LoginDialog::LoginDialog(QWidget *parent, const QString& loginErrMsg) :
|
||||||
QDialog(parent),
|
QDialog(parent),
|
||||||
ui(new Ui::LoginDialog)
|
ui(new Ui::LoginDialog)
|
||||||
{
|
{
|
||||||
ui->setupUi(this);
|
ui->setupUi(this);
|
||||||
|
|
||||||
|
blockToggles = false;
|
||||||
//FIXME: translateable?
|
//FIXME: translateable?
|
||||||
ui->usernameTextBox->lineEdit()->setPlaceholderText(QApplication::translate("LoginDialog", "Name", 0));
|
ui->usernameTextBox->lineEdit()->setPlaceholderText(QApplication::translate("LoginDialog", "Name", 0));
|
||||||
|
|
||||||
@ -50,6 +53,9 @@ LoginDialog::LoginDialog(QWidget *parent, const QString& loginErrMsg) :
|
|||||||
{
|
{
|
||||||
ui->passwordTextBox->setFocus(Qt::OtherFocusReason);
|
ui->passwordTextBox->setFocus(Qt::OtherFocusReason);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
connect(ui->rememberUsernameCheckbox,SIGNAL(toggled(bool)), SLOT(usernameToggled(bool)));
|
||||||
|
connect(ui->rememberPasswordCheckbox,SIGNAL(toggled(bool)), SLOT(passwordToggled(bool)));
|
||||||
}
|
}
|
||||||
|
|
||||||
LoginDialog::~LoginDialog()
|
LoginDialog::~LoginDialog()
|
||||||
@ -76,14 +82,71 @@ void LoginDialog::forgetCurrentUser()
|
|||||||
int index = ui->usernameTextBox->findText(acct);
|
int index = ui->usernameTextBox->findText(acct);
|
||||||
if(index != -1)
|
if(index != -1)
|
||||||
ui->usernameTextBox->removeItem(index);
|
ui->usernameTextBox->removeItem(index);
|
||||||
|
if(!ui->usernameTextBox->count())
|
||||||
|
{
|
||||||
|
blockToggles = true;
|
||||||
|
ui->rememberUsernameCheckbox->setChecked(false);
|
||||||
|
ui->rememberPasswordCheckbox->setChecked(false);
|
||||||
|
blockToggles = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void LoginDialog::passwordToggled ( bool state )
|
||||||
|
{
|
||||||
|
// if toggled off
|
||||||
|
if(blockToggles)
|
||||||
|
return;
|
||||||
|
blockToggles = true;
|
||||||
|
if(!state)
|
||||||
|
{
|
||||||
|
qDebug() << "password disabled";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if(!ui->rememberUsernameCheckbox->isChecked())
|
||||||
|
{
|
||||||
|
ui->rememberUsernameCheckbox->setChecked(true);
|
||||||
|
}
|
||||||
|
qDebug() << "password enabled";
|
||||||
|
}
|
||||||
|
blockToggles = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
void LoginDialog::usernameToggled ( bool state )
|
||||||
|
{
|
||||||
|
// if toggled off
|
||||||
|
if(blockToggles)
|
||||||
|
return;
|
||||||
|
blockToggles = true;
|
||||||
|
if(!state)
|
||||||
|
{
|
||||||
|
if(ui->rememberPasswordCheckbox->isChecked())
|
||||||
|
{
|
||||||
|
ui->rememberPasswordCheckbox->setChecked(false);
|
||||||
|
}
|
||||||
|
qDebug() << "username disabled";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
qDebug() << "username enabled";
|
||||||
|
}
|
||||||
|
blockToggles = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void LoginDialog::userTextChanged ( const QString& user )
|
void LoginDialog::userTextChanged ( const QString& user )
|
||||||
{
|
{
|
||||||
|
blockToggles = true;
|
||||||
Keyring * k = Keyring::instance();
|
Keyring * k = Keyring::instance();
|
||||||
QString acct = ui->usernameTextBox->currentText();
|
QStringList sl = k->getStoredAccounts("minecraft");
|
||||||
QString passwd = k->getPassword("minecraft",acct);
|
if(sl.contains(user))
|
||||||
ui->passwordTextBox->setText(passwd);
|
{
|
||||||
|
ui->rememberUsernameCheckbox->setChecked(true);
|
||||||
|
QString passwd = k->getPassword("minecraft",user);
|
||||||
|
ui->rememberPasswordCheckbox->setChecked(!passwd.isEmpty());
|
||||||
|
ui->passwordTextBox->setText(passwd);
|
||||||
|
}
|
||||||
|
blockToggles = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -91,9 +154,9 @@ void LoginDialog::accept()
|
|||||||
{
|
{
|
||||||
bool saveName = ui->rememberUsernameCheckbox->isChecked();
|
bool saveName = ui->rememberUsernameCheckbox->isChecked();
|
||||||
bool savePass = ui->rememberPasswordCheckbox->isChecked();
|
bool savePass = ui->rememberPasswordCheckbox->isChecked();
|
||||||
|
Keyring * k = Keyring::instance();
|
||||||
if(saveName)
|
if(saveName)
|
||||||
{
|
{
|
||||||
Keyring * k = Keyring::instance();
|
|
||||||
if(savePass)
|
if(savePass)
|
||||||
{
|
{
|
||||||
k->storePassword("minecraft",getUsername(),getPassword());
|
k->storePassword("minecraft",getUsername(),getPassword());
|
||||||
@ -103,5 +166,10 @@ void LoginDialog::accept()
|
|||||||
k->storePassword("minecraft",getUsername(),QString());
|
k->storePassword("minecraft",getUsername(),QString());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
QString acct = ui->usernameTextBox->currentText();
|
||||||
|
k->removeStoredAccount("minecraft", acct);
|
||||||
|
}
|
||||||
QDialog::accept();
|
QDialog::accept();
|
||||||
}
|
}
|
||||||
|
@ -37,8 +37,12 @@ public slots:
|
|||||||
virtual void accept();
|
virtual void accept();
|
||||||
virtual void userTextChanged(const QString& user);
|
virtual void userTextChanged(const QString& user);
|
||||||
virtual void forgetCurrentUser();
|
virtual void forgetCurrentUser();
|
||||||
|
private slots:
|
||||||
|
void usernameToggled ( bool );
|
||||||
|
void passwordToggled ( bool );
|
||||||
private:
|
private:
|
||||||
Ui::LoginDialog *ui;
|
Ui::LoginDialog *ui;
|
||||||
|
bool blockToggles;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // LOGINDIALOG_H
|
#endif // LOGINDIALOG_H
|
||||||
|
Loading…
x
Reference in New Issue
Block a user