From b212f8233e2d3ceffaddc5fcd1ef884e137dae2a Mon Sep 17 00:00:00 2001 From: Jay Date: Fri, 7 Feb 2020 04:33:55 -0800 Subject: [PATCH] Unread sorting now always shows unread on top --- .../data/database/models/Category.kt | 13 +++++++ .../tachiyomi/ui/library/LibraryPresenter.kt | 37 +++++++++++++++---- 2 files changed, 43 insertions(+), 7 deletions(-) diff --git a/app/src/main/java/eu/kanade/tachiyomi/data/database/models/Category.kt b/app/src/main/java/eu/kanade/tachiyomi/data/database/models/Category.kt index 1991e74bb6..ecf8988560 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/data/database/models/Category.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/data/database/models/Category.kt @@ -21,7 +21,20 @@ interface Category : Serializable { val nameLower: String get() = name.toLowerCase() + fun isAscending(): Boolean { + return ((mangaSort?.minus('a') ?: 0) % 2) != 1 + } + companion object { + const val ALPHA_ASC = 'a' + const val ALPHA_DSC = 'b' + const val UPDATED_ASC = 'c' + const val UPDATED_DSC = 'd' + const val UNREAD_ASC = 'e' + const val UNREAD_DSC = 'f' + const val LAST_READ_ASC = 'g' + const val LAST_READ_DSC = 'h' + fun create(name: String): Category = CategoryImpl().apply { this.name = name diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibraryPresenter.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibraryPresenter.kt index 2b0fa3b32f..8094a6ca8f 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibraryPresenter.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibraryPresenter.kt @@ -5,6 +5,14 @@ import com.jakewharton.rxrelay.BehaviorRelay import eu.kanade.tachiyomi.data.cache.CoverCache import eu.kanade.tachiyomi.data.database.DatabaseHelper import eu.kanade.tachiyomi.data.database.models.Category +import eu.kanade.tachiyomi.data.database.models.Category.Companion.ALPHA_ASC +import eu.kanade.tachiyomi.data.database.models.Category.Companion.ALPHA_DSC +import eu.kanade.tachiyomi.data.database.models.Category.Companion.LAST_READ_ASC +import eu.kanade.tachiyomi.data.database.models.Category.Companion.LAST_READ_DSC +import eu.kanade.tachiyomi.data.database.models.Category.Companion.UNREAD_ASC +import eu.kanade.tachiyomi.data.database.models.Category.Companion.UNREAD_DSC +import eu.kanade.tachiyomi.data.database.models.Category.Companion.UPDATED_ASC +import eu.kanade.tachiyomi.data.database.models.Category.Companion.UPDATED_DSC import eu.kanade.tachiyomi.data.database.models.Manga import eu.kanade.tachiyomi.data.database.models.MangaCategory import eu.kanade.tachiyomi.data.download.DownloadManager @@ -221,7 +229,13 @@ class LibraryPresenter( manga1LastRead.compareTo(manga2LastRead) } LibrarySort.LAST_UPDATED -> i2.manga.last_update.compareTo(i1.manga.last_update) - LibrarySort.UNREAD -> i1.manga.unread.compareTo(i2.manga.unread) + LibrarySort.UNREAD -> + when { + i1.manga.unread == i2.manga.unread -> 0 + i1.manga.unread == 0 -> if (ascending) 1 else -1 + i2.manga.unread == 0 -> if (ascending) -1 else 1 + else -> i1.manga.unread.compareTo(i2.manga.unread) + } LibrarySort.TOTAL -> { val manga1TotalChapter = totalChapterManga[i1.manga.id!!] ?: 0 val mange2TotalChapter = totalChapterManga[i2.manga.id!!] ?: 0 @@ -233,17 +247,26 @@ class LibraryPresenter( when { category?.mangaSort != null -> { var sort = when (category.mangaSort) { - 'a', 'b' -> sortAlphabetical(i1, i2) - 'c', 'd' -> i2.manga.last_update.compareTo(i1.manga.last_update) - 'e', 'f' -> i2.manga.unread.compareTo(i1.manga.unread) - 'g', 'h' -> { + ALPHA_ASC, ALPHA_DSC -> sortAlphabetical(i1, i2) + UPDATED_ASC, UPDATED_DSC -> + i2.manga.last_update.compareTo(i1.manga.last_update) + UNREAD_ASC, UNREAD_DSC -> + when { + i1.manga.unread == i2.manga.unread -> 0 + i1.manga.unread == 0 -> + if (category.isAscending()) 1 else -1 + i2.manga.unread == 0 -> + if (category.isAscending()) -1 else 1 + else -> i1.manga.unread.compareTo(i2.manga.unread) + } + LAST_READ_ASC, LAST_READ_DSC -> { val manga1LastRead = lastReadManga[i1.manga.id!!] ?: lastReadManga.size val manga2LastRead = lastReadManga[i2.manga.id!!] ?: lastReadManga.size manga1LastRead.compareTo(manga2LastRead) } else -> sortAlphabetical(i1, i2) } - if ((category.mangaSort?.minus('a')) ?: 0 % 2 == 1 ) + if (!category.isAscending()) sort *= -1 sort } @@ -260,7 +283,7 @@ class LibraryPresenter( else -> 0 } } - else { + else { val category = catListing.find { it.id == i1.manga.category }?.order ?: -1 val category2 = catListing.find { it.id == i2.manga.category }?.order ?: -1 category.compareTo(category2)