android/ui: updated MDM settings screen to material design

Updates #cleanup

Signed-off-by: Percy Wegmann <percy@tailscale.com>
pull/251/head
Percy Wegmann 2 months ago committed by Percy Wegmann
parent 7392c7086e
commit 8e063051b6

@ -29,6 +29,8 @@ object Lists {
inline fun <T> LazyListScope.itemsWithDividers( inline fun <T> LazyListScope.itemsWithDividers(
items: List<T>, items: List<T>,
noinline key: ((item: T) -> Any)? = null, noinline key: ((item: T) -> Any)? = null,
forceLeading: Boolean = false,
forceTrailing: Boolean = false,
crossinline contentType: (item: T) -> Any? = { _ -> null }, crossinline contentType: (item: T) -> Any? = { _ -> null },
crossinline itemContent: @Composable LazyItemScope.(item: T) -> Unit crossinline itemContent: @Composable LazyItemScope.(item: T) -> Unit
) = ) =
@ -36,8 +38,19 @@ inline fun <T> LazyListScope.itemsWithDividers(
count = items.size, count = items.size,
key = if (key != null) { index: Int -> key(items[index]) } else null, key = if (key != null) { index: Int -> key(items[index]) } else null,
contentType = { index -> contentType(items[index]) }) { contentType = { index -> contentType(items[index]) }) {
if (it > 0 && it < items.size) { if (forceLeading && it == 0 ||
forceTrailing && it == items.size - 1 ||
it > 0 && it < items.size) {
Lists.ItemDivider() Lists.ItemDivider()
} }
itemContent(items[it]) itemContent(items[it])
} }
inline fun <T> LazyListScope.itemsWithDividers(
items: Array<T>,
noinline key: ((item: T) -> Any)? = null,
forceLeading: Boolean = false,
forceTrailing: Boolean = false,
crossinline contentType: (item: T) -> Any? = { _ -> null },
crossinline itemContent: @Composable LazyItemScope.(item: T) -> Unit
) = itemsWithDividers(items.toList(), key, forceLeading, forceTrailing, contentType, itemContent)

