Browse Source

listmodels self-initialize,

lazy-load listmodels in QEWallet,
process channel updates in qechannellistmodel
patch-4
Sander van Grieken 3 years ago
parent
commit
7ef52c6625
  1. 1
      electrum/gui/qml/components/Addresses.qml
  2. 1
      electrum/gui/qml/components/Channels.qml
  3. 4
      electrum/gui/qml/qeaddresslistmodel.py
  4. 43
      electrum/gui/qml/qechannellistmodel.py
  5. 2
      electrum/gui/qml/qeinvoicelistmodel.py
  6. 2
      electrum/gui/qml/qetransactionlistmodel.py
  7. 23
      electrum/gui/qml/qewallet.py

1
electrum/gui/qml/components/Addresses.qml

@ -169,5 +169,4 @@ Pane {
} }
} }
Component.onCompleted: Daemon.currentWallet.addressModel.init_model()
} }

1
electrum/gui/qml/components/Channels.qml

@ -102,5 +102,4 @@ Pane {
} }
Component.onCompleted: Daemon.currentWallet.channelModel.init_model()
} }

4
electrum/gui/qml/qeaddresslistmodel.py

@ -10,9 +10,7 @@ class QEAddressListModel(QAbstractListModel):
def __init__(self, wallet, parent=None): def __init__(self, wallet, parent=None):
super().__init__(parent) super().__init__(parent)
self.wallet = wallet self.wallet = wallet
self.receive_addresses = [] self.init_model()
self.change_addresses = []
_logger = get_logger(__name__) _logger = get_logger(__name__)

43
electrum/gui/qml/qechannellistmodel.py

@ -4,7 +4,7 @@ from PyQt5.QtCore import pyqtProperty, pyqtSignal, pyqtSlot, QObject
from PyQt5.QtCore import Qt, QAbstractListModel, QModelIndex from PyQt5.QtCore import Qt, QAbstractListModel, QModelIndex
from electrum.logging import get_logger from electrum.logging import get_logger
from electrum.util import Satoshis, TxMinedInfo from electrum.util import Satoshis, register_callback
from .qetypes import QEAmount from .qetypes import QEAmount
@ -12,7 +12,16 @@ class QEChannelListModel(QAbstractListModel):
def __init__(self, wallet, parent=None): def __init__(self, wallet, parent=None):
super().__init__(parent) super().__init__(parent)
self.wallet = wallet self.wallet = wallet
self.channels = [] self.init_model()
interests = ['channel', 'channels_updated', 'gossip_peers',
'ln_gossip_sync_progress', 'unknown_channels',
'channel_db', 'gossip_db_loaded']
# To avoid leaking references to "self" that prevent the
# window from being GC-ed when closed, callbacks should be
# methods of this class only, and specifically not be
# partials, lambdas or methods of subobjects. Hence...
register_callback(self.on_network, interests)
_logger = get_logger(__name__) _logger = get_logger(__name__)
@ -48,6 +57,7 @@ class QEChannelListModel(QAbstractListModel):
def channel_to_model(self, lnc): def channel_to_model(self, lnc):
lnworker = self.wallet.lnworker lnworker = self.wallet.lnworker
item = {} item = {}
item['channel_id'] = lnc.channel_id
item['node_alias'] = lnworker.get_node_alias(lnc.node_id) or lnc.node_id.hex() item['node_alias'] = lnworker.get_node_alias(lnc.node_id) or lnc.node_id.hex()
item['short_cid'] = lnc.short_id_for_GUI() item['short_cid'] = lnc.short_id_for_GUI()
item['state'] = lnc.get_state_for_GUI() item['state'] = lnc.get_state_for_GUI()
@ -57,6 +67,7 @@ class QEChannelListModel(QAbstractListModel):
@pyqtSlot() @pyqtSlot()
def init_model(self): def init_model(self):
self._logger.debug('init_model')
if not self.wallet.lnworker: if not self.wallet.lnworker:
self._logger.warning('lnworker should be defined') self._logger.warning('lnworker should be defined')
return return
@ -73,3 +84,31 @@ class QEChannelListModel(QAbstractListModel):
self.beginInsertRows(QModelIndex(), 0, len(channels) - 1) self.beginInsertRows(QModelIndex(), 0, len(channels) - 1)
self.channels = channels self.channels = channels
self.endInsertRows() self.endInsertRows()
def on_network(self, event, *args):
if event == 'channel':
wallet, channel = args
if wallet == self.wallet:
self.on_channel_updated(channel)
elif event == 'channels_updated':
wallet, = args
if wallet == self.wallet:
self.init_model() # TODO: remove/add less crude than full re-init
else:
self._logger.debug('unhandled event %s: %s' % (event, repr(args)))
def on_channel_updated(self, channel):
i = 0
for c in self.channels:
if c['channel_id'] == channel.channel_id:
self.do_update(i,channel)
break
i = i + 1
def do_update(self, modelindex, channel):
modelitem = self.channels[modelindex]
self._logger.debug(repr(modelitem))
modelitem.update(self.channel_to_model(channel))
mi = self.createIndex(modelindex, 0)
self.dataChanged.emit(mi, mi, self._ROLE_KEYS)

