Pablo
01/04/2025, 8:39 PMPablo
01/04/2025, 8:40 PMval appStateHolder = rememberAppStateHolder()
@Composable
fun rememberAppStateHolder(
navController: NavHostController = rememberNavController(),
dialogTitle: StringResource? = null,
dialogMessage: StringResource? = null,
): AppStateHolder {
return remember(
navController,
dialogTitle,
dialogMessage
) {
AppStateHolder(
navController = navController,
dialogTitle = dialogTitle,
dialogMessage = dialogMessage
)
}
}
@Stable
class AppStateHolder(
val navController: NavHostController = NavHostController(),
var dialogTitle: StringResource? = null,
var dialogMessage: StringResource? = null
) {
// UI State
val currentDestination: NavDestination?
@Composable get() = navController
.currentBackStackEntryAsState().value?.destination
fun isDialogEnabled(): Boolean {
return (dialogTitle != null || dialogMessage != null)
}
// UI logic
fun navigate(route: String) {
navController.navigate(route)
}
fun showDialog(dialogTitle: StringResource, dialogMessage: StringResource) {
this.dialogTitle = dialogTitle
this.dialogMessage = dialogMessage
}
fun hideDialog() {
this.dialogTitle = null
this.dialogMessage = null
}
}
This is how I check if the dialog should be displayed:
if (appStateHolder.isDialogEnabled()) {
MessageDialog(
title = stringResource(Res.string.about),
message = stringResource(Res.string.about_message),
onCloseRequest = { appStateHolder.hideDialog() }
)
}
This is how I set the dialog values to different of null:
appStateHolder.showDialog(title, message)
Zach Klippenstein (he/him) [MOD]
01/04/2025, 10:24 PMPablo
01/04/2025, 10:55 PMZach Klippenstein (he/him) [MOD]
01/04/2025, 11:12 PM