Check if permission was denied

pull/208/head
M66B 3 years ago
parent 7bcd4ad7ad
commit a32860641b

@ -704,8 +704,6 @@ public class FragmentSetup extends FragmentBase {
grpDataSaver.setVisibility(View.GONE); grpDataSaver.setVisibility(View.GONE);
tvStamina.setVisibility(View.GONE); tvStamina.setVisibility(View.GONE);
setGrantedPermissions();
return view; return view;
} }
@ -804,6 +802,9 @@ public class FragmentSetup extends FragmentBase {
cm.registerDefaultNetworkCallback(networkCallback); cm.registerDefaultNetworkCallback(networkCallback);
} }
// Permissions
setGrantedPermissions();
// Doze // Doze
boolean isIgnoring = !Boolean.FALSE.equals(Helper.isIgnoringOptimizations(getContext())); boolean isIgnoring = !Boolean.FALSE.equals(Helper.isIgnoringOptimizations(getContext()));
boolean canScheduleExact = AlarmManagerCompatEx.canScheduleExactAlarms(getContext()); boolean canScheduleExact = AlarmManagerCompatEx.canScheduleExactAlarms(getContext());
@ -969,6 +970,33 @@ public class FragmentSetup extends FragmentBase {
@Override @Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
setGrantedPermissions(); setGrantedPermissions();
SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(getContext());
SharedPreferences.Editor editor = prefs.edit();
int denied = 0;
for (int i = 0; i < Math.min(permissions.length, grantResults.length); i++) {
String key = "requested." + permissions[i];
if (grantResults[i] == PackageManager.PERMISSION_DENIED &&
grantResults[i] == prefs.getInt(key, PackageManager.PERMISSION_GRANTED))
denied++;
if (grantResults[i] == PackageManager.PERMISSION_GRANTED &&
Manifest.permission.READ_CONTACTS.equals(permissions[i]))
ContactInfo.init(getContext().getApplicationContext());
editor.putInt(key, grantResults[i]);
}
editor.apply();
if (denied > 0) {
Intent settings = new Intent(
Settings.ACTION_APPLICATION_DETAILS_SETTINGS,
Uri.parse("package:" + BuildConfig.APPLICATION_ID));
startActivity(settings);
}
} }
private List<String> getDesiredPermissions() { private List<String> getDesiredPermissions() {
@ -985,9 +1013,6 @@ public class FragmentSetup extends FragmentBase {
if (hasPermission(permission)) if (hasPermission(permission))
granted.add(permission); granted.add(permission);
if (granted.contains(Manifest.permission.READ_CONTACTS))
ContactInfo.init(getContext().getApplicationContext());
boolean all = true; boolean all = true;
for (String permission : getDesiredPermissions()) for (String permission : getDesiredPermissions())
if (!granted.contains(permission)) { if (!granted.contains(permission)) {

Loading…
Cancel
Save