Skip to content

Commit

Permalink
Navigation hotfix for new root navigation (#1728)
Browse files Browse the repository at this point in the history
Co-authored-by: Honza <rychnovsky.honza@gmail.com>
  • Loading branch information
Milan-Cerovsky and HonzaR authored Jan 21, 2025
1 parent f527d3c commit b709496
Show file tree
Hide file tree
Showing 7 changed files with 60 additions and 57 deletions.
4 changes: 3 additions & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,9 @@ and this application adheres to [Semantic Versioning](https://semver.org/spec/v2
`Synchronizer` is still in the `SYNCING` state

### Fixed
- The Disconnected popup trigger when the app is backgrounded has been fixed
- The Disconnected popup trigger when the app is backgrounded has been fixed
- The issue when the application does not clean navigation stack after clicking View Transactions after a successful
transaction has been resolved

## [1.3.2 (829)] - 2025-01-10

Expand Down
2 changes: 2 additions & 0 deletions docs/whatsNew/WHATS_NEW_EN.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,8 @@ directly impact users rather than highlighting other key architectural updates.*

### Fixed
- The Disconnected popup trigger when the app is backgrounded has been fixed
- The issue when the application does not clean navigation stack after clicking View Transactions after a successful
transaction has been resolved

## [1.3.2 (829)] - 2025-01-10

Expand Down
2 changes: 2 additions & 0 deletions docs/whatsNew/WHATS_NEW_ES.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,8 @@ directly impact users rather than highlighting other key architectural updates.*

### Fixed
- The Disconnected popup trigger when the app is backgrounded has been fixed
- The issue when the application does not clean navigation stack after clicking View Transactions after a successful
transaction has been resolved

## [1.3.2 (829)] - 2025-01-10

Expand Down
54 changes: 31 additions & 23 deletions ui-lib/src/main/java/co/electriccoin/zcash/ui/Navigation.kt
Original file line number Diff line number Diff line change
Expand Up @@ -126,47 +126,36 @@ internal fun MainActivity.Navigation() {
LaunchedEffect(Unit) {
navigationRouter.observe().collect {
when (it) {
is NavigationCommand.Forward.ByRoute -> {
navController.navigate(it.route)
}
is NavigationCommand.Forward.ByTypeSafetyRoute<*> -> {
is NavigationCommand.Forward ->
if (it.route is ExternalUrl) {
WebBrowserUtil.startActivity(this@Navigation, it.route.url)
return@collect
} else {
navController.navigate(it.route)
}
}
is NavigationCommand.Replace.ByRoute -> {
navController.navigate(it.route) {
popUpTo(navController.currentBackStackEntry?.destination?.id ?: 0) {
inclusive = true
}
navController.executeNavigation(route = it.route)
}
}
is NavigationCommand.Replace.ByTypeSafetyRoute<*> -> {
is NavigationCommand.Replace ->
if (it.route is ExternalUrl) {
navController.popBackStack()
WebBrowserUtil.startActivity(this@Navigation, it.route.url)
return@collect
} else {
navController.navigate(it.route) {
navController.executeNavigation(route = it.route) {
popUpTo(navController.currentBackStackEntry?.destination?.id ?: 0) {
inclusive = true
}
}
}
}
NavigationCommand.Back -> {
navController.popBackStack()
}
is NavigationCommand.NewRoot ->
navController.executeNavigation(route = it.route) {
popUpTo(HOME) {
inclusive = true
}
}
NavigationCommand.Back -> navController.popBackStack()

NavigationCommand.BackToRoot -> {
NavigationCommand.BackToRoot ->
navController.popBackStack(
destinationId = navController.graph.startDestinationId,
inclusive = false
)
}
}
}
}
Expand Down Expand Up @@ -525,6 +514,25 @@ fun NavHostController.navigateJustOnce(
}
}

private fun NavHostController.executeNavigation(
route: Any,
builder: (NavOptionsBuilder.() -> Unit)? = null
) {
if (route is String) {
if (builder == null) {
navigate(route)
} else {
navigate(route, builder)
}
} else {
if (builder == null) {
navigate(route)
} else {
navigate(route, builder)
}
}
}

/**
* Pops up the current screen from the back stack. Parameter currentRouteToBePopped is meant to be
* set only to the current screen so we can easily debounce multiple screen popping from the back stack.
Expand Down
38 changes: 12 additions & 26 deletions ui-lib/src/main/java/co/electriccoin/zcash/ui/NavigationRouter.kt
Original file line number Diff line number Diff line change
Expand Up @@ -9,13 +9,11 @@ import kotlinx.coroutines.flow.receiveAsFlow
import kotlinx.coroutines.launch

interface NavigationRouter {
fun forward(route: String)
fun forward(route: Any)

fun <T : Any> forward(route: T)
fun replace(route: Any)

fun replace(route: String)

fun <T : Any> replace(route: T)
fun newRoot(route: Any)

fun back()

Expand All @@ -29,27 +27,21 @@ class NavigationRouterImpl : NavigationRouter {

private val channel = Channel<NavigationCommand>()

override fun forward(route: String) {
scope.launch {
channel.send(NavigationCommand.Forward.ByRoute(route))
}
}

override fun <T : Any> forward(route: T) {
override fun forward(route: Any) {
scope.launch {
channel.send(NavigationCommand.Forward.ByTypeSafetyRoute(route))
channel.send(NavigationCommand.Forward(route))
}
}

override fun replace(route: String) {
override fun replace(route: Any) {
scope.launch {
channel.send(NavigationCommand.Replace.ByRoute(route))
channel.send(NavigationCommand.Replace(route))
}
}

override fun <T : Any> replace(route: T) {
override fun newRoot(route: Any) {
scope.launch {
channel.send(NavigationCommand.Replace.ByTypeSafetyRoute(route))
channel.send(NavigationCommand.NewRoot(route))
}
}

Expand All @@ -69,17 +61,11 @@ class NavigationRouterImpl : NavigationRouter {
}

sealed interface NavigationCommand {
sealed interface Forward : NavigationCommand {
data class ByRoute(val route: String) : Forward

data class ByTypeSafetyRoute<T : Any>(val route: T) : Forward
}
data class Forward(val route: Any) : NavigationCommand

sealed interface Replace : NavigationCommand {
data class ByRoute(val route: String) : Replace
data class Replace(val route: Any) : NavigationCommand

data class ByTypeSafetyRoute<T : Any>(val route: T) : Replace
}
data class NewRoot(val route: Any) : NavigationCommand

data object Back : NavigationCommand

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@ package co.electriccoin.zcash.ui.common.usecase
import co.electriccoin.zcash.ui.NavigationRouter
import co.electriccoin.zcash.ui.screen.selectkeystoneaccount.SelectKeystoneAccount
import com.sparrowwallet.hummingbird.UR
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.withContext

class ParseKeystoneSignInRequestUseCase(
private val navigationRouter: NavigationRouter
Expand All @@ -14,13 +16,14 @@ class ParseKeystoneSignInRequestUseCase(

@Suppress("TooGenericExceptionCaught")
@Throws(InvalidKeystoneSignInQRException::class)
private fun parseOrThrow(ur: UR) {
try {
keystoneSDK.parseZcashAccounts(ur)
} catch (e: Exception) {
throw InvalidKeystoneSignInQRException(e)
private suspend fun parseOrThrow(ur: UR) =
withContext(Dispatchers.Default) {
try {
keystoneSDK.parseZcashAccounts(ur)
} catch (e: Exception) {
throw InvalidKeystoneSignInQRException(e)
}
}
}
}

class InvalidKeystoneSignInQRException(cause: Throwable) : Exception(cause)
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,6 @@ class ViewTransactionsAfterSuccessfulProposalUseCase(
zashiProposalRepository.clear()
keystoneProposalRepository.clear()
observeClearSend.requestClear()
navigationRouter.forward(HOME)
navigationRouter.newRoot(HOME)
}
}

0 comments on commit b709496

Please sign in to comment.