summaryrefslogtreecommitdiffstats
path: root/src/com/android/settings/display/AmbientDisplayAlwaysOnPreferenceController.java
diff options
context:
space:
mode:
authorDieter Hsu <dieterhsu@google.com>2018-03-21 18:47:43 +0800
committerDieter Hsu <dieterhsu@google.com>2018-03-30 13:20:56 +0800
commitbeb89c3545138b5b576dfaaa95b88a3dd375196f (patch)
treee9efb37616e719517e5868a2ea7a4d7d3e7c0c01 /src/com/android/settings/display/AmbientDisplayAlwaysOnPreferenceController.java
parente06a4abb5c235ebb9fb877ac0ed392a6695d2026 (diff)
downloadpackages_apps_Settings-beb89c3545138b5b576dfaaa95b88a3dd375196f.tar.gz
packages_apps_Settings-beb89c3545138b5b576dfaaa95b88a3dd375196f.tar.bz2
packages_apps_Settings-beb89c3545138b5b576dfaaa95b88a3dd375196f.zip
Support AOD in the Universal Settings API
Bug: 67997452 Test: make -j RunSettingsRoboTests Change-Id: I609ac74f70bf040bd9033f421b4bb7c02bf33440
Diffstat (limited to 'src/com/android/settings/display/AmbientDisplayAlwaysOnPreferenceController.java')
-rw-r--r--src/com/android/settings/display/AmbientDisplayAlwaysOnPreferenceController.java58
1 files changed, 23 insertions, 35 deletions
diff --git a/src/com/android/settings/display/AmbientDisplayAlwaysOnPreferenceController.java b/src/com/android/settings/display/AmbientDisplayAlwaysOnPreferenceController.java
index 9132daa691..e0efaacb87 100644
--- a/src/com/android/settings/display/AmbientDisplayAlwaysOnPreferenceController.java
+++ b/src/com/android/settings/display/AmbientDisplayAlwaysOnPreferenceController.java
@@ -19,59 +19,45 @@ import android.content.Context;
import android.content.Intent;
import android.os.UserHandle;
import android.provider.Settings;
-import android.support.v14.preference.SwitchPreference;
-import android.support.v7.preference.Preference;
-import android.support.annotation.VisibleForTesting;
import com.android.internal.hardware.AmbientDisplayConfiguration;
import com.android.settings.R;
-import com.android.settings.core.PreferenceControllerMixin;
+import com.android.settings.core.TogglePreferenceController;
import com.android.settings.search.DatabaseIndexingUtils;
import com.android.settings.search.InlineSwitchPayload;
import com.android.settings.search.ResultPayload;
-import com.android.settingslib.core.AbstractPreferenceController;
-public class AmbientDisplayAlwaysOnPreferenceController extends
- AbstractPreferenceController implements PreferenceControllerMixin,
- Preference.OnPreferenceChangeListener {
+public class AmbientDisplayAlwaysOnPreferenceController extends TogglePreferenceController {
private final int ON = 1;
private final int OFF = 0;
- public static final String KEY_ALWAYS_ON = "ambient_display_always_on";
private static final int MY_USER = UserHandle.myUserId();
- private final AmbientDisplayConfiguration mConfig;
- private final OnPreferenceChangedCallback mCallback;
+ private AmbientDisplayConfiguration mConfig;
+ private OnPreferenceChangedCallback mCallback;
public interface OnPreferenceChangedCallback {
void onPreferenceChanged();
}
- public AmbientDisplayAlwaysOnPreferenceController(Context context,
- AmbientDisplayConfiguration config, OnPreferenceChangedCallback callback) {
- super(context);
- mConfig = config;
- mCallback = callback;
+ public AmbientDisplayAlwaysOnPreferenceController(Context context, String key) {
+ super(context, key);
}
@Override
- public String getPreferenceKey() {
- return KEY_ALWAYS_ON;
+ public int getAvailabilityStatus() {
+ return isAvailable(mConfig) ? AVAILABLE : DISABLED_UNSUPPORTED;
}
@Override
- public void updateState(Preference preference) {
- ((SwitchPreference) preference).setChecked(isAlwaysOnEnabled(mConfig));
- }
-
- public static boolean isAlwaysOnEnabled(AmbientDisplayConfiguration config) {
- return config.alwaysOnEnabled(MY_USER);
+ public boolean isChecked() {
+ return mConfig.alwaysOnEnabled(MY_USER);
}
@Override
- public boolean onPreferenceChange(Preference preference, Object newValue) {
- int enabled = (boolean) newValue ? ON : OFF;
+ public boolean setChecked(boolean isChecked) {
+ int enabled = isChecked ? ON : OFF;
Settings.Secure.putInt(
mContext.getContentResolver(), Settings.Secure.DOZE_ALWAYS_ON, enabled);
if (mCallback != null) {
@@ -80,9 +66,16 @@ public class AmbientDisplayAlwaysOnPreferenceController extends
return true;
}
- @Override
- public boolean isAvailable() {
- return alwaysOnAvailableForUser(mConfig);
+ public void setConfig(AmbientDisplayConfiguration config) {
+ mConfig = config;
+ }
+
+ public void setCallback(OnPreferenceChangedCallback callback) {
+ mCallback = callback;
+ }
+
+ public static boolean isAlwaysOnEnabled(AmbientDisplayConfiguration config) {
+ return config.alwaysOnEnabled(MY_USER);
}
public static boolean isAvailable(AmbientDisplayConfiguration config) {
@@ -96,16 +89,11 @@ public class AmbientDisplayAlwaysOnPreferenceController extends
@Override
public ResultPayload getResultPayload() {
final Intent intent = DatabaseIndexingUtils.buildSearchResultPageIntent(mContext,
- AmbientDisplaySettings.class.getName(), KEY_ALWAYS_ON,
+ AmbientDisplaySettings.class.getName(), getPreferenceKey(),
mContext.getString(R.string.ambient_display_screen_title));
return new InlineSwitchPayload(Settings.Secure.DOZE_ALWAYS_ON,
ResultPayload.SettingsSource.SECURE, ON /* onValue */, intent, isAvailable(),
ON /* defaultValue */);
}
-
- @VisibleForTesting
- boolean alwaysOnAvailableForUser(AmbientDisplayConfiguration config) {
- return isAvailable(config);
- }
}