Changed listener for update of transactions list.

This commit is contained in:
M 2020-12-04 21:09:55 +02:00
parent 042b17a82f
commit cbf265bd92

View file

@ -89,16 +89,16 @@ abstract class DashboardViewModelBase with Store {
_onMoneroAccountChangeReaction = reaction((_) => _wallet.account, _onMoneroAccountChangeReaction = reaction((_) => _wallet.account,
(Account account) => _onMoneroAccountChange(_wallet)); (Account account) => _onMoneroAccountChange(_wallet));
_onMoneroBalanceChangeReaction = reaction((_) => _onMoneroBalanceChangeReaction = reaction((_) => _wallet.balance,
_wallet.balance, (MoneroBalance balance) => (MoneroBalance balance) => _onMoneroTransactionsUpdate(_wallet));
_onMoneroTransactionsUpdate(_wallet));
final _accountTransactions = _wallet final _accountTransactions = _wallet
.transactionHistory.transactions.values .transactionHistory.transactions.values
.where((tx) => tx.accountIndex == _wallet.account.id).toList(); .where((tx) => tx.accountIndex == _wallet.account.id)
.toList();
transactions = ObservableList.of(_accountTransactions transactions = ObservableList.of(_accountTransactions.map((transaction) =>
.map((transaction) => TransactionListItem( TransactionListItem(
transaction: transaction, transaction: transaction,
balanceViewModel: balanceViewModel, balanceViewModel: balanceViewModel,
settingsStore: appStore.settingsStore))); settingsStore: appStore.settingsStore)));
@ -109,16 +109,23 @@ abstract class DashboardViewModelBase with Store {
transaction: transaction, transaction: transaction,
balanceViewModel: balanceViewModel, balanceViewModel: balanceViewModel,
settingsStore: appStore.settingsStore))); settingsStore: appStore.settingsStore)));
}
// FIXME: fixme
connectMapToListWithTransform( connectMapToListWithTransform(
appStore.wallet.transactionHistory.transactions, appStore.wallet.transactionHistory.transactions,
transactions, transactions,
(TransactionInfo val) => TransactionListItem( (TransactionInfo val) => TransactionListItem(
transaction: val, transaction: val,
balanceViewModel: balanceViewModel, balanceViewModel: balanceViewModel,
settingsStore: appStore.settingsStore)); settingsStore: appStore.settingsStore),
filter: (TransactionInfo tx) {
final wallet = _wallet;
if (tx is MoneroTransactionInfo && wallet is MoneroWallet) {
return tx.accountIndex == wallet.account.id;
} }
return true;
});
} }
@observable @observable
@ -216,9 +223,8 @@ abstract class DashboardViewModelBase with Store {
_onMoneroAccountChangeReaction = reaction((_) => wallet.account, _onMoneroAccountChangeReaction = reaction((_) => wallet.account,
(Account account) => _onMoneroAccountChange(wallet)); (Account account) => _onMoneroAccountChange(wallet));
_onMoneroBalanceChangeReaction = reaction((_) => _onMoneroBalanceChangeReaction = reaction((_) => wallet.balance,
wallet.balance, (MoneroBalance balance) => (MoneroBalance balance) => _onMoneroTransactionsUpdate(wallet));
_onMoneroTransactionsUpdate(wallet));
_onMoneroTransactionsUpdate(wallet); _onMoneroTransactionsUpdate(wallet);
} else { } else {
@ -242,12 +248,12 @@ abstract class DashboardViewModelBase with Store {
void _onMoneroTransactionsUpdate(MoneroWallet wallet) { void _onMoneroTransactionsUpdate(MoneroWallet wallet) {
transactions.clear(); transactions.clear();
final _accountTransactions = wallet final _accountTransactions = wallet.transactionHistory.transactions.values
.transactionHistory.transactions.values .where((tx) => tx.accountIndex == wallet.account.id)
.where((tx) => tx.accountIndex == wallet.account.id).toList(); .toList();
transactions.addAll(_accountTransactions transactions.addAll(_accountTransactions.map((transaction) =>
.map((transaction) => TransactionListItem( TransactionListItem(
transaction: transaction, transaction: transaction,
balanceViewModel: balanceViewModel, balanceViewModel: balanceViewModel,
settingsStore: appStore.settingsStore))); settingsStore: appStore.settingsStore)));