Fix legal info back button
Make it its own SettingsPreferenceFragment. whitespace-- Bug: 20727881 Change-Id: I1f790af03d316c1d43377a6d8606084d9f3a747f
This commit is contained in:
60
res/xml/about_legal.xml
Normal file
60
res/xml/about_legal.xml
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!-- Copyright (C) 2015 The Android Open Source Project
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:title="@string/legal_information">
|
||||||
|
|
||||||
|
<!-- Note: The titles given here probably won't be used. Instead, we programmatically
|
||||||
|
fill the title with the label of the activity with the corresponding action.
|
||||||
|
If there is not an activity for an action, the item will be removed from the
|
||||||
|
list. -->
|
||||||
|
|
||||||
|
<!-- Copyright information -->
|
||||||
|
<PreferenceScreen
|
||||||
|
android:key="copyright"
|
||||||
|
android:title="@string/copyright_title">
|
||||||
|
<intent android:action="android.settings.COPYRIGHT" />
|
||||||
|
</PreferenceScreen>
|
||||||
|
|
||||||
|
<!-- License information -->
|
||||||
|
<PreferenceScreen
|
||||||
|
android:key="license"
|
||||||
|
android:title="@string/license_title">
|
||||||
|
<intent android:action="android.settings.LICENSE" />
|
||||||
|
</PreferenceScreen>
|
||||||
|
|
||||||
|
<!-- Terms and conditions -->
|
||||||
|
<PreferenceScreen
|
||||||
|
android:key="terms"
|
||||||
|
android:title="@string/terms_title">
|
||||||
|
<intent android:action="android.settings.TERMS" />
|
||||||
|
</PreferenceScreen>
|
||||||
|
|
||||||
|
<!-- System WebView License information -->
|
||||||
|
<PreferenceScreen
|
||||||
|
android:key="webview_license"
|
||||||
|
android:title="@string/webview_license_title">
|
||||||
|
<intent android:action="android.settings.WEBVIEW_LICENSE" />
|
||||||
|
</PreferenceScreen>
|
||||||
|
|
||||||
|
<Preference
|
||||||
|
android:key="wallpaper_attributions"
|
||||||
|
android:title="@string/wallpaper_attributions"
|
||||||
|
android:summary="@string/wallpaper_attributions_values"
|
||||||
|
/>
|
||||||
|
|
||||||
|
</PreferenceScreen>
|
||||||
|
|
@@ -44,48 +44,8 @@
|
|||||||
<!-- Legal Information -->
|
<!-- Legal Information -->
|
||||||
<PreferenceScreen
|
<PreferenceScreen
|
||||||
android:key="container"
|
android:key="container"
|
||||||
android:title="@string/legal_information">
|
android:title="@string/legal_information"
|
||||||
|
android:fragment="com.android.settings.LegalSettings" />
|
||||||
<!-- Note: The titles given here probably won't be used. Instead, we programmatically
|
|
||||||
fill the title with the label of the activity with the corresponding action.
|
|
||||||
If there is not an activity for an action, the item will be removed from the
|
|
||||||
list. -->
|
|
||||||
|
|
||||||
<!-- Copyright information -->
|
|
||||||
<PreferenceScreen
|
|
||||||
android:key="copyright"
|
|
||||||
android:title="@string/copyright_title">
|
|
||||||
<intent android:action="android.settings.COPYRIGHT" />
|
|
||||||
</PreferenceScreen>
|
|
||||||
|
|
||||||
<!-- License information -->
|
|
||||||
<PreferenceScreen
|
|
||||||
android:key="license"
|
|
||||||
android:title="@string/license_title">
|
|
||||||
<intent android:action="android.settings.LICENSE" />
|
|
||||||
</PreferenceScreen>
|
|
||||||
|
|
||||||
<!-- Terms and conditions -->
|
|
||||||
<PreferenceScreen
|
|
||||||
android:key="terms"
|
|
||||||
android:title="@string/terms_title">
|
|
||||||
<intent android:action="android.settings.TERMS" />
|
|
||||||
</PreferenceScreen>
|
|
||||||
|
|
||||||
<!-- System WebView License information -->
|
|
||||||
<PreferenceScreen
|
|
||||||
android:key="webview_license"
|
|
||||||
android:title="@string/webview_license_title">
|
|
||||||
<intent android:action="android.settings.WEBVIEW_LICENSE" />
|
|
||||||
</PreferenceScreen>
|
|
||||||
|
|
||||||
<Preference
|
|
||||||
android:key="wallpaper_attributions"
|
|
||||||
android:title="@string/wallpaper_attributions"
|
|
||||||
android:summary="@string/wallpaper_attributions_values"
|
|
||||||
/>
|
|
||||||
|
|
||||||
</PreferenceScreen>
|
|
||||||
|
|
||||||
<PreferenceScreen
|
<PreferenceScreen
|
||||||
android:key="regulatory_info"
|
android:key="regulatory_info"
|
||||||
|
@@ -57,12 +57,7 @@ public class DeviceInfoSettings extends SettingsPreferenceFragment implements In
|
|||||||
private static final String FILENAME_PROC_VERSION = "/proc/version";
|
private static final String FILENAME_PROC_VERSION = "/proc/version";
|
||||||
private static final String FILENAME_MSV = "/sys/board_properties/soc/msv";
|
private static final String FILENAME_MSV = "/sys/board_properties/soc/msv";
|
||||||
|
|
||||||
private static final String KEY_CONTAINER = "container";
|
|
||||||
private static final String KEY_REGULATORY_INFO = "regulatory_info";
|
private static final String KEY_REGULATORY_INFO = "regulatory_info";
|
||||||
private static final String KEY_TERMS = "terms";
|
|
||||||
private static final String KEY_LICENSE = "license";
|
|
||||||
private static final String KEY_COPYRIGHT = "copyright";
|
|
||||||
private static final String KEY_WEBVIEW_LICENSE = "webview_license";
|
|
||||||
private static final String KEY_SYSTEM_UPDATE_SETTINGS = "system_update_settings";
|
private static final String KEY_SYSTEM_UPDATE_SETTINGS = "system_update_settings";
|
||||||
private static final String PROPERTY_URL_SAFETYLEGAL = "ro.url.safetylegal";
|
private static final String PROPERTY_URL_SAFETYLEGAL = "ro.url.safetylegal";
|
||||||
private static final String PROPERTY_SELINUX_STATUS = "ro.build.selinux";
|
private static final String PROPERTY_SELINUX_STATUS = "ro.build.selinux";
|
||||||
@@ -145,19 +140,9 @@ public class DeviceInfoSettings extends SettingsPreferenceFragment implements In
|
|||||||
* info.
|
* info.
|
||||||
*/
|
*/
|
||||||
final Activity act = getActivity();
|
final Activity act = getActivity();
|
||||||
// These are contained in the "container" preference group
|
|
||||||
PreferenceGroup parentPreference = (PreferenceGroup) findPreference(KEY_CONTAINER);
|
|
||||||
Utils.updatePreferenceToSpecificActivityOrRemove(act, parentPreference, KEY_TERMS,
|
|
||||||
Utils.UPDATE_PREFERENCE_FLAG_SET_TITLE_TO_MATCHING_ACTIVITY);
|
|
||||||
Utils.updatePreferenceToSpecificActivityOrRemove(act, parentPreference, KEY_LICENSE,
|
|
||||||
Utils.UPDATE_PREFERENCE_FLAG_SET_TITLE_TO_MATCHING_ACTIVITY);
|
|
||||||
Utils.updatePreferenceToSpecificActivityOrRemove(act, parentPreference, KEY_COPYRIGHT,
|
|
||||||
Utils.UPDATE_PREFERENCE_FLAG_SET_TITLE_TO_MATCHING_ACTIVITY);
|
|
||||||
Utils.updatePreferenceToSpecificActivityOrRemove(act, parentPreference, KEY_WEBVIEW_LICENSE,
|
|
||||||
Utils.UPDATE_PREFERENCE_FLAG_SET_TITLE_TO_MATCHING_ACTIVITY);
|
|
||||||
|
|
||||||
// These are contained by the root preference screen
|
// These are contained by the root preference screen
|
||||||
parentPreference = getPreferenceScreen();
|
PreferenceGroup parentPreference = getPreferenceScreen();
|
||||||
if (UserHandle.myUserId() == UserHandle.USER_OWNER) {
|
if (UserHandle.myUserId() == UserHandle.USER_OWNER) {
|
||||||
Utils.updatePreferenceToSpecificActivityOrRemove(act, parentPreference,
|
Utils.updatePreferenceToSpecificActivityOrRemove(act, parentPreference,
|
||||||
KEY_SYSTEM_UPDATE_SETTINGS,
|
KEY_SYSTEM_UPDATE_SETTINGS,
|
||||||
@@ -450,18 +435,6 @@ public class DeviceInfoSettings extends SettingsPreferenceFragment implements In
|
|||||||
if (TextUtils.isEmpty(getFeedbackReporterPackage(context))) {
|
if (TextUtils.isEmpty(getFeedbackReporterPackage(context))) {
|
||||||
keys.add(KEY_DEVICE_FEEDBACK);
|
keys.add(KEY_DEVICE_FEEDBACK);
|
||||||
}
|
}
|
||||||
if (!checkIntentAction(context, "android.settings.TERMS")) {
|
|
||||||
keys.add(KEY_TERMS);
|
|
||||||
}
|
|
||||||
if (!checkIntentAction(context, "android.settings.LICENSE")) {
|
|
||||||
keys.add(KEY_LICENSE);
|
|
||||||
}
|
|
||||||
if (!checkIntentAction(context, "android.settings.COPYRIGHT")) {
|
|
||||||
keys.add(KEY_COPYRIGHT);
|
|
||||||
}
|
|
||||||
if (!checkIntentAction(context, "android.settings.WEBVIEW_LICENSE")) {
|
|
||||||
keys.add(KEY_WEBVIEW_LICENSE);
|
|
||||||
}
|
|
||||||
if (UserHandle.myUserId() != UserHandle.USER_OWNER) {
|
if (UserHandle.myUserId() != UserHandle.USER_OWNER) {
|
||||||
keys.add(KEY_SYSTEM_UPDATE_SETTINGS);
|
keys.add(KEY_SYSTEM_UPDATE_SETTINGS);
|
||||||
}
|
}
|
||||||
@@ -475,25 +448,6 @@ public class DeviceInfoSettings extends SettingsPreferenceFragment implements In
|
|||||||
private boolean isPropertyMissing(String property) {
|
private boolean isPropertyMissing(String property) {
|
||||||
return SystemProperties.get(property).equals("");
|
return SystemProperties.get(property).equals("");
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean checkIntentAction(Context context, String action) {
|
|
||||||
final Intent intent = new Intent(action);
|
|
||||||
|
|
||||||
// Find the activity that is in the system image
|
|
||||||
final PackageManager pm = context.getPackageManager();
|
|
||||||
final List<ResolveInfo> list = pm.queryIntentActivities(intent, 0);
|
|
||||||
final int listSize = list.size();
|
|
||||||
|
|
||||||
for (int i = 0; i < listSize; i++) {
|
|
||||||
ResolveInfo resolveInfo = list.get(i);
|
|
||||||
if ((resolveInfo.activityInfo.applicationInfo.flags &
|
|
||||||
ApplicationInfo.FLAG_SYSTEM) != 0) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -26,6 +26,8 @@ public abstract class InstrumentedFragment extends PreferenceFragment {
|
|||||||
// Declare new temporary categories here, starting after this value.
|
// Declare new temporary categories here, starting after this value.
|
||||||
public static final int UNDECLARED = 100000;
|
public static final int UNDECLARED = 100000;
|
||||||
|
|
||||||
|
public static final int ABOUT_LEGAL_SETTINGS = UNDECLARED + 1;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Declare the view of this category.
|
* Declare the view of this category.
|
||||||
*
|
*
|
||||||
|
114
src/com/android/settings/LegalSettings.java
Normal file
114
src/com/android/settings/LegalSettings.java
Normal file
@@ -0,0 +1,114 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2015 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.android.settings;
|
||||||
|
|
||||||
|
import android.app.Activity;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.content.pm.ApplicationInfo;
|
||||||
|
import android.content.pm.PackageManager;
|
||||||
|
import android.content.pm.ResolveInfo;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.preference.PreferenceGroup;
|
||||||
|
import android.provider.SearchIndexableResource;
|
||||||
|
|
||||||
|
import com.android.settings.search.BaseSearchIndexProvider;
|
||||||
|
import com.android.settings.search.Indexable;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class LegalSettings extends SettingsPreferenceFragment implements Indexable {
|
||||||
|
|
||||||
|
private static final String KEY_TERMS = "terms";
|
||||||
|
private static final String KEY_LICENSE = "license";
|
||||||
|
private static final String KEY_COPYRIGHT = "copyright";
|
||||||
|
private static final String KEY_WEBVIEW_LICENSE = "webview_license";
|
||||||
|
|
||||||
|
public void onCreate(Bundle icicle) {
|
||||||
|
super.onCreate(icicle);
|
||||||
|
addPreferencesFromResource(R.xml.about_legal);
|
||||||
|
|
||||||
|
final Activity act = getActivity();
|
||||||
|
// These are contained in the "container" preference group
|
||||||
|
PreferenceGroup parentPreference = getPreferenceScreen();
|
||||||
|
Utils.updatePreferenceToSpecificActivityOrRemove(act, parentPreference, KEY_TERMS,
|
||||||
|
Utils.UPDATE_PREFERENCE_FLAG_SET_TITLE_TO_MATCHING_ACTIVITY);
|
||||||
|
Utils.updatePreferenceToSpecificActivityOrRemove(act, parentPreference, KEY_LICENSE,
|
||||||
|
Utils.UPDATE_PREFERENCE_FLAG_SET_TITLE_TO_MATCHING_ACTIVITY);
|
||||||
|
Utils.updatePreferenceToSpecificActivityOrRemove(act, parentPreference, KEY_COPYRIGHT,
|
||||||
|
Utils.UPDATE_PREFERENCE_FLAG_SET_TITLE_TO_MATCHING_ACTIVITY);
|
||||||
|
Utils.updatePreferenceToSpecificActivityOrRemove(act, parentPreference, KEY_WEBVIEW_LICENSE,
|
||||||
|
Utils.UPDATE_PREFERENCE_FLAG_SET_TITLE_TO_MATCHING_ACTIVITY);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected int getMetricsCategory() {
|
||||||
|
return InstrumentedFragment.ABOUT_LEGAL_SETTINGS;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static final SearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
|
||||||
|
new BaseSearchIndexProvider() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<SearchIndexableResource> getXmlResourcesToIndex(
|
||||||
|
Context context, boolean enabled) {
|
||||||
|
final SearchIndexableResource sir = new SearchIndexableResource(context);
|
||||||
|
sir.xmlResId = R.xml.about_legal;
|
||||||
|
return Arrays.asList(sir);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<String> getNonIndexableKeys(Context context) {
|
||||||
|
final List<String> keys = new ArrayList<String>();
|
||||||
|
if (!checkIntentAction(context, "android.settings.TERMS")) {
|
||||||
|
keys.add(KEY_TERMS);
|
||||||
|
}
|
||||||
|
if (!checkIntentAction(context, "android.settings.LICENSE")) {
|
||||||
|
keys.add(KEY_LICENSE);
|
||||||
|
}
|
||||||
|
if (!checkIntentAction(context, "android.settings.COPYRIGHT")) {
|
||||||
|
keys.add(KEY_COPYRIGHT);
|
||||||
|
}
|
||||||
|
if (!checkIntentAction(context, "android.settings.WEBVIEW_LICENSE")) {
|
||||||
|
keys.add(KEY_WEBVIEW_LICENSE);
|
||||||
|
}
|
||||||
|
return keys;
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean checkIntentAction(Context context, String action) {
|
||||||
|
final Intent intent = new Intent(action);
|
||||||
|
|
||||||
|
// Find the activity that is in the system image
|
||||||
|
final PackageManager pm = context.getPackageManager();
|
||||||
|
final List<ResolveInfo> list = pm.queryIntentActivities(intent, 0);
|
||||||
|
final int listSize = list.size();
|
||||||
|
|
||||||
|
for (int i = 0; i < listSize; i++) {
|
||||||
|
ResolveInfo resolveInfo = list.get(i);
|
||||||
|
if ((resolveInfo.activityInfo.applicationInfo.flags &
|
||||||
|
ApplicationInfo.FLAG_SYSTEM) != 0) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
@@ -23,6 +23,7 @@ import com.android.settings.DevelopmentSettings;
|
|||||||
import com.android.settings.DeviceInfoSettings;
|
import com.android.settings.DeviceInfoSettings;
|
||||||
import com.android.settings.DisplaySettings;
|
import com.android.settings.DisplaySettings;
|
||||||
import com.android.settings.HomeSettings;
|
import com.android.settings.HomeSettings;
|
||||||
|
import com.android.settings.LegalSettings;
|
||||||
import com.android.settings.PrivacySettings;
|
import com.android.settings.PrivacySettings;
|
||||||
import com.android.settings.ScreenPinningSettings;
|
import com.android.settings.ScreenPinningSettings;
|
||||||
import com.android.settings.SecuritySettings;
|
import com.android.settings.SecuritySettings;
|
||||||
@@ -172,6 +173,7 @@ public final class Ranking {
|
|||||||
|
|
||||||
// Device infos
|
// Device infos
|
||||||
sRankMap.put(DeviceInfoSettings.class.getName(), RANK_DEVICE_INFO);
|
sRankMap.put(DeviceInfoSettings.class.getName(), RANK_DEVICE_INFO);
|
||||||
|
sRankMap.put(LegalSettings.class.getName(), RANK_DEVICE_INFO);
|
||||||
|
|
||||||
sBaseRankMap.put("com.android.settings", 0);
|
sBaseRankMap.put("com.android.settings", 0);
|
||||||
}
|
}
|
||||||
|
@@ -24,6 +24,7 @@ import com.android.settings.DevelopmentSettings;
|
|||||||
import com.android.settings.DeviceInfoSettings;
|
import com.android.settings.DeviceInfoSettings;
|
||||||
import com.android.settings.DisplaySettings;
|
import com.android.settings.DisplaySettings;
|
||||||
import com.android.settings.HomeSettings;
|
import com.android.settings.HomeSettings;
|
||||||
|
import com.android.settings.LegalSettings;
|
||||||
import com.android.settings.PrivacySettings;
|
import com.android.settings.PrivacySettings;
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.ScreenPinningSettings;
|
import com.android.settings.ScreenPinningSettings;
|
||||||
@@ -296,6 +297,13 @@ public final class SearchIndexableResources {
|
|||||||
DeviceInfoSettings.class.getName(),
|
DeviceInfoSettings.class.getName(),
|
||||||
R.drawable.ic_settings_about));
|
R.drawable.ic_settings_about));
|
||||||
|
|
||||||
|
sResMap.put(LegalSettings.class.getName(),
|
||||||
|
new SearchIndexableResource(
|
||||||
|
Ranking.getRankForClassName(LegalSettings.class.getName()),
|
||||||
|
NO_DATA_RES_ID,
|
||||||
|
LegalSettings.class.getName(),
|
||||||
|
R.drawable.ic_settings_about));
|
||||||
|
|
||||||
sResMap.put(WifiCallingSettings.class.getName(),
|
sResMap.put(WifiCallingSettings.class.getName(),
|
||||||
new SearchIndexableResource(
|
new SearchIndexableResource(
|
||||||
Ranking.getRankForClassName(WifiCallingSettings.class.getName()),
|
Ranking.getRankForClassName(WifiCallingSettings.class.getName()),
|
||||||
|
Reference in New Issue
Block a user