diff --git a/bitcoin-qt.pro b/bitcoin-qt.pro
index a47d6616..f1ebec6b 100644
--- a/bitcoin-qt.pro
+++ b/bitcoin-qt.pro
@@ -234,7 +234,8 @@ FORMS += \
src/qt/forms/sendcoinsentry.ui \
src/qt/forms/askpassphrasedialog.ui \
src/qt/forms/rpcconsole.ui \
- src/qt/forms/verifymessagedialog.ui
+ src/qt/forms/verifymessagedialog.ui \
+ src/qt/forms/optionsdialog.ui
contains(USE_QRCODE, 1) {
HEADERS += src/qt/qrcodedialog.h
diff --git a/src/qt/forms/optionsdialog.ui b/src/qt/forms/optionsdialog.ui
new file mode 100644
index 00000000..07e2324e
--- /dev/null
+++ b/src/qt/forms/optionsdialog.ui
@@ -0,0 +1,466 @@
+
+
+ OptionsDialog
+
+
+
+ 0
+ 0
+ 540
+ 380
+
+
+
+ Options
+
+
+ true
+
+
+ -
+
+
+ QTabWidget::North
+
+
+ 0
+
+
+
+ &Main
+
+
+
-
+
+
+ Optional transaction fee per kB that helps make sure your transactions are processed quickly. Most transactions are 1 kB. Fee 0.01 recommended.
+
+
+ Qt::PlainText
+
+
+ true
+
+
+
+ -
+
+
-
+
+
+ Pay transaction &fee
+
+
+ Qt::PlainText
+
+
+ transactionFee
+
+
+
+ -
+
+
+ -
+
+
+ Qt::Horizontal
+
+
+
+ 40
+ 20
+
+
+
+
+
+
+ -
+
+
+ Automatically start Bitcoin after logging in to the system.
+
+
+ &Start Bitcoin on system login
+
+
+
+ -
+
+
+ Detach block and address databases at shutdown. This means they can be moved to another data directory, but it slows down shutdown. The wallet is always detached.
+
+
+ &Detach databases at shutdown
+
+
+
+ -
+
+
+ Qt::Vertical
+
+
+
+ 20
+ 40
+
+
+
+
+
+
+
+
+ &Network
+
+
+ -
+
+
+ Automatically open the Bitcoin client port on the router. This only works when your router supports UPnP and it is enabled.
+
+
+ Map port using &UPnP
+
+
+
+ -
+
+
+ Connect to the Bitcon network through a SOCKS proxy (e.g. when connecting through Tor).
+
+
+ &Connect through SOCKS proxy:
+
+
+
+ -
+
+
-
+
+
+ Proxy &IP:
+
+
+ Qt::PlainText
+
+
+ proxyIp
+
+
+
+ -
+
+
+
+ 140
+ 16777215
+
+
+
+ IP address of the proxy (e.g. 127.0.0.1)
+
+
+
+ -
+
+
+ &Port:
+
+
+ Qt::PlainText
+
+
+ proxyPort
+
+
+
+ -
+
+
+
+ 55
+ 16777215
+
+
+
+ Port of the proxy (e.g. 9050)
+
+
+
+ -
+
+
+ SOCKS &Version:
+
+
+ Qt::PlainText
+
+
+ socksVersion
+
+
+
+ -
+
+
+ SOCKS version of the proxy (e.g. 5)
+
+
+
+ -
+
+
+ Qt::Horizontal
+
+
+
+ 40
+ 20
+
+
+
+
+
+
+ -
+
+
+ Qt::Vertical
+
+
+
+ 20
+ 40
+
+
+
+
+
+
+
+
+ &Window
+
+
+ -
+
+
+ Show only a tray icon after minimizing the window.
+
+
+ &Minimize to the tray instead of the taskbar
+
+
+
+ -
+
+
+ Minimize instead of exit the application when the window is closed. When this option is enabled, the application will be closed only after selecting Quit in the menu.
+
+
+ M&inimize on close
+
+
+
+ -
+
+
+ Qt::Vertical
+
+
+
+ 20
+ 40
+
+
+
+
+
+
+
+
+ &Display
+
+
+ -
+
+
-
+
+
+ User Interface &language:
+
+
+ Qt::PlainText
+
+
+ lang
+
+
+
+ -
+
+
+ The user interface language can be set here. This setting will take effect after restarting Bitcoin.
+
+
+
+
+
+ -
+
+
-
+
+
+ &Unit to show amounts in:
+
+
+ Qt::PlainText
+
+
+ unit
+
+
+
+ -
+
+
+ Choose the default subdivision unit to show in the interface and when sending coins.
+
+
+
+
+
+ -
+
+
+ Whether to show Bitcoin addresses in the transaction list or not.
+
+
+ &Display addresses in transaction list
+
+
+
+ -
+
+
+ Qt::Vertical
+
+
+
+ 20
+ 40
+
+
+
+
+
+
+
+
+ -
+
+
-
+
+
+ Qt::Horizontal
+
+
+
+ 40
+ 48
+
+
+
+
+ -
+
+
+
+ 75
+ true
+
+
+
+
+
+
+ Qt::PlainText
+
+
+ true
+
+
+
+ -
+
+
+ Qt::Horizontal
+
+
+
+ 40
+ 48
+
+
+
+
+ -
+
+
+ &OK
+
+
+
+ -
+
+
+ &Cancel
+
+
+ false
+
+
+
+ -
+
+
+ &Apply
+
+
+ false
+
+
+ false
+
+
+ false
+
+
+
+
+
+
+
+
+
+ BitcoinAmountField
+ QSpinBox
+
+
+
+ QValueComboBox
+ QComboBox
+
+
+
+ QValidatedLineEdit
+ QLineEdit
+
+
+
+
+
+
diff --git a/src/qt/optionsdialog.cpp b/src/qt/optionsdialog.cpp
index 50374ddc..9c7b8545 100644
--- a/src/qt/optionsdialog.cpp
+++ b/src/qt/optionsdialog.cpp
@@ -1,396 +1,218 @@
#include "optionsdialog.h"
-#include "optionsmodel.h"
+#include "ui_optionsdialog.h"
+
#include "bitcoinamountfield.h"
-#include "monitoreddatamapper.h"
-#include "guiutil.h"
#include "bitcoinunits.h"
+#include "monitoreddatamapper.h"
+#include "netbase.h"
+#include "optionsmodel.h"
+#include "qvalidatedlineedit.h"
#include "qvaluecombobox.h"
-#include
-#include
-#include
-#include
-#include
-
#include
+#include
+#include
#include
#include
-#include
-#include
-#include
-#include
-#include
#include
+#include
+#include
+#include
+#include
+#include
-class OptionsPage: public QWidget
+OptionsDialog::OptionsDialog(QWidget *parent) :
+ QDialog(parent),
+ ui(new Ui::OptionsDialog),
+ model(0),
+ mapper(0),
+ fRestartWarningDisplayed_Proxy(false),
+ fRestartWarningDisplayed_Lang(false),
+ fProxyIpValid(true)
{
- Q_OBJECT
-public:
- explicit OptionsPage(QWidget *parent=0): QWidget(parent) {}
+ ui->setupUi(this);
- virtual void setMapper(MonitoredDataMapper *mapper) = 0;
-};
-
-class MainOptionsPage: public OptionsPage
-{
- Q_OBJECT
-public:
- explicit MainOptionsPage(QWidget *parent=0);
-
- virtual void setMapper(MonitoredDataMapper *mapper);
-private:
- BitcoinAmountField *fee_edit;
- QCheckBox *bitcoin_at_startup;
- QCheckBox *detach_database;
-};
-
-class WindowOptionsPage: public OptionsPage
-{
- Q_OBJECT
-public:
- explicit WindowOptionsPage(QWidget *parent=0);
-
- virtual void setMapper(MonitoredDataMapper *mapper);
-private:
-#ifndef Q_WS_MAC
- QCheckBox *minimize_to_tray;
- QCheckBox *minimize_on_close;
+ /* Network elements init */
+#ifndef USE_UPNP
+ ui->mapPortUpnp->setEnabled(false);
#endif
-};
-class DisplayOptionsPage: public OptionsPage
-{
- Q_OBJECT
-public:
- explicit DisplayOptionsPage(QWidget *parent=0);
+ ui->socksVersion->setEnabled(false);
+ ui->socksVersion->addItem("5", 5);
+ ui->socksVersion->addItem("4", 4);
+ ui->socksVersion->setCurrentIndex(0);
- virtual void setMapper(MonitoredDataMapper *mapper);
-private:
- QValueComboBox *lang;
- QValueComboBox *unit;
- QCheckBox *display_addresses;
- bool restart_warning_displayed;
-private slots:
- void showRestartWarning();
-};
+ ui->proxyIp->setEnabled(false);
+ ui->proxyPort->setEnabled(false);
+ ui->proxyPort->setValidator(new QIntValidator(0, 65535, this));
-class NetworkOptionsPage: public OptionsPage
-{
- Q_OBJECT
-public:
- explicit NetworkOptionsPage(QWidget *parent=0);
+ connect(ui->connectSocks, SIGNAL(toggled(bool)), ui->socksVersion, SLOT(setEnabled(bool)));
+ connect(ui->connectSocks, SIGNAL(toggled(bool)), ui->proxyIp, SLOT(setEnabled(bool)));
+ connect(ui->connectSocks, SIGNAL(toggled(bool)), ui->proxyPort, SLOT(setEnabled(bool)));
- virtual void setMapper(MonitoredDataMapper *mapper);
-private:
- QCheckBox *map_port_upnp;
- QCheckBox *connect_socks4;
- QLineEdit *proxy_ip;
- QLineEdit *proxy_port;
-};
+ ui->proxyIp->installEventFilter(this);
-
-#include "optionsdialog.moc"
-
-OptionsDialog::OptionsDialog(QWidget *parent):
- QDialog(parent), contents_widget(0), pages_widget(0),
- model(0)
-{
- contents_widget = new QListWidget();
- contents_widget->setMaximumWidth(128);
-
- pages_widget = new QStackedWidget();
- pages_widget->setMinimumWidth(500);
- pages_widget->setMinimumHeight(300);
-
- pages.append(new MainOptionsPage(this));
- pages.append(new NetworkOptionsPage(this));
-#ifndef Q_WS_MAC
- /* Hide Window options on Mac as there are currently none available */
- pages.append(new WindowOptionsPage(this));
+ /* Window elements init */
+#ifdef Q_WS_MAC
+ ui->tabWindow->setVisible(false);
#endif
- pages.append(new DisplayOptionsPage(this));
- foreach(OptionsPage *page, pages)
+ /* Display elements init */
+ QDir translations(":translations");
+ ui->lang->addItem(QString("(") + tr("default") + QString(")"), QVariant(""));
+ foreach(const QString &langStr, translations.entryList())
{
- QListWidgetItem *item = new QListWidgetItem(page->windowTitle());
- contents_widget->addItem(item);
- pages_widget->addWidget(page);
+ ui->lang->addItem(langStr, QVariant(langStr));
}
- contents_widget->setCurrentRow(0);
+ ui->unit->setModel(new BitcoinUnits(this));
- QHBoxLayout *main_layout = new QHBoxLayout();
- main_layout->addWidget(contents_widget);
- main_layout->addWidget(pages_widget, 1);
-
- QVBoxLayout *layout = new QVBoxLayout();
- layout->addLayout(main_layout);
-
- QDialogButtonBox *buttonbox = new QDialogButtonBox();
- buttonbox->setStandardButtons(QDialogButtonBox::Apply|QDialogButtonBox::Ok|QDialogButtonBox::Cancel);
- apply_button = buttonbox->button(QDialogButtonBox::Apply);
- layout->addWidget(buttonbox);
-
- setLayout(layout);
- setWindowTitle(tr("Options"));
+ connect(ui->connectSocks, SIGNAL(clicked(bool)), this, SLOT(showRestartWarning_Proxy()));
+ connect(ui->lang, SIGNAL(activated(int)), this, SLOT(showRestartWarning_Lang()));
/* Widget-to-option mapper */
mapper = new MonitoredDataMapper(this);
mapper->setSubmitPolicy(QDataWidgetMapper::ManualSubmit);
mapper->setOrientation(Qt::Vertical);
- /* enable apply button when data modified */
- connect(mapper, SIGNAL(viewModified()), this, SLOT(enableApply()));
- /* disable apply button when new data loaded */
- connect(mapper, SIGNAL(currentIndexChanged(int)), this, SLOT(disableApply()));
- /* Event bindings */
- connect(contents_widget, SIGNAL(currentRowChanged(int)), this, SLOT(changePage(int)));
- connect(buttonbox->button(QDialogButtonBox::Ok), SIGNAL(clicked()), this, SLOT(okClicked()));
- connect(buttonbox->button(QDialogButtonBox::Cancel), SIGNAL(clicked()), this, SLOT(cancelClicked()));
- connect(buttonbox->button(QDialogButtonBox::Apply), SIGNAL(clicked()), this, SLOT(applyClicked()));
+ /* enable save buttons when data modified */
+ connect(mapper, SIGNAL(viewModified()), this, SLOT(enableSaveButtons()));
+ /* disable save buttons when new data loaded */
+ connect(mapper, SIGNAL(currentIndexChanged(int)), this, SLOT(disableSaveButtons()));
+ /* disable/enable save buttons when proxy IP is invalid/valid */
+ connect(this, SIGNAL(proxyIpValid(bool)), this, SLOT(setSaveButtonState(bool)));
+}
+
+OptionsDialog::~OptionsDialog()
+{
+ delete ui;
}
void OptionsDialog::setModel(OptionsModel *model)
{
this->model = model;
- mapper->setModel(model);
-
- foreach(OptionsPage *page, pages)
+ if(model)
{
- page->setMapper(mapper);
+ connect(model, SIGNAL(displayUnitChanged(int)), this, SLOT(updateDisplayUnit()));
+
+ mapper->setModel(model);
+ setMapper();
+ mapper->toFirst();
}
- mapper->toFirst();
+ // update the display unit, to not use the default ("BTC")
+ updateDisplayUnit();
}
-void OptionsDialog::changePage(int index)
+void OptionsDialog::setMapper()
{
- pages_widget->setCurrentIndex(index);
+ /* Main */
+ mapper->addMapping(ui->transactionFee, OptionsModel::Fee);
+ mapper->addMapping(ui->bitcoinAtStartup, OptionsModel::StartAtStartup);
+ mapper->addMapping(ui->detachDatabases, OptionsModel::DetachDatabases);
+
+ /* Network */
+ mapper->addMapping(ui->mapPortUpnp, OptionsModel::MapPortUPnP);
+ mapper->addMapping(ui->connectSocks, OptionsModel::ProxyUse);
+ mapper->addMapping(ui->socksVersion, OptionsModel::ProxySocksVersion);
+ mapper->addMapping(ui->proxyIp, OptionsModel::ProxyIP);
+ mapper->addMapping(ui->proxyPort, OptionsModel::ProxyPort);
+
+ /* Window */
+#ifndef Q_WS_MAC
+ mapper->addMapping(ui->minimizeToTray, OptionsModel::MinimizeToTray);
+ mapper->addMapping(ui->minimizeOnClose, OptionsModel::MinimizeOnClose);
+#endif
+
+ /* Display */
+ mapper->addMapping(ui->lang, OptionsModel::Language);
+ mapper->addMapping(ui->unit, OptionsModel::DisplayUnit);
+ mapper->addMapping(ui->displayAddresses, OptionsModel::DisplayAddresses);
}
-void OptionsDialog::okClicked()
+void OptionsDialog::enableSaveButtons()
+{
+ // prevent enabling of the save buttons when data modified, if there is an invalid proxy address present
+ if(fProxyIpValid)
+ setSaveButtonState(true);
+}
+
+void OptionsDialog::disableSaveButtons()
+{
+ setSaveButtonState(false);
+}
+
+void OptionsDialog::setSaveButtonState(bool fState)
+{
+ ui->applyButton->setEnabled(fState);
+ ui->okButton->setEnabled(fState);
+}
+
+void OptionsDialog::on_okButton_clicked()
{
mapper->submit();
accept();
}
-void OptionsDialog::cancelClicked()
+void OptionsDialog::on_cancelButton_clicked()
{
reject();
}
-void OptionsDialog::applyClicked()
+void OptionsDialog::on_applyButton_clicked()
{
mapper->submit();
- apply_button->setEnabled(false);
+ ui->applyButton->setEnabled(false);
}
-void OptionsDialog::enableApply()
+void OptionsDialog::showRestartWarning_Proxy()
{
- apply_button->setEnabled(true);
-}
-
-void OptionsDialog::disableApply()
-{
- apply_button->setEnabled(false);
-}
-
-/* Main options */
-MainOptionsPage::MainOptionsPage(QWidget *parent):
- OptionsPage(parent)
-{
- QVBoxLayout *layout = new QVBoxLayout();
- setWindowTitle(tr("Main"));
-
- QLabel *fee_help = new QLabel(tr("Optional transaction fee per kB that helps make sure your transactions are processed quickly. Most transactions are 1 kB. Fee 0.01 recommended."));
- fee_help->setWordWrap(true);
- layout->addWidget(fee_help);
-
- QHBoxLayout *fee_hbox = new QHBoxLayout();
- fee_hbox->addSpacing(18);
- QLabel *fee_label = new QLabel(tr("Pay transaction &fee"));
- fee_hbox->addWidget(fee_label);
- fee_edit = new BitcoinAmountField();
-
- fee_label->setBuddy(fee_edit);
- fee_hbox->addWidget(fee_edit);
- fee_hbox->addStretch(1);
-
- layout->addLayout(fee_hbox);
-
- bitcoin_at_startup = new QCheckBox(tr("&Start Bitcoin on system login"));
- bitcoin_at_startup->setToolTip(tr("Automatically start Bitcoin after logging in to the system"));
- layout->addWidget(bitcoin_at_startup);
-
- detach_database = new QCheckBox(tr("&Detach databases at shutdown"));
- detach_database->setToolTip(tr("Detach block and address databases at shutdown. This means they can be moved to another data directory, but it slows down shutdown. The wallet is always detached."));
- layout->addWidget(detach_database);
-
- layout->addStretch(1); // Extra space at bottom
- setLayout(layout);
-}
-
-void MainOptionsPage::setMapper(MonitoredDataMapper *mapper)
-{
- // Map model to widgets
- mapper->addMapping(fee_edit, OptionsModel::Fee);
- mapper->addMapping(bitcoin_at_startup, OptionsModel::StartAtStartup);
- mapper->addMapping(detach_database, OptionsModel::DetachDatabases);
-}
-
-/* Display options */
-DisplayOptionsPage::DisplayOptionsPage(QWidget *parent):
- OptionsPage(parent), restart_warning_displayed(false)
-{
- setWindowTitle(tr("Display"));
-
- QVBoxLayout *layout = new QVBoxLayout();
-
- QHBoxLayout *lang_hbox = new QHBoxLayout();
- lang_hbox->addSpacing(18);
- QLabel *lang_label = new QLabel(tr("User Interface &Language:"));
- lang_hbox->addWidget(lang_label);
- lang = new QValueComboBox(this);
- // Make list of languages
- QDir translations(":translations");
- lang->addItem(QString("(") + tr("default") + QString(")"), QVariant(""));
- foreach(const QString &langStr, translations.entryList())
- {
- lang->addItem(langStr, QVariant(langStr));
- }
-
- lang->setToolTip(tr("The user interface language can be set here. This setting will only take effect after restarting Bitcoin."));
- connect(lang, SIGNAL(activated(int)), this, SLOT(showRestartWarning()));
-
- lang_label->setBuddy(lang);
- lang_hbox->addWidget(lang);
-
- layout->addLayout(lang_hbox);
-
- QHBoxLayout *unit_hbox = new QHBoxLayout();
- unit_hbox->addSpacing(18);
- QLabel *unit_label = new QLabel(tr("&Unit to show amounts in:"));
- unit_hbox->addWidget(unit_label);
- unit = new QValueComboBox(this);
- unit->setModel(new BitcoinUnits(this));
- unit->setToolTip(tr("Choose the default subdivision unit to show in the interface, and when sending coins"));
-
- unit_label->setBuddy(unit);
- unit_hbox->addWidget(unit);
-
- layout->addLayout(unit_hbox);
-
- display_addresses = new QCheckBox(tr("&Display addresses in transaction list"), this);
- display_addresses->setToolTip(tr("Whether to show Bitcoin addresses in the transaction list"));
- layout->addWidget(display_addresses);
-
- layout->addStretch();
- setLayout(layout);
-}
-
-void DisplayOptionsPage::setMapper(MonitoredDataMapper *mapper)
-{
- mapper->addMapping(lang, OptionsModel::Language);
- mapper->addMapping(unit, OptionsModel::DisplayUnit);
- mapper->addMapping(display_addresses, OptionsModel::DisplayAddresses);
-}
-
-void DisplayOptionsPage::showRestartWarning()
-{
- if(!restart_warning_displayed)
+ if(!fRestartWarningDisplayed_Proxy)
{
QMessageBox::warning(this, tr("Warning"), tr("This setting will take effect after restarting Bitcoin."), QMessageBox::Ok);
- restart_warning_displayed = true;
+ fRestartWarningDisplayed_Proxy = true;
}
}
-/* Window options */
-WindowOptionsPage::WindowOptionsPage(QWidget *parent):
- OptionsPage(parent)
+void OptionsDialog::showRestartWarning_Lang()
{
- QVBoxLayout *layout = new QVBoxLayout();
- setWindowTitle(tr("Window"));
-
-#ifndef Q_WS_MAC
- minimize_to_tray = new QCheckBox(tr("&Minimize to the tray instead of the taskbar"));
- minimize_to_tray->setToolTip(tr("Show only a tray icon after minimizing the window"));
- layout->addWidget(minimize_to_tray);
-
- minimize_on_close = new QCheckBox(tr("M&inimize on close"));
- minimize_on_close->setToolTip(tr("Minimize instead of exit the application when the window is closed. When this option is enabled, the application will be closed only after selecting Quit in the menu."));
- layout->addWidget(minimize_on_close);
-#endif
-
- layout->addStretch(1); // Extra space at bottom
- setLayout(layout);
+ if(!fRestartWarningDisplayed_Lang)
+ {
+ QMessageBox::warning(this, tr("Warning"), tr("This setting will take effect after restarting Bitcoin."), QMessageBox::Ok);
+ fRestartWarningDisplayed_Lang = true;
+ }
}
-void WindowOptionsPage::setMapper(MonitoredDataMapper *mapper)
+void OptionsDialog::updateDisplayUnit()
{
- // Map model to widgets
-#ifndef Q_WS_MAC
- mapper->addMapping(minimize_to_tray, OptionsModel::MinimizeToTray);
-#endif
-#ifndef Q_WS_MAC
- mapper->addMapping(minimize_on_close, OptionsModel::MinimizeOnClose);
-#endif
+ if(model)
+ {
+ // Update transactionFee with the current unit
+ ui->transactionFee->setDisplayUnit(model->getDisplayUnit());
+ }
}
-/* Network options */
-NetworkOptionsPage::NetworkOptionsPage(QWidget *parent):
- OptionsPage(parent)
+bool OptionsDialog::eventFilter(QObject *object, QEvent *event)
{
- QVBoxLayout *layout = new QVBoxLayout();
- setWindowTitle(tr("Network"));
-
- map_port_upnp = new QCheckBox(tr("Map port using &UPnP"));
- map_port_upnp->setToolTip(tr("Automatically open the Bitcoin client port on the router. This only works when your router supports UPnP and it is enabled."));
- layout->addWidget(map_port_upnp);
-
- connect_socks4 = new QCheckBox(tr("&Connect through SOCKS4 proxy:"));
- connect_socks4->setToolTip(tr("Connect to the Bitcon network through a SOCKS4 proxy (e.g. when connecting through Tor)"));
- layout->addWidget(connect_socks4);
-
- QHBoxLayout *proxy_hbox = new QHBoxLayout();
- proxy_hbox->addSpacing(18);
- QLabel *proxy_ip_label = new QLabel(tr("Proxy &IP:"));
- proxy_hbox->addWidget(proxy_ip_label);
- proxy_ip = new QLineEdit();
- proxy_ip->setMaximumWidth(140);
- proxy_ip->setEnabled(false);
- proxy_ip->setValidator(new QRegExpValidator(QRegExp("[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}"), this));
- proxy_ip->setToolTip(tr("IP address of the proxy (e.g. 127.0.0.1)"));
- proxy_ip_label->setBuddy(proxy_ip);
- proxy_hbox->addWidget(proxy_ip);
- QLabel *proxy_port_label = new QLabel(tr("&Port:"));
- proxy_hbox->addWidget(proxy_port_label);
- proxy_port = new QLineEdit();
- proxy_port->setMaximumWidth(55);
- proxy_port->setValidator(new QIntValidator(0, 65535, this));
- proxy_port->setEnabled(false);
- proxy_port->setToolTip(tr("Port of the proxy (e.g. 1234)"));
- proxy_port_label->setBuddy(proxy_port);
- proxy_hbox->addWidget(proxy_port);
- proxy_hbox->addStretch(1);
- layout->addLayout(proxy_hbox);
-
- layout->addStretch(1); // Extra space at bottom
- setLayout(layout);
-
- connect(connect_socks4, SIGNAL(toggled(bool)), proxy_ip, SLOT(setEnabled(bool)));
- connect(connect_socks4, SIGNAL(toggled(bool)), proxy_port, SLOT(setEnabled(bool)));
-
-#ifndef USE_UPNP
- map_port_upnp->setDisabled(true);
-#endif
-}
-
-void NetworkOptionsPage::setMapper(MonitoredDataMapper *mapper)
-{
- // Map model to widgets
- mapper->addMapping(map_port_upnp, OptionsModel::MapPortUPnP);
- mapper->addMapping(connect_socks4, OptionsModel::ProxyUse);
- mapper->addMapping(proxy_ip, OptionsModel::ProxyIP);
- mapper->addMapping(proxy_port, OptionsModel::ProxyPort);
+ if(object == ui->proxyIp && event->type() == QEvent::FocusOut)
+ {
+ // Check proxyIP for a valid IPv4/IPv6 address
+ CService addr;
+ if(!LookupNumeric(ui->proxyIp->text().toStdString().c_str(), addr))
+ {
+ ui->proxyIp->setValid(false);
+ fProxyIpValid = false;
+ ui->statusLabel->setStyleSheet("QLabel { color: red; }");
+ ui->statusLabel->setText(tr("The supplied proxy address is invalid."));
+ emit proxyIpValid(false);
+ }
+ else
+ {
+ fProxyIpValid = true;
+ ui->statusLabel->clear();
+ emit proxyIpValid(true);
+ }
+ }
+ return QDialog::eventFilter(object, event);
}
diff --git a/src/qt/optionsdialog.h b/src/qt/optionsdialog.h
index ea0cbb8b..7e91c964 100644
--- a/src/qt/optionsdialog.h
+++ b/src/qt/optionsdialog.h
@@ -2,48 +2,53 @@
#define OPTIONSDIALOG_H
#include
-#include
-QT_BEGIN_NAMESPACE
-class QStackedWidget;
-class QListWidget;
-class QListWidgetItem;
-class QPushButton;
-QT_END_NAMESPACE
+namespace Ui {
+class OptionsDialog;
+}
class OptionsModel;
-class OptionsPage;
class MonitoredDataMapper;
/** Preferences dialog. */
class OptionsDialog : public QDialog
{
Q_OBJECT
+
public:
- explicit OptionsDialog(QWidget *parent=0);
+ explicit OptionsDialog(QWidget *parent = 0);
+ ~OptionsDialog();
void setModel(OptionsModel *model);
+ void setMapper();
-signals:
-
-public slots:
- /** Change the current page to \a index. */
- void changePage(int index);
+protected:
+ bool eventFilter(QObject *object, QEvent *event);
private slots:
- void okClicked();
- void cancelClicked();
- void applyClicked();
- void enableApply();
- void disableApply();
+ /* enable apply button and OK button */
+ void enableSaveButtons();
+ /* disable apply button and OK button */
+ void disableSaveButtons();
+ /* set apply button and OK button state (enabled / disabled) */
+ void setSaveButtonState(bool fState);
+ void on_okButton_clicked();
+ void on_cancelButton_clicked();
+ void on_applyButton_clicked();
+
+ void showRestartWarning_Proxy();
+ void showRestartWarning_Lang();
+ void updateDisplayUnit();
+
+signals:
+ void proxyIpValid(bool fValid);
private:
- QListWidget *contents_widget;
- QStackedWidget *pages_widget;
+ Ui::OptionsDialog *ui;
OptionsModel *model;
MonitoredDataMapper *mapper;
- QPushButton *apply_button;
-
- QList pages;
+ bool fRestartWarningDisplayed_Proxy;
+ bool fRestartWarningDisplayed_Lang;
+ bool fProxyIpValid;
};
#endif // OPTIONSDIALOG_H
diff --git a/src/qt/optionsmodel.cpp b/src/qt/optionsmodel.cpp
index 64d91cb0..d6c6bbf4 100644
--- a/src/qt/optionsmodel.cpp
+++ b/src/qt/optionsmodel.cpp
@@ -20,6 +20,7 @@ bool static ApplyProxySettings()
if (!settings.value("fUseProxy", false).toBool()) {
addrProxy = CService();
nSocksVersion = 0;
+ return false;
}
if (nSocksVersion && !addrProxy.IsValid())
return false;
@@ -53,6 +54,8 @@ void OptionsModel::Init()
SoftSetBoolArg("-upnp", settings.value("fUseUPnP").toBool());
if (settings.contains("addrProxy") && settings.value("fUseProxy").toBool())
SoftSetArg("-proxy", settings.value("addrProxy").toString().toStdString());
+ if (settings.contains("nSocksVersion") && settings.value("fUseProxy").toBool())
+ SoftSetArg("-socks", settings.value("nSocksVersion").toString().toStdString());
if (settings.contains("detachDB"))
SoftSetBoolArg("-detachdb", settings.value("detachDB").toBool());
if (!language.isEmpty())
@@ -142,7 +145,7 @@ QVariant OptionsModel::data(const QModelIndex & index, int role) const
case ProxyUse:
return settings.value("fUseProxy", false);
case ProxySocksVersion:
- return settings.value("nSocksVersion", false);
+ return settings.value("nSocksVersion", 5);
case ProxyIP: {
CService addrProxy;
if (GetProxy(NET_IPV4, addrProxy))
@@ -203,6 +206,10 @@ bool OptionsModel::setData(const QModelIndex & index, const QVariant & value, in
settings.setValue("fUseProxy", value.toBool());
ApplyProxySettings();
break;
+ case ProxySocksVersion:
+ settings.setValue("nSocksVersion", value.toInt());
+ ApplyProxySettings();
+ break;
case ProxyIP:
{
CService addrProxy("127.0.0.1", 9050);