diff options
author | David Braun <dabraun@google.com> | 2013-09-16 13:45:42 -0700 |
---|---|---|
committer | David Braun <dabraun@google.com> | 2013-09-16 13:45:42 -0700 |
commit | 4e9f04de0a6511086f47479addb53b84c3bb9763 (patch) | |
tree | 5c4aa4bc108af50aa9a78a9c116e0147474d78b8 /src/com/android/settings/WirelessSettings.java | |
parent | 77fbf0c7a43fff4cf427a31186d1ca8777895205 (diff) | |
download | packages_apps_Settings-4e9f04de0a6511086f47479addb53b84c3bb9763.zip packages_apps_Settings-4e9f04de0a6511086f47479addb53b84c3bb9763.tar.gz packages_apps_Settings-4e9f04de0a6511086f47479addb53b84c3bb9763.tar.bz2 |
Implement new method for handling SMS/MMS on the platform
Multi project change:
The changes in this project update the settings app to support the new
default SMS app setting. I have also updated the order of the wireless
settings in the UX as per request from rachelg.
Bug: 10449618
Change-Id: Iba1ac6ea3f29c2a72af83b122ec5ea3a16a28e58
Diffstat (limited to 'src/com/android/settings/WirelessSettings.java')
-rw-r--r-- | src/com/android/settings/WirelessSettings.java | 97 |
1 files changed, 95 insertions, 2 deletions
diff --git a/src/com/android/settings/WirelessSettings.java b/src/com/android/settings/WirelessSettings.java index bff9ba7..e9b7419 100644 --- a/src/com/android/settings/WirelessSettings.java +++ b/src/com/android/settings/WirelessSettings.java @@ -21,11 +21,14 @@ import android.app.Activity; import android.app.AlertDialog; import android.app.Dialog; import android.app.admin.DevicePolicyManager; +import android.content.ComponentName; import android.content.Context; import android.content.DialogInterface; import android.content.Intent; import android.content.pm.PackageManager; +import android.content.pm.PackageManager.NameNotFoundException; import android.content.res.Resources; +import android.graphics.drawable.Drawable; import android.net.ConnectivityManager; import android.net.NetworkInfo; import android.nfc.NfcAdapter; @@ -34,17 +37,23 @@ import android.os.SystemProperties; import android.os.UserHandle; import android.preference.CheckBoxPreference; import android.preference.Preference; +import android.preference.Preference.OnPreferenceChangeListener; import android.preference.PreferenceScreen; import android.provider.Settings; import android.telephony.TelephonyManager; import android.text.TextUtils; import android.util.Log; + +import com.android.internal.telephony.SmsApplication; +import com.android.internal.telephony.SmsApplication.SmsApplicationData; import com.android.internal.telephony.TelephonyIntents; import com.android.internal.telephony.TelephonyProperties; import com.android.settings.nfc.NfcEnabler; -import com.android.settings.NsdEnabler; -public class WirelessSettings extends RestrictedSettingsFragment { +import java.util.Collection; + +public class WirelessSettings extends RestrictedSettingsFragment + implements OnPreferenceChangeListener { private static final String TAG = "WirelessSettings"; private static final String KEY_TOGGLE_AIRPLANE = "toggle_airplane"; @@ -56,6 +65,7 @@ public class WirelessSettings extends RestrictedSettingsFragment { private static final String KEY_PROXY_SETTINGS = "proxy_settings"; private static final String KEY_MOBILE_NETWORK_SETTINGS = "mobile_network_settings"; private static final String KEY_MANAGE_MOBILE_PLAN = "manage_mobile_plan"; + private static final String KEY_SMS_APPLICATION = "sms_application"; private static final String KEY_TOGGLE_NSD = "toggle_nsd"; //network service discovery private static final String KEY_CELL_BROADCAST_SETTINGS = "cell_broadcast_settings"; @@ -74,6 +84,8 @@ public class WirelessSettings extends RestrictedSettingsFragment { private static final int MANAGE_MOBILE_PLAN_DIALOG_ID = 1; private static final String SAVED_MANAGE_MOBILE_PLAN_MSG = "mManageMobilePlanMessage"; + private SmsListPreference mSmsApplicationPreference; + public WirelessSettings() { super(null); } @@ -152,6 +164,52 @@ public class WirelessSettings extends RestrictedSettingsFragment { } } + private void updateSmsApplicationSetting() { + log("updateSmsApplicationSetting:"); + ComponentName appName = SmsApplication.getDefaultSmsApplication(getActivity(), true); + if (appName != null) { + String packageName = appName.getPackageName(); + + CharSequence[] values = mSmsApplicationPreference.getEntryValues(); + for (int i = 0; i < values.length; i++) { + if (packageName.contentEquals(values[i])) { + mSmsApplicationPreference.setValueIndex(i); + mSmsApplicationPreference.setSummary(mSmsApplicationPreference.getEntries()[i]); + break; + } + } + } + } + + private void initSmsApplicationSetting() { + log("initSmsApplicationSetting:"); + Collection<SmsApplicationData> smsApplications = + SmsApplication.getApplicationCollection(getActivity()); + + // If the list is empty the dialog will be empty, but we will not crash. + int count = smsApplications.size(); + CharSequence[] entries = new CharSequence[count]; + CharSequence[] entryValues = new CharSequence[count]; + Drawable[] entryImages = new Drawable[count]; + + PackageManager packageManager = getPackageManager(); + int i = 0; + for (SmsApplicationData smsApplicationData : smsApplications) { + entries[i] = smsApplicationData.mApplicationName; + entryValues[i] = smsApplicationData.mPackageName; + try { + entryImages[i] = packageManager.getApplicationIcon(smsApplicationData.mPackageName); + } catch (NameNotFoundException e) { + entryImages[i] = packageManager.getDefaultActivityIcon(); + } + i++; + } + mSmsApplicationPreference.setEntries(entries); + mSmsApplicationPreference.setEntryValues(entryValues); + mSmsApplicationPreference.setEntryDrawables(entryImages); + updateSmsApplicationSetting(); + } + @Override public Dialog onCreateDialog(int dialogId) { log("onCreateDialog: dialogId=" + dialogId); @@ -187,6 +245,16 @@ public class WirelessSettings extends RestrictedSettingsFragment { return toggleable != null && toggleable.contains(type); } + private boolean isSmsSupported() { + // Some tablet has sim card but could not do telephony operations. Skip those. + if (mTm.getPhoneType() == TelephonyManager.PHONE_TYPE_NONE) { + return false; + } + int simState = mTm.getSimState(); + return simState != TelephonyManager.SIM_STATE_ABSENT && + simState != TelephonyManager.SIM_STATE_UNKNOWN; + } + @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); @@ -211,6 +279,9 @@ public class WirelessSettings extends RestrictedSettingsFragment { mAirplaneModeEnabler = new AirplaneModeEnabler(activity, mAirplaneModePreference); mNfcEnabler = new NfcEnabler(activity, nfc, androidBeam); + mSmsApplicationPreference = (SmsListPreference) findPreference(KEY_SMS_APPLICATION); + mSmsApplicationPreference.setOnPreferenceChangeListener(this); + // Remove NSD checkbox by default getPreferenceScreen().removePreference(nsd); //mNsdEnabler = new NsdEnabler(activity, nsd); @@ -269,6 +340,11 @@ public class WirelessSettings extends RestrictedSettingsFragment { protectByRestrictions(KEY_MOBILE_NETWORK_SETTINGS); protectByRestrictions(KEY_MANAGE_MOBILE_PLAN); + // Remove SMS Application if the device does not support SMS + if (!isSmsSupported()) { + removePreference(KEY_SMS_APPLICATION); + } + // Remove Airplane Mode settings if it's a stationary device such as a TV. if (getActivity().getPackageManager().hasSystemFeature(PackageManager.FEATURE_TELEVISION)) { removePreference(KEY_TOGGLE_AIRPLANE); @@ -316,6 +392,13 @@ public class WirelessSettings extends RestrictedSettingsFragment { } @Override + public void onStart() { + super.onStart(); + + initSmsApplicationSetting(); + } + + @Override public void onResume() { super.onResume(); @@ -365,4 +448,14 @@ public class WirelessSettings extends RestrictedSettingsFragment { protected int getHelpResource() { return R.string.help_url_more_networks; } + + @Override + public boolean onPreferenceChange(Preference preference, Object newValue) { + if (preference == mSmsApplicationPreference && newValue != null) { + SmsApplication.setDefaultApplication(newValue.toString(), getActivity()); + updateSmsApplicationSetting(); + return true; + } + return false; + } } |