diff options
Diffstat (limited to 'src/com/android/settings/profiles')
-rw-r--r-- | src/com/android/settings/profiles/SetupActionsFragment.java | 89 | ||||
-rw-r--r-- | src/com/android/settings/profiles/actions/item/ConnectionOverrideItem.java | 39 |
2 files changed, 99 insertions, 29 deletions
diff --git a/src/com/android/settings/profiles/SetupActionsFragment.java b/src/com/android/settings/profiles/SetupActionsFragment.java index 6b9c962..485981a 100644 --- a/src/com/android/settings/profiles/SetupActionsFragment.java +++ b/src/com/android/settings/profiles/SetupActionsFragment.java @@ -74,7 +74,7 @@ import com.android.settings.profiles.actions.item.VolumeStreamItem; import java.util.ArrayList; import java.util.List; -import static android.app.ConnectionSettings.PROFILE_CONNECTION_2G3G; +import static android.app.ConnectionSettings.PROFILE_CONNECTION_2G3G4G; import static android.app.ConnectionSettings.PROFILE_CONNECTION_BLUETOOTH; import static android.app.ConnectionSettings.PROFILE_CONNECTION_GPS; import static android.app.ConnectionSettings.PROFILE_CONNECTION_MOBILEDATA; @@ -169,7 +169,7 @@ public class SetupActionsFragment extends SettingsPreferenceFragment final TelephonyManager tm = (TelephonyManager) getActivity().getSystemService(Context.TELEPHONY_SERVICE); if (tm.getPhoneType() == TelephonyManager.PHONE_TYPE_GSM) { - mItems.add(generateConnectionOverrideItem(PROFILE_CONNECTION_2G3G)); + mItems.add(generateConnectionOverrideItem(PROFILE_CONNECTION_2G3G4G)); } } if (WimaxHelper.isWimaxSupported(getActivity())) { @@ -585,27 +585,64 @@ public class SetupActionsFragment extends SettingsPreferenceFragment builder.setTitle(ConnectionOverrideItem.getConnectionTitle(setting.getConnectionId())); builder.setSingleChoiceItems(connectionNames, defaultIndex, new DialogInterface.OnClickListener() { - @Override - public void onClick(DialogInterface dialog, int item) { - switch (item) { - case 0: // disable override - setting.setOverride(false); - break; - case 1: // enable override, disable - setting.setOverride(true); - setting.setValue(0); - break; - case 2: // enable override, enable - setting.setOverride(true); - setting.setValue(1); - break; - } - mProfile.setConnectionSettings(setting); - mAdapter.notifyDataSetChanged(); - updateProfile(); - dialog.dismiss(); - } - }); + @Override + public void onClick(DialogInterface dialog, int item) { + switch (item) { + case 0: // disable override + setting.setOverride(false); + break; + case 1: // enable override, disable + setting.setOverride(true); + setting.setValue(0); + break; + case 2: // enable override, enable + setting.setOverride(true); + setting.setValue(1); + break; + } + mProfile.setConnectionSettings(setting); + mAdapter.notifyDataSetChanged(); + updateProfile(); + dialog.dismiss(); + } + }); + + builder.setNegativeButton(android.R.string.cancel, null); + builder.show(); + } + + private void requestMobileConnectionOverrideDialog(final ConnectionSettings setting) { + if (setting == null) { + throw new UnsupportedOperationException("connection setting cannot be null yo"); + } + AlertDialog.Builder builder = new AlertDialog.Builder(getActivity()); + final String[] connectionNames = + getResources().getStringArray(R.array.profile_networkmode_entries_4g); + + int defaultIndex = ConnectionOverrideItem.CM_MODE_UNCHANGED; // no action + if (setting.isOverride()) { + defaultIndex = setting.getValue(); + } + + builder.setTitle(ConnectionOverrideItem.getConnectionTitle(setting.getConnectionId())); + builder.setSingleChoiceItems(connectionNames, defaultIndex, + new DialogInterface.OnClickListener() { + @Override + public void onClick(DialogInterface dialog, int item) { + switch (item) { + case ConnectionOverrideItem.CM_MODE_UNCHANGED: + setting.setOverride(false); + break; + default: + setting.setOverride(true); + setting.setValue(item); + } + mProfile.setConnectionSettings(setting); + mAdapter.notifyDataSetChanged(); + updateProfile(); + dialog.dismiss(); + } + }); builder.setNegativeButton(android.R.string.cancel, null); builder.show(); @@ -726,7 +763,11 @@ public class SetupActionsFragment extends SettingsPreferenceFragment requestRingModeDialog(item.getSettings()); } else if (itemAtPosition instanceof ConnectionOverrideItem) { ConnectionOverrideItem item = (ConnectionOverrideItem) itemAtPosition; - requestConnectionOverrideDialog(item.getSettings()); + if (item.getConnectionType() == ConnectionSettings.PROFILE_CONNECTION_2G3G4G) { + requestMobileConnectionOverrideDialog(item.getSettings()); + } else { + requestConnectionOverrideDialog(item.getSettings()); + } } else if (itemAtPosition instanceof VolumeStreamItem) { VolumeStreamItem item = (VolumeStreamItem) itemAtPosition; requestVolumeDialog(item.getStreamType(), item.getSettings()); diff --git a/src/com/android/settings/profiles/actions/item/ConnectionOverrideItem.java b/src/com/android/settings/profiles/actions/item/ConnectionOverrideItem.java index 74efd27..7ec5553 100644 --- a/src/com/android/settings/profiles/actions/item/ConnectionOverrideItem.java +++ b/src/com/android/settings/profiles/actions/item/ConnectionOverrideItem.java @@ -28,6 +28,13 @@ public class ConnectionOverrideItem implements Item { int mConnectionId; ConnectionSettings mConnectionSettings; + public static final int CM_MODE_2G = 0; + public static final int CM_MODE_3G = 1; + public static final int CM_MODE_4G = 2; + public static final int CM_MODE_2G3G = 3; + public static final int CM_MODE_ALL = 4; + public static final int CM_MODE_UNCHANGED = 5; + public ConnectionOverrideItem(int connectionId, ConnectionSettings settings) { mConnectionId = connectionId; if (settings == null) { @@ -71,8 +78,8 @@ public class ConnectionOverrideItem implements Item { return R.string.toggleBluetooth; case ConnectionSettings.PROFILE_CONNECTION_MOBILEDATA: return R.string.toggleData; - case ConnectionSettings.PROFILE_CONNECTION_2G3G: - return R.string.toggle2g3g; + case ConnectionSettings.PROFILE_CONNECTION_2G3G4G: + return R.string.toggle2g3g4g; case ConnectionSettings.PROFILE_CONNECTION_GPS: return R.string.toggleGPS; case ConnectionSettings.PROFILE_CONNECTION_NFC: @@ -89,9 +96,31 @@ public class ConnectionOverrideItem implements Item { } public int getSummary() { - if (mConnectionSettings != null && mConnectionSettings.isOverride()) { - if (mConnectionSettings.getValue() == 1) { - return R.string.profile_action_enable; + if (mConnectionSettings != null) { + if (mConnectionId == ConnectionSettings.PROFILE_CONNECTION_2G3G4G) { // different options + if (mConnectionSettings.isOverride()) { + switch (mConnectionSettings.getValue()) { + case CM_MODE_2G: + return R.string.profile_networkmode_2g; + case CM_MODE_3G: + return R.string.profile_networkmode_3g; + case CM_MODE_4G: + return R.string.profile_networkmode_4g; + case CM_MODE_2G3G: + return R.string.profile_networkmode_2g3g; + default: + case CM_MODE_ALL: + return R.string.profile_networkmode_2g3g4g; + } + } else { + return R.string.profile_action_none; + } + } else if (mConnectionSettings.isOverride()) { // enabled, disabled, or none + if (mConnectionSettings.getValue() == 1) { + return R.string.profile_action_enable; + } else { + return R.string.profile_action_disable; + } } else { return R.string.profile_action_disable; } |