Zen mode settings fixes.

- Fix wiring for the "At night" section. Remove fragile index-based
  logic by adding value support to DropDownPreference.
- Actually refresh zen config if it changes.
- Only show the enter zen dialog for user-initiated changes.

Change-Id: Ic3a3b9864942fb3ebf18cd838339de2ff28f9394
This commit is contained in:
John Spurlock
2014-05-01 23:07:23 -04:00
parent 1e2174da96
commit 04a73fe3c0
3 changed files with 53 additions and 37 deletions

View File

@@ -26,10 +26,13 @@ import android.widget.ArrayAdapter;
import android.widget.Spinner; import android.widget.Spinner;
import android.widget.AdapterView.OnItemSelectedListener; import android.widget.AdapterView.OnItemSelectedListener;
import java.util.ArrayList;
public class DropDownPreference extends Preference { public class DropDownPreference extends Preference {
private final Context mContext; private final Context mContext;
private final ArrayAdapter<String> mAdapter; private final ArrayAdapter<String> mAdapter;
private final Spinner mSpinner; private final Spinner mSpinner;
private final ArrayList<Object> mValues = new ArrayList<Object>();
private Callback mCallback; private Callback mCallback;
@@ -77,17 +80,26 @@ public class DropDownPreference extends Preference {
} }
public void setSelectedItem(int position) { public void setSelectedItem(int position) {
if (mCallback != null && !mCallback.onItemSelected(position)) { final Object value = mValues.get(position);
if (mCallback != null && !mCallback.onItemSelected(position, value)) {
return; return;
} }
mSpinner.setSelection(position); mSpinner.setSelection(position);
setSummary(mAdapter.getItem(position)); setSummary(mAdapter.getItem(position));
final boolean disableDependents = position == 0; final boolean disableDependents = value == null;
notifyDependencyChange(disableDependents); notifyDependencyChange(disableDependents);
} }
public void addItem(int resId) { public void setSelectedValue(Object value) {
final int i = mValues.indexOf(value);
if (i > -1) {
setSelectedItem(i);
}
}
public void addItem(int resId, Object value) {
mAdapter.add(mContext.getResources().getString(resId)); mAdapter.add(mContext.getResources().getString(resId));
mValues.add(value);
} }
@Override @Override
@@ -105,6 +117,6 @@ public class DropDownPreference extends Preference {
} }
public interface Callback { public interface Callback {
boolean onItemSelected(int pos); boolean onItemSelected(int pos, Object value);
} }
} }

View File

