Browse Source

qt addresses list: custom sort order for "Type" and "fiat balance" cols

fixes #4920
fixes #5641
master
SomberNight 5 years ago
parent
commit
efc5deb06e
No known key found for this signature in database GPG Key ID: B33B5F232C6271E9
  1. 29
      electrum/gui/qt/address_list.py

29
electrum/gui/qt/address_list.py

@ -35,7 +35,7 @@ from electrum.plugin import run_hook
from electrum.bitcoin import is_address from electrum.bitcoin import is_address
from electrum.wallet import InternalAddressCorruption from electrum.wallet import InternalAddressCorruption
from .util import MyTreeView, MONOSPACE_FONT, ColorScheme, webopen from .util import MyTreeView, MONOSPACE_FONT, ColorScheme, webopen, MySortModel
class AddressUsageStateFilter(IntEnum): class AddressUsageStateFilter(IntEnum):
@ -78,6 +78,8 @@ class AddressList(MyTreeView):
filter_columns = [Columns.TYPE, Columns.ADDRESS, Columns.LABEL, Columns.COIN_BALANCE] filter_columns = [Columns.TYPE, Columns.ADDRESS, Columns.LABEL, Columns.COIN_BALANCE]
ROLE_SORT_ORDER = Qt.UserRole + 1000
def __init__(self, parent): def __init__(self, parent):
super().__init__(parent, self.create_menu, stretch_column=self.Columns.LABEL) super().__init__(parent, self.create_menu, stretch_column=self.Columns.LABEL)
self.wallet = self.parent.wallet self.wallet = self.parent.wallet
@ -93,8 +95,12 @@ class AddressList(MyTreeView):
self.used_button.currentIndexChanged.connect(self.toggle_used) self.used_button.currentIndexChanged.connect(self.toggle_used)
for addr_usage_state in AddressUsageStateFilter.__members__.values(): # type: AddressUsageStateFilter for addr_usage_state in AddressUsageStateFilter.__members__.values(): # type: AddressUsageStateFilter
self.used_button.addItem(addr_usage_state.ui_text()) self.used_button.addItem(addr_usage_state.ui_text())
self.setModel(QStandardItemModel(self)) self.std_model = QStandardItemModel(self)
self.proxy = MySortModel(self, sort_role=self.ROLE_SORT_ORDER)
self.proxy.setSourceModel(self.std_model)
self.setModel(self.proxy)
self.update() self.update()
self.sortByColumn(self.Columns.TYPE, Qt.AscendingOrder)
def get_toolbar_buttons(self): def get_toolbar_buttons(self):
return QLabel(_("Filter:")), self.change_button, self.used_button return QLabel(_("Filter:")), self.change_button, self.used_button
@ -146,7 +152,8 @@ class AddressList(MyTreeView):
addr_list = self.wallet.get_change_addresses() addr_list = self.wallet.get_change_addresses()
else: else:
addr_list = self.wallet.get_addresses() addr_list = self.wallet.get_addresses()
self.model().clear() self.proxy.setDynamicSortFilter(False) # temp. disable re-sorting after every change
self.std_model.clear()
self.refresh_headers() self.refresh_headers()
fx = self.parent.fx fx = self.parent.fx
set_address = None set_address = None
@ -187,18 +194,21 @@ class AddressList(MyTreeView):
address_item[self.Columns.TYPE].setText(_('receiving')) address_item[self.Columns.TYPE].setText(_('receiving'))
address_item[self.Columns.TYPE].setBackground(ColorScheme.GREEN.as_color(True)) address_item[self.Columns.TYPE].setBackground(ColorScheme.GREEN.as_color(True))
address_item[self.Columns.LABEL].setData(address, Qt.UserRole) address_item[self.Columns.LABEL].setData(address, Qt.UserRole)
address_path = self.wallet.get_address_index(address)
address_item[self.Columns.TYPE].setData(address_path, self.ROLE_SORT_ORDER)
address_path_str = self.wallet.get_address_path_str(address) address_path_str = self.wallet.get_address_path_str(address)
if address_path_str is not None: if address_path_str is not None:
address_item[self.Columns.TYPE].setToolTip(address_path_str) address_item[self.Columns.TYPE].setToolTip(address_path_str)
address_item[self.Columns.FIAT_BALANCE].setData(balance, self.ROLE_SORT_ORDER)
# setup column 1 # setup column 1
if self.wallet.is_frozen_address(address): if self.wallet.is_frozen_address(address):
address_item[self.Columns.ADDRESS].setBackground(ColorScheme.BLUE.as_color(True)) address_item[self.Columns.ADDRESS].setBackground(ColorScheme.BLUE.as_color(True))
if address in addresses_beyond_gap_limit: if address in addresses_beyond_gap_limit:
address_item[self.Columns.ADDRESS].setBackground(ColorScheme.RED.as_color(True)) address_item[self.Columns.ADDRESS].setBackground(ColorScheme.RED.as_color(True))
# add item # add item
count = self.model().rowCount() count = self.std_model.rowCount()
self.model().insertRow(count, address_item) self.std_model.insertRow(count, address_item)
address_idx = self.model().index(count, self.Columns.LABEL) address_idx = self.std_model.index(count, self.Columns.LABEL)
if address == current_address: if address == current_address:
set_address = QPersistentModelIndex(address_idx) set_address = QPersistentModelIndex(address_idx)
self.set_current_idx(set_address) self.set_current_idx(set_address)
@ -208,6 +218,7 @@ class AddressList(MyTreeView):
else: else:
self.hideColumn(self.Columns.FIAT_BALANCE) self.hideColumn(self.Columns.FIAT_BALANCE)
self.filter() self.filter()
self.proxy.setDynamicSortFilter(True)
def create_menu(self, position): def create_menu(self, position):
from electrum.wallet import Multisig_Wallet from electrum.wallet import Multisig_Wallet
@ -217,17 +228,17 @@ class AddressList(MyTreeView):
if not selected: if not selected:
return return
multi_select = len(selected) > 1 multi_select = len(selected) > 1
addrs = [self.model().itemFromIndex(item).text() for item in selected] addrs = [self.item_from_index(item).text() for item in selected]
menu = QMenu() menu = QMenu()
if not multi_select: if not multi_select:
idx = self.indexAt(position) idx = self.indexAt(position)
if not idx.isValid(): if not idx.isValid():
return return
item = self.model().itemFromIndex(idx) item = self.item_from_index(idx)
if not item: if not item:
return return
addr = addrs[0] addr = addrs[0]
addr_column_title = self.model().horizontalHeaderItem(self.Columns.LABEL).text() addr_column_title = self.std_model.horizontalHeaderItem(self.Columns.LABEL).text()
addr_idx = idx.sibling(idx.row(), self.Columns.LABEL) addr_idx = idx.sibling(idx.row(), self.Columns.LABEL)
self.add_copy_menu(menu, idx) self.add_copy_menu(menu, idx)
menu.addAction(_('Details'), lambda: self.parent.show_address(addr)) menu.addAction(_('Details'), lambda: self.parent.show_address(addr))

Loading…
Cancel
Save