From 15ef61f6b39b26bfbcb89f2f62bc15325a24da04 Mon Sep 17 00:00:00 2001 From: Nikita Date: Sun, 4 Aug 2024 06:42:52 +0300 Subject: [PATCH] fix: visibility of UI elements in Downloads --- .../ui/fragments/DownloadsFragment.kt | 30 +++++++++++-------- .../main/res/layout/fragment_downloads.xml | 20 ++++++++----- 2 files changed, 29 insertions(+), 21 deletions(-) diff --git a/app/src/main/java/com/github/libretube/ui/fragments/DownloadsFragment.kt b/app/src/main/java/com/github/libretube/ui/fragments/DownloadsFragment.kt index cc468f1b0..eb4ebad16 100644 --- a/app/src/main/java/com/github/libretube/ui/fragments/DownloadsFragment.kt +++ b/app/src/main/java/com/github/libretube/ui/fragments/DownloadsFragment.kt @@ -12,7 +12,6 @@ import android.view.View import android.view.ViewGroup import androidx.core.content.ContextCompat import androidx.core.view.isGone -import androidx.core.view.isInvisible import androidx.core.view.isVisible import androidx.lifecycle.lifecycleScope import androidx.recyclerview.widget.GridLayoutManager @@ -87,7 +86,6 @@ class DownloadsFragment : DynamicLayoutManagerFragment() { override fun onViewCreated(view: View, savedInstanceState: Bundle?) { super.onViewCreated(view, savedInstanceState) - binding.deleteAll.isInvisible = true var selectedSortType = PreferenceHelper.getInt(PreferenceKeys.SELECTED_DOWNLOAD_SORT_TYPE, 0) val filterOptions = resources.getStringArray(R.array.downloadSortOptions) @@ -166,25 +164,31 @@ class DownloadsFragment : DynamicLayoutManagerFragment() { object : RecyclerView.AdapterDataObserver() { override fun onItemRangeRemoved(positionStart: Int, itemCount: Int) { super.onItemRangeRemoved(positionStart, itemCount) - val binding = _binding ?: return - if (binding.downloads.adapter?.itemCount == 0) { - binding.downloads.isGone = true - binding.downloadsEmpty.isVisible = true - } + toggleButtonsVisibility() } } ) - if (dbDownloads.isNotEmpty()) { - binding.deleteAll.isVisible = true - binding.deleteAll.setOnClickListener { - showDeleteAllDialog(binding.root.context, adapter) - } - } + toggleButtonsVisibility() binding.shuffleBackground.setOnClickListener { BackgroundHelper.playOnBackgroundOffline(requireContext(), null) } + + binding.deleteAll.setOnClickListener { + showDeleteAllDialog(binding.root.context, adapter) + } + } + + private fun toggleButtonsVisibility() { + val binding = _binding ?: return + + val isEmpty = binding.downloads.adapter?.itemCount == 0 + binding.downloadsEmpty.isVisible = isEmpty + binding.downloads.isGone = isEmpty + binding.sortType.isGone = isEmpty + binding.deleteAll.isGone = isEmpty + binding.shuffleBackground.isGone = isEmpty } private fun sortDownloadList(sortType: Int, previousSortType: Int? = null) { diff --git a/app/src/main/res/layout/fragment_downloads.xml b/app/src/main/res/layout/fragment_downloads.xml index dc7c09e0f..a69b6e1f8 100644 --- a/app/src/main/res/layout/fragment_downloads.xml +++ b/app/src/main/res/layout/fragment_downloads.xml @@ -11,19 +11,19 @@ android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginEnd="10dp" - android:paddingVertical="5dp" + android:clickable="true" + android:drawablePadding="10dp" android:focusable="true" android:fontFamily="@font/roboto" + android:paddingVertical="5dp" android:text="@string/sort_by" - - android:clickable="true" android:textSize="15sp" android:textStyle="bold" - android:drawablePadding="10dp" + android:visibility="gone" app:drawableEndCompat="@drawable/ic_sort" - app:layout_constraintTop_toTopOf="parent" app:layout_constraintEnd_toEndOf="parent" - /> + app:layout_constraintTop_toTopOf="parent" + tools:visibility="visible" /> + tools:targetApi="o" + tools:visibility="visible" /> + tools:targetApi="o" + tools:visibility="visible" /> \ No newline at end of file