Merge "Add user selectable Default Browser feature - part 3" into mnc-dev
This commit is contained in:
committed by
Android (Google) Code Review
commit
b880f1424b
@@ -21,6 +21,7 @@ import android.content.Context;
|
|||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.content.pm.ResolveInfo;
|
import android.content.pm.ResolveInfo;
|
||||||
|
import android.net.Uri;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.UserHandle;
|
import android.os.UserHandle;
|
||||||
import android.os.UserManager;
|
import android.os.UserManager;
|
||||||
@@ -66,15 +67,25 @@ public class ManageDefaultApps extends SettingsPreferenceFragment
|
|||||||
myUserId = UserHandle.myUserId();
|
myUserId = UserHandle.myUserId();
|
||||||
|
|
||||||
mDefaultBrowserPreference = (DefaultBrowserPreference) findPreference(KEY_DEFAULT_BROWSER);
|
mDefaultBrowserPreference = (DefaultBrowserPreference) findPreference(KEY_DEFAULT_BROWSER);
|
||||||
mDefaultBrowserPreference.setOnPreferenceClickListener(
|
mDefaultBrowserPreference.setOnPreferenceChangeListener(
|
||||||
new Preference.OnPreferenceClickListener() {
|
new Preference.OnPreferenceChangeListener() {
|
||||||
@Override
|
@Override
|
||||||
public boolean onPreferenceClick(Preference preference) {
|
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
||||||
final CharSequence packageName = mDefaultBrowserPreference.getValue();
|
if (newValue == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
final CharSequence packageName = (CharSequence) newValue;
|
||||||
if (TextUtils.isEmpty(packageName)) {
|
if (TextUtils.isEmpty(packageName)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return mPm.setDefaultBrowserPackageName(packageName.toString(), myUserId);
|
boolean result = mPm.setDefaultBrowserPackageName(
|
||||||
|
packageName.toString(), myUserId);
|
||||||
|
if (result) {
|
||||||
|
mDefaultBrowserPreference.setValue(packageName.toString());
|
||||||
|
final CharSequence appName = mDefaultBrowserPreference.getEntry();
|
||||||
|
mDefaultBrowserPreference.setSummary(appName);
|
||||||
|
}
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
final boolean isRestrictedUser = UserManager.get(getActivity())
|
final boolean isRestrictedUser = UserManager.get(getActivity())
|
||||||
@@ -104,18 +115,30 @@ public class ManageDefaultApps extends SettingsPreferenceFragment
|
|||||||
public void onViewCreated(View view, @Nullable Bundle savedInstanceState) {
|
public void onViewCreated(View view, @Nullable Bundle savedInstanceState) {
|
||||||
super.onViewCreated(view, savedInstanceState);
|
super.onViewCreated(view, savedInstanceState);
|
||||||
|
|
||||||
String packageName = getPackageManager().getDefaultBrowserPackageName(
|
final PackageManager pm = getPackageManager();
|
||||||
UserHandle.myUserId());
|
|
||||||
|
String packageName = pm.getDefaultBrowserPackageName(UserHandle.myUserId());
|
||||||
if (!TextUtils.isEmpty(packageName)) {
|
if (!TextUtils.isEmpty(packageName)) {
|
||||||
// Check if the package is still there
|
// Check if the default Browser package is still there
|
||||||
Intent intent = new Intent();
|
Intent intent = new Intent();
|
||||||
intent.setPackage(packageName);
|
intent.setPackage(packageName);
|
||||||
|
intent.setAction(Intent.ACTION_VIEW);
|
||||||
|
intent.addCategory(Intent.CATEGORY_BROWSABLE);
|
||||||
|
intent.setData(Uri.parse("http:"));
|
||||||
|
|
||||||
ResolveInfo info = mPm.resolveActivityAsUser(intent, 0, myUserId);
|
ResolveInfo info = mPm.resolveActivityAsUser(intent, 0, myUserId);
|
||||||
if (info != null) {
|
if (info != null) {
|
||||||
mDefaultBrowserPreference.setValue(packageName);
|
mDefaultBrowserPreference.setValue(packageName);
|
||||||
|
CharSequence label = info.loadLabel(pm);
|
||||||
|
mDefaultBrowserPreference.setSummary(label);
|
||||||
} else {
|
} else {
|
||||||
// Otherwise select the first one
|
CharSequence[] values = mDefaultBrowserPreference.getEntryValues();
|
||||||
|
if (values.length > 0) {
|
||||||
|
// Otherwise select the first one if we can
|
||||||
mDefaultBrowserPreference.setValueIndex(0);
|
mDefaultBrowserPreference.setValueIndex(0);
|
||||||
|
} else {
|
||||||
|
// Do nothing, we cannot select any value
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Log.d(TAG, "Cannot set empty default Browser value!");
|
Log.d(TAG, "Cannot set empty default Browser value!");
|
||||||
|
Reference in New Issue
Block a user