Merge pull request #2412 from KryptKode/feat/request_access_media_location

request ACCESS_MEDIA_LOCATION permission
This commit is contained in:
Tibor Kaputa 2022-04-15 08:51:56 +02:00 committed by GitHub
commit 4ce5425cd4
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -145,7 +145,7 @@ class MainActivity : SimpleActivity(), DirectoryOperationsListener {
}
// just request the permission, tryLoadGallery will then trigger in onResume
handlePermission(PERMISSION_WRITE_STORAGE) {
handleMediaPermissions {
if (!it) {
toast(R.string.no_storage_permissions)
finish()
@ -153,6 +153,15 @@ class MainActivity : SimpleActivity(), DirectoryOperationsListener {
}
}
private fun handleMediaPermissions(callback: (granted: Boolean) -> Unit) {
handlePermission(PERMISSION_WRITE_STORAGE) { granted ->
callback(granted)
if (granted && isSPlus()) {
handlePermission(PERMISSION_MEDIA_LOCATION) {}
}
}
}
override fun onStart() {
super.onStart()
mTempShowHiddenHandler.removeCallbacksAndMessages(null)
@ -435,9 +444,9 @@ class MainActivity : SimpleActivity(), DirectoryOperationsListener {
private fun tryLoadGallery() {
// avoid calling anything right after granting the permission, it will be called from onResume()
val wasMissingPermission = config.appRunCount == 1 && !hasPermission(PERMISSION_WRITE_STORAGE)
handlePermission(PERMISSION_WRITE_STORAGE) {
handleMediaPermissions {
if (wasMissingPermission) {
return@handlePermission
return@handleMediaPermissions
}
if (it) {