2
electrum/gui/qml/qeinvoicelistmodel.py

@ -15,7 +15,7 @@ class QEAbstractInvoiceListModel(QAbstractListModel):
def __init__(self, wallet, parent=None): def __init__(self, wallet, parent=None):
super().__init__(parent) super().__init__(parent)
self.wallet = wallet self.wallet = wallet
self.invoices = [] self.init_model()
# define listmodel rolemap # define listmodel rolemap
_ROLE_NAMES=('key','is_lightning','timestamp','date','message','amount','status','status_str','address','expiration','type') _ROLE_NAMES=('key','is_lightning','timestamp','date','message','amount','status','status_str','address','expiration','type')

2
electrum/gui/qml/qetransactionlistmodel.py

@ -12,7 +12,7 @@ class QETransactionListModel(QAbstractListModel):
def __init__(self, wallet, parent=None): def __init__(self, wallet, parent=None):
super().__init__(parent) super().__init__(parent)
self.wallet = wallet self.wallet = wallet
self.tx_history = [] self.init_model()
_logger = get_logger(__name__) _logger = get_logger(__name__)

23
electrum/gui/qml/qewallet.py

@ -57,16 +57,12 @@ class QEWallet(QObject):
super().__init__(parent) super().__init__(parent)
self.wallet = wallet self.wallet = wallet
self._historyModel = QETransactionListModel(wallet) self._historyModel = None
self._addressModel = QEAddressListModel(wallet) self._addressModel = None
self._requestModel = QERequestListModel(wallet) self._requestModel = None
self._invoiceModel = QEInvoiceListModel(wallet) self._invoiceModel = None
self._channelModel = None self._channelModel = None
self._historyModel.init_model()
self._requestModel.init_model()
self._invoiceModel.init_model()
self.tx_notification_queue = queue.Queue() self.tx_notification_queue = queue.Queue()
self.tx_notification_last_time = 0 self.tx_notification_last_time = 0
@ -125,6 +121,9 @@ class QEWallet(QObject):
if wallet == self.wallet: if wallet == self.wallet:
self._logger.debug('wallet %s updated' % str(wallet)) self._logger.debug('wallet %s updated' % str(wallet))
self.balanceChanged.emit() self.balanceChanged.emit()
elif event in ['channel','channels_updated']:
# TODO update balance/can-spend etc
pass
else: else:
self._logger.debug('unhandled event: %s %s' % (event, str(args))) self._logger.debug('unhandled event: %s %s' % (event, str(args)))
@ -177,21 +176,29 @@ class QEWallet(QObject):
historyModelChanged = pyqtSignal() historyModelChanged = pyqtSignal()
@pyqtProperty(QETransactionListModel, notify=historyModelChanged) @pyqtProperty(QETransactionListModel, notify=historyModelChanged)
def historyModel(self): def historyModel(self):
if self._historyModel is None:
self._historyModel = QETransactionListModel(self.wallet)
return self._historyModel return self._historyModel
addressModelChanged = pyqtSignal() addressModelChanged = pyqtSignal()
@pyqtProperty(QEAddressListModel, notify=addressModelChanged) @pyqtProperty(QEAddressListModel, notify=addressModelChanged)
def addressModel(self): def addressModel(self):
if self._addressModel is None:
self._addressModel = QEAddressListModel(self.wallet)
return self._addressModel return self._addressModel
requestModelChanged = pyqtSignal() requestModelChanged = pyqtSignal()
@pyqtProperty(QERequestListModel, notify=requestModelChanged) @pyqtProperty(QERequestListModel, notify=requestModelChanged)
def requestModel(self): def requestModel(self):
if self._requestModel is None:
self._requestModel = QERequestListModel(self.wallet)
return self._requestModel return self._requestModel
invoiceModelChanged = pyqtSignal() invoiceModelChanged = pyqtSignal()
@pyqtProperty(QEInvoiceListModel, notify=invoiceModelChanged) @pyqtProperty(QEInvoiceListModel, notify=invoiceModelChanged)
def invoiceModel(self): def invoiceModel(self):
if self._invoiceModel is None:
self._invoiceModel = QEInvoiceListModel(self.wallet)
return self._invoiceModel return self._invoiceModel
channelModelChanged = pyqtSignal() channelModelChanged = pyqtSignal()

Loading…
Cancel
Save