aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorWladimir J. van der Laan <laanwj@gmail.com>2011-05-15 19:31:20 +0200
committerWladimir J. van der Laan <laanwj@gmail.com>2011-05-15 19:31:20 +0200
commit992ff49b43cd9110fc8ce41151f7555458dcf4dc (patch)
tree589c25b9608f671e9ca4be7f32e384c931ab19a7
parent85663f2c1886cf867ebe8c5b11b5d8fea10f6e82 (diff)
make send coins dialog more user friendly (better checking)
-rw-r--r--TODO4
-rw-r--r--gui/forms/sendcoinsdialog.ui28
-rw-r--r--gui/include/sendcoinsdialog.h2
-rw-r--r--gui/src/addressbookdialog.cpp10
-rw-r--r--gui/src/bitcoingui.cpp7
-rw-r--r--gui/src/sendcoinsdialog.cpp43
6 files changed, 66 insertions, 28 deletions
diff --git a/TODO b/TODO
index dceee9b24d..3136696ffc 100644
--- a/TODO
+++ b/TODO
@@ -92,3 +92,7 @@ Todo:
- Check windows support / cross platform
+Check send dialog:
+ 1MCwBbhNGp5hRm5rC1Aims2YFRe2SXPYKt
+
+
diff --git a/gui/forms/sendcoinsdialog.ui b/gui/forms/sendcoinsdialog.ui
index 31a0b99e20..ce4edde4ed 100644
--- a/gui/forms/sendcoinsdialog.ui
+++ b/gui/forms/sendcoinsdialog.ui
@@ -64,6 +64,9 @@
<property name="text">
<string>&amp;Paste</string>
</property>
+ <property name="autoDefault">
+ <bool>false</bool>
+ </property>
</widget>
</item>
<item row="3" column="3">
@@ -71,6 +74,9 @@
<property name="text">
<string>Address &amp;Book...</string>
</property>
+ <property name="autoDefault">
+ <bool>false</bool>
+ </property>
</widget>
</item>
<item row="2" column="1">
@@ -124,6 +130,9 @@
<iconset resource="../bitcoin.qrc">
<normaloff>:/icons/send</normaloff>:/icons/send</iconset>
</property>
+ <property name="default">
+ <bool>true</bool>
+ </property>
</widget>
</item>
<item>
@@ -146,22 +155,5 @@
<resources>
<include location="../bitcoin.qrc"/>
</resources>
- <connections>
- <connection>
- <sender>payAmount</sender>
- <signal>returnPressed()</signal>
- <receiver>sendButton</receiver>
- <slot>click()</slot>
- <hints>
- <hint type="sourcelabel">
- <x>191</x>
- <y>65</y>
- </hint>
- <hint type="destinationlabel">
- <x>570</x>
- <y>121</y>
- </hint>
- </hints>
- </connection>
- </connections>
+ <connections/>
</ui>
diff --git a/gui/include/sendcoinsdialog.h b/gui/include/sendcoinsdialog.h
index a2fcdd0762..95dd34b1e5 100644
--- a/gui/include/sendcoinsdialog.h
+++ b/gui/include/sendcoinsdialog.h
@@ -12,7 +12,7 @@ class SendCoinsDialog : public QDialog
Q_OBJECT
public:
- explicit SendCoinsDialog(QWidget *parent = 0);
+ explicit SendCoinsDialog(QWidget *parent = 0, const QString &address = "");
~SendCoinsDialog();
private:
diff --git a/gui/src/addressbookdialog.cpp b/gui/src/addressbookdialog.cpp
index 71543f11a7..9ad18f1cd7 100644
--- a/gui/src/addressbookdialog.cpp
+++ b/gui/src/addressbookdialog.cpp
@@ -127,6 +127,12 @@ void AddressBookDialog::on_buttonBox_accepted()
QVariant address = table->model()->data(index);
returnValue = address.toString();
}
-
- accept();
+ if(!returnValue.isEmpty())
+ {
+ accept();
+ }
+ else
+ {
+ reject();
+ }
}
diff --git a/gui/src/bitcoingui.cpp b/gui/src/bitcoingui.cpp
index 4af703cf8d..760789a015 100644
--- a/gui/src/bitcoingui.cpp
+++ b/gui/src/bitcoingui.cpp
@@ -211,7 +211,12 @@ void BitcoinGUI::addressbookClicked()
qDebug() << "Address book clicked";
AddressBookDialog dlg;
dlg.setTab(AddressBookDialog::SendingTab);
- dlg.exec();
+ /* if an address accepted, do a 'send' to specified address */
+ if(dlg.exec())
+ {
+ SendCoinsDialog send(0, dlg.getReturnValue());
+ send.exec();
+ }
}
void BitcoinGUI::receivingAddressesClicked()
diff --git a/gui/src/sendcoinsdialog.cpp b/gui/src/sendcoinsdialog.cpp
index ce95244dcb..3907b4bc59 100644
--- a/gui/src/sendcoinsdialog.cpp
+++ b/gui/src/sendcoinsdialog.cpp
@@ -6,17 +6,31 @@
#include <QApplication>
#include <QClipboard>
+#include <QMessageBox>
+#include <QLocale>
#include "base58.h"
-SendCoinsDialog::SendCoinsDialog(QWidget *parent) :
+SendCoinsDialog::SendCoinsDialog(QWidget *parent, const QString &address) :
QDialog(parent),
ui(new Ui::SendCoinsDialog)
{
ui->setupUi(this);
+
+ /* Set up validators */
ui->payTo->setMaxLength(BitcoinAddressValidator::MaxAddressLength);
ui->payTo->setValidator(new BitcoinAddressValidator(this));
- ui->payAmount->setValidator(new QDoubleValidator(this));
+ QDoubleValidator *amountValidator = new QDoubleValidator(this);
+ amountValidator->setDecimals(8);
+ amountValidator->setBottom(0.0);
+ ui->payAmount->setValidator(amountValidator);
+
+ /* Set initial address if provided */
+ if(!address.isEmpty())
+ {
+ ui->payTo->setText(address);
+ ui->payAmount->setFocus();
+ }
}
SendCoinsDialog::~SendCoinsDialog()
@@ -28,14 +42,31 @@ void SendCoinsDialog::on_sendButton_clicked()
{
QByteArray payTo = ui->payTo->text().toUtf8();
uint160 payToHash = 0;
- if(AddressToHash160(payTo.constData(), payToHash))
+ double payAmount = 0.0;
+ bool valid = false;
+
+ if(!AddressToHash160(payTo.constData(), payToHash))
{
- accept();
+ QMessageBox::warning(this, tr("Warning"),
+ tr("The recepient address is not valid, please recheck."),
+ QMessageBox::Ok,
+ QMessageBox::Ok);
+ ui->payTo->setFocus();
+ return;
}
- else
+ payAmount = QLocale::system().toDouble(ui->payAmount->text(), &valid);
+ if(!valid || payAmount <= 0.0)
{
-
+ QMessageBox::warning(this, tr("Warning"),
+ tr("The amount to pay must be a valid number larger than 0."),
+ QMessageBox::Ok,
+ QMessageBox::Ok);
+ ui->payAmount->setFocus();
+ return;
}
+
+ /* TODO: send command to core, once this succeeds do accept() */
+ accept();
}
void SendCoinsDialog::on_pasteButton_clicked()