|
@ -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)) |
|
|