package com.android.systemui.statusbar.policy; import static java.lang.Float.NaN; import android.annotation.ColorInt; import android.app.Notification; import android.app.PendingIntent; import android.app.RemoteInput; import android.content.Context; import android.content.res.ColorStateList; import android.content.res.TypedArray; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.drawable.Drawable; import android.graphics.drawable.GradientDrawable; import android.graphics.drawable.InsetDrawable; import android.graphics.drawable.RippleDrawable; import android.os.SystemClock; import android.text.Layout; import android.text.TextPaint; import android.text.method.TransformationMethod; import android.util.AttributeSet; import android.util.IndentingPrintWriter; import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.Button; import android.widget.TextView; import androidx.annotation.NonNull; import com.android.internal.annotations.VisibleForTesting; import com.android.internal.util.ContrastColorUtil; import com.android.systemui.R; import com.android.systemui.statusbar.notification.NotificationUtils; import java.text.BreakIterator; import java.util.ArrayList; import java.util.Comparator; import java.util.List; import java.util.PriorityQueue; /** View which displays smart reply and smart actions buttons in notifications. */ public class SmartReplyView extends ViewGroup { private static final String TAG = "SmartReplyView"; private static final int MEASURE_SPEC_ANY_LENGTH = MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED); private static final Comparator DECREASING_MEASURED_WIDTH_WITHOUT_PADDING_COMPARATOR = (v1, v2) -> ((v2.getMeasuredWidth() - v2.getPaddingLeft() - v2.getPaddingRight()) - (v1.getMeasuredWidth() - v1.getPaddingLeft() - v1.getPaddingRight())); private static final int SQUEEZE_FAILED = -1; /** * The upper bound for the height of this view in pixels. Notifications are automatically * recreated on density or font size changes so caching this should be fine. */ private final int mHeightUpperLimit; /** Spacing to be applied between views. */ private final int mSpacing; private final BreakIterator mBreakIterator; private PriorityQueue