From 6f747eb77616d7f9949997d7e5a47414534a355a Mon Sep 17 00:00:00 2001 From: Tony Mantler Date: Tue, 17 Jun 2014 11:33:16 -0700 Subject: [PATCH] Unify general settings Make Email GeneralPreferences subclass GeneralPrefsFragment. Only contains a minimum of code to strip out archive-related prefs, which are not relevant to the current state of Email back-ends. (These actions could be relevant for Gmail IMAP extensions if support is added for them) b/9566150 Change-Id: Ie8e26379ed504c7d96c2a2f8e1c843bbe0582cc7 --- res/xml/general_preferences.xml | 62 -------------- .../activity/setup/GeneralPreferences.java | 83 ++++--------------- 2 files changed, 14 insertions(+), 131 deletions(-) delete mode 100644 res/xml/general_preferences.xml diff --git a/res/xml/general_preferences.xml b/res/xml/general_preferences.xml deleted file mode 100644 index 0bd26fcac..000000000 --- a/res/xml/general_preferences.xml +++ /dev/null @@ -1,62 +0,0 @@ - - - - - - - - - - - - - - - - - - - diff --git a/src/com/android/email/activity/setup/GeneralPreferences.java b/src/com/android/email/activity/setup/GeneralPreferences.java index 8118268a3..8f6a5c6ae 100644 --- a/src/com/android/email/activity/setup/GeneralPreferences.java +++ b/src/com/android/email/activity/setup/GeneralPreferences.java @@ -16,87 +16,32 @@ package com.android.email.activity.setup; -import android.content.ContentResolver; import android.os.Bundle; -import android.preference.ListPreference; import android.preference.Preference; -import android.preference.Preference.OnPreferenceChangeListener; -import android.preference.PreferenceFragment; +import android.preference.PreferenceGroup; import android.preference.PreferenceScreen; -import android.view.Menu; -import android.view.MenuInflater; -import android.view.MenuItem; -import com.android.email.R; -import com.android.email.provider.EmailProvider; -import com.android.mail.preferences.MailPrefs; -import com.android.mail.ui.settings.ClearPictureApprovalsDialogFragment; +import com.android.mail.preferences.MailPrefs.PreferenceKeys; +import com.android.mail.ui.settings.GeneralPrefsFragment; -public class GeneralPreferences extends PreferenceFragment implements - OnPreferenceChangeListener { +public class GeneralPreferences extends GeneralPrefsFragment { - private static final String AUTO_ADVANCE_MODE_WIDGET = "auto-advance-mode-widget"; - - private MailPrefs mMailPrefs; - private ListPreference mAutoAdvance; + public GeneralPreferences() {} @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); - setHasOptionsMenu(true); - mMailPrefs = MailPrefs.get(getActivity()); - getPreferenceManager().setSharedPreferencesName(mMailPrefs.getSharedPreferencesName()); - - // Load the preferences from an XML resource - addPreferencesFromResource(R.xml.general_preferences); - } - - @Override - public void onResume() { - loadSettings(); - super.onResume(); - } - - @Override - public boolean onPreferenceChange(Preference preference, Object newValue) { - String key = preference.getKey(); - // Indicate we need to send notifications to UI - if (AUTO_ADVANCE_MODE_WIDGET.equals(key)) { - mMailPrefs.setAutoAdvanceMode(mAutoAdvance.findIndexOfValue((String) newValue) + 1); - return true; + final PreferenceScreen ps = getPreferenceScreen(); + final Preference removalAction = findPreference(PreferenceKeys.REMOVAL_ACTION); + if (removalAction != null) { + ps.removePreference(removalAction); } - return false; - } - - private void loadSettings() { - mAutoAdvance = (ListPreference) findPreference(AUTO_ADVANCE_MODE_WIDGET); - mAutoAdvance.setValueIndex(mMailPrefs.getAutoAdvanceMode() - 1); - mAutoAdvance.setOnPreferenceChangeListener(this); - } - - @Override - public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) { - menu.clear(); - inflater.inflate(R.menu.general_prefs_fragment_menu, menu); - } - - @Override - public boolean onOptionsItemSelected(MenuItem item) { - switch (item.getItemId()) { - case R.id.clear_picture_approvals_menu_item: - clearDisplayImages(); - return true; + final Preference confirmArchive = findPreference(PreferenceKeys.CONFIRM_ARCHIVE); + final PreferenceGroup removalGroup = + (PreferenceGroup) findPreference(REMOVAL_ACTIONS_GROUP); + if (confirmArchive != null) { + removalGroup.removePreference(confirmArchive); } - - return super.onOptionsItemSelected(item); } - - private void clearDisplayImages() { - final ClearPictureApprovalsDialogFragment fragment = - ClearPictureApprovalsDialogFragment.newInstance(); - fragment.show(getActivity().getFragmentManager(), - ClearPictureApprovalsDialogFragment.FRAGMENT_TAG); - } - }