diff --git a/integrations/crowdnode/src/main/java/org/dash/wallet/integrations/crowdnode/api/CrowdNodeApi.kt b/integrations/crowdnode/src/main/java/org/dash/wallet/integrations/crowdnode/api/CrowdNodeApi.kt index 49543ef44..3705d19ed 100644 --- a/integrations/crowdnode/src/main/java/org/dash/wallet/integrations/crowdnode/api/CrowdNodeApi.kt +++ b/integrations/crowdnode/src/main/java/org/dash/wallet/integrations/crowdnode/api/CrowdNodeApi.kt @@ -865,7 +865,7 @@ class CrowdNodeApiAggregator @Inject constructor( * obtains the current CrowdNode fee on masternode rewards once per 24 hours */ private suspend fun refreshFees() { - val lastFeeRequest = 0;//config.get(CrowdNodeConfig.LAST_FEE_REQUEST) + val lastFeeRequest = config.get(CrowdNodeConfig.LAST_FEE_REQUEST) if (lastFeeRequest == null || (lastFeeRequest + TimeUnit.DAYS.toMillis(1)) < System.currentTimeMillis()) { val feeInfo = webApi.getFees(accountAddress) log.info("crowdnode feeInfo: {}", feeInfo) diff --git a/wallet/src/de/schildbach/wallet/ui/TransactionResultViewModel.kt b/wallet/src/de/schildbach/wallet/ui/TransactionResultViewModel.kt index fe77476c3..b18b47f96 100644 --- a/wallet/src/de/schildbach/wallet/ui/TransactionResultViewModel.kt +++ b/wallet/src/de/schildbach/wallet/ui/TransactionResultViewModel.kt @@ -96,8 +96,9 @@ class TransactionResultViewModel @Inject constructor( } } - private suspend fun monitorTransactionMetadata(txId: Sha256Hash) { - withContext(Dispatchers.IO) { + private fun monitorTransactionMetadata(txId: Sha256Hash) { + // this might take some time, so let it run asynchronously + viewModelScope.launch(Dispatchers.IO) { transactionMetadataProvider.importTransactionMetadata(txId) transactionMetadataProvider.observeTransactionMetadata(txId).collect { _transactionMetadata.value = it diff --git a/wallet/src/de/schildbach/wallet/ui/transactions/TransactionDetailsDialogFragment.kt b/wallet/src/de/schildbach/wallet/ui/transactions/TransactionDetailsDialogFragment.kt index c33dd72f1..2d5bc1a66 100644 --- a/wallet/src/de/schildbach/wallet/ui/transactions/TransactionDetailsDialogFragment.kt +++ b/wallet/src/de/schildbach/wallet/ui/transactions/TransactionDetailsDialogFragment.kt @@ -101,11 +101,6 @@ class TransactionDetailsDialogFragment : OffsetDialogFragment(R.layout.transacti viewModel.init(txId) viewModel.transaction.filterNotNull().observe(viewLifecycleOwner) { tx -> // the transactionResultViewBinder.bind is called later -// if (tx == null) { -// // log.error("Transaction not found. TxId: {}", txId) -// return@observe -// } - viewModel.transactionIcon.observe(this) { transactionResultViewBinder.setTransactionIcon(it) diff --git a/wallet/src/de/schildbach/wallet/ui/transactions/TransactionResultActivity.kt b/wallet/src/de/schildbach/wallet/ui/transactions/TransactionResultActivity.kt index 83517a105..476fa642c 100644 --- a/wallet/src/de/schildbach/wallet/ui/transactions/TransactionResultActivity.kt +++ b/wallet/src/de/schildbach/wallet/ui/transactions/TransactionResultActivity.kt @@ -41,6 +41,7 @@ import de.schildbach.wallet.util.WalletUtils import de.schildbach.wallet_test.R import de.schildbach.wallet_test.databinding.ActivitySuccessfulTransactionBinding import de.schildbach.wallet_test.databinding.TransactionResultContentBinding +import kotlinx.coroutines.flow.filterNotNull import org.bitcoinj.core.Sha256Hash import org.bitcoinj.core.Transaction import org.dash.wallet.common.services.analytics.AnalyticsConstants @@ -151,27 +152,22 @@ class TransactionResultActivity : LockScreenActivity() { viewModel.init(txId) - viewModel.transaction.observe(this) { tx -> - if (tx != null) { - transactionResultViewBinder.setTransactionIcon(R.drawable.check_animated) - contentBinding.openExplorerCard.setOnClickListener { viewOnExplorer(tx) } - contentBinding.taxCategoryLayout.setOnClickListener { viewOnTaxCategory() } - binding.transactionCloseBtn.setOnClickListener { - onTransactionDetailsDismiss() - } - contentBinding.reportIssueCard.setOnClickListener { - showReportIssue() - } - - viewModel.transactionMetadata.observe(this) { - transactionResultViewBinder.setTransactionMetadata(it) - } - transactionResultViewBinder.setOnRescanTriggered { rescanBlockchain() } - } else { - log.error("Transaction not found. TxId: {}", txId) - finish() - return@observe + viewModel.transaction.filterNotNull().observe(this) { tx -> + transactionResultViewBinder.setTransactionIcon(R.drawable.check_animated) + contentBinding.openExplorerCard.setOnClickListener { viewOnExplorer(tx) } + contentBinding.taxCategoryLayout.setOnClickListener { viewOnTaxCategory() } + binding.transactionCloseBtn.setOnClickListener { + onTransactionDetailsDismiss() + } + contentBinding.reportIssueCard.setOnClickListener { + showReportIssue() + } + + viewModel.transactionMetadata.observe(this) { + transactionResultViewBinder.setTransactionMetadata(it) } + transactionResultViewBinder.setOnRescanTriggered { rescanBlockchain() } + viewModel.transactionMetadata.observe(this) { transactionResultViewBinder.setTransactionMetadata(it)