Custom dark theme scheduling
allows the use to set the start and end automatic dark theme activation within a day. Test: run all settings tests Change-Id: If96fc050159724d553acb09c2da4fab1d5ff519f
This commit is contained in:
@@ -106,6 +106,8 @@
|
|||||||
<item>@string/dark_ui_auto_mode_never</item>
|
<item>@string/dark_ui_auto_mode_never</item>
|
||||||
<!-- 1: Auto -->
|
<!-- 1: Auto -->
|
||||||
<item>@string/dark_ui_auto_mode_auto</item>
|
<item>@string/dark_ui_auto_mode_auto</item>
|
||||||
|
<!-- 2: Custom -->
|
||||||
|
<item>@string/dark_ui_auto_mode_custom</item>
|
||||||
</string-array>
|
</string-array>
|
||||||
|
|
||||||
<!-- Security settings. The delay after screen is turned off until device locks.
|
<!-- Security settings. The delay after screen is turned off until device locks.
|
||||||
|
@@ -2763,7 +2763,7 @@
|
|||||||
<string name="night_display_summary_off">Off / <xliff:g name="auto_mode_summary" example="Never turn on automatically">%1$s</xliff:g></string>
|
<string name="night_display_summary_off">Off / <xliff:g name="auto_mode_summary" example="Never turn on automatically">%1$s</xliff:g></string>
|
||||||
<!-- Display settings screen, summary of night display when off and will *never* turn on automatically. [CHAR LIMIT=NONE] -->
|
<!-- Display settings screen, summary of night display when off and will *never* turn on automatically. [CHAR LIMIT=NONE] -->
|
||||||
<string name="night_display_summary_off_auto_mode_never">Will never turn on automatically</string>
|
<string name="night_display_summary_off_auto_mode_never">Will never turn on automatically</string>
|
||||||
<!-- Display settings screen, summary format of night display when off and will turn on automatically at a user defined time. [CHAR LIMIT=NONE] -->
|
<!-- Display settings screen, summary format of night display when off and will turn on automatically at a user defined time. [CHAR LIMIT=NONE] -->
|
||||||
<string name="night_display_summary_off_auto_mode_custom">Will turn on automatically at <xliff:g name="time" example="6 AM">%1$s</xliff:g></string>
|
<string name="night_display_summary_off_auto_mode_custom">Will turn on automatically at <xliff:g name="time" example="6 AM">%1$s</xliff:g></string>
|
||||||
<!-- Display settings screen, summary of night display when off and will turn on automatically at sunset. [CHAR LIMIT=NONE] -->
|
<!-- Display settings screen, summary of night display when off and will turn on automatically at sunset. [CHAR LIMIT=NONE] -->
|
||||||
<string name="night_display_summary_off_auto_mode_twilight">Will turn on automatically at sunset</string>
|
<string name="night_display_summary_off_auto_mode_twilight">Will turn on automatically at sunset</string>
|
||||||
@@ -2805,9 +2805,11 @@
|
|||||||
<string name="dark_ui_auto_mode_title">Schedule</string>
|
<string name="dark_ui_auto_mode_title">Schedule</string>
|
||||||
<!-- Dark UI screen, setting option value for Dark UI to *never* turn on/off automatically. [CHAR LIMIT=30] -->
|
<!-- Dark UI screen, setting option value for Dark UI to *never* turn on/off automatically. [CHAR LIMIT=30] -->
|
||||||
<string name="dark_ui_auto_mode_never">None</string>
|
<string name="dark_ui_auto_mode_never">None</string>
|
||||||
<!-- Dark UIscreen, setting option value for Dark UI to turn on/off automatically at sunset/sunrise. [CHAR LIMIT=32] -->
|
<!-- Dark UI screen, setting option value for Dark UI to turn on/off automatically at sunset/sunrise. [CHAR LIMIT=32] -->
|
||||||
<string name="dark_ui_auto_mode_auto">Turns on from sunset to sunrise</string>
|
<string name="dark_ui_auto_mode_auto">Turns on from sunset to sunrise</string>
|
||||||
<!-- Dark UIscreen, setting option name controlling the current activation status. [CHAR LIMIT=30] -->
|
<!-- Dark UI screen, setting option value for Dark theme to turn on/off automatically according to a user defined schedule. [CHAR LIMIT=32] -->
|
||||||
|
<string name="dark_ui_auto_mode_custom">Turns on at custom time</string>
|
||||||
|
<!-- Dark UI screen, setting option name controlling the current activation status. [CHAR LIMIT=30] -->
|
||||||
<string name="dark_ui_status_title">Status</string>
|
<string name="dark_ui_status_title">Status</string>
|
||||||
<!-- Display settings screen, summary format of Dark UI when off. [CHAR LIMIT=NONE] -->
|
<!-- Display settings screen, summary format of Dark UI when off. [CHAR LIMIT=NONE] -->
|
||||||
<string name="dark_ui_summary_off">Off / <xliff:g name="auto_mode_summary" example="Never turn on automatically">%1$s</xliff:g></string>
|
<string name="dark_ui_summary_off">Off / <xliff:g name="auto_mode_summary" example="Never turn on automatically">%1$s</xliff:g></string>
|
||||||
@@ -2815,12 +2817,20 @@
|
|||||||
<string name="dark_ui_summary_off_auto_mode_never">Will never turn on automatically</string>
|
<string name="dark_ui_summary_off_auto_mode_never">Will never turn on automatically</string>
|
||||||
<!-- Display settings screen, summary of Dark UI when off and will turn on automatically at sunset. [CHAR LIMIT=NONE] -->
|
<!-- Display settings screen, summary of Dark UI when off and will turn on automatically at sunset. [CHAR LIMIT=NONE] -->
|
||||||
<string name="dark_ui_summary_off_auto_mode_auto">Will turn on automatically at sunset</string>
|
<string name="dark_ui_summary_off_auto_mode_auto">Will turn on automatically at sunset</string>
|
||||||
|
<!-- Display settings screen, summary format of night display when off and will turn on automatically at a user defined time. [CHAR LIMIT=NONE] -->
|
||||||
|
<string name="dark_ui_summary_off_auto_mode_custom">Will turn on automatically at <xliff:g name="time" example="6 AM">%1$s</xliff:g></string>
|
||||||
<!-- Display settings screen, summary format of Dark UI when on. [CHAR LIMIT=NONE] -->
|
<!-- Display settings screen, summary format of Dark UI when on. [CHAR LIMIT=NONE] -->
|
||||||
<string name="dark_ui_summary_on">On / <xliff:g name="auto_mode_summary" example="Never turn off automatically">%1$s</xliff:g></string>
|
<string name="dark_ui_summary_on">On / <xliff:g name="auto_mode_summary" example="Never turn off automatically">%1$s</xliff:g></string>
|
||||||
<!-- Display settings screen, summary of Dark UI when on and will *never* turn off automatically. [CHAR LIMIT=NONE] -->
|
<!-- Display settings screen, summary of Dark UI when on and will *never* turn off automatically. [CHAR LIMIT=NONE] -->
|
||||||
<string name="dark_ui_summary_on_auto_mode_never">Will never turn off automatically</string>
|
<string name="dark_ui_summary_on_auto_mode_never">Will never turn off automatically</string>
|
||||||
<!-- Display settings screen, summary of Dark UI when on and will turn off automatically at sunrise. [CHAR LIMIT=NONE] -->
|
<!-- Display settings screen, summary of Dark UI when on and will turn off automatically at sunrise. [CHAR LIMIT=NONE] -->
|
||||||
<string name="dark_ui_summary_on_auto_mode_auto">Will turn off automatically at sunrise</string>
|
<string name="dark_ui_summary_on_auto_mode_auto">Will turn off automatically at sunrise</string>
|
||||||
|
<!-- Display settings screen, summary format of night display when on and will turn off automatically at a user defined time. [CHAR LIMIT=NONE] -->
|
||||||
|
<string name="dark_ui_summary_on_auto_mode_custom">Will turn off automatically at <xliff:g name="time" example="10 PM">%1$s</xliff:g></string>
|
||||||
|
<!-- Display settings screen, activation button action for custom schedule [CHAR LIMIT=40] -->
|
||||||
|
<string name="dark_ui_activation_on_custom">Turn on until <xliff:g name="time" example="6 AM">%1$s</xliff:g></string>
|
||||||
|
<!-- Display settings screen, deactivation button action for custom schedule [CHAR LIMIT=40] -->
|
||||||
|
<string name="dark_ui_activation_off_custom">Turn off until <xliff:g name="time" example="10 PM">%1$s</xliff:g></string>
|
||||||
<!-- Dark theme screen, description of Dark theme feature. [CHAR LIMIT=NONE] -->
|
<!-- Dark theme screen, description of Dark theme feature. [CHAR LIMIT=NONE] -->
|
||||||
<string name="dark_ui_text">Dark theme uses a black background to help keep battery alive longer on some screens. Dark theme schedules wait to turn on until your screen is off.</string>
|
<string name="dark_ui_text">Dark theme uses a black background to help keep battery alive longer on some screens. Dark theme schedules wait to turn on until your screen is off.</string>
|
||||||
|
|
||||||
|
@@ -30,6 +30,16 @@
|
|||||||
settings:controller="com.android.settings.display.darkmode.DarkModeScheduleSelectorController"
|
settings:controller="com.android.settings.display.darkmode.DarkModeScheduleSelectorController"
|
||||||
settings:keywords="@string/keywords_dark_ui_mode"/>
|
settings:keywords="@string/keywords_dark_ui_mode"/>
|
||||||
|
|
||||||
|
<Preference
|
||||||
|
android:key="dark_theme_start_time"
|
||||||
|
android:title="@string/night_display_start_time_title"
|
||||||
|
settings:searchable="false"/>
|
||||||
|
|
||||||
|
<Preference
|
||||||
|
android:key="dark_theme_end_time"
|
||||||
|
android:title="@string/night_display_end_time_title"
|
||||||
|
settings:searchable="false"/>
|
||||||
|
|
||||||
<com.android.settingslib.widget.LayoutPreference
|
<com.android.settingslib.widget.LayoutPreference
|
||||||
android:key="dark_ui_activated"
|
android:key="dark_ui_activated"
|
||||||
android:title="@string/dark_ui_title"
|
android:title="@string/dark_ui_title"
|
||||||
|
@@ -1,8 +1,9 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (C) 2019 The Android Open Source Project
|
* Copyright (C) 2019 The Android Open Source Project
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* except in compliance with the License. You may obtain a copy of the License at
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
*
|
*
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
*
|
*
|
||||||
@@ -26,6 +27,8 @@ import com.android.settings.R;
|
|||||||
import com.android.settings.core.BasePreferenceController;
|
import com.android.settings.core.BasePreferenceController;
|
||||||
import com.android.settingslib.widget.LayoutPreference;
|
import com.android.settingslib.widget.LayoutPreference;
|
||||||
|
|
||||||
|
import java.time.LocalTime;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Controller for activate/deactivate night mode button
|
* Controller for activate/deactivate night mode button
|
||||||
*/
|
*/
|
||||||
@@ -34,12 +37,20 @@ public class DarkModeActivationPreferenceController extends BasePreferenceContro
|
|||||||
private PowerManager mPowerManager;
|
private PowerManager mPowerManager;
|
||||||
private Button mTurnOffButton;
|
private Button mTurnOffButton;
|
||||||
private Button mTurnOnButton;
|
private Button mTurnOnButton;
|
||||||
|
private TimeFormatter mFormat;
|
||||||
|
|
||||||
public DarkModeActivationPreferenceController(Context context,
|
public DarkModeActivationPreferenceController(Context context,
|
||||||
String preferenceKey) {
|
String preferenceKey) {
|
||||||
super(context, preferenceKey);
|
super(context, preferenceKey);
|
||||||
mPowerManager = context.getSystemService(PowerManager.class);
|
mPowerManager = context.getSystemService(PowerManager.class);
|
||||||
mUiModeManager = context.getSystemService(UiModeManager.class);
|
mUiModeManager = context.getSystemService(UiModeManager.class);
|
||||||
|
mFormat = new TimeFormatter(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
public DarkModeActivationPreferenceController(Context context,
|
||||||
|
String preferenceKey, TimeFormatter f) {
|
||||||
|
this(context, preferenceKey);
|
||||||
|
mFormat = f;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -58,13 +69,21 @@ public class DarkModeActivationPreferenceController extends BasePreferenceContro
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void updateNightMode(boolean active) {
|
private void updateNightMode(boolean active) {
|
||||||
final int autoMode = mUiModeManager.getNightMode();
|
final int mode = mUiModeManager.getNightMode();
|
||||||
String buttonText;
|
String buttonText;
|
||||||
|
|
||||||
if (autoMode == UiModeManager.MODE_NIGHT_AUTO) {
|
if (mode == UiModeManager.MODE_NIGHT_AUTO) {
|
||||||
buttonText = mContext.getString(active
|
buttonText = mContext.getString(active
|
||||||
? R.string.dark_ui_activation_off_auto
|
? R.string.dark_ui_activation_off_auto
|
||||||
: R.string.dark_ui_activation_on_auto);
|
: R.string.dark_ui_activation_on_auto);
|
||||||
|
} else if (mode == UiModeManager.MODE_NIGHT_CUSTOM) {
|
||||||
|
final LocalTime time = active
|
||||||
|
? mUiModeManager.getCustomNightModeStart()
|
||||||
|
: mUiModeManager.getCustomNightModeEnd();
|
||||||
|
final String timeStr = mFormat.of(time);
|
||||||
|
buttonText = mContext.getString(active
|
||||||
|
? R.string.dark_ui_activation_off_custom
|
||||||
|
: R.string.dark_ui_activation_on_custom, timeStr);
|
||||||
} else {
|
} else {
|
||||||
buttonText = mContext.getString(active
|
buttonText = mContext.getString(active
|
||||||
? R.string.dark_ui_activation_off_manual
|
? R.string.dark_ui_activation_off_manual
|
||||||
@@ -85,11 +104,20 @@ public class DarkModeActivationPreferenceController extends BasePreferenceContro
|
|||||||
public CharSequence getSummary() {
|
public CharSequence getSummary() {
|
||||||
final boolean isActivated = (mContext.getResources().getConfiguration().uiMode
|
final boolean isActivated = (mContext.getResources().getConfiguration().uiMode
|
||||||
& Configuration.UI_MODE_NIGHT_YES) != 0;
|
& Configuration.UI_MODE_NIGHT_YES) != 0;
|
||||||
final int autoMode = mUiModeManager.getNightMode();
|
final int mode = mUiModeManager.getNightMode();
|
||||||
if (autoMode == UiModeManager.MODE_NIGHT_AUTO) {
|
if (mode == UiModeManager.MODE_NIGHT_AUTO) {
|
||||||
return mContext.getString(isActivated
|
return mContext.getString(isActivated
|
||||||
? R.string.dark_ui_summary_on_auto_mode_auto
|
? R.string.dark_ui_summary_on_auto_mode_auto
|
||||||
: R.string.dark_ui_summary_off_auto_mode_auto);
|
: R.string.dark_ui_summary_off_auto_mode_auto);
|
||||||
|
} else if (mode == UiModeManager.MODE_NIGHT_CUSTOM) {
|
||||||
|
final LocalTime time = isActivated
|
||||||
|
? mUiModeManager.getCustomNightModeEnd()
|
||||||
|
: mUiModeManager.getCustomNightModeStart();
|
||||||
|
final String timeStr = mFormat.of(time);
|
||||||
|
|
||||||
|
return mContext.getString(isActivated
|
||||||
|
? R.string.dark_ui_summary_on_auto_mode_custom
|
||||||
|
: R.string.dark_ui_summary_off_auto_mode_custom, timeStr);
|
||||||
} else {
|
} else {
|
||||||
return mContext.getString(isActivated
|
return mContext.getString(isActivated
|
||||||
? R.string.dark_ui_summary_on_auto_mode_never
|
? R.string.dark_ui_summary_on_auto_mode_never
|
||||||
|
@@ -0,0 +1,105 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2020 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software distributed under the
|
||||||
|
* License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the specific language governing
|
||||||
|
* permissions and limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.android.settings.display.darkmode;
|
||||||
|
|
||||||
|
import android.app.Dialog;
|
||||||
|
import android.app.TimePickerDialog;
|
||||||
|
import android.app.UiModeManager;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.text.TextUtils;
|
||||||
|
import androidx.preference.Preference;
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
import com.android.settings.core.BasePreferenceController;
|
||||||
|
import com.android.settings.dashboard.DashboardFragment;
|
||||||
|
|
||||||
|
import java.time.LocalTime;
|
||||||
|
import java.time.format.DateTimeFormatter;
|
||||||
|
|
||||||
|
import static android.app.UiModeManager.MODE_NIGHT_CUSTOM;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Controller for custom mode night mode time settings
|
||||||
|
*/
|
||||||
|
public class DarkModeCustomPreferenceController extends BasePreferenceController {
|
||||||
|
private static final String START_TIME_KEY = "dark_theme_start_time";
|
||||||
|
private static final String END_TIME_KEY = "dark_theme_end_time";
|
||||||
|
public static DateTimeFormatter formatter = DateTimeFormatter.ofPattern("hh:mm a");
|
||||||
|
private final UiModeManager mUiModeManager;
|
||||||
|
private TimeFormatter mFormat;
|
||||||
|
private DarkModeSettingsFragment mFragmet;
|
||||||
|
|
||||||
|
public DarkModeCustomPreferenceController(Context context, String key) {
|
||||||
|
super(context, key);
|
||||||
|
mFormat = new TimeFormatter(mContext);
|
||||||
|
mUiModeManager = context.getSystemService(UiModeManager.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
public DarkModeCustomPreferenceController(
|
||||||
|
Context context, String key,
|
||||||
|
DarkModeSettingsFragment fragment) {
|
||||||
|
this(context, key);
|
||||||
|
mFragmet = fragment;
|
||||||
|
}
|
||||||
|
|
||||||
|
public DarkModeCustomPreferenceController(
|
||||||
|
Context context, String key,
|
||||||
|
DarkModeSettingsFragment fragment,
|
||||||
|
TimeFormatter format) {
|
||||||
|
this(context, key, fragment);
|
||||||
|
mFormat = format;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getAvailabilityStatus() {
|
||||||
|
return AVAILABLE;
|
||||||
|
}
|
||||||
|
|
||||||
|
public TimePickerDialog getDialog() {
|
||||||
|
final LocalTime initialTime;
|
||||||
|
if (TextUtils.equals(getPreferenceKey(), START_TIME_KEY)) {
|
||||||
|
initialTime = mUiModeManager.getCustomNightModeStart();
|
||||||
|
} else {
|
||||||
|
initialTime = mUiModeManager.getCustomNightModeEnd();
|
||||||
|
}
|
||||||
|
return new TimePickerDialog(mContext, (view, hourOfDay, minute) -> {
|
||||||
|
final LocalTime time = LocalTime.of(hourOfDay, minute);
|
||||||
|
if (TextUtils.equals(getPreferenceKey(), START_TIME_KEY)) {
|
||||||
|
mUiModeManager.setCustomNightModeStart(time);
|
||||||
|
} else {
|
||||||
|
mUiModeManager.setCustomNightModeEnd(time);
|
||||||
|
}
|
||||||
|
if (mFragmet != null) {
|
||||||
|
mFragmet.refresh();
|
||||||
|
}
|
||||||
|
}, initialTime.getHour(), initialTime.getMinute(), mFormat.is24HourFormat());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void refreshSummary(Preference preference) {
|
||||||
|
if (mUiModeManager.getNightMode() != MODE_NIGHT_CUSTOM) {
|
||||||
|
preference.setVisible(false);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
preference.setVisible(true);
|
||||||
|
final LocalTime time;
|
||||||
|
if (TextUtils.equals(getPreferenceKey(), START_TIME_KEY)) {
|
||||||
|
time = mUiModeManager.getCustomNightModeStart();
|
||||||
|
} else {
|
||||||
|
time = mUiModeManager.getCustomNightModeEnd();
|
||||||
|
}
|
||||||
|
preference.setSummary(mFormat.of(time));
|
||||||
|
}
|
||||||
|
}
|
@@ -22,6 +22,8 @@ import android.util.AttributeSet;
|
|||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.widget.MasterSwitchPreference;
|
import com.android.settings.widget.MasterSwitchPreference;
|
||||||
|
|
||||||
|
import java.time.LocalTime;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* component for the display settings dark ui summary*/
|
* component for the display settings dark ui summary*/
|
||||||
public class DarkModePreference extends MasterSwitchPreference {
|
public class DarkModePreference extends MasterSwitchPreference {
|
||||||
@@ -31,11 +33,14 @@ public class DarkModePreference extends MasterSwitchPreference {
|
|||||||
private PowerManager mPowerManager;
|
private PowerManager mPowerManager;
|
||||||
private Runnable mCallback;
|
private Runnable mCallback;
|
||||||
|
|
||||||
|
private TimeFormatter mFormat;
|
||||||
|
|
||||||
public DarkModePreference(Context context, AttributeSet attrs) {
|
public DarkModePreference(Context context, AttributeSet attrs) {
|
||||||
super(context, attrs);
|
super(context, attrs);
|
||||||
mDarkModeObserver = new DarkModeObserver(context);
|
mDarkModeObserver = new DarkModeObserver(context);
|
||||||
mUiModeManager = context.getSystemService(UiModeManager.class);
|
mUiModeManager = context.getSystemService(UiModeManager.class);
|
||||||
mPowerManager = context.getSystemService(PowerManager.class);
|
mPowerManager = context.getSystemService(PowerManager.class);
|
||||||
|
mFormat = new TimeFormatter(context);
|
||||||
mCallback = () -> {
|
mCallback = () -> {
|
||||||
final boolean batterySaver = mPowerManager.isPowerSaveMode();
|
final boolean batterySaver = mPowerManager.isPowerSaveMode();
|
||||||
final boolean active = (getContext().getResources().getConfiguration().uiMode
|
final boolean active = (getContext().getResources().getConfiguration().uiMode
|
||||||
@@ -60,21 +65,30 @@ public class DarkModePreference extends MasterSwitchPreference {
|
|||||||
|
|
||||||
private void updateSummary(boolean batterySaver, boolean active) {
|
private void updateSummary(boolean batterySaver, boolean active) {
|
||||||
if (batterySaver) {
|
if (batterySaver) {
|
||||||
final int stringId = active ? R.string.dark_ui_mode_disabled_summary_dark_theme_on
|
final int stringId = active
|
||||||
|
? R.string.dark_ui_mode_disabled_summary_dark_theme_on
|
||||||
: R.string.dark_ui_mode_disabled_summary_dark_theme_off;
|
: R.string.dark_ui_mode_disabled_summary_dark_theme_off;
|
||||||
setSummary(getContext().getString(stringId));
|
setSummary(getContext().getString(stringId));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
final boolean auto = mUiModeManager.getNightMode() == UiModeManager.MODE_NIGHT_AUTO;
|
final int mode = mUiModeManager.getNightMode();
|
||||||
|
|
||||||
String detail;
|
String detail;
|
||||||
if (active) {
|
|
||||||
detail = getContext().getString(auto
|
if (mode == UiModeManager.MODE_NIGHT_AUTO) {
|
||||||
|
detail = getContext().getString(active
|
||||||
? R.string.dark_ui_summary_on_auto_mode_auto
|
? R.string.dark_ui_summary_on_auto_mode_auto
|
||||||
: R.string.dark_ui_summary_on_auto_mode_never);
|
: R.string.dark_ui_summary_off_auto_mode_auto);
|
||||||
|
} else if (mode == UiModeManager.MODE_NIGHT_CUSTOM) {
|
||||||
|
final LocalTime time = active
|
||||||
|
? mUiModeManager.getCustomNightModeEnd()
|
||||||
|
: mUiModeManager.getCustomNightModeStart();
|
||||||
|
final String timeStr = mFormat.of(time);
|
||||||
|
detail = getContext().getString(active
|
||||||
|
? R.string.dark_ui_summary_on_auto_mode_custom
|
||||||
|
: R.string.dark_ui_summary_off_auto_mode_custom, timeStr);
|
||||||
} else {
|
} else {
|
||||||
detail = getContext().getString(auto
|
detail = getContext().getString(active
|
||||||
? R.string.dark_ui_summary_off_auto_mode_auto
|
? R.string.dark_ui_summary_on_auto_mode_never
|
||||||
: R.string.dark_ui_summary_off_auto_mode_never);
|
: R.string.dark_ui_summary_off_auto_mode_never);
|
||||||
}
|
}
|
||||||
String summary = getContext().getString(active
|
String summary = getContext().getString(active
|
||||||
|
@@ -63,8 +63,17 @@ public class DarkModeScheduleSelectorController extends BasePreferenceController
|
|||||||
}
|
}
|
||||||
|
|
||||||
private int getCurrentMode() {
|
private int getCurrentMode() {
|
||||||
final int resId = mUiModeManager.getNightMode() == UiModeManager.MODE_NIGHT_AUTO
|
int resId;
|
||||||
? R.string.dark_ui_auto_mode_auto : R.string.dark_ui_auto_mode_never;
|
switch (mUiModeManager.getNightMode()) {
|
||||||
|
case UiModeManager.MODE_NIGHT_AUTO:
|
||||||
|
resId = R.string.dark_ui_auto_mode_auto;
|
||||||
|
break;
|
||||||
|
case UiModeManager.MODE_NIGHT_CUSTOM:
|
||||||
|
resId = R.string.dark_ui_auto_mode_custom;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
resId = R.string.dark_ui_auto_mode_never;
|
||||||
|
}
|
||||||
return mPreference.findIndexOfValue(mContext.getString(resId));
|
return mPreference.findIndexOfValue(mContext.getString(resId));
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -85,6 +94,9 @@ public class DarkModeScheduleSelectorController extends BasePreferenceController
|
|||||||
} else if (mCurrentMode == mPreference.findIndexOfValue(
|
} else if (mCurrentMode == mPreference.findIndexOfValue(
|
||||||
mContext.getString(R.string.dark_ui_auto_mode_auto))) {
|
mContext.getString(R.string.dark_ui_auto_mode_auto))) {
|
||||||
mUiModeManager.setNightMode(UiModeManager.MODE_NIGHT_AUTO);
|
mUiModeManager.setNightMode(UiModeManager.MODE_NIGHT_AUTO);
|
||||||
|
} else if (mCurrentMode == mPreference.findIndexOfValue(
|
||||||
|
mContext.getString(R.string.dark_ui_auto_mode_custom))) {
|
||||||
|
mUiModeManager.setNightMode(UiModeManager.MODE_NIGHT_CUSTOM);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@@ -14,14 +14,23 @@
|
|||||||
|
|
||||||
package com.android.settings.display.darkmode;
|
package com.android.settings.display.darkmode;
|
||||||
|
|
||||||
|
import android.app.Dialog;
|
||||||
|
import android.app.TimePickerDialog;
|
||||||
|
import android.app.UiModeManager;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.app.settings.SettingsEnums;
|
import android.app.settings.SettingsEnums;
|
||||||
|
import androidx.preference.Preference;
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.dashboard.DashboardFragment;
|
import com.android.settings.dashboard.DashboardFragment;
|
||||||
import com.android.settings.search.BaseSearchIndexProvider;
|
import com.android.settings.search.BaseSearchIndexProvider;
|
||||||
|
import com.android.settingslib.core.AbstractPreferenceController;
|
||||||
import com.android.settingslib.search.SearchIndexable;
|
import com.android.settingslib.search.SearchIndexable;
|
||||||
|
|
||||||
|
import java.time.LocalTime;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Settings screen for Dark UI Mode
|
* Settings screen for Dark UI Mode
|
||||||
*/
|
*/
|
||||||
@@ -29,15 +38,20 @@ import com.android.settingslib.search.SearchIndexable;
|
|||||||
public class DarkModeSettingsFragment extends DashboardFragment {
|
public class DarkModeSettingsFragment extends DashboardFragment {
|
||||||
|
|
||||||
private static final String TAG = "DarkModeSettingsFragment";
|
private static final String TAG = "DarkModeSettingsFragment";
|
||||||
|
private static final String DARK_THEME_END_TIME = "dark_theme_end_time";
|
||||||
|
private static final String DARK_THEME_START_TIME = "dark_theme_start_time";
|
||||||
private DarkModeObserver mContentObserver;
|
private DarkModeObserver mContentObserver;
|
||||||
|
private DarkModeCustomPreferenceController mCustomStartController;
|
||||||
|
private DarkModeCustomPreferenceController mCustomEndController;
|
||||||
private Runnable mCallback = () -> {
|
private Runnable mCallback = () -> {
|
||||||
updatePreferenceStates();
|
updatePreferenceStates();
|
||||||
};
|
};
|
||||||
|
private static final int DIALOG_START_TIME = 0;
|
||||||
|
private static final int DIALOG_END_TIME = 1;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCreate(Bundle savedInstanceState) {
|
public void onCreate(Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
|
|
||||||
final Context context = getContext();
|
final Context context = getContext();
|
||||||
mContentObserver = new DarkModeObserver(context);
|
mContentObserver = new DarkModeObserver(context);
|
||||||
}
|
}
|
||||||
@@ -49,6 +63,18 @@ public class DarkModeSettingsFragment extends DashboardFragment {
|
|||||||
mContentObserver.subscribe(mCallback);
|
mContentObserver.subscribe(mCallback);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected List<AbstractPreferenceController> createPreferenceControllers(Context context) {
|
||||||
|
List<AbstractPreferenceController> controllers = new ArrayList(2);
|
||||||
|
mCustomStartController = new DarkModeCustomPreferenceController(getContext(),
|
||||||
|
DARK_THEME_START_TIME, this);
|
||||||
|
mCustomEndController = new DarkModeCustomPreferenceController(getContext(),
|
||||||
|
DARK_THEME_END_TIME, this);
|
||||||
|
controllers.add(mCustomStartController);
|
||||||
|
controllers.add(mCustomEndController);
|
||||||
|
return controllers;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onStop() {
|
public void onStop() {
|
||||||
super.onStop();
|
super.onStop();
|
||||||
@@ -56,6 +82,34 @@ public class DarkModeSettingsFragment extends DashboardFragment {
|
|||||||
mContentObserver.unsubscribe();
|
mContentObserver.unsubscribe();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onPreferenceTreeClick(Preference preference) {
|
||||||
|
if (DARK_THEME_END_TIME.equals(preference.getKey())) {
|
||||||
|
showDialog(DIALOG_END_TIME);
|
||||||
|
return true;
|
||||||
|
} else if (DARK_THEME_START_TIME.equals(preference.getKey())) {
|
||||||
|
showDialog(DIALOG_START_TIME);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return super.onPreferenceTreeClick(preference);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void refresh() {
|
||||||
|
this.updatePreferenceStates();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Dialog onCreateDialog(final int dialogId) {
|
||||||
|
if (dialogId == DIALOG_START_TIME || dialogId == DIALOG_END_TIME) {
|
||||||
|
if (dialogId == DIALOG_START_TIME) {
|
||||||
|
return mCustomStartController.getDialog();
|
||||||
|
} else {
|
||||||
|
return mCustomEndController.getDialog();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return super.onCreateDialog(dialogId);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected int getPreferenceScreenResId() {
|
protected int getPreferenceScreenResId() {
|
||||||
return R.xml.dark_mode_settings;
|
return R.xml.dark_mode_settings;
|
||||||
@@ -76,6 +130,18 @@ public class DarkModeSettingsFragment extends DashboardFragment {
|
|||||||
return SettingsEnums.DARK_UI_SETTINGS;
|
return SettingsEnums.DARK_UI_SETTINGS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getDialogMetricsCategory(int dialogId) {
|
||||||
|
switch (dialogId) {
|
||||||
|
case DIALOG_START_TIME:
|
||||||
|
return SettingsEnums.DIALOG_DARK_THEME_SET_START_TIME;
|
||||||
|
case DIALOG_END_TIME:
|
||||||
|
return SettingsEnums.DIALOG_DARK_THEME_SET_END_TIME;
|
||||||
|
default:
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static final BaseSearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
|
public static final BaseSearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
|
||||||
new BaseSearchIndexProvider(R.xml.dark_mode_settings);
|
new BaseSearchIndexProvider(R.xml.dark_mode_settings);
|
||||||
}
|
}
|
||||||
|
40
src/com/android/settings/display/darkmode/TimeFormatter.java
Normal file
40
src/com/android/settings/display/darkmode/TimeFormatter.java
Normal file
@@ -0,0 +1,40 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2020 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software distributed under the
|
||||||
|
* License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the specific language governing
|
||||||
|
* permissions and limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.android.settings.display.darkmode;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
|
||||||
|
import java.time.LocalTime;
|
||||||
|
import java.time.format.DateTimeFormatter;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Formats LocalTime to the locale time string format
|
||||||
|
*/
|
||||||
|
public class TimeFormatter {
|
||||||
|
private final Context mContext;
|
||||||
|
public static DateTimeFormatter formatter = DateTimeFormatter.ofPattern("hh:mm a");
|
||||||
|
public TimeFormatter(Context context) {
|
||||||
|
mContext = context;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String of(LocalTime time) {
|
||||||
|
return is24HourFormat() ? time.toString() : formatter.format(time);
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean is24HourFormat() {
|
||||||
|
return android.text.format.DateFormat.is24HourFormat(mContext);
|
||||||
|
}
|
||||||
|
}
|
@@ -32,7 +32,10 @@ import org.mockito.Mock;
|
|||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
|
|
||||||
|
import java.util.Locale;
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
import static org.mockito.ArgumentMatchers.anyBoolean;
|
import static org.mockito.ArgumentMatchers.anyBoolean;
|
||||||
import static org.mockito.ArgumentMatchers.anyString;
|
import static org.mockito.ArgumentMatchers.anyString;
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
@@ -60,9 +63,12 @@ public class DarkModeActivationPreferenceControllerTest {
|
|||||||
private Button mTurnOnButton;
|
private Button mTurnOnButton;
|
||||||
@Mock
|
@Mock
|
||||||
private PowerManager mPM;
|
private PowerManager mPM;
|
||||||
|
@Mock
|
||||||
|
private TimeFormatter mFormat;
|
||||||
|
|
||||||
private Configuration configNightYes = new Configuration();
|
private Configuration mConfigNightYes = new Configuration();
|
||||||
private Configuration configNightNo = new Configuration();;
|
private Configuration mConfigNightNo = new Configuration();
|
||||||
|
private Locale mLocal = new Locale("ENG");
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
@@ -77,6 +83,7 @@ public class DarkModeActivationPreferenceControllerTest {
|
|||||||
when(mPreference.findViewById(
|
when(mPreference.findViewById(
|
||||||
eq(R.id.dark_ui_turn_off_button))).thenReturn(mTurnOffButton);
|
eq(R.id.dark_ui_turn_off_button))).thenReturn(mTurnOffButton);
|
||||||
when(mService.setNightModeActivated(anyBoolean())).thenReturn(true);
|
when(mService.setNightModeActivated(anyBoolean())).thenReturn(true);
|
||||||
|
when(mFormat.of(any())).thenReturn("10:00 AM");
|
||||||
when(mContext.getString(
|
when(mContext.getString(
|
||||||
R.string.dark_ui_activation_off_auto)).thenReturn("off_auto");
|
R.string.dark_ui_activation_off_auto)).thenReturn("off_auto");
|
||||||
when(mContext.getString(
|
when(mContext.getString(
|
||||||
@@ -93,16 +100,22 @@ public class DarkModeActivationPreferenceControllerTest {
|
|||||||
R.string.dark_ui_summary_off_auto_mode_never)).thenReturn("summary_off_manual");
|
R.string.dark_ui_summary_off_auto_mode_never)).thenReturn("summary_off_manual");
|
||||||
when(mContext.getString(
|
when(mContext.getString(
|
||||||
R.string.dark_ui_summary_on_auto_mode_never)).thenReturn("summary_on_manual");
|
R.string.dark_ui_summary_on_auto_mode_never)).thenReturn("summary_on_manual");
|
||||||
mController = new DarkModeActivationPreferenceController(mContext, mPreferenceKey);
|
when(mContext.getString(
|
||||||
|
R.string.dark_ui_summary_on_auto_mode_custom)).thenReturn("summary_on_custom");
|
||||||
|
when(mContext.getString(
|
||||||
|
R.string.dark_ui_summary_off_auto_mode_custom)).thenReturn("summary_off_custom");
|
||||||
|
mController = new DarkModeActivationPreferenceController(mContext, mPreferenceKey, mFormat);
|
||||||
mController.displayPreference(mScreen);
|
mController.displayPreference(mScreen);
|
||||||
configNightNo.uiMode = Configuration.UI_MODE_NIGHT_NO;
|
mConfigNightNo.uiMode = Configuration.UI_MODE_NIGHT_NO;
|
||||||
configNightYes.uiMode = Configuration.UI_MODE_NIGHT_YES;
|
mConfigNightYes.uiMode = Configuration.UI_MODE_NIGHT_YES;
|
||||||
|
mConfigNightNo.locale = mLocal;
|
||||||
|
mConfigNightYes.locale = mLocal;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void nightMode_toggleButton_offManual() {
|
public void nightMode_toggleButton_offManual() {
|
||||||
when(mService.getNightMode()).thenReturn(UiModeManager.MODE_NIGHT_YES);
|
when(mService.getNightMode()).thenReturn(UiModeManager.MODE_NIGHT_YES);
|
||||||
when(res.getConfiguration()).thenReturn(configNightYes);
|
when(res.getConfiguration()).thenReturn(mConfigNightYes);
|
||||||
|
|
||||||
mController.updateState(mPreference);
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
@@ -112,11 +125,37 @@ public class DarkModeActivationPreferenceControllerTest {
|
|||||||
R.string.dark_ui_activation_off_manual)));
|
R.string.dark_ui_activation_off_manual)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void nightMode_toggleButton_offCustom() {
|
||||||
|
when(mService.getNightMode()).thenReturn(UiModeManager.MODE_NIGHT_CUSTOM);
|
||||||
|
when(res.getConfiguration()).thenReturn(mConfigNightYes);
|
||||||
|
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
|
verify(mTurnOnButton).setVisibility(eq(View.GONE));
|
||||||
|
verify(mTurnOffButton).setVisibility(eq(View.VISIBLE));
|
||||||
|
verify(mTurnOffButton).setText(eq(mContext.getString(
|
||||||
|
R.string.dark_ui_activation_off_custom)));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void nightMode_toggleButton_onCustom() {
|
||||||
|
when(mService.getNightMode()).thenReturn(UiModeManager.MODE_NIGHT_CUSTOM);
|
||||||
|
when(res.getConfiguration()).thenReturn(mConfigNightYes);
|
||||||
|
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
|
verify(mTurnOnButton).setVisibility(eq(View.GONE));
|
||||||
|
verify(mTurnOffButton).setVisibility(eq(View.VISIBLE));
|
||||||
|
verify(mTurnOffButton).setText(eq(mContext.getString(
|
||||||
|
R.string.dark_ui_activation_on_custom)));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void nightMode_toggleButton_onAutoWhenModeIsYes() {
|
public void nightMode_toggleButton_onAutoWhenModeIsYes() {
|
||||||
when(mService.getNightMode()).thenReturn(UiModeManager.MODE_NIGHT_YES);
|
when(mService.getNightMode()).thenReturn(UiModeManager.MODE_NIGHT_YES);
|
||||||
when(res.getConfiguration()).thenReturn(configNightNo);
|
when(res.getConfiguration()).thenReturn(mConfigNightNo);
|
||||||
|
|
||||||
mController.updateState(mPreference);
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
@@ -129,7 +168,7 @@ public class DarkModeActivationPreferenceControllerTest {
|
|||||||
@Test
|
@Test
|
||||||
public void nightMode_toggleButton_onAutoWhenModeIsAuto() {
|
public void nightMode_toggleButton_onAutoWhenModeIsAuto() {
|
||||||
when(mService.getNightMode()).thenReturn(UiModeManager.MODE_NIGHT_AUTO);
|
when(mService.getNightMode()).thenReturn(UiModeManager.MODE_NIGHT_AUTO);
|
||||||
when(res.getConfiguration()).thenReturn(configNightNo);
|
when(res.getConfiguration()).thenReturn(mConfigNightNo);
|
||||||
|
|
||||||
mController.updateState(mPreference);
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
@@ -142,7 +181,7 @@ public class DarkModeActivationPreferenceControllerTest {
|
|||||||
@Test
|
@Test
|
||||||
public void nightModeSummary_buttonText_onManual() {
|
public void nightModeSummary_buttonText_onManual() {
|
||||||
when(mService.getNightMode()).thenReturn(UiModeManager.MODE_NIGHT_NO);
|
when(mService.getNightMode()).thenReturn(UiModeManager.MODE_NIGHT_NO);
|
||||||
when(res.getConfiguration()).thenReturn(configNightYes);
|
when(res.getConfiguration()).thenReturn(mConfigNightYes);
|
||||||
|
|
||||||
assertEquals(mController.getSummary(), mContext.getString(
|
assertEquals(mController.getSummary(), mContext.getString(
|
||||||
R.string.dark_ui_summary_on_auto_mode_never));
|
R.string.dark_ui_summary_on_auto_mode_never));
|
||||||
@@ -151,7 +190,7 @@ public class DarkModeActivationPreferenceControllerTest {
|
|||||||
@Test
|
@Test
|
||||||
public void nightModeSummary_buttonText_offAuto() {
|
public void nightModeSummary_buttonText_offAuto() {
|
||||||
when(mService.getNightMode()).thenReturn(UiModeManager.MODE_NIGHT_AUTO);
|
when(mService.getNightMode()).thenReturn(UiModeManager.MODE_NIGHT_AUTO);
|
||||||
when(res.getConfiguration()).thenReturn(configNightNo);
|
when(res.getConfiguration()).thenReturn(mConfigNightNo);
|
||||||
|
|
||||||
assertEquals(mController.getSummary(), mContext.getString(
|
assertEquals(mController.getSummary(), mContext.getString(
|
||||||
R.string.dark_ui_summary_off_auto_mode_auto));
|
R.string.dark_ui_summary_off_auto_mode_auto));
|
||||||
|
@@ -0,0 +1,91 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2020 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software distributed under the
|
||||||
|
* License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the specific language governing
|
||||||
|
* permissions and limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.android.settings.display.darkmode;
|
||||||
|
|
||||||
|
import android.app.UiModeManager;
|
||||||
|
import android.content.ContentResolver;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.res.Configuration;
|
||||||
|
import android.content.res.Resources;
|
||||||
|
import androidx.preference.Preference;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.MockitoAnnotations;
|
||||||
|
import org.robolectric.RobolectricTestRunner;
|
||||||
|
|
||||||
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
|
import static org.mockito.ArgumentMatchers.eq;
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
@RunWith(RobolectricTestRunner.class)
|
||||||
|
public class DarkModeCustomPreferenceControllerTest {
|
||||||
|
private DarkModeCustomPreferenceController mController;
|
||||||
|
@Mock
|
||||||
|
private UiModeManager mService;
|
||||||
|
@Mock
|
||||||
|
private Context mContext;
|
||||||
|
@Mock
|
||||||
|
private Preference mPreference;
|
||||||
|
@Mock
|
||||||
|
private Resources mResources;
|
||||||
|
@Mock
|
||||||
|
private ContentResolver mCR;
|
||||||
|
@Mock
|
||||||
|
private TimeFormatter mFormat;
|
||||||
|
@Mock
|
||||||
|
private DarkModeSettingsFragment mFragment;
|
||||||
|
private Configuration mConfig = new Configuration();
|
||||||
|
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
MockitoAnnotations.initMocks(this);
|
||||||
|
when(mContext.getResources()).thenReturn(mResources);
|
||||||
|
when(mResources.getConfiguration()).thenReturn(mConfig);
|
||||||
|
when(mContext.getContentResolver()).thenReturn(mCR);
|
||||||
|
mService = mock(UiModeManager.class);
|
||||||
|
when(mContext.getResources()).thenReturn(mResources);
|
||||||
|
when(mContext.getSystemService(UiModeManager.class)).thenReturn(mService);
|
||||||
|
mController = new DarkModeCustomPreferenceController(mContext, "key", mFragment, mFormat);
|
||||||
|
when(mFormat.is24HourFormat()).thenReturn(false);
|
||||||
|
when(mFormat.of(any())).thenReturn("10:00 AM");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void nightMode_customOff_hidePreference() {
|
||||||
|
when(mService.getNightMode()).thenReturn(UiModeManager.MODE_NIGHT_YES);
|
||||||
|
mController.refreshSummary(mPreference);
|
||||||
|
verify(mPreference).setVisible(eq(false));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void nightMode_customOff_showPreference() {
|
||||||
|
when(mService.getNightMode()).thenReturn(UiModeManager.MODE_NIGHT_CUSTOM);
|
||||||
|
mController.refreshSummary(mPreference);
|
||||||
|
verify(mPreference).setVisible(eq(true));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void nightMode_customOff_setSummaryNotNull() {
|
||||||
|
when(mService.getNightMode()).thenReturn(UiModeManager.MODE_NIGHT_CUSTOM);
|
||||||
|
mController.refreshSummary(mPreference);
|
||||||
|
verify(mPreference).setSummary(eq(mFormat.of(null)));
|
||||||
|
}
|
||||||
|
}
|
@@ -65,6 +65,7 @@ public class DarkModeScheduleSelectorControllerTest {
|
|||||||
when(mContext.getSystemService(PowerManager.class)).thenReturn(mPM);
|
when(mContext.getSystemService(PowerManager.class)).thenReturn(mPM);
|
||||||
when(mContext.getString(R.string.dark_ui_auto_mode_never)).thenReturn("never");
|
when(mContext.getString(R.string.dark_ui_auto_mode_never)).thenReturn("never");
|
||||||
when(mContext.getString(R.string.dark_ui_auto_mode_auto)).thenReturn("auto");
|
when(mContext.getString(R.string.dark_ui_auto_mode_auto)).thenReturn("auto");
|
||||||
|
when(mContext.getString(R.string.dark_ui_auto_mode_custom)).thenReturn("custom");
|
||||||
mPreference = spy(new DropDownPreference(mContext));
|
mPreference = spy(new DropDownPreference(mContext));
|
||||||
mPreference.setEntryValues(new CharSequence[]{
|
mPreference.setEntryValues(new CharSequence[]{
|
||||||
mContext.getString(R.string.dark_ui_auto_mode_never),
|
mContext.getString(R.string.dark_ui_auto_mode_never),
|
||||||
|
Reference in New Issue
Block a user