Merge "Card showing mechanism change in homepage"
This commit is contained in:
@@ -16,6 +16,7 @@
|
||||
|
||||
package com.android.settings.homepage.contextualcards;
|
||||
|
||||
import static com.android.settings.intelligence.ContextualCardProto.ContextualCard.Category.STICKY_VALUE;
|
||||
import static com.android.settings.slices.CustomSliceRegistry.BLUETOOTH_DEVICES_SLICE_URI;
|
||||
import static com.android.settings.slices.CustomSliceRegistry.CONTEXTUAL_NOTIFICATION_CHANNEL_SLICE_URI;
|
||||
import static com.android.settings.slices.CustomSliceRegistry.CONTEXTUAL_WIFI_SLICE_URI;
|
||||
@@ -127,18 +128,34 @@ public class ContextualCardLoader extends AsyncLoaderCompat<List<ContextualCard>
|
||||
@VisibleForTesting
|
||||
List<ContextualCard> getDisplayableCards(List<ContextualCard> candidates) {
|
||||
final List<ContextualCard> eligibleCards = filterEligibleCards(candidates);
|
||||
final List<ContextualCard> stickyCards = new ArrayList<>();
|
||||
final List<ContextualCard> visibleCards = new ArrayList<>();
|
||||
final List<ContextualCard> hiddenCards = new ArrayList<>();
|
||||
|
||||
final int size = eligibleCards.size();
|
||||
final int cardCount = getCardCount();
|
||||
for (int i = 0; i < size; i++) {
|
||||
if (i < cardCount) {
|
||||
visibleCards.add(eligibleCards.get(i));
|
||||
} else {
|
||||
hiddenCards.add(eligibleCards.get(i));
|
||||
final int maxCardCount = getCardCount();
|
||||
eligibleCards.forEach(card -> {
|
||||
if (card.getCategory() != STICKY_VALUE) {
|
||||
return;
|
||||
}
|
||||
}
|
||||
if (stickyCards.size() < maxCardCount) {
|
||||
stickyCards.add(card);
|
||||
} else {
|
||||
hiddenCards.add(card);
|
||||
}
|
||||
});
|
||||
|
||||
final int nonStickyCardCount = maxCardCount - stickyCards.size();
|
||||
eligibleCards.forEach(card -> {
|
||||
if (card.getCategory() == STICKY_VALUE) {
|
||||
return;
|
||||
}
|
||||
if (visibleCards.size() < nonStickyCardCount) {
|
||||
visibleCards.add(card);
|
||||
} else {
|
||||
hiddenCards.add(card);
|
||||
}
|
||||
});
|
||||
visibleCards.addAll(stickyCards);
|
||||
|
||||
if (!CardContentProvider.DELETE_CARD_URI.equals(mNotifyUri)) {
|
||||
final MetricsFeatureProvider metricsFeatureProvider =
|
||||
|
Reference in New Issue
Block a user