Я реализовал это в приложении, которое делаю, и подумал, что будет легко создать из него библиотеку... но ничего более далекого от реальности
Основа библиотеки будет:
Код: Выделить всё
// commonMain
interface ThemePreferences {
suspend fun saveTheme(appThemeScheme: AppThemeScheme)
fun observeTheme(): Flow
}
// androidMain
class ThemePreferenceImpl(private val context: Context) : ThemePreferences {
private val Context.dataStore by preferencesDataStore(name = THEME_PREFERENCES_NAME)
override suspend fun saveTheme(appThemeScheme: AppThemeScheme) {
context.dataStore.edit {
it[THEME_MODE_KEY] = appThemeScheme.name
}
}
override fun observeTheme() = context.dataStore.data.map { preferences ->
when (preferences[THEME_MODE_KEY]) {
AppThemeScheme.LIGHT.name -> AppThemeScheme.LIGHT
AppThemeScheme.DARK.name -> AppThemeScheme.DARK
else -> AppThemeScheme.SYSTEM
}
}
companion object {
private const val STRING_PREFERENCES_KEY = "app_theme_scheme"
private val THEME_MODE_KEY = stringPreferencesKey(STRING_PREFERENCES_KEY)
private const val THEME_PREFERENCES_NAME = "theme_preferences"
}
}
// iosMain
class ThemePreferencesImpl private constructor() : ThemePreferences {
private val userDefaults = NSUserDefaults.standardUserDefaults
actual override fun getTheme(): AppThemeScheme {
val themeValue = userDefaults.stringForKey("theme") ?: AppThemeScheme.SYSTEM.name
return AppThemeScheme.valueOf(themeValue)
}
actual override fun saveTheme(theme: AppThemeScheme) {
userDefaults.setObject(theme.name, "theme")
}
}
Код: Выделить всё
// commonMain
expect fun createThemePreferences(): ThemePreferences
// androidMain
actual class ThemePreferencesImpl(context: Context)
// iosMain
actual class ThemePreferencesImpl()
Подробнее здесь: https://stackoverflow.com/questions/792 ... ual-expect