|  | @@ -213,20 +213,19 @@ class MangaInfoScreenModel(
 | 
	
		
			
				|  |  |       * Fetch manga information from source.
 | 
	
		
			
				|  |  |       */
 | 
	
		
			
				|  |  |      private suspend fun fetchMangaFromSource(manualFetch: Boolean = false) {
 | 
	
		
			
				|  |  | -        withIOContext {
 | 
	
		
			
				|  |  | -            try {
 | 
	
		
			
				|  |  | -                successState?.let {
 | 
	
		
			
				|  |  | -                    val networkManga = it.source.getMangaDetails(it.manga.toSManga())
 | 
	
		
			
				|  |  | -                    updateManga.awaitUpdateFromSource(it.manga, networkManga, manualFetch)
 | 
	
		
			
				|  |  | -                }
 | 
	
		
			
				|  |  | -            } catch (e: Throwable) {
 | 
	
		
			
				|  |  | -                withUIContext {
 | 
	
		
			
				|  |  | -                    // Ignore early hints "errors" that aren't handled by OkHttp
 | 
	
		
			
				|  |  | -                    if (e !is HttpException || e.code != 103) {
 | 
	
		
			
				|  |  | -                        snackbarHostState.showSnackbar(message = "${e.message}")
 | 
	
		
			
				|  |  | -                        logcat(LogPriority.ERROR, e)
 | 
	
		
			
				|  |  | -                    }
 | 
	
		
			
				|  |  | -                }
 | 
	
		
			
				|  |  | +        val state = successState ?: return
 | 
	
		
			
				|  |  | +        try {
 | 
	
		
			
				|  |  | +            withIOContext {
 | 
	
		
			
				|  |  | +                val networkManga = state.source.getMangaDetails(state.manga.toSManga())
 | 
	
		
			
				|  |  | +                updateManga.awaitUpdateFromSource(state.manga, networkManga, manualFetch)
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +        } catch (e: Throwable) {
 | 
	
		
			
				|  |  | +            // Ignore early hints "errors" that aren't handled by OkHttp
 | 
	
		
			
				|  |  | +            if (e is HttpException && e.code == 103) return
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +            logcat(LogPriority.ERROR, e)
 | 
	
		
			
				|  |  | +            coroutineScope.launch {
 | 
	
		
			
				|  |  | +                snackbarHostState.showSnackbar(message = e.toString())
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |      }
 | 
	
	
		
			
				|  | @@ -524,31 +523,32 @@ class MangaInfoScreenModel(
 | 
	
		
			
				|  |  |       * Requests an updated list of chapters from the source.
 | 
	
		
			
				|  |  |       */
 | 
	
		
			
				|  |  |      private suspend fun fetchChaptersFromSource(manualFetch: Boolean = false) {
 | 
	
		
			
				|  |  | -        withIOContext {
 | 
	
		
			
				|  |  | -            try {
 | 
	
		
			
				|  |  | -                successState?.let { successState ->
 | 
	
		
			
				|  |  | -                    val chapters = successState.source.getChapterList(successState.manga.toSManga())
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -                    val newChapters = syncChaptersWithSource.await(
 | 
	
		
			
				|  |  | -                        chapters,
 | 
	
		
			
				|  |  | -                        successState.manga,
 | 
	
		
			
				|  |  | -                        successState.source,
 | 
	
		
			
				|  |  | -                    )
 | 
	
		
			
				|  |  | +        val state = successState ?: return
 | 
	
		
			
				|  |  | +        try {
 | 
	
		
			
				|  |  | +            withIOContext {
 | 
	
		
			
				|  |  | +                val chapters = state.source.getChapterList(state.manga.toSManga())
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +                val newChapters = syncChaptersWithSource.await(
 | 
	
		
			
				|  |  | +                    chapters,
 | 
	
		
			
				|  |  | +                    state.manga,
 | 
	
		
			
				|  |  | +                    state.source,
 | 
	
		
			
				|  |  | +                )
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -                    if (manualFetch) {
 | 
	
		
			
				|  |  | -                        downloadNewChapters(newChapters)
 | 
	
		
			
				|  |  | -                    }
 | 
	
		
			
				|  |  | -                }
 | 
	
		
			
				|  |  | -            } catch (e: Throwable) {
 | 
	
		
			
				|  |  | -                withUIContext {
 | 
	
		
			
				|  |  | -                    if (e is NoChaptersException) {
 | 
	
		
			
				|  |  | -                        snackbarHostState.showSnackbar(message = context.getString(R.string.no_chapters_error))
 | 
	
		
			
				|  |  | -                    } else {
 | 
	
		
			
				|  |  | -                        snackbarHostState.showSnackbar(message = "${e.message}")
 | 
	
		
			
				|  |  | -                        logcat(LogPriority.ERROR, e)
 | 
	
		
			
				|  |  | -                    }
 | 
	
		
			
				|  |  | +                if (manualFetch) {
 | 
	
		
			
				|  |  | +                    downloadNewChapters(newChapters)
 | 
	
		
			
				|  |  |                  }
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  | +        } catch (e: Throwable) {
 | 
	
		
			
				|  |  | +            val message = if (e is NoChaptersException) {
 | 
	
		
			
				|  |  | +                context.getString(R.string.no_chapters_error)
 | 
	
		
			
				|  |  | +            } else {
 | 
	
		
			
				|  |  | +                logcat(LogPriority.ERROR, e)
 | 
	
		
			
				|  |  | +                e.toString()
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +            coroutineScope.launch {
 | 
	
		
			
				|  |  | +                snackbarHostState.showSnackbar(message = message)
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 |