mirror of
https://github.com/LBRYFoundation/LBRY-Vault.git
synced 2025-08-23 17:47:31 +00:00
qt receive tab: show plain bitcoin address
This commit is contained in:
parent
20bbe85bce
commit
d2a8028cde
4 changed files with 57 additions and 38 deletions
|
@ -227,7 +227,7 @@ class AddressList(MyTreeView):
|
|||
menu.addAction(_('Details'), lambda: self.parent.show_address(addr))
|
||||
persistent = QPersistentModelIndex(addr_idx)
|
||||
menu.addAction(_("Edit {}").format(addr_column_title), lambda p=persistent: self.edit(QModelIndex(p)))
|
||||
menu.addAction(_("Request payment"), lambda: self.parent.receive_at(addr))
|
||||
#menu.addAction(_("Request payment"), lambda: self.parent.receive_at(addr))
|
||||
if self.wallet.can_export():
|
||||
menu.addAction(_("Private key"), lambda: self.parent.show_private_key(addr))
|
||||
if not is_multisig and not self.wallet.is_watching_only():
|
||||
|
|
|
@ -38,7 +38,7 @@ import queue
|
|||
import asyncio
|
||||
from typing import Optional, TYPE_CHECKING, Sequence, List, Union
|
||||
|
||||
from PyQt5.QtGui import QPixmap, QKeySequence, QIcon, QCursor
|
||||
from PyQt5.QtGui import QPixmap, QKeySequence, QIcon, QCursor, QFont
|
||||
from PyQt5.QtCore import Qt, QRect, QStringListModel, QSize, pyqtSignal
|
||||
from PyQt5.QtWidgets import (QMessageBox, QComboBox, QSystemTrayIcon, QTabWidget,
|
||||
QMenuBar, QFileDialog, QCheckBox, QLabel,
|
||||
|
@ -88,7 +88,7 @@ from .util import (read_QIcon, ColorScheme, text_dialog, icon_path, WaitingDialo
|
|||
CloseButton, HelpButton, MessageBoxMixin, EnterButton,
|
||||
import_meta_gui, export_meta_gui,
|
||||
filename_field, address_field, char_width_in_lineedit, webopen,
|
||||
TRANSACTION_FILE_EXTENSION_FILTER)
|
||||
TRANSACTION_FILE_EXTENSION_FILTER, MONOSPACE_FONT)
|
||||
from .util import ButtonsTextEdit
|
||||
from .installwizard import WIF_HELP_TEXT
|
||||
from .history_list import HistoryList, HistoryModel
|
||||
|
@ -1002,18 +1002,36 @@ class ElectrumWindow(QMainWindow, MessageBoxMixin, Logger):
|
|||
buttons.addWidget(self.create_lightning_invoice_button)
|
||||
grid.addLayout(buttons, 4, 3, 1, 2)
|
||||
|
||||
self.receive_address_e = ButtonsTextEdit()
|
||||
self.receive_address_e.addCopyButton(self.app)
|
||||
self.receive_address_e.setReadOnly(True)
|
||||
self.receive_address_e.textChanged.connect(self.update_receive_qr)
|
||||
self.receive_address_e.textChanged.connect(self.update_receive_address_styling)
|
||||
self.receive_address_e.setFocusPolicy(Qt.ClickFocus)
|
||||
self.receive_payreq_e = ButtonsTextEdit()
|
||||
self.receive_payreq_e.addCopyButton(self.app)
|
||||
self.receive_payreq_e.setReadOnly(True)
|
||||
self.receive_payreq_e.textChanged.connect(self.update_receive_qr)
|
||||
self.receive_payreq_e.setFocusPolicy(Qt.ClickFocus)
|
||||
|
||||
self.receive_qr = QRCodeWidget(fixedSize=230)
|
||||
self.receive_qr = QRCodeWidget(fixedSize=220)
|
||||
self.receive_qr.mouseReleaseEvent = lambda x: self.toggle_qr_window()
|
||||
self.receive_qr.enterEvent = lambda x: self.app.setOverrideCursor(QCursor(Qt.PointingHandCursor))
|
||||
self.receive_qr.leaveEvent = lambda x: self.app.setOverrideCursor(QCursor(Qt.ArrowCursor))
|
||||
|
||||
def on_receive_address_changed():
|
||||
addr = str(self.receive_address_e.text())
|
||||
self.receive_address_widgets.setVisible(bool(addr))
|
||||
|
||||
msg = _('Bitcoin address where the payment should be received. Note that each payment request uses a different Bitcoin address.')
|
||||
receive_address_label = HelpLabel(_('Receiving address'), msg)
|
||||
|
||||
self.receive_address_e = ButtonsTextEdit()
|
||||
self.receive_address_e.setFont(QFont(MONOSPACE_FONT))
|
||||
self.receive_address_e.addCopyButton(self.app)
|
||||
self.receive_address_e.setReadOnly(True)
|
||||
self.receive_address_e.textChanged.connect(on_receive_address_changed)
|
||||
self.receive_address_e.textChanged.connect(self.update_receive_address_styling)
|
||||
self.receive_address_e.setMinimumHeight(6 * char_width_in_lineedit())
|
||||
self.receive_address_e.setMaximumHeight(10 * char_width_in_lineedit())
|
||||
qr_show = lambda: self.show_qrcode(str(self.receive_address_e.text()), _('Receiving address'), parent=self)
|
||||
qr_icon = "qrcode_white.png" if ColorScheme.dark_scheme else "qrcode.png"
|
||||
self.receive_address_e.addButton(qr_icon, qr_show, _("Show as QR code"))
|
||||
|
||||
self.receive_requests_label = QLabel(_('Incoming payments'))
|
||||
|
||||
from .request_list import RequestList
|
||||
|
@ -1024,14 +1042,29 @@ class ElectrumWindow(QMainWindow, MessageBoxMixin, Logger):
|
|||
vbox_g.addLayout(grid)
|
||||
vbox_g.addStretch()
|
||||
|
||||
self.receive_widgets = QTabWidget()
|
||||
self.receive_widgets.addTab(self.receive_qr, 'QR Code')
|
||||
self.receive_widgets.addTab(self.receive_address_e, 'Text')
|
||||
receive_tabbed_widgets = QTabWidget()
|
||||
receive_tabbed_widgets.addTab(self.receive_qr, 'QR Code')
|
||||
receive_tabbed_widgets.addTab(self.receive_payreq_e, 'Text')
|
||||
|
||||
vbox_receive_address = QVBoxLayout()
|
||||
vbox_receive_address.setContentsMargins(0, 0, 0, 0)
|
||||
vbox_receive_address.setSpacing(0)
|
||||
vbox_receive_address.addWidget(receive_address_label)
|
||||
vbox_receive_address.addWidget(self.receive_address_e)
|
||||
self.receive_address_widgets = QWidget()
|
||||
self.receive_address_widgets.setLayout(vbox_receive_address)
|
||||
size_policy = self.receive_address_widgets.sizePolicy()
|
||||
size_policy.setRetainSizeWhenHidden(True)
|
||||
self.receive_address_widgets.setSizePolicy(size_policy)
|
||||
|
||||
vbox_receive = QVBoxLayout()
|
||||
vbox_receive.addWidget(receive_tabbed_widgets)
|
||||
vbox_receive.addWidget(self.receive_address_widgets)
|
||||
|
||||
hbox = QHBoxLayout()
|
||||
hbox.addLayout(vbox_g)
|
||||
hbox.addStretch()
|
||||
hbox.addWidget(self.receive_widgets)
|
||||
hbox.addLayout(vbox_receive)
|
||||
|
||||
w = QWidget()
|
||||
w.searchable_list = self.request_list
|
||||
|
@ -1043,6 +1076,8 @@ class ElectrumWindow(QMainWindow, MessageBoxMixin, Logger):
|
|||
vbox.addWidget(self.request_list)
|
||||
vbox.setStretchFactor(self.request_list, 1000)
|
||||
|
||||
on_receive_address_changed()
|
||||
|
||||
return w
|
||||
|
||||
def delete_request(self, key):
|
||||
|
@ -1136,6 +1171,7 @@ class ElectrumWindow(QMainWindow, MessageBoxMixin, Logger):
|
|||
self.saved = True
|
||||
|
||||
def clear_receive_tab(self):
|
||||
self.receive_payreq_e.setText('')
|
||||
self.receive_address_e.setText('')
|
||||
self.receive_message_e.setText('')
|
||||
self.receive_amount_e.setAmount(None)
|
||||
|
@ -1163,14 +1199,8 @@ class ElectrumWindow(QMainWindow, MessageBoxMixin, Logger):
|
|||
def show_receive_tab(self):
|
||||
self.tabs.setCurrentIndex(self.tabs.indexOf(self.receive_tab))
|
||||
|
||||
def receive_at(self, addr):
|
||||
if not bitcoin.is_address(addr):
|
||||
return
|
||||
self.show_receive_tab()
|
||||
self.receive_address_e.setText(addr)
|
||||
|
||||
def update_receive_qr(self):
|
||||
uri = str(self.receive_address_e.text())
|
||||
uri = str(self.receive_payreq_e.text())
|
||||
if maybe_extract_bolt11_invoice(uri):
|
||||
# encode lightning invoices as uppercase so QR encoding can use
|
||||
# alphanumeric mode; resulting in smaller QR codes
|
||||
|
@ -1181,13 +1211,6 @@ class ElectrumWindow(QMainWindow, MessageBoxMixin, Logger):
|
|||
|
||||
def update_receive_address_styling(self):
|
||||
addr = str(self.receive_address_e.text())
|
||||
# note: 'addr' could be ln invoice or BIP21 URI
|
||||
try:
|
||||
uri = util.parse_URI(addr)
|
||||
except InvalidBitcoinURI:
|
||||
pass
|
||||
else:
|
||||
addr = uri.get('address')
|
||||
if is_address(addr) and self.wallet.is_used(addr):
|
||||
self.receive_address_e.setStyleSheet(ColorScheme.RED.as_stylesheet(True))
|
||||
self.receive_address_e.setToolTip(_("This address has already been used. "
|
||||
|
|
|
@ -83,9 +83,12 @@ class RequestList(MyTreeView):
|
|||
if req is None:
|
||||
self.update()
|
||||
return
|
||||
is_lightning = request_type == PR_TYPE_LN
|
||||
text = req.get('invoice') if is_lightning else req.get('URI')
|
||||
self.parent.receive_address_e.setText(text)
|
||||
if request_type == PR_TYPE_LN:
|
||||
self.parent.receive_payreq_e.setText(req.get('invoice'))
|
||||
self.parent.receive_address_e.setText('')
|
||||
else:
|
||||
self.parent.receive_payreq_e.setText(req.get('URI'))
|
||||
self.parent.receive_address_e.setText(req['address'])
|
||||
|
||||
def refresh_status(self):
|
||||
m = self.model()
|
||||
|
|
|
@ -263,13 +263,6 @@ class QtPluginBase(object):
|
|||
|
||||
def show_address():
|
||||
addr = str(receive_address_e.text())
|
||||
# note: 'addr' could be ln invoice or BIP21 URI
|
||||
try:
|
||||
uri = parse_URI(addr)
|
||||
except InvalidBitcoinURI:
|
||||
pass
|
||||
else:
|
||||
addr = uri.get('address')
|
||||
keystore.thread.add(partial(plugin.show_address, wallet, addr, keystore))
|
||||
dev_name = f"{plugin.device} ({keystore.label})"
|
||||
receive_address_e.addButton("eye1.png", show_address, _("Show on {}").format(dev_name))
|
||||
|
|
Loading…
Add table
Reference in a new issue