Improve App notification loading
1) Use UiBlocker, for better animations for apps with a lot of channels 2) Only load data in onResume, because the data loading step in some of the controllers is expensive Test: make -j64 RunSettingsRoboTests ROBOTEST_FILTER="com.android.settings.notification" Test: load small channel and large (6000ish) channel app pages Test: load individual channel pages Test: load in-app channel shelf UI Fixes: 215072888 Change-Id: I9a1c96f75b02f94b3ffc529d17d9c0cad7752de1
This commit is contained in:
@@ -56,7 +56,7 @@ public class BubblePreferenceController extends NotificationPreferenceController
|
||||
public BubblePreferenceController(Context context, @Nullable FragmentManager fragmentManager,
|
||||
NotificationBackend backend, boolean isAppPage,
|
||||
@Nullable NotificationSettings.DependentFieldListener listener) {
|
||||
super(context, backend);
|
||||
super(context, backend, KEY);
|
||||
mFragmentManager = fragmentManager;
|
||||
mIsAppPage = isAppPage;
|
||||
mListener = listener;
|
||||
@@ -68,21 +68,24 @@ public class BubblePreferenceController extends NotificationPreferenceController
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isAvailable() {
|
||||
if (!super.isAvailable()) {
|
||||
return false;
|
||||
public int getAvailabilityStatus() {
|
||||
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||
return CONDITIONALLY_UNAVAILABLE;
|
||||
}
|
||||
if (!mIsAppPage && !isEnabled()) {
|
||||
return false;
|
||||
return CONDITIONALLY_UNAVAILABLE;
|
||||
}
|
||||
if (mChannel != null) {
|
||||
if (isDefaultChannel()) {
|
||||
return true;
|
||||
return AVAILABLE;
|
||||
} else {
|
||||
return mAppRow != null && mAppRow.bubblePreference != BUBBLE_PREFERENCE_NONE;
|
||||
if (mAppRow != null && mAppRow.bubblePreference != BUBBLE_PREFERENCE_NONE) {
|
||||
return AVAILABLE;
|
||||
}
|
||||
return CONDITIONALLY_UNAVAILABLE;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
return AVAILABLE;
|
||||
}
|
||||
|
||||
@Override
|
||||
|
||||
Reference in New Issue
Block a user