Browse Source

Merge branch 'Tafelpoot-contacts'

283
ThomasV 10 years ago
parent
commit
7cb02f5d2a
  1. 72
      gui/qt/main_window.py
  2. 2
      lib/wallet.py

72
gui/qt/main_window.py

@ -628,6 +628,13 @@ class ElectrumWindow(QMainWindow):
run_hook('current_item_changed', a) run_hook('current_item_changed', a)
def format_time(self, timestamp):
try:
time_str = datetime.datetime.fromtimestamp( timestamp).isoformat(' ')[:-3]
except Exception:
time_str = _("error")
return time_str
def update_history_tab(self): def update_history_tab(self):
@ -636,11 +643,7 @@ class ElectrumWindow(QMainWindow):
tx_hash, conf, is_mine, value, fee, balance, timestamp = item tx_hash, conf, is_mine, value, fee, balance, timestamp = item
time_str = _("unknown") time_str = _("unknown")
if conf > 0: if conf > 0:
try: time_str = self.format_time(timestamp)
time_str = datetime.datetime.fromtimestamp( timestamp).isoformat(' ')[:-3]
except Exception:
time_str = _("error")
if conf == -1: if conf == -1:
time_str = 'unverified' time_str = 'unverified'
icon = QIcon(":icons/unconfirmed.png") icon = QIcon(":icons/unconfirmed.png")
@ -715,6 +718,7 @@ class ElectrumWindow(QMainWindow):
self.save_request_button = QPushButton(_('Save')) self.save_request_button = QPushButton(_('Save'))
self.save_request_button.clicked.connect(self.save_payment_request) self.save_request_button.clicked.connect(self.save_payment_request)
grid.addWidget(self.save_request_button, 3, 1) grid.addWidget(self.save_request_button, 3, 1)
clear_button = QPushButton(_('New')) clear_button = QPushButton(_('New'))
clear_button.clicked.connect(self.new_receive_address) clear_button.clicked.connect(self.new_receive_address)
grid.addWidget(clear_button, 3, 2) grid.addWidget(clear_button, 3, 2)
@ -731,12 +735,14 @@ class ElectrumWindow(QMainWindow):
self.receive_list.customContextMenuRequested.connect(self.receive_list_menu) self.receive_list.customContextMenuRequested.connect(self.receive_list_menu)
self.receive_list.currentItemChanged.connect(self.receive_item_changed) self.receive_list.currentItemChanged.connect(self.receive_item_changed)
self.receive_list.itemClicked.connect(self.receive_item_changed) self.receive_list.itemClicked.connect(self.receive_item_changed)
self.receive_list.setHeaderLabels( [_('Address'), _('Message'), _('Amount')] ) self.receive_list.setHeaderLabels( [_('Date'), _('Account'), _('Address'), _('Message'), _('Amount')] )
self.receive_list.setColumnWidth(0, 340) self.receive_list.setSortingEnabled(True)
self.receive_list.setColumnWidth(0, 180)
self.receive_list.hideColumn(1) # the update will show it if necessary
self.receive_list.setColumnWidth(2, 340)
h = self.receive_list.header() h = self.receive_list.header()
h.setStretchLastSection(False) h.setStretchLastSection(False)
h.setResizeMode(1, QHeaderView.Stretch) h.setResizeMode(3, QHeaderView.Stretch)
grid.addWidget(self.receive_requests_label, 6, 0) grid.addWidget(self.receive_requests_label, 6, 0)
grid.addWidget(self.receive_list, 7, 0, 1, 6) grid.addWidget(self.receive_list, 7, 0, 1, 6)
return w return w
@ -744,37 +750,39 @@ class ElectrumWindow(QMainWindow):
def receive_item_changed(self, item): def receive_item_changed(self, item):
if item is None: if item is None:
return return
addr = str(item.text(0)) addr = str(item.text(2))
amount, message = self.receive_requests[addr] req = self.receive_requests[addr]
time, amount, message = req['time'], req['amount'], req['msg']
self.receive_address_e.setText(addr) self.receive_address_e.setText(addr)
self.receive_message_e.setText(message) self.receive_message_e.setText(message)
self.receive_amount_e.setAmount(amount) self.receive_amount_e.setAmount(amount)
def receive_list_delete(self, item): def receive_list_delete(self, item):
addr = str(item.text(0)) addr = str(item.text(2))
self.receive_requests.pop(addr) self.receive_requests.pop(addr)
self.wallet.storage.put('receive_requests', self.receive_requests) self.wallet.storage.put('receive_requests2', self.receive_requests)
self.update_receive_tab() self.update_receive_tab()
self.clear_receive_tab() self.clear_receive_tab()
def receive_list_menu(self, position): def receive_list_menu(self, position):
item = self.receive_list.itemAt(position) item = self.receive_list.itemAt(position)
menu = QMenu() menu = QMenu()
menu.addAction(_("Copy to clipboard"), lambda: self.app.clipboard().setText(str(item.text(0)))) menu.addAction(_("Copy to clipboard"), lambda: self.app.clipboard().setText(str(item.text(2))))
menu.addAction(_("Delete"), lambda: self.receive_list_delete(item)) menu.addAction(_("Delete"), lambda: self.receive_list_delete(item))
menu.exec_(self.receive_list.viewport().mapToGlobal(position)) menu.exec_(self.receive_list.viewport().mapToGlobal(position))
def save_payment_request(self): def save_payment_request(self):
timestamp = int(time.time())
addr = str(self.receive_address_e.text()) addr = str(self.receive_address_e.text())
amount = self.receive_amount_e.get_amount() amount = self.receive_amount_e.get_amount()
message = unicode(self.receive_message_e.text()) message = unicode(self.receive_message_e.text())
if not message and not amount: if not message and not amount:
QMessageBox.warning(self, _('Error'), _('No message or amount'), _('OK')) QMessageBox.warning(self, _('Error'), _('No message or amount'), _('OK'))
return return
self.receive_requests = self.wallet.storage.get('receive_requests',{}) self.receive_requests = self.wallet.storage.get('receive_requests2',{})
self.receive_requests[addr] = (amount, message) self.receive_requests[addr] = {'time':timestamp, 'amount':amount, 'msg':message}
self.wallet.storage.put('receive_requests', self.receive_requests) self.wallet.storage.put('receive_requests2', self.receive_requests)
self.update_receive_tab() self.update_receive_tab()
def new_receive_address(self): def new_receive_address(self):
@ -794,7 +802,7 @@ class ElectrumWindow(QMainWindow):
self.receive_amount_e.setAmount(None) self.receive_amount_e.setAmount(None)
def clear_receive_tab(self): def clear_receive_tab(self):
self.receive_requests = self.wallet.storage.get('receive_requests',{}) self.receive_requests = self.wallet.storage.get('receive_requests2',{})
domain = self.wallet.get_account_addresses(self.current_account, include_change=False) domain = self.wallet.get_account_addresses(self.current_account, include_change=False)
for addr in domain: for addr in domain:
if not self.wallet.history.get(addr) and addr not in self.receive_requests.keys(): if not self.wallet.history.get(addr) and addr not in self.receive_requests.keys():
@ -828,19 +836,37 @@ class ElectrumWindow(QMainWindow):
self.receive_address_e.setText(addr) self.receive_address_e.setText(addr)
def update_receive_tab(self): def update_receive_tab(self):
self.receive_requests = self.wallet.storage.get('receive_requests',{}) self.receive_requests = self.wallet.storage.get('receive_requests2',{})
# hide receive tab if no receive requests available
b = len(self.receive_requests) > 0 b = len(self.receive_requests) > 0
self.receive_list.setVisible(b) self.receive_list.setVisible(b)
self.receive_requests_label.setVisible(b) self.receive_requests_label.setVisible(b)
# check if it is necessary to show the account
self.receive_list.setColumnHidden(1, len(self.wallet.get_accounts()) == 1)
# update the receive address if necessary
current_address = self.receive_address_e.text()
domain = self.wallet.get_account_addresses(self.current_account, include_change=False)
if not current_address in domain:
self.new_receive_address()
# clear the list and fill it again
self.receive_list.clear() self.receive_list.clear()
for address, v in self.receive_requests.items(): for address, req in self.receive_requests.viewitems():
amount, message = v timestamp, amount, message = req['time'], req['amount'], req['msg']
item = QTreeWidgetItem( [ address, message, self.format_amount(amount) if amount else ""] ) # only show requests for the current account
item.setFont(0, QFont(MONOSPACE_FONT)) if address not in domain:
continue
date = self.format_time(timestamp)
account = self.wallet.get_account_name(self.wallet.get_account_from_address(address))
item = QTreeWidgetItem( [ date, account, address, message, self.format_amount(amount) if amount else ""])
item.setFont(2, QFont(MONOSPACE_FONT))
self.receive_list.addTopLevelItem(item) self.receive_list.addTopLevelItem(item)
def update_receive_qr(self): def update_receive_qr(self):
import urlparse, urllib import urlparse, urllib
addr = str(self.receive_address_e.text()) addr = str(self.receive_address_e.text())

2
lib/wallet.py

@ -486,7 +486,7 @@ class Abstract_Wallet(object):
"Returns the account that contains this address, or None" "Returns the account that contains this address, or None"
for acc_id in self.accounts: # similar to get_address_index but simpler for acc_id in self.accounts: # similar to get_address_index but simpler
if addr in self.get_account_addresses(acc_id): if addr in self.get_account_addresses(acc_id):
return self.accounts[acc_id] return acc_id
return None return None
def get_account_balance(self, account): def get_account_balance(self, account):

Loading…
Cancel
Save