From bdffa73d7d3712b75ea1634ef900137aea7b26a0 Mon Sep 17 00:00:00 2001 From: Naveen Date: Wed, 24 May 2023 04:02:36 +0530 Subject: [PATCH] Filter out other files as needed before resizing --- .../gallery/pro/adapters/MediaAdapter.kt | 23 +++++++++++-------- 1 file changed, 14 insertions(+), 9 deletions(-) diff --git a/app/src/main/kotlin/com/simplemobiletools/gallery/pro/adapters/MediaAdapter.kt b/app/src/main/kotlin/com/simplemobiletools/gallery/pro/adapters/MediaAdapter.kt index 521cb6f76..6bdee1414 100644 --- a/app/src/main/kotlin/com/simplemobiletools/gallery/pro/adapters/MediaAdapter.kt +++ b/app/src/main/kotlin/com/simplemobiletools/gallery/pro/adapters/MediaAdapter.kt @@ -30,14 +30,9 @@ import com.simplemobiletools.gallery.pro.interfaces.MediaOperationsListener import com.simplemobiletools.gallery.pro.models.Medium import com.simplemobiletools.gallery.pro.models.ThumbnailItem import com.simplemobiletools.gallery.pro.models.ThumbnailSection -import kotlinx.android.synthetic.main.photo_item_grid.view.* -import kotlinx.android.synthetic.main.thumbnail_section.view.* +import kotlinx.android.synthetic.main.photo_item_grid.view.file_type +import kotlinx.android.synthetic.main.thumbnail_section.view.thumbnail_section import kotlinx.android.synthetic.main.video_item_grid.view.* -import kotlinx.android.synthetic.main.video_item_grid.view.favorite -import kotlinx.android.synthetic.main.video_item_grid.view.media_item_holder -import kotlinx.android.synthetic.main.video_item_grid.view.medium_check -import kotlinx.android.synthetic.main.video_item_grid.view.medium_name -import kotlinx.android.synthetic.main.video_item_grid.view.medium_thumbnail class MediaAdapter( activity: BaseSimpleActivity, var media: ArrayList, val listener: MediaOperationsListener?, val isAGetIntent: Boolean, @@ -144,7 +139,7 @@ class MediaAdapter( findItem(R.id.cab_open_with).isVisible = isOneItemSelected findItem(R.id.cab_edit).isVisible = isOneItemSelected findItem(R.id.cab_set_as).isVisible = isOneItemSelected - findItem(R.id.cab_resize).isVisible = selectedItems.all { it.isImage() } + findItem(R.id.cab_resize).isVisible = canResize(selectedItems) findItem(R.id.cab_confirm_selection).isVisible = isAGetIntent && allowMultiplePicks && selectedKeys.isNotEmpty() findItem(R.id.cab_restore_recycle_bin_files).isVisible = selectedPaths.all { it.startsWith(activity.recycleBinPath) } findItem(R.id.cab_create_shortcut).isVisible = isOreoPlus() && isOneItemSelected @@ -289,7 +284,7 @@ class MediaAdapter( } private fun resize() { - val paths = getSelectedPaths() + val paths = getSelectedItems().filter { it.isImage() }.map { it.path } if (isOneItemSelected()) { val path = paths.first() activity.launchResizeImageDialog(path) { @@ -302,6 +297,16 @@ class MediaAdapter( } } + private fun canResize(selectedItems: ArrayList): Boolean { + val selectionContainsImages = selectedItems.any { it.isImage() } + if (!selectionContainsImages) { + return false + } + val parentPath = selectedItems.first { it.isImage() }.path.getParentPath() + val isRestrictedDir = activity.isRestrictedWithSAFSdk30(parentPath) + return !isRestrictedDir + } + private fun toggleFileVisibility(hide: Boolean) { ensureBackgroundThread { getSelectedItems().forEach {