Browse Source

qml: refactor proxy options to map, remove explicit TOR option

master
Sander van Grieken 3 years ago
parent
commit
d26440b964
  1. 8
      electrum/gui/qml/components/ProxyConfigDialog.qml
  2. 31
      electrum/gui/qml/components/controls/ProxyConfig.qml

8
electrum/gui/qml/components/ProxyConfigDialog.qml

@ -58,7 +58,6 @@ ElDialog {
Component.onCompleted: {
var p = Network.proxy
console.log(JSON.stringify(p))
if ('mode' in p) {
proxyconfig.proxy_enabled = true
@ -66,10 +65,9 @@ ElDialog {
proxyconfig.proxy_port = p['port']
proxyconfig.username = p['user']
proxyconfig.password = p['password']
if (p['mode'] == 'socks5' && p['port'] == 9050)
p['mode'] = 'tor'
proxyconfig.proxy_type = proxyconfig.proxy_types.indexOf(p['mode'].toUpperCase())
console.log('proxy type: ' + proxyconfig.proxy_type)
proxyconfig.proxy_type = proxyconfig.proxy_types.map(function(x) {
return x.value
}).indexOf(p['mode'])
} else {
proxyconfig.proxy_enabled = false
}

31
electrum/gui/qml/components/controls/ProxyConfig.qml

@ -5,6 +5,8 @@ import QtQuick.Controls 2.1
Item {
id: pc
implicitHeight: rootLayout.height
property alias proxy_enabled: proxy_enabled_cb.checked
property alias proxy_type: proxytype.currentIndex
property alias proxy_address: address.text
@ -12,17 +14,16 @@ Item {
property alias username: username_tf.text
property alias password: password_tf.text
property var proxy_types: ['TOR', 'SOCKS5', 'SOCKS4']
height: rootLayout.height
property var proxy_type_map: [
{ text: qsTr('SOCKS5/TOR'), value: 'socks5' },
{ text: qsTr('SOCKS4'), value: 'socks4' }
]
function toProxyDict() {
var p = {}
p['enabled'] = pc.proxy_enabled
if (pc.proxy_enabled) {
var type = pc.proxy_types[pc.proxy_type].toLowerCase()
if (type == 'tor')
type = 'socks5'
var type = proxy_type_map[pc.proxy_type]['value']
p['mode'] = type
p['host'] = pc.proxy_address
p['port'] = pc.proxy_port
@ -43,17 +44,23 @@ Item {
text: qsTr('Enable Proxy')
}
ComboBox {
ElComboBox {
id: proxytype
enabled: proxy_enabled_cb.checked
model: proxy_types
textRole: 'text'
valueRole: 'value'
model: proxy_type_map
onCurrentIndexChanged: {
if (currentIndex == 0) {
if (address.text == '' || port.text == '') {
address.text = "127.0.0.1"
port.text = "9050"
}
}
}
}
GridLayout {
columns: 2
@ -66,7 +73,7 @@ Item {
TextField {
id: address
enabled: proxytype.enabled && proxytype.currentIndex > 0
enabled: proxy_enabled_cb.checked
}
Label {
@ -76,7 +83,7 @@ Item {
TextField {
id: port
enabled: proxytype.enabled && proxytype.currentIndex > 0
enabled: proxy_enabled_cb.checked
}
Label {
@ -86,7 +93,7 @@ Item {
TextField {
id: username_tf
enabled: proxytype.enabled && proxytype.currentIndex > 0
enabled: proxy_enabled_cb.checked
}
Label {
@ -96,7 +103,7 @@ Item {
PasswordField {
id: password_tf
enabled: proxytype.enabled && proxytype.currentIndex > 0
enabled: proxy_enabled_cb.checked
}
}
}

Loading…
Cancel
Save