1 /*
2  * Copyright (C) 2024 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 package com.android.systemui.qs.panels.domain.interactor
18 
19 import com.android.systemui.dagger.SysUISingleton
20 import com.android.systemui.dagger.qualifiers.Application
21 import com.android.systemui.log.LogBuffer
22 import com.android.systemui.log.core.LogLevel
23 import com.android.systemui.qs.panels.shared.model.IconLabelVisibilityLog
24 import javax.inject.Inject
25 import kotlinx.coroutines.CoroutineScope
26 import kotlinx.coroutines.flow.SharingStarted
27 import kotlinx.coroutines.flow.StateFlow
28 import kotlinx.coroutines.flow.onEach
29 import kotlinx.coroutines.flow.stateIn
30 
31 @SysUISingleton
32 class IconLabelVisibilityInteractor
33 @Inject
34 constructor(
35     private val preferencesInteractor: QSPreferencesInteractor,
36     @IconLabelVisibilityLog private val logBuffer: LogBuffer,
37     @Application scope: CoroutineScope,
38 ) {
39     val showLabels: StateFlow<Boolean> =
40         preferencesInteractor.showLabels
<lambda>null41             .onEach { logChange(it) }
42             .stateIn(scope, SharingStarted.WhileSubscribed(), false)
43 
setShowLabelsnull44     fun setShowLabels(showLabels: Boolean) {
45         preferencesInteractor.setShowLabels(showLabels)
46     }
47 
logChangenull48     private fun logChange(showLabels: Boolean) {
49         logBuffer.log(
50             LOG_BUFFER_ICON_TILE_LABEL_VISIBILITY_CHANGE_TAG,
51             LogLevel.DEBUG,
52             { bool1 = showLabels },
53             { "Icon tile label visibility changed: $bool1" }
54         )
55     }
56 
57     private companion object {
58         const val LOG_BUFFER_ICON_TILE_LABEL_VISIBILITY_CHANGE_TAG = "IconLabelVisibilityChange"
59     }
60 }
61