diff --git a/gui/qt/main_window.py b/gui/qt/main_window.py
index 880b84f54..4bec1d354 100644
--- a/gui/qt/main_window.py
+++ b/gui/qt/main_window.py
@@ -791,6 +791,7 @@ class ElectrumWindow(QMainWindow):
else:
url = ""
self.receive_qr.setData(url)
+ run_hook('update_receive_qr', addr, amount, message, url)
def create_send_tab(self):
diff --git a/plugins/pointofsale.py b/plugins/pointofsale.py
index 27f4ccd14..47e12ef12 100644
--- a/plugins/pointofsale.py
+++ b/plugins/pointofsale.py
@@ -25,9 +25,9 @@ column_index = 4
class QR_Window(QWidget):
- def __init__(self, exchanger):
+ def __init__(self, win):
QWidget.__init__(self)
- self.exchanger = exchanger
+ self.win = win
self.setWindowTitle('Electrum - '+_('Invoice'))
self.setMinimumSize(800, 250)
self.address = ''
@@ -57,46 +57,18 @@ class QR_Window(QWidget):
self.setLayout(main_box)
- def set_content(self, addr, label, amount, currency):
- self.address = addr
- address_text = "%s" % addr if addr else ""
+ def set_content(self, address, amount, message, url):
+ address_text = "%s" % address if address else ""
self.address_label.setText(address_text)
-
- if currency == 'BTC': currency = None
- amount_text = ''
if amount:
- if currency:
- try:
- self.amount = Decimal(amount) / self.exchanger.exchange(1, currency) if currency else amount
- except Exception:
- self.amount = None
- else:
- self.amount = Decimal(amount)
- self.amount = self.amount.quantize(Decimal('1.0000'))
-
- if currency:
- amount_text += "%s %s
" % (amount, currency)
- amount_text += "%s BTC " % str(self.amount)
+ amount = self.win.format_amount(amount)
+ amount_text = "%s %s " % (amount, self.win.base_unit())
else:
- self.amount = None
-
+ amount_text = ''
self.amount_label.setText(amount_text)
-
- self.label = label
- label_text = "%s" % label if label else ""
+ label_text = "%s" % message if message else ""
self.label_label.setText(label_text)
-
- msg = 'bitcoin:'+self.address
- if self.amount is not None:
- msg += '?amount=%s'%(str( self.amount))
- if self.label is not None:
- encoded_label = quote(self.label)
- msg += '&label=%s'%(encoded_label)
- elif self.label is not None:
- encoded_label = quote(self.label)
- msg += '?label=%s'%(encoded_label)
-
- self.qrw.set_addr( msg )
+ self.qrw.setData(url)
@@ -106,64 +78,36 @@ class Plugin(BasePlugin):
def fullname(self):
return 'Point of Sale'
+
def description(self):
- return _('Show QR code window and amounts requested for each address. Add menu item to request amount.')+_(' Note: This requires the exchange rate plugin to be installed.')
+ return _('Show payment requests in a large, separate window.')
+
def init(self):
self.window = self.gui.main_window
- self.wallet = self.window.wallet
-
self.qr_window = None
- self.merchant_name = self.config.get('merchant_name', 'Invoice')
-
- self.window.expert_mode = True
- self.window.receive_list.setColumnCount(5)
- self.window.receive_list.setHeaderLabels([ _('Address'), _('Label'), _('Balance'), _('Tx'), _('Request')])
- self.requested_amounts = {}
self.toggle_QR_window(True)
- def enable(self):
- if not self.config.get('use_exchange_rate'):
- self.gui.main_window.show_message("Please enable exchange rates first!")
- return False
-
- return BasePlugin.enable(self)
-
-
- def load_wallet(self, wallet):
- self.wallet = wallet
- self.requested_amounts = self.wallet.storage.get('requested_amounts',{})
def close(self):
- self.window.receive_list.setHeaderLabels([ _('Address'), _('Label'), _('Balance'), _('Tx')])
- self.window.receive_list.setColumnCount(4)
- for i,width in enumerate(self.window.column_widths['receive']):
- self.window.receive_list.setColumnWidth(i, width)
self.toggle_QR_window(False)
-
+
def close_main_window(self):
if self.qr_window:
self.qr_window.close()
self.qr_window = None
-
- def timer_actions(self):
- if self.qr_window:
- self.qr_window.qrw.update_qr()
+ def update_receive_qr(self, address, amount, message, url):
+ self.qr_window.set_content( address, amount, message, url )
+
def toggle_QR_window(self, show):
if show and not self.qr_window:
- self.qr_window = QR_Window(self.gui.exchanger)
+ self.qr_window = QR_Window(self.gui.main_window)
self.qr_window.setVisible(True)
self.qr_window_geometry = self.qr_window.geometry()
- item = self.window.receive_list.currentItem()
- if item:
- address = str(item.text(1))
- label = self.wallet.labels.get(address)
- amount, currency = self.requested_amounts.get(address, (None, None))
- self.qr_window.set_content( address, label, amount, currency )
elif show and self.qr_window and not self.qr_window.isVisible():
self.qr_window.setVisible(True)
@@ -174,88 +118,5 @@ class Plugin(BasePlugin):
self.qr_window.setVisible(False)
-
- def update_receive_item(self, address, item):
- try:
- amount, currency = self.requested_amounts.get(address, (None, None))
- except Exception:
- print "cannot get requested amount", address, self.requested_amounts.get(address)
- amount, currency = None, None
- self.requested_amounts.pop(address)
-
- amount_str = amount + (' ' + currency if currency else '') if amount is not None else ''
- item.setData(column_index,0,amount_str)
-
-
-
- def current_item_changed(self, a):
- if not self.wallet:
- return
- if a is not None and self.qr_window and self.qr_window.isVisible():
- address = str(a.text(0))
- label = self.wallet.labels.get(address)
- try:
- amount, currency = self.requested_amounts.get(address, (None, None))
- except Exception:
- amount, currency = None, None
- self.qr_window.set_content( address, label, amount, currency )
-
-
-
- def item_changed(self, item, column):
- if column != column_index:
- return
- address = str( item.text(0) )
- text = str( item.text(column) )
- try:
- seq = self.wallet.get_address_index(address)
- index = seq[1][1]
- except Exception:
- print "cannot get index"
- return
-
- text = text.strip().upper()
- #print text
- m = re.match('^(\d*(|\.\d*))\s*(|BTC|EUR|USD|GBP|CNY|JPY|RUB|BRL)$', text)
- if m and m.group(1) and m.group(1)!='.':
- amount = m.group(1)
- currency = m.group(3)
- if not currency:
- currency = 'BTC'
- else:
- currency = currency.upper()
-
- self.requested_amounts[address] = (amount, currency)
- self.wallet.storage.put('requested_amounts', self.requested_amounts, True)
-
- label = self.wallet.labels.get(address)
- if label is None:
- label = self.merchant_name + ' - %04d'%(index+1)
- self.wallet.labels[address] = label
-
- if self.qr_window:
- self.qr_window.set_content( address, label, amount, currency )
-
- else:
- item.setText(column,'')
- if address in self.requested_amounts:
- self.requested_amounts.pop(address)
-
- self.window.update_receive_item(self.window.receive_list.currentItem())
-
-
-
-
- def edit_amount(self):
- l = self.window.receive_list
- item = l.currentItem()
- item.setFlags(Qt.ItemIsEditable|Qt.ItemIsSelectable | Qt.ItemIsUserCheckable | Qt.ItemIsEnabled | Qt.ItemIsDragEnabled)
- l.editItem( item, column_index )
- item.setFlags(Qt.ItemIsSelectable | Qt.ItemIsUserCheckable | Qt.ItemIsEnabled | Qt.ItemIsDragEnabled)
-
-
- def receive_menu(self, menu, addr):
- menu.addAction(_("Request amount"), self.edit_amount)
- menu.addAction(_("Show Invoice"), lambda: self.toggle_QR_window(True))