Adding Nfc Tag App Preference setting to special_access settings
In the settings app, allow users to change the preference of the Nfc Tag apps. Bug: 244272155 Test: make RunSettingsRoboTests ROBOTEST_FILTER=NfcTagAppsPreferenceControllerTest Change-Id: I28903fae8935613a0e8618da21ca44e98b8801d5
This commit is contained in:
@@ -32,6 +32,7 @@ import com.android.settings.applications.AppStateOverlayBridge;
|
||||
import com.android.settings.applications.AppStatePowerBridge;
|
||||
import com.android.settings.applications.AppStateUsageBridge;
|
||||
import com.android.settings.applications.AppStateWriteSettingsBridge;
|
||||
import com.android.settings.nfc.AppStateNfcTagAppsBridge;
|
||||
import com.android.settings.wifi.AppStateChangeWifiStateBridge;
|
||||
import com.android.settingslib.applications.ApplicationsState;
|
||||
|
||||
@@ -65,6 +66,7 @@ public class AppFilterRegistry {
|
||||
FILTER_APPS_BATTERY_RESTRICTED,
|
||||
FILTER_LONG_BACKGROUND_TASKS,
|
||||
FILTER_APPS_CLONE,
|
||||
FILTER_APPS_NFC_TAG,
|
||||
})
|
||||
@interface FilterType {}
|
||||
|
||||
@@ -95,8 +97,9 @@ public class AppFilterRegistry {
|
||||
public static final int FILTER_APPS_BATTERY_RESTRICTED = 23;
|
||||
public static final int FILTER_LONG_BACKGROUND_TASKS = 24;
|
||||
public static final int FILTER_APPS_CLONE = 25;
|
||||
// Next id: 26. If you add an entry here, please change NUM_FILTER_ENTRIES.
|
||||
private static final int NUM_FILTER_ENTRIES = 26;
|
||||
public static final int FILTER_APPS_NFC_TAG = 26;
|
||||
private static final int NUM_FILTER_ENTRIES = 27;
|
||||
// Next id: 27. If you add an entry here, please change NUM_FILTER_ENTRIES.
|
||||
|
||||
private static AppFilterRegistry sRegistry;
|
||||
|
||||
@@ -261,6 +264,13 @@ public class AppFilterRegistry {
|
||||
AppStateClonedAppsBridge.FILTER_APPS_CLONE,
|
||||
FILTER_APPS_CLONE,
|
||||
R.string.cloned_apps_dashboard_title);
|
||||
|
||||
// Apps that are nfc tag allowlisted.
|
||||
mFilters[FILTER_APPS_NFC_TAG] =
|
||||
new AppFilterItem(
|
||||
AppStateNfcTagAppsBridge.FILTER_APPS_NFC_TAG,
|
||||
FILTER_APPS_NFC_TAG,
|
||||
R.string.change_nfc_tag_apps_title);
|
||||
}
|
||||
|
||||
public static AppFilterRegistry getInstance() {
|
||||
@@ -301,6 +311,8 @@ public class AppFilterRegistry {
|
||||
return FILTER_LONG_BACKGROUND_TASKS;
|
||||
case ManageApplications.LIST_TYPE_CLONED_APPS:
|
||||
return FILTER_APPS_CLONE;
|
||||
case ManageApplications.LIST_TYPE_NFC_TAG_APPS:
|
||||
return FILTER_APPS_NFC_TAG;
|
||||
default:
|
||||
return FILTER_APPS_ALL;
|
||||
}
|
||||
|
@@ -99,6 +99,7 @@ import com.android.internal.jank.InteractionJankMonitor;
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.Settings.AlarmsAndRemindersActivity;
|
||||
import com.android.settings.Settings.AppBatteryUsageActivity;
|
||||
import com.android.settings.Settings.ChangeNfcTagAppsActivity;
|
||||
import com.android.settings.Settings.ChangeWifiStateActivity;
|
||||
import com.android.settings.Settings.ClonedAppsListActivity;
|
||||
import com.android.settings.Settings.HighPowerApplicationsActivity;
|
||||
@@ -148,6 +149,8 @@ import com.android.settings.dashboard.profileselector.ProfileSelectFragment;
|
||||
import com.android.settings.fuelgauge.AdvancedPowerUsageDetail;
|
||||
import com.android.settings.fuelgauge.HighPowerDetail;
|
||||
import com.android.settings.localepicker.AppLocalePickerActivity;
|
||||
import com.android.settings.nfc.AppStateNfcTagAppsBridge;
|
||||
import com.android.settings.nfc.ChangeNfcTagAppsStateDetails;
|
||||
import com.android.settings.notification.ConfigureNotificationSettings;
|
||||
import com.android.settings.notification.NotificationBackend;
|
||||
import com.android.settings.notification.app.AppNotificationSettings;
|
||||
@@ -264,6 +267,7 @@ public class ManageApplications extends InstrumentedFragment
|
||||
public static final int LIST_TYPE_BATTERY_OPTIMIZATION = 15;
|
||||
public static final int LIST_TYPE_LONG_BACKGROUND_TASKS = 16;
|
||||
public static final int LIST_TYPE_CLONED_APPS = 17;
|
||||
public static final int LIST_TYPE_NFC_TAG_APPS = 18;
|
||||
|
||||
// List types that should show instant apps.
|
||||
public static final Set<Integer> LIST_TYPES_WITH_INSTANT = new ArraySet<>(Arrays.asList(
|
||||
@@ -362,6 +366,9 @@ public class ManageApplications extends InstrumentedFragment
|
||||
1); // USER_INTERACTED
|
||||
}
|
||||
break;
|
||||
case LIST_TYPE_NFC_TAG_APPS:
|
||||
mShowSystem = true;
|
||||
break;
|
||||
}
|
||||
final AppFilterRegistry appFilterRegistry = AppFilterRegistry.getInstance();
|
||||
mFilter = appFilterRegistry.get(appFilterRegistry.getDefaultFilterType(mListType));
|
||||
@@ -560,6 +567,8 @@ public class ManageApplications extends InstrumentedFragment
|
||||
return SettingsEnums.LONG_BACKGROUND_TASKS;
|
||||
case LIST_TYPE_CLONED_APPS:
|
||||
return SettingsEnums.CLONED_APPS;
|
||||
case LIST_TYPE_NFC_TAG_APPS:
|
||||
return SettingsEnums.CONFIG_NFC_TAG_APP_PREF;
|
||||
default:
|
||||
return SettingsEnums.PAGE_UNKNOWN;
|
||||
}
|
||||
@@ -629,10 +638,9 @@ public class ManageApplications extends InstrumentedFragment
|
||||
@Override
|
||||
public void onActivityResult(int requestCode, int resultCode, Intent data) {
|
||||
if (requestCode == INSTALLED_APP_DETAILS && mCurrentPkgName != null) {
|
||||
if (mListType == LIST_TYPE_NOTIFICATION) {
|
||||
mApplications.mExtraInfoBridge.forceUpdate(mCurrentPkgName, mCurrentUid);
|
||||
} else if (mListType == LIST_TYPE_HIGH_POWER || mListType == LIST_TYPE_OVERLAY
|
||||
|| mListType == LIST_TYPE_WRITE_SETTINGS) {
|
||||
if (mListType == LIST_TYPE_NOTIFICATION || mListType == LIST_TYPE_HIGH_POWER
|
||||
|| mListType == LIST_TYPE_OVERLAY || mListType == LIST_TYPE_WRITE_SETTINGS
|
||||
|| mListType == LIST_TYPE_NFC_TAG_APPS) {
|
||||
mApplications.mExtraInfoBridge.forceUpdate(mCurrentPkgName, mCurrentUid);
|
||||
} else {
|
||||
mApplicationsState.requestSize(mCurrentPkgName, UserHandle.getUserId(mCurrentUid));
|
||||
@@ -727,6 +735,10 @@ public class ManageApplications extends InstrumentedFragment
|
||||
.getRoute(mCurrentPkgName, userId));
|
||||
}
|
||||
break;
|
||||
case LIST_TYPE_NFC_TAG_APPS:
|
||||
startAppInfoFragment(ChangeNfcTagAppsStateDetails.class,
|
||||
R.string.change_nfc_tag_apps_title);
|
||||
break;
|
||||
// TODO: Figure out if there is a way where we can spin up the profile's settings
|
||||
// process ahead of time, to avoid a long load of data when user clicks on a managed
|
||||
// app. Maybe when they load the list of apps that contains managed profile apps.
|
||||
@@ -1052,6 +1064,8 @@ public class ManageApplications extends InstrumentedFragment
|
||||
screenTitle = R.string.long_background_tasks_title;
|
||||
} else if (className.equals(ClonedAppsListActivity.class.getName())) {
|
||||
screenTitle = R.string.cloned_apps_dashboard_title;
|
||||
} else if (className.equals(ChangeNfcTagAppsActivity.class.getName())) {
|
||||
screenTitle = R.string.change_nfc_tag_apps_title;
|
||||
} else {
|
||||
if (screenTitle == -1) {
|
||||
screenTitle = R.string.all_apps;
|
||||
@@ -1260,6 +1274,8 @@ public class ManageApplications extends InstrumentedFragment
|
||||
mExtraInfoBridge = new AppStateLongBackgroundTasksBridge(mContext, mState, this);
|
||||
} else if (mManageApplications.mListType == LIST_TYPE_CLONED_APPS) {
|
||||
mExtraInfoBridge = new AppStateClonedAppsBridge(mContext, mState, this);
|
||||
} else if (mManageApplications.mListType == LIST_TYPE_NFC_TAG_APPS) {
|
||||
mExtraInfoBridge = new AppStateNfcTagAppsBridge(mContext, mState, this);
|
||||
} else {
|
||||
mExtraInfoBridge = null;
|
||||
}
|
||||
@@ -1810,6 +1826,10 @@ public class ManageApplications extends InstrumentedFragment
|
||||
case LIST_TYPE_CLONED_APPS:
|
||||
holder.setSummary(null);
|
||||
break;
|
||||
case LIST_TYPE_NFC_TAG_APPS:
|
||||
holder.setSummary(
|
||||
ChangeNfcTagAppsStateDetails.getSummary(mContext, entry));
|
||||
break;
|
||||
default:
|
||||
holder.updateSizeText(entry, mManageApplications.mInvalidSizeStr, mWhichSize);
|
||||
break;
|
||||
|
@@ -20,6 +20,7 @@ import android.content.Context
|
||||
import android.util.FeatureFlagUtils
|
||||
import com.android.settings.Settings.AlarmsAndRemindersActivity
|
||||
import com.android.settings.Settings.AppBatteryUsageActivity
|
||||
import com.android.settings.Settings.ChangeNfcTagAppsActivity
|
||||
import com.android.settings.Settings.ChangeWifiStateActivity
|
||||
import com.android.settings.Settings.ClonedAppsListActivity
|
||||
import com.android.settings.Settings.GamesStorageActivity
|
||||
@@ -46,6 +47,7 @@ import com.android.settings.applications.manageapplications.ManageApplications.L
|
||||
import com.android.settings.applications.manageapplications.ManageApplications.LIST_TYPE_MAIN
|
||||
import com.android.settings.applications.manageapplications.ManageApplications.LIST_TYPE_MANAGE_SOURCES
|
||||
import com.android.settings.applications.manageapplications.ManageApplications.LIST_TYPE_MEDIA_MANAGEMENT_APPS
|
||||
import com.android.settings.applications.manageapplications.ManageApplications.LIST_TYPE_NFC_TAG_APPS
|
||||
import com.android.settings.applications.manageapplications.ManageApplications.LIST_TYPE_NOTIFICATION
|
||||
import com.android.settings.applications.manageapplications.ManageApplications.LIST_TYPE_OVERLAY
|
||||
import com.android.settings.applications.manageapplications.ManageApplications.LIST_TYPE_STORAGE
|
||||
@@ -85,6 +87,7 @@ object ManageApplicationsUtil {
|
||||
AppBatteryUsageActivity::class to LIST_TYPE_BATTERY_OPTIMIZATION,
|
||||
LongBackgroundTasksActivity::class to LIST_TYPE_LONG_BACKGROUND_TASKS,
|
||||
ClonedAppsListActivity::class to LIST_TYPE_CLONED_APPS,
|
||||
ChangeNfcTagAppsActivity::class to LIST_TYPE_NFC_TAG_APPS,
|
||||
)
|
||||
|
||||
@JvmField
|
||||
|
Reference in New Issue
Block a user