/* * Copyright 2023 Google LLC * * 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 * * https://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 me.zhanghai.compose.preference import androidx.compose.foundation.layout.fillMaxWidth import androidx.compose.foundation.layout.padding import androidx.compose.foundation.lazy.LazyListScope import androidx.compose.foundation.selection.toggleable import androidx.compose.material3.Checkbox import androidx.compose.runtime.Composable import androidx.compose.runtime.MutableState import androidx.compose.runtime.getValue import androidx.compose.runtime.setValue import androidx.compose.ui.Modifier import androidx.compose.ui.semantics.Role public inline fun LazyListScope.checkboxPreference( key: String, defaultValue: Boolean, crossinline title: @Composable (Boolean) -> Unit, modifier: Modifier = Modifier.fillMaxWidth(), crossinline rememberState: @Composable () -> MutableState = { rememberPreferenceState(key, defaultValue) }, crossinline enabled: (Boolean) -> Boolean = { true }, noinline icon: @Composable ((Boolean) -> Unit)? = null, noinline summary: @Composable ((Boolean) -> Unit)? = null, ) { item(key = key, contentType = "CheckboxPreference") { val state = rememberState() val value by state CheckboxPreference( state = state, title = { title(value) }, modifier = modifier, enabled = enabled(value), icon = icon?.let { { it(value) } }, summary = summary?.let { { it(value) } }, ) } } @Composable public fun CheckboxPreference( state: MutableState, title: @Composable () -> Unit, modifier: Modifier = Modifier, enabled: Boolean = true, icon: @Composable (() -> Unit)? = null, summary: @Composable (() -> Unit)? = null, ) { var value by state CheckboxPreference( value = value, onValueChange = { value = it }, title = title, modifier = modifier, enabled = enabled, icon = icon, summary = summary, ) } @Composable public fun CheckboxPreference( value: Boolean, onValueChange: (Boolean) -> Unit, title: @Composable () -> Unit, modifier: Modifier = Modifier, enabled: Boolean = true, icon: @Composable (() -> Unit)? = null, summary: @Composable (() -> Unit)? = null, ) { Preference( title = title, modifier = modifier.toggleable(value, enabled, Role.Checkbox, onValueChange = onValueChange), enabled = enabled, icon = icon, summary = summary, widgetContainer = { val theme = LocalPreferenceTheme.current Checkbox( checked = value, onCheckedChange = null, modifier = Modifier.padding(theme.padding.copy(start = theme.horizontalSpacing)), enabled = enabled, ) }, ) }