diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaScreenModel.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaScreenModel.kt index 71d43af16..0467448a9 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaScreenModel.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaScreenModel.kt @@ -402,8 +402,7 @@ class MangaInfoScreenModel( logcat(LogPriority.ERROR, e) coroutineScope.launch { - val errorMessage = e.message.orEmpty().ifEmpty { e.toString() } - snackbarHostState.showSnackbar(message = errorMessage) + snackbarHostState.showSnackbar(message = e.snackbarMessage) } } } @@ -995,7 +994,7 @@ class MangaInfoScreenModel( context.getString(R.string.no_chapters_error) } else { logcat(LogPriority.ERROR, e) - e.message.orEmpty().ifEmpty { e.toString() } + e.snackbarMessage } coroutineScope.launch { @@ -1647,6 +1646,13 @@ val chapterDecimalFormat = DecimalFormat( .apply { decimalSeparator = '.' }, ) +private val Throwable.snackbarMessage: String + get() = when (val className = this::class.simpleName) { + null -> message ?: "" + "Exception", "HttpException", "IOException" -> message ?: className + else -> "$className: $message" + } + // SY --> sealed class PagePreviewState { object Unused : PagePreviewState()