Add dynamic summaries to Slices
Summary on slices will now determined by checking that summaries in the following order are valid: 1) SliceData summary 2) Preference Controller summary 3) SliceData screen title Valid is currently defined as: - Not empty / null - Not whitespace - Not sumamry placeholder Fixes: 71640678 Test: robotests Change-Id: I5e699e8566ece80742d311617b7dc4e9a9bda8cf
This commit is contained in:
@@ -24,10 +24,13 @@ import android.content.Intent;
|
||||
import android.graphics.drawable.Icon;
|
||||
import android.text.TextUtils;
|
||||
|
||||
import com.android.internal.annotations.VisibleForTesting;
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.SubSettings;
|
||||
import com.android.settings.core.BasePreferenceController;
|
||||
import com.android.settings.core.TogglePreferenceController;
|
||||
import com.android.settings.search.DatabaseIndexingUtils;
|
||||
import com.android.settingslib.core.AbstractPreferenceController;
|
||||
|
||||
import java.lang.reflect.Constructor;
|
||||
import java.lang.reflect.InvocationTargetException;
|
||||
@@ -54,21 +57,17 @@ public class SliceBuilderUtils {
|
||||
public static Slice buildSlice(Context context, SliceData sliceData) {
|
||||
final PendingIntent contentIntent = getContentIntent(context, sliceData);
|
||||
final Icon icon = Icon.createWithResource(context, sliceData.getIconResource());
|
||||
String summaryText = sliceData.getSummary();
|
||||
String subtitleText = TextUtils.isEmpty(summaryText)
|
||||
? sliceData.getScreenTitle()
|
||||
: summaryText;
|
||||
final BasePreferenceController controller = getPreferenceController(context, sliceData);
|
||||
|
||||
RowBuilder builder = new RowBuilder(context, sliceData.getUri())
|
||||
final String subtitleText = getSubtitleText(context, controller, sliceData);
|
||||
|
||||
final RowBuilder builder = new RowBuilder(context, sliceData.getUri())
|
||||
.setTitle(sliceData.getTitle())
|
||||
.setTitleItem(icon)
|
||||
.setSubtitle(subtitleText)
|
||||
.setContentIntent(contentIntent);
|
||||
|
||||
BasePreferenceController controller = getPreferenceController(context, sliceData);
|
||||
|
||||
// TODO (b/71640747) Respect setting availability.
|
||||
// TODO (b/71640678) Add dynamic summary text.
|
||||
|
||||
if (controller instanceof TogglePreferenceController) {
|
||||
addToggleAction(context, builder, ((TogglePreferenceController) controller).isChecked(),
|
||||
@@ -82,7 +81,7 @@ public class SliceBuilderUtils {
|
||||
|
||||
/**
|
||||
* Looks at the {@link SliceData#preferenceController} from {@param sliceData} and attempts to
|
||||
* build a {@link BasePreferenceController}.
|
||||
* build an {@link AbstractPreferenceController}.
|
||||
*/
|
||||
public static BasePreferenceController getPreferenceController(Context context,
|
||||
SliceData sliceData) {
|
||||
@@ -122,4 +121,35 @@ public class SliceBuilderUtils {
|
||||
intent.setClassName("com.android.settings", SubSettings.class.getName());
|
||||
return PendingIntent.getActivity(context, 0 /* requestCode */, intent, 0 /* flags */);
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
static String getSubtitleText(Context context, AbstractPreferenceController controller,
|
||||
SliceData sliceData) {
|
||||
String summaryText = sliceData.getSummary();
|
||||
if (isValidSummary(context, summaryText)) {
|
||||
return summaryText;
|
||||
}
|
||||
|
||||
if (controller != null) {
|
||||
summaryText = controller.getSummary();
|
||||
|
||||
if (isValidSummary(context, summaryText)) {
|
||||
return summaryText;
|
||||
}
|
||||
}
|
||||
|
||||
return sliceData.getScreenTitle();
|
||||
}
|
||||
|
||||
private static boolean isValidSummary(Context context, String summary) {
|
||||
if (summary == null || TextUtils.isEmpty(summary.trim())) {
|
||||
return false;
|
||||
}
|
||||
|
||||
final String placeHolder = context.getString(R.string.summary_placeholder);
|
||||
final String doublePlaceHolder = context.getString(R.string.summary_two_lines_placeholder);
|
||||
|
||||
return !(TextUtils.equals(summary, placeHolder)
|
||||
|| TextUtils.equals(summary, doublePlaceHolder));
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user