navigation-compose
Gradle:
dependencies {
implementation("ro.dragossusi:navigation:<version>")
}
Features
- Route navigation
- Key-Value arguments
- Backstack
- ViewModel
Usage
I made this similar to android’s navigation component, you declare routes and navigate using the route String.
There is also a sample app in sample
directory.
Create a NavController using
val navController = rememberNavController()
Create the graph and declare the composable methods like this:
NavHost(
navController,
startRoute = "home"
) {
composable("home") {
HomeScreen(
onGoToItem = {
navController.navigate("item")
},
onGoToHelp = {
navController.navigate("help")
}
)
}
composable("item") {
ItemScreen(
onClick = navController::navigateUp
)
}
composable("help") {
HelpScreen(
onClick = navController::navigateUp
)
}
}
You can extend ViewModel
and use the viewModelScope
to launch coroutines whenever you want, they will be canceled
when the screen is removed from backstack.
To obtain a ViewModel
instance use the rememberViewModel
method.
val viewModel: ItemViewModel = rememberViewModel { arguments ->
//here you create your ViewModel however you want, it will be reused
ItemViewModel()
}