| /* |
| * 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; |
| } |
| } |
| } |