@@ -18,7 +18,6 @@ package com.android.settings.notification;
import android.content.ContentResolver; import android.content.ContentResolver;
import android.content.Context; import android.content.Context;
import android.content.Intent;
import android.content.pm.PackageManager; import android.content.pm.PackageManager;
import android.database.ContentObserver; import android.database.ContentObserver;
import android.media.RingtoneManager; import android.media.RingtoneManager;
@@ -57,7 +56,7 @@ public class NotificationSettings extends SettingsPreferenceFragment implements
private Preference mNotificationSoundPreference; private Preference mNotificationSoundPreference;
private Preference mNotificationAccess; private Preference mNotificationAccess;
private DropDownPreference mLockscreenNotifications; private DropDownPreference mLockscreen;
private TwoStatePreference mHeadsUp; private TwoStatePreference mHeadsUp;
private TwoStatePreference mNotificationPulse; private TwoStatePreference mNotificationPulse;
@@ -112,20 +111,19 @@ public class NotificationSettings extends SettingsPreferenceFragment implements
mNotificationAccess = findPreference(KEY_NOTIFICATION_ACCESS); mNotificationAccess = findPreference(KEY_NOTIFICATION_ACCESS);
refreshNotificationListeners(); refreshNotificationListeners();
mLockscreenNotifications mLockscreen = (DropDownPreference) root.findPreference(KEY_LOCK_SCREEN_NOTIFICATIONS);
= (DropDownPreference) root.findPreference(KEY_LOCK_SCREEN_NOTIFICATIONS); if (mLockscreen != null) {
if (mLockscreenNotifications != null) {
if (!getDeviceLockscreenNotificationsEnabled()) { if (!getDeviceLockscreenNotificationsEnabled()) {
root.removePreference(mLockscreenNotifications); root.removePreference(mLockscreen);
} else { } else {
mLockscreenNotifications.addItem(R.string.lock_screen_notifications_summary_show); mLockscreen.addItem(R.string.lock_screen_notifications_summary_show, 1);
mLockscreenNotifications.addItem(R.string.lock_screen_notifications_summary_hide); mLockscreen.addItem(R.string.lock_screen_notifications_summary_hide, 0);
final int pos = getLockscreenAllowPrivateNotifications() ? 0 : 1; final int val = getLockscreenAllowPrivateNotifications() ? 1 : 0;
mLockscreenNotifications.setSelectedItem(pos); mLockscreen.setSelectedValue(val);
mLockscreenNotifications.setCallback(new DropDownPreference.Callback() { mLockscreen.setCallback(new DropDownPreference.Callback() {
@Override @Override
public boolean onItemSelected(int pos) { public boolean onItemSelected(int pos, Object value) {
final int val = pos == 0 ? 1 : 0; final int val = (Integer) value;
Settings.Secure.putInt(getContentResolver(), Settings.Secure.putInt(getContentResolver(),
Settings.Secure.LOCK_SCREEN_ALLOW_PRIVATE_NOTIFICATIONS, val); Settings.Secure.LOCK_SCREEN_ALLOW_PRIVATE_NOTIFICATIONS, val);
return true; return true;

View File

@@ -95,6 +95,7 @@ public class ZenModeSettings extends SettingsPreferenceFragment implements Index
private Preference mEntry; private Preference mEntry;
private Preference mConditionProviders; private Preference mConditionProviders;
private AlertDialog mDialog; private AlertDialog mDialog;
private boolean mIgnoreNext;
@Override @Override
public void onCreate(Bundle icicle) { public void onCreate(Bundle icicle) {
@@ -111,6 +112,7 @@ public class ZenModeSettings extends SettingsPreferenceFragment implements Index
if (DEBUG) Log.d(TAG, "Loaded mConfig=" + mConfig); if (DEBUG) Log.d(TAG, "Loaded mConfig=" + mConfig);
mSwitch = (SwitchPreference) root.findPreference(KEY_ZEN_MODE); mSwitch = (SwitchPreference) root.findPreference(KEY_ZEN_MODE);
mSwitch.setOnPreferenceChangeListener(mSwitchListener);
final PreferenceCategory general = (PreferenceCategory) root.findPreference(KEY_GENERAL); final PreferenceCategory general = (PreferenceCategory) root.findPreference(KEY_GENERAL);
@@ -146,9 +148,9 @@ public class ZenModeSettings extends SettingsPreferenceFragment implements Index
mStarred.setEnabled(false); mStarred.setEnabled(false);
mStarred.setTitle(R.string.zen_mode_from); mStarred.setTitle(R.string.zen_mode_from);
mStarred.setDropDownWidth(R.dimen.zen_mode_dropdown_width); mStarred.setDropDownWidth(R.dimen.zen_mode_dropdown_width);
mStarred.addItem(R.string.zen_mode_from_anyone); mStarred.addItem(R.string.zen_mode_from_anyone, null);
mStarred.addItem(R.string.zen_mode_from_starred); mStarred.addItem(R.string.zen_mode_from_starred, null);
mStarred.addItem(R.string.zen_mode_from_contacts); mStarred.addItem(R.string.zen_mode_from_contacts, null);
general.addPreference(mStarred); general.addPreference(mStarred);
final Preference alarmInfo = new Preference(mContext) { final Preference alarmInfo = new Preference(mContext) {
@@ -171,15 +173,14 @@ public class ZenModeSettings extends SettingsPreferenceFragment implements Index
mWhen.setKey(KEY_WHEN); mWhen.setKey(KEY_WHEN);
mWhen.setTitle(R.string.zen_mode_when); mWhen.setTitle(R.string.zen_mode_when);
mWhen.setDropDownWidth(R.dimen.zen_mode_dropdown_width); mWhen.setDropDownWidth(R.dimen.zen_mode_dropdown_width);
mWhen.addItem(R.string.zen_mode_when_every_night); mWhen.addItem(R.string.zen_mode_when_every_night, ZenModeConfig.SLEEP_MODE_NIGHTS);
mWhen.addItem(R.string.zen_mode_when_weeknights); mWhen.addItem(R.string.zen_mode_when_weeknights, ZenModeConfig.SLEEP_MODE_WEEKNIGHTS);
mWhen.addItem(R.string.zen_mode_when_never); mWhen.addItem(R.string.zen_mode_when_never, null);
mWhen.setCallback(new DropDownPreference.Callback() { mWhen.setCallback(new DropDownPreference.Callback() {
@Override @Override
public boolean onItemSelected(int pos) { public boolean onItemSelected(int pos, Object value) {
if (mDisableListeners) return true; if (mDisableListeners) return true;
final String mode = pos == 1 ? ZenModeConfig.SLEEP_MODE_NIGHTS : final String mode = (String) value;
pos == 2 ? ZenModeConfig.SLEEP_MODE_WEEKNIGHTS : null;
if (Objects.equals(mode, mConfig.sleepMode)) return true; if (Objects.equals(mode, mConfig.sleepMode)) return true;
if (DEBUG) Log.d(TAG, "onPrefChange sleepMode=" + mode); if (DEBUG) Log.d(TAG, "onPrefChange sleepMode=" + mode);
final ZenModeConfig newConfig = mConfig.copy(); final ZenModeConfig newConfig = mConfig.copy();
@@ -210,6 +211,7 @@ public class ZenModeSettings extends SettingsPreferenceFragment implements Index
} }
}); });
auto.addPreference(mStart); auto.addPreference(mStart);
mStart.setDependency(mWhen.getKey());
mEnd = new TimePickerPreference(mContext, mgr); mEnd = new TimePickerPreference(mContext, mgr);
mEnd.setTitle(R.string.zen_mode_end_time); mEnd.setTitle(R.string.zen_mode_end_time);
@@ -231,8 +233,6 @@ public class ZenModeSettings extends SettingsPreferenceFragment implements Index
} }
}); });
auto.addPreference(mEnd); auto.addPreference(mEnd);
mStart.setDependency(mWhen.getKey());
mEnd.setDependency(mWhen.getKey()); mEnd.setDependency(mWhen.getKey());
mAutomationCategory = (PreferenceCategory) findPreference(KEY_AUTOMATION); mAutomationCategory = (PreferenceCategory) findPreference(KEY_AUTOMATION);
@@ -255,7 +255,6 @@ public class ZenModeSettings extends SettingsPreferenceFragment implements Index
} }
}); });
mConditionProviders = findPreference(KEY_CONDITION_PROVIDERS); mConditionProviders = findPreference(KEY_CONDITION_PROVIDERS);
refreshAutomationSection();
updateZenMode(); updateZenMode();
updateControls(); updateControls();
@@ -266,12 +265,11 @@ public class ZenModeSettings extends SettingsPreferenceFragment implements Index
mCalls.setChecked(mConfig.allowCalls); mCalls.setChecked(mConfig.allowCalls);
mMessages.setChecked(mConfig.allowMessages); mMessages.setChecked(mConfig.allowMessages);
mStarred.setSelectedItem(0); mStarred.setSelectedItem(0);
mWhen.setSelectedItem( mWhen.setSelectedValue(mConfig.sleepMode);
ZenModeConfig.SLEEP_MODE_NIGHTS.equals(mConfig.sleepMode) ? 1 :
ZenModeConfig.SLEEP_MODE_WEEKNIGHTS.equals(mConfig.sleepMode) ? 2 : 0);
mStart.setTime(mConfig.sleepStartHour, mConfig.sleepStartMinute); mStart.setTime(mConfig.sleepStartHour, mConfig.sleepStartMinute);
mEnd.setTime(mConfig.sleepEndHour, mConfig.sleepEndMinute); mEnd.setTime(mConfig.sleepEndHour, mConfig.sleepEndMinute);
mDisableListeners = false; mDisableListeners = false;
refreshAutomationSection();
} }
private void refreshAutomationSection() { private void refreshAutomationSection() {
@@ -323,7 +321,7 @@ public class ZenModeSettings extends SettingsPreferenceFragment implements Index
@Override @Override
public void onResume() { public void onResume() {
super.onResume(); super.onResume();
refreshAutomationSection(); updateControls();
updateZenMode(); updateZenMode();
mSettingsObserver.register(); mSettingsObserver.register();
} }
@@ -335,18 +333,20 @@ public class ZenModeSettings extends SettingsPreferenceFragment implements Index
} }
private void updateZenMode() { private void updateZenMode() {
mSwitch.setOnPreferenceChangeListener(null);
final boolean zenMode = Global.getInt(getContentResolver(), final boolean zenMode = Global.getInt(getContentResolver(),
Global.ZEN_MODE, Global.ZEN_MODE_OFF) != Global.ZEN_MODE_OFF; Global.ZEN_MODE, Global.ZEN_MODE_OFF) != Global.ZEN_MODE_OFF;
mSwitch.setChecked(zenMode); if (mSwitch.isChecked() != zenMode) {
mSwitch.setChecked(zenMode);
mIgnoreNext = true;
}
mSwitch.setTitle(zenMode ? R.string.zen_mode_option_on : R.string.zen_mode_option_off); mSwitch.setTitle(zenMode ? R.string.zen_mode_option_on : R.string.zen_mode_option_off);
mSwitch.setOnPreferenceChangeListener(mSwitchListener);
} }
private void updateZenModeConfig() { private void updateZenModeConfig() {
final ZenModeConfig config = getZenModeConfig(); final ZenModeConfig config = getZenModeConfig();
if (Objects.equals(config, mConfig)) return; if (Objects.equals(config, mConfig)) return;
if (DEBUG) Log.d(TAG, "updateZenModeConfig"); mConfig = config;
if (DEBUG) Log.d(TAG, "updateZenModeConfig mConfig=" + mConfig);
updateControls(); updateControls();
} }
@@ -421,6 +421,12 @@ public class ZenModeSettings extends SettingsPreferenceFragment implements Index
@Override @Override
public boolean onPreferenceChange(Preference preference, Object newValue) { public boolean onPreferenceChange(Preference preference, Object newValue) {
final boolean isChecked = (Boolean) newValue; final boolean isChecked = (Boolean) newValue;
if (DEBUG) Log.d(TAG, "onPreferenceChange isChecked=" + isChecked
+ " mIgnoreNext=" + mIgnoreNext);
if (mIgnoreNext) {
mIgnoreNext = false;
return true;
}
AsyncTask.execute(new Runnable() { AsyncTask.execute(new Runnable() {
@Override @Override
public void run() { public void run() {