diff options
-rw-r--r-- | AndroidManifest.xml | 2 | ||||
-rw-r--r-- | res/values/strings.xml | 6 | ||||
-rw-r--r-- | src/com/android/settings/notification/ZenAccessSettings.java | 107 |
3 files changed, 103 insertions, 12 deletions
diff --git a/AndroidManifest.xml b/AndroidManifest.xml index 674dfc9..1bfee90 100644 --- a/AndroidManifest.xml +++ b/AndroidManifest.xml @@ -2268,7 +2268,7 @@ android:label="@string/manage_zen_access_title" android:taskAffinity=""> <intent-filter android:priority="1"> - <action android:name="android.settings.ZEN_ACCESS_SETTINGS" /> + <action android:name="android.settings.NOTIFICATION_POLICY_ACCESS_SETTINGS" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> <intent-filter> diff --git a/res/values/strings.xml b/res/values/strings.xml index 58169f8..ad8dc1e 100644 --- a/res/values/strings.xml +++ b/res/values/strings.xml @@ -6722,4 +6722,10 @@ <!-- Summary of data item when no data usage [CHAR LIMIT=40] --> <string name="no_data_usage">No data used</string> + + <!-- Zen mode access settings - title for warning dialog when enabling access [CHAR LIMIT=NONE] --> + <string name="zen_access_warning_dialog_title">Allow access to Do Not Disturb for <xliff:g id="app" example="Tasker">%1$s</xliff:g>?</string> + + <!-- Zen mode access settings - summary for warning dialog when enabling access [CHAR LIMIT=NONE] --> + <string name="zen_access_warning_dialog_summary">The app will be able to turn on/off Do Not Disturb and make changes to related settings.</string> </resources> diff --git a/src/com/android/settings/notification/ZenAccessSettings.java b/src/com/android/settings/notification/ZenAccessSettings.java index 99cfe74..88e6c58 100644 --- a/src/com/android/settings/notification/ZenAccessSettings.java +++ b/src/com/android/settings/notification/ZenAccessSettings.java @@ -16,17 +16,27 @@ package com.android.settings.notification; +import android.app.AlertDialog; +import android.app.Dialog; +import android.app.DialogFragment; import android.app.NotificationManager; import android.content.Context; +import android.content.DialogInterface; import android.content.pm.ApplicationInfo; import android.content.pm.PackageItemInfo; import android.content.pm.PackageManager; +import android.database.ContentObserver; +import android.net.Uri; import android.os.AsyncTask; import android.os.Bundle; +import android.os.Handler; +import android.os.Looper; import android.preference.Preference; -import android.preference.PreferenceScreen; import android.preference.Preference.OnPreferenceChangeListener; +import android.preference.PreferenceScreen; import android.preference.SwitchPreference; +import android.provider.Settings.Secure; +import android.text.TextUtils; import android.util.ArraySet; import android.view.LayoutInflater; import android.view.View; @@ -42,6 +52,9 @@ import java.util.Collections; import java.util.List; public class ZenAccessSettings extends SettingsPreferenceFragment { + + private final SettingObserver mObserver = new SettingObserver(); + private Context mContext; private PackageManager mPkgMan; private NotificationManager mNoMan; @@ -75,6 +88,15 @@ public class ZenAccessSettings extends SettingsPreferenceFragment { public void onResume() { super.onResume(); reloadList(); + getContentResolver().registerContentObserver( + Secure.getUriFor(Secure.ENABLED_NOTIFICATION_POLICY_ACCESS_PACKAGES), false, + mObserver); + } + + @Override + public void onPause() { + super.onPause(); + getContentResolver().unregisterContentObserver(mObserver); } private void reloadList() { @@ -95,22 +117,26 @@ public class ZenAccessSettings extends SettingsPreferenceFragment { Collections.sort(apps, new PackageItemInfo.DisplayNameComparator(mPkgMan)); for (ApplicationInfo app : apps) { final String pkg = app.packageName; + final CharSequence label = app.loadLabel(mPkgMan); final SwitchPreference pref = new SwitchPreference(mContext); pref.setPersistent(false); pref.setIcon(app.loadIcon(mPkgMan)); - pref.setTitle(app.packageName); + pref.setTitle(label); pref.setChecked(hasAccess(pkg)); pref.setOnPreferenceChangeListener(new OnPreferenceChangeListener() { @Override public boolean onPreferenceChange(Preference preference, Object newValue) { final boolean access = (Boolean) newValue; - AsyncTask.execute(new Runnable() { - @Override - public void run() { - setAccess(pkg, access); - } - }); - return true; + if (!access) { + // disabling access + setAccess(mContext, pkg, access); + return true; + } + // enabling access: show a scary dialog first + new ScaryWarningDialogFragment() + .setPkgInfo(pkg, label) + .show(getFragmentManager(), "dialog"); + return false; } }); screen.addPreference(pref); @@ -122,8 +148,67 @@ public class ZenAccessSettings extends SettingsPreferenceFragment { return mNoMan.isNotificationPolicyAccessGrantedForPackage(pkg); } - private void setAccess(String pkg, boolean access) { - mNoMan.setNotificationPolicyAccessGranted(pkg, access); + private static void setAccess(final Context context, final String pkg, final boolean access) { + AsyncTask.execute(new Runnable() { + @Override + public void run() { + final NotificationManager mgr = context.getSystemService(NotificationManager.class); + mgr.setNotificationPolicyAccessGranted(pkg, access); + } + }); + } + + private final class SettingObserver extends ContentObserver { + public SettingObserver() { + super(new Handler(Looper.getMainLooper())); + } + + @Override + public void onChange(boolean selfChange, Uri uri) { + reloadList(); + } } + public static class ScaryWarningDialogFragment extends DialogFragment { + static final String KEY_PKG = "p"; + static final String KEY_LABEL = "l"; + + public ScaryWarningDialogFragment setPkgInfo(String pkg, CharSequence label) { + Bundle args = new Bundle(); + args.putString(KEY_PKG, pkg); + args.putString(KEY_LABEL, TextUtils.isEmpty(label) ? pkg : label.toString()); + setArguments(args); + return this; + } + + @Override + public Dialog onCreateDialog(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + final Bundle args = getArguments(); + final String pkg = args.getString(KEY_PKG); + final String label = args.getString(KEY_LABEL); + + final String title = getResources().getString(R.string.zen_access_warning_dialog_title, + label); + final String summary = getResources() + .getString(R.string.zen_access_warning_dialog_summary); + return new AlertDialog.Builder(getContext()) + .setMessage(summary) + .setTitle(title) + .setCancelable(true) + .setPositiveButton(R.string.allow, + new DialogInterface.OnClickListener() { + public void onClick(DialogInterface dialog, int id) { + setAccess(getContext(), pkg, true); + } + }) + .setNegativeButton(R.string.deny, + new DialogInterface.OnClickListener() { + public void onClick(DialogInterface dialog, int id) { + // pass + } + }) + .create(); + } + } } |