Browse Source

fix: always use UserRole to store the key

283
ThomasV 10 years ago
parent
commit
ff152141ae
  1. 2
      gui/qt/history_widget.py
  2. 20
      gui/qt/main_window.py
  3. 4
      gui/qt/util.py

2
gui/qt/history_widget.py

@ -94,7 +94,7 @@ class HistoryWidget(MyTreeWidget):
menu = QMenu() menu = QMenu()
menu.addAction(_("Copy ID to Clipboard"), lambda: self.parent.app.clipboard().setText(tx_hash)) menu.addAction(_("Copy ID to Clipboard"), lambda: self.parent.app.clipboard().setText(tx_hash))
menu.addAction(_("Details"), lambda: self.parent.show_transaction(self.wallet.transactions.get(tx_hash))) menu.addAction(_("Details"), lambda: self.parent.show_transaction(self.wallet.transactions.get(tx_hash)))
menu.addAction(_("Edit description"), lambda: self.edit_label(item, 2)) menu.addAction(_("Edit description"), lambda: self.edit_label(item))
menu.addAction(_("View on block explorer"), lambda: webbrowser.open(block_explorer + tx_hash)) menu.addAction(_("View on block explorer"), lambda: webbrowser.open(block_explorer + tx_hash))
menu.exec_(self.viewport().mapToGlobal(position)) menu.exec_(self.viewport().mapToGlobal(position))

20
gui/qt/main_window.py

