From 18625d9d2704151d65679f2523f012c25ed3b7de Mon Sep 17 00:00:00 2001 From: Konstantinos Sideris Date: Mon, 21 Aug 2017 20:55:35 +0300 Subject: [PATCH] Fix login UX The mxid input will not prevent the user from entering any invalid value. closes #22 --- include/LoginPage.h | 2 ++ src/LoginPage.cc | 19 +++++++++++++------ 2 files changed, 15 insertions(+), 6 deletions(-) diff --git a/include/LoginPage.h b/include/LoginPage.h index 8e95061a..ef0a6e9e 100644 --- a/include/LoginPage.h +++ b/include/LoginPage.h @@ -66,6 +66,8 @@ private slots: void versionSuccess(); private: + bool isMatrixIdValid(); + QVBoxLayout *top_layout_; QHBoxLayout *top_bar_layout_; diff --git a/src/LoginPage.cc b/src/LoginPage.cc index 402206fc..c4048f98 100644 --- a/src/LoginPage.cc +++ b/src/LoginPage.cc @@ -155,8 +155,6 @@ LoginPage::LoginPage(QSharedPointer client, QWidget *parent) connect(client_.data(), SIGNAL(versionError(QString)), this, SLOT(versionError(QString))); connect(client_.data(), SIGNAL(versionSuccess()), this, SLOT(versionSuccess())); connect(serverInput_, SIGNAL(editingFinished()), this, SLOT(onServerAddressEntered())); - - matrixid_input_->setValidator(&InputValidator::Id); } void @@ -165,13 +163,22 @@ LoginPage::loginError(QString error) error_label_->setText(error); } +bool +LoginPage::isMatrixIdValid() +{ + int pos = 0; + auto matrix_id = matrixid_input_->text(); + + return InputValidator::Id.validate(matrix_id, pos) == QValidator::Acceptable; +} + void LoginPage::onMatrixIdEntered() { error_label_->setText(""); - if (!matrixid_input_->hasAcceptableInput()) { - loginError(tr("Invalid Matrix ID")); + if (!isMatrixIdValid()) { + loginError("You have entered an invalid Matrix ID e.g @joe:matrix.org"); return; } else if (password_input_->text().isEmpty()) { loginError(tr("Empty password")); @@ -255,8 +262,8 @@ LoginPage::onLoginButtonClicked() { error_label_->setText(""); - if (!matrixid_input_->hasAcceptableInput()) { - loginError("Invalid Matrix ID"); + if (!isMatrixIdValid()) { + loginError("You have entered an invalid Matrix ID e.g @joe:matrix.org"); } else if (password_input_->text().isEmpty()) { loginError("Empty password"); } else {