Browse Source

show one item per line in utxo tab, move address actions to addresses tab

283
ThomasV 8 years ago
parent
commit
0955b0d34d
  1. 9
      gui/qt/address_list.py
  2. 34
      gui/qt/utxo_list.py

9
gui/qt/address_list.py

@ -125,6 +125,15 @@ class AddressList(MyTreeWidget):
if addr_URL: if addr_URL:
menu.addAction(_("View on block explorer"), lambda: webbrowser.open(addr_URL)) menu.addAction(_("View on block explorer"), lambda: webbrowser.open(addr_URL))
if not self.wallet.is_frozen(addr):
menu.addAction(_("Freeze"), lambda: self.parent.set_frozen_state([addr], True))
else:
menu.addAction(_("Unfreeze"), lambda: self.parent.set_frozen_state([addr], False))
coins = self.wallet.get_utxos(addrs)
if coins:
menu.addAction(_("Spend from"), lambda: self.parent.spend_coins(coins))
run_hook('receive_menu', menu, addrs, self.wallet) run_hook('receive_menu', menu, addrs, self.wallet)
menu.exec_(self.viewport().mapToGlobal(position)) menu.exec_(self.viewport().mapToGlobal(position))

34
gui/qt/utxo_list.py

@ -31,7 +31,7 @@ from electrum.bitcoin import is_address
class UTXOList(MyTreeWidget): class UTXOList(MyTreeWidget):
def __init__(self, parent=None): def __init__(self, parent=None):
MyTreeWidget.__init__(self, parent, self.create_menu, [ _('Address'), _('Label'), _('Amount'), ''], 1) MyTreeWidget.__init__(self, parent, self.create_menu, [ _('Address'), _('Output point'), _('Label'), _('Amount'), ''], 2)
self.setSelectionMode(QAbstractItemView.ExtendedSelection) self.setSelectionMode(QAbstractItemView.ExtendedSelection)
def get_name(self, x): def get_name(self, x):
@ -42,44 +42,24 @@ class UTXOList(MyTreeWidget):
item = self.currentItem() item = self.currentItem()
self.clear() self.clear()
self.utxos = self.wallet.get_utxos() self.utxos = self.wallet.get_utxos()
address_items = {}
for x in self.utxos: for x in self.utxos:
address = x.get('address') address = x.get('address')
address_item = address_items.get(address)
if address_item is None:
label = self.wallet.get_label(address)
address_item = QTreeWidgetItem([address, label, ''])
address_item.setData(0, Qt.UserRole, address)
address_items[address] = address_item
self.addChild(address_item)
address_item.setExpanded(True)
if self.wallet.is_frozen(address):
address_item.setBackgroundColor(0, QColor('lightblue'))
name = self.get_name(x) name = self.get_name(x)
label = self.wallet.get_label(x.get('prevout_hash')) label = self.wallet.get_label(x.get('prevout_hash'))
amount = self.parent.format_amount(x['value']) amount = self.parent.format_amount(x['value'])
utxo_item = QTreeWidgetItem([name[0:20]+'...'+name[-20:], label, amount]) utxo_item = QTreeWidgetItem([address, name[0:10] + '...' + name[-2:], label, amount])
utxo_item.setFont(0, QFont(MONOSPACE_FONT)) utxo_item.setFont(0, QFont(MONOSPACE_FONT))
utxo_item.setFont(1, QFont(MONOSPACE_FONT)) utxo_item.setFont(1, QFont(MONOSPACE_FONT))
utxo_item.setData(0, Qt.UserRole, name) utxo_item.setData(0, Qt.UserRole, name)
address_item.addChild(utxo_item) if self.wallet.is_frozen(address):
utxo_item.setBackgroundColor(0, QColor('lightblue'))
self.addChild(utxo_item)
def create_menu(self, position): def create_menu(self, position):
selected = [str(x.data(0, Qt.UserRole).toString()) for x in self.selectedItems()] selected = [str(x.data(0, Qt.UserRole).toString()) for x in self.selectedItems()]
if not selected: if not selected:
return return
menu = QMenu() menu = QMenu()
if len(selected) == 1 and is_address(selected[0]): coins = filter(lambda x: self.get_name(x) in selected, self.utxos)
addr = selected[0] menu.addAction(_("Spend"), lambda: self.parent.spend_coins(coins))
coins = filter(lambda x: x.get('address') == addr, self.utxos)
menu.addAction(_("Copy Address"), lambda: self.parent.app.clipboard().setText(addr))
if not self.wallet.is_frozen(addr):
menu.addAction(_("Freeze"), lambda: self.parent.set_frozen_state([addr], True))
else:
menu.addAction(_("Unfreeze"), lambda: self.parent.set_frozen_state([addr], False))
menu.addAction(_("Spend from Address"), lambda: self.parent.spend_coins(coins))
else:
coins = filter(lambda x: self.get_name(x) in selected, self.utxos)
menu.addAction(_("Spend"), lambda: self.parent.spend_coins(coins))
menu.exec_(self.viewport().mapToGlobal(position)) menu.exec_(self.viewport().mapToGlobal(position))

Loading…
Cancel
Save