Fix that the user has no way of knowing if the reset was successful.
Goal: Added the new confirm dialog into to warn users. Bug: 220126995 Bug: 222419452 Test: make RunSettingsRoboTests ROBOTEST_FILTER=TextReadingResetControllerTest Change-Id: Id6e3ebdd6e9990996a5a4f12d9d19e28d3d58a13
This commit is contained in:
@@ -27,9 +27,14 @@
|
|||||||
android:id="@+id/reset_button"
|
android:id="@+id/reset_button"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_gravity="center"
|
android:layout_gravity="center|end"
|
||||||
android:paddingHorizontal="24dp"
|
|
||||||
android:paddingVertical="14dp"
|
android:paddingVertical="14dp"
|
||||||
android:text="@string/accessibility_text_reading_reset_button_title"
|
android:background="@null"
|
||||||
style="@style/ActionPrimaryButton"/>
|
android:drawableStart="@drawable/ic_history"
|
||||||
|
android:drawablePadding="9dp"
|
||||||
|
android:drawableTint="?android:attr/colorAccent"
|
||||||
|
android:textColor="?android:attr/colorAccent"
|
||||||
|
android:textSize="16sp"
|
||||||
|
android:textAppearance="@android:style/TextAppearance.DeviceDefault.Medium"
|
||||||
|
android:text="@string/accessibility_text_reading_reset_button_title"/>
|
||||||
</FrameLayout>
|
</FrameLayout>
|
||||||
|
@@ -119,6 +119,11 @@ public class AccessibilityDialogUtils {
|
|||||||
* launch tutorial.
|
* launch tutorial.
|
||||||
*/
|
*/
|
||||||
int LAUNCH_ACCESSIBILITY_TUTORIAL = 1008;
|
int LAUNCH_ACCESSIBILITY_TUTORIAL = 1008;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* OPEN: Settings > Accessibility > Display size and text > Click 'Reset settings' button.
|
||||||
|
*/
|
||||||
|
int DIALOG_RESET_SETTINGS = 1009;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@@ -18,10 +18,15 @@ package com.android.settings.accessibility;
|
|||||||
|
|
||||||
import static com.android.settings.accessibility.TextReadingResetController.ResetStateListener;
|
import static com.android.settings.accessibility.TextReadingResetController.ResetStateListener;
|
||||||
|
|
||||||
|
import android.app.Dialog;
|
||||||
import android.app.settings.SettingsEnums;
|
import android.app.settings.SettingsEnums;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.content.DialogInterface;
|
||||||
|
|
||||||
|
import androidx.appcompat.app.AlertDialog;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.accessibility.AccessibilityDialogUtils.DialogEnums;
|
||||||
import com.android.settings.dashboard.DashboardFragment;
|
import com.android.settings.dashboard.DashboardFragment;
|
||||||
import com.android.settings.search.BaseSearchIndexProvider;
|
import com.android.settings.search.BaseSearchIndexProvider;
|
||||||
import com.android.settingslib.core.AbstractPreferenceController;
|
import com.android.settingslib.core.AbstractPreferenceController;
|
||||||
@@ -88,16 +93,54 @@ public class TextReadingPreferenceFragment extends DashboardFragment {
|
|||||||
new HighTextContrastPreferenceController(context, HIGHT_TEXT_CONTRAST_KEY);
|
new HighTextContrastPreferenceController(context, HIGHT_TEXT_CONTRAST_KEY);
|
||||||
controllers.add(highTextContrastController);
|
controllers.add(highTextContrastController);
|
||||||
|
|
||||||
final List<ResetStateListener> resetStateListeners =
|
|
||||||
controllers.stream().filter(c -> c instanceof ResetStateListener).map(
|
|
||||||
c -> (ResetStateListener) c).collect(Collectors.toList());
|
|
||||||
final TextReadingResetController resetController =
|
final TextReadingResetController resetController =
|
||||||
new TextReadingResetController(context, RESET_KEY, resetStateListeners);
|
new TextReadingResetController(context, RESET_KEY,
|
||||||
|
v -> showDialog(DialogEnums.DIALOG_RESET_SETTINGS));
|
||||||
controllers.add(resetController);
|
controllers.add(resetController);
|
||||||
|
|
||||||
return controllers;
|
return controllers;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Dialog onCreateDialog(int dialogId) {
|
||||||
|
if (dialogId == DialogEnums.DIALOG_RESET_SETTINGS) {
|
||||||
|
return new AlertDialog.Builder(getPrefContext())
|
||||||
|
.setTitle(R.string.accessibility_text_reading_confirm_dialog_title)
|
||||||
|
.setMessage(R.string.accessibility_text_reading_confirm_dialog_message)
|
||||||
|
.setPositiveButton(
|
||||||
|
R.string.accessibility_text_reading_confirm_dialog_reset_button,
|
||||||
|
this::onPositiveButtonClicked)
|
||||||
|
.setNegativeButton(R.string.cancel, /* listener= */ null)
|
||||||
|
.create();
|
||||||
|
}
|
||||||
|
|
||||||
|
throw new IllegalArgumentException("Unsupported dialogId " + dialogId);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getDialogMetricsCategory(int dialogId) {
|
||||||
|
if (dialogId == DialogEnums.DIALOG_RESET_SETTINGS) {
|
||||||
|
return SettingsEnums.DIALOG_RESET_SETTINGS;
|
||||||
|
}
|
||||||
|
|
||||||
|
return super.getDialogMetricsCategory(dialogId);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void onPositiveButtonClicked(DialogInterface dialog, int which) {
|
||||||
|
// To avoid showing the dialog again, probably the onDetach() of SettingsDialogFragment
|
||||||
|
// was interrupted by unexpectedly recreating the activity.
|
||||||
|
removeDialog(DialogEnums.DIALOG_RESET_SETTINGS);
|
||||||
|
|
||||||
|
getResetStateListeners().forEach(ResetStateListener::resetState);
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<ResetStateListener> getResetStateListeners() {
|
||||||
|
final List<AbstractPreferenceController> controllers = new ArrayList<>();
|
||||||
|
getPreferenceControllers().forEach(controllers::addAll);
|
||||||
|
return controllers.stream().filter(c -> c instanceof ResetStateListener).map(
|
||||||
|
c -> (ResetStateListener) c).collect(Collectors.toList());
|
||||||
|
}
|
||||||
|
|
||||||
public static final BaseSearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
|
public static final BaseSearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
|
||||||
new BaseSearchIndexProvider(R.xml.accessibility_text_reading_options);
|
new BaseSearchIndexProvider(R.xml.accessibility_text_reading_options);
|
||||||
}
|
}
|
||||||
|
@@ -19,25 +19,23 @@ package com.android.settings.accessibility;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
|
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.Nullable;
|
||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.core.BasePreferenceController;
|
import com.android.settings.core.BasePreferenceController;
|
||||||
import com.android.settingslib.widget.LayoutPreference;
|
import com.android.settingslib.widget.LayoutPreference;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The controller of the reset button in the text and reading options page.
|
* The controller of the reset button in the text and reading options page.
|
||||||
*/
|
*/
|
||||||
class TextReadingResetController extends BasePreferenceController {
|
class TextReadingResetController extends BasePreferenceController {
|
||||||
private final List<ResetStateListener> mListeners;
|
private final View.OnClickListener mOnResetClickListener;
|
||||||
|
|
||||||
TextReadingResetController(Context context, String preferenceKey,
|
TextReadingResetController(Context context, String preferenceKey,
|
||||||
@NonNull List<ResetStateListener> listeners) {
|
@Nullable View.OnClickListener listener) {
|
||||||
super(context, preferenceKey);
|
super(context, preferenceKey);
|
||||||
mListeners = listeners;
|
mOnResetClickListener = listener;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -51,7 +49,11 @@ class TextReadingResetController extends BasePreferenceController {
|
|||||||
|
|
||||||
final LayoutPreference layoutPreference = screen.findPreference(getPreferenceKey());
|
final LayoutPreference layoutPreference = screen.findPreference(getPreferenceKey());
|
||||||
final View view = layoutPreference.findViewById(R.id.reset_button);
|
final View view = layoutPreference.findViewById(R.id.reset_button);
|
||||||
view.setOnClickListener(v -> mListeners.forEach(ResetStateListener::resetState));
|
view.setOnClickListener(v -> {
|
||||||
|
if (mOnResetClickListener != null) {
|
||||||
|
mOnResetClickListener.onClick(v);
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@@ -16,10 +16,10 @@
|
|||||||
|
|
||||||
package com.android.settings.accessibility;
|
package com.android.settings.accessibility;
|
||||||
|
|
||||||
import static com.android.settings.accessibility.TextReadingResetController.ResetStateListener;
|
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
@@ -29,7 +29,6 @@ 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.R;
|
||||||
import com.android.settings.core.BasePreferenceController;
|
|
||||||
import com.android.settingslib.widget.LayoutPreference;
|
import com.android.settingslib.widget.LayoutPreference;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
@@ -39,21 +38,18 @@ import org.mockito.Mock;
|
|||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests for {@link TextReadingResetController}.
|
* Tests for {@link TextReadingResetController}.
|
||||||
*/
|
*/
|
||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
public class TextReadingResetControllerTest {
|
public class TextReadingResetControllerTest {
|
||||||
private static final String TEST_KEY = "test";
|
|
||||||
private static final String RESET_KEY = "reset";
|
private static final String RESET_KEY = "reset";
|
||||||
private final Context mContext = ApplicationProvider.getApplicationContext();
|
private final Context mContext = ApplicationProvider.getApplicationContext();
|
||||||
private final View mResetView = new View(mContext);
|
private final View mResetView = new View(mContext);
|
||||||
private final List<ResetStateListener> mListeners = new ArrayList<>();
|
|
||||||
private TextReadingResetController mResetController;
|
private TextReadingResetController mResetController;
|
||||||
private TestPreferenceController mPreferenceController;
|
|
||||||
|
@Mock
|
||||||
|
private View.OnClickListener mOnResetButtonClickListener;
|
||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private PreferenceScreen mPreferenceScreen;
|
private PreferenceScreen mPreferenceScreen;
|
||||||
@@ -64,10 +60,8 @@ public class TextReadingResetControllerTest {
|
|||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
|
mResetController = new TextReadingResetController(mContext, RESET_KEY,
|
||||||
mPreferenceController = new TestPreferenceController(mContext, TEST_KEY);
|
mOnResetButtonClickListener);
|
||||||
mListeners.add(mPreferenceController);
|
|
||||||
mResetController = new TextReadingResetController(mContext, RESET_KEY, mListeners);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -80,40 +74,17 @@ public class TextReadingResetControllerTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void triggerResetState_success() {
|
public void clickResetButtonAfterDisplayPreference_verifyClickListener() {
|
||||||
setupResetButton();
|
setupResetButton();
|
||||||
|
|
||||||
mResetController.displayPreference(mPreferenceScreen);
|
mResetController.displayPreference(mPreferenceScreen);
|
||||||
mResetView.callOnClick();
|
mResetView.callOnClick();
|
||||||
|
|
||||||
assertThat(mPreferenceController.isReset()).isTrue();
|
verify(mOnResetButtonClickListener).onClick(any(View.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setupResetButton() {
|
private void setupResetButton() {
|
||||||
when(mPreferenceScreen.findPreference(RESET_KEY)).thenReturn(mLayoutPreference);
|
when(mPreferenceScreen.findPreference(RESET_KEY)).thenReturn(mLayoutPreference);
|
||||||
when(mLayoutPreference.findViewById(R.id.reset_button)).thenReturn(mResetView);
|
when(mLayoutPreference.findViewById(R.id.reset_button)).thenReturn(mResetView);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class TestPreferenceController extends BasePreferenceController implements
|
|
||||||
ResetStateListener {
|
|
||||||
private boolean mIsReset = false;
|
|
||||||
|
|
||||||
TestPreferenceController(Context context, String preferenceKey) {
|
|
||||||
super(context, preferenceKey);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void resetState() {
|
|
||||||
mIsReset = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int getAvailabilityStatus() {
|
|
||||||
return AVAILABLE;
|
|
||||||
}
|
|
||||||
|
|
||||||
boolean isReset() {
|
|
||||||
return mIsReset;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user