Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit cdbd992d authored by Treehugger Robot's avatar Treehugger Robot Committed by Android (Google) Code Review
Browse files

Merge "Listen for screen power changes in ClockEventController" into main

parents 84f11774 b1309841
Loading
Loading
Loading
Loading
+20 −5
Original line number Diff line number Diff line
@@ -61,6 +61,8 @@ import com.android.systemui.plugins.clocks.ClockTickRate
import com.android.systemui.plugins.clocks.WeatherData
import com.android.systemui.plugins.clocks.ZenData
import com.android.systemui.plugins.clocks.ZenData.ZenMode
import com.android.systemui.power.domain.interactor.PowerInteractor
import com.android.systemui.power.shared.model.ScreenPowerState
import com.android.systemui.res.R as SysuiR
import com.android.systemui.scene.shared.flag.SceneContainerFlag
import com.android.systemui.settings.UserTracker
@@ -106,6 +108,7 @@ constructor(
    private val zenModeController: ZenModeController,
    private val zenModeInteractor: ZenModeInteractor,
    private val userTracker: UserTracker,
    private val powerInteractor: PowerInteractor,
) {
    var loggers =
        listOf(
@@ -377,12 +380,12 @@ constructor(
            override fun onTimeChanged() {
                refreshTime()
            }
        }

    private fun refreshTime() {
        clock?.smallClock?.events?.onTimeTick()
        clock?.largeClock?.events?.onTimeTick()
    }
        }

    @VisibleForTesting
    internal fun listenForDnd(scope: CoroutineScope): Job {
@@ -474,6 +477,7 @@ constructor(
                    listenForAnyStateToAodTransition(this)
                    listenForAnyStateToLockscreenTransition(this)
                    listenForAnyStateToDozingTransition(this)
                    listenForScreenPowerOn(this)
                }
            }
        smallTimeListener?.update(shouldTimeListenerRun)
@@ -643,6 +647,17 @@ constructor(
        }
    }

    @VisibleForTesting
    internal fun listenForScreenPowerOn(scope: CoroutineScope): Job {
        return scope.launch {
            powerInteractor.screenPowerState.collect { powerState ->
                if (powerState != ScreenPowerState.SCREEN_OFF) {
                    refreshTime()
                }
            }
        }
    }

    class TimeListener(val clockFace: ClockFaceController, val executor: DelayableExecutor) {
        val predrawListener =
            ViewTreeObserver.OnPreDrawListener {
+3 −0
Original line number Diff line number Diff line
@@ -55,6 +55,7 @@ import com.android.systemui.plugins.clocks.ClockTickRate
import com.android.systemui.plugins.clocks.ThemeConfig
import com.android.systemui.plugins.clocks.ZenData
import com.android.systemui.plugins.clocks.ZenData.ZenMode
import com.android.systemui.power.domain.interactor.PowerInteractor
import com.android.systemui.res.R
import com.android.systemui.settings.UserTracker
import com.android.systemui.statusbar.policy.BatteryController
@@ -131,6 +132,7 @@ class ClockEventControllerTest : SysuiTestCase() {
    @Mock private lateinit var parentView: View
    @Mock private lateinit var keyguardTransitionInteractor: KeyguardTransitionInteractor
    @Mock private lateinit var userTracker: UserTracker
    @Mock private lateinit var powerInteractor: PowerInteractor

    @Mock private lateinit var zenModeController: ZenModeController
    private var zenModeControllerCallback: ZenModeController.Callback? = null
@@ -178,6 +180,7 @@ class ClockEventControllerTest : SysuiTestCase() {
                zenModeController,
                zenModeInteractor,
                userTracker,
                powerInteractor,
            )
        underTest.clock = clock