qr qrtextedit: move functionality up to ButtonsWidget
This commit is contained in:
@@ -1,95 +1,21 @@
|
|||||||
from functools import partial
|
|
||||||
from typing import Callable
|
|
||||||
|
|
||||||
from electrum.i18n import _
|
from electrum.i18n import _
|
||||||
from electrum.plugin import run_hook
|
from electrum.plugin import run_hook
|
||||||
from electrum.simple_config import SimpleConfig
|
from electrum.simple_config import SimpleConfig
|
||||||
|
|
||||||
from .util import ButtonsTextEdit, MessageBoxMixin, ColorScheme, getOpenFileName
|
from .util import ButtonsTextEdit, MessageBoxMixin
|
||||||
from .qrreader import scan_qrcode
|
|
||||||
|
|
||||||
|
|
||||||
def qr_show(text_edit, *, config: SimpleConfig) -> None:
|
|
||||||
from .qrcodewidget import QRDialog
|
|
||||||
try:
|
|
||||||
s = str(text_edit.text())
|
|
||||||
except:
|
|
||||||
s = text_edit.text()
|
|
||||||
if not s:
|
|
||||||
return
|
|
||||||
QRDialog(
|
|
||||||
data=s,
|
|
||||||
parent=text_edit,
|
|
||||||
config=config,
|
|
||||||
).exec_()
|
|
||||||
|
|
||||||
|
|
||||||
def qr_input(
|
|
||||||
text_edit,
|
|
||||||
*,
|
|
||||||
config: SimpleConfig,
|
|
||||||
allow_multi: bool = False,
|
|
||||||
show_error: Callable[[str], None],
|
|
||||||
) -> None:
|
|
||||||
def cb(success: bool, error: str, data):
|
|
||||||
if not success:
|
|
||||||
if error:
|
|
||||||
show_error(error)
|
|
||||||
return
|
|
||||||
if not data:
|
|
||||||
data = ''
|
|
||||||
if allow_multi:
|
|
||||||
new_text = text_edit.text() + data + '\n'
|
|
||||||
else:
|
|
||||||
new_text = data
|
|
||||||
text_edit.setText(new_text)
|
|
||||||
|
|
||||||
scan_qrcode(parent=text_edit, config=config, callback=cb)
|
|
||||||
|
|
||||||
|
|
||||||
def file_input(
|
|
||||||
text_edit,
|
|
||||||
*,
|
|
||||||
config: SimpleConfig,
|
|
||||||
show_error: Callable[[str], None],
|
|
||||||
) -> None:
|
|
||||||
fileName = getOpenFileName(
|
|
||||||
parent=text_edit,
|
|
||||||
title='select file',
|
|
||||||
config=config,
|
|
||||||
)
|
|
||||||
if not fileName:
|
|
||||||
return
|
|
||||||
try:
|
|
||||||
try:
|
|
||||||
with open(fileName, "r") as f:
|
|
||||||
data = f.read()
|
|
||||||
except UnicodeError as e:
|
|
||||||
with open(fileName, "rb") as f:
|
|
||||||
data = f.read()
|
|
||||||
data = data.hex()
|
|
||||||
except BaseException as e:
|
|
||||||
show_error(_('Error opening file') + ':\n' + repr(e))
|
|
||||||
else:
|
|
||||||
text_edit.setText(data)
|
|
||||||
|
|
||||||
|
|
||||||
class ShowQRTextEdit(ButtonsTextEdit):
|
class ShowQRTextEdit(ButtonsTextEdit):
|
||||||
|
|
||||||
def __init__(self, text=None, *, config: SimpleConfig):
|
def __init__(self, text=None, *, config: SimpleConfig):
|
||||||
ButtonsTextEdit.__init__(self, text)
|
ButtonsTextEdit.__init__(self, text)
|
||||||
self.config = config
|
|
||||||
self.setReadOnly(True)
|
self.setReadOnly(True)
|
||||||
# qr_show
|
self.add_qr_show_button(config=config)
|
||||||
self.qr_show = partial(qr_show, self, config=config)
|
|
||||||
icon = "qrcode_white.png" if ColorScheme.dark_scheme else "qrcode.png"
|
|
||||||
self.addButton(icon, self.qr_show, _("Show as QR code"))
|
|
||||||
|
|
||||||
run_hook('show_text_edit', self)
|
run_hook('show_text_edit', self)
|
||||||
|
|
||||||
def contextMenuEvent(self, e):
|
def contextMenuEvent(self, e):
|
||||||
m = self.createStandardContextMenu()
|
m = self.createStandardContextMenu()
|
||||||
m.addAction(_("Show as QR code"), self.qr_show)
|
m.addAction(_("Show as QR code"), self.on_qr_show_btn)
|
||||||
m.exec_(e.globalPos())
|
m.exec_(e.globalPos())
|
||||||
|
|
||||||
|
|
||||||
@@ -97,21 +23,14 @@ class ScanQRTextEdit(ButtonsTextEdit, MessageBoxMixin):
|
|||||||
|
|
||||||
def __init__(self, text="", allow_multi: bool = False, *, config: SimpleConfig):
|
def __init__(self, text="", allow_multi: bool = False, *, config: SimpleConfig):
|
||||||
ButtonsTextEdit.__init__(self, text)
|
ButtonsTextEdit.__init__(self, text)
|
||||||
self.config = config
|
|
||||||
self.setReadOnly(False)
|
self.setReadOnly(False)
|
||||||
# file_input
|
self.add_file_input_button(config=config, show_error=self.show_error)
|
||||||
self.file_input = partial(file_input, self, config=config, show_error=self.show_error)
|
self.add_qr_input_button(config=config, show_error=self.show_error, allow_multi=allow_multi)
|
||||||
self.addButton("file.png", self.file_input, _("Read file"))
|
|
||||||
# qr_input
|
|
||||||
self.qr_input = partial(qr_input, self, config=config, show_error=self.show_error, allow_multi=allow_multi)
|
|
||||||
icon = "camera_white.png" if ColorScheme.dark_scheme else "camera_dark.png"
|
|
||||||
self.addButton(icon, self.qr_input, _("Read QR code"))
|
|
||||||
|
|
||||||
run_hook('scan_text_edit', self)
|
run_hook('scan_text_edit', self)
|
||||||
|
|
||||||
def contextMenuEvent(self, e):
|
def contextMenuEvent(self, e):
|
||||||
m = self.createStandardContextMenu()
|
m = self.createStandardContextMenu()
|
||||||
m.addAction(_("Read QR code"), self.qr_input)
|
m.addAction(_("Read QR code"), self.on_qr_input_btn)
|
||||||
m.exec_(e.globalPos())
|
m.exec_(e.globalPos())
|
||||||
|
|
||||||
|
|
||||||
@@ -119,22 +38,14 @@ class ScanShowQRTextEdit(ButtonsTextEdit, MessageBoxMixin):
|
|||||||
|
|
||||||
def __init__(self, text="", allow_multi: bool = False, *, config: SimpleConfig):
|
def __init__(self, text="", allow_multi: bool = False, *, config: SimpleConfig):
|
||||||
ButtonsTextEdit.__init__(self, text)
|
ButtonsTextEdit.__init__(self, text)
|
||||||
self.config = config
|
|
||||||
self.setReadOnly(False)
|
self.setReadOnly(False)
|
||||||
# qr_input
|
self.add_qr_input_button(config=config, show_error=self.show_error, allow_multi=allow_multi)
|
||||||
self.qr_input = partial(qr_input, self, config=config, show_error=self.show_error, allow_multi=allow_multi)
|
self.add_qr_show_button(config=config)
|
||||||
icon = "camera_white.png" if ColorScheme.dark_scheme else "camera_dark.png"
|
|
||||||
self.addButton(icon, self.qr_input, _("Read QR code"))
|
|
||||||
# qr_show
|
|
||||||
self.qr_show = partial(qr_show, self, config=config)
|
|
||||||
icon = "qrcode_white.png" if ColorScheme.dark_scheme else "qrcode.png"
|
|
||||||
self.addButton(icon, self.qr_show, _("Show as QR code"))
|
|
||||||
|
|
||||||
run_hook('scan_text_edit', self)
|
run_hook('scan_text_edit', self)
|
||||||
run_hook('show_text_edit', self)
|
run_hook('show_text_edit', self)
|
||||||
|
|
||||||
def contextMenuEvent(self, e):
|
def contextMenuEvent(self, e):
|
||||||
m = self.createStandardContextMenu()
|
m = self.createStandardContextMenu()
|
||||||
m.addAction(_("Read QR code"), self.qr_input)
|
m.addAction(_("Read QR code"), self.on_qr_input_btn)
|
||||||
m.addAction(_("Show as QR code"), self.qr_show)
|
m.addAction(_("Show as QR code"), self.on_qr_show_btn)
|
||||||
m.exec_(e.globalPos())
|
m.exec_(e.globalPos())
|
||||||
|
|||||||
@@ -853,7 +853,7 @@ class ButtonsWidget(QWidget):
|
|||||||
self.buttons.append(button)
|
self.buttons.append(button)
|
||||||
return button
|
return button
|
||||||
|
|
||||||
def addCopyButton(self, app):
|
def addCopyButton(self, app: QApplication):
|
||||||
self.app = app
|
self.app = app
|
||||||
self.addButton("copy.png", self.on_copy, _("Copy to clipboard"))
|
self.addButton("copy.png", self.on_copy, _("Copy to clipboard"))
|
||||||
|
|
||||||
@@ -861,13 +861,91 @@ class ButtonsWidget(QWidget):
|
|||||||
self.app.clipboard().setText(self.text())
|
self.app.clipboard().setText(self.text())
|
||||||
QToolTip.showText(QCursor.pos(), _("Text copied to clipboard"), self)
|
QToolTip.showText(QCursor.pos(), _("Text copied to clipboard"), self)
|
||||||
|
|
||||||
def addPasteButton(self, app):
|
def addPasteButton(self, app: QApplication):
|
||||||
self.app = app
|
self.app = app
|
||||||
self.addButton("copy.png", self.on_paste, _("Paste from clipboard"))
|
self.addButton("copy.png", self.on_paste, _("Paste from clipboard"))
|
||||||
|
|
||||||
def on_paste(self):
|
def on_paste(self):
|
||||||
self.setText(self.app.clipboard().text())
|
self.setText(self.app.clipboard().text())
|
||||||
|
|
||||||
|
def add_qr_show_button(self, *, config: 'SimpleConfig'):
|
||||||
|
def qr_show():
|
||||||
|
from .qrcodewidget import QRDialog
|
||||||
|
try:
|
||||||
|
s = str(self.text())
|
||||||
|
except:
|
||||||
|
s = self.text()
|
||||||
|
if not s:
|
||||||
|
return
|
||||||
|
QRDialog(
|
||||||
|
data=s,
|
||||||
|
parent=self,
|
||||||
|
config=config,
|
||||||
|
).exec_()
|
||||||
|
|
||||||
|
icon = "qrcode_white.png" if ColorScheme.dark_scheme else "qrcode.png"
|
||||||
|
self.addButton(icon, qr_show, _("Show as QR code"))
|
||||||
|
# side-effect: we export this method:
|
||||||
|
self.on_qr_show_btn = qr_show
|
||||||
|
|
||||||
|
def add_qr_input_button(
|
||||||
|
self,
|
||||||
|
*,
|
||||||
|
config: 'SimpleConfig',
|
||||||
|
allow_multi: bool = False,
|
||||||
|
show_error: Callable[[str], None],
|
||||||
|
):
|
||||||
|
def qr_input():
|
||||||
|
def cb(success: bool, error: str, data):
|
||||||
|
if not success:
|
||||||
|
if error:
|
||||||
|
show_error(error)
|
||||||
|
return
|
||||||
|
if not data:
|
||||||
|
data = ''
|
||||||
|
if allow_multi:
|
||||||
|
new_text = self.text() + data + '\n'
|
||||||
|
else:
|
||||||
|
new_text = data
|
||||||
|
self.setText(new_text)
|
||||||
|
|
||||||
|
from .qrreader import scan_qrcode
|
||||||
|
scan_qrcode(parent=self, config=config, callback=cb)
|
||||||
|
|
||||||
|
icon = "camera_white.png" if ColorScheme.dark_scheme else "camera_dark.png"
|
||||||
|
self.addButton(icon, qr_input, _("Read QR code"))
|
||||||
|
# side-effect: we export this method:
|
||||||
|
self.on_qr_input_btn = qr_input
|
||||||
|
|
||||||
|
def add_file_input_button(
|
||||||
|
self,
|
||||||
|
*,
|
||||||
|
config: 'SimpleConfig',
|
||||||
|
show_error: Callable[[str], None],
|
||||||
|
) -> None:
|
||||||
|
def file_input():
|
||||||
|
fileName = getOpenFileName(
|
||||||
|
parent=self,
|
||||||
|
title='select file',
|
||||||
|
config=config,
|
||||||
|
)
|
||||||
|
if not fileName:
|
||||||
|
return
|
||||||
|
try:
|
||||||
|
try:
|
||||||
|
with open(fileName, "r") as f:
|
||||||
|
data = f.read()
|
||||||
|
except UnicodeError as e:
|
||||||
|
with open(fileName, "rb") as f:
|
||||||
|
data = f.read()
|
||||||
|
data = data.hex()
|
||||||
|
except BaseException as e:
|
||||||
|
show_error(_('Error opening file') + ':\n' + repr(e))
|
||||||
|
else:
|
||||||
|
self.setText(data)
|
||||||
|
|
||||||
|
self.addButton("file.png", file_input, _("Read file"))
|
||||||
|
|
||||||
|
|
||||||
class ButtonsLineEdit(QLineEdit, ButtonsWidget):
|
class ButtonsLineEdit(QLineEdit, ButtonsWidget):
|
||||||
def __init__(self, text=None):
|
def __init__(self, text=None):
|
||||||
|
|||||||
Reference in New Issue
Block a user