Show current WebView package as selected in Dev Setting.
When intenting to the select-webview-implementation Dev Setting a user won't know which package is currently being used as WebView implementation. To solve this we change the background color of the item representing the current WebView package. With this CL, also ensure we update the summary of the WebView implementation Dev Setting even if we failed to switch to the package chosen by the user - we might have switched to another package instead. Bug: 34702900 Test: Ensure the current WebView package has a different background color than the rest of the packages. Change-Id: Ieb65fdc635d5dd1253931c8ab8bb0d827a142c56
This commit is contained in:
@@ -16,8 +16,10 @@ package com.android.settings.webview;
|
||||
|
||||
import android.content.Context;
|
||||
import android.content.pm.ApplicationInfo;
|
||||
import android.content.pm.PackageInfo;
|
||||
import android.content.pm.PackageManager;
|
||||
import android.os.RemoteException;
|
||||
import android.graphics.Color;
|
||||
import android.support.annotation.VisibleForTesting;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
@@ -36,6 +38,7 @@ import java.util.List;
|
||||
*/
|
||||
class WebViewAppListAdapter extends ArrayAdapter<WebViewApplicationInfo> {
|
||||
private final LayoutInflater mInflater;
|
||||
private final String mCurrentWebViewPackageName;
|
||||
|
||||
public WebViewAppListAdapter(Context context,
|
||||
WebViewUpdateServiceWrapper webviewUpdateServiceWrapper) {
|
||||
@@ -53,6 +56,10 @@ class WebViewAppListAdapter extends ArrayAdapter<WebViewApplicationInfo> {
|
||||
packageInfoList.add(info);
|
||||
}
|
||||
addAll(packageInfoList);
|
||||
|
||||
PackageInfo currentWebViewPackage = webviewUpdateServiceWrapper.getCurrentWebViewPackage();
|
||||
mCurrentWebViewPackageName =
|
||||
currentWebViewPackage == null ? null : currentWebViewPackage.packageName;
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -80,6 +87,11 @@ class WebViewAppListAdapter extends ArrayAdapter<WebViewApplicationInfo> {
|
||||
holder.disabled.setVisibility(View.GONE);
|
||||
// Only allow a package to be chosen if it is enabled and installed for all users.
|
||||
convertView.setEnabled(isEnabled(position));
|
||||
if (info.info.packageName.equals(mCurrentWebViewPackageName)) {
|
||||
convertView.setBackgroundColor(Color.GRAY);
|
||||
} else {
|
||||
convertView.setBackgroundColor(Color.WHITE);
|
||||
}
|
||||
return convertView;
|
||||
}
|
||||
|
||||
|
@@ -73,10 +73,11 @@ public class WebViewAppPreferenceController extends PreferenceController {
|
||||
* Handle the return-value from the WebViewAppPicker Activity.
|
||||
*/
|
||||
public void onActivityResult(int resultCode, Intent data) {
|
||||
if (resultCode == Activity.RESULT_OK) {
|
||||
// Update the preference summary no matter whether we succeeded to change the webview
|
||||
// implementation correctly - we might have changed implementation to one the user did not
|
||||
// choose.
|
||||
updateState(null);
|
||||
}
|
||||
}
|
||||
|
||||
private String getCurrentWebViewPackageLabel(Context context) {
|
||||
PackageInfo webViewPackage = mWebViewUpdateServiceWrapper.getCurrentWebViewPackage();
|
||||
|
@@ -70,7 +70,7 @@ public class WebViewAppPreferenceControllerTest {
|
||||
verify(controller, times(1)).updateState(any());
|
||||
}
|
||||
|
||||
@Test public void testOnActivityResultWithFailureDoesNothing() {
|
||||
@Test public void testOnActivityResultWithFailure() {
|
||||
WebViewUpdateServiceWrapper wvusWrapper = mock(WebViewUpdateServiceWrapper.class);
|
||||
|
||||
WebViewAppPreferenceController controller =
|
||||
@@ -78,6 +78,6 @@ public class WebViewAppPreferenceControllerTest {
|
||||
|
||||
controller.displayPreference(mPreferenceScreen); // Makes sure Preference is non-null
|
||||
controller.onActivityResult(Activity.RESULT_CANCELED, new Intent(DEFAULT_PACKAGE_NAME));
|
||||
verify(controller, never()).updateState(any());
|
||||
verify(controller, times(1)).updateState(any());
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user