mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-24 11:36:21 +00:00
Changed listener for update of transactions list.
This commit is contained in:
parent
042b17a82f
commit
cbf265bd92
1 changed files with 40 additions and 34 deletions
|
@ -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)));
|
||||||
|
|
Loading…
Reference in a new issue