Pressing category button in hopper opens a mini category jump sheet

instead of opening backdrop
This commit is contained in:
Jay 2020-05-23 15:50:50 -04:00
parent b3069b191e
commit 2413d4c91e
5 changed files with 62 additions and 17 deletions

View File

@ -0,0 +1,19 @@
package eu.kanade.tachiyomi.ui.base
import android.content.Context
import android.util.AttributeSet
import androidx.core.widget.NestedScrollView
class MaxHeightScrollView @JvmOverloads constructor(context: Context, attrs: AttributeSet? = null) :
NestedScrollView(context, attrs) {
var maxHeight = -1
override fun onMeasure(widthMeasureSpec: Int, heightMeasureSpec: Int) {
val heightS = if (maxHeight > 0) {
MeasureSpec.makeMeasureSpec(maxHeight, MeasureSpec.AT_MOST)
} else {
heightMeasureSpec
}
super.onMeasure(widthMeasureSpec, heightS)
}
}

View File

@ -481,7 +481,19 @@ class LibraryController(
true
}
category_button.setOnClickListener {
showCategories(!recycler_cover.isClickable)
val items = presenter.categories.map { category ->
MaterialMenuSheet.MenuSheetItem(category.order, text = category.name)
}
MaterialMenuSheet(
activity!!,
items,
it.context.getString(R.string.jump_to_category),
activeCategory,
300.dpToPx
) { _, item ->
scrollToHeader(item)
true
}.show()
}
category_button.setOnLongClickListener {

View File

@ -36,6 +36,7 @@ class MaterialMenuSheet(
items: List<MenuSheetItem>,
title: String? = null,
selectedId: Int? = null,
maxHeight: Int? = null,
onMenuItemClicked: (MaterialMenuSheet, Int) -> Boolean
) :
BottomSheetDialog
@ -50,6 +51,10 @@ class MaterialMenuSheet(
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O && !context.isInNightMode() && !activity.window.decorView.rootWindowInsets.hasSideNavBar()) {
window?.decorView?.systemUiVisibility = View.SYSTEM_UI_FLAG_LIGHT_NAVIGATION_BAR
}
maxHeight?.let {
menu_scroll_view.maxHeight = it
menu_scroll_view.requestLayout()
}
var currentIndex: Int? = null
items.forEachIndexed { index, item ->
@ -76,6 +81,9 @@ class MaterialMenuSheet(
setText(item.textRes)
}
setCompoundDrawablesRelativeWithIntrinsicBounds(item.drawable, 0, 0, 0)
if (item.drawable == 0) {
textSize = 14f
}
if (item.id == selectedId) {
currentIndex = index
setTextColorRes(R.color.colorAccent)
@ -103,24 +111,28 @@ class MaterialMenuSheet(
}
}
var isNotElevated = false
var isElevated = false
var elevationAnimator: ValueAnimator? = null
if (title_layout.isVisible()) {
menu_scroll_view.setOnScrollChangeListener { _: View?, _: Int, _: Int, _: Int, _: Int ->
val atTop = !menu_scroll_view.canScrollVertically(-1)
if (atTop != isNotElevated) {
fun elevate(elevate: Boolean) {
elevationAnimator?.cancel()
isNotElevated = atTop
isElevated = elevate
elevationAnimator?.cancel()
elevationAnimator = ObjectAnimator.ofFloat(
title_layout,
"elevation",
title_layout.elevation,
if (atTop) 0f else 10f.dpToPx
title_layout, "elevation", title_layout.elevation, if (elevate) 10f else 0f
)
elevationAnimator?.duration = 100
ObjectAnimator.ofFloat(
bottom_divider, "alpha", bottom_divider.alpha, if (elevate) 0f else 1f
).start()
elevationAnimator?.start()
}
elevate(menu_scroll_view.canScrollVertically(-1))
if (title_layout.isVisible()) {
menu_scroll_view.setOnScrollChangeListener { _: View?, _: Int, _: Int, _: Int, _: Int ->
val notAtTop = menu_scroll_view.canScrollVertically(-1)
if (notAtTop != isElevated) {
elevate(notAtTop)
}
}
}
}

View File

@ -9,7 +9,7 @@
app:layout_constraintVertical_chainStyle="packed"
android:backgroundTint="?android:attr/colorBackground">
<androidx.core.widget.NestedScrollView
<eu.kanade.tachiyomi.ui.base.MaxHeightScrollView
android:id="@+id/menu_scroll_view"
android:layout_width="match_parent"
android:layout_height="wrap_content"
@ -25,7 +25,7 @@
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical" />
</androidx.core.widget.NestedScrollView>
</eu.kanade.tachiyomi.ui.base.MaxHeightScrollView>
<androidx.constraintlayout.widget.ConstraintLayout
android:id="@+id/title_layout"
@ -60,6 +60,7 @@
tools:text="Title Text" />
<View
android:id="@+id/bottom_divider"
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="@color/divider"

View File

@ -91,6 +91,7 @@
<string name="category_with_name_exists">A category with that name already exists!</string>
<string name="category_deleted">Category deleted</string>
<string name="long_press_category">Press and hold to edit a category</string>
<string name="jump_to_category">Jump to category</string>
<!-- Updates -->
<string name="update">Update</string>