Add Manage mobile plan to Settings.
Bug: 9279964 Change-Id: I42c326a21e05aa301e9d974ed9ac1d59472780ec
This commit is contained in:
@@ -2335,6 +2335,21 @@
|
||||
<!-- Wireless controls, item title to go into the network settings -->
|
||||
<string name="network_settings_title">Mobile networks</string>
|
||||
|
||||
<!-- Manage mobile plan [CHAR LIMIT=35]-->
|
||||
<string name="manage_mobile_plan_title" translatable="true">Manage mobile plan</string>
|
||||
|
||||
<!-- The SIM operator is not known [CHAR_ LIMIT=50]-->
|
||||
<string name="mobile_unknown_sim_operator" translatable="true">Uknown SIM operator</string>
|
||||
|
||||
<!-- There is no mobile provisiong website for the operator which is the firat parameter [CHAR_ LIMIT=50]-->
|
||||
<string name="mobile_no_provisioning_url" translatable="true">%1$s has no known provisioning website</string>
|
||||
|
||||
<!-- Ask user to insert a SIM card [CHAR_ LIMIT=50]-->
|
||||
<string name="mobile_insert_sim_card" translatable="true">Please insert SIM card and restart</string>
|
||||
|
||||
<!-- Ask user to connect to the internet [CHAR_ LIMIT=50]-->
|
||||
<string name="mobile_connect_to_internet" translatable="true">Please connect to the internet</string>
|
||||
|
||||
<!-- Security & location settings screen, section header for settings relating to location -->
|
||||
<string name="location_title">My Location</string>
|
||||
<!-- [CHAR LIMIT=30] Security & location settings screen, setting check box label for Google location service (cell ID, wifi, etc.) -->
|
||||
|
@@ -64,6 +64,11 @@
|
||||
android:targetClass="com.android.phone.MobileNetworkSettings" />
|
||||
</PreferenceScreen>
|
||||
|
||||
<Preference
|
||||
android:key="manage_mobile_plan"
|
||||
android:title="@string/manage_mobile_plan_title"
|
||||
android:persistent="false" />
|
||||
|
||||
<CheckBoxPreference
|
||||
android:key="toggle_nsd"
|
||||
android:title="@string/nsd_quick_toggle_title"
|
||||
|
@@ -17,12 +17,17 @@
|
||||
package com.android.settings;
|
||||
|
||||
import android.app.Activity;
|
||||
import android.app.AlertDialog;
|
||||
import android.app.Dialog;
|
||||
import android.app.admin.DevicePolicyManager;
|
||||
import android.content.Context;
|
||||
import android.content.DialogInterface;
|
||||
import android.content.Intent;
|
||||
import android.content.pm.PackageManager;
|
||||
import android.content.res.Resources;
|
||||
import android.net.ConnectivityManager;
|
||||
import android.net.wifi.p2p.WifiP2pManager;
|
||||
import android.net.NetworkInfo;
|
||||
import android.net.Uri;
|
||||
import android.nfc.NfcAdapter;
|
||||
import android.os.Bundle;
|
||||
import android.os.SystemProperties;
|
||||
@@ -31,16 +36,16 @@ import android.preference.CheckBoxPreference;
|
||||
import android.preference.Preference;
|
||||
import android.preference.PreferenceScreen;
|
||||
import android.provider.Settings;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.widget.Switch;
|
||||
|
||||
import android.telephony.TelephonyManager;
|
||||
import android.text.TextUtils;
|
||||
import android.util.Log;
|
||||
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 SettingsPreferenceFragment {
|
||||
private static final String TAG = "WirelessSettiings";
|
||||
|
||||
private static final String KEY_TOGGLE_AIRPLANE = "toggle_airplane";
|
||||
private static final String KEY_TOGGLE_NFC = "toggle_nfc";
|
||||
@@ -50,6 +55,7 @@ public class WirelessSettings extends SettingsPreferenceFragment {
|
||||
private static final String KEY_TETHER_SETTINGS = "tether_settings";
|
||||
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_TOGGLE_NSD = "toggle_nsd"; //network service discovery
|
||||
private static final String KEY_CELL_BROADCAST_SETTINGS = "cell_broadcast_settings";
|
||||
|
||||
@@ -62,6 +68,12 @@ public class WirelessSettings extends SettingsPreferenceFragment {
|
||||
private NfcAdapter mNfcAdapter;
|
||||
private NsdEnabler mNsdEnabler;
|
||||
|
||||
private ConnectivityManager mCm;
|
||||
private TelephonyManager mTm;
|
||||
|
||||
private static final int MANAGE_MOBILE_PLAN_DIALOG_ID = 1;
|
||||
private static final String SAVED_MANAGE_MOBILE_PLAN_MSG = "mManageMobilePlanMessage";
|
||||
|
||||
/**
|
||||
* Invoked on each preference click in this hierarchy, overrides
|
||||
* PreferenceActivity's implementation. Used to make sure we track the
|
||||
@@ -69,6 +81,7 @@ public class WirelessSettings extends SettingsPreferenceFragment {
|
||||
*/
|
||||
@Override
|
||||
public boolean onPreferenceTreeClick(PreferenceScreen preferenceScreen, Preference preference) {
|
||||
log("onPreferenceTreeClick: preference=" + preference);
|
||||
if (preference == mAirplaneModePreference && Boolean.parseBoolean(
|
||||
SystemProperties.get(TelephonyProperties.PROPERTY_INECM_MODE))) {
|
||||
// In ECM mode launch ECM app dialog
|
||||
@@ -76,11 +89,106 @@ public class WirelessSettings extends SettingsPreferenceFragment {
|
||||
new Intent(TelephonyIntents.ACTION_SHOW_NOTICE_ECM_BLOCK_OTHERS, null),
|
||||
REQUEST_CODE_EXIT_ECM);
|
||||
return true;
|
||||
} else if (preference == findPreference(KEY_MANAGE_MOBILE_PLAN)) {
|
||||
onManageMobilePlanClick();
|
||||
}
|
||||
// Let the intents be launched by the Preference manager
|
||||
return super.onPreferenceTreeClick(preferenceScreen, preference);
|
||||
}
|
||||
|
||||
private String mManageMobilePlanMessage;
|
||||
|
||||
public void onManageMobilePlanClick() {
|
||||
log("onManageMobilePlanClick:");
|
||||
mManageMobilePlanMessage = null;
|
||||
Resources resources = getActivity().getResources();
|
||||
|
||||
NetworkInfo ni = mCm.getActiveNetworkInfo();
|
||||
if (mTm.hasIccCard() && (ni != null)) {
|
||||
// Get provisioning URL
|
||||
String url = getProvisioningUrl();
|
||||
if (!TextUtils.isEmpty(url)) {
|
||||
// Send user to provisioning webpage
|
||||
Intent intent = new Intent(Intent.ACTION_VIEW);
|
||||
intent.setData(Uri.parse(url));
|
||||
startActivity(intent);
|
||||
mManageMobilePlanMessage = null;
|
||||
} else {
|
||||
// No provisioning URL
|
||||
String operatorName = mTm.getSimOperatorName();
|
||||
if (TextUtils.isEmpty(operatorName)) {
|
||||
// Use NetworkOperatorName as second choice in case there is no
|
||||
// SPN (Service Provider Name on the SIM). Such as with T-mobile.
|
||||
operatorName = mTm.getNetworkOperatorName();
|
||||
if (TextUtils.isEmpty(operatorName)) {
|
||||
mManageMobilePlanMessage = resources.getString(
|
||||
R.string.mobile_unknown_sim_operator);
|
||||
} else {
|
||||
mManageMobilePlanMessage = resources.getString(
|
||||
R.string.mobile_no_provisioning_url, operatorName);
|
||||
}
|
||||
} else {
|
||||
mManageMobilePlanMessage = resources.getString(
|
||||
R.string.mobile_no_provisioning_url, operatorName);
|
||||
}
|
||||
}
|
||||
} else if (mTm.hasIccCard() == false) {
|
||||
// No sim card
|
||||
mManageMobilePlanMessage = resources.getString(R.string.mobile_insert_sim_card);
|
||||
} else {
|
||||
// NetworkInfo is null, there is no connection
|
||||
mManageMobilePlanMessage = resources.getString(R.string.mobile_connect_to_internet);
|
||||
}
|
||||
if (!TextUtils.isEmpty(mManageMobilePlanMessage)) {
|
||||
log("onManageMobilePlanClick: message=" + mManageMobilePlanMessage);
|
||||
showDialog(MANAGE_MOBILE_PLAN_DIALOG_ID);
|
||||
}
|
||||
}
|
||||
|
||||
private String getProvisioningUrl() {
|
||||
String url = getActivity().getResources()
|
||||
.getString(com.android.internal.R.string.mobile_provisioning_url);
|
||||
log("getProvisioningUrl: mobile_provisioning_url=" + url);
|
||||
|
||||
// populate the iccid and imei in the provisioning url.
|
||||
if (!TextUtils.isEmpty(url)) {
|
||||
log("getProvisioningUrl: iccid=" + mTm.getSimSerialNumber()
|
||||
+ " imei=" + mTm.getDeviceId() + " phone number=" + mTm.getLine1Number());
|
||||
url = String.format(url,
|
||||
mTm.getSimSerialNumber() /* ICCID */,
|
||||
mTm.getDeviceId() /* IMEI */,
|
||||
mTm.getLine1Number() /* Phone number */);
|
||||
}
|
||||
|
||||
log("getProvisioningUrl: url=" + url);
|
||||
return url;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Dialog onCreateDialog(int dialogId) {
|
||||
log("onCreateDialog: dialogId=" + dialogId);
|
||||
switch (dialogId) {
|
||||
case MANAGE_MOBILE_PLAN_DIALOG_ID:
|
||||
return new AlertDialog.Builder(getActivity())
|
||||
.setMessage(mManageMobilePlanMessage)
|
||||
.setCancelable(false)
|
||||
.setPositiveButton(com.android.internal.R.string.ok,
|
||||
new DialogInterface.OnClickListener() {
|
||||
@Override
|
||||
public void onClick(DialogInterface dialog, int id) {
|
||||
log("MANAGE_MOBILE_PLAN_DIALOG.onClickListener id=" + id);
|
||||
mManageMobilePlanMessage = null;
|
||||
}
|
||||
})
|
||||
.create();
|
||||
}
|
||||
return super.onCreateDialog(dialogId);
|
||||
}
|
||||
|
||||
private void log(String s) {
|
||||
Log.d(TAG, s);
|
||||
}
|
||||
|
||||
public static boolean isRadioAllowed(Context context, String type) {
|
||||
if (!AirplaneModeEnabler.isAirplaneModeOn(context)) {
|
||||
return true;
|
||||
@@ -94,6 +202,13 @@ public class WirelessSettings extends SettingsPreferenceFragment {
|
||||
@Override
|
||||
public void onCreate(Bundle savedInstanceState) {
|
||||
super.onCreate(savedInstanceState);
|
||||
if (savedInstanceState != null) {
|
||||
mManageMobilePlanMessage = savedInstanceState.getString(SAVED_MANAGE_MOBILE_PLAN_MSG);
|
||||
}
|
||||
log("onCreate: mManageMobilePlanMessage=" + mManageMobilePlanMessage);
|
||||
|
||||
mCm = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
|
||||
mTm = (TelephonyManager) getSystemService(Context.TELEPHONY_SERVICE);
|
||||
|
||||
addPreferencesFromResource(R.xml.wireless_settings);
|
||||
|
||||
@@ -156,9 +271,10 @@ public class WirelessSettings extends SettingsPreferenceFragment {
|
||||
mNfcEnabler = null;
|
||||
}
|
||||
|
||||
// Remove Mobile Network Settings if it's a wifi-only device.
|
||||
// Remove Mobile Network Settings and Manage Mobile Plan if it's a wifi-only device.
|
||||
if (isSecondaryUser || Utils.isWifiOnly(getActivity())) {
|
||||
removePreference(KEY_MOBILE_NETWORK_SETTINGS);
|
||||
removePreference(KEY_MANAGE_MOBILE_PLAN);
|
||||
}
|
||||
|
||||
// Enable Proxy selector settings if allowed.
|
||||
@@ -213,6 +329,15 @@ public class WirelessSettings extends SettingsPreferenceFragment {
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onSaveInstanceState(Bundle outState) {
|
||||
super.onSaveInstanceState(outState);
|
||||
|
||||
if (!TextUtils.isEmpty(mManageMobilePlanMessage)) {
|
||||
outState.putString(SAVED_MANAGE_MOBILE_PLAN_MSG, mManageMobilePlanMessage);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onPause() {
|
||||
super.onPause();
|
||||
|
Reference in New Issue
Block a user