jeziellago / multinavcompose

Android multi-module navigation built on top of Jetpack Navigation Compose

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

MultiNavCompose logo

GitHub license ktlint Android API JitPack

Android library for multi-module navigation built on top of Jetpack Navigation Compose.

The goal of this library is to simplify the setup for multi-module navigation with Jetpack Navigation Compose.

Setup

Add jitpack.io url as maven repository:

repositories {  
	...  
	maven { url 'https://jitpack.io' }  
}    

Add dependency into build.gradle:

dependencies {  
    implementation 'com.github.jeziellago:multinavcompose:TAG'  
}  

1. Create a NavComposableModule

Make your composables internal and expose only a NavComposableModule for each module.

// module :posts  
val postsNavModule = NavComposableModule { graph, navController ->  
    graph.composable(POSTS_ROUTE) {  
        PostsScreen(onClick = { postId ->  
            navController.navigate("$POST_DETAIL_ROUTE/$postId")  
        })  
    }  
}  

You also can have nested graphs:

// module :posts  
val postsNavModule = NavComposableModule { graph, navController ->  
	graph.navigation(startDestination = POSTS_ROUTE, route = POSTS) { 
	    composable(POSTS_ROUTE) {  
	        PostsScreen(onClick = { postId ->  
	            navController.navigate("$POST_DETAIL_ROUTE/$postId")  
	        })  
	     }
	     ...
    }
}  

2. Register the NavComposeModule`s

Single NavHost

Call multiNavModules and put all the NavComposeModule's.

For single activity applications (and only a NavHost) you should register the NavComposeModule in onCreate on Application.

class MyApplication : Application() {  
  
    override fun onCreate() {  
        super.onCreate()  
        // Register all NavComposeModules  
        multiNavModules(homeNavModule, postsNavModule, postDetailNavModule)  
    }  
}  

Multiple NavHost's

If you have multiple NavHost's, a key is required on registering each of them:

// feed nav graph
multiNavModules(feedNavModule) { FEED_GRAPH }

// posts nav graph
multiNavModules(postsNavModule, postDetailNavModule) { POST_GRAPH }

3. Setup on NavHost

The loadMultiNavComposables loads the composables into NavHost.

Single NavHost

NavHost(navController = navController, startDestination = HOME) {  
  loadMultiNavComposables(navController)  
}

Multiple NavHost

If you have multiple NavHost's, a key is required too (see POSTS_GRAPH).

NavHost(navController = navController, startDestination = POSTS_ROUTE) {  
  loadMultiNavComposables(navController, POSTS_GRAPH)  
}

License

Copyright (c) 2021 Jeziel Lago  
  
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.  

About

Android multi-module navigation built on top of Jetpack Navigation Compose

License:MIT License


Languages

Language:Kotlin 100.0%