@ -1240,7 +1240,7 @@ class ElectrumWindow(QMainWindow):
icon = QIcon(pr_icons.get(status)) icon = QIcon(pr_icons.get(status))
item.setIcon(4, icon) item.setIcon(4, icon)
item.setToolTip(4, pr_tooltips.get(status,'')) item.setToolTip(4, pr_tooltips.get(status,''))
item.setData(0, 32, key) item.setData(0, Qt.UserRole, key)
item.setFont(1, QFont(MONOSPACE_FONT)) item.setFont(1, QFont(MONOSPACE_FONT))
item.setFont(3, QFont(MONOSPACE_FONT)) item.setFont(3, QFont(MONOSPACE_FONT))
l.addTopLevelItem(item) l.addTopLevelItem(item)
@ -1289,8 +1289,8 @@ class ElectrumWindow(QMainWindow):
addrs = [unicode(item.text(0)) for item in selected] addrs = [unicode(item.text(0)) for item in selected]
if not multi_select: if not multi_select:
item = self.address_list.itemAt(position) item = self.address_list.itemAt(position)
if not item: return if not item:
return
addr = addrs[0] addr = addrs[0]
if not is_valid(addr): if not is_valid(addr):
k = str(item.data(0,32).toString()) k = str(item.data(0,32).toString())
@ -1304,7 +1304,7 @@ class ElectrumWindow(QMainWindow):
if not multi_select: if not multi_select:
menu.addAction(_("Copy to clipboard"), lambda: self.app.clipboard().setText(addr)) menu.addAction(_("Copy to clipboard"), lambda: self.app.clipboard().setText(addr))
menu.addAction(_("Request payment"), lambda: self.receive_at(addr)) menu.addAction(_("Request payment"), lambda: self.receive_at(addr))
menu.addAction(_("Edit label"), lambda: self.edit_label(True)) menu.addAction(_("Edit label"), lambda: self.address_list.edit_label(item))
menu.addAction(_('History'), lambda: self.show_address(addr)) menu.addAction(_('History'), lambda: self.show_address(addr))
menu.addAction(_('Public Keys'), lambda: self.show_public_keys(addr)) menu.addAction(_('Public Keys'), lambda: self.show_public_keys(addr))
if self.wallet.can_export(): if self.wallet.can_export():
@ -1380,7 +1380,7 @@ class ElectrumWindow(QMainWindow):
menu.addAction(_("Pay to"), lambda: self.payto(payto_addr)) menu.addAction(_("Pay to"), lambda: self.payto(payto_addr))
menu.addAction(_("QR code"), lambda: self.show_qrcode("bitcoin:" + addr, _("Address"))) menu.addAction(_("QR code"), lambda: self.show_qrcode("bitcoin:" + addr, _("Address")))
if is_editable: if is_editable:
menu.addAction(_("Edit label"), lambda: self.edit_label(False)) menu.addAction(_("Edit label"), lambda: self.contacts_list.edit_label(item))
menu.addAction(_("Delete"), lambda: self.delete_contact(addr)) menu.addAction(_("Delete"), lambda: self.delete_contact(addr))
run_hook('create_contact_menu', menu, item) run_hook('create_contact_menu', menu, item)
@ -1456,7 +1456,7 @@ class ElectrumWindow(QMainWindow):
account_item = QTreeWidgetItem( [ name, '', self.format_amount(c+u), ''] ) account_item = QTreeWidgetItem( [ name, '', self.format_amount(c+u), ''] )
l.addTopLevelItem(account_item) l.addTopLevelItem(account_item)
account_item.setExpanded(self.accounts_expanded.get(k, True)) account_item.setExpanded(self.accounts_expanded.get(k, True))
account_item.setData(0, Qt.UserRole+1, k) account_item.setData(0, Qt.UserRole, k)
else: else:
account_item = l account_item = l
sequences = [0,1] if account.has_change() else [0] sequences = [0,1] if account.has_change() else [0]
@ -1479,8 +1479,8 @@ class ElectrumWindow(QMainWindow):
balance = self.format_amount(c + u) balance = self.format_amount(c + u)
item = QTreeWidgetItem( [ address, label, balance, "%d"%num] ) item = QTreeWidgetItem( [ address, label, balance, "%d"%num] )
item.setFont(0, QFont(MONOSPACE_FONT)) item.setFont(0, QFont(MONOSPACE_FONT))
item.setData(0, Qt.UserRole, True) # label can be edited item.setData(0, Qt.UserRole, address)
item.setData(0, Qt.UserRole+1, address) item.setData(0, Qt.UserRole+1, True) # label can be edited
if address in self.wallet.frozen_addresses: if address in self.wallet.frozen_addresses:
item.setBackgroundColor(0, QColor('lightblue')) item.setBackgroundColor(0, QColor('lightblue'))
if self.wallet.is_beyond_limit(address, account, is_change): if self.wallet.is_beyond_limit(address, account, is_change):
@ -1506,10 +1506,8 @@ class ElectrumWindow(QMainWindow):
n = self.wallet.get_num_tx(address) n = self.wallet.get_num_tx(address)
item = QTreeWidgetItem( [ address, label, "%d"%n] ) item = QTreeWidgetItem( [ address, label, "%d"%n] )
item.setFont(0, QFont(MONOSPACE_FONT)) item.setFont(0, QFont(MONOSPACE_FONT))
# 32 = label can be edited (bool)
item.setData(0, Qt.UserRole, True)
# 33 = payto string
item.setData(0, Qt.UserRole+1, address) item.setData(0, Qt.UserRole+1, address)
item.setData(0, Qt.UserRole+1, True)
l.addTopLevelItem(item) l.addTopLevelItem(item)
if address == current_address: if address == current_address:
l.setCurrentItem(item) l.setCurrentItem(item)

4
gui/qt/util.py

@ -291,7 +291,9 @@ class MyTreeWidget(QTreeWidget):
break break
self.emit(SIGNAL('customContextMenuRequested(const QPoint&)'), QPoint(50, i*5 + j - 1)) self.emit(SIGNAL('customContextMenuRequested(const QPoint&)'), QPoint(50, i*5 + j - 1))
def edit_label(self, item, column): def edit_label(self, item, column=None):
if column is None:
column = self.edit_column
if column==self.edit_column and item.isSelected(): if column==self.edit_column and item.isSelected():
text = unicode(item.text(column)) text = unicode(item.text(column))
key = str(item.data(0, Qt.UserRole).toString()) key = str(item.data(0, Qt.UserRole).toString())

Loading…
Cancel
Save