From 31d96c2bf0a2ae87978bd4c2774eed0cf050e6ec Mon Sep 17 00:00:00 2001 From: Ivan Iskandar <12537387+ivaniskandar@users.noreply.github.com> Date: Tue, 8 Jun 2021 22:18:56 +0700 Subject: [PATCH] Fix download status not updated properly after starting batch download (#5348) --- .../main/java/eu/kanade/tachiyomi/ui/manga/MangaPresenter.kt | 4 ++-- .../kanade/tachiyomi/ui/manga/chapter/ChapterDownloadView.kt | 3 +-- .../eu/kanade/tachiyomi/ui/recent/updates/UpdatesPresenter.kt | 4 ++-- 3 files changed, 5 insertions(+), 6 deletions(-) diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaPresenter.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaPresenter.kt index 9ef77d136..e8b643394 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaPresenter.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/MangaPresenter.kt @@ -359,7 +359,7 @@ class MangaPresenter( observeDownloadsStatusSubscription?.let { remove(it) } observeDownloadsStatusSubscription = downloadManager.queue.getStatusObservable() .observeOn(Schedulers.io()) - .onBackpressureLatest() + .onBackpressureBuffer() .filter { download -> download.manga.id == manga.id } .observeOn(AndroidSchedulers.mainThread()) .subscribeLatestCache( @@ -375,7 +375,7 @@ class MangaPresenter( observeDownloadsPageSubscription?.let { remove(it) } observeDownloadsPageSubscription = downloadManager.queue.getProgressObservable() .observeOn(Schedulers.io()) - .onBackpressureLatest() + .onBackpressureBuffer() .filter { download -> download.manga.id == manga.id } .observeOn(AndroidSchedulers.mainThread()) .subscribeLatestCache(MangaController::onChapterDownloadUpdate) { _, error -> diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/chapter/ChapterDownloadView.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/chapter/ChapterDownloadView.kt index e056e0ad8..25049319d 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/manga/chapter/ChapterDownloadView.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/manga/chapter/ChapterDownloadView.kt @@ -48,8 +48,6 @@ class ChapterDownloadView @JvmOverloads constructor(context: Context, attrs: Att state == Download.State.NOT_DOWNLOADED || state == Download.State.QUEUE if (shouldBeVisible) { hideAnimationBehavior = BaseProgressIndicator.HIDE_NONE - show() - if (state == Download.State.NOT_DOWNLOADED || state == Download.State.QUEUE) { trackThickness = 2.dpToPx setIndicatorColor(context.getThemeColor(android.R.attr.textColorHint)) @@ -72,6 +70,7 @@ class ChapterDownloadView @JvmOverloads constructor(context: Context, attrs: Att setIndicatorColor(context.getThemeColor(android.R.attr.textColorPrimary)) setProgressCompat(progress, true) } + show() } else { hideAnimationBehavior = BaseProgressIndicator.HIDE_OUTWARD hide() diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/recent/updates/UpdatesPresenter.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/recent/updates/UpdatesPresenter.kt index d44af094c..2ba0c7dfa 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/recent/updates/UpdatesPresenter.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/recent/updates/UpdatesPresenter.kt @@ -41,7 +41,7 @@ class UpdatesPresenter( downloadManager.queue.getStatusObservable() .observeOn(Schedulers.io()) - .onBackpressureLatest() + .onBackpressureBuffer() .observeOn(AndroidSchedulers.mainThread()) .subscribeLatestCache( { view, it -> @@ -55,7 +55,7 @@ class UpdatesPresenter( downloadManager.queue.getProgressObservable() .observeOn(Schedulers.io()) - .onBackpressureLatest() + .onBackpressureBuffer() .observeOn(AndroidSchedulers.mainThread()) .subscribeLatestCache(UpdatesController::onChapterDownloadUpdate) { _, error -> Timber.e(error)