mirror of
https://github.com/FossifyOrg/Gallery.git
synced 2025-01-19 06:48:00 +01:00
properly handle moving multiple items in the recycle bin too
This commit is contained in:
parent
87fde0f813
commit
721890ce67
3 changed files with 44 additions and 23 deletions
|
@ -772,6 +772,20 @@ class MediaActivity : SimpleActivity(), MediaAdapter.MediaOperationsListener {
|
||||||
|
|
||||||
override fun tryDeleteFiles(fileDirItems: ArrayList<FileDirItem>) {
|
override fun tryDeleteFiles(fileDirItems: ArrayList<FileDirItem>) {
|
||||||
val filtered = fileDirItems.filter { it.path.isImageVideoGif() } as ArrayList
|
val filtered = fileDirItems.filter { it.path.isImageVideoGif() } as ArrayList
|
||||||
|
if (config.useRecycleBin) {
|
||||||
|
movePathsInRecycleBin(filtered.map { it.path } as ArrayList<String>) {
|
||||||
|
if (it) {
|
||||||
|
deleteFilteredFiles(filtered)
|
||||||
|
} else {
|
||||||
|
toast(R.string.unknown_error_occurred)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
deleteFilteredFiles(filtered)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun deleteFilteredFiles(filtered: ArrayList<FileDirItem>) {
|
||||||
deleteFiles(filtered) {
|
deleteFiles(filtered) {
|
||||||
if (!it) {
|
if (!it) {
|
||||||
toast(R.string.unknown_error_occurred)
|
toast(R.string.unknown_error_occurred)
|
||||||
|
@ -782,9 +796,12 @@ class MediaActivity : SimpleActivity(), MediaAdapter.MediaOperationsListener {
|
||||||
|
|
||||||
Thread {
|
Thread {
|
||||||
val mediumDao = galleryDB.MediumDao()
|
val mediumDao = galleryDB.MediumDao()
|
||||||
|
val useRecycleBin = config.useRecycleBin
|
||||||
filtered.forEach {
|
filtered.forEach {
|
||||||
|
if (!useRecycleBin) {
|
||||||
mediumDao.deleteMediumPath(it.path)
|
mediumDao.deleteMediumPath(it.path)
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}.start()
|
}.start()
|
||||||
|
|
||||||
if (mMedia.isEmpty()) {
|
if (mMedia.isEmpty()) {
|
||||||
|
|
|
@ -838,19 +838,18 @@ class ViewPagerActivity : SimpleActivity(), ViewPager.OnPageChangeListener, View
|
||||||
|
|
||||||
private fun deleteConfirmed() {
|
private fun deleteConfirmed() {
|
||||||
val path = getCurrentMedia().getOrNull(mPos)?.path ?: return
|
val path = getCurrentMedia().getOrNull(mPos)?.path ?: return
|
||||||
|
val fileDirItem = FileDirItem(path, path.getFilenameFromPath())
|
||||||
if (config.useRecycleBin) {
|
if (config.useRecycleBin) {
|
||||||
Thread {
|
|
||||||
movePathInRecycleBin(path) {
|
movePathInRecycleBin(path) {
|
||||||
if (it) {
|
if (it) {
|
||||||
galleryDB.MediumDao().updateDeleted(path, System.currentTimeMillis())
|
tryDeleteFileDirItem(fileDirItem, false, false) {
|
||||||
refreshViewPager()
|
refreshViewPager()
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
toast(R.string.unknown_error_occurred)
|
toast(R.string.unknown_error_occurred)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}.start()
|
|
||||||
} else {
|
} else {
|
||||||
val fileDirItem = FileDirItem(path, path.getFilenameFromPath())
|
|
||||||
tryDeleteFileDirItem(fileDirItem, false, true) {
|
tryDeleteFileDirItem(fileDirItem, false, true) {
|
||||||
refreshViewPager()
|
refreshViewPager()
|
||||||
}
|
}
|
||||||
|
|
|
@ -181,18 +181,23 @@ fun BaseSimpleActivity.tryDeleteFileDirItem(fileDirItem: FileDirItem, allowDelet
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fun BaseSimpleActivity.movePathInRecycleBin(path: String, callback: (success: Boolean) -> Unit) {
|
fun BaseSimpleActivity.movePathInRecycleBin(path: String, callback: ((wasSuccess: Boolean) -> Unit)?) {
|
||||||
val file = File(path)
|
movePathsInRecycleBin(arrayListOf(path), callback)
|
||||||
val internalFile = File(filesDir, path)
|
}
|
||||||
return try {
|
|
||||||
file.copyRecursively(internalFile, true)
|
fun BaseSimpleActivity.movePathsInRecycleBin(paths: ArrayList<String>, callback: ((wasSuccess: Boolean) -> Unit)?) {
|
||||||
val fileDirItem = FileDirItem(path, path.getFilenameFromPath())
|
Thread {
|
||||||
tryDeleteFileDirItem(fileDirItem, getIsPathDirectory(path), false) {
|
var pathsCnt = paths.size
|
||||||
Thread {
|
paths.forEach {
|
||||||
callback(it)
|
val file = File(it)
|
||||||
}.start()
|
val internalFile = File(filesDir, it)
|
||||||
}
|
try {
|
||||||
} catch (ignored: Exception) {
|
file.copyRecursively(internalFile, true)
|
||||||
callback(false)
|
galleryDB.MediumDao().updateDeleted(it, System.currentTimeMillis())
|
||||||
}
|
pathsCnt--
|
||||||
|
} catch (ignored: Exception) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
callback?.invoke(pathsCnt == 0)
|
||||||
|
}.start()
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue