Cleanup MangaScreenModel successState usage (#9582)
* Refactor updateSuccessState - Convert to inline function - Use when for type safety if we add other MangaScreenState types * Replace equivalent expressions with updateSuccessState * Replace safe cast in MangaScreen
This commit is contained in:
parent
0d9f8e8743
commit
cf777d9893
2 changed files with 21 additions and 53 deletions
|
@ -134,7 +134,7 @@ class MangaScreen(
|
||||||
)
|
)
|
||||||
|
|
||||||
val onDismissRequest = { screenModel.dismissDialog() }
|
val onDismissRequest = { screenModel.dismissDialog() }
|
||||||
when (val dialog = (state as? MangaScreenState.Success)?.dialog) {
|
when (val dialog = successState.dialog) {
|
||||||
null -> {}
|
null -> {}
|
||||||
is MangaInfoScreenModel.Dialog.ChangeCategory -> {
|
is MangaInfoScreenModel.Dialog.ChangeCategory -> {
|
||||||
ChangeCategoryDialog(
|
ChangeCategoryDialog(
|
||||||
|
|
|
@ -135,8 +135,13 @@ class MangaInfoScreenModel(
|
||||||
/**
|
/**
|
||||||
* Helper function to update the UI state only if it's currently in success state
|
* Helper function to update the UI state only if it's currently in success state
|
||||||
*/
|
*/
|
||||||
private fun updateSuccessState(func: (MangaScreenState.Success) -> MangaScreenState.Success) {
|
private inline fun updateSuccessState(func: (MangaScreenState.Success) -> MangaScreenState.Success) {
|
||||||
mutableState.update { if (it is MangaScreenState.Success) func(it) else it }
|
mutableState.update {
|
||||||
|
when (it) {
|
||||||
|
MangaScreenState.Loading -> it
|
||||||
|
is MangaScreenState.Success -> func(it)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
init {
|
init {
|
||||||
|
@ -278,12 +283,7 @@ class MangaInfoScreenModel(
|
||||||
val duplicate = getDuplicateLibraryManga.await(manga.title)
|
val duplicate = getDuplicateLibraryManga.await(manga.title)
|
||||||
|
|
||||||
if (duplicate != null) {
|
if (duplicate != null) {
|
||||||
mutableState.update { state ->
|
updateSuccessState { it.copy(dialog = Dialog.DuplicateManga(manga, duplicate)) }
|
||||||
when (state) {
|
|
||||||
MangaScreenState.Loading -> state
|
|
||||||
is MangaScreenState.Success -> state.copy(dialog = Dialog.DuplicateManga(manga, duplicate))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return@launchIO
|
return@launchIO
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -340,16 +340,13 @@ class MangaInfoScreenModel(
|
||||||
coroutineScope.launch {
|
coroutineScope.launch {
|
||||||
val categories = getCategories()
|
val categories = getCategories()
|
||||||
val selection = getMangaCategoryIds(manga)
|
val selection = getMangaCategoryIds(manga)
|
||||||
mutableState.update { state ->
|
updateSuccessState { successState ->
|
||||||
when (state) {
|
successState.copy(
|
||||||
MangaScreenState.Loading -> state
|
dialog = Dialog.ChangeCategory(
|
||||||
is MangaScreenState.Success -> state.copy(
|
manga = manga,
|
||||||
dialog = Dialog.ChangeCategory(
|
initialSelection = categories.mapAsCheckboxState { it.id in selection },
|
||||||
manga = manga,
|
),
|
||||||
initialSelection = categories.mapAsCheckboxState { it.id in selection },
|
)
|
||||||
),
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -954,52 +951,23 @@ class MangaInfoScreenModel(
|
||||||
}
|
}
|
||||||
|
|
||||||
fun dismissDialog() {
|
fun dismissDialog() {
|
||||||
mutableState.update { state ->
|
updateSuccessState { it.copy(dialog = null) }
|
||||||
when (state) {
|
|
||||||
MangaScreenState.Loading -> state
|
|
||||||
is MangaScreenState.Success -> state.copy(dialog = null)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fun showDeleteChapterDialog(chapters: List<Chapter>) {
|
fun showDeleteChapterDialog(chapters: List<Chapter>) {
|
||||||
mutableState.update { state ->
|
updateSuccessState { it.copy(dialog = Dialog.DeleteChapters(chapters)) }
|
||||||
when (state) {
|
|
||||||
MangaScreenState.Loading -> state
|
|
||||||
is MangaScreenState.Success -> state.copy(dialog = Dialog.DeleteChapters(chapters))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fun showSettingsDialog() {
|
fun showSettingsDialog() {
|
||||||
mutableState.update { state ->
|
updateSuccessState { it.copy(dialog = Dialog.SettingsSheet) }
|
||||||
when (state) {
|
|
||||||
MangaScreenState.Loading -> state
|
|
||||||
is MangaScreenState.Success -> state.copy(dialog = Dialog.SettingsSheet)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fun showTrackDialog() {
|
fun showTrackDialog() {
|
||||||
mutableState.update { state ->
|
updateSuccessState { it.copy(dialog = Dialog.TrackSheet) }
|
||||||
when (state) {
|
|
||||||
MangaScreenState.Loading -> state
|
|
||||||
is MangaScreenState.Success -> {
|
|
||||||
state.copy(dialog = Dialog.TrackSheet)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fun showCoverDialog() {
|
fun showCoverDialog() {
|
||||||
mutableState.update { state ->
|
updateSuccessState { it.copy(dialog = Dialog.FullCover) }
|
||||||
when (state) {
|
|
||||||
MangaScreenState.Loading -> state
|
|
||||||
is MangaScreenState.Success -> {
|
|
||||||
state.copy(dialog = Dialog.FullCover)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Reference in a new issue