Remove the specific UX of Deferred Setup card
Bug: 142927894 Test: visual, robotests Change-Id: If93506fb11c6417967fab3d082b19947adef0d61
This commit is contained in:
@@ -79,10 +79,6 @@ public class ContextualCardLookupTable {
|
||||
LegacySuggestionContextualCardRenderer.VIEW_TYPE,
|
||||
LegacySuggestionContextualCardController.class,
|
||||
LegacySuggestionContextualCardRenderer.class));
|
||||
add(new ControllerRendererMapping(CardType.SLICE,
|
||||
SliceContextualCardRenderer.VIEW_TYPE_DEFERRED_SETUP,
|
||||
SliceContextualCardController.class,
|
||||
SliceContextualCardRenderer.class));
|
||||
add(new ControllerRendererMapping(CardType.SLICE,
|
||||
SliceContextualCardRenderer.VIEW_TYPE_FULL_WIDTH,
|
||||
SliceContextualCardController.class,
|
||||
|
@@ -17,7 +17,6 @@
|
||||
package com.android.settings.homepage.contextualcards;
|
||||
|
||||
import static com.android.settings.homepage.contextualcards.ContextualCardLoader.CARD_CONTENT_LOADER_ID;
|
||||
import static com.android.settings.intelligence.ContextualCardProto.ContextualCard.Category.DEFERRED_SETUP_VALUE;
|
||||
import static com.android.settings.intelligence.ContextualCardProto.ContextualCard.Category.SUGGESTION_VALUE;
|
||||
|
||||
import static java.util.stream.Collectors.groupingBy;
|
||||
@@ -309,9 +308,7 @@ public class ContextualCardManager implements ContextualCardLoader.CardContentLo
|
||||
if (cards.isEmpty()) {
|
||||
return cards;
|
||||
}
|
||||
|
||||
final List<ContextualCard> result = getCardsWithDeferredSetupViewType(cards);
|
||||
return getCardsWithSuggestionViewType(result);
|
||||
return getCardsWithSuggestionViewType(cards);
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
@@ -341,22 +338,6 @@ public class ContextualCardManager implements ContextualCardLoader.CardContentLo
|
||||
return result;
|
||||
}
|
||||
|
||||
private List<ContextualCard> getCardsWithDeferredSetupViewType(List<ContextualCard> cards) {
|
||||
// Find the deferred setup card and assign it with proper view type.
|
||||
// Reason: The returned card list will mix deferred setup card and other suggestion cards
|
||||
// after device running 1 days.
|
||||
final List<ContextualCard> result = new ArrayList<>(cards);
|
||||
for (int index = 0; index < result.size(); index++) {
|
||||
final ContextualCard card = cards.get(index);
|
||||
if (card.getCategory() == DEFERRED_SETUP_VALUE) {
|
||||
result.set(index, card.mutate().setViewType(
|
||||
SliceContextualCardRenderer.VIEW_TYPE_DEFERRED_SETUP).build());
|
||||
return result;
|
||||
}
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
List<ContextualCard> getCardsToKeep(List<ContextualCard> cards) {
|
||||
if (mSavedCards != null) {
|
||||
|
@@ -54,7 +54,6 @@ import java.util.Set;
|
||||
public class SliceContextualCardRenderer implements ContextualCardRenderer, LifecycleObserver {
|
||||
public static final int VIEW_TYPE_FULL_WIDTH = R.layout.contextual_slice_full_tile;
|
||||
public static final int VIEW_TYPE_HALF_WIDTH = R.layout.contextual_slice_half_tile;
|
||||
public static final int VIEW_TYPE_DEFERRED_SETUP = R.layout.contextual_slice_deferred_setup;
|
||||
|
||||
private static final String TAG = "SliceCardRenderer";
|
||||
|
||||
@@ -66,7 +65,6 @@ public class SliceContextualCardRenderer implements ContextualCardRenderer, Life
|
||||
private final Context mContext;
|
||||
private final LifecycleOwner mLifecycleOwner;
|
||||
private final ControllerRendererPool mControllerRendererPool;
|
||||
private final SliceDeferredSetupCardRendererHelper mDeferredSetupCardHelper;
|
||||
private final SliceFullCardRendererHelper mFullCardHelper;
|
||||
private final SliceHalfCardRendererHelper mHalfCardHelper;
|
||||
|
||||
@@ -80,14 +78,11 @@ public class SliceContextualCardRenderer implements ContextualCardRenderer, Life
|
||||
mLifecycleOwner.getLifecycle().addObserver(this);
|
||||
mFullCardHelper = new SliceFullCardRendererHelper(context);
|
||||
mHalfCardHelper = new SliceHalfCardRendererHelper(context);
|
||||
mDeferredSetupCardHelper = new SliceDeferredSetupCardRendererHelper(context);
|
||||
}
|
||||
|
||||
@Override
|
||||
public RecyclerView.ViewHolder createViewHolder(View view, @LayoutRes int viewType) {
|
||||
if (viewType == VIEW_TYPE_DEFERRED_SETUP) {
|
||||
return mDeferredSetupCardHelper.createViewHolder(view);
|
||||
} else if (viewType == VIEW_TYPE_HALF_WIDTH) {
|
||||
if (viewType == VIEW_TYPE_HALF_WIDTH) {
|
||||
return mHalfCardHelper.createViewHolder(view);
|
||||
}
|
||||
return mFullCardHelper.createViewHolder(view);
|
||||
@@ -132,9 +127,7 @@ public class SliceContextualCardRenderer implements ContextualCardRenderer, Life
|
||||
return;
|
||||
}
|
||||
|
||||
if (holder.getItemViewType() == VIEW_TYPE_DEFERRED_SETUP) {
|
||||
mDeferredSetupCardHelper.bindView(holder, card, slice);
|
||||
} else if (holder.getItemViewType() == VIEW_TYPE_HALF_WIDTH) {
|
||||
if (holder.getItemViewType() == VIEW_TYPE_HALF_WIDTH) {
|
||||
mHalfCardHelper.bindView(holder, card, slice);
|
||||
} else {
|
||||
mFullCardHelper.bindView(holder, card, slice);
|
||||
@@ -144,13 +137,7 @@ public class SliceContextualCardRenderer implements ContextualCardRenderer, Life
|
||||
}
|
||||
});
|
||||
|
||||
if (holder.getItemViewType()
|
||||
== VIEW_TYPE_DEFERRED_SETUP) {// Deferred setup is never dismissible.
|
||||
} else if (holder.getItemViewType() == VIEW_TYPE_HALF_WIDTH) {
|
||||
initDismissalActions(holder, card);
|
||||
} else {
|
||||
initDismissalActions(holder, card);
|
||||
}
|
||||
initDismissalActions(holder, card);
|
||||
|
||||
if (card.isPendingDismiss()) {
|
||||
showDismissalView(holder);
|
||||
|
@@ -1,97 +0,0 @@
|
||||
/*
|
||||
* Copyright (C) 2019 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.android.settings.homepage.contextualcards.slices;
|
||||
|
||||
import android.app.PendingIntent;
|
||||
import android.app.settings.SettingsEnums;
|
||||
import android.content.Context;
|
||||
import android.util.Log;
|
||||
import android.view.View;
|
||||
import android.widget.Button;
|
||||
import android.widget.ImageView;
|
||||
import android.widget.LinearLayout;
|
||||
import android.widget.TextView;
|
||||
|
||||
import androidx.recyclerview.widget.RecyclerView;
|
||||
import androidx.slice.Slice;
|
||||
import androidx.slice.SliceMetadata;
|
||||
import androidx.slice.core.SliceAction;
|
||||
import androidx.slice.widget.EventInfo;
|
||||
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.homepage.contextualcards.ContextualCard;
|
||||
import com.android.settings.homepage.contextualcards.logging.ContextualCardLogUtils;
|
||||
import com.android.settings.overlay.FeatureFactory;
|
||||
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
||||
|
||||
/**
|
||||
* Card renderer helper for {@link ContextualCard} built as slice deferred setup card.
|
||||
*/
|
||||
class SliceDeferredSetupCardRendererHelper {
|
||||
private static final String TAG = "SliceDSCRendererHelper";
|
||||
|
||||
private final Context mContext;
|
||||
|
||||
SliceDeferredSetupCardRendererHelper(Context context) {
|
||||
mContext = context;
|
||||
}
|
||||
|
||||
RecyclerView.ViewHolder createViewHolder(View view) {
|
||||
return new DeferredSetupCardViewHolder(view);
|
||||
}
|
||||
|
||||
void bindView(RecyclerView.ViewHolder holder, ContextualCard card, Slice slice) {
|
||||
final DeferredSetupCardViewHolder view = (DeferredSetupCardViewHolder) holder;
|
||||
final SliceMetadata sliceMetadata = SliceMetadata.from(mContext, slice);
|
||||
final SliceAction primaryAction = sliceMetadata.getPrimaryAction();
|
||||
view.icon.setImageDrawable(primaryAction.getIcon().loadDrawable(mContext));
|
||||
view.title.setText(primaryAction.getTitle());
|
||||
view.summary.setText(sliceMetadata.getSubtitle());
|
||||
view.button.setOnClickListener(v -> {
|
||||
try {
|
||||
primaryAction.getAction().send();
|
||||
} catch (PendingIntent.CanceledException e) {
|
||||
Log.w(TAG, "Failed to start intent " + primaryAction.getTitle());
|
||||
}
|
||||
final String log = ContextualCardLogUtils.buildCardClickLog(card, 0 /* row */,
|
||||
EventInfo.ACTION_TYPE_CONTENT, view.getAdapterPosition());
|
||||
|
||||
final MetricsFeatureProvider metricsFeatureProvider =
|
||||
FeatureFactory.getFactory(mContext).getMetricsFeatureProvider();
|
||||
|
||||
metricsFeatureProvider.action(mContext,
|
||||
SettingsEnums.ACTION_CONTEXTUAL_CARD_CLICK, log);
|
||||
});
|
||||
}
|
||||
|
||||
static class DeferredSetupCardViewHolder extends RecyclerView.ViewHolder {
|
||||
public final LinearLayout content;
|
||||
public final ImageView icon;
|
||||
public final TextView title;
|
||||
public final TextView summary;
|
||||
public final Button button;
|
||||
|
||||
public DeferredSetupCardViewHolder(View itemView) {
|
||||
super(itemView);
|
||||
content = itemView.findViewById(R.id.content);
|
||||
icon = itemView.findViewById(android.R.id.icon);
|
||||
title = itemView.findViewById(android.R.id.title);
|
||||
summary = itemView.findViewById(android.R.id.summary);
|
||||
button = itemView.findViewById(R.id.finish_setup);
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user