Snap for 6588207 from 6ccd5339fa to mainline-release

Change-Id: I5120e94fa7e35a5be63aa75a78780e5378a56f86
This commit is contained in:
android-build-team Robot
2020-06-14 07:08:30 +00:00
8 changed files with 33 additions and 65 deletions

View File

@@ -24,7 +24,6 @@
<Button <Button
android:id="@+id/night_display_turn_on_button" android:id="@+id/night_display_turn_on_button"
style="@style/ActionPrimaryButton" style="@style/ActionPrimaryButton"
android:focusableInTouchMode="true"
android:layout_marginStart="@dimen/screen_margin_sides" android:layout_marginStart="@dimen/screen_margin_sides"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
@@ -33,7 +32,6 @@
<Button <Button
android:id="@+id/night_display_turn_off_button" android:id="@+id/night_display_turn_off_button"
style="@style/ActionSecondaryButton" style="@style/ActionSecondaryButton"
android:focusableInTouchMode="true"
android:layout_marginStart="@dimen/screen_margin_sides" android:layout_marginStart="@dimen/screen_margin_sides"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"

View File

@@ -38,7 +38,6 @@
android:layout_marginTop="@dimen/zen_mode_settings_button_margin_vertical" android:layout_marginTop="@dimen/zen_mode_settings_button_margin_vertical"
android:layout_marginBottom="@dimen/zen_mode_settings_button_margin_vertical" android:layout_marginBottom="@dimen/zen_mode_settings_button_margin_vertical"
android:text="@string/zen_mode_button_turn_on" android:text="@string/zen_mode_button_turn_on"
android:focusableInTouchMode="true"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content"/> android:layout_height="wrap_content"/>
@@ -50,7 +49,6 @@
android:layout_marginTop="@dimen/zen_mode_settings_button_margin_vertical" android:layout_marginTop="@dimen/zen_mode_settings_button_margin_vertical"
android:layout_marginBottom="@dimen/zen_mode_settings_button_margin_vertical" android:layout_marginBottom="@dimen/zen_mode_settings_button_margin_vertical"
android:text="@string/zen_mode_button_turn_off" android:text="@string/zen_mode_button_turn_off"
android:focusableInTouchMode="true"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content"/> android:layout_height="wrap_content"/>

View File

@@ -16,6 +16,8 @@
package com.android.settings.display; package com.android.settings.display;
import static android.view.accessibility.AccessibilityEvent.TYPE_VIEW_FOCUSED;
import android.content.Context; import android.content.Context;
import android.hardware.display.ColorDisplayManager; import android.hardware.display.ColorDisplayManager;
import android.text.TextUtils; import android.text.TextUtils;
@@ -39,20 +41,16 @@ public class NightDisplayActivationPreferenceController extends TogglePreference
private NightDisplayTimeFormatter mTimeFormatter; private NightDisplayTimeFormatter mTimeFormatter;
private LayoutPreference mPreference; private LayoutPreference mPreference;
// Night light can also be toggled from QS. If night light wasn't toggled by this preference,
// don't requestFocus
private boolean mButtonTriggered = false;
private Button mTurnOffButton; private Button mTurnOffButton;
private Button mTurnOnButton; private Button mTurnOnButton;
private final OnClickListener mListener = new OnClickListener() { private final OnClickListener mListener = new OnClickListener() {
@Override @Override
public void onClick(View v) { public void onClick(View v) {
mButtonTriggered = true;
mMetricsFeatureProvider.logClickedPreference(mPreference, getMetricsCategory()); mMetricsFeatureProvider.logClickedPreference(mPreference, getMetricsCategory());
mColorDisplayManager.setNightDisplayActivated( mColorDisplayManager.setNightDisplayActivated(
!mColorDisplayManager.isNightDisplayActivated()); !mColorDisplayManager.isNightDisplayActivated());
updateStateInternal(); updateStateInternal(true);
} }
}; };
@@ -93,7 +91,7 @@ public class NightDisplayActivationPreferenceController extends TogglePreference
@Override @Override
public final void updateState(Preference preference) { public final void updateState(Preference preference) {
updateStateInternal(); updateStateInternal(false);
} }
/** FOR SLICES */ /** FOR SLICES */
@@ -113,7 +111,7 @@ public class NightDisplayActivationPreferenceController extends TogglePreference
return mTimeFormatter.getAutoModeSummary(mContext, mColorDisplayManager); return mTimeFormatter.getAutoModeSummary(mContext, mColorDisplayManager);
} }
private void updateStateInternal() { private void updateStateInternal(boolean selfChanged) {
if (mTurnOnButton == null || mTurnOffButton == null) { if (mTurnOnButton == null || mTurnOffButton == null) {
return; return;
} }
@@ -143,17 +141,15 @@ public class NightDisplayActivationPreferenceController extends TogglePreference
mTurnOnButton.setVisibility(View.GONE); mTurnOnButton.setVisibility(View.GONE);
mTurnOffButton.setVisibility(View.VISIBLE); mTurnOffButton.setVisibility(View.VISIBLE);
mTurnOffButton.setText(buttonText); mTurnOffButton.setText(buttonText);
if (mButtonTriggered) { if (selfChanged) {
mButtonTriggered = false; mTurnOffButton.sendAccessibilityEvent(TYPE_VIEW_FOCUSED);
mTurnOffButton.requestFocus();
} }
} else { } else {
mTurnOnButton.setVisibility(View.VISIBLE); mTurnOnButton.setVisibility(View.VISIBLE);
mTurnOffButton.setVisibility(View.GONE); mTurnOffButton.setVisibility(View.GONE);
mTurnOnButton.setText(buttonText); mTurnOnButton.setText(buttonText);
if (mButtonTriggered) { if (selfChanged) {
mButtonTriggered = false; mTurnOnButton.sendAccessibilityEvent(TYPE_VIEW_FOCUSED);
mTurnOnButton.requestFocus();
} }
} }
} }

