blob: 15576182c53a0d4056082c1f2dbdda51db2f636e [file] [log] [blame]
/*
* Copyright (C) 2016 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.settingslib.widget;
import android.annotation.StringRes;
import android.content.Context;
import android.text.TextUtils;
import android.text.method.LinkMovementMethod;
import android.util.AttributeSet;
import android.widget.TextView;
import androidx.annotation.NonNull;
import androidx.core.content.res.TypedArrayUtils;
import androidx.preference.Preference;
import androidx.preference.PreferenceViewHolder;
import com.android.settingslib.R;
/**
* A custom preference acting as "footer" of a page. It has a field for icon and text. It is added
* to screen as the last preference.
*/
public class FooterPreference extends Preference {
static final int ORDER_FOOTER = Integer.MAX_VALUE - 1;
public static final String KEY_FOOTER = "footer_preference";
public FooterPreference(Context context, AttributeSet attrs) {
super(context, attrs, TypedArrayUtils.getAttr(
context, R.attr.footerPreferenceStyle, android.R.attr.preferenceStyle));
init();
}
public FooterPreference(Context context) {
this(context, null);
}
@Override
public void onBindViewHolder(PreferenceViewHolder holder) {
super.onBindViewHolder(holder);
TextView title = holder.itemView.findViewById(android.R.id.title);
title.setMovementMethod(new LinkMovementMethod());
title.setClickable(false);
title.setLongClickable(false);
}
@Override
public void setSummary(CharSequence summary) {
setTitle(summary);
}
@Override
public void setSummary(int summaryResId) {
setTitle(summaryResId);
}
@Override
public CharSequence getSummary() {
return getTitle();
}
private void init() {
if (getIcon() == null) {
setIcon(R.drawable.ic_info_outline_24);
}
setOrder(ORDER_FOOTER);
if (TextUtils.isEmpty(getKey())) {
setKey(KEY_FOOTER);
}
}
/**
* The builder is convenient to creat a dynamic FooterPreference.
*/
public static class Builder {
private Context mContext;
private String mKey;
private CharSequence mTitle;
public Builder(@NonNull Context context) {
mContext = context;
}
/**
* To set the key value of the {@link FooterPreference}.
* @param key The key value.
*/
public Builder setKey(@NonNull String key) {
mKey = key;
return this;
}
/**
* To set the title of the {@link FooterPreference}.
* @param title The title.
*/
public Builder setTitle(CharSequence title) {
mTitle = title;
return this;
}
/**
* To set the title of the {@link FooterPreference}.
* @param titleResId The resource id of the title.
*/
public Builder setTitle(@StringRes int titleResId) {
mTitle = mContext.getText(titleResId);
return this;
}
/**
* To generate the {@link FooterPreference}.
*/
public FooterPreference build() {
final FooterPreference footerPreference = new FooterPreference(mContext);
footerPreference.setSelectable(false);
if (TextUtils.isEmpty(mTitle)) {
throw new IllegalArgumentException("Footer title cannot be empty!");
}
footerPreference.setTitle(mTitle);
if (!TextUtils.isEmpty(mKey)) {
footerPreference.setKey(mKey);
}
return footerPreference;
}
}
}