diff options
author | Dieter Hsu <dieterhsu@google.com> | 2018-03-21 18:47:43 +0800 |
---|---|---|
committer | Dieter Hsu <dieterhsu@google.com> | 2018-03-30 13:20:56 +0800 |
commit | beb89c3545138b5b576dfaaa95b88a3dd375196f (patch) | |
tree | e9efb37616e719517e5868a2ea7a4d7d3e7c0c01 /src/com/android/settings/display/AmbientDisplayAlwaysOnPreferenceController.java | |
parent | e06a4abb5c235ebb9fb877ac0ed392a6695d2026 (diff) | |
download | packages_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.java | 58 |
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); - } } |