diff --git a/res/values/evolution_arrays.xml b/res/values/evolution_arrays.xml
index ef0a8d9e475..2ae1a16816c 100644
--- a/res/values/evolution_arrays.xml
+++ b/res/values/evolution_arrays.xml
@@ -118,4 +118,21 @@
- 600000
- 1800000
+
+
+
+ - @string/string_disabled
+ - @string/night_display_auto_mode_twilight
+ - @string/always_on_display_schedule_mixed_sunset
+ - @string/always_on_display_schedule_mixed_sunrise
+ - @string/night_display_auto_mode_custom
+
+
+
+ - 0
+ - 1
+ - 3
+ - 4
+ - 2
+
diff --git a/res/values/evolution_strings.xml b/res/values/evolution_strings.xml
index 84ea3f54cb2..664a18c1569 100644
--- a/res/values/evolution_strings.xml
+++ b/res/values/evolution_strings.xml
@@ -274,4 +274,12 @@
Calls
Alarms
steps
+
+
+ Always on display schedule
+ Disabled
+ Sunset
+ Sunrise
+ Turns on from sunset till a time
+ Turns on from a time till sunrise
diff --git a/res/xml/always_on_display_schedule.xml b/res/xml/always_on_display_schedule.xml
new file mode 100644
index 00000000000..127099f71ab
--- /dev/null
+++ b/res/xml/always_on_display_schedule.xml
@@ -0,0 +1,33 @@
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/res/xml/security_lockscreen_settings.xml b/res/xml/security_lockscreen_settings.xml
index 6a736f2a1f8..64d54e57474 100644
--- a/res/xml/security_lockscreen_settings.xml
+++ b/res/xml/security_lockscreen_settings.xml
@@ -118,6 +118,12 @@
android:summary="@string/doze_on_charge_summary"
android:defaultValue="false" />
+
+
+ updateTimeSetting(isSince, hourOfDay, minute1);
+ final TimePickerDialog dialog = new TimePickerDialog(getContext(), listener,
+ hour, minute, DateFormat.is24HourFormat(getContext()));
+ dialog.show();
+ return true;
+ }
+
+ private String[] getCustomTimeSetting() {
+ final String value = Settings.Secure.getStringForUser(getActivity().getContentResolver(),
+ Settings.Secure.DOZE_ALWAYS_ON_AUTO_TIME, UserHandle.USER_CURRENT);
+ if (value == null || value.isEmpty()) return new String[] { "20:00", "07:00" };
+ return value.split(",", 0);
+ }
+
+ private void updateTimeEnablement(int mode) {
+ mSincePref.setEnabled(mode == MODE_TIME || mode == MODE_MIXED_SUNRISE);
+ mTillPref.setEnabled(mode == MODE_TIME || mode == MODE_MIXED_SUNSET);
+ }
+
+ private void updateTimeSummary(int mode) {
+ updateTimeSummary(getCustomTimeSetting(), mode);
+ }
+
+ private void updateTimeSummary(String[] times, int mode) {
+ if (mode == MODE_DISABLED) {
+ mSincePref.setSummary("-");
+ mTillPref.setSummary("-");
+ return;
+ }
+
+ if (mode == MODE_NIGHT) {
+ mSincePref.setSummary(R.string.always_on_display_schedule_sunset);
+ mTillPref.setSummary(R.string.always_on_display_schedule_sunrise);
+ return;
+ }
+
+ final String outputFormat = DateFormat.is24HourFormat(getContext()) ? "HH:mm" : "hh:mm a";
+ final DateTimeFormatter outputFormatter = DateTimeFormatter.ofPattern(outputFormat);
+ final DateTimeFormatter formatter = DateTimeFormatter.ofPattern("HH:mm");
+ final LocalTime sinceDT = LocalTime.parse(times[0], formatter);
+ final LocalTime tillDT = LocalTime.parse(times[1], formatter);
+
+ if (mode == MODE_MIXED_SUNSET) {
+ mSincePref.setSummary(R.string.always_on_display_schedule_sunset);
+ mTillPref.setSummary(tillDT.format(outputFormatter));
+ } else if (mode == MODE_MIXED_SUNRISE) {
+ mTillPref.setSummary(R.string.always_on_display_schedule_sunrise);
+ mSincePref.setSummary(sinceDT.format(outputFormatter));
+ } else {
+ mSincePref.setSummary(sinceDT.format(outputFormatter));
+ mTillPref.setSummary(tillDT.format(outputFormatter));
+ }
+ }
+
+ private void updateTimeSetting(boolean since, int hour, int minute) {
+ final String[] times = getCustomTimeSetting();
+ String nHour = "";
+ String nMinute = "";
+ if (hour < 10) nHour += "0";
+ if (minute < 10) nMinute += "0";
+ nHour += String.valueOf(hour);
+ nMinute += String.valueOf(minute);
+ times[since ? 0 : 1] = nHour + ":" + nMinute;
+ Settings.Secure.putStringForUser(getActivity().getContentResolver(),
+ Settings.Secure.DOZE_ALWAYS_ON_AUTO_TIME,
+ times[0] + "," + times[1], UserHandle.USER_CURRENT);
+ updateTimeSummary(times, Integer.parseInt(mModePref.getValue()));
+ }
+}
diff --git a/src/com/android/settings/display/AODSchedulePreferenceController.kt b/src/com/android/settings/display/AODSchedulePreferenceController.kt
new file mode 100644
index 00000000000..a1d991d0d88
--- /dev/null
+++ b/src/com/android/settings/display/AODSchedulePreferenceController.kt
@@ -0,0 +1,76 @@
+/*
+ * Copyright (C) 2021 Yet Another AOSP Project
+ * Copyright (C) 2022 FlamingoOS 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
+
+import android.content.Context
+import android.hardware.display.AmbientDisplayConfiguration
+import android.os.SystemProperties
+import android.os.UserHandle
+import android.provider.Settings
+
+import com.android.settings.R
+import com.android.settings.core.BasePreferenceController
+
+class AODSchedulePreferenceController(
+ context: Context,
+ key: String,
+) : BasePreferenceController(context, key) {
+
+ private var ambientDisplayConfig: AmbientDisplayConfiguration? = null
+
+ override fun getAvailabilityStatus() =
+ if (isAODAvailable()) AVAILABLE else UNSUPPORTED_ON_DEVICE
+
+ override fun getSummary(): CharSequence {
+ val mode = Settings.Secure.getIntForUser(mContext.contentResolver,
+ Settings.Secure.DOZE_ALWAYS_ON_AUTO_MODE, 0, UserHandle.USER_CURRENT)
+ return when (mode) {
+ MODE_NIGHT -> mContext.getString(R.string.night_display_auto_mode_twilight)
+ MODE_TIME -> mContext.getString(R.string.night_display_auto_mode_custom)
+ MODE_MIXED_SUNSET -> mContext.getString(R.string.always_on_display_schedule_mixed_sunset)
+ MODE_MIXED_SUNRISE -> mContext.getString(R.string.always_on_display_schedule_mixed_sunrise)
+ else -> mContext.getString(R.string.string_disabled)
+ }
+ }
+
+ fun setConfig(config: AmbientDisplayConfiguration): AODSchedulePreferenceController {
+ ambientDisplayConfig = config
+ return this
+ }
+
+ private fun getConfig(): AmbientDisplayConfiguration {
+ if (ambientDisplayConfig == null) {
+ ambientDisplayConfig = AmbientDisplayConfiguration(mContext)
+ }
+ return ambientDisplayConfig!!
+ }
+
+ private fun isAODAvailable(): Boolean {
+ return getConfig().alwaysOnAvailableForUser(UserHandle.myUserId()) &&
+ !SystemProperties.getBoolean(PROP_AWARE_AVAILABLE, false)
+ }
+
+ companion object {
+ const val MODE_DISABLED = 0
+ const val MODE_NIGHT = 1
+ const val MODE_TIME = 2
+ const val MODE_MIXED_SUNSET = 3
+ const val MODE_MIXED_SUNRISE = 4
+
+ private const val PROP_AWARE_AVAILABLE = "ro.vendor.aware_available"
+ }
+}
diff --git a/src/com/android/settings/security/LockscreenDashboardFragment.java b/src/com/android/settings/security/LockscreenDashboardFragment.java
index 0e547603727..a0c9d3891aa 100644
--- a/src/com/android/settings/security/LockscreenDashboardFragment.java
+++ b/src/com/android/settings/security/LockscreenDashboardFragment.java
@@ -39,6 +39,7 @@ import com.android.settings.R;
import com.android.settings.dashboard.DashboardFragment;
import com.android.settings.display.AmbientDisplayAlwaysOnPreferenceController;
import com.android.settings.display.AmbientDisplayNotificationsPreferenceController;
+import com.android.settings.display.AODSchedulePreferenceController;
import com.android.settings.gestures.DoubleTapScreenPreferenceController;
import com.android.settings.gestures.PickupGesturePreferenceController;
import com.android.settings.notification.LockScreenNotificationPreferenceController;
@@ -59,7 +60,6 @@ import org.evolution.settings.utils.DeviceUtils;
@SearchIndexable
public class LockscreenDashboardFragment extends DashboardFragment
implements OwnerInfoPreferenceController.OwnerInfoCallback {
-
private static final String TAG = "LockscreenDashboardFragment";
@VisibleForTesting
@@ -133,6 +133,7 @@ public class LockscreenDashboardFragment extends DashboardFragment
use(AmbientDisplayNotificationsPreferenceController.class).setConfig(getConfig(context));
use(DoubleTapScreenPreferenceController.class).setConfig(getConfig(context));
use(PickupGesturePreferenceController.class).setConfig(getConfig(context));
+ use(AODSchedulePreferenceController.class).setConfig(getConfig(context));
mControlsContentObserver = new ContentObserver(
new Handler(Looper.getMainLooper())) {