taler-android

Android apps for GNU Taler (wallet, PoS, cashier)
Log | Files | Refs | README | LICENSE

commit 0d4d6358ac6db7e0a1e936ecfd70ec4bb3262846
parent d284953c7f540ea15a99b8ae3d99c2bfb6d1ee6b
Author: Torsten Grote <t@grobox.de>
Date:   Mon, 27 Apr 2020 09:17:25 -0300

[wallet] refresh transactions when certain notifications arrive

Diffstat:
Mwallet/src/main/java/net/taler/wallet/MainViewModel.kt | 15++++++++++++++-
1 file changed, 14 insertions(+), 1 deletion(-)

diff --git a/wallet/src/main/java/net/taler/wallet/MainViewModel.kt b/wallet/src/main/java/net/taler/wallet/MainViewModel.kt @@ -37,6 +37,12 @@ import org.json.JSONObject const val TAG = "taler-wallet" +private val transactionNotifications = listOf( + "proposal-accepted", + "refresh-revealed", + "withdraw-group-finished" +) + data class BalanceItem(val available: Amount, val pendingIncoming: Amount) class MainViewModel(val app: Application) : AndroidViewModel(app) { @@ -56,6 +62,13 @@ class MainViewModel(val app: Application) : AndroidViewModel(app) { ) { Log.i(TAG, "Received notification from wallet-core: ${payload.toString(2)}") loadBalances() + if (payload.optString("type") in transactionNotifications) { + // update transaction list + // TODO do this in a better way + transactionManager.showAll.value?.let { + transactionManager.showAll.postValue(it) + } + } } } @@ -66,7 +79,7 @@ class MainViewModel(val app: Application) : AndroidViewModel(app) { val withdrawManager = WithdrawManager(walletBackendApi) val paymentManager = PaymentManager(walletBackendApi, mapper) val pendingOperationsManager = PendingOperationsManager(walletBackendApi) - val transactionManager = TransactionManager(walletBackendApi, mapper) + val transactionManager: TransactionManager = TransactionManager(walletBackendApi, mapper) val refundManager = RefundManager(walletBackendApi) override fun onCleared() {