Merge "Flip the preference for sticky battery saver"
This commit is contained in:
committed by
Android (Google) Code Review
commit
507b7bf4f8
@@ -5659,12 +5659,6 @@
|
|||||||
<!-- Battery saver: Title for battery saver schedule screen [CHAR_LIMIT=40] -->
|
<!-- Battery saver: Title for battery saver schedule screen [CHAR_LIMIT=40] -->
|
||||||
<string name="battery_saver_schedule_settings_title">Set a schedule</string>
|
<string name="battery_saver_schedule_settings_title">Set a schedule</string>
|
||||||
|
|
||||||
<!-- Battery Saver: Title for sticky battery saver preference [CHAR_LIMIT=60] -->
|
|
||||||
<string name="battery_saver_sticky_title">Keep battery saver on</string>
|
|
||||||
|
|
||||||
<!-- Battery Saver: Description for sticky battery saver preference [CHAR_LIMIT=NONE] -->
|
|
||||||
<string name="battery_saver_sticky_description">Battery saver will stay on even after device is fully charged</string>
|
|
||||||
|
|
||||||
<!-- Battery Saver: Title for sticky battery saver preference [CHAR_LIMIT=60] -->
|
<!-- Battery Saver: Title for sticky battery saver preference [CHAR_LIMIT=60] -->
|
||||||
<string name="battery_saver_sticky_title_new">Turn off when fully charged</string>
|
<string name="battery_saver_sticky_title_new">Turn off when fully charged</string>
|
||||||
|
|
||||||
|
@@ -28,8 +28,8 @@
|
|||||||
|
|
||||||
<SwitchPreference
|
<SwitchPreference
|
||||||
android:key="battery_saver_sticky"
|
android:key="battery_saver_sticky"
|
||||||
android:title="@string/battery_saver_sticky_title"
|
android:title="@string/battery_saver_sticky_title_new"
|
||||||
android:summary="@string/battery_saver_sticky_description"
|
android:summary="@string/summary_placeholder"
|
||||||
settings:keywords="@string/keywords_battery_saver_sticky"
|
settings:keywords="@string/keywords_battery_saver_sticky"
|
||||||
settings:controller="com.android.settings.fuelgauge.batterysaver.BatterySaverStickyPreferenceController"/>
|
settings:controller="com.android.settings.fuelgauge.batterysaver.BatterySaverStickyPreferenceController"/>
|
||||||
|
|
||||||
|
@@ -1,37 +1,58 @@
|
|||||||
package com.android.settings.fuelgauge.batterysaver;
|
package com.android.settings.fuelgauge.batterysaver;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.icu.text.NumberFormat;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
|
import android.provider.Settings.Global;
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
import androidx.preference.SwitchPreference;
|
import androidx.preference.SwitchPreference;
|
||||||
import com.android.settings.core.BasePreferenceController;
|
import com.android.settings.R;
|
||||||
import com.android.settings.core.PreferenceControllerMixin;
|
import com.android.settings.core.PreferenceControllerMixin;
|
||||||
|
import com.android.settings.core.TogglePreferenceController;
|
||||||
|
|
||||||
public class BatterySaverStickyPreferenceController extends BasePreferenceController implements
|
public class BatterySaverStickyPreferenceController extends TogglePreferenceController implements
|
||||||
PreferenceControllerMixin, Preference.OnPreferenceChangeListener {
|
PreferenceControllerMixin, Preference.OnPreferenceChangeListener {
|
||||||
|
|
||||||
public static final String LOW_POWER_STICKY_AUTO_DISABLE_ENABLED =
|
private Context mContext;
|
||||||
"low_power_sticky_auto_disable_enabled";
|
|
||||||
|
|
||||||
public BatterySaverStickyPreferenceController(Context context, String preferenceKey) {
|
public BatterySaverStickyPreferenceController(Context context, String preferenceKey) {
|
||||||
super(context, preferenceKey);
|
super(context, preferenceKey);
|
||||||
|
mContext = context;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isChecked() {
|
||||||
|
return Settings.Global.getInt(mContext.getContentResolver(),
|
||||||
|
Global.LOW_POWER_MODE_STICKY_AUTO_DISABLE_ENABLED, 1) == 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean setChecked(boolean isChecked) {
|
||||||
|
Settings.Global.putInt(mContext.getContentResolver(),
|
||||||
|
Global.LOW_POWER_MODE_STICKY_AUTO_DISABLE_ENABLED,
|
||||||
|
isChecked ? 1 : 0);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void refreshSummary(Preference preference) {
|
||||||
|
super.refreshSummary(preference);
|
||||||
|
final double stickyShutoffLevel = Settings.Global.getInt(
|
||||||
|
mContext.getContentResolver(), Global.LOW_POWER_MODE_STICKY_AUTO_DISABLE_LEVEL, 90);
|
||||||
|
final String percentage = NumberFormat
|
||||||
|
.getPercentInstance()
|
||||||
|
.format(stickyShutoffLevel / 100.0);
|
||||||
|
preference.setSummary(
|
||||||
|
mContext.getString(R.string.battery_saver_sticky_description_new, percentage));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void updateState(Preference preference) {
|
public void updateState(Preference preference) {
|
||||||
int setting = Settings.Global.getInt(mContext.getContentResolver(),
|
int setting = Settings.Global.getInt(mContext.getContentResolver(),
|
||||||
LOW_POWER_STICKY_AUTO_DISABLE_ENABLED, 1);
|
Global.LOW_POWER_MODE_STICKY_AUTO_DISABLE_ENABLED, 1);
|
||||||
|
|
||||||
((SwitchPreference) preference).setChecked(setting == 0);
|
((SwitchPreference) preference).setChecked(setting == 1);
|
||||||
}
|
refreshSummary(preference);
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
|
||||||
boolean keepActive = (Boolean) newValue;
|
|
||||||
Settings.Global.putInt(mContext.getContentResolver(),
|
|
||||||
LOW_POWER_STICKY_AUTO_DISABLE_ENABLED,
|
|
||||||
keepActive ? 0 : 1);
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@@ -16,11 +16,11 @@
|
|||||||
|
|
||||||
package com.android.settings.fuelgauge.batterysaver;
|
package com.android.settings.fuelgauge.batterysaver;
|
||||||
|
|
||||||
import static com.android.settings.fuelgauge.batterysaver.BatterySaverStickyPreferenceController.LOW_POWER_STICKY_AUTO_DISABLE_ENABLED;
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
|
import android.provider.Settings.Global;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
@@ -43,21 +43,21 @@ public class BatterySaverStickyPreferenceControllerTest {
|
|||||||
|
|
||||||
private int getAutoDisableSetting() {
|
private int getAutoDisableSetting() {
|
||||||
return Settings.Global.getInt(mContext.getContentResolver(),
|
return Settings.Global.getInt(mContext.getContentResolver(),
|
||||||
LOW_POWER_STICKY_AUTO_DISABLE_ENABLED,
|
Global.LOW_POWER_MODE_STICKY_AUTO_DISABLE_ENABLED,
|
||||||
1);
|
1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testOnPreferenceChange_turnOnKeepActive_autoDisableOff() {
|
public void testOnPreferenceChange_turnOnAutoOff_autoDisableOn() {
|
||||||
mController.onPreferenceChange(null, true);
|
mController.setChecked(true);
|
||||||
final int isOn = getAutoDisableSetting();
|
|
||||||
assertThat(isOn).isEqualTo(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testOnPreferenceChange_TurnOffKeepActive_autoDisableOff() {
|
|
||||||
mController.onPreferenceChange(null, false);
|
|
||||||
final int isOn = getAutoDisableSetting();
|
final int isOn = getAutoDisableSetting();
|
||||||
assertThat(isOn).isEqualTo(1);
|
assertThat(isOn).isEqualTo(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testOnPreferenceChange_TurnOffAutoOff_autoDisableOff() {
|
||||||
|
mController.setChecked(false);
|
||||||
|
final int isOn = getAutoDisableSetting();
|
||||||
|
assertThat(isOn).isEqualTo(0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user