Merge pull request #684 from MaximillianLeonov/feature-settings

Replace `if` condition with AnimatedVisibility component
pull/804/head
Alex Vanyo 2 years ago committed by GitHub
commit 9cd390c56a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -17,9 +17,11 @@
package com.google.samples.apps.nowinandroid.feature.settings package com.google.samples.apps.nowinandroid.feature.settings
import android.content.Intent import android.content.Intent
import androidx.compose.animation.AnimatedVisibility
import androidx.compose.foundation.clickable import androidx.compose.foundation.clickable
import androidx.compose.foundation.layout.Arrangement import androidx.compose.foundation.layout.Arrangement
import androidx.compose.foundation.layout.Column import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.ColumnScope
import androidx.compose.foundation.layout.ExperimentalLayoutApi import androidx.compose.foundation.layout.ExperimentalLayoutApi
import androidx.compose.foundation.layout.FlowRow import androidx.compose.foundation.layout.FlowRow
import androidx.compose.foundation.layout.Row import androidx.compose.foundation.layout.Row
@ -149,8 +151,9 @@ fun SettingsDialog(
) )
} }
// [ColumnScope] is used for using the [ColumnScope.AnimatedVisibility] extension overload composable.
@Composable @Composable
private fun SettingsPanel( private fun ColumnScope.SettingsPanel(
settings: UserEditableSettings, settings: UserEditableSettings,
supportDynamicColor: Boolean, supportDynamicColor: Boolean,
onChangeThemeBrand: (themeBrand: ThemeBrand) -> Unit, onChangeThemeBrand: (themeBrand: ThemeBrand) -> Unit,
@ -170,19 +173,21 @@ private fun SettingsPanel(
onClick = { onChangeThemeBrand(ANDROID) }, onClick = { onChangeThemeBrand(ANDROID) },
) )
} }
if (settings.brand == DEFAULT && supportDynamicColor) { AnimatedVisibility(visible = settings.brand == DEFAULT && supportDynamicColor) {
SettingsDialogSectionTitle(text = stringResource(R.string.dynamic_color_preference)) Column {
Column(Modifier.selectableGroup()) { SettingsDialogSectionTitle(text = stringResource(R.string.dynamic_color_preference))
SettingsDialogThemeChooserRow( Column(Modifier.selectableGroup()) {
text = stringResource(string.dynamic_color_yes), SettingsDialogThemeChooserRow(
selected = settings.useDynamicColor, text = stringResource(string.dynamic_color_yes),
onClick = { onChangeDynamicColorPreference(true) }, selected = settings.useDynamicColor,
) onClick = { onChangeDynamicColorPreference(true) },
SettingsDialogThemeChooserRow( )
text = stringResource(string.dynamic_color_no), SettingsDialogThemeChooserRow(
selected = !settings.useDynamicColor, text = stringResource(string.dynamic_color_no),
onClick = { onChangeDynamicColorPreference(false) }, selected = !settings.useDynamicColor,
) onClick = { onChangeDynamicColorPreference(false) },
)
}
} }
} }
SettingsDialogSectionTitle(text = stringResource(R.string.dark_mode_preference)) SettingsDialogSectionTitle(text = stringResource(R.string.dark_mode_preference))

Loading…
Cancel
Save