Merge pull request #652 from strongville/feat/materialYouCompat
Use Material You Compat on Android 12+ if flag is enabled
This commit is contained in:
commit
f037a72379
@ -9,6 +9,7 @@ import androidx.compose.ui.platform.LocalContext
|
|||||||
import androidx.compose.ui.res.stringResource
|
import androidx.compose.ui.res.stringResource
|
||||||
import androidx.lifecycle.compose.collectAsStateWithLifecycle
|
import androidx.lifecycle.compose.collectAsStateWithLifecycle
|
||||||
import androidx.lifecycle.viewmodel.compose.viewModel
|
import androidx.lifecycle.viewmodel.compose.viewModel
|
||||||
|
import de.mm20.launcher2.ktx.isAtLeastApiLevel
|
||||||
import de.mm20.launcher2.preferences.ColorScheme
|
import de.mm20.launcher2.preferences.ColorScheme
|
||||||
import de.mm20.launcher2.preferences.Font
|
import de.mm20.launcher2.preferences.Font
|
||||||
import de.mm20.launcher2.ui.R
|
import de.mm20.launcher2.ui.R
|
||||||
@ -16,6 +17,7 @@ import de.mm20.launcher2.ui.component.preferences.ListPreference
|
|||||||
import de.mm20.launcher2.ui.component.preferences.Preference
|
import de.mm20.launcher2.ui.component.preferences.Preference
|
||||||
import de.mm20.launcher2.ui.component.preferences.PreferenceCategory
|
import de.mm20.launcher2.ui.component.preferences.PreferenceCategory
|
||||||
import de.mm20.launcher2.ui.component.preferences.PreferenceScreen
|
import de.mm20.launcher2.ui.component.preferences.PreferenceScreen
|
||||||
|
import de.mm20.launcher2.ui.component.preferences.SwitchPreference
|
||||||
import de.mm20.launcher2.ui.component.preferences.value
|
import de.mm20.launcher2.ui.component.preferences.value
|
||||||
import de.mm20.launcher2.ui.locals.LocalNavController
|
import de.mm20.launcher2.ui.locals.LocalNavController
|
||||||
import de.mm20.launcher2.ui.theme.getTypography
|
import de.mm20.launcher2.ui.theme.getTypography
|
||||||
@ -50,6 +52,17 @@ fun AppearanceSettingsScreen() {
|
|||||||
navController?.navigate("settings/appearance/themes")
|
navController?.navigate("settings/appearance/themes")
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
if (isAtLeastApiLevel(31)) {
|
||||||
|
val compatModeColors by viewModel.compatModeColors.collectAsState()
|
||||||
|
SwitchPreference(
|
||||||
|
title = stringResource(id = R.string.preference_force_compat_system_colors),
|
||||||
|
summary = stringResource(id = R.string.preference_force_compat_system_colors_summary),
|
||||||
|
value = compatModeColors,
|
||||||
|
onValueChanged = {
|
||||||
|
viewModel.setCompatModeColors(it)
|
||||||
|
}
|
||||||
|
)
|
||||||
|
}
|
||||||
val font by viewModel.font.collectAsState()
|
val font by viewModel.font.collectAsState()
|
||||||
ListPreference(
|
ListPreference(
|
||||||
title = stringResource(R.string.preference_font),
|
title = stringResource(R.string.preference_font),
|
||||||
|
|||||||
@ -33,6 +33,12 @@ class AppearanceSettingsScreenVM : ViewModel(), KoinComponent {
|
|||||||
}
|
}
|
||||||
.stateIn(viewModelScope, SharingStarted.WhileSubscribed(), null)
|
.stateIn(viewModelScope, SharingStarted.WhileSubscribed(), null)
|
||||||
|
|
||||||
|
val compatModeColors = uiSettings.compatModeColors
|
||||||
|
.stateIn(viewModelScope, SharingStarted.WhileSubscribed(), false)
|
||||||
|
|
||||||
|
fun setCompatModeColors(enabled: Boolean) {
|
||||||
|
uiSettings.setCompatModeColors(enabled)
|
||||||
|
}
|
||||||
|
|
||||||
val font = uiSettings.font
|
val font = uiSettings.font
|
||||||
.stateIn(viewModelScope, SharingStarted.WhileSubscribed(), null)
|
.stateIn(viewModelScope, SharingStarted.WhileSubscribed(), null)
|
||||||
|
|||||||
@ -3,12 +3,16 @@ package de.mm20.launcher2.ui.theme.colorscheme
|
|||||||
import android.os.Build
|
import android.os.Build
|
||||||
import androidx.compose.material3.ColorScheme
|
import androidx.compose.material3.ColorScheme
|
||||||
import androidx.compose.runtime.Composable
|
import androidx.compose.runtime.Composable
|
||||||
|
import androidx.compose.runtime.collectAsState
|
||||||
|
import androidx.compose.runtime.getValue
|
||||||
import androidx.compose.runtime.remember
|
import androidx.compose.runtime.remember
|
||||||
import androidx.compose.ui.graphics.Color
|
import androidx.compose.ui.graphics.Color
|
||||||
import androidx.compose.ui.graphics.toArgb
|
import androidx.compose.ui.graphics.toArgb
|
||||||
import androidx.compose.ui.platform.LocalContext
|
import androidx.compose.ui.platform.LocalContext
|
||||||
import androidx.core.content.ContextCompat
|
import androidx.core.content.ContextCompat
|
||||||
|
import androidx.datastore.core.DataStore
|
||||||
import de.mm20.launcher2.preferences.LegacySettings
|
import de.mm20.launcher2.preferences.LegacySettings
|
||||||
|
import de.mm20.launcher2.preferences.ui.UiSettings
|
||||||
import de.mm20.launcher2.themes.CorePalette
|
import de.mm20.launcher2.themes.CorePalette
|
||||||
import de.mm20.launcher2.themes.DefaultDarkColorScheme
|
import de.mm20.launcher2.themes.DefaultDarkColorScheme
|
||||||
import de.mm20.launcher2.themes.DefaultLightColorScheme
|
import de.mm20.launcher2.themes.DefaultLightColorScheme
|
||||||
@ -18,6 +22,9 @@ import de.mm20.launcher2.themes.Theme
|
|||||||
import de.mm20.launcher2.themes.get
|
import de.mm20.launcher2.themes.get
|
||||||
import de.mm20.launcher2.themes.merge
|
import de.mm20.launcher2.themes.merge
|
||||||
import de.mm20.launcher2.ui.locals.LocalWallpaperColors
|
import de.mm20.launcher2.ui.locals.LocalWallpaperColors
|
||||||
|
import kotlinx.coroutines.flow.map
|
||||||
|
import org.koin.androidx.compose.inject
|
||||||
|
import org.koin.core.component.inject
|
||||||
|
|
||||||
@Composable
|
@Composable
|
||||||
fun lightColorSchemeOf(theme: Theme): ColorScheme {
|
fun lightColorSchemeOf(theme: Theme): ColorScheme {
|
||||||
@ -77,8 +84,13 @@ fun colorSchemeOf(colorScheme: FullColorScheme, corePalette: PartialCorePalette)
|
|||||||
|
|
||||||
@Composable
|
@Composable
|
||||||
fun systemCorePalette(): CorePalette<Int> {
|
fun systemCorePalette(): CorePalette<Int> {
|
||||||
val context = LocalContext.current
|
val uiSettings: UiSettings by inject()
|
||||||
if (Build.VERSION.SDK_INT >= 31) {
|
val compatModeColors by remember {
|
||||||
|
uiSettings.compatModeColors
|
||||||
|
}.collectAsState(false)
|
||||||
|
|
||||||
|
if (Build.VERSION.SDK_INT >= 31 && !compatModeColors) {
|
||||||
|
val context = LocalContext.current
|
||||||
return CorePalette(
|
return CorePalette(
|
||||||
primary = ContextCompat.getColor(context, android.R.color.system_accent1_500),
|
primary = ContextCompat.getColor(context, android.R.color.system_accent1_500),
|
||||||
secondary = ContextCompat.getColor(context, android.R.color.system_accent2_500),
|
secondary = ContextCompat.getColor(context, android.R.color.system_accent2_500),
|
||||||
|
|||||||
@ -447,6 +447,8 @@
|
|||||||
<string name="preference_colors_auto_generate">Generate from primary color</string>
|
<string name="preference_colors_auto_generate">Generate from primary color</string>
|
||||||
<string name="preference_category_custom_colors_light">Light color scheme</string>
|
<string name="preference_category_custom_colors_light">Light color scheme</string>
|
||||||
<string name="preference_category_custom_colors_dark">Dark color scheme</string>
|
<string name="preference_category_custom_colors_dark">Dark color scheme</string>
|
||||||
|
<string name="preference_force_compat_system_colors">Ignore system colors</string>
|
||||||
|
<string name="preference_force_compat_system_colors_summary">Request color scheme via Material You Compat</string>
|
||||||
<string name="preference_font">Font</string>
|
<string name="preference_font">Font</string>
|
||||||
<string name="preference_font_system">System default</string>
|
<string name="preference_font_system">System default</string>
|
||||||
<string name="preference_screen_about">About</string>
|
<string name="preference_screen_about">About</string>
|
||||||
|
|||||||
@ -11,6 +11,7 @@ data class LauncherSettingsData(
|
|||||||
|
|
||||||
val uiColorScheme: ColorScheme = ColorScheme.System,
|
val uiColorScheme: ColorScheme = ColorScheme.System,
|
||||||
val uiTheme: ThemeDescriptor = ThemeDescriptor.Default,
|
val uiTheme: ThemeDescriptor = ThemeDescriptor.Default,
|
||||||
|
val uiCompatModeColors: Boolean = false,
|
||||||
val uiFont: Font = Font.Outfit,
|
val uiFont: Font = Font.Outfit,
|
||||||
val uiBaseLayout: BaseLayout = BaseLayout.PullDown,
|
val uiBaseLayout: BaseLayout = BaseLayout.PullDown,
|
||||||
val uiOrientation: ScreenOrientation = ScreenOrientation.Auto,
|
val uiOrientation: ScreenOrientation = ScreenOrientation.Auto,
|
||||||
|
|||||||
@ -144,6 +144,17 @@ class UiSettings internal constructor(
|
|||||||
it.uiColorScheme
|
it.uiColorScheme
|
||||||
}.distinctUntilChanged()
|
}.distinctUntilChanged()
|
||||||
|
|
||||||
|
val compatModeColors
|
||||||
|
get() = launcherDataStore.data.map {
|
||||||
|
it.uiCompatModeColors
|
||||||
|
}.distinctUntilChanged()
|
||||||
|
|
||||||
|
fun setCompatModeColors(enabled: Boolean) {
|
||||||
|
launcherDataStore.update {
|
||||||
|
it.copy(uiCompatModeColors = enabled)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
val statusBarColor
|
val statusBarColor
|
||||||
get() = launcherDataStore.data.map {
|
get() = launcherDataStore.data.map {
|
||||||
it.systemBarsStatusColors
|
it.systemBarsStatusColors
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user