Merge "Use MobileDataEnabledFlow in BillingCyclePreference" into main

This commit is contained in:
Chaohui Wang
2023-11-10 10:15:30 +00:00
committed by Android (Google) Code Review
6 changed files with 81 additions and 49 deletions

View File

@@ -16,15 +16,21 @@ package com.android.settings.datausage
import android.app.settings.SettingsEnums
import android.content.Context
import android.content.Intent
import android.net.NetworkTemplate
import android.os.Bundle
import android.util.AttributeSet
import androidx.preference.Preference
import androidx.compose.runtime.getValue
import androidx.compose.runtime.remember
import androidx.compose.ui.res.stringResource
import androidx.lifecycle.compose.collectAsStateWithLifecycle
import com.android.settings.R
import com.android.settings.core.SubSettingLauncher
import com.android.settings.datausage.lib.BillingCycleRepository
import com.android.settings.network.MobileDataEnabledListener
import com.android.settings.network.mobileDataEnabledFlow
import com.android.settings.spa.preference.ComposePreference
import com.android.settingslib.spa.widget.preference.Preference
import com.android.settingslib.spa.widget.preference.PreferenceModel
import kotlinx.coroutines.flow.map
/**
* Preference which displays billing cycle of subscription
@@ -36,45 +42,31 @@ class BillingCyclePreference @JvmOverloads constructor(
context: Context,
attrs: AttributeSet?,
private val repository: BillingCycleRepository = BillingCycleRepository(context),
) : Preference(context, attrs), TemplatePreference {
private lateinit var template: NetworkTemplate
private var subId = 0
private val listener = MobileDataEnabledListener(context) {
updateEnabled()
}
) : ComposePreference(context, attrs), TemplatePreference {
override fun setTemplate(template: NetworkTemplate, subId: Int) {
this.template = template
this.subId = subId
summary = null
updateEnabled()
intent = intent
setContent {
val isModifiable by remember {
context.mobileDataEnabledFlow(subId).map { repository.isModifiable(subId) }
}.collectAsStateWithLifecycle(initialValue = false)
Preference(object : PreferenceModel {
override val title = stringResource(R.string.billing_cycle)
override val enabled = { isModifiable }
override val onClick = { launchBillingCycleSettings(template) }
})
}
}
override fun onAttached() {
super.onAttached()
listener.start(subId)
}
override fun onDetached() {
listener.stop()
super.onDetached()
}
private fun updateEnabled() {
isEnabled = repository.isModifiable(subId)
}
override fun getIntent(): Intent {
private fun launchBillingCycleSettings(template: NetworkTemplate) {
val args = Bundle().apply {
putParcelable(DataUsageList.EXTRA_NETWORK_TEMPLATE, template)
}
return SubSettingLauncher(context).apply {
SubSettingLauncher(context).apply {
setDestination(BillingCycleSettings::class.java.name)
setArguments(args)
setTitleRes(R.string.billing_cycle)
setSourceMetricsCategory(SettingsEnums.PAGE_UNKNOWN)
}.toIntent()
}.launch()
}
}

View File

@@ -18,6 +18,7 @@ package com.android.settings.spa.preference
import android.content.Context
import android.util.AttributeSet
import androidx.annotation.VisibleForTesting
import androidx.compose.runtime.Composable
import androidx.compose.ui.platform.ComposeView
import androidx.compose.ui.platform.ViewCompositionStrategy
@@ -26,13 +27,23 @@ import androidx.preference.PreferenceViewHolder
import com.android.settings.R
import com.android.settingslib.spa.framework.theme.SettingsTheme
class ComposePreference @JvmOverloads constructor(
open class ComposePreference @JvmOverloads constructor(
context: Context,
attrs: AttributeSet? = null,
defStyleAttr: Int = 0,
defStyleRes: Int = 0,
) : Preference(context, attrs, defStyleAttr, defStyleRes) {
var content: @Composable () -> Unit = {}
private var content: @Composable () -> Unit = {}
fun setContent(content: @Composable () -> Unit) {
this.content = content
}
@VisibleForTesting
@Composable
fun Content() {
content()
}
init {
layoutResource = R.layout.preference_compose

View File

@@ -29,7 +29,7 @@ abstract class ComposePreferenceController(context: Context, preferenceKey: Stri
override fun displayPreference(screen: PreferenceScreen) {
super.displayPreference(screen)
preference = screen.findPreference(preferenceKey)!!
preference.content = { Content() }
preference.setContent { Content() }
}
@Composable