From 0d4d6358ac6db7e0a1e936ecfd70ec4bb3262846 Mon Sep 17 00:00:00 2001 From: Torsten Grote Date: Mon, 27 Apr 2020 09:17:25 -0300 Subject: [wallet] refresh transactions when certain notifications arrive --- wallet/src/main/java/net/taler/wallet/MainViewModel.kt | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) (limited to 'wallet') diff --git a/wallet/src/main/java/net/taler/wallet/MainViewModel.kt b/wallet/src/main/java/net/taler/wallet/MainViewModel.kt index 907278c..159540b 100644 --- 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() { -- cgit v1.2.3