diff --git a/src/qt/forms/verifymessagedialog.ui b/src/qt/forms/verifymessagedialog.ui index 6b7f94258..a7c99716e 100644 --- a/src/qt/forms/verifymessagedialog.ui +++ b/src/qt/forms/verifymessagedialog.ui @@ -17,7 +17,7 @@ - Enter the message and signature below (be careful to correctly copy newlines, spaces, tabs, and other invisible characters), and press apply to obtain the bitcoin address used to sign the message. + Enter the message and signature below (be careful to correctly copy newlines, spaces, tabs and other invisible characters) to obtain the Bitcoin address used to sign the message. Qt::AlignLeading|Qt::AlignLeft|Qt::AlignTop @@ -35,9 +35,6 @@ - - Signature - @@ -48,9 +45,6 @@ true - - Address - @@ -62,6 +56,20 @@ + + + + Verify a message and obtain the Bitcoin address used to sign the message + + + &Verify Message + + + + :/icons/transaction_0:/icons/transaction_0 + + + @@ -79,6 +87,20 @@ + + + + Reset all verify message fields + + + Clear &All + + + + :/icons/remove:/icons/remove + + + @@ -92,19 +114,6 @@ - - - - Qt::Horizontal - - - QDialogButtonBox::Apply|QDialogButtonBox::Close - - - false - - - @@ -112,38 +121,5 @@ - - - buttonBox - accepted() - VerifyMessageDialog - accept() - - - 248 - 254 - - - 157 - 274 - - - - - buttonBox - rejected() - VerifyMessageDialog - reject() - - - 316 - 260 - - - 286 - 274 - - - - + diff --git a/src/qt/verifymessagedialog.cpp b/src/qt/verifymessagedialog.cpp index 884290871..1f82e2ac3 100644 --- a/src/qt/verifymessagedialog.cpp +++ b/src/qt/verifymessagedialog.cpp @@ -22,7 +22,16 @@ VerifyMessageDialog::VerifyMessageDialog(AddressTableModel *addressModel, QWidge { ui->setupUi(this); +#if (QT_VERSION >= 0x040700) + /* Do not move this to the XML file, Qt before 4.7 will choke on it */ + ui->lnSig->setPlaceholderText(tr("Enter Bitcoin signature")); + ui->lnAddress->setPlaceholderText(tr("Click \"Apply\" to obtain address")); +#endif + GUIUtil::setupAddressWidget(ui->lnAddress, this); + ui->lnAddress->installEventFilter(this); + + ui->edMessage->setFocus(); } VerifyMessageDialog::~VerifyMessageDialog() @@ -63,13 +72,33 @@ bool VerifyMessageDialog::checkAddress() return true; } -void VerifyMessageDialog::on_buttonBox_clicked(QAbstractButton *button) +void VerifyMessageDialog::on_verifyMessage_clicked() { - if(ui->buttonBox->buttonRole(button) == QDialogButtonBox::ApplyRole) - checkAddress(); + checkAddress(); } void VerifyMessageDialog::on_copyToClipboard_clicked() { QApplication::clipboard()->setText(ui->lnAddress->text()); } + +void VerifyMessageDialog::on_clearButton_clicked() +{ + ui->edMessage->clear(); + ui->lnSig->clear(); + ui->lnAddress->clear(); + ui->lblStatus->clear(); + + ui->edMessage->setFocus(); +} + +bool VerifyMessageDialog::eventFilter(QObject *object, QEvent *event) +{ + if(object == ui->lnAddress && (event->type() == QEvent::MouseButtonPress || + event->type() == QEvent::FocusIn)) + { + ui->lnAddress->selectAll(); + return true; + } + return QDialog::eventFilter(object, event); +} diff --git a/src/qt/verifymessagedialog.h b/src/qt/verifymessagedialog.h index 6a641f773..9a3fb4341 100644 --- a/src/qt/verifymessagedialog.h +++ b/src/qt/verifymessagedialog.h @@ -3,15 +3,13 @@ #include -class AddressTableModel; - -QT_BEGIN_NAMESPACE -class QAbstractButton; -QT_END_NAMESPACE - namespace Ui { class VerifyMessageDialog; } +class AddressTableModel; + +QT_BEGIN_NAMESPACE +QT_END_NAMESPACE class VerifyMessageDialog : public QDialog { @@ -21,16 +19,19 @@ public: explicit VerifyMessageDialog(AddressTableModel *addressModel, QWidget *parent = 0); ~VerifyMessageDialog(); -private slots: - void on_buttonBox_clicked(QAbstractButton *button); - - void on_copyToClipboard_clicked(); +protected: + bool eventFilter(QObject *object, QEvent *event); private: bool checkAddress(); Ui::VerifyMessageDialog *ui; AddressTableModel *model; + +private slots: + void on_verifyMessage_clicked(); + void on_copyToClipboard_clicked(); + void on_clearButton_clicked(); }; #endif // VERIFYMESSAGEDIALOG_H