tshow one item per line in utxo tab, move address actions to addresses tab - electrum - Electrum Bitcoin wallet HTML git clone https://git.parazyd.org/electrum DIR Log DIR Files DIR Refs DIR Submodules --- DIR commit 0955b0d34dd6d562e2a37777d18e4d1b74c36d8b DIR parent e30a179c974cc2885be37b48d79703935b67eaee HTML Author: ThomasV <thomasv@electrum.org> Date: Wed, 22 Feb 2017 22:09:05 +0100 show one item per line in utxo tab, move address actions to addresses tab Diffstat: M gui/qt/address_list.py | 9 +++++++++ M gui/qt/utxo_list.py | 34 +++++++------------------------ 2 files changed, 16 insertions(+), 27 deletions(-) --- DIR diff --git a/gui/qt/address_list.py b/gui/qt/address_list.py t@@ -125,6 +125,15 @@ class AddressList(MyTreeWidget): if 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) menu.exec_(self.viewport().mapToGlobal(position)) DIR diff --git a/gui/qt/utxo_list.py b/gui/qt/utxo_list.py t@@ -31,7 +31,7 @@ from electrum.bitcoin import is_address class UTXOList(MyTreeWidget): 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) def get_name(self, x): t@@ -42,44 +42,24 @@ class UTXOList(MyTreeWidget): item = self.currentItem() self.clear() self.utxos = self.wallet.get_utxos() - address_items = {} for x in self.utxos: 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) label = self.wallet.get_label(x.get('prevout_hash')) 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(1, QFont(MONOSPACE_FONT)) 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): selected = [str(x.data(0, Qt.UserRole).toString()) for x in self.selectedItems()] if not selected: return menu = QMenu() - if len(selected) == 1 and is_address(selected[0]): - addr = selected[0] - 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)) + 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))