[#1456] runCreateTransactions on lifecycleScope
- Closes #1456 - Also, these changes leverage updated snapshot Zcash SDK version 2.1.2 - Changelog update
This commit is contained in:
parent
030d2e20b0
commit
75e90607d1
|
@ -15,6 +15,10 @@ directly impact users rather than highlighting other key architectural updates.*
|
||||||
### Changed
|
### Changed
|
||||||
- The color palette used across the app has been reworked to align with the updated design document
|
- The color palette used across the app has been reworked to align with the updated design document
|
||||||
|
|
||||||
|
### Fixed
|
||||||
|
- An updated snapshot Zcash SDK version has been adopted to improve unstable lightwalletd communication
|
||||||
|
- Transaction submission has been slightly refactored to improve its stability
|
||||||
|
|
||||||
## [1.1 (655)] - 2024-05-24
|
## [1.1 (655)] - 2024-05-24
|
||||||
|
|
||||||
### Added
|
### Added
|
||||||
|
|
|
@ -201,7 +201,11 @@ class WalletViewModel(application: Application) : AndroidViewModel(application)
|
||||||
synchronizer
|
synchronizer
|
||||||
.filterNotNull()
|
.filterNotNull()
|
||||||
.map {
|
.map {
|
||||||
|
runCatching {
|
||||||
WalletAddresses.new(it)
|
WalletAddresses.new(it)
|
||||||
|
}.onFailure {
|
||||||
|
Twig.warn { "Wait until the SDK starts providing the addresses" }
|
||||||
|
}.getOrNull()
|
||||||
}.stateIn(
|
}.stateIn(
|
||||||
viewModelScope,
|
viewModelScope,
|
||||||
SharingStarted.WhileSubscribed(ANDROID_STATE_FLOW_TIMEOUT),
|
SharingStarted.WhileSubscribed(ANDROID_STATE_FLOW_TIMEOUT),
|
||||||
|
|
|
@ -4,7 +4,6 @@ package co.electriccoin.zcash.ui.screen.balances
|
||||||
|
|
||||||
import android.content.Context
|
import android.content.Context
|
||||||
import android.widget.Toast
|
import android.widget.Toast
|
||||||
import androidx.activity.ComponentActivity
|
|
||||||
import androidx.activity.viewModels
|
import androidx.activity.viewModels
|
||||||
import androidx.compose.material3.SnackbarHostState
|
import androidx.compose.material3.SnackbarHostState
|
||||||
import androidx.compose.runtime.Composable
|
import androidx.compose.runtime.Composable
|
||||||
|
@ -14,11 +13,13 @@ import androidx.compose.runtime.rememberCoroutineScope
|
||||||
import androidx.compose.runtime.saveable.rememberSaveable
|
import androidx.compose.runtime.saveable.rememberSaveable
|
||||||
import androidx.compose.ui.platform.LocalContext
|
import androidx.compose.ui.platform.LocalContext
|
||||||
import androidx.lifecycle.compose.collectAsStateWithLifecycle
|
import androidx.lifecycle.compose.collectAsStateWithLifecycle
|
||||||
|
import androidx.lifecycle.lifecycleScope
|
||||||
import cash.z.ecc.android.sdk.SdkSynchronizer
|
import cash.z.ecc.android.sdk.SdkSynchronizer
|
||||||
import cash.z.ecc.android.sdk.Synchronizer
|
import cash.z.ecc.android.sdk.Synchronizer
|
||||||
import cash.z.ecc.android.sdk.model.UnifiedSpendingKey
|
import cash.z.ecc.android.sdk.model.UnifiedSpendingKey
|
||||||
import cash.z.ecc.android.sdk.model.Zatoshi
|
import cash.z.ecc.android.sdk.model.Zatoshi
|
||||||
import co.electriccoin.zcash.spackle.Twig
|
import co.electriccoin.zcash.spackle.Twig
|
||||||
|
import co.electriccoin.zcash.ui.MainActivity
|
||||||
import co.electriccoin.zcash.ui.R
|
import co.electriccoin.zcash.ui.R
|
||||||
import co.electriccoin.zcash.ui.common.compose.BalanceState
|
import co.electriccoin.zcash.ui.common.compose.BalanceState
|
||||||
import co.electriccoin.zcash.ui.common.model.WalletRestoringState
|
import co.electriccoin.zcash.ui.common.model.WalletRestoringState
|
||||||
|
@ -43,7 +44,7 @@ import org.jetbrains.annotations.VisibleForTesting
|
||||||
|
|
||||||
@Composable
|
@Composable
|
||||||
internal fun WrapBalances(
|
internal fun WrapBalances(
|
||||||
activity: ComponentActivity,
|
activity: MainActivity,
|
||||||
goSettings: () -> Unit,
|
goSettings: () -> Unit,
|
||||||
goMultiTrxSubmissionFailure: () -> Unit,
|
goMultiTrxSubmissionFailure: () -> Unit,
|
||||||
) {
|
) {
|
||||||
|
@ -74,6 +75,7 @@ internal fun WrapBalances(
|
||||||
checkUpdateViewModel = checkUpdateViewModel,
|
checkUpdateViewModel = checkUpdateViewModel,
|
||||||
goSettings = goSettings,
|
goSettings = goSettings,
|
||||||
goMultiTrxSubmissionFailure = goMultiTrxSubmissionFailure,
|
goMultiTrxSubmissionFailure = goMultiTrxSubmissionFailure,
|
||||||
|
lifecycleScope = activity.lifecycleScope,
|
||||||
spendingKey = spendingKey,
|
spendingKey = spendingKey,
|
||||||
synchronizer = synchronizer,
|
synchronizer = synchronizer,
|
||||||
walletSnapshot = walletSnapshot,
|
walletSnapshot = walletSnapshot,
|
||||||
|
@ -93,6 +95,7 @@ internal fun WrapBalances(
|
||||||
createTransactionsViewModel: CreateTransactionsViewModel,
|
createTransactionsViewModel: CreateTransactionsViewModel,
|
||||||
goSettings: () -> Unit,
|
goSettings: () -> Unit,
|
||||||
goMultiTrxSubmissionFailure: () -> Unit,
|
goMultiTrxSubmissionFailure: () -> Unit,
|
||||||
|
lifecycleScope: CoroutineScope,
|
||||||
spendingKey: UnifiedSpendingKey?,
|
spendingKey: UnifiedSpendingKey?,
|
||||||
synchronizer: Synchronizer?,
|
synchronizer: Synchronizer?,
|
||||||
walletSnapshot: WalletSnapshot?,
|
walletSnapshot: WalletSnapshot?,
|
||||||
|
@ -157,7 +160,7 @@ internal fun WrapBalances(
|
||||||
hideStatusDialog = { showStatusDialog.value = null },
|
hideStatusDialog = { showStatusDialog.value = null },
|
||||||
snackbarHostState = snackbarHostState,
|
snackbarHostState = snackbarHostState,
|
||||||
onShielding = {
|
onShielding = {
|
||||||
scope.launch {
|
lifecycleScope.launch {
|
||||||
setShieldState(ShieldState.Running)
|
setShieldState(ShieldState.Running)
|
||||||
|
|
||||||
Twig.debug { "Shielding transparent funds" }
|
Twig.debug { "Shielding transparent funds" }
|
||||||
|
|
|
@ -2,7 +2,6 @@
|
||||||
|
|
||||||
package co.electriccoin.zcash.ui.screen.home
|
package co.electriccoin.zcash.ui.screen.home
|
||||||
|
|
||||||
import androidx.activity.ComponentActivity
|
|
||||||
import androidx.activity.compose.BackHandler
|
import androidx.activity.compose.BackHandler
|
||||||
import androidx.activity.viewModels
|
import androidx.activity.viewModels
|
||||||
import androidx.compose.runtime.Composable
|
import androidx.compose.runtime.Composable
|
||||||
|
@ -104,7 +103,7 @@ internal fun MainActivity.WrapHome(
|
||||||
@Suppress("LongParameterList", "LongMethod")
|
@Suppress("LongParameterList", "LongMethod")
|
||||||
@Composable
|
@Composable
|
||||||
internal fun WrapHome(
|
internal fun WrapHome(
|
||||||
activity: ComponentActivity,
|
activity: MainActivity,
|
||||||
goBack: () -> Unit,
|
goBack: () -> Unit,
|
||||||
goSettings: () -> Unit,
|
goSettings: () -> Unit,
|
||||||
goMultiTrxSubmissionFailure: () -> Unit,
|
goMultiTrxSubmissionFailure: () -> Unit,
|
||||||
|
|
|
@ -16,6 +16,7 @@ import androidx.compose.runtime.remember
|
||||||
import androidx.compose.runtime.rememberCoroutineScope
|
import androidx.compose.runtime.rememberCoroutineScope
|
||||||
import androidx.compose.runtime.saveable.rememberSaveable
|
import androidx.compose.runtime.saveable.rememberSaveable
|
||||||
import androidx.lifecycle.compose.collectAsStateWithLifecycle
|
import androidx.lifecycle.compose.collectAsStateWithLifecycle
|
||||||
|
import androidx.lifecycle.lifecycleScope
|
||||||
import cash.z.ecc.android.sdk.SdkSynchronizer
|
import cash.z.ecc.android.sdk.SdkSynchronizer
|
||||||
import cash.z.ecc.android.sdk.Synchronizer
|
import cash.z.ecc.android.sdk.Synchronizer
|
||||||
import cash.z.ecc.android.sdk.model.Proposal
|
import cash.z.ecc.android.sdk.model.Proposal
|
||||||
|
@ -44,6 +45,7 @@ import co.electriccoin.zcash.ui.screen.support.viewmodel.SupportViewModel
|
||||||
import co.electriccoin.zcash.ui.util.EmailUtil
|
import co.electriccoin.zcash.ui.util.EmailUtil
|
||||||
import kotlinx.collections.immutable.ImmutableList
|
import kotlinx.collections.immutable.ImmutableList
|
||||||
import kotlinx.collections.immutable.toImmutableList
|
import kotlinx.collections.immutable.toImmutableList
|
||||||
|
import kotlinx.coroutines.CoroutineScope
|
||||||
import kotlinx.coroutines.flow.filterNotNull
|
import kotlinx.coroutines.flow.filterNotNull
|
||||||
import kotlinx.coroutines.launch
|
import kotlinx.coroutines.launch
|
||||||
|
|
||||||
|
@ -76,10 +78,11 @@ internal fun MainActivity.WrapSendConfirmation(
|
||||||
activity = this,
|
activity = this,
|
||||||
arguments = arguments,
|
arguments = arguments,
|
||||||
authenticationViewModel = authenticationViewModel,
|
authenticationViewModel = authenticationViewModel,
|
||||||
|
createTransactionsViewModel = createTransactionsViewModel,
|
||||||
goBack = goBack,
|
goBack = goBack,
|
||||||
goHome = goHome,
|
goHome = goHome,
|
||||||
goSupport = goSupport,
|
goSupport = goSupport,
|
||||||
createTransactionsViewModel = createTransactionsViewModel,
|
lifecycleScope = this.lifecycleScope,
|
||||||
spendingKey = spendingKey,
|
spendingKey = spendingKey,
|
||||||
supportMessage = supportMessage,
|
supportMessage = supportMessage,
|
||||||
synchronizer = synchronizer,
|
synchronizer = synchronizer,
|
||||||
|
@ -94,10 +97,11 @@ internal fun WrapSendConfirmation(
|
||||||
activity: MainActivity,
|
activity: MainActivity,
|
||||||
arguments: SendConfirmationArguments,
|
arguments: SendConfirmationArguments,
|
||||||
authenticationViewModel: AuthenticationViewModel,
|
authenticationViewModel: AuthenticationViewModel,
|
||||||
|
createTransactionsViewModel: CreateTransactionsViewModel,
|
||||||
goBack: (clearForm: Boolean) -> Unit,
|
goBack: (clearForm: Boolean) -> Unit,
|
||||||
goHome: () -> Unit,
|
goHome: () -> Unit,
|
||||||
goSupport: () -> Unit,
|
goSupport: () -> Unit,
|
||||||
createTransactionsViewModel: CreateTransactionsViewModel,
|
lifecycleScope: CoroutineScope,
|
||||||
spendingKey: UnifiedSpendingKey?,
|
spendingKey: UnifiedSpendingKey?,
|
||||||
supportMessage: SupportInfo?,
|
supportMessage: SupportInfo?,
|
||||||
synchronizer: Synchronizer?,
|
synchronizer: Synchronizer?,
|
||||||
|
@ -179,7 +183,7 @@ internal fun WrapSendConfirmation(
|
||||||
},
|
},
|
||||||
onConfirmation = {
|
onConfirmation = {
|
||||||
// Check and trigger authentication if required, or just submit transactions otherwise
|
// Check and trigger authentication if required, or just submit transactions otherwise
|
||||||
scope.launch {
|
lifecycleScope.launch {
|
||||||
authenticationViewModel.isSendFundsAuthenticationRequired
|
authenticationViewModel.isSendFundsAuthenticationRequired
|
||||||
.filterNotNull()
|
.filterNotNull()
|
||||||
.collect { isProtected ->
|
.collect { isProtected ->
|
||||||
|
@ -211,7 +215,7 @@ internal fun WrapSendConfirmation(
|
||||||
goSupport()
|
goSupport()
|
||||||
},
|
},
|
||||||
onSuccess = {
|
onSuccess = {
|
||||||
scope.launch {
|
lifecycleScope.launch {
|
||||||
runSendFundsAction(
|
runSendFundsAction(
|
||||||
createTransactionsViewModel = createTransactionsViewModel,
|
createTransactionsViewModel = createTransactionsViewModel,
|
||||||
goHome = goHome,
|
goHome = goHome,
|
||||||
|
|
Loading…
Reference in New Issue