@ -3,14 +3,10 @@
package com.tailscale.ipn.ui.view package com.tailscale.ipn.ui.view
import androidx.compose.foundation.layout.Arrangement
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.Row
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.foundation.layout.padding import androidx.compose.foundation.layout.padding
import androidx.compose.foundation.lazy.LazyColumn import androidx.compose.foundation.lazy.LazyColumn
import androidx.compose.foundation.lazy.items
import androidx.compose.material3.ExperimentalMaterial3Api import androidx.compose.material3.ExperimentalMaterial3Api
import androidx.compose.material3.ListItem
import androidx.compose.material3.MaterialTheme import androidx.compose.material3.MaterialTheme
import androidx.compose.material3.Scaffold import androidx.compose.material3.Scaffold
import androidx.compose.material3.Text import androidx.compose.material3.Text
@ -26,7 +22,7 @@ import com.tailscale.ipn.mdm.BooleanSetting
import com.tailscale.ipn.mdm.ShowHideSetting import com.tailscale.ipn.mdm.ShowHideSetting
import com.tailscale.ipn.mdm.StringArraySetting import com.tailscale.ipn.mdm.StringArraySetting
import com.tailscale.ipn.mdm.StringSetting import com.tailscale.ipn.mdm.StringSetting
import com.tailscale.ipn.ui.util.defaultPaddingModifier import com.tailscale.ipn.ui.util.itemsWithDividers
import com.tailscale.ipn.ui.viewModel.IpnViewModel import com.tailscale.ipn.ui.viewModel.IpnViewModel
@OptIn(ExperimentalMaterial3Api::class) @OptIn(ExperimentalMaterial3Api::class)
@ -36,35 +32,37 @@ fun MDMSettingsDebugView(nav: BackNavigation, model: IpnViewModel = viewModel())
-> ->
val mdmSettings = IpnViewModel.mdmSettings.collectAsState().value val mdmSettings = IpnViewModel.mdmSettings.collectAsState().value
LazyColumn(modifier = Modifier.padding(innerPadding)) { LazyColumn(modifier = Modifier.padding(innerPadding)) {
items(enumValues<BooleanSetting>()) { booleanSetting -> itemsWithDividers(enumValues<BooleanSetting>()) { booleanSetting ->
MDMSettingView( MDMSettingView(
title = booleanSetting.localizedTitle, title = booleanSetting.localizedTitle,
caption = booleanSetting.key, caption = booleanSetting.key,
valueDescription = mdmSettings.get(booleanSetting).toString()) valueDescription = mdmSettings.get(booleanSetting).toString())
} }
items(enumValues<StringSetting>()) { stringSetting -> itemsWithDividers(enumValues<StringSetting>(), forceLeading = true) { stringSetting ->
MDMSettingView( MDMSettingView(
title = stringSetting.localizedTitle, title = stringSetting.localizedTitle,
caption = stringSetting.key, caption = stringSetting.key,
valueDescription = mdmSettings.get(stringSetting).toString()) valueDescription = mdmSettings.get(stringSetting).toString())
} }
items(enumValues<ShowHideSetting>()) { showHideSetting -> itemsWithDividers(enumValues<ShowHideSetting>(), forceLeading = true) { showHideSetting ->
MDMSettingView( MDMSettingView(
title = showHideSetting.localizedTitle, title = showHideSetting.localizedTitle,
caption = showHideSetting.key, caption = showHideSetting.key,
valueDescription = mdmSettings.get(showHideSetting).toString()) valueDescription = mdmSettings.get(showHideSetting).toString())
} }
items(enumValues<AlwaysNeverUserDecidesSetting>()) { anuSetting -> itemsWithDividers(enumValues<AlwaysNeverUserDecidesSetting>(), forceLeading = true) {
anuSetting ->
MDMSettingView( MDMSettingView(
title = anuSetting.localizedTitle, title = anuSetting.localizedTitle,
caption = anuSetting.key, caption = anuSetting.key,
valueDescription = mdmSettings.get(anuSetting).toString()) valueDescription = mdmSettings.get(anuSetting).toString())
} }
items(enumValues<StringArraySetting>()) { stringArraySetting -> itemsWithDividers(enumValues<StringArraySetting>(), forceLeading = true) { stringArraySetting
->
MDMSettingView( MDMSettingView(
title = stringArraySetting.localizedTitle, title = stringArraySetting.localizedTitle,
caption = stringArraySetting.key, caption = stringArraySetting.key,
@ -76,23 +74,21 @@ fun MDMSettingsDebugView(nav: BackNavigation, model: IpnViewModel = viewModel())
@Composable @Composable
fun MDMSettingView(title: String, caption: String, valueDescription: String) { fun MDMSettingView(title: String, caption: String, valueDescription: String) {
Row( ListItem(
horizontalArrangement = Arrangement.SpaceBetween, headlineContent = { Text(title, maxLines = 3) },
modifier = defaultPaddingModifier().fillMaxWidth()) { supportingContent = {
Column { Text(
Text(title, maxLines = 3) caption,
Text( fontSize = MaterialTheme.typography.labelSmall.fontSize,
caption, color = MaterialTheme.colorScheme.tertiary,
fontSize = MaterialTheme.typography.labelSmall.fontSize, fontFamily = FontFamily.Monospace)
color = MaterialTheme.colorScheme.tertiary, },
fontFamily = FontFamily.Monospace) trailingContent = {
}
Text( Text(
valueDescription, valueDescription,
color = MaterialTheme.colorScheme.secondary, color = MaterialTheme.colorScheme.secondary,
fontFamily = FontFamily.Monospace, fontFamily = FontFamily.Monospace,
maxLines = 1, maxLines = 1,
fontWeight = FontWeight.SemiBold) fontWeight = FontWeight.SemiBold)
} })
} }

Loading…
Cancel
Save