|
@@ -1,11 +1,11 @@
|
|
|
package eu.kanade.tachiyomi.ui.library
|
|
|
|
|
|
import android.content.Context
|
|
|
-import androidx.recyclerview.widget.LinearLayoutManager
|
|
|
-import androidx.recyclerview.widget.RecyclerView
|
|
|
import android.util.AttributeSet
|
|
|
import android.view.View
|
|
|
import android.widget.FrameLayout
|
|
|
+import androidx.recyclerview.widget.LinearLayoutManager
|
|
|
+import androidx.recyclerview.widget.RecyclerView
|
|
|
import eu.davidea.flexibleadapter.FlexibleAdapter
|
|
|
import eu.davidea.flexibleadapter.SelectableAdapter
|
|
|
import eu.kanade.tachiyomi.R
|
|
@@ -18,8 +18,8 @@ import eu.kanade.tachiyomi.util.inflate
|
|
|
import eu.kanade.tachiyomi.util.plusAssign
|
|
|
import eu.kanade.tachiyomi.util.toast
|
|
|
import eu.kanade.tachiyomi.widget.AutofitRecyclerView
|
|
|
-import kotlinx.android.synthetic.main.chapters_controller.fast_scroller
|
|
|
-import kotlinx.android.synthetic.main.library_category.view.*
|
|
|
+import kotlinx.android.synthetic.main.library_category.view.fast_scroller
|
|
|
+import kotlinx.android.synthetic.main.library_category.view.swipe_refresh
|
|
|
import rx.subscriptions.CompositeSubscription
|
|
|
import uy.kohesive.injekt.injectLazy
|
|
|
|
|
@@ -62,6 +62,8 @@ class LibraryCategoryView @JvmOverloads constructor(context: Context, attrs: Att
|
|
|
*/
|
|
|
private var subscriptions = CompositeSubscription()
|
|
|
|
|
|
+ private var lastClickPosition = -1
|
|
|
+
|
|
|
fun onCreate(controller: LibraryController) {
|
|
|
this.controller = controller
|
|
|
|
|
@@ -174,6 +176,7 @@ class LibraryCategoryView @JvmOverloads constructor(context: Context, attrs: Att
|
|
|
}
|
|
|
is LibrarySelectionEvent.Unselected -> {
|
|
|
findAndToggleSelection(event.manga)
|
|
|
+ if (adapter.indexOf(event.manga) != -1) lastClickPosition = -1
|
|
|
if (controller.selectedMangas.isEmpty()) {
|
|
|
adapter.mode = SelectableAdapter.Mode.SINGLE
|
|
|
}
|
|
@@ -181,6 +184,7 @@ class LibraryCategoryView @JvmOverloads constructor(context: Context, attrs: Att
|
|
|
is LibrarySelectionEvent.Cleared -> {
|
|
|
adapter.mode = SelectableAdapter.Mode.SINGLE
|
|
|
adapter.clearSelection()
|
|
|
+ lastClickPosition = -1
|
|
|
}
|
|
|
}
|
|
|
}
|
|
@@ -204,10 +208,11 @@ class LibraryCategoryView @JvmOverloads constructor(context: Context, attrs: Att
|
|
|
* @param position the position of the element clicked.
|
|
|
* @return true if the item should be selected, false otherwise.
|
|
|
*/
|
|
|
- override fun onItemClick(view: View, position: Int): Boolean {
|
|
|
+ override fun onItemClick(view: View?, position: Int): Boolean {
|
|
|
// If the action mode is created and the position is valid, toggle the selection.
|
|
|
val item = adapter.getItem(position) ?: return false
|
|
|
if (adapter.mode == SelectableAdapter.Mode.MULTI) {
|
|
|
+ lastClickPosition = position
|
|
|
toggleSelection(position)
|
|
|
return true
|
|
|
} else {
|
|
@@ -223,7 +228,15 @@ class LibraryCategoryView @JvmOverloads constructor(context: Context, attrs: Att
|
|
|
*/
|
|
|
override fun onItemLongClick(position: Int) {
|
|
|
controller.createActionModeIfNeeded()
|
|
|
- toggleSelection(position)
|
|
|
+ when {
|
|
|
+ lastClickPosition == -1 -> setSelection(position)
|
|
|
+ lastClickPosition > position -> for (i in position until lastClickPosition)
|
|
|
+ setSelection(i)
|
|
|
+ lastClickPosition < position -> for (i in lastClickPosition + 1..position)
|
|
|
+ setSelection(i)
|
|
|
+ else -> setSelection(position)
|
|
|
+ }
|
|
|
+ lastClickPosition = position
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -247,4 +260,17 @@ class LibraryCategoryView @JvmOverloads constructor(context: Context, attrs: Att
|
|
|
controller.invalidateActionMode()
|
|
|
}
|
|
|
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Tells the presenter to set the selection for the given position.
|
|
|
+ *
|
|
|
+ * @param position the position to toggle.
|
|
|
+ */
|
|
|
+ private fun setSelection(position: Int) {
|
|
|
+ val item = adapter.getItem(position) ?: return
|
|
|
+
|
|
|
+ controller.setSelection(item.manga, true)
|
|
|
+ controller.invalidateActionMode()
|
|
|
+ }
|
|
|
+
|
|
|
}
|