From 662d77cb7ec4e489b4e04e283ce5e0860391e33d Mon Sep 17 00:00:00 2001 From: ericdecanini Date: Mon, 12 Sep 2022 17:40:22 -0400 Subject: [PATCH] Adds min height to space sheet --- .../features/spaces/SpaceListBottomSheet.kt | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/vector/src/main/java/im/vector/app/features/spaces/SpaceListBottomSheet.kt b/vector/src/main/java/im/vector/app/features/spaces/SpaceListBottomSheet.kt index 910f8c5379..866d2d81a7 100644 --- a/vector/src/main/java/im/vector/app/features/spaces/SpaceListBottomSheet.kt +++ b/vector/src/main/java/im/vector/app/features/spaces/SpaceListBottomSheet.kt @@ -16,10 +16,14 @@ package im.vector.app.features.spaces +import android.app.Dialog import android.os.Bundle +import android.util.DisplayMetrics import android.view.LayoutInflater import android.view.View import android.view.ViewGroup +import androidx.annotation.FloatRange +import com.google.android.material.bottomsheet.BottomSheetDialog import com.google.android.material.bottomsheet.BottomSheetDialogFragment import im.vector.app.R import im.vector.app.core.extensions.replaceChildFragment @@ -37,6 +41,21 @@ class SpaceListBottomSheet : BottomSheetDialogFragment() { return binding.root } + + override fun onCreateDialog(savedInstanceState: Bundle?): Dialog { + return super.onCreateDialog(savedInstanceState).apply { + (this as BottomSheetDialog).setPeekHeightAsScreenPercentage(0.75f) + } + } + + @Suppress("DEPRECATION") + private fun BottomSheetDialog.setPeekHeightAsScreenPercentage(@FloatRange(from = 0.0, to = 1.0) percentage: Float) { + val displayMetrics = DisplayMetrics() + window?.windowManager?.defaultDisplay?.getMetrics(displayMetrics) + val height = displayMetrics.heightPixels + behavior.setPeekHeight((height * percentage).toInt(), true) + } + companion object { const val TAG = "SpacesBottomSheet" }