浏览代码

Library sort change doesn't trigger filtering

len 8 年之前
父节点
当前提交
36bbb906c1

+ 2 - 2
app/src/main/java/eu/kanade/tachiyomi/ui/library/LibraryFragment.kt

@@ -275,7 +275,7 @@ class LibraryFragment : BaseRxFragment<LibraryPresenter>(), ActionMode.Callback
      * Called when a filter is changed.
      */
     private fun onFilterChanged() {
-        presenter.requestLibraryUpdate()
+        presenter.requestFilterUpdate()
         activity.supportInvalidateOptionsMenu()
     }
 
@@ -283,7 +283,7 @@ class LibraryFragment : BaseRxFragment<LibraryPresenter>(), ActionMode.Callback
      * Called when the sorting mode is changed.
      */
     private fun onSortChanged() {
-        presenter.requestLibraryUpdate()
+        presenter.requestSortUpdate()
     }
 
     /**

+ 54 - 41
app/src/main/java/eu/kanade/tachiyomi/ui/library/LibraryPresenter.kt

@@ -15,6 +15,7 @@ import eu.kanade.tachiyomi.data.preference.PreferencesHelper
 import eu.kanade.tachiyomi.data.preference.getOrDefault
 import eu.kanade.tachiyomi.data.source.SourceManager
 import eu.kanade.tachiyomi.ui.base.presenter.BasePresenter
+import eu.kanade.tachiyomi.util.combineLatest
 import eu.kanade.tachiyomi.util.isNullOrUnsubscribed
 import rx.Observable
 import rx.Subscription
@@ -83,12 +84,12 @@ class LibraryPresenter : BasePresenter<LibraryFragment>() {
     /**
      * Relay used to apply the UI filters to the last emission of the library.
      */
-    private val updateTriggerRelay = BehaviorRelay.create(Unit)
+    private val filterTriggerRelay = BehaviorRelay.create(Unit)
 
     /**
-     * Value that contains library sorted by last read
+     * Relay used to apply the selected sorting method to the last emission of the library.
      */
-    private lateinit var lastReadManga: Map<Long, Int>
+    private val sortTriggerRelay = BehaviorRelay.create(Unit)
 
     /**
      * Library subscription.
@@ -105,16 +106,23 @@ class LibraryPresenter : BasePresenter<LibraryFragment>() {
      */
     fun subscribeLibrary() {
         if (librarySubscription.isNullOrUnsubscribed()) {
-            librarySubscription = Observable.combineLatest(getLibraryObservable(),
-                    updateTriggerRelay.observeOn(Schedulers.io()),
-                    { library, updateTrigger -> library })
-                    .map { Pair(it.first, applyFilters(it.second)) }
+            librarySubscription = getLibraryObservable()
+                    .combineLatest(filterTriggerRelay.observeOn(Schedulers.io()),
+                            { lib, tick -> Pair(lib.first, applyFilters(lib.second)) })
+                    .combineLatest(sortTriggerRelay.observeOn(Schedulers.io()),
+                            { lib, tick -> Pair(lib.first, applySort(lib.second)) })
                     .observeOn(AndroidSchedulers.mainThread())
-                    .subscribeLatestCache(
-                            { view, pair -> view.onNextLibraryUpdate(pair.first, pair.second) })
+                    .subscribeLatestCache({ view, pair ->
+                        view.onNextLibraryUpdate(pair.first, pair.second)
+                    })
         }
     }
 
