Support AOD in the Universal Settings API
Bug: 67997452 Test: make -j RunSettingsRoboTests Change-Id: I609ac74f70bf040bd9033f421b4bb7c02bf33440
This commit is contained in:
@@ -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);
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user