View File

@@ -35,13 +35,10 @@ import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
import java.util.List; import java.util.List;
import java.util.concurrent.Callable; import java.util.concurrent.Callable;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.TimeUnit;
public class EligibleCardChecker implements Callable<ContextualCard> { public class EligibleCardChecker implements Callable<ContextualCard> {
private static final String TAG = "EligibleCardChecker"; private static final String TAG = "EligibleCardChecker";
private static final long LATCH_TIMEOUT_MS = 300;
private final Context mContext; private final Context mContext;
@@ -54,7 +51,7 @@ public class EligibleCardChecker implements Callable<ContextualCard> {
} }
@Override @Override
public ContextualCard call() throws Exception { public ContextualCard call() {
final long startTime = System.currentTimeMillis(); final long startTime = System.currentTimeMillis();
final MetricsFeatureProvider metricsFeatureProvider = final MetricsFeatureProvider metricsFeatureProvider =
FeatureFactory.getFactory(mContext).getMetricsFeatureProvider(); FeatureFactory.getFactory(mContext).getMetricsFeatureProvider();
@@ -113,35 +110,10 @@ public class EligibleCardChecker implements Callable<ContextualCard> {
@VisibleForTesting @VisibleForTesting
Slice bindSlice(Uri uri) { Slice bindSlice(Uri uri) {
final SliceViewManager manager = SliceViewManager.getInstance(mContext); final SliceViewManager manager = SliceViewManager.getInstance(mContext);
final Slice[] returnSlice = new Slice[1]; manager.pinSlice(uri);
final CountDownLatch latch = new CountDownLatch(1); final Slice slice = manager.bindSlice(uri);
final SliceViewManager.SliceCallback callback = manager.unpinSlice(uri);
new SliceViewManager.SliceCallback() { return slice;
@Override
public void onSliceUpdated(Slice slice) {
try {
// We are just making sure the existence of the slice, so ignore
// slice loading state here.
returnSlice[0] = slice;
latch.countDown();
} catch (Exception e) {
Log.w(TAG, uri + " cannot be indexed", e);
} finally {
manager.unregisterSliceCallback(uri, this);
}
}
};
// Register a callback until we get a loaded slice.
manager.registerSliceCallback(uri, callback);
// Trigger the binding.
callback.onSliceUpdated(manager.bindSlice(uri));
try {
latch.await(LATCH_TIMEOUT_MS, TimeUnit.MILLISECONDS);
} catch (InterruptedException e) {
Log.w(TAG, "Error waiting for slice binding for uri" + uri, e);
manager.unregisterSliceCallback(uri, callback);
}
return returnSlice[0];
} }
@VisibleForTesting @VisibleForTesting

View File

@@ -16,6 +16,8 @@
package com.android.settings.notification.zen; package com.android.settings.notification.zen;
import static android.view.accessibility.AccessibilityEvent.TYPE_VIEW_FOCUSED;
import android.app.settings.SettingsEnums; import android.app.settings.SettingsEnums;
import android.content.Context; import android.content.Context;
import android.provider.Settings; import android.provider.Settings;
@@ -40,8 +42,9 @@ public class ZenModeButtonPreferenceController extends AbstractZenModePreference
private static final String TAG = "EnableZenModeButton"; private static final String TAG = "EnableZenModeButton";
private final FragmentManager mFragment; private final FragmentManager mFragment;
// DND can also be toggled from QS. If DND wasn't toggled by this preference, don't requestFocus // DND can also be toggled from QS. If DND wasn't toggled by this preference, don't
private boolean mButtonTriggered = false; // reroute focus.
private boolean mRefocusButton = false;
private Button mZenButtonOn; private Button mZenButtonOn;
private Button mZenButtonOff; private Button mZenButtonOff;
@@ -75,7 +78,7 @@ public class ZenModeButtonPreferenceController extends AbstractZenModePreference
mZenButtonOff = ((LayoutPreference) preference) mZenButtonOff = ((LayoutPreference) preference)
.findViewById(R.id.zen_mode_settings_turn_off_button); .findViewById(R.id.zen_mode_settings_turn_off_button);
mZenButtonOff.setOnClickListener(v -> { mZenButtonOff.setOnClickListener(v -> {
mButtonTriggered = true; mRefocusButton = true;
writeMetrics(preference, false); writeMetrics(preference, false);
mBackend.setZenMode(Settings.Global.ZEN_MODE_OFF); mBackend.setZenMode(Settings.Global.ZEN_MODE_OFF);
}); });
@@ -91,9 +94,9 @@ public class ZenModeButtonPreferenceController extends AbstractZenModePreference
case Settings.Global.ZEN_MODE_NO_INTERRUPTIONS: case Settings.Global.ZEN_MODE_NO_INTERRUPTIONS:
mZenButtonOff.setVisibility(View.VISIBLE); mZenButtonOff.setVisibility(View.VISIBLE);
mZenButtonOn.setVisibility(View.GONE); mZenButtonOn.setVisibility(View.GONE);
if (mButtonTriggered) { if (mRefocusButton) {
mButtonTriggered = false; mRefocusButton = false;
mZenButtonOff.requestFocus(); mZenButtonOff.sendAccessibilityEvent(TYPE_VIEW_FOCUSED);
} }
break; break;
case Settings.Global.ZEN_MODE_OFF: case Settings.Global.ZEN_MODE_OFF:
@@ -101,16 +104,16 @@ public class ZenModeButtonPreferenceController extends AbstractZenModePreference
mZenButtonOff.setVisibility(View.GONE); mZenButtonOff.setVisibility(View.GONE);
updateZenButtonOnClickListener(preference); updateZenButtonOnClickListener(preference);
mZenButtonOn.setVisibility(View.VISIBLE); mZenButtonOn.setVisibility(View.VISIBLE);
if (mButtonTriggered) { if (mRefocusButton) {
mButtonTriggered = false; mRefocusButton = false;
mZenButtonOn.requestFocus(); mZenButtonOn.sendAccessibilityEvent(TYPE_VIEW_FOCUSED);
} }
} }
} }
private void updateZenButtonOnClickListener(Preference preference) { private void updateZenButtonOnClickListener(Preference preference) {
mZenButtonOn.setOnClickListener(v -> { mZenButtonOn.setOnClickListener(v -> {
mButtonTriggered = true; mRefocusButton = true;
writeMetrics(preference, true); writeMetrics(preference, true);
int zenDuration = getZenDuration(); int zenDuration = getZenDuration();
switch (zenDuration) { switch (zenDuration) {

View File

@@ -124,7 +124,8 @@ public class BiometricFragment extends InstrumentedFragment {
private void cleanup() { private void cleanup() {
if (getActivity() != null) { if (getActivity() != null) {
getActivity().getSupportFragmentManager().beginTransaction().remove(this).commit(); getActivity().getSupportFragmentManager().beginTransaction().remove(this)
.commitAllowingStateLoss();
} }
} }

View File

@@ -77,9 +77,9 @@ public class EligibleCardCheckerTest {
@Test @Test
public void isCardEligibleToDisplay_invalidScheme_returnFalse() { public void isCardEligibleToDisplay_invalidScheme_returnFalse() {
final Uri sliceUri = Uri.parse("contet://com.android.settings.slices/action/flashlight"); final Uri invalidUri = Uri.parse("contet://com.android.settings.slices/action/flashlight");
assertThat(mEligibleCardChecker.isCardEligibleToDisplay(getContextualCard(sliceUri))) assertThat(mEligibleCardChecker.isCardEligibleToDisplay(getContextualCard(invalidUri)))
.isFalse(); .isFalse();
} }

View File

@@ -86,10 +86,10 @@ public class SliceContextualCardRendererTest {
@Test @Test
public void bindView_invalidScheme_sliceShouldBeNull() { public void bindView_invalidScheme_sliceShouldBeNull() {
final Uri sliceUri = Uri.parse("contet://com.android.settings.slices/action/flashlight"); final Uri invalidUri = Uri.parse("contet://com.android.settings.slices/action/flashlight");
final RecyclerView.ViewHolder viewHolder = getSliceViewHolder(); final RecyclerView.ViewHolder viewHolder = getSliceViewHolder();
mRenderer.bindView(viewHolder, buildContextualCard(sliceUri)); mRenderer.bindView(viewHolder, buildContextualCard(invalidUri));
assertThat( assertThat(
((SliceFullCardRendererHelper.SliceViewHolder) viewHolder).sliceView.getSlice()) ((SliceFullCardRendererHelper.SliceViewHolder) viewHolder).sliceView.getSlice())