+    /**
+     * Applies library filters to the given map of manga.
+     *
+     * @param map the map to filter.
+     */
     private fun applyFilters(map: Map<Int, List<Manga>>): Map<Int, List<Manga>> {
         // Cached list of downloaded manga directories given a source id.
         val mangaDirectories = mutableMapOf<Int, Array<UniFile>>()
@@ -126,7 +134,7 @@ class LibraryPresenter : BasePresenter<LibraryFragment>() {
 
         val filterUnread = preferences.filterUnread().getOrDefault()
 
-        val filterFn: (Manga) -> Boolean = f@ { manga: Manga ->
+        val filterFn: (Manga) -> Boolean = f@ { manga ->
             // Filter out manga without source.
             val source = sourceManager.get(manga.source) ?: return@f false
 
@@ -154,24 +162,46 @@ class LibraryPresenter : BasePresenter<LibraryFragment>() {
             true
         }
 
-        // Sorting
+        return map.mapValues { entry -> entry.value.filter(filterFn) }
+    }
+
+    /**
+     * Applies library sorting to the given map of manga.
+     *
+     * @param map the map to sort.
+     */
+    private fun applySort(map: Map<Int, List<Manga>>): Map<Int, List<Manga>> {
         val sortingMode = preferences.librarySortingMode().getOrDefault()
+
+        // TODO lazy initialization in kotlin 1.1
+        var lastReadManga: Map<Long, Int>? = null
         if (sortingMode == LibrarySort.LAST_READ) {
             var counter = 0
             lastReadManga = db.getLastReadManga().executeAsBlocking()
                     .associate { it.id!! to counter++ }
         }
 
-        val comparator: Comparator<Manga> = if (preferences.librarySortingAscending().getOrDefault())
-            Comparator { m1, m2 -> sortManga(sortingMode, m1, m2) }
+        val sortFn: (Manga, Manga) -> Int = { manga1, manga2 ->
+            when (sortingMode) {
+                LibrarySort.ALPHA -> manga1.title.compareTo(manga2.title)
+                LibrarySort.LAST_READ -> {
+                    // Get index of manga, set equal to list if size unknown.
+                    val manga1LastRead = lastReadManga!![manga1.id!!] ?: lastReadManga!!.size
+                    val manga2LastRead = lastReadManga!![manga2.id!!] ?: lastReadManga!!.size
+                    manga1LastRead.compareTo(manga2LastRead)
+                }
+                LibrarySort.LAST_UPDATED -> manga2.last_update.compareTo(manga1.last_update)
+                LibrarySort.UNREAD -> manga1.unread.compareTo(manga2.unread)
+                else -> throw Exception("Unknown sorting mode")
+            }
+        }
+
+        val comparator = if (preferences.librarySortingAscending().getOrDefault())
+            Comparator(sortFn)
         else
-            Comparator { m1, m2 -> sortManga(sortingMode, m2, m1) }
+            Collections.reverseOrder(sortFn)
 
-        return map.mapValues { entry ->
-            entry.value
-                    .filter(filterFn)
-                    .sortedWith(comparator)
-        }
+        return map.mapValues { entry -> entry.value.sortedWith(comparator) }
     }
 
     /**
@@ -215,32 +245,15 @@ class LibraryPresenter : BasePresenter<LibraryFragment>() {
     /**
      * Requests the library to be filtered.
      */
-    fun requestLibraryUpdate() {
-        updateTriggerRelay.call(Unit)
+    fun requestFilterUpdate() {
+        filterTriggerRelay.call(Unit)
     }
 
     /**
-     * Compares the two manga determined by sorting mode.
-     * Returns zero if this object is equal to the specified other object,
-     * a negative number if it's less than other, or a positive number if it's greater than other.
-     *
-     * @param sortingMode current sorting mode
-     * @param manga1 first manga to compare
-     * @param manga2 second manga to compare
+     * Requests the library to be sorted.
      */
-    fun sortManga(sortingMode: Int, manga1: Manga, manga2: Manga): Int {
-        return when (sortingMode) {
-            LibrarySort.ALPHA -> manga1.title.compareTo(manga2.title)
-            LibrarySort.LAST_READ -> {
-                // Get index of manga, set equal to list if size unknown.
-                val manga1LastRead = lastReadManga.getOrElse(manga1.id!!, { lastReadManga.size })
-                val manga2LastRead = lastReadManga.getOrElse(manga2.id!!, { lastReadManga.size })
-                manga1LastRead.compareTo(manga2LastRead)
-            }
-            LibrarySort.LAST_UPDATED -> manga2.last_update.compareTo(manga1.last_update)
-            LibrarySort.UNREAD -> manga1.unread.compareTo(manga2.unread)
-            else -> throw Exception("Unknown sorting mode")
-        }
+    fun requestSortUpdate() {
+        sortTriggerRelay.call(Unit)
     }
 
     /**

+ 1 - 1
app/src/main/java/eu/kanade/tachiyomi/util/LocaleHelper.kt

@@ -27,7 +27,7 @@ object LocaleHelper {
         }
     }
 
-    fun updateCfg(app: Application, config: Configuration){
+    fun updateCfg(app: Application, config: Configuration) {
         if (Build.VERSION.SDK_INT < Build.VERSION_CODES.JELLY_BEAN_MR1) {
             config.locale = pLocale
             app.baseContext.resources.updateConfiguration(config, app.baseContext.resources.displayMetrics)

+ 6 - 1
app/src/main/java/eu/kanade/tachiyomi/util/RxExtensions.kt

@@ -1,8 +1,13 @@
 package eu.kanade.tachiyomi.util
 
+import rx.Observable
 import rx.Subscription
 import rx.subscriptions.CompositeSubscription
 
 fun Subscription?.isNullOrUnsubscribed() = this == null || isUnsubscribed
 
-operator fun CompositeSubscription.plusAssign(subscription: Subscription) = add(subscription)
+operator fun CompositeSubscription.plusAssign(subscription: Subscription) = add(subscription)
+
+fun <T, U, R> Observable<T>.combineLatest(o2: Observable<U>, combineFn: (T, U) -> R): Observable<R> {
+    return Observable.combineLatest(this, o2, combineFn)
+}

+ 0 - 8
app/src/main/res/raw/changelog_debug.xml

@@ -28,12 +28,4 @@
         </changelogtext>
     </changelogversion>
 
-    <changelogversion
-            changeDate=""
-            versionName="r359">
-        <changelogtext>Library sort for "last updated" will only work with manga updated after this
-            version.
-        </changelogtext>
-    </changelogversion>
-
 </changelog>