Handle fragment breadcrumbs for deep-linked settings launches.
This adds meta-data to the manifest for specifying the parent fragment and enabling a link in the breadcrumbs to navigate "up" a level even if the parent is not in the back-stack. Bug: 3236568 Fix a monkey issue in VpnSettings.
This commit is contained in:
@@ -118,6 +118,10 @@
|
|||||||
android:value="com.android.settings.wifi.WifiSettings" />
|
android:value="com.android.settings.wifi.WifiSettings" />
|
||||||
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
||||||
android:resource="@id/wireless_settings" />
|
android:resource="@id/wireless_settings" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_TITLE"
|
||||||
|
android:resource="@string/wireless_networks_settings_title" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_CLASS"
|
||||||
|
android:value="com.android.settings.Settings$WirelessSettingsActivity" />
|
||||||
</activity>
|
</activity>
|
||||||
|
|
||||||
<activity android:name=".wifi.WifiSettingsForSetupWizardXL"
|
<activity android:name=".wifi.WifiSettingsForSetupWizardXL"
|
||||||
@@ -210,6 +214,10 @@
|
|||||||
android:value="com.android.settings.bluetooth.BluetoothSettings" />
|
android:value="com.android.settings.bluetooth.BluetoothSettings" />
|
||||||
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
||||||
android:resource="@id/wireless_settings" />
|
android:resource="@id/wireless_settings" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_TITLE"
|
||||||
|
android:resource="@string/wireless_networks_settings_title" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_CLASS"
|
||||||
|
android:value="com.android.settings.Settings$WirelessSettingsActivity" />
|
||||||
</activity>
|
</activity>
|
||||||
|
|
||||||
<activity android:name=".bluetooth.DevicePickerActivity"
|
<activity android:name=".bluetooth.DevicePickerActivity"
|
||||||
@@ -234,6 +242,10 @@
|
|||||||
android:value="com.android.settings.TetherSettings" />
|
android:value="com.android.settings.TetherSettings" />
|
||||||
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
||||||
android:resource="@id/wireless_settings" />
|
android:resource="@id/wireless_settings" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_TITLE"
|
||||||
|
android:resource="@string/wireless_networks_settings_title" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_CLASS"
|
||||||
|
android:value="com.android.settings.Settings$WirelessSettingsActivity" />
|
||||||
</activity>
|
</activity>
|
||||||
|
|
||||||
<activity android:name="Settings$VpnSettingsActivity"
|
<activity android:name="Settings$VpnSettingsActivity"
|
||||||
@@ -252,6 +264,10 @@
|
|||||||
android:value="com.android.settings.vpn.VpnSettings" />
|
android:value="com.android.settings.vpn.VpnSettings" />
|
||||||
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
||||||
android:resource="@id/wireless_settings" />
|
android:resource="@id/wireless_settings" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_TITLE"
|
||||||
|
android:resource="@string/wireless_networks_settings_title" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_CLASS"
|
||||||
|
android:value="com.android.settings.Settings$WirelessSettingsActivity" />
|
||||||
</activity>
|
</activity>
|
||||||
|
|
||||||
<activity android:name="Settings$DateTimeSettingsActivity"
|
<activity android:name="Settings$DateTimeSettingsActivity"
|
||||||
@@ -327,6 +343,10 @@
|
|||||||
android:value="com.android.settings.inputmethod.InputMethodAndSubtypeEnabler" />
|
android:value="com.android.settings.inputmethod.InputMethodAndSubtypeEnabler" />
|
||||||
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
||||||
android:resource="@id/language_settings" />
|
android:resource="@id/language_settings" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_TITLE"
|
||||||
|
android:resource="@string/language_keyboard_settings_title" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_CLASS"
|
||||||
|
android:value="com.android.settings.Settings$InputMethodAndLanguageSettingsActivity" />
|
||||||
</activity>
|
</activity>
|
||||||
|
|
||||||
<activity android:name="PhysicalKeyboardSettings"
|
<activity android:name="PhysicalKeyboardSettings"
|
||||||
@@ -354,6 +374,10 @@
|
|||||||
android:value="com.android.settings.UserDictionarySettings" />
|
android:value="com.android.settings.UserDictionarySettings" />
|
||||||
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
||||||
android:resource="@id/language_settings" />
|
android:resource="@id/language_settings" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_TITLE"
|
||||||
|
android:resource="@string/language_keyboard_settings_title" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_CLASS"
|
||||||
|
android:value="com.android.settings.Settings$InputMethodAndLanguageSettingsActivity" />
|
||||||
</activity>
|
</activity>
|
||||||
|
|
||||||
<activity android:name="Settings$SoundSettingsActivity"
|
<activity android:name="Settings$SoundSettingsActivity"
|
||||||
@@ -475,6 +499,10 @@
|
|||||||
android:value="com.android.settings.applications.ManageApplications" />
|
android:value="com.android.settings.applications.ManageApplications" />
|
||||||
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
||||||
android:resource="@id/application_settings" />
|
android:resource="@id/application_settings" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_TITLE"
|
||||||
|
android:resource="@string/applications_settings_header" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_CLASS"
|
||||||
|
android:value="com.android.settings.Settings$ApplicationSettingsActivity" />
|
||||||
</activity>
|
</activity>
|
||||||
|
|
||||||
<!-- Keep compatibility with old shortcuts. -->
|
<!-- Keep compatibility with old shortcuts. -->
|
||||||
@@ -518,6 +546,10 @@
|
|||||||
android:value="com.android.settings.applications.ManageApplications" />
|
android:value="com.android.settings.applications.ManageApplications" />
|
||||||
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
||||||
android:resource="@id/application_settings" />
|
android:resource="@id/application_settings" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_TITLE"
|
||||||
|
android:resource="@string/applications_settings_header" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_CLASS"
|
||||||
|
android:value="com.android.settings.Settings$ApplicationSettingsActivity" />
|
||||||
</activity>
|
</activity>
|
||||||
|
|
||||||
<!-- Provide direct entry into manage apps showing running services. -->
|
<!-- Provide direct entry into manage apps showing running services. -->
|
||||||
@@ -535,6 +567,10 @@
|
|||||||
android:value="com.android.settings.applications.ManageApplications" />
|
android:value="com.android.settings.applications.ManageApplications" />
|
||||||
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
||||||
android:resource="@id/application_settings" />
|
android:resource="@id/application_settings" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_TITLE"
|
||||||
|
android:resource="@string/applications_settings_header" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_CLASS"
|
||||||
|
android:value="com.android.settings.Settings$ApplicationSettingsActivity" />
|
||||||
</activity>
|
</activity>
|
||||||
|
|
||||||
<activity android:name="Settings$SecuritySettingsActivity"
|
<activity android:name="Settings$SecuritySettingsActivity"
|
||||||
@@ -752,6 +788,10 @@
|
|||||||
android:value="com.android.settings.DevelopmentSettings" />
|
android:value="com.android.settings.DevelopmentSettings" />
|
||||||
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
||||||
android:resource="@id/application_settings" />
|
android:resource="@id/application_settings" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_TITLE"
|
||||||
|
android:resource="@string/applications_settings_header" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_CLASS"
|
||||||
|
android:value="com.android.settings.Settings$ApplicationSettingsActivity" />
|
||||||
</activity>
|
</activity>
|
||||||
|
|
||||||
|
|
||||||
@@ -927,6 +967,10 @@
|
|||||||
android:value="com.android.settings.fuelgauge.PowerUsageSummary" />
|
android:value="com.android.settings.fuelgauge.PowerUsageSummary" />
|
||||||
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
<meta-data android:name="com.android.settings.TOP_LEVEL_HEADER_ID"
|
||||||
android:resource="@id/application_settings" />
|
android:resource="@id/application_settings" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_TITLE"
|
||||||
|
android:resource="@string/applications_settings_header" />
|
||||||
|
<meta-data android:name="com.android.settings.PARENT_FRAGMENT_CLASS"
|
||||||
|
android:value="com.android.settings.Settings$ApplicationSettingsActivity" />
|
||||||
</activity>
|
</activity>
|
||||||
|
|
||||||
<activity
|
<activity
|
||||||
|
@@ -487,7 +487,7 @@
|
|||||||
<!-- Main Settings screen settings title for things like Wi-Fi, bluetooth, airplane mode. This will take you to another screen with those settings. -->
|
<!-- Main Settings screen settings title for things like Wi-Fi, bluetooth, airplane mode. This will take you to another screen with those settings. -->
|
||||||
<string name="radio_controls_title">Wireless & networks</string>
|
<string name="radio_controls_title">Wireless & networks</string>
|
||||||
<!-- Wireless Settings screen title for things like Wi-Fi, bluetooth, airplane mode. -->
|
<!-- Wireless Settings screen title for things like Wi-Fi, bluetooth, airplane mode. -->
|
||||||
<string name="wireless_networks_settings_title">Wireless & network settings</string>
|
<string name="wireless_networks_settings_title">Wireless & networks</string>
|
||||||
<!-- Main Settings screen settings summary text for the "Wireless controls" setting -->
|
<!-- Main Settings screen settings summary text for the "Wireless controls" setting -->
|
||||||
<string name="radio_controls_summary">Manage Wi-Fi, Bluetooth, airplane mode, mobile networks, & VPNs</string>
|
<string name="radio_controls_summary">Manage Wi-Fi, Bluetooth, airplane mode, mobile networks, & VPNs</string>
|
||||||
|
|
||||||
@@ -2180,7 +2180,7 @@ found in the list of installed applications.</string>
|
|||||||
<!-- Title of setting on main settings screen. This item will take the user to the screen to tweak settings realted to locale and text -->
|
<!-- Title of setting on main settings screen. This item will take the user to the screen to tweak settings realted to locale and text -->
|
||||||
<string name="language_settings">Language & input</string>
|
<string name="language_settings">Language & input</string>
|
||||||
<!-- Title of Language and keyboard settings screen -->
|
<!-- Title of Language and keyboard settings screen -->
|
||||||
<string name="language_keyboard_settings_title">Language & keyboard settings</string>
|
<string name="language_keyboard_settings_title">Language & input</string>
|
||||||
<!-- On Language & keyboard settings screen, heading. Inside the "Language & keyboard settings" screen, this is the header for settings that relate to language (select the system language, user dictionary for the language). -->
|
<!-- On Language & keyboard settings screen, heading. Inside the "Language & keyboard settings" screen, this is the header for settings that relate to language (select the system language, user dictionary for the language). -->
|
||||||
<string name="language_settings_category">Language settings</string>
|
<string name="language_settings_category">Language settings</string>
|
||||||
<!-- On Language & keyboard settings screen, heading. Inside the "Language & keyboard settings" screen, this is the header for settings that relate to keyboard (enable/disable each keyboard, settings for each keyboard). -->
|
<!-- On Language & keyboard settings screen, heading. Inside the "Language & keyboard settings" screen, this is the header for settings that relate to keyboard (enable/disable each keyboard, settings for each keyboard). -->
|
||||||
|
@@ -16,12 +16,17 @@
|
|||||||
|
|
||||||
package com.android.settings;
|
package com.android.settings;
|
||||||
|
|
||||||
|
import android.content.ComponentName;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.pm.ActivityInfo;
|
import android.content.pm.ActivityInfo;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.content.pm.PackageManager.NameNotFoundException;
|
import android.content.pm.PackageManager.NameNotFoundException;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.preference.PreferenceActivity;
|
import android.preference.PreferenceActivity;
|
||||||
|
import android.preference.PreferenceActivity.Header;
|
||||||
|
import android.util.Log;
|
||||||
|
import android.view.View;
|
||||||
|
import android.view.View.OnClickListener;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@@ -35,10 +40,20 @@ public class Settings extends PreferenceActivity {
|
|||||||
"com.android.settings.TOP_LEVEL_HEADER_ID";
|
"com.android.settings.TOP_LEVEL_HEADER_ID";
|
||||||
private static final String META_DATA_KEY_FRAGMENT_CLASS =
|
private static final String META_DATA_KEY_FRAGMENT_CLASS =
|
||||||
"com.android.settings.FRAGMENT_CLASS";
|
"com.android.settings.FRAGMENT_CLASS";
|
||||||
|
private static final String META_DATA_KEY_PARENT_TITLE =
|
||||||
|
"com.android.settings.PARENT_FRAGMENT_TITLE";
|
||||||
|
private static final String META_DATA_KEY_PARENT_FRAGMENT_CLASS =
|
||||||
|
"com.android.settings.PARENT_FRAGMENT_CLASS";
|
||||||
|
|
||||||
|
private static final String SAVE_KEY_CURRENT_HEADER = "com.android.settings.CURRENT_HEADER";
|
||||||
|
private static final String SAVE_KEY_PARENT_HEADER = "com.android.settings.PARENT_HEADER";
|
||||||
|
|
||||||
private String mFragmentClass;
|
private String mFragmentClass;
|
||||||
private int mTopLevelHeaderId;
|
private int mTopLevelHeaderId;
|
||||||
private Header mFirstHeader;
|
private Header mFirstHeader;
|
||||||
|
private Header mCurrentHeader;
|
||||||
|
private Header mParentHeader;
|
||||||
|
private boolean mInLocalHeaderSwitch;
|
||||||
|
|
||||||
// TODO: Update Call Settings based on airplane mode state.
|
// TODO: Update Call Settings based on airplane mode state.
|
||||||
|
|
||||||
@@ -47,7 +62,9 @@ public class Settings extends PreferenceActivity {
|
|||||||
@Override
|
@Override
|
||||||
protected void onCreate(Bundle savedInstanceState) {
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
getMetaData();
|
getMetaData();
|
||||||
|
mInLocalHeaderSwitch = true;
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
|
mInLocalHeaderSwitch = false;
|
||||||
|
|
||||||
if (!onIsHidingHeaders() && onIsMultiPane()) {
|
if (!onIsHidingHeaders() && onIsMultiPane()) {
|
||||||
highlightHeader();
|
highlightHeader();
|
||||||
@@ -55,6 +72,84 @@ public class Settings extends PreferenceActivity {
|
|||||||
// a specific settings screen.
|
// a specific settings screen.
|
||||||
setTitle(R.string.settings_label);
|
setTitle(R.string.settings_label);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Retrieve any saved state
|
||||||
|
if (savedInstanceState != null) {
|
||||||
|
mCurrentHeader = savedInstanceState.getParcelable(SAVE_KEY_CURRENT_HEADER);
|
||||||
|
mParentHeader = savedInstanceState.getParcelable(SAVE_KEY_PARENT_HEADER);
|
||||||
|
}
|
||||||
|
|
||||||
|
// If the current header was saved, switch to it
|
||||||
|
if (savedInstanceState != null && mCurrentHeader != null) {
|
||||||
|
//switchToHeaderLocal(mCurrentHeader);
|
||||||
|
showBreadCrumbs(mCurrentHeader.title, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mParentHeader != null) {
|
||||||
|
setParentTitle(mParentHeader.title, null, new OnClickListener() {
|
||||||
|
public void onClick(View v) {
|
||||||
|
switchToParent(mParentHeader.fragment);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onSaveInstanceState(Bundle outState) {
|
||||||
|
super.onSaveInstanceState(outState);
|
||||||
|
|
||||||
|
// Save the current fragment, if it is the same as originally launched
|
||||||
|
if (mCurrentHeader != null) {
|
||||||
|
outState.putParcelable(SAVE_KEY_CURRENT_HEADER, mCurrentHeader);
|
||||||
|
}
|
||||||
|
if (mParentHeader != null) {
|
||||||
|
outState.putParcelable(SAVE_KEY_PARENT_HEADER, mParentHeader);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void switchToHeaderLocal(Header header) {
|
||||||
|
mInLocalHeaderSwitch = true;
|
||||||
|
switchToHeader(header);
|
||||||
|
mInLocalHeaderSwitch = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void switchToHeader(Header header) {
|
||||||
|
if (!mInLocalHeaderSwitch) {
|
||||||
|
mCurrentHeader = null;
|
||||||
|
mParentHeader = null;
|
||||||
|
}
|
||||||
|
super.switchToHeader(header);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Switch to parent fragment and store the grand parent's info
|
||||||
|
* @param class name of the activity wrapper for the parent fragment.
|
||||||
|
*/
|
||||||
|
private void switchToParent(String className) {
|
||||||
|
final ComponentName cn = new ComponentName(this, className);
|
||||||
|
try {
|
||||||
|
final PackageManager pm = getPackageManager();
|
||||||
|
final ActivityInfo parentInfo = pm.getActivityInfo(cn, PackageManager.GET_META_DATA);
|
||||||
|
|
||||||
|
if (parentInfo != null && parentInfo.metaData != null) {
|
||||||
|
String fragmentClass = parentInfo.metaData.getString(META_DATA_KEY_FRAGMENT_CLASS);
|
||||||
|
CharSequence fragmentTitle = parentInfo.loadLabel(pm);
|
||||||
|
Header parentHeader = new Header();
|
||||||
|
parentHeader.fragment = fragmentClass;
|
||||||
|
parentHeader.title = fragmentTitle;
|
||||||
|
mCurrentHeader = parentHeader;
|
||||||
|
|
||||||
|
switchToHeaderLocal(parentHeader);
|
||||||
|
|
||||||
|
mParentHeader = new Header();
|
||||||
|
mParentHeader.fragment
|
||||||
|
= parentInfo.metaData.getString(META_DATA_KEY_PARENT_FRAGMENT_CLASS);
|
||||||
|
mParentHeader.title = parentInfo.metaData.getString(META_DATA_KEY_PARENT_TITLE);
|
||||||
|
}
|
||||||
|
} catch (NameNotFoundException nnfe) {
|
||||||
|
Log.w("Settings", "Could not find parent activity : " + className);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -64,7 +159,7 @@ public class Settings extends PreferenceActivity {
|
|||||||
// If it is not launched from history, then reset to top-level
|
// If it is not launched from history, then reset to top-level
|
||||||
if ((intent.getFlags() & Intent.FLAG_ACTIVITY_LAUNCHED_FROM_HISTORY) == 0
|
if ((intent.getFlags() & Intent.FLAG_ACTIVITY_LAUNCHED_FROM_HISTORY) == 0
|
||||||
&& mFirstHeader != null) {
|
&& mFirstHeader != null) {
|
||||||
switchToHeader(mFirstHeader);
|
switchToHeaderLocal(mFirstHeader);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -126,7 +221,9 @@ public class Settings extends PreferenceActivity {
|
|||||||
if (fragmentClass != null) {
|
if (fragmentClass != null) {
|
||||||
Header header = new Header();
|
Header header = new Header();
|
||||||
header.fragment = fragmentClass;
|
header.fragment = fragmentClass;
|
||||||
|
header.title = getTitle();
|
||||||
header.fragmentArguments = getIntent().getExtras();
|
header.fragmentArguments = getIntent().getExtras();
|
||||||
|
mCurrentHeader = header;
|
||||||
return header;
|
return header;
|
||||||
}
|
}
|
||||||
return super.onGetInitialHeader();
|
return super.onGetInitialHeader();
|
||||||
@@ -178,6 +275,17 @@ public class Settings extends PreferenceActivity {
|
|||||||
if (ai == null || ai.metaData == null) return;
|
if (ai == null || ai.metaData == null) return;
|
||||||
mTopLevelHeaderId = ai.metaData.getInt(META_DATA_KEY_HEADER_ID);
|
mTopLevelHeaderId = ai.metaData.getInt(META_DATA_KEY_HEADER_ID);
|
||||||
mFragmentClass = ai.metaData.getString(META_DATA_KEY_FRAGMENT_CLASS);
|
mFragmentClass = ai.metaData.getString(META_DATA_KEY_FRAGMENT_CLASS);
|
||||||
|
|
||||||
|
// Check if it has a parent specified and create a Header object
|
||||||
|
final int parentHeaderTitleRes = ai.metaData.getInt(META_DATA_KEY_PARENT_TITLE);
|
||||||
|
String parentFragmentClass = ai.metaData.getString(META_DATA_KEY_PARENT_FRAGMENT_CLASS);
|
||||||
|
if (parentFragmentClass != null) {
|
||||||
|
mParentHeader = new Header();
|
||||||
|
mParentHeader.fragment = parentFragmentClass;
|
||||||
|
if (parentHeaderTitleRes != 0) {
|
||||||
|
mParentHeader.title = getResources().getString(parentHeaderTitleRes);
|
||||||
|
}
|
||||||
|
}
|
||||||
} catch (NameNotFoundException nnfe) {
|
} catch (NameNotFoundException nnfe) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -196,6 +196,17 @@ public class VpnSettings extends SettingsPreferenceFragment
|
|||||||
super.onDestroyView();
|
super.onDestroyView();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onDestroy() {
|
||||||
|
super.onDestroy();
|
||||||
|
// Remove any onClick listeners
|
||||||
|
if (mVpnListContainer != null) {
|
||||||
|
for (int i = 0; i < mVpnListContainer.getPreferenceCount(); i++) {
|
||||||
|
mVpnListContainer.getPreference(i).setOnPreferenceClickListener(null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Dialog onCreateDialog (int id) {
|
public Dialog onCreateDialog (int id) {
|
||||||
switch (id) {
|
switch (id) {
|
||||||
@@ -1050,6 +1061,7 @@ public class VpnSettings extends SettingsPreferenceFragment
|
|||||||
changeState(p, VpnState.IDLE);
|
changeState(p, VpnState.IDLE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (getActivity() == null) return;
|
||||||
getActivity().unbindService(this);
|
getActivity().unbindService(this);
|
||||||
showPreferences();
|
showPreferences();
|
||||||
}
|
}
|
||||||
@@ -1058,6 +1070,7 @@ public class VpnSettings extends SettingsPreferenceFragment
|
|||||||
cv.open();
|
cv.open();
|
||||||
|
|
||||||
setDefaultState(list);
|
setDefaultState(list);
|
||||||
|
if (getActivity() == null) return;
|
||||||
getActivity().unbindService(this);
|
getActivity().unbindService(this);
|
||||||
showPreferences();
|
showPreferences();
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user