Fixed fast scroll when category above is collasped

This commit is contained in:
Jay 2020-05-04 23:45:42 -04:00
parent ee2df0f87a
commit 4bc44b22f6

View File

@ -303,6 +303,10 @@ class LibraryController(
} }
} }
appbar?.y = 0f appbar?.y = 0f
val item = adapter.getItem(itemPosition)
if (item is LibraryHeaderItem) {
scrollToHeader(item.category.order)
} else {
recycler.suppressLayout(true) recycler.suppressLayout(true)
(recycler.layoutManager as LinearLayoutManager).scrollToPositionWithOffset( (recycler.layoutManager as LinearLayoutManager).scrollToPositionWithOffset(
itemPosition, if (adapter.isSingleCategory) { itemPosition, if (adapter.isSingleCategory) {
@ -318,6 +322,7 @@ class LibraryController(
recycler.suppressLayout(false) recycler.suppressLayout(false)
} }
} }
}
recycler.addOnScrollListener(scrollListener) recycler.addOnScrollListener(scrollListener)
val tv = TypedValue() val tv = TypedValue()
@ -653,8 +658,13 @@ class LibraryController(
val appbarOffset = if (appbar?.y ?: 0f > -20) 0 else (appbar?.y?.plus( val appbarOffset = if (appbar?.y ?: 0f > -20) 0 else (appbar?.y?.plus(
view?.rootWindowInsets?.systemWindowInsetTop ?: 0 view?.rootWindowInsets?.systemWindowInsetTop ?: 0
) ?: 0f).roundToInt() + 30.dpToPx ) ?: 0f).roundToInt() + 30.dpToPx
val previousHeader = adapter.getItem(adapter.indexOf(pos - 1)) as? LibraryHeaderItem
(recycler.layoutManager as LinearLayoutManager).scrollToPositionWithOffset( (recycler.layoutManager as LinearLayoutManager).scrollToPositionWithOffset(
headerPosition, (if (headerPosition == 0) 0 else (-32).dpToPx) + appbarOffset headerPosition, (when {
headerPosition == 0 -> 0
previousHeader?.category?.isHidden == true -> (-3).dpToPx
else -> (-32).dpToPx
}) + appbarOffset
) )
recycler.suppressLayout(false) recycler.suppressLayout(false)
} }