blob: 523066fa98ac704e09b41c115efd86cc04290b69 [file]
/*
* Copyright (C) 2021 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.accessibility;
import android.content.Context;
import android.content.Intent;
import android.text.TextUtils;
import androidx.annotation.NonNull;
import androidx.preference.PreferenceScreen;
import com.android.settings.core.BasePreferenceController;
import com.android.settingslib.HelpUtils;
/**
* Preference controller that controls the help link and customizes the preference title in {@link
* AccessibilityFooterPreference}.
*/
public class AccessibilityFooterPreferenceController extends BasePreferenceController {
private int mHelpResource;
private String mLearnMoreText;
private String mIntroductionTitle;
private CharSequence mSummary;
public AccessibilityFooterPreferenceController(Context context, String key) {
super(context, key);
}
@Override
public int getAvailabilityStatus() {
return AVAILABLE_UNSEARCHABLE;
}
@Override
public void displayPreference(PreferenceScreen screen) {
super.displayPreference(screen);
final AccessibilityFooterPreference footerPreference =
screen.findPreference(getPreferenceKey());
updateFooterPreferences(footerPreference);
}
/**
* Setups a help item in the {@link AccessibilityFooterPreference} with specific content
* description.
*/
public void setupHelpLink(int helpResource, String learnMoreText) {
mHelpResource = helpResource;
mLearnMoreText = learnMoreText;
}
/**
* Overrides this if showing a help item in the {@link AccessibilityFooterPreference}, by
* returning the resource id.
*
* @return the resource id for the help url
*/
protected int getHelpResource() {
return mHelpResource;
}
/**
* Overrides this if showing a help item in the {@link AccessibilityFooterPreference} with
* specific learn more title.
*
* @return learn more title for the help url
*/
protected String getLearnMoreText() {
return mLearnMoreText;
}
/**
* Sets the announcement the specific features introduction in the {@link
* AccessibilityFooterPreference}.
*/
public void setIntroductionTitle(String introductionTitle) {
mIntroductionTitle = introductionTitle;
}
/**
* Overrides this if announcement the specific features introduction in the {@link
* AccessibilityFooterPreference}.
*
* @return the extended content description for specific features introduction
*/
protected String getIntroductionTitle() {
return mIntroductionTitle;
}
/**
* Overrides ths summary of {@link AccessibilityFooterPreference}
*/
protected void setSummary(@NonNull CharSequence summary) {
mSummary = summary;
}
/**
* Updates the footer preference with the given data set to this PreferenceController
*/
public void updateFooterPreferences(@NonNull AccessibilityFooterPreference footerPreference) {
final Intent helpIntent;
if (getHelpResource() != 0) {
// Returns may be null if content is wrong or empty.
helpIntent = HelpUtils.getHelpIntent(mContext, mContext.getString(getHelpResource()),
mContext.getClass().getName());
} else {
helpIntent = null;
}
if (helpIntent != null) {
footerPreference.setLearnMoreAction(view -> {
view.startActivityForResult(helpIntent, 0);
});
footerPreference.setLearnMoreText(getLearnMoreText());
footerPreference.setLinkEnabled(true);
} else {
footerPreference.setLinkEnabled(false);
}
// Set footer summary and content description, prioritizing mSummary if available,
// otherwise using the default title from XML for content description.
if (!TextUtils.isEmpty(mSummary)) {
footerPreference.setSummary(mSummary);
updateContentDescription(footerPreference, mSummary);
} else {
updateContentDescription(footerPreference, footerPreference.getTitle());
}
// Grouping subcomponents to make more accessible.
footerPreference.setSelectable(false);
if (TextUtils.isEmpty(footerPreference.getTitle())
&& TextUtils.isEmpty(footerPreference.getSummary())) {
footerPreference.setVisible(false);
} else {
footerPreference.setVisible(true);
}
}
private void updateContentDescription(
@NonNull AccessibilityFooterPreference footerPreference, CharSequence textToDescribe) {
if (TextUtils.isEmpty(textToDescribe)) {
return;
}
final StringBuffer sb = new StringBuffer();
sb.append(getIntroductionTitle()).append("\n\n").append(textToDescribe);
footerPreference.setContentDescription(sb);
}
}