improved network dialog

This commit is contained in:
thomasv 2012-10-12 11:01:09 +02:00
parent 8fe6673814
commit 91609dab9e

View file

@ -1309,7 +1309,7 @@ class ElectrumWindow(QMainWindow):
interface = wallet.interface interface = wallet.interface
if parent: if parent:
if interface.is_connected: if interface.is_connected:
status = _("Connected to")+" %s:%d\n%d blocks"%(interface.host, interface.port, wallet.blocks) status = _("Connected to")+" %s\n%d blocks"%(interface.host, wallet.blocks)
else: else:
status = _("Not connected") status = _("Not connected")
server = interface.server server = interface.server
@ -1341,92 +1341,54 @@ class ElectrumWindow(QMainWindow):
d.setMinimumSize(375, 20) d.setMinimumSize(375, 20)
vbox = QVBoxLayout() vbox = QVBoxLayout()
vbox.setSpacing(20) vbox.setSpacing(30)
hbox = QHBoxLayout() hbox = QHBoxLayout()
l = QLabel() l = QLabel()
l.setPixmap(QPixmap(":icons/network.png")) l.setPixmap(QPixmap(":icons/network.png"))
hbox.addStretch(10)
hbox.addWidget(l) hbox.addWidget(l)
hbox.addWidget(QLabel(status)) hbox.addWidget(QLabel(status))
hbox.addStretch(50)
vbox.addLayout(hbox) vbox.addLayout(hbox)
hbox = QHBoxLayout()
host_line = QLineEdit()
host_line.setText(server)
hbox.addWidget(QLabel(_('Connect to') + ':'))
hbox.addWidget(host_line)
vbox.addLayout(hbox)
hbox = QHBoxLayout() # grid layout
grid = QGridLayout()
grid.setSpacing(8)
vbox.addLayout(grid)
buttonGroup = QGroupBox(_("Protocol")) # server
radio1 = QRadioButton("tcp", buttonGroup) server_protocol = QComboBox()
radio2 = QRadioButton("http", buttonGroup) server_host = QLineEdit()
server_host.setFixedWidth(200)
server_port = QLineEdit()
server_port.setFixedWidth(60)
server_protocol.addItems(['TCP', 'HTTP'])
def current_line(): host, port, protocol = server.split(':')
return unicode(host_line.text()).split(':') server_host.setText(host)
server_port.setText(port)
def set_button(protocol): server_protocol.setCurrentIndex(0 if protocol=='t' else 1)
if protocol == 't':
radio1.setChecked(1)
elif protocol == 'h':
radio2.setChecked(1)
def set_protocol(protocol): grid.addWidget(QLabel(_('Server') + ':'), 0, 0)
host = current_line()[0] grid.addWidget(server_protocol, 0, 1)
grid.addWidget(server_host, 0, 2)
grid.addWidget(server_port, 0, 3)
def change_protocol(p):
protocol = 't' if p == 0 else 'h'
host = unicode(server_host.text())
pp = plist[host] pp = plist[host]
if protocol not in pp.keys(): if protocol not in pp.keys():
protocol = pp.keys()[0] protocol = pp.keys()[0]
set_button(protocol)
port = pp[protocol] port = pp[protocol]
host_line.setText( host + ':' + port + ':' + protocol) server_host.setText( host )
server_port.setText( port )
radio1.clicked.connect(lambda x: set_protocol('t') ) server_protocol.connect(server_protocol, SIGNAL('currentIndexChanged(int)'), change_protocol)
radio2.clicked.connect(lambda x: set_protocol('h') )
set_button(current_line()[2])
hbox.addWidget(QLabel(_('Protocol')+':'))
hbox.addWidget(radio1)
hbox.addWidget(radio2)
vbox.addLayout(hbox)
hbox = QHBoxLayout()
proxy_mode = QComboBox()
proxy_host = QLineEdit()
proxy_host.setFixedWidth(200)
proxy_port = QLineEdit()
proxy_port.setFixedWidth(50)
proxy_mode.addItems(['NONE', 'SOCKS4', 'SOCKS5', 'HTTP'])
def check_for_disable(index = False):
if proxy_mode.currentText() != 'NONE':
proxy_host.setEnabled(True)
proxy_port.setEnabled(True)
else:
proxy_host.setEnabled(False)
proxy_port.setEnabled(False)
check_for_disable()
proxy_mode.connect(proxy_mode, SIGNAL('currentIndexChanged(int)'), check_for_disable)
proxy_config = interface.proxy if interface.proxy else { "mode":"none", "host":"localhost", "port":"8080"}
proxy_mode.setCurrentIndex(proxy_mode.findText(str(proxy_config.get("mode").upper())))
proxy_host.setText(proxy_config.get("host"))
proxy_port.setText(proxy_config.get("port"))
hbox.addWidget(QLabel(_('Proxy') + ':'))
hbox.addWidget(proxy_mode)
hbox.addWidget(proxy_host)
hbox.addWidget(proxy_port)
vbox.addLayout(hbox)
hbox = QHBoxLayout()
if wallet.interface.servers: if wallet.interface.servers:
label = _('Active Servers') label = _('Active Servers')
else: else:
@ -1438,7 +1400,7 @@ class ElectrumWindow(QMainWindow):
for host in plist.keys(): for host in plist.keys():
servers_list_widget.addTopLevelItem(QTreeWidgetItem( [ host ] )) servers_list_widget.addTopLevelItem(QTreeWidgetItem( [ host ] ))
def do_set_line(x): def change_server(x):
host = unicode(x.text(0)) host = unicode(x.text(0))
pp = plist[host] pp = plist[host]
if 't' in pp.keys(): if 't' in pp.keys():
@ -1446,18 +1408,49 @@ class ElectrumWindow(QMainWindow):
else: else:
protocol = pp.keys()[0] protocol = pp.keys()[0]
port = pp[protocol] port = pp[protocol]
host_line.setText( host + ':' + port + ':' + protocol) server_host.setText( host )
set_button(protocol) server_port.setText( port )
server_protocol.setCurrentIndex(0 if protocol == 't' else 1)
servers_list_widget.connect(servers_list_widget, SIGNAL('itemClicked(QTreeWidgetItem*, int)'), do_set_line) servers_list_widget.connect(servers_list_widget, SIGNAL('itemClicked(QTreeWidgetItem*, int)'), change_server)
vbox.addWidget(servers_list_widget) grid.addWidget(servers_list_widget, 1, 1, 1, 3)
# proxy setting
proxy_mode = QComboBox()
proxy_host = QLineEdit()
proxy_host.setFixedWidth(200)
proxy_port = QLineEdit()
proxy_port.setFixedWidth(60)
proxy_mode.addItems(['NONE', 'SOCKS4', 'SOCKS5', 'HTTP'])
def check_for_disable(index = False):
if proxy_mode.currentText() != 'NONE':
proxy_host.setEnabled(True)
proxy_port.setEnabled(True)
else:
proxy_host.setEnabled(False)
proxy_port.setEnabled(False)
check_for_disable()
proxy_mode.connect(proxy_mode, SIGNAL('currentIndexChanged(int)'), check_for_disable)
proxy_config = interface.proxy if interface.proxy else { "mode":"none", "host":"localhost", "port":"8080"}
proxy_mode.setCurrentIndex(proxy_mode.findText(str(proxy_config.get("mode").upper())))
proxy_host.setText(proxy_config.get("host"))
proxy_port.setText(proxy_config.get("port"))
grid.addWidget(QLabel(_('Proxy') + ':'), 2, 0)
grid.addWidget(proxy_mode, 2, 1)
grid.addWidget(proxy_host, 2, 2)
grid.addWidget(proxy_port, 2, 3)
# buttons
vbox.addLayout(ok_cancel_buttons(d)) vbox.addLayout(ok_cancel_buttons(d))
d.setLayout(vbox) d.setLayout(vbox)
if not d.exec_(): return if not d.exec_(): return
server = unicode( host_line.text() )
server = unicode( server_host.text() ) + ':' + unicode( server_port.text() ) + ':' + 't' if server_protocol.currentIndex() == 0 else 'h'
if proxy_mode.currentText() != 'NONE': if proxy_mode.currentText() != 'NONE':
proxy = { u'mode':unicode(proxy_mode.currentText()).lower(), u'host':unicode(proxy_host.text()), u'port':unicode(proxy_port.text()) } proxy = { u'mode':unicode(proxy_mode.currentText()).lower(), u'host':unicode(proxy_host.text()), u'port':unicode(proxy_port.text()) }
else: else: