Merge "Fallback to AOSP emergency info if the original intent is broken" into rvc-dev
This commit is contained in:
committed by
Android (Google) Code Review
commit
afbf9e60c0
@@ -220,10 +220,21 @@
|
|||||||
<!-- Settings intelligence interaction log intent action -->
|
<!-- Settings intelligence interaction log intent action -->
|
||||||
<string name="config_settingsintelligence_log_action" translatable="false"></string>
|
<string name="config_settingsintelligence_log_action" translatable="false"></string>
|
||||||
|
|
||||||
|
<!-- AOSP Emergency app package name -->
|
||||||
|
<string name="config_aosp_emergency_package_name" translatable="false">
|
||||||
|
com.android.emergency
|
||||||
|
</string>
|
||||||
|
|
||||||
|
<!-- AOSP Emergency app intent action -->
|
||||||
|
<string name="config_aosp_emergency_intent_action" translatable="false">
|
||||||
|
android.settings.EDIT_EMERGENCY_INFO
|
||||||
|
</string>
|
||||||
|
|
||||||
<!-- Emergency app package name -->
|
<!-- Emergency app package name -->
|
||||||
<string name="config_emergency_package_name" translatable="false">
|
<string name="config_emergency_package_name" translatable="false">
|
||||||
com.android.emergency
|
com.android.emergency
|
||||||
</string>
|
</string>
|
||||||
|
|
||||||
<!-- Emergency app intent action -->
|
<!-- Emergency app intent action -->
|
||||||
<string name="config_emergency_intent_action" translatable="false">
|
<string name="config_emergency_intent_action" translatable="false">
|
||||||
android.settings.EDIT_EMERGENCY_INFO
|
android.settings.EDIT_EMERGENCY_INFO
|
||||||
|
@@ -24,6 +24,7 @@ import android.os.UserHandle;
|
|||||||
import android.os.UserManager;
|
import android.os.UserManager;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
|
|
||||||
|
import androidx.annotation.VisibleForTesting;
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
@@ -34,9 +35,8 @@ import java.util.List;
|
|||||||
|
|
||||||
public class EmergencyInfoPreferenceController extends BasePreferenceController {
|
public class EmergencyInfoPreferenceController extends BasePreferenceController {
|
||||||
|
|
||||||
public static String getIntentAction(Context context) {
|
@VisibleForTesting
|
||||||
return context.getResources().getString(R.string.config_emergency_intent_action);
|
Intent mIntent;
|
||||||
}
|
|
||||||
|
|
||||||
public EmergencyInfoPreferenceController(Context context, String preferenceKey) {
|
public EmergencyInfoPreferenceController(Context context, String preferenceKey) {
|
||||||
super(context, preferenceKey);
|
super(context, preferenceKey);
|
||||||
@@ -62,10 +62,9 @@ public class EmergencyInfoPreferenceController extends BasePreferenceController
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean handlePreferenceTreeClick(Preference preference) {
|
public boolean handlePreferenceTreeClick(Preference preference) {
|
||||||
if (TextUtils.equals(getPreferenceKey(), preference.getKey())) {
|
if (TextUtils.equals(getPreferenceKey(), preference.getKey()) && mIntent != null) {
|
||||||
Intent intent = new Intent(getIntentAction(mContext));
|
mIntent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
|
||||||
intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
|
mContext.startActivity(mIntent);
|
||||||
mContext.startActivity(intent);
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
@@ -76,15 +75,38 @@ public class EmergencyInfoPreferenceController extends BasePreferenceController
|
|||||||
if (!mContext.getResources().getBoolean(R.bool.config_show_emergency_info_in_device_info)) {
|
if (!mContext.getResources().getBoolean(R.bool.config_show_emergency_info_in_device_info)) {
|
||||||
return UNSUPPORTED_ON_DEVICE;
|
return UNSUPPORTED_ON_DEVICE;
|
||||||
}
|
}
|
||||||
final Intent intent = new Intent(getIntentAction(mContext)).setPackage(
|
|
||||||
getPackageName(mContext));
|
// If the variant of emergency info can not work, we should fallback to AOSP version.
|
||||||
final List<ResolveInfo> infos = mContext.getPackageManager().queryIntentActivities(intent,
|
if (isEmergencyInfoSupported()) {
|
||||||
0);
|
return AVAILABLE;
|
||||||
return infos != null && !infos.isEmpty()
|
} else if (isAOSPVersionSupported()) {
|
||||||
? AVAILABLE : UNSUPPORTED_ON_DEVICE;
|
return AVAILABLE;
|
||||||
|
}
|
||||||
|
return UNSUPPORTED_ON_DEVICE;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static String getPackageName(Context context) {
|
private boolean isEmergencyInfoSupported() {
|
||||||
return context.getResources().getString(R.string.config_emergency_package_name);
|
final String packageName = mContext.getResources().getString(
|
||||||
|
R.string.config_emergency_package_name);
|
||||||
|
final String intentName = mContext.getResources().getString(
|
||||||
|
R.string.config_emergency_intent_action);
|
||||||
|
mIntent = new Intent(intentName).setPackage(packageName);
|
||||||
|
final List<ResolveInfo> infos = mContext.getPackageManager().queryIntentActivities(mIntent,
|
||||||
|
0);
|
||||||
|
|
||||||
|
return infos != null && !infos.isEmpty();
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isAOSPVersionSupported() {
|
||||||
|
final String aospPackageName = mContext.getResources().getString(
|
||||||
|
R.string.config_aosp_emergency_package_name);
|
||||||
|
final String aospIntentName = mContext.getResources().getString(
|
||||||
|
R.string.config_aosp_emergency_intent_action);
|
||||||
|
|
||||||
|
mIntent = new Intent(aospIntentName).setPackage(aospPackageName);
|
||||||
|
final List<ResolveInfo> infos = mContext.getPackageManager().queryIntentActivities(mIntent,
|
||||||
|
0);
|
||||||
|
|
||||||
|
return infos != null && !infos.isEmpty();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -156,10 +156,11 @@ public class EmergencyInfoPreferenceControllerTest {
|
|||||||
final Preference preference = new Preference(activity);
|
final Preference preference = new Preference(activity);
|
||||||
preference.setKey("emergency_info");
|
preference.setKey("emergency_info");
|
||||||
mController = new EmergencyInfoPreferenceController(activity, preference.getKey());
|
mController = new EmergencyInfoPreferenceController(activity, preference.getKey());
|
||||||
|
mController.mIntent = new Intent("com.example.action.new").setPackage("com.example.test");
|
||||||
|
|
||||||
mController.handlePreferenceTreeClick(preference);
|
mController.handlePreferenceTreeClick(preference);
|
||||||
|
|
||||||
assertThat(application.getNextStartedActivity().getAction())
|
assertThat(application.getNextStartedActivity().getAction())
|
||||||
.isEqualTo("android.settings.EDIT_EMERGENCY_INFO");
|
.isEqualTo("com.example.action.new");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user