Tweak login dialog.

This commit is contained in:
Petr Mrázek 2013-08-28 00:07:52 +02:00
parent fcd05ca2f6
commit aa8766581e
2 changed files with 76 additions and 4 deletions

View File

@ -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->rememberUsernameCheckbox->setChecked(true);
QString passwd = k->getPassword("minecraft",user);
ui->rememberPasswordCheckbox->setChecked(!passwd.isEmpty());
ui->passwordTextBox->setText(passwd); 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();
} }

View File

@ -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