Merge changes Ia0035222,I309ca48c into tm-dev
* changes: Show quick settings tooltip when turning on extra dim in Accessibility setting Customized accessibility framework features quick setting tooltips content
This commit is contained in:
@@ -5554,11 +5554,27 @@
|
|||||||
<string name="accessibility_service_primary_switch_title">Use <xliff:g id="accessibility_app_name" example="TalkBack">%1$s</xliff:g></string>
|
<string name="accessibility_service_primary_switch_title">Use <xliff:g id="accessibility_app_name" example="TalkBack">%1$s</xliff:g></string>
|
||||||
<!-- Used in the accessibility service settings to open the activity. [CHAR LIMIT=NONE] -->
|
<!-- Used in the accessibility service settings to open the activity. [CHAR LIMIT=NONE] -->
|
||||||
<string name="accessibility_service_primary_open_title">Open <xliff:g id="accessibility_app_name" example="TalkBack">%1$s</xliff:g></string>
|
<string name="accessibility_service_primary_open_title">Open <xliff:g id="accessibility_app_name" example="TalkBack">%1$s</xliff:g></string>
|
||||||
<!-- Used in the accessibility service settings to show quick settings tooltips for auto-added feature. [CHAR LIMIT=NONE] -->
|
<!-- Used in the accessibility service settings to show quick settings tooltip for auto-added feature. [CHAR LIMIT=NONE] -->
|
||||||
<string name="accessibility_service_auto_added_qs_tooltips_content"><xliff:g id="accessibility_app_name" example="TalkBack">%1$s</xliff:g> added to Quick Settings. Swipe down to turn it on or off anytime.</string>
|
<string name="accessibility_service_auto_added_qs_tooltips_content"><xliff:g id="accessibility_app_name" example="TalkBack">%1$s</xliff:g> added to Quick Settings. Swipe down to turn it on or off anytime.</string>
|
||||||
<!-- Used in the accessibility service settings to show quick settings tooltips. [CHAR LIMIT=NONE] -->
|
<!-- Used in the accessibility service settings to show quick settings tooltip. [CHAR LIMIT=NONE] -->
|
||||||
<string name="accessibility_service_qs_tooltips_content">You can also add <xliff:g id="accessibility_app_name" example="TalkBack">%1$s</xliff:g> to Quick Settings from the top of your screen</string>
|
<string name="accessibility_service_qs_tooltips_content">You can also add <xliff:g id="accessibility_app_name" example="TalkBack">%1$s</xliff:g> to Quick Settings from the top of your screen</string>
|
||||||
<!-- Used in the accessibility action for accessibility quick settings tooltips to dismiss. [CHAR LIMIT=NONE] -->
|
<!-- Used in the color correction settings to show quick settings tooltip for auto-added feature. [CHAR LIMIT=NONE] -->
|
||||||
|
<string name="accessibility_color_correction_auto_added_qs_tooltip_content">Color correction added to Quick Settings. Swipe down to turn it on or off anytime.</string>
|
||||||
|
<!-- Used in the color correction settings to show quick settings tooltip. [CHAR LIMIT=NONE] -->
|
||||||
|
<string name="accessibility_color_correction_qs_tooltip_content">You can also add color correction to Quick Settings from the top of your screen</string>
|
||||||
|
<!-- Used in the color inversion settings to show quick settings tooltip for auto-added feature. [CHAR LIMIT=NONE] -->
|
||||||
|
<string name="accessibility_color_inversion_auto_added_qs_tooltip_content">Color inversion added to Quick Settings. Swipe down to turn it on or off anytime.</string>
|
||||||
|
<!-- Used in the color inversion settings to show quick settings tooltip. [CHAR LIMIT=NONE] -->
|
||||||
|
<string name="accessibility_color_inversion_qs_tooltip_content">You can also add color inversion to Quick Settings from the top of your screen</string>
|
||||||
|
<!-- Used in the reduce bright colors settings to show quick settings tooltip for auto-added feature. [CHAR LIMIT=NONE] -->
|
||||||
|
<string name="accessibility_reduce_bright_colors_auto_added_qs_tooltip_content">Extra dim added to Quick Settings. Swipe down to turn it on or off anytime.</string>
|
||||||
|
<!-- Used in the reduce bright colors settings to show quick settings tooltip. [CHAR LIMIT=NONE] -->
|
||||||
|
<string name="accessibility_reduce_bright_colors_qs_tooltip_content">You can also add extra dim to Quick Settings from the top of your screen</string>
|
||||||
|
<!-- Used in the One-hand mode color to show quick settings tooltip for auto-added feature. [CHAR LIMIT=NONE] -->
|
||||||
|
<string name="accessibility_one_handed_mode_auto_added_qs_tooltip_content">One-handed mode added to Quick Settings. Swipe down to turn it on or off anytime.</string>
|
||||||
|
<!-- Used in the One-hand mode settings to show quick settings tooltip. [CHAR LIMIT=NONE] -->
|
||||||
|
<string name="accessibility_one_handed_mode_qs_tooltip_content">You can also add one-handed mode to Quick Settings from the top of your screen</string>
|
||||||
|
<!-- Used in the accessibility action for accessibility quick settings tooltip to dismiss. [CHAR LIMIT=NONE] -->
|
||||||
<string name="accessibility_quick_settings_tooltips_dismiss">Dismiss</string>
|
<string name="accessibility_quick_settings_tooltips_dismiss">Dismiss</string>
|
||||||
<!-- Intro for color correction settings screen to control turning on/off the feature entirely. [CHAR LIMIT=NONE] -->
|
<!-- Intro for color correction settings screen to control turning on/off the feature entirely. [CHAR LIMIT=NONE] -->
|
||||||
<string name="accessibility_daltonizer_about_intro_text" product="default">Adjust how colors display on your phone</string>
|
<string name="accessibility_daltonizer_about_intro_text" product="default">Adjust how colors display on your phone</string>
|
||||||
|
@@ -0,0 +1,124 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2022 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.ComponentName;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.os.Handler;
|
||||||
|
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.core.TogglePreferenceController;
|
||||||
|
import com.android.settingslib.PrimarySwitchPreference;
|
||||||
|
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
||||||
|
import com.android.settingslib.core.lifecycle.events.OnCreate;
|
||||||
|
import com.android.settingslib.core.lifecycle.events.OnSaveInstanceState;
|
||||||
|
|
||||||
|
/** PrimarySwitchPreferenceController that shows quick settings tooltip on first use. */
|
||||||
|
public abstract class AccessibilityQuickSettingsPrimarySwitchPreferenceController
|
||||||
|
extends TogglePreferenceController
|
||||||
|
implements LifecycleObserver, OnCreate, OnSaveInstanceState {
|
||||||
|
private static final String KEY_SAVED_QS_TOOLTIP_RESHOW = "qs_tooltip_reshow";
|
||||||
|
private final Handler mHandler;
|
||||||
|
private PrimarySwitchPreference mPreference;
|
||||||
|
private AccessibilityQuickSettingsTooltipWindow mTooltipWindow;
|
||||||
|
private boolean mNeedsQSTooltipReshow = false;
|
||||||
|
|
||||||
|
/** Returns the accessibility tile component name. */
|
||||||
|
abstract ComponentName getTileComponentName();
|
||||||
|
|
||||||
|
/** Returns the accessibility tile tooltip content. */
|
||||||
|
abstract CharSequence getTileTooltipContent();
|
||||||
|
|
||||||
|
public AccessibilityQuickSettingsPrimarySwitchPreferenceController(Context context,
|
||||||
|
String preferenceKey) {
|
||||||
|
super(context, preferenceKey);
|
||||||
|
mHandler = new Handler(context.getMainLooper());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCreate(Bundle savedInstanceState) {
|
||||||
|
// Restore the tooltip.
|
||||||
|
if (savedInstanceState != null) {
|
||||||
|
if (savedInstanceState.containsKey(KEY_SAVED_QS_TOOLTIP_RESHOW)) {
|
||||||
|
mNeedsQSTooltipReshow = savedInstanceState.getBoolean(KEY_SAVED_QS_TOOLTIP_RESHOW);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSaveInstanceState(Bundle outState) {
|
||||||
|
if (mTooltipWindow != null) {
|
||||||
|
outState.putBoolean(KEY_SAVED_QS_TOOLTIP_RESHOW, mTooltipWindow.isShowing());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void displayPreference(PreferenceScreen screen) {
|
||||||
|
super.displayPreference(screen);
|
||||||
|
mPreference = screen.findPreference(getPreferenceKey());
|
||||||
|
if (mNeedsQSTooltipReshow) {
|
||||||
|
mHandler.post(this::showQuickSettingsTooltipIfNeeded);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean setChecked(boolean isChecked) {
|
||||||
|
if (isChecked) {
|
||||||
|
showQuickSettingsTooltipIfNeeded();
|
||||||
|
}
|
||||||
|
return isChecked;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isChecked() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getAvailabilityStatus() {
|
||||||
|
return AVAILABLE;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getSliceHighlightMenuRes() {
|
||||||
|
return R.string.menu_key_accessibility;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void showQuickSettingsTooltipIfNeeded() {
|
||||||
|
final ComponentName tileComponentName = getTileComponentName();
|
||||||
|
if (tileComponentName == null) {
|
||||||
|
// Returns if no tile service assigned.
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!mNeedsQSTooltipReshow && AccessibilityQuickSettingUtils.hasValueInSharedPreferences(
|
||||||
|
mContext, tileComponentName)) {
|
||||||
|
// Returns if quick settings tooltip only show once.
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
mTooltipWindow = new AccessibilityQuickSettingsTooltipWindow(mContext);
|
||||||
|
mTooltipWindow.setup(getTileTooltipContent(),
|
||||||
|
R.drawable.accessibility_auto_added_qs_tooltips_illustration);
|
||||||
|
mTooltipWindow.showAtTopCenter(mPreference.getSwitch());
|
||||||
|
AccessibilityQuickSettingUtils.optInValueToSharedPreferences(mContext, tileComponentName);
|
||||||
|
mNeedsQSTooltipReshow = false;
|
||||||
|
}
|
||||||
|
}
|
@@ -80,7 +80,7 @@ public class AccessibilityQuickSettingsTooltipWindow extends PopupWindow {
|
|||||||
* @param text text to be displayed
|
* @param text text to be displayed
|
||||||
* @param imageResId the resource ID of the image drawable
|
* @param imageResId the resource ID of the image drawable
|
||||||
*/
|
*/
|
||||||
public void setup(String text, @DrawableRes int imageResId) {
|
public void setup(CharSequence text, @DrawableRes int imageResId) {
|
||||||
this.setup(text, imageResId, /* closeDelayTimeMillis= */ 0);
|
this.setup(text, imageResId, /* closeDelayTimeMillis= */ 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -94,7 +94,7 @@ public class AccessibilityQuickSettingsTooltipWindow extends PopupWindow {
|
|||||||
* @param imageResId the resource ID of the image drawable
|
* @param imageResId the resource ID of the image drawable
|
||||||
* @param closeDelayTimeMillis how long the popup window be auto-closed
|
* @param closeDelayTimeMillis how long the popup window be auto-closed
|
||||||
*/
|
*/
|
||||||
public void setup(String text, @DrawableRes int imageResId, long closeDelayTimeMillis) {
|
public void setup(CharSequence text, @DrawableRes int imageResId, long closeDelayTimeMillis) {
|
||||||
this.mCloseDelayTimeMillis = closeDelayTimeMillis;
|
this.mCloseDelayTimeMillis = closeDelayTimeMillis;
|
||||||
|
|
||||||
setBackgroundDrawable(new ColorDrawable(mContext.getColor(android.R.color.transparent)));
|
setBackgroundDrawable(new ColorDrawable(mContext.getColor(android.R.color.transparent)));
|
||||||
|
@@ -83,8 +83,8 @@ public abstract class AccessibilityShortcutPreferenceFragment extends DashboardF
|
|||||||
/** Returns the accessibility tile component name. */
|
/** Returns the accessibility tile component name. */
|
||||||
protected abstract ComponentName getTileComponentName();
|
protected abstract ComponentName getTileComponentName();
|
||||||
|
|
||||||
/** Returns the accessibility tile feature name. */
|
/** Returns the accessibility tile tooltip content. */
|
||||||
protected abstract CharSequence getTileName();
|
protected abstract CharSequence getTileTooltipContent(@QuickSettingsTooltipType int type);
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCreate(Bundle savedInstanceState) {
|
public void onCreate(Bundle savedInstanceState) {
|
||||||
@@ -148,7 +148,7 @@ public abstract class AccessibilityShortcutPreferenceFragment extends DashboardF
|
|||||||
public void onViewCreated(View view, Bundle savedInstanceState) {
|
public void onViewCreated(View view, Bundle savedInstanceState) {
|
||||||
super.onViewCreated(view, savedInstanceState);
|
super.onViewCreated(view, savedInstanceState);
|
||||||
|
|
||||||
// Reshow tooltips when activity recreate, such as rotate device.
|
// Reshow tooltip when activity recreate, such as rotate device.
|
||||||
if (mNeedsQSTooltipReshow) {
|
if (mNeedsQSTooltipReshow) {
|
||||||
getView().post(this::showQuickSettingsTooltipIfNeeded);
|
getView().post(this::showQuickSettingsTooltipIfNeeded);
|
||||||
}
|
}
|
||||||
@@ -499,21 +499,17 @@ public abstract class AccessibilityShortcutPreferenceFragment extends DashboardF
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final CharSequence tileName = getTileName();
|
final CharSequence content = getTileTooltipContent(mNeedsQSTooltipType);
|
||||||
if (TextUtils.isEmpty(tileName)) {
|
if (TextUtils.isEmpty(content)) {
|
||||||
// Returns if no title of tile service assigned.
|
// Returns if no content of tile tooltip assigned.
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final int titleResId = mNeedsQSTooltipType == QuickSettingsTooltipType.GUIDE_TO_EDIT
|
|
||||||
? R.string.accessibility_service_qs_tooltips_content
|
|
||||||
: R.string.accessibility_service_auto_added_qs_tooltips_content;
|
|
||||||
final String title = getString(titleResId, tileName);
|
|
||||||
final int imageResId = mNeedsQSTooltipType == QuickSettingsTooltipType.GUIDE_TO_EDIT
|
final int imageResId = mNeedsQSTooltipType == QuickSettingsTooltipType.GUIDE_TO_EDIT
|
||||||
? R.drawable.accessibility_qs_tooltips_illustration
|
? R.drawable.accessibility_qs_tooltips_illustration
|
||||||
: R.drawable.accessibility_auto_added_qs_tooltips_illustration;
|
: R.drawable.accessibility_auto_added_qs_tooltips_illustration;
|
||||||
mTooltipWindow = new AccessibilityQuickSettingsTooltipWindow(getContext());
|
mTooltipWindow = new AccessibilityQuickSettingsTooltipWindow(getContext());
|
||||||
mTooltipWindow.setup(title, imageResId);
|
mTooltipWindow.setup(content, imageResId);
|
||||||
mTooltipWindow.showAtTopCenter(getView());
|
mTooltipWindow.showAtTopCenter(getView());
|
||||||
AccessibilityQuickSettingUtils.optInValueToSharedPreferences(getContext(),
|
AccessibilityQuickSettingUtils.optInValueToSharedPreferences(getContext(),
|
||||||
tileComponentName);
|
tileComponentName);
|
||||||
|
@@ -41,6 +41,7 @@ import androidx.annotation.Nullable;
|
|||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.accessibility.AccessibilityUtil.QuickSettingsTooltipType;
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
@@ -128,12 +129,21 @@ public class LaunchAccessibilityActivityPreferenceFragment extends ToggleFeature
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
CharSequence getTileName() {
|
CharSequence getTileTooltipContent(@QuickSettingsTooltipType int type) {
|
||||||
final ComponentName componentName = getTileComponentName();
|
final ComponentName componentName = getTileComponentName();
|
||||||
if (componentName == null) {
|
if (componentName == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return loadTileLabel(getPrefContext(), componentName);
|
|
||||||
|
final CharSequence tileName = loadTileLabel(getPrefContext(), componentName);
|
||||||
|
if (tileName == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
final int titleResId = type == QuickSettingsTooltipType.GUIDE_TO_EDIT
|
||||||
|
? R.string.accessibility_service_qs_tooltips_content
|
||||||
|
: R.string.accessibility_service_auto_added_qs_tooltips_content;
|
||||||
|
return getString(titleResId, tileName);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@@ -16,6 +16,9 @@
|
|||||||
|
|
||||||
package com.android.settings.accessibility;
|
package com.android.settings.accessibility;
|
||||||
|
|
||||||
|
import static com.android.internal.accessibility.AccessibilityShortcutController.REDUCE_BRIGHT_COLORS_TILE_SERVICE_COMPONENT_NAME;
|
||||||
|
|
||||||
|
import android.content.ComponentName;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.database.ContentObserver;
|
import android.database.ContentObserver;
|
||||||
import android.hardware.display.ColorDisplayManager;
|
import android.hardware.display.ColorDisplayManager;
|
||||||
@@ -30,14 +33,14 @@ import androidx.preference.Preference;
|
|||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.core.TogglePreferenceController;
|
|
||||||
import com.android.settingslib.PrimarySwitchPreference;
|
import com.android.settingslib.PrimarySwitchPreference;
|
||||||
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
||||||
import com.android.settingslib.core.lifecycle.events.OnStart;
|
import com.android.settingslib.core.lifecycle.events.OnStart;
|
||||||
import com.android.settingslib.core.lifecycle.events.OnStop;
|
import com.android.settingslib.core.lifecycle.events.OnStop;
|
||||||
|
|
||||||
/** PreferenceController that shows the Reduce Bright Colors summary */
|
/** PreferenceController that shows the Reduce Bright Colors summary */
|
||||||
public class ReduceBrightColorsPreferenceController extends TogglePreferenceController
|
public class ReduceBrightColorsPreferenceController
|
||||||
|
extends AccessibilityQuickSettingsPrimarySwitchPreferenceController
|
||||||
implements LifecycleObserver, OnStart, OnStop {
|
implements LifecycleObserver, OnStart, OnStop {
|
||||||
private ContentObserver mSettingsContentObserver;
|
private ContentObserver mSettingsContentObserver;
|
||||||
private PrimarySwitchPreference mPreference;
|
private PrimarySwitchPreference mPreference;
|
||||||
@@ -67,6 +70,7 @@ public class ReduceBrightColorsPreferenceController extends TogglePreferenceCont
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean setChecked(boolean isChecked) {
|
public boolean setChecked(boolean isChecked) {
|
||||||
|
super.setChecked(isChecked);
|
||||||
return mColorDisplayManager.setReduceBrightColorsActivated(isChecked);
|
return mColorDisplayManager.setReduceBrightColorsActivated(isChecked);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -105,8 +109,20 @@ public class ReduceBrightColorsPreferenceController extends TogglePreferenceCont
|
|||||||
Settings.Secure.REDUCE_BRIGHT_COLORS_ACTIVATED),
|
Settings.Secure.REDUCE_BRIGHT_COLORS_ACTIVATED),
|
||||||
false, mSettingsContentObserver, UserHandle.USER_CURRENT);
|
false, mSettingsContentObserver, UserHandle.USER_CURRENT);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onStop() {
|
public void onStop() {
|
||||||
mContext.getContentResolver().unregisterContentObserver(mSettingsContentObserver);
|
mContext.getContentResolver().unregisterContentObserver(mSettingsContentObserver);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected ComponentName getTileComponentName() {
|
||||||
|
return REDUCE_BRIGHT_COLORS_TILE_SERVICE_COMPONENT_NAME;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
CharSequence getTileTooltipContent() {
|
||||||
|
return mContext.getText(
|
||||||
|
R.string.accessibility_reduce_bright_colors_auto_added_qs_tooltip_content);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -47,6 +47,7 @@ import android.widget.Switch;
|
|||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.accessibility.AccessibilityUtil.QuickSettingsTooltipType;
|
||||||
import com.android.settings.accessibility.AccessibilityUtil.UserShortcutType;
|
import com.android.settings.accessibility.AccessibilityUtil.UserShortcutType;
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
import com.android.settingslib.accessibility.AccessibilityUtils;
|
import com.android.settingslib.accessibility.AccessibilityUtils;
|
||||||
@@ -239,12 +240,21 @@ public class ToggleAccessibilityServicePreferenceFragment extends
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
CharSequence getTileName() {
|
CharSequence getTileTooltipContent(@QuickSettingsTooltipType int type) {
|
||||||
final ComponentName componentName = getTileComponentName();
|
final ComponentName componentName = getTileComponentName();
|
||||||
if (componentName == null) {
|
if (componentName == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return loadTileLabel(getPrefContext(), componentName);
|
|
||||||
|
final CharSequence tileName = loadTileLabel(getPrefContext(), componentName);
|
||||||
|
if (tileName == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
final int titleResId = type == QuickSettingsTooltipType.GUIDE_TO_EDIT
|
||||||
|
? R.string.accessibility_service_qs_tooltips_content
|
||||||
|
: R.string.accessibility_service_auto_added_qs_tooltips_content;
|
||||||
|
return getString(titleResId, tileName);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@@ -144,8 +144,10 @@ public class ToggleColorInversionPreferenceFragment extends ToggleFeaturePrefere
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
CharSequence getTileName() {
|
CharSequence getTileTooltipContent(@QuickSettingsTooltipType int type) {
|
||||||
return getText(R.string.accessibility_display_inversion_preference_title);
|
return getText(type == QuickSettingsTooltipType.GUIDE_TO_EDIT
|
||||||
|
? R.string.accessibility_color_inversion_qs_tooltip_content
|
||||||
|
: R.string.accessibility_color_inversion_auto_added_qs_tooltip_content);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@@ -201,8 +201,10 @@ public final class ToggleDaltonizerPreferenceFragment extends ToggleFeaturePrefe
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
CharSequence getTileName() {
|
CharSequence getTileTooltipContent(@QuickSettingsTooltipType int type) {
|
||||||
return getText(R.string.accessibility_display_daltonizer_preference_title);
|
return getText(type == QuickSettingsTooltipType.GUIDE_TO_EDIT
|
||||||
|
? R.string.accessibility_color_correction_qs_tooltip_content
|
||||||
|
: R.string.accessibility_color_correction_auto_added_qs_tooltip_content);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@@ -222,7 +222,7 @@ public abstract class ToggleFeaturePreferenceFragment extends SettingsPreference
|
|||||||
|
|
||||||
updatePreferenceOrder();
|
updatePreferenceOrder();
|
||||||
|
|
||||||
// Reshow tooltips when activity recreate, such as rotate device.
|
// Reshow tooltip when activity recreate, such as rotate device.
|
||||||
if (mNeedsQSTooltipReshow) {
|
if (mNeedsQSTooltipReshow) {
|
||||||
getView().post(this::showQuickSettingsTooltipIfNeeded);
|
getView().post(this::showQuickSettingsTooltipIfNeeded);
|
||||||
}
|
}
|
||||||
@@ -331,8 +331,8 @@ public abstract class ToggleFeaturePreferenceFragment extends SettingsPreference
|
|||||||
/** Returns the accessibility tile component name. */
|
/** Returns the accessibility tile component name. */
|
||||||
abstract ComponentName getTileComponentName();
|
abstract ComponentName getTileComponentName();
|
||||||
|
|
||||||
/** Returns the accessibility tile feature name. */
|
/** Returns the accessibility tile tooltip content. */
|
||||||
abstract CharSequence getTileName();
|
abstract CharSequence getTileTooltipContent(@QuickSettingsTooltipType int type);
|
||||||
|
|
||||||
protected void updateToggleServiceTitle(SettingsMainSwitchPreference switchPreference) {
|
protected void updateToggleServiceTitle(SettingsMainSwitchPreference switchPreference) {
|
||||||
final CharSequence title =
|
final CharSequence title =
|
||||||
@@ -870,21 +870,17 @@ public abstract class ToggleFeaturePreferenceFragment extends SettingsPreference
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final CharSequence tileName = getTileName();
|
final CharSequence content = getTileTooltipContent(mNeedsQSTooltipType);
|
||||||
if (TextUtils.isEmpty(tileName)) {
|
if (TextUtils.isEmpty(content)) {
|
||||||
// Returns if no title of tile service assigned.
|
// Returns if no content of tile tooltip assigned.
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final int titleResId = mNeedsQSTooltipType == QuickSettingsTooltipType.GUIDE_TO_EDIT
|
|
||||||
? R.string.accessibility_service_qs_tooltips_content
|
|
||||||
: R.string.accessibility_service_auto_added_qs_tooltips_content;
|
|
||||||
final String title = getString(titleResId, tileName);
|
|
||||||
final int imageResId = mNeedsQSTooltipType == QuickSettingsTooltipType.GUIDE_TO_EDIT
|
final int imageResId = mNeedsQSTooltipType == QuickSettingsTooltipType.GUIDE_TO_EDIT
|
||||||
? R.drawable.accessibility_qs_tooltips_illustration
|
? R.drawable.accessibility_qs_tooltips_illustration
|
||||||
: R.drawable.accessibility_auto_added_qs_tooltips_illustration;
|
: R.drawable.accessibility_auto_added_qs_tooltips_illustration;
|
||||||
mTooltipWindow = new AccessibilityQuickSettingsTooltipWindow(getContext());
|
mTooltipWindow = new AccessibilityQuickSettingsTooltipWindow(getContext());
|
||||||
mTooltipWindow.setup(title, imageResId);
|
mTooltipWindow.setup(content, imageResId);
|
||||||
mTooltipWindow.showAtTopCenter(getView());
|
mTooltipWindow.showAtTopCenter(getView());
|
||||||
AccessibilityQuickSettingUtils.optInValueToSharedPreferences(getContext(),
|
AccessibilityQuickSettingUtils.optInValueToSharedPreferences(getContext(),
|
||||||
tileComponentName);
|
tileComponentName);
|
||||||
|
@@ -184,8 +184,10 @@ public class ToggleReduceBrightColorsPreferenceFragment extends ToggleFeaturePre
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
CharSequence getTileName() {
|
CharSequence getTileTooltipContent(@QuickSettingsTooltipType int type) {
|
||||||
return getText(R.string.reduce_bright_colors_preference_title);
|
return getText(type == QuickSettingsTooltipType.GUIDE_TO_EDIT
|
||||||
|
? R.string.accessibility_reduce_bright_colors_qs_tooltip_content
|
||||||
|
: R.string.accessibility_reduce_bright_colors_auto_added_qs_tooltip_content);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@@ -47,6 +47,7 @@ import com.android.internal.annotations.VisibleForTesting;
|
|||||||
import com.android.settings.DialogCreatable;
|
import com.android.settings.DialogCreatable;
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.accessibility.AccessibilityDialogUtils.DialogType;
|
import com.android.settings.accessibility.AccessibilityDialogUtils.DialogType;
|
||||||
|
import com.android.settings.accessibility.AccessibilityUtil.QuickSettingsTooltipType;
|
||||||
import com.android.settings.accessibility.AccessibilityUtil.UserShortcutType;
|
import com.android.settings.accessibility.AccessibilityUtil.UserShortcutType;
|
||||||
import com.android.settings.utils.LocaleUtils;
|
import com.android.settings.utils.LocaleUtils;
|
||||||
|
|
||||||
@@ -405,7 +406,7 @@ public class ToggleScreenMagnificationPreferenceFragment extends
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
CharSequence getTileName() {
|
CharSequence getTileTooltipContent(@QuickSettingsTooltipType int type) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -131,8 +131,10 @@ public class OneHandedSettings extends AccessibilityShortcutPreferenceFragment {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected CharSequence getTileName() {
|
protected CharSequence getTileTooltipContent(@QuickSettingsTooltipType int type) {
|
||||||
return mFeatureName;
|
return type == QuickSettingsTooltipType.GUIDE_TO_EDIT
|
||||||
|
? getText(R.string.accessibility_one_handed_mode_qs_tooltip_content)
|
||||||
|
: getText(R.string.accessibility_one_handed_mode_auto_added_qs_tooltip_content);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@@ -0,0 +1,186 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2022 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 static com.android.settings.accessibility.ToggleFeaturePreferenceFragment.KEY_SAVED_QS_TOOLTIP_RESHOW;
|
||||||
|
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.Mockito.doReturn;
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.content.ComponentName;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.view.LayoutInflater;
|
||||||
|
import android.widget.LinearLayout;
|
||||||
|
import android.widget.PopupWindow;
|
||||||
|
|
||||||
|
import androidx.preference.PreferenceManager;
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
import androidx.preference.PreferenceViewHolder;
|
||||||
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.SettingsPreferenceFragment;
|
||||||
|
import com.android.settings.testutils.shadow.ShadowFragment;
|
||||||
|
import com.android.settingslib.PrimarySwitchPreference;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Rule;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Answers;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.MockitoAnnotations;
|
||||||
|
import org.mockito.Spy;
|
||||||
|
import org.mockito.junit.MockitoJUnit;
|
||||||
|
import org.mockito.junit.MockitoRule;
|
||||||
|
import org.robolectric.RobolectricTestRunner;
|
||||||
|
import org.robolectric.annotation.Config;
|
||||||
|
import org.robolectric.shadow.api.Shadow;
|
||||||
|
import org.robolectric.shadows.ShadowApplication;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests for {@link AccessibilityQuickSettingsPrimarySwitchPreferenceController}.
|
||||||
|
*/
|
||||||
|
@RunWith(RobolectricTestRunner.class)
|
||||||
|
public class AccessibilityQuickSettingsPrimarySwitchPreferenceControllerTest {
|
||||||
|
|
||||||
|
private static final String PLACEHOLDER_PACKAGE_NAME = "com.placeholder.example";
|
||||||
|
private static final String PLACEHOLDER_TILE_CLASS_NAME =
|
||||||
|
PLACEHOLDER_PACKAGE_NAME + "tile.placeholder";
|
||||||
|
private static final ComponentName PLACEHOLDER_TILE_COMPONENT_NAME = new ComponentName(
|
||||||
|
PLACEHOLDER_PACKAGE_NAME, PLACEHOLDER_TILE_CLASS_NAME);
|
||||||
|
private static final CharSequence PLACEHOLDER_TILE_CONTENT =
|
||||||
|
PLACEHOLDER_TILE_CLASS_NAME + ".tile.content";
|
||||||
|
private static final String TEST_KEY = "test_pref_key";
|
||||||
|
private static final String TEST_TITLE = "test_title";
|
||||||
|
|
||||||
|
@Rule
|
||||||
|
public final MockitoRule mockito = MockitoJUnit.rule();
|
||||||
|
|
||||||
|
@Spy
|
||||||
|
private final Context mContext = ApplicationProvider.getApplicationContext();
|
||||||
|
|
||||||
|
private TestAccessibilityQuickSettingsPrimarySwitchPreferenceController mController;
|
||||||
|
private PrimarySwitchPreference mPreference;
|
||||||
|
private TestFragment mFragment;
|
||||||
|
private PreferenceScreen mScreen;
|
||||||
|
private PreferenceViewHolder mHolder;
|
||||||
|
@Mock(answer = Answers.RETURNS_DEEP_STUBS)
|
||||||
|
private PreferenceManager mPreferenceManager;
|
||||||
|
|
||||||
|
private static PopupWindow getLatestPopupWindow() {
|
||||||
|
final ShadowApplication shadowApplication =
|
||||||
|
Shadow.extract(ApplicationProvider.getApplicationContext());
|
||||||
|
return shadowApplication.getLatestPopupWindow();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
MockitoAnnotations.initMocks(this);
|
||||||
|
|
||||||
|
mContext.setTheme(R.style.Theme_AppCompat);
|
||||||
|
mFragment = spy(new TestFragment());
|
||||||
|
when(mFragment.getPreferenceManager()).thenReturn(mPreferenceManager);
|
||||||
|
when(mFragment.getPreferenceManager().getContext()).thenReturn(mContext);
|
||||||
|
when(mFragment.getContext()).thenReturn(mContext);
|
||||||
|
mScreen = spy(new PreferenceScreen(mContext, /* attrs= */ null));
|
||||||
|
when(mScreen.getPreferenceManager()).thenReturn(mPreferenceManager);
|
||||||
|
doReturn(mScreen).when(mFragment).getPreferenceScreen();
|
||||||
|
|
||||||
|
mPreference = new PrimarySwitchPreference(mContext);
|
||||||
|
mPreference.setKey(TEST_KEY);
|
||||||
|
mPreference.setTitle(TEST_TITLE);
|
||||||
|
LayoutInflater inflater = LayoutInflater.from(mContext);
|
||||||
|
mHolder = PreferenceViewHolder.createInstanceForTests(inflater.inflate(
|
||||||
|
com.android.settingslib.R.layout.preference_two_target, null));
|
||||||
|
LinearLayout mWidgetView = mHolder.itemView.findViewById(android.R.id.widget_frame);
|
||||||
|
inflater.inflate(R.layout.preference_widget_primary_switch, mWidgetView, true);
|
||||||
|
mPreference.onBindViewHolder(mHolder);
|
||||||
|
|
||||||
|
mController = new TestAccessibilityQuickSettingsPrimarySwitchPreferenceController(mContext,
|
||||||
|
TEST_KEY);
|
||||||
|
when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mPreference);
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void setChecked_showTooltipView() {
|
||||||
|
mController.setChecked(true);
|
||||||
|
|
||||||
|
assertThat(getLatestPopupWindow().isShowing()).isTrue();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void setChecked_tooltipViewShown_notShowTooltipView() {
|
||||||
|
mController.setChecked(true);
|
||||||
|
getLatestPopupWindow().dismiss();
|
||||||
|
mController.setChecked(false);
|
||||||
|
|
||||||
|
mController.setChecked(true);
|
||||||
|
|
||||||
|
assertThat(getLatestPopupWindow().isShowing()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Config(shadows = ShadowFragment.class)
|
||||||
|
public void restoreValueFromSavedInstanceState_showTooltipView() {
|
||||||
|
mController.setChecked(true);
|
||||||
|
final Bundle savedInstanceState = new Bundle();
|
||||||
|
savedInstanceState.putBoolean(KEY_SAVED_QS_TOOLTIP_RESHOW, /* value= */ true);
|
||||||
|
|
||||||
|
mFragment.onCreate(savedInstanceState);
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
|
|
||||||
|
assertThat(getLatestPopupWindow().isShowing()).isTrue();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class TestAccessibilityQuickSettingsPrimarySwitchPreferenceController
|
||||||
|
extends AccessibilityQuickSettingsPrimarySwitchPreferenceController {
|
||||||
|
|
||||||
|
public TestAccessibilityQuickSettingsPrimarySwitchPreferenceController(Context context,
|
||||||
|
String preferenceKey) {
|
||||||
|
super(context, preferenceKey);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
ComponentName getTileComponentName() {
|
||||||
|
return PLACEHOLDER_TILE_COMPONENT_NAME;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
CharSequence getTileTooltipContent() {
|
||||||
|
return PLACEHOLDER_TILE_CONTENT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static class TestFragment extends SettingsPreferenceFragment {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected boolean shouldSkipForInitialSUW() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getMetricsCategory() {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@@ -73,6 +73,8 @@ public class AccessibilityShortcutPreferenceFragmentTest {
|
|||||||
PLACEHOLDER_PACKAGE_NAME, PLACEHOLDER_CLASS_NAME);
|
PLACEHOLDER_PACKAGE_NAME, PLACEHOLDER_CLASS_NAME);
|
||||||
private static final ComponentName PLACEHOLDER_TILE_COMPONENT_NAME = new ComponentName(
|
private static final ComponentName PLACEHOLDER_TILE_COMPONENT_NAME = new ComponentName(
|
||||||
PLACEHOLDER_PACKAGE_NAME, PLACEHOLDER_TILE_CLASS_NAME);
|
PLACEHOLDER_PACKAGE_NAME, PLACEHOLDER_TILE_CLASS_NAME);
|
||||||
|
private static final String PLACEHOLDER_TILE_TOOLTIP_CONTENT =
|
||||||
|
PLACEHOLDER_PACKAGE_NAME + "tooltip_content";
|
||||||
private static final String PLACEHOLDER_DIALOG_TITLE = "title";
|
private static final String PLACEHOLDER_DIALOG_TITLE = "title";
|
||||||
|
|
||||||
private static final String SOFTWARE_SHORTCUT_KEY =
|
private static final String SOFTWARE_SHORTCUT_KEY =
|
||||||
@@ -281,8 +283,8 @@ public class AccessibilityShortcutPreferenceFragmentTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected CharSequence getTileName() {
|
protected CharSequence getTileTooltipContent(@QuickSettingsTooltipType int type) {
|
||||||
return PLACEHOLDER_PACKAGE_NAME;
|
return PLACEHOLDER_TILE_TOOLTIP_CONTENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@@ -34,6 +34,9 @@ import androidx.preference.PreferenceManager;
|
|||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.accessibility.AccessibilityUtil.QuickSettingsTooltipType;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
@@ -44,8 +47,6 @@ import org.robolectric.RobolectricTestRunner;
|
|||||||
import org.robolectric.Shadows;
|
import org.robolectric.Shadows;
|
||||||
import org.robolectric.shadows.ShadowPackageManager;
|
import org.robolectric.shadows.ShadowPackageManager;
|
||||||
|
|
||||||
import java.util.Arrays;
|
|
||||||
|
|
||||||
/** Tests for {@link LaunchAccessibilityActivityPreferenceFragment} */
|
/** Tests for {@link LaunchAccessibilityActivityPreferenceFragment} */
|
||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
public class LaunchAccessibilityActivityPreferenceFragmentTest {
|
public class LaunchAccessibilityActivityPreferenceFragmentTest {
|
||||||
@@ -83,53 +84,91 @@ public class LaunchAccessibilityActivityPreferenceFragmentTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getTileName_noTileServiceAssigned_returnNull() {
|
public void getTileTooltipContent_noTileServiceAssigned_returnNull() {
|
||||||
assertThat(mFragment.getTileName()).isNull();
|
final CharSequence tileTooltipContent =
|
||||||
|
mFragment.getTileTooltipContent(QuickSettingsTooltipType.GUIDE_TO_EDIT);
|
||||||
|
|
||||||
|
assertThat(tileTooltipContent).isNull();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getTileName_hasOneTileService_haveMatchString() {
|
public void getTileTooltipContent_hasOneTileService_guideToEdit_haveMatchString() {
|
||||||
final Intent tileProbe = new Intent(TileService.ACTION_QS_TILE);
|
setupTileService(PLACEHOLDER_PACKAGE_NAME, PLACEHOLDER_TILE_CLASS_NAME,
|
||||||
final ResolveInfo info = new ResolveInfo();
|
PLACEHOLDER_TILE_NAME);
|
||||||
info.serviceInfo = new FakeServiceInfo();
|
|
||||||
info.serviceInfo.packageName = PLACEHOLDER_PACKAGE_NAME;
|
|
||||||
info.serviceInfo.name = PLACEHOLDER_TILE_CLASS_NAME;
|
|
||||||
final ShadowPackageManager shadowPackageManager =
|
|
||||||
Shadows.shadowOf(mContext.getPackageManager());
|
|
||||||
shadowPackageManager.setResolveInfosForIntent(tileProbe, Arrays.asList(info));
|
|
||||||
|
|
||||||
final CharSequence tileName = mFragment.getTileName();
|
final CharSequence tileTooltipContent =
|
||||||
assertThat(tileName.toString()).isEqualTo(PLACEHOLDER_TILE_NAME);
|
mFragment.getTileTooltipContent(QuickSettingsTooltipType.GUIDE_TO_EDIT);
|
||||||
|
final CharSequence tileName =
|
||||||
|
mFragment.loadTileLabel(mContext, mFragment.getTileComponentName());
|
||||||
|
assertThat(tileTooltipContent.toString()).isEqualTo(
|
||||||
|
mContext.getString(R.string.accessibility_service_qs_tooltips_content, tileName));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getTileName_hasTwoTileServices_haveMatchString() {
|
public void getTileTooltipContent_hasOneTileService_guideToDirectUse_haveMatchString() {
|
||||||
|
setupTileService(PLACEHOLDER_PACKAGE_NAME, PLACEHOLDER_TILE_CLASS_NAME,
|
||||||
|
PLACEHOLDER_TILE_NAME);
|
||||||
|
|
||||||
|
final CharSequence tileTooltipContent =
|
||||||
|
mFragment.getTileTooltipContent(QuickSettingsTooltipType.GUIDE_TO_DIRECT_USE);
|
||||||
|
final CharSequence tileName =
|
||||||
|
mFragment.loadTileLabel(mContext, mFragment.getTileComponentName());
|
||||||
|
assertThat(tileTooltipContent.toString()).isEqualTo(
|
||||||
|
mContext.getString(
|
||||||
|
R.string.accessibility_service_auto_added_qs_tooltips_content, tileName));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getTileTooltipContent_hasTwoTileServices_guideToEdit_haveMatchString() {
|
||||||
|
setupTileService(PLACEHOLDER_PACKAGE_NAME, PLACEHOLDER_TILE_CLASS_NAME,
|
||||||
|
PLACEHOLDER_TILE_NAME);
|
||||||
|
setupTileService(PLACEHOLDER_PACKAGE_NAME, PLACEHOLDER_TILE_CLASS_NAME2,
|
||||||
|
PLACEHOLDER_TILE_NAME2);
|
||||||
|
|
||||||
|
final CharSequence tileTooltipContent =
|
||||||
|
mFragment.getTileTooltipContent(QuickSettingsTooltipType.GUIDE_TO_EDIT);
|
||||||
|
final CharSequence tileName =
|
||||||
|
mFragment.loadTileLabel(mContext, mFragment.getTileComponentName());
|
||||||
|
assertThat(tileTooltipContent.toString()).isEqualTo(
|
||||||
|
mContext.getString(R.string.accessibility_service_qs_tooltips_content, tileName));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getTileTooltipContent_hasTwoTileServices_guideToDirectUse_haveMatchString() {
|
||||||
|
setupTileService(PLACEHOLDER_PACKAGE_NAME, PLACEHOLDER_TILE_CLASS_NAME,
|
||||||
|
PLACEHOLDER_TILE_NAME);
|
||||||
|
setupTileService(PLACEHOLDER_PACKAGE_NAME, PLACEHOLDER_TILE_CLASS_NAME2,
|
||||||
|
PLACEHOLDER_TILE_NAME2);
|
||||||
|
|
||||||
|
final CharSequence tileTooltipContent =
|
||||||
|
mFragment.getTileTooltipContent(QuickSettingsTooltipType.GUIDE_TO_DIRECT_USE);
|
||||||
|
final CharSequence tileName =
|
||||||
|
mFragment.loadTileLabel(mContext, mFragment.getTileComponentName());
|
||||||
|
assertThat(tileTooltipContent.toString()).isEqualTo(
|
||||||
|
mContext.getString(
|
||||||
|
R.string.accessibility_service_auto_added_qs_tooltips_content, tileName));
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setupTileService(String packageName, String name, String tileName) {
|
||||||
final Intent tileProbe = new Intent(TileService.ACTION_QS_TILE);
|
final Intent tileProbe = new Intent(TileService.ACTION_QS_TILE);
|
||||||
final ResolveInfo info = new ResolveInfo();
|
final ResolveInfo info = new ResolveInfo();
|
||||||
info.serviceInfo = new FakeServiceInfo();
|
info.serviceInfo = new FakeServiceInfo(packageName, name, tileName);
|
||||||
info.serviceInfo.packageName = PLACEHOLDER_PACKAGE_NAME;
|
|
||||||
info.serviceInfo.name = PLACEHOLDER_TILE_CLASS_NAME;
|
|
||||||
final ResolveInfo info2 = new ResolveInfo();
|
|
||||||
info2.serviceInfo = new FakeServiceInfo2();
|
|
||||||
info2.serviceInfo.packageName = PLACEHOLDER_PACKAGE_NAME;
|
|
||||||
info2.serviceInfo.name = PLACEHOLDER_TILE_CLASS_NAME2;
|
|
||||||
final ShadowPackageManager shadowPackageManager =
|
final ShadowPackageManager shadowPackageManager =
|
||||||
Shadows.shadowOf(mContext.getPackageManager());
|
Shadows.shadowOf(mContext.getPackageManager());
|
||||||
shadowPackageManager.setResolveInfosForIntent(tileProbe, Arrays.asList(info, info2));
|
shadowPackageManager.addResolveInfoForIntent(tileProbe, info);
|
||||||
|
|
||||||
final CharSequence tileName = mFragment.getTileName();
|
|
||||||
assertThat(tileName.toString()).isEqualTo(PLACEHOLDER_TILE_NAME);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class FakeServiceInfo extends ServiceInfo {
|
private static class FakeServiceInfo extends ServiceInfo {
|
||||||
public String loadLabel(PackageManager mgr) {
|
private String mTileName;
|
||||||
return PLACEHOLDER_TILE_NAME;
|
|
||||||
}
|
FakeServiceInfo(String packageName, String name, String tileName) {
|
||||||
}
|
this.packageName = packageName;
|
||||||
|
this.name = name;
|
||||||
|
mTileName = tileName;
|
||||||
|
}
|
||||||
|
|
||||||
private static class FakeServiceInfo2 extends ServiceInfo {
|
|
||||||
public String loadLabel(PackageManager mgr) {
|
public String loadLabel(PackageManager mgr) {
|
||||||
return PLACEHOLDER_TILE_NAME2;
|
return mTileName;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -34,6 +34,9 @@ import androidx.preference.PreferenceManager;
|
|||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.accessibility.AccessibilityUtil.QuickSettingsTooltipType;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
@@ -44,8 +47,6 @@ import org.robolectric.RobolectricTestRunner;
|
|||||||
import org.robolectric.Shadows;
|
import org.robolectric.Shadows;
|
||||||
import org.robolectric.shadows.ShadowPackageManager;
|
import org.robolectric.shadows.ShadowPackageManager;
|
||||||
|
|
||||||
import java.util.Arrays;
|
|
||||||
|
|
||||||
/** Tests for {@link ToggleAccessibilityServicePreferenceFragment} */
|
/** Tests for {@link ToggleAccessibilityServicePreferenceFragment} */
|
||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
public class ToggleAccessibilityServicePreferenceFragmentTest {
|
public class ToggleAccessibilityServicePreferenceFragmentTest {
|
||||||
@@ -83,53 +84,91 @@ public class ToggleAccessibilityServicePreferenceFragmentTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getTileName_noTileServiceAssigned_returnNull() {
|
public void getTileTooltipContent_noTileServiceAssigned_returnNull() {
|
||||||
assertThat(mFragment.getTileName()).isNull();
|
final CharSequence tileTooltipContent =
|
||||||
|
mFragment.getTileTooltipContent(QuickSettingsTooltipType.GUIDE_TO_EDIT);
|
||||||
|
|
||||||
|
assertThat(tileTooltipContent).isNull();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getTileName_hasOneTileService_haveMatchString() {
|
public void getTileTooltipContent_hasOneTileService_guideToEdit_haveMatchString() {
|
||||||
final Intent tileProbe = new Intent(TileService.ACTION_QS_TILE);
|
setupTileService(PLACEHOLDER_PACKAGE_NAME, PLACEHOLDER_TILE_CLASS_NAME,
|
||||||
final ResolveInfo info = new ResolveInfo();
|
PLACEHOLDER_TILE_NAME);
|
||||||
info.serviceInfo = new FakeServiceInfo();
|
|
||||||
info.serviceInfo.packageName = PLACEHOLDER_PACKAGE_NAME;
|
|
||||||
info.serviceInfo.name = PLACEHOLDER_TILE_CLASS_NAME;
|
|
||||||
final ShadowPackageManager shadowPackageManager =
|
|
||||||
Shadows.shadowOf(mContext.getPackageManager());
|
|
||||||
shadowPackageManager.setResolveInfosForIntent(tileProbe, Arrays.asList(info));
|
|
||||||
|
|
||||||
final CharSequence tileName = mFragment.getTileName();
|
final CharSequence tileTooltipContent =
|
||||||
assertThat(tileName.toString()).isEqualTo(PLACEHOLDER_TILE_NAME);
|
mFragment.getTileTooltipContent(QuickSettingsTooltipType.GUIDE_TO_EDIT);
|
||||||
|
final CharSequence tileName =
|
||||||
|
mFragment.loadTileLabel(mContext, mFragment.getTileComponentName());
|
||||||
|
assertThat(tileTooltipContent.toString()).isEqualTo(
|
||||||
|
mContext.getString(R.string.accessibility_service_qs_tooltips_content, tileName));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getTileName_hasTwoTileServices_haveMatchString() {
|
public void getTileTooltipContent_hasOneTileService_guideToDirectUse_haveMatchString() {
|
||||||
|
setupTileService(PLACEHOLDER_PACKAGE_NAME, PLACEHOLDER_TILE_CLASS_NAME,
|
||||||
|
PLACEHOLDER_TILE_NAME);
|
||||||
|
|
||||||
|
final CharSequence tileTooltipContent =
|
||||||
|
mFragment.getTileTooltipContent(QuickSettingsTooltipType.GUIDE_TO_DIRECT_USE);
|
||||||
|
final CharSequence tileName =
|
||||||
|
mFragment.loadTileLabel(mContext, mFragment.getTileComponentName());
|
||||||
|
assertThat(tileTooltipContent.toString()).isEqualTo(
|
||||||
|
mContext.getString(
|
||||||
|
R.string.accessibility_service_auto_added_qs_tooltips_content, tileName));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getTileTooltipContent_hasTwoTileServices_guideToEdit_haveMatchString() {
|
||||||
|
setupTileService(PLACEHOLDER_PACKAGE_NAME, PLACEHOLDER_TILE_CLASS_NAME,
|
||||||
|
PLACEHOLDER_TILE_NAME);
|
||||||
|
setupTileService(PLACEHOLDER_PACKAGE_NAME, PLACEHOLDER_TILE_CLASS_NAME2,
|
||||||
|
PLACEHOLDER_TILE_NAME2);
|
||||||
|
|
||||||
|
final CharSequence tileTooltipContent =
|
||||||
|
mFragment.getTileTooltipContent(QuickSettingsTooltipType.GUIDE_TO_EDIT);
|
||||||
|
final CharSequence tileName =
|
||||||
|
mFragment.loadTileLabel(mContext, mFragment.getTileComponentName());
|
||||||
|
assertThat(tileTooltipContent.toString()).isEqualTo(
|
||||||
|
mContext.getString(R.string.accessibility_service_qs_tooltips_content, tileName));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getTileTooltipContent_hasTwoTileServices_guideToDirectUse_haveMatchString() {
|
||||||
|
setupTileService(PLACEHOLDER_PACKAGE_NAME, PLACEHOLDER_TILE_CLASS_NAME,
|
||||||
|
PLACEHOLDER_TILE_NAME);
|
||||||
|
setupTileService(PLACEHOLDER_PACKAGE_NAME, PLACEHOLDER_TILE_CLASS_NAME2,
|
||||||
|
PLACEHOLDER_TILE_NAME2);
|
||||||
|
|
||||||
|
final CharSequence tileTooltipContent =
|
||||||
|
mFragment.getTileTooltipContent(QuickSettingsTooltipType.GUIDE_TO_DIRECT_USE);
|
||||||
|
final CharSequence tileName =
|
||||||
|
mFragment.loadTileLabel(mContext, mFragment.getTileComponentName());
|
||||||
|
assertThat(tileTooltipContent.toString()).isEqualTo(
|
||||||
|
mContext.getString(
|
||||||
|
R.string.accessibility_service_auto_added_qs_tooltips_content, tileName));
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setupTileService(String packageName, String name, String tileName) {
|
||||||
final Intent tileProbe = new Intent(TileService.ACTION_QS_TILE);
|
final Intent tileProbe = new Intent(TileService.ACTION_QS_TILE);
|
||||||
final ResolveInfo info = new ResolveInfo();
|
final ResolveInfo info = new ResolveInfo();
|
||||||
info.serviceInfo = new FakeServiceInfo();
|
info.serviceInfo = new FakeServiceInfo(packageName, name, tileName);
|
||||||
info.serviceInfo.packageName = PLACEHOLDER_PACKAGE_NAME;
|
|
||||||
info.serviceInfo.name = PLACEHOLDER_TILE_CLASS_NAME;
|
|
||||||
final ResolveInfo info2 = new ResolveInfo();
|
|
||||||
info2.serviceInfo = new FakeServiceInfo2();
|
|
||||||
info2.serviceInfo.packageName = PLACEHOLDER_PACKAGE_NAME;
|
|
||||||
info2.serviceInfo.name = PLACEHOLDER_TILE_CLASS_NAME2;
|
|
||||||
final ShadowPackageManager shadowPackageManager =
|
final ShadowPackageManager shadowPackageManager =
|
||||||
Shadows.shadowOf(mContext.getPackageManager());
|
Shadows.shadowOf(mContext.getPackageManager());
|
||||||
shadowPackageManager.setResolveInfosForIntent(tileProbe, Arrays.asList(info, info2));
|
shadowPackageManager.addResolveInfoForIntent(tileProbe, info);
|
||||||
|
|
||||||
final CharSequence tileName = mFragment.getTileName();
|
|
||||||
assertThat(tileName.toString()).isEqualTo(PLACEHOLDER_TILE_NAME);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class FakeServiceInfo extends ServiceInfo {
|
private static class FakeServiceInfo extends ServiceInfo {
|
||||||
public String loadLabel(PackageManager mgr) {
|
private String mTileName;
|
||||||
return PLACEHOLDER_TILE_NAME;
|
|
||||||
}
|
FakeServiceInfo(String packageName, String name, String tileName) {
|
||||||
}
|
this.packageName = packageName;
|
||||||
|
this.name = name;
|
||||||
|
mTileName = tileName;
|
||||||
|
}
|
||||||
|
|
||||||
private static class FakeServiceInfo2 extends ServiceInfo {
|
|
||||||
public String loadLabel(PackageManager mgr) {
|
public String loadLabel(PackageManager mgr) {
|
||||||
return PLACEHOLDER_TILE_NAME2;
|
return mTileName;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -49,6 +49,7 @@ import androidx.test.core.app.ApplicationProvider;
|
|||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.accessibility.AccessibilityDialogUtils.DialogType;
|
import com.android.settings.accessibility.AccessibilityDialogUtils.DialogType;
|
||||||
|
import com.android.settings.accessibility.AccessibilityUtil.QuickSettingsTooltipType;
|
||||||
import com.android.settings.accessibility.AccessibilityUtil.UserShortcutType;
|
import com.android.settings.accessibility.AccessibilityUtil.UserShortcutType;
|
||||||
import com.android.settings.testutils.shadow.ShadowFragment;
|
import com.android.settings.testutils.shadow.ShadowFragment;
|
||||||
import com.android.settingslib.widget.TopIntroPreference;
|
import com.android.settingslib.widget.TopIntroPreference;
|
||||||
@@ -77,8 +78,8 @@ public class ToggleFeaturePreferenceFragmentTest {
|
|||||||
PLACEHOLDER_PACKAGE_NAME + "tile.placeholder";
|
PLACEHOLDER_PACKAGE_NAME + "tile.placeholder";
|
||||||
private static final ComponentName PLACEHOLDER_TILE_COMPONENT_NAME = new ComponentName(
|
private static final ComponentName PLACEHOLDER_TILE_COMPONENT_NAME = new ComponentName(
|
||||||
PLACEHOLDER_PACKAGE_NAME, PLACEHOLDER_TILE_CLASS_NAME);
|
PLACEHOLDER_PACKAGE_NAME, PLACEHOLDER_TILE_CLASS_NAME);
|
||||||
private static final String PLACEHOLDER_TILE_NAME =
|
private static final String PLACEHOLDER_TILE_TOOLTIP_CONTENT =
|
||||||
PLACEHOLDER_PACKAGE_NAME + "tile.placeholder";
|
PLACEHOLDER_PACKAGE_NAME + "tooltip_content";
|
||||||
private static final String PLACEHOLDER_DIALOG_TITLE = "title";
|
private static final String PLACEHOLDER_DIALOG_TITLE = "title";
|
||||||
private static final String DEFAULT_SUMMARY = "default summary";
|
private static final String DEFAULT_SUMMARY = "default summary";
|
||||||
private static final String DEFAULT_DESCRIPTION = "default description";
|
private static final String DEFAULT_DESCRIPTION = "default description";
|
||||||
@@ -361,8 +362,8 @@ public class ToggleFeaturePreferenceFragmentTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
CharSequence getTileName() {
|
protected CharSequence getTileTooltipContent(@QuickSettingsTooltipType int type) {
|
||||||
return PLACEHOLDER_TILE_NAME;
|
return PLACEHOLDER_TILE_TOOLTIP_CONTENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
Reference in New Issue
Block a user