diff --git a/app/src/main/java/fr/free/nrw/commons/filepicker/Constants.java b/app/src/main/java/fr/free/nrw/commons/filepicker/Constants.java
index cc04e39561..3c9299c1aa 100644
--- a/app/src/main/java/fr/free/nrw/commons/filepicker/Constants.java
+++ b/app/src/main/java/fr/free/nrw/commons/filepicker/Constants.java
@@ -8,6 +8,7 @@ public interface Constants {
*/
interface RequestCodes {
int LOCATION = 1;
+ int STORAGE = 2;
int FILE_PICKER_IMAGE_IDENTIFICATOR = 0b1101101100; //876
int SOURCE_CHOOSER = 1 << 15;
diff --git a/app/src/main/java/fr/free/nrw/commons/upload/UploadActivity.java b/app/src/main/java/fr/free/nrw/commons/upload/UploadActivity.java
index 69c67e15e8..06706df8a8 100644
--- a/app/src/main/java/fr/free/nrw/commons/upload/UploadActivity.java
+++ b/app/src/main/java/fr/free/nrw/commons/upload/UploadActivity.java
@@ -10,9 +10,12 @@
import android.annotation.SuppressLint;
import android.app.ProgressDialog;
import android.content.Intent;
+import android.content.pm.PackageManager;
import android.location.Location;
import android.location.LocationManager;
import android.os.Build;
+import android.os.Build.VERSION;
+import android.os.Build.VERSION_CODES;
import android.os.Bundle;
import android.provider.Settings;
import android.util.DisplayMetrics;
@@ -21,6 +24,7 @@
import android.widget.LinearLayout;
import android.widget.RelativeLayout;
import android.widget.TextView;
+import androidx.annotation.NonNull;
import androidx.cardview.widget.CardView;
import androidx.fragment.app.Fragment;
import androidx.fragment.app.FragmentManager;
@@ -38,6 +42,7 @@
import fr.free.nrw.commons.auth.LoginActivity;
import fr.free.nrw.commons.auth.SessionManager;
import fr.free.nrw.commons.contributions.ContributionController;
+import fr.free.nrw.commons.filepicker.Constants.RequestCodes;
import fr.free.nrw.commons.filepicker.UploadableFile;
import fr.free.nrw.commons.kvstore.JsonKvStore;
import fr.free.nrw.commons.location.LatLng;
@@ -59,7 +64,6 @@
import io.reactivex.android.schedulers.AndroidSchedulers;
import io.reactivex.disposables.CompositeDisposable;
import io.reactivex.schedulers.Schedulers;
-import java.security.Permission;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
@@ -150,11 +154,6 @@ protected void onCreate(Bundle savedInstanceState) {
compositeDisposable = new CompositeDisposable();
init();
nearbyPopupAnswers = new HashMap<>();
- PermissionUtils.checkPermissionsAndPerformAction(this,
- this::receiveSharedItems,
- R.string.storage_permission_title,
- R.string.write_storage_permission_rationale_for_image_share,
- PERMISSIONS_STORAGE);
//getting the current dpi of the device and if it is less than 320dp i.e. overlapping
//threshold, thumbnails automatically minimizes
DisplayMetrics metrics = getResources().getDisplayMetrics();
@@ -167,6 +166,7 @@ protected void onCreate(Bundle savedInstanceState) {
}
locationManager.requestLocationUpdatesFromProvider(LocationManager.GPS_PROVIDER);
locationManager.requestLocationUpdatesFromProvider(LocationManager.NETWORK_PROVIDER);
+ checkStoragePermissions();
}
private void init() {
@@ -232,7 +232,6 @@ protected void onResume() {
askUserToLogIn();
}
checkBlockStatus();
- checkStoragePermissions();
}
/**
@@ -255,14 +254,10 @@ protected void checkBlockStatus() {
private void checkStoragePermissions() {
final boolean hasAllPermissions = PermissionUtils.hasPermission(this, PERMISSIONS_STORAGE);
- if (!hasAllPermissions) {
- PermissionUtils.checkPermissionsAndPerformAction(this,
- () -> {
- //TODO handle this
- },
- R.string.storage_permission_title,
- R.string.write_storage_permission_rationale_for_image_share,
- PERMISSIONS_STORAGE);
+ if (hasAllPermissions) {
+ receiveSharedItems();
+ } else if (VERSION.SDK_INT >= VERSION_CODES.M) {
+ requestPermissions(PERMISSIONS_STORAGE, RequestCodes.STORAGE);
}
}
@@ -350,7 +345,44 @@ public void askUserToLogIn() {
startActivity(loginIntent);
}
+ @Override
+ public void onRequestPermissionsResult(final int requestCode,
+ @NonNull final String[] permissions,
+ @NonNull final int[] grantResults) {
+ boolean areAllGranted = false;
+ if (requestCode == RequestCodes.STORAGE) {
+ if (VERSION.SDK_INT >= VERSION_CODES.M) {
+ for (int i = 0; i < grantResults.length; i++) {
+ String permission = permissions[i];
+ areAllGranted = grantResults[i] == PackageManager.PERMISSION_GRANTED;
+ if (grantResults[i] == PackageManager.PERMISSION_DENIED) {
+ boolean showRationale = shouldShowRequestPermissionRationale(permission);
+ if (!showRationale) {
+ DialogUtil.showAlertDialog(this,
+ getString(R.string.storage_permissions_denied),
+ getString(R.string.unable_to_share_upload_item),
+ getString(android.R.string.ok),
+ this::finish,
+ false);
+ } else {
+ DialogUtil.showAlertDialog(this,
+ getString(R.string.storage_permission_title),
+ getString(
+ R.string.write_storage_permission_rationale_for_image_share),
+ getString(android.R.string.ok),
+ this::checkStoragePermissions,
+ false);
+ }
+ }
+ }
+ if (areAllGranted) {
+ receiveSharedItems();
+ }
+ }
+ }
+ super.onRequestPermissionsResult(requestCode, permissions, grantResults);
+ }
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml
index 0a7ef24992..85bb19bdc5 100644
--- a/app/src/main/res/values/strings.xml
+++ b/app/src/main/res/values/strings.xml
@@ -775,6 +775,8 @@ Upload your first media by tapping on the add button.
Swipe fast and long to perform these actions: \n- Left/Right: Go to previous/next \n- Up: Select\n- Down: Mark as not for upload.
To set up your leaderboard avatar, tap \"Set as avatar\" in the three-dots menu of any image.
The coordinates are not the exact coordinates, but the person who uploaded this picture thinks they are close enough.
+ Storage Permissions Denied
+ Unable to share this item
- %d image selected
- %d images selected