Add safety & regulatory info to "about device".

Renamed "Regulatory information" to "Regulatory labels"
and added a new option called "Safety & regulatory information".

The new option only shows if an activity exists that can
accept android.settings.SHOW_SAFETY_AND_REGULATORY_INFO intents.

BUG: 27876015
Change-Id: Iaf9588658eb7919b330ac8b3d673b8e81a4f76dc
This commit is contained in:
Andrew Sapperstein
2016-05-31 10:34:01 -07:00
parent c687e9bfbd
commit 1fad9af3c7
5 changed files with 29 additions and 13 deletions

View File

@@ -2665,7 +2665,7 @@
<!-- Show regulatory info (from settings item or dialing "*#07#") --> <!-- Show regulatory info (from settings item or dialing "*#07#") -->
<activity android:name="RegulatoryInfoDisplayActivity" <activity android:name="RegulatoryInfoDisplayActivity"
android:label="@string/regulatory_information" android:label="@string/regulatory_labels"
android:taskAffinity="" android:taskAffinity=""
android:enabled="@bool/config_show_regulatory_info"> android:enabled="@bool/config_show_regulatory_info">
<intent-filter> <intent-filter>

View File

@@ -3011,8 +3011,10 @@
<string name="contributors_title">Contributors</string> <string name="contributors_title">Contributors</string>
<!-- About phone settings screen, setting option name to show Manual [CHAR LIMIT=25] --> <!-- About phone settings screen, setting option name to show Manual [CHAR LIMIT=25] -->
<string name="manual">Manual</string> <string name="manual">Manual</string>
<!-- About phone settings screen, setting option name to show regulatory information [CHAR LIMIT=25] --> <!-- About phone settings screen, setting option name to show regulatory labels [CHAR LIMIT=25] -->
<string name="regulatory_information">Regulatory information</string> <string name="regulatory_labels">Regulatory labels</string>
<!-- About phone settings screen, setting option name to show safety and regulatory information [CHAR LIMIT=40] -->
<string name="safety_and_regulatory_info">Safety &amp; regulatory information</string>
<!-- Note: this may be replaced by a more-specific title of the activity that will get launched --> <skip /> <!-- Note: this may be replaced by a more-specific title of the activity that will get launched --> <skip />
<!-- About phone settings screen, setting option name to see copyright-related info --> <!-- About phone settings screen, setting option name to see copyright-related info -->
<string name="copyright_title">Copyright</string> <string name="copyright_title">Copyright</string>

View File

@@ -56,10 +56,16 @@
<PreferenceScreen <PreferenceScreen
android:key="regulatory_info" android:key="regulatory_info"
android:title="@string/regulatory_information"> android:title="@string/regulatory_labels">
<intent android:action="android.settings.SHOW_REGULATORY_INFO" /> <intent android:action="android.settings.SHOW_REGULATORY_INFO" />
</PreferenceScreen> </PreferenceScreen>
<PreferenceScreen
android:key="safety_info"
android:title="@string/safety_and_regulatory_info">
<intent android:action="android.settings.SHOW_SAFETY_AND_REGULATORY_INFO" />
</PreferenceScreen>
<!-- Feedback on the device --> <!-- Feedback on the device -->
<PreferenceScreen android:key="device_feedback" <PreferenceScreen android:key="device_feedback"
android:title="@string/device_feedback"> android:title="@string/device_feedback">

View File

@@ -175,14 +175,12 @@ public class DeviceInfoSettings extends SettingsPreferenceFragment implements In
// Remove manual entry if none present. // Remove manual entry if none present.
removePreferenceIfBoolFalse(KEY_MANUAL, R.bool.config_show_manual); removePreferenceIfBoolFalse(KEY_MANUAL, R.bool.config_show_manual);
// Remove regulatory information if none present. // Remove regulatory labels if no activity present to handle intent.
final Intent intent = new Intent(Settings.ACTION_SHOW_REGULATORY_INFO); removePreferenceIfActivityMissing(
if (getPackageManager().queryIntentActivities(intent, 0).isEmpty()) { KEY_REGULATORY_INFO, Settings.ACTION_SHOW_REGULATORY_INFO);
Preference pref = findPreference(KEY_REGULATORY_INFO);
if (pref != null) { removePreferenceIfActivityMissing(
getPreferenceScreen().removePreference(pref); "safety_info", "android.settings.SHOW_SAFETY_AND_REGULATORY_INFO");
}
}
} }
@Override @Override
@@ -327,6 +325,16 @@ public class DeviceInfoSettings extends SettingsPreferenceFragment implements In
} }
} }
private void removePreferenceIfActivityMissing(String preferenceKey, String action) {
final Intent intent = new Intent(action);
if (getPackageManager().queryIntentActivities(intent, 0).isEmpty()) {
Preference pref = findPreference(preferenceKey);
if (pref != null) {
getPreferenceScreen().removePreference(pref);
}
}
}
private void removePreferenceIfBoolFalse(String preference, int resId) { private void removePreferenceIfBoolFalse(String preference, int resId) {
if (!getResources().getBoolean(resId)) { if (!getResources().getBoolean(resId)) {
Preference pref = findPreference(preference); Preference pref = findPreference(preference);

View File

@@ -56,7 +56,7 @@ public class RegulatoryInfoDisplayActivity extends Activity implements
} }
AlertDialog.Builder builder = new AlertDialog.Builder(this) AlertDialog.Builder builder = new AlertDialog.Builder(this)
.setTitle(R.string.regulatory_information) .setTitle(R.string.regulatory_labels)
.setOnDismissListener(this); .setOnDismissListener(this);
boolean regulatoryInfoDrawableExists = false; boolean regulatoryInfoDrawableExists = false;