/ViewModelNavigationCompose

Fork of the orginal repo to bring uptodate and swap out Hilt for Koin to see if it works as expected

Primary LanguageKotlin

Compose Navigation triggered from ViewModel

An tiny example app build with Jetpack Compose in which navigation is triggered from the ViewModel.

This example implements logic so that the ViewModel can call navigate(route), navigateUp() and popUpto(route). This example abstracts away most navigation logic from the View and ViewModel. We use state to navigate, but one could use events if prefered.

Alternatives

Singleton Navigation Manager

Joe Birch describes a singleton navigation manager. This implementation is simpler. However, a vulnerability of this singleton navigator is that any ViewModel (and any other class) can trigger navigation. This can cause Viewmodels in the backstack to start navigation, for example after an async action finishes. You could cause hard-to-find bugs this way.

View in Charge

An alternative to ViewModel-controlled-navigation is to let the View control and start navigation. However, that would often mean that the View must wait on the ViewModel to finish something async before navigating. It results in a state of thruth that lies inbetween ViewModel and View, instead of solely in the ViewModel.

Events up, state down

'Events up, state down' is Google's suggested way of communicating from ViewModel to View. This is what is used here, though the same logic can easily be used with events.

'Events up, state down' means that from the View to te ViewModel we communicate using events / functions like (onXClicked). From the ViewModel to the View we expose (View)State only. In our case, this requires a callback from the View to the ViewModel to notify that the navigation has been done and state should be updated. This is needed, sadly, because the (Jetpack Compose) navigation library uses events, not state.

To use this in your project

Copy paste these classes into your project:

Then use them: