Merge "Disable dreams home controls button when disabled on lockscreen." into udc-dev am: 5bce93eb17
am: 2611253691
Original change: https://googleplex-android-review.googlesource.com/c/platform/packages/apps/Settings/+/23321459 Change-Id: I4ae13573dd8858c2f121bbcc859488601eae7c41 Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
@@ -17,6 +17,9 @@
|
|||||||
package com.android.settings.dream;
|
package com.android.settings.dream;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.provider.Settings;
|
||||||
|
|
||||||
|
import androidx.preference.Preference;
|
||||||
|
|
||||||
import com.android.internal.annotations.VisibleForTesting;
|
import com.android.internal.annotations.VisibleForTesting;
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
@@ -46,12 +49,21 @@ public class DreamHomeControlsPreferenceController extends TogglePreferenceContr
|
|||||||
final boolean supported =
|
final boolean supported =
|
||||||
mBackend.getSupportedComplications()
|
mBackend.getSupportedComplications()
|
||||||
.contains(DreamBackend.COMPLICATION_TYPE_HOME_CONTROLS);
|
.contains(DreamBackend.COMPLICATION_TYPE_HOME_CONTROLS);
|
||||||
return supported ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
|
||||||
|
return controlsEnabledOnLockscreen() ? (supported ? AVAILABLE : CONDITIONALLY_UNAVAILABLE)
|
||||||
|
: DISABLED_DEPENDENT_SETTING;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void updateState(Preference preference) {
|
||||||
|
super.updateState(preference);
|
||||||
|
preference.setEnabled(getAvailabilityStatus() == AVAILABLE);
|
||||||
|
refreshSummary(preference);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isChecked() {
|
public boolean isChecked() {
|
||||||
return mBackend.getEnabledComplications().contains(
|
return controlsEnabledOnLockscreen() && mBackend.getEnabledComplications().contains(
|
||||||
DreamBackend.COMPLICATION_TYPE_HOME_CONTROLS);
|
DreamBackend.COMPLICATION_TYPE_HOME_CONTROLS);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -61,6 +73,12 @@ public class DreamHomeControlsPreferenceController extends TogglePreferenceContr
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private boolean controlsEnabledOnLockscreen() {
|
||||||
|
return Settings.Secure.getInt(
|
||||||
|
mContext.getContentResolver(),
|
||||||
|
Settings.Secure.LOCKSCREEN_SHOW_CONTROLS, 0) != 0;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getSliceHighlightMenuRes() {
|
public int getSliceHighlightMenuRes() {
|
||||||
return R.string.menu_key_display;
|
return R.string.menu_key_display;
|
||||||
|
@@ -23,6 +23,7 @@ import static com.google.common.truth.Truth.assertThat;
|
|||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.provider.Settings;
|
||||||
import android.util.ArraySet;
|
import android.util.ArraySet;
|
||||||
|
|
||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
@@ -80,6 +81,7 @@ public class DreamHomeControlsPreferenceControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSetChecked_setTrue_enablesSetting() {
|
public void testSetChecked_setTrue_enablesSetting() {
|
||||||
|
setControlsEnabledOnLockscreen(true);
|
||||||
mBackend.setHomeControlsEnabled(false);
|
mBackend.setHomeControlsEnabled(false);
|
||||||
assertThat(mBackend.getEnabledComplications())
|
assertThat(mBackend.getEnabledComplications())
|
||||||
.doesNotContain(COMPLICATION_TYPE_HOME_CONTROLS);
|
.doesNotContain(COMPLICATION_TYPE_HOME_CONTROLS);
|
||||||
@@ -91,6 +93,7 @@ public class DreamHomeControlsPreferenceControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSetChecked_setFalse_disablesSetting() {
|
public void testSetChecked_setFalse_disablesSetting() {
|
||||||
|
setControlsEnabledOnLockscreen(true);
|
||||||
mBackend.setHomeControlsEnabled(true);
|
mBackend.setHomeControlsEnabled(true);
|
||||||
assertThat(mBackend.getEnabledComplications())
|
assertThat(mBackend.getEnabledComplications())
|
||||||
.contains(COMPLICATION_TYPE_HOME_CONTROLS);
|
.contains(COMPLICATION_TYPE_HOME_CONTROLS);
|
||||||
@@ -102,15 +105,33 @@ public class DreamHomeControlsPreferenceControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testIsChecked_returnsFalse() {
|
public void testIsChecked_returnsFalse() {
|
||||||
|
setControlsEnabledOnLockscreen(true);
|
||||||
mBackend.setHomeControlsEnabled(false);
|
mBackend.setHomeControlsEnabled(false);
|
||||||
assertThat(mController.isChecked()).isFalse();
|
assertThat(mController.isChecked()).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testIsChecked_returnsTrue() {
|
public void testIsChecked_returnsTrue() {
|
||||||
|
setControlsEnabledOnLockscreen(true);
|
||||||
mBackend.setHomeControlsEnabled(true);
|
mBackend.setHomeControlsEnabled(true);
|
||||||
assertThat(mBackend.getEnabledComplications())
|
assertThat(mBackend.getEnabledComplications())
|
||||||
.contains(COMPLICATION_TYPE_HOME_CONTROLS);
|
.contains(COMPLICATION_TYPE_HOME_CONTROLS);
|
||||||
assertThat(mController.isChecked()).isTrue();
|
assertThat(mController.isChecked()).isTrue();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testIsChecked_lockScreenDisabled_returnsFalse() {
|
||||||
|
setControlsEnabledOnLockscreen(false);
|
||||||
|
mBackend.setHomeControlsEnabled(true);
|
||||||
|
assertThat(mBackend.getEnabledComplications())
|
||||||
|
.doesNotContain(COMPLICATION_TYPE_HOME_CONTROLS);
|
||||||
|
assertThat(mController.isChecked()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setControlsEnabledOnLockscreen(boolean enabled) {
|
||||||
|
Settings.Secure.putInt(
|
||||||
|
mContext.getContentResolver(),
|
||||||
|
Settings.Secure.LOCKSCREEN_SHOW_CONTROLS,
|
||||||
|
enabled ? 1 : 0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user