commit 222c70ada62cb49ab0949f4097e5819049bf7ede
parent 51f3c613a5acad42268f10356ca74e6c47bc2b18
Author: ThomasV <thomasv@electrum.org>
Date: Wed, 3 Mar 2021 10:45:46 +0100
qt swap_dialog: use a single button to toggle direction
Diffstat:
2 files changed, 37 insertions(+), 17 deletions(-)
diff --git a/electrum/gui/qt/swap_dialog.py b/electrum/gui/qt/swap_dialog.py
@@ -8,7 +8,7 @@ from electrum.lnutil import ln_dummy_address
from electrum.transaction import PartialTxOutput, PartialTransaction
from .util import (WindowModalDialog, Buttons, OkButton, CancelButton,
- EnterButton, ColorScheme, WWLabel, read_QIcon)
+ EnterButton, ColorScheme, WWLabel, read_QIcon, IconLabel)
from .amountedit import BTCAmountEdit
from .fee_slider import FeeSlider, FeeComboBox
@@ -43,15 +43,13 @@ class SwapDialog(WindowModalDialog):
self.max_button = EnterButton(_("Max"), self.spend_max)
self.max_button.setFixedWidth(100)
self.max_button.setCheckable(True)
- self.send_button = QPushButton('')
- self.recv_button = QPushButton('')
+ self.toggle_button = QPushButton(u'\U000021c4')
# send_follows is used to know whether the send amount field / receive
# amount field should be adjusted after the fee slider was moved
self.send_follows = False
self.send_amount_e.follows = False
self.recv_amount_e.follows = False
- self.send_button.clicked.connect(self.toggle_direction)
- self.recv_button.clicked.connect(self.toggle_direction)
+ self.toggle_button.clicked.connect(self.toggle_direction)
# textChanged is triggered for both user and automatic action
self.send_amount_e.textChanged.connect(self.on_send_edited)
self.recv_amount_e.textChanged.connect(self.on_recv_edited)
@@ -65,17 +63,18 @@ class SwapDialog(WindowModalDialog):
self.server_fee_label = QLabel()
vbox.addWidget(self.description_label)
h = QGridLayout()
- h.addWidget(QLabel(_('You send')+':'), 1, 0)
+ self.send_label = IconLabel(text=_('You send')+':')
+ self.recv_label = IconLabel(text=_('You receive')+':')
+ h.addWidget(self.send_label, 1, 0)
h.addWidget(self.send_amount_e, 1, 1)
- h.addWidget(self.send_button, 1, 2)
- h.addWidget(self.max_button, 1, 3)
- h.addWidget(QLabel(_('You receive')+':'), 2, 0)
+ h.addWidget(self.max_button, 1, 2)
+ h.addWidget(self.toggle_button, 1, 3)
+ h.addWidget(self.recv_label, 2, 0)
h.addWidget(self.recv_amount_e, 2, 1)
- h.addWidget(self.recv_button, 2, 2)
h.addWidget(QLabel(_('Server fee')+':'), 4, 0)
- h.addWidget(self.server_fee_label, 4, 1)
+ h.addWidget(self.server_fee_label, 4, 1, 1, 2)
h.addWidget(QLabel(_('Mining fee')+':'), 5, 0)
- h.addWidget(self.fee_label, 5, 1)
+ h.addWidget(self.fee_label, 5, 1, 1, 2)
h.addWidget(fee_slider, 6, 1)
h.addWidget(fee_combo, 6, 2)
vbox.addLayout(h)
@@ -180,11 +179,12 @@ class SwapDialog(WindowModalDialog):
self.update_ok_button()
def update(self):
+ from .util import IconLabel
sm = self.swap_manager
- self.send_button.setIcon(read_QIcon("lightning.png" if self.is_reverse else "bitcoin.png"))
- self.send_button.repaint() # macOS hack for #6269
- self.recv_button.setIcon(read_QIcon("lightning.png" if not self.is_reverse else "bitcoin.png"))
- self.recv_button.repaint() # macOS hack for #6269
+ send_icon = read_QIcon("lightning.png" if self.is_reverse else "bitcoin.png")
+ self.send_label.setIcon(send_icon)
+ recv_icon = read_QIcon("lightning.png" if not self.is_reverse else "bitcoin.png")
+ self.recv_label.setIcon(recv_icon)
self.description_label.setText(self.get_description())
self.description_label.repaint() # macOS hack for #6269
server_mining_fee = sm.lockup_fee if self.is_reverse else sm.normal_fee
@@ -284,7 +284,7 @@ class SwapDialog(WindowModalDialog):
onchain_funds = "onchain funds"
lightning_funds = "lightning funds"
- return "Swap {fromType} for {toType} if you need to increase your {capacityType} capacity. This service is powered by the Boltz backend.".format(
+ return "Swap {fromType} for {toType}. This will increase your {capacityType} capacity. This service is powered by the Boltz backend.".format(
fromType=lightning_funds if self.is_reverse else onchain_funds,
toType=onchain_funds if self.is_reverse else lightning_funds,
capacityType="receiving" if self.is_reverse else "sending",
diff --git a/electrum/gui/qt/util.py b/electrum/gui/qt/util.py
@@ -1042,6 +1042,26 @@ def icon_path(icon_basename):
def read_QIcon(icon_basename):
return QIcon(icon_path(icon_basename))
+class IconLabel(QWidget):
+ IconSize = QSize(16, 16)
+ HorizontalSpacing = 2
+ def __init__(self, *, text='', final_stretch=True):
+ super(QWidget, self).__init__()
+ layout = QHBoxLayout()
+ layout.setContentsMargins(0, 0, 0, 0)
+ self.setLayout(layout)
+ self.icon = QLabel()
+ self.label = QLabel(text)
+ layout.addWidget(self.label)
+ layout.addSpacing(self.HorizontalSpacing)
+ layout.addWidget(self.icon)
+ if final_stretch:
+ layout.addStretch()
+ def setText(self, text):
+ self.label.setText(text)
+ def setIcon(self, icon):
+ self.icon.setPixmap(icon.pixmap(self.IconSize))
+ self.icon.repaint() # macOS hack for #6269
def get_default_language():
name = QLocale.system().name()