Set of utils to help integrating Jetpack Compose with Jetpack's Navigation
Please keep in mind that this is still in early stage. If you're willing to use it in your project, then please remember that the API is still not set in stone
I'm doing refactors / changes almost every day currently, in hopes that I'll be able to simplify the API even more.
See #63
List of releases can be found at https://github.com/AdamKobus/compose-navigation/releases
repositories {
mavenCentral()
}
dependencies {
implementation "com.adamkobus:compose-navigation:1.0.0"
}
Past snapshots can be found at Sonatype Snapshots Repository
repositories {
maven { url "https://s01.oss.sonatype.org/content/repositories/snapshots/" }
}
dependencies {
implementation "com.adamkobus:compose-navigation:1.0.0-SNAPSHOT"
}
This library allows you to produce navigation actions from anywhere, including ViewModel
.
Just use ComposeNavigation.getNavigationConsumer.offer(<action or intent>)
NavigationConsumer
has suspend versions of its offer
methods.
Thanks to this, you can block your coroutine until back stack actually changes.
Example graph:
private const val PARAM_IMAGE_ID = "imageId"
object MyGraph : NavGraph("myGraph") {
override fun startDestination() = Home
val Home = screenDestination("home")
val ImagePreview = Home.next {
param(PARAM_IMAGE_ID)
}
val Alert = dialogDestination("alertDialog")
}
// extension which you can later use in your AnimatedNavHost
@ExperimentalAnimationApi
fun NavGraphBuilder.myGraph() {
composableNavigation(MyGraph) {
composableDestination(MyGraph.Home) { HomeScreen() }
composableDestination(MyGraph.ImagePreview) { entry ->
ImagePreviewScreen(entry.getInt(PARAM_IMAGE_ID))
}
composableDialog(MyGraph.Alert) { HomeAlert() }
}
}
And actions:
// using wrapper:
sealed class FromHome(action: NavAction) : NavActionWrapper(action) {
class ToImagePreview(imageId: Int) : FromHome(MyGraph.Home goTo MyGraph.ImagePreview arg imageId)
object ToAlert : FromHome(MyGraph.Home goTo MyGraph.Alert)
}
// or you can declare actions without NavActionWrapper like this:
fun FromHomeToImagePreview(imageId: Int) = MyGraph.Home goTo MyGraph.ImagePreview arg imageId
val FromHomeToAlert = MyGraph.Home goTo MyGraph.Alert
// back navigation action declaration:
val FromImagePreviewNavigateBack = MyGraph.ImagePreview.pop()
With NavActionVerifier
you can discard NavActions
that don't meet your criteria.
object AppNavActionVerifier : NavActionVerifier {
// will reject an action if its origin is different from the current destination
override fun isNavActionAllowed(navState: NavState, action: NavAction): VerifyResult {
return if (state.isCurrent(action.fromDestination)) {
VerifyResult.Allow
} else {
VerifyResult.Discard
}
}
}
NavIntent
and NavIntentResolver
can be used to:
- abstract the navigation between feature modules to keep them independent
- open a dev menu while keeping no hard references to it anywhere in your production code
- handle complex navigation like bottom tab bar (see TabBarIntentResolver)
Sometimes you might want to learn what destination was used to render the current screen dynamically, i.e. when screen is reused in multiple destinations and you don't want to hardcode it within view or view model.
In such case it's risky to rely on the back stack, because it will change during screen transitions.
This library introduces LocalNavDestination to address this issue.
// graph
composableDestination(MyGraph.Home) { HomeScreen() }
// HomeScreen.kt
fun HomeScreen() {
val destination = LocalNavDestination.current // this will return MyGraph.Home
}
MIT License
Copyright (c) 2022 Adam Kobus
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.