From 11d72a2336c2789d3d65ae89550bd331546a4d5f Mon Sep 17 00:00:00 2001 From: Anthony La Date: Mon, 4 Nov 2024 10:34:53 -0800 Subject: [PATCH] chore/Refactor usage of flow for settings viewmodel --- .../data/settings/SettingsDataStore.kt | 5 + .../data/settings/SettingsDataStoreImpl.kt | 43 +- .../wallpaper/presentation/MainActivity.kt | 49 -- .../wallpaper/presentation/PaperizeApp.kt | 213 +------ .../presentation/home_screen/HomeScreen.kt | 2 - .../settings_screen/SettingsEvent.kt | 7 - .../settings_screen/SettingsViewModel.kt | 583 ++++-------------- .../wallpaper_screen/WallpaperScreen.kt | 3 - 8 files changed, 204 insertions(+), 701 deletions(-) diff --git a/app/src/main/java/com/anthonyla/paperize/data/settings/SettingsDataStore.kt b/app/src/main/java/com/anthonyla/paperize/data/settings/SettingsDataStore.kt index 3fdfb8a..aa72396 100644 --- a/app/src/main/java/com/anthonyla/paperize/data/settings/SettingsDataStore.kt +++ b/app/src/main/java/com/anthonyla/paperize/data/settings/SettingsDataStore.kt @@ -1,5 +1,7 @@ package com.anthonyla.paperize.data.settings +import kotlinx.coroutines.flow.Flow + /** * Interface for the data store that handles the settings for application */ @@ -10,6 +12,9 @@ interface SettingsDataStore { suspend fun getBoolean(key: String): Boolean? suspend fun getString(key: String): String? suspend fun getInt(key: String): Int? + fun getBooleanFlow(key: String): Flow + fun getStringFlow(key: String): Flow + fun getIntFlow(key: String): Flow suspend fun deleteBoolean(key: String) suspend fun deleteString(key: String) suspend fun deleteInt(key: String) diff --git a/app/src/main/java/com/anthonyla/paperize/data/settings/SettingsDataStoreImpl.kt b/app/src/main/java/com/anthonyla/paperize/data/settings/SettingsDataStoreImpl.kt index b085a2f..1ee2e9d 100644 --- a/app/src/main/java/com/anthonyla/paperize/data/settings/SettingsDataStoreImpl.kt +++ b/app/src/main/java/com/anthonyla/paperize/data/settings/SettingsDataStoreImpl.kt @@ -5,10 +5,15 @@ import androidx.datastore.core.DataStore import androidx.datastore.preferences.core.Preferences import androidx.datastore.preferences.core.booleanPreferencesKey import androidx.datastore.preferences.core.edit +import androidx.datastore.preferences.core.emptyPreferences +import androidx.datastore.preferences.core.intPreferencesKey import androidx.datastore.preferences.core.stringPreferencesKey import androidx.datastore.preferences.preferencesDataStore import com.anthonyla.paperize.core.SettingsConstants.SETTINGS_DATASTORE +import kotlinx.coroutines.flow.Flow +import kotlinx.coroutines.flow.catch import kotlinx.coroutines.flow.first +import kotlinx.coroutines.flow.map private val Context.dataStore: DataStore by preferencesDataStore(name = SETTINGS_DATASTORE) @@ -28,9 +33,9 @@ class SettingsDataStoreImpl(private val context: Context) : SettingsDataStore { } override suspend fun putInt(key: String, value: Int) { - val preferencesKey = stringPreferencesKey(key) + val preferencesKey = intPreferencesKey(key) context.dataStore.edit { - it[preferencesKey] = value.toString() + it[preferencesKey] = value } } @@ -54,7 +59,7 @@ class SettingsDataStoreImpl(private val context: Context) : SettingsDataStore { override suspend fun getInt(key: String): Int? { return try { val head = context.dataStore.data.first() - val preferencesKey = stringPreferencesKey(key) + val preferencesKey = intPreferencesKey(key) head[preferencesKey]?.toInt() } catch (exception: Exception) { exception.printStackTrace() @@ -62,6 +67,33 @@ class SettingsDataStoreImpl(private val context: Context) : SettingsDataStore { } } + override fun getBooleanFlow(key: String): Flow = context.dataStore.data + .catch { exception -> + exception.printStackTrace() + emit(emptyPreferences()) + } + .map { preferences -> + preferences[booleanPreferencesKey(key)] + } + + override fun getStringFlow(key: String): Flow = context.dataStore.data + .catch { exception -> + exception.printStackTrace() + emit(emptyPreferences()) + } + .map { preferences -> + preferences[stringPreferencesKey(key)] + } + + override fun getIntFlow(key: String): Flow = context.dataStore.data + .catch { exception -> + exception.printStackTrace() + emit(emptyPreferences()) + } + .map { preferences -> + preferences[intPreferencesKey(key)] + } + override suspend fun deleteBoolean(key: String) { val preferencesKey = booleanPreferencesKey(key) context.dataStore.edit { @@ -81,7 +113,7 @@ class SettingsDataStoreImpl(private val context: Context) : SettingsDataStore { } override suspend fun deleteInt(key: String) { - val preferencesKey = stringPreferencesKey(key) + val preferencesKey = intPreferencesKey(key) context.dataStore.edit { if (it.contains(preferencesKey)) { it.remove(preferencesKey) @@ -104,6 +136,9 @@ class SettingsDataStoreImpl(private val context: Context) : SettingsDataStore { else if (preferences.contains(stringPreferencesKey(key))) { preferences.remove(stringPreferencesKey(key)) } + else if (preferences.contains(intPreferencesKey(key))) { + preferences.remove(intPreferencesKey(key)) + } } } } diff --git a/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/MainActivity.kt b/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/MainActivity.kt index e5b46e6..84edce9 100644 --- a/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/MainActivity.kt +++ b/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/MainActivity.kt @@ -145,7 +145,6 @@ class MainActivity : ComponentActivity() { if (shouldScheduleAlarm) { scheduleWallpaperAlarm(settings, scheduler) - updateCurrentWallpapers(settings) } } @@ -174,54 +173,6 @@ class MainActivity : ComponentActivity() { settingsViewModel.onEvent(SettingsEvent.RefreshNextSetTime) } - private fun updateCurrentWallpapers(settings: SettingsState) { - val selectedState = wallpaperScreenViewModel.state.value - val currentHomeAlbum = selectedState.selectedAlbum?.find { - it.album.initialAlbumName == settings.wallpaperSettings.homeAlbumName - } - val currentLockAlbum = selectedState.selectedAlbum?.find { - it.album.initialAlbumName == settings.wallpaperSettings.lockAlbumName - } - - val wallpaperSettings = settings.wallpaperSettings - val scheduleSettings = settings.scheduleSettings - - when { - scheduleSettings.scheduleSeparately && wallpaperSettings.setHomeWallpaper && wallpaperSettings.setLockWallpaper -> { - if (currentHomeAlbum != null && currentLockAlbum != null) { - settingsViewModel.onEvent(SettingsEvent.SetCurrentWallpaper( - currentHomeWallpaper = currentHomeAlbum.album.homeWallpapersInQueue.firstOrNull() ?: currentHomeAlbum.wallpapers.firstOrNull()?.wallpaperUri, - currentLockWallpaper = currentLockAlbum.album.lockWallpapersInQueue.firstOrNull() ?: currentLockAlbum.wallpapers.firstOrNull()?.wallpaperUri - )) - } - } - !scheduleSettings.scheduleSeparately && wallpaperSettings.setHomeWallpaper && wallpaperSettings.setLockWallpaper -> { - if (currentHomeAlbum != null && currentLockAlbum != null) { - settingsViewModel.onEvent(SettingsEvent.SetCurrentWallpaper( - currentHomeWallpaper = currentHomeAlbum.album.homeWallpapersInQueue.firstOrNull() ?: currentHomeAlbum.wallpapers.firstOrNull()?.wallpaperUri, - currentLockWallpaper = currentHomeAlbum.album.homeWallpapersInQueue.firstOrNull() ?: currentHomeAlbum.wallpapers.firstOrNull()?.wallpaperUri - )) - } - } - wallpaperSettings.setHomeWallpaper -> { - if (currentHomeAlbum != null) { - settingsViewModel.onEvent(SettingsEvent.SetCurrentWallpaper( - currentHomeWallpaper = currentHomeAlbum.album.homeWallpapersInQueue.firstOrNull() ?: currentHomeAlbum.wallpapers.firstOrNull()?.wallpaperUri, - currentLockWallpaper = if (scheduleSettings.scheduleSeparately) null else currentHomeAlbum.album.homeWallpapersInQueue.firstOrNull() ?: currentHomeAlbum.wallpapers.firstOrNull()?.wallpaperUri - )) - } - } - wallpaperSettings.setLockWallpaper -> { - if (currentLockAlbum != null) { - settingsViewModel.onEvent(SettingsEvent.SetCurrentWallpaper( - currentHomeWallpaper = if (scheduleSettings.scheduleSeparately) null else currentLockAlbum.album.lockWallpapersInQueue.firstOrNull() ?: currentLockAlbum.wallpapers.firstOrNull()?.wallpaperUri, - currentLockWallpaper = currentLockAlbum.album.lockWallpapersInQueue.firstOrNull() ?: currentLockAlbum.wallpapers.firstOrNull()?.wallpaperUri - )) - } - } - } - } - override fun onResume() { super.onResume() if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.S) { diff --git a/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/PaperizeApp.kt b/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/PaperizeApp.kt index 24b79cb..f9b756d 100644 --- a/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/PaperizeApp.kt +++ b/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/PaperizeApp.kt @@ -69,11 +69,11 @@ fun PaperizeApp( wallpaperScreenViewModel: WallpaperScreenViewModel = hiltViewModel(), addAlbumViewModel: AddAlbumViewModel = hiltViewModel(), ) { + val context = LocalContext.current val navController = rememberNavController() val albumState = albumsViewModel.state.collectAsStateWithLifecycle() val selectedState = wallpaperScreenViewModel.state.collectAsStateWithLifecycle() val settingsState = settingsViewModel.state.collectAsStateWithLifecycle() - val context = LocalContext.current var job by remember { mutableStateOf(null) } val scope = rememberCoroutineScope() val folderViewModel: FolderViewModel = hiltViewModel() @@ -162,32 +162,6 @@ fun PaperizeApp( onSettingsClick = { navController.navigate(Settings) }, onNavigateAddWallpaper = { navController.navigate(AddAlbum(it)) }, onViewAlbum = { navController.navigate(AlbumView(it)) }, - onScheduleWallpaperChanger = { - if (settingsState.value.wallpaperSettings.enableChanger) { - settingsViewModel.onEvent(SettingsEvent.RefreshNextSetTime) - job?.cancel() - job = scope.launch { - delay(1000) - val alarmItem = WallpaperAlarmItem( - homeInterval = settingsState.value.scheduleSettings.homeInterval, - lockInterval = settingsState.value.scheduleSettings.lockInterval, - scheduleSeparately = settingsState.value.scheduleSettings.scheduleSeparately, - setHome = settingsState.value.wallpaperSettings.setHomeWallpaper, - setLock = settingsState.value.wallpaperSettings.setLockWallpaper, - changeStartTime = settingsState.value.scheduleSettings.changeStartTime, - startTime = settingsState.value.scheduleSettings.startTime - ) - alarmItem.let{scheduler.scheduleWallpaperAlarm( - wallpaperAlarmItem = it, - origin = null, - changeImmediate = true, - cancelImmediate = true, - firstLaunch = true - ) } - scheduler.scheduleRefresh() - } - } - }, onHomeTimeChange = { timeInMinutes -> settingsViewModel.onEvent(SettingsEvent.SetHomeWallpaperInterval(timeInMinutes)) if (settingsState.value.wallpaperSettings.enableChanger) { @@ -254,8 +228,6 @@ fun PaperizeApp( job?.cancel() job = scope.launch { settingsViewModel.onEvent(SettingsEvent.RefreshNextSetTime) - settingsViewModel.onEvent(SettingsEvent.RefreshNextWallpaper) - delay(1000) val alarmItem = WallpaperAlarmItem( homeInterval = settingsState.value.scheduleSettings.homeInterval, lockInterval = settingsState.value.scheduleSettings.lockInterval, @@ -278,7 +250,7 @@ fun PaperizeApp( else { scheduler.cancelWallpaperAlarm() } } }, - onSelectAlbum = {album, lock, home -> + onSelectAlbum = { album, lock, home -> val notSameAlbum = settingsState.value.wallpaperSettings.homeAlbumName != settingsState.value.wallpaperSettings.lockAlbumName when { lock && home -> { @@ -312,101 +284,28 @@ fun PaperizeApp( ) } } + settingsViewModel.onEvent(SettingsEvent.RefreshNextSetTime) scope.launch { - settingsViewModel.onEvent(SettingsEvent.RefreshNextSetTime) - delay(1000) // Delay for enableChanger to refresh - if (settingsState.value.wallpaperSettings.enableChanger) { - val currentHomeAlbum = selectedState.value.selectedAlbum?.find { it.album.initialAlbumName == settingsState.value.wallpaperSettings.homeAlbumName } - val currentLockAlbum = selectedState.value.selectedAlbum?.find { it.album.initialAlbumName == settingsState.value.wallpaperSettings.lockAlbumName } - when { - settingsState.value.scheduleSettings.scheduleSeparately && settingsState.value.wallpaperSettings.setHomeWallpaper && settingsState.value.wallpaperSettings.setLockWallpaper -> { - if (currentHomeAlbum != null && currentLockAlbum != null) { - settingsViewModel.onEvent( - SettingsEvent.SetCurrentWallpaper( - currentHomeWallpaper = currentHomeAlbum.album.homeWallpapersInQueue.firstOrNull(), - currentLockWallpaper = currentLockAlbum.album.lockWallpapersInQueue.firstOrNull() - ) - ) - settingsViewModel.onEvent( - SettingsEvent.SetNextWallpaper( - nextHomeWallpaper = if (currentHomeAlbum.album.homeWallpapersInQueue.size > 1) currentHomeAlbum.album.homeWallpapersInQueue[1] else currentHomeAlbum.album.homeWallpapersInQueue.firstOrNull(), - nextLockWallpaper = if (currentLockAlbum.album.lockWallpapersInQueue.size > 1) currentLockAlbum.album.lockWallpapersInQueue[1] else currentLockAlbum.album.lockWallpapersInQueue.firstOrNull() - ) - ) - } - } - - !settingsState.value.scheduleSettings.scheduleSeparately && settingsState.value.wallpaperSettings.setHomeWallpaper && settingsState.value.wallpaperSettings.setLockWallpaper -> { - if (currentHomeAlbum != null && currentLockAlbum != null) { - settingsViewModel.onEvent( - SettingsEvent.SetCurrentWallpaper( - currentHomeWallpaper = currentHomeAlbum.album.homeWallpapersInQueue.firstOrNull(), - currentLockWallpaper = currentHomeAlbum.album.homeWallpapersInQueue.firstOrNull() - ) - ) - settingsViewModel.onEvent( - SettingsEvent.SetNextWallpaper( - nextHomeWallpaper = if (currentHomeAlbum.album.homeWallpapersInQueue.size > 1) currentHomeAlbum.album.homeWallpapersInQueue[1] else currentHomeAlbum.album.homeWallpapersInQueue.firstOrNull(), - nextLockWallpaper = if (currentHomeAlbum.album.homeWallpapersInQueue.size > 1) currentHomeAlbum.album.homeWallpapersInQueue[1] else currentHomeAlbum.album.homeWallpapersInQueue.firstOrNull(), - ) - ) - } - } - - settingsState.value.wallpaperSettings.setHomeWallpaper -> { - if (currentHomeAlbum != null) { - settingsViewModel.onEvent( - SettingsEvent.SetCurrentWallpaper( - currentHomeWallpaper = currentHomeAlbum.album.homeWallpapersInQueue.firstOrNull(), - currentLockWallpaper = if (settingsState.value.scheduleSettings.scheduleSeparately) null else currentHomeAlbum.album.homeWallpapersInQueue.firstOrNull() - ) - ) - settingsViewModel.onEvent( - SettingsEvent.SetNextWallpaper( - nextHomeWallpaper = if (currentHomeAlbum.album.homeWallpapersInQueue.size > 1) currentHomeAlbum.album.homeWallpapersInQueue[1] else currentHomeAlbum.album.homeWallpapersInQueue.firstOrNull(), - nextLockWallpaper = if (settingsState.value.scheduleSettings.scheduleSeparately) null else if (currentHomeAlbum.album.homeWallpapersInQueue.size > 1) currentHomeAlbum.album.homeWallpapersInQueue[1] else currentHomeAlbum.album.homeWallpapersInQueue.firstOrNull() - ) - ) - } - } - - settingsState.value.wallpaperSettings.setLockWallpaper -> { - if (currentLockAlbum != null) { - settingsViewModel.onEvent( - SettingsEvent.SetCurrentWallpaper( - currentHomeWallpaper = if (settingsState.value.scheduleSettings.scheduleSeparately) null else currentLockAlbum.album.lockWallpapersInQueue.firstOrNull(), - currentLockWallpaper = currentLockAlbum.album.lockWallpapersInQueue.firstOrNull() - ) - ) - settingsViewModel.onEvent( - SettingsEvent.SetNextWallpaper( - nextHomeWallpaper = if (settingsState.value.scheduleSettings.scheduleSeparately) null else if (currentLockAlbum.album.lockWallpapersInQueue.size > 1) currentLockAlbum.album.lockWallpapersInQueue[1] else currentLockAlbum.album.lockWallpapersInQueue.firstOrNull(), - nextLockWallpaper = if (currentLockAlbum.album.lockWallpapersInQueue.size > 1) currentLockAlbum.album.lockWallpapersInQueue[1] else currentLockAlbum.album.lockWallpapersInQueue.firstOrNull() - ) - ) - } - } - } - val alarmItem = WallpaperAlarmItem( - homeInterval = settingsState.value.scheduleSettings.homeInterval, - lockInterval = settingsState.value.scheduleSettings.lockInterval, - scheduleSeparately = settingsState.value.scheduleSettings.scheduleSeparately, - setHome = settingsState.value.wallpaperSettings.setHomeWallpaper, - setLock = settingsState.value.wallpaperSettings.setLockWallpaper, - changeStartTime = settingsState.value.scheduleSettings.changeStartTime, - startTime = settingsState.value.scheduleSettings.startTime + delay(1000) + val alarmItem = WallpaperAlarmItem( + homeInterval = settingsState.value.scheduleSettings.homeInterval, + lockInterval = settingsState.value.scheduleSettings.lockInterval, + scheduleSeparately = settingsState.value.scheduleSettings.scheduleSeparately, + setHome = home, + setLock = lock, + changeStartTime = settingsState.value.scheduleSettings.changeStartTime, + startTime = settingsState.value.scheduleSettings.startTime + ) + alarmItem.let { + scheduler.scheduleWallpaperAlarm( + wallpaperAlarmItem = it, + origin = null, + changeImmediate = true, + cancelImmediate = true, + firstLaunch = true ) - alarmItem.let { - scheduler.scheduleWallpaperAlarm( - wallpaperAlarmItem = it, - origin = null, - changeImmediate = true, - cancelImmediate = true, - firstLaunch = true - ) - } - scheduler.scheduleRefresh() } + scheduler.scheduleRefresh() } }, onDarkenPercentage = { home, lock -> @@ -424,7 +323,6 @@ fun PaperizeApp( if (settingsState.value.wallpaperSettings.enableChanger) { job?.cancel() job = scope.launch { - delay(1000) scheduler.updateWallpaper(settingsState.value.scheduleSettings.scheduleSeparately, settingsState.value.wallpaperSettings.setHomeWallpaper, settingsState.value.wallpaperSettings.setLockWallpaper) } } @@ -435,13 +333,13 @@ fun PaperizeApp( if (settingsState.value.wallpaperSettings.enableChanger) { job?.cancel() job = scope.launch { - delay(1000) scheduler.updateWallpaper(settingsState.value.scheduleSettings.scheduleSeparately, settingsState.value.wallpaperSettings.setHomeWallpaper, settingsState.value.wallpaperSettings.setLockWallpaper) } } } }, - onHomeCheckedChange = { setHome -> settingsViewModel.onEvent(SettingsEvent.SetHome(setHome)) + onHomeCheckedChange = { setHome -> + settingsViewModel.onEvent(SettingsEvent.SetHome(setHome)) if (!selectedState.value.selectedAlbum.isNullOrEmpty() && !setHome && !settingsState.value.wallpaperSettings.setLockWallpaper) { settingsViewModel.onEvent(SettingsEvent.SetChangerToggle(false)) selectedState.value.selectedAlbum?.let { wallpaperScreenViewModel.onEvent(WallpaperEvent.Reset()) } @@ -488,21 +386,12 @@ fun PaperizeApp( else if (!selectedState.value.selectedAlbum.isNullOrEmpty() && settingsState.value.wallpaperSettings.enableChanger) { job?.cancel() job = scope.launch { - val homeAlbum = selectedState.value.selectedAlbum?.find { it.album.initialAlbumName == settingsState.value.wallpaperSettings.homeAlbumName } - if (homeAlbum != null) { - settingsViewModel.onEvent( - SettingsEvent.SetNextWallpaper( - nextHomeWallpaper = homeAlbum.album.homeWallpapersInQueue.firstOrNull() ?: homeAlbum.wallpapers.firstOrNull()?.wallpaperUri, - nextLockWallpaper = homeAlbum.album.homeWallpapersInQueue.firstOrNull() ?: homeAlbum.wallpapers.firstOrNull()?.wallpaperUri - ) - ) - } - delay(1000) - scheduler.updateWallpaper(settingsState.value.scheduleSettings.scheduleSeparately, settingsState.value.wallpaperSettings.setHomeWallpaper, settingsState.value.wallpaperSettings.setLockWallpaper) + scheduler.updateWallpaper(settingsState.value.scheduleSettings.scheduleSeparately, setHome, settingsState.value.wallpaperSettings.setLockWallpaper) } } }, - onLockCheckedChange = { setLock -> settingsViewModel.onEvent(SettingsEvent.SetLock(setLock)) + onLockCheckedChange = { setLock -> + settingsViewModel.onEvent(SettingsEvent.SetLock(setLock)) if (selectedState.value.selectedAlbum!= null && !setLock && !settingsState.value.wallpaperSettings.setHomeWallpaper) { settingsViewModel.onEvent(SettingsEvent.SetChangerToggle(false)) selectedState.value.selectedAlbum?.let { @@ -538,15 +427,6 @@ fun PaperizeApp( else if (!selectedState.value.selectedAlbum.isNullOrEmpty() && settingsState.value.wallpaperSettings.enableChanger) { job?.cancel() job = scope.launch { - val homeAlbum = selectedState.value.selectedAlbum?.find { it.album.initialAlbumName == settingsState.value.wallpaperSettings.homeAlbumName } - if (homeAlbum != null) { - settingsViewModel.onEvent( - SettingsEvent.SetNextWallpaper( - nextHomeWallpaper = homeAlbum.album.homeWallpapersInQueue.firstOrNull() ?: homeAlbum.wallpapers.firstOrNull()?.wallpaperUri, - nextLockWallpaper = homeAlbum.album.homeWallpapersInQueue.firstOrNull() ?: homeAlbum.wallpapers.firstOrNull()?.wallpaperUri - ) - ) - } delay(1000) scheduler.updateWallpaper(settingsState.value.scheduleSettings.scheduleSeparately, settingsState.value.wallpaperSettings.setHomeWallpaper, settingsState.value.wallpaperSettings.setLockWallpaper) } @@ -555,42 +435,6 @@ fun PaperizeApp( onScheduleSeparatelyChange = { changeSeparately -> settingsViewModel.onEvent(SettingsEvent.SetScheduleSeparately(changeSeparately)) if (!selectedState.value.selectedAlbum.isNullOrEmpty() && settingsState.value.wallpaperSettings.enableChanger) { - val currentHomeAlbum = selectedState.value.selectedAlbum?.find { it.album.initialAlbumName == settingsState.value.wallpaperSettings.homeAlbumName } - val currentLockAlbum = selectedState.value.selectedAlbum?.find { it.album.initialAlbumName == settingsState.value.wallpaperSettings.lockAlbumName } - when { - changeSeparately && settingsState.value.wallpaperSettings.setHomeWallpaper && settingsState.value.wallpaperSettings.setLockWallpaper -> { - if (currentHomeAlbum != null && currentLockAlbum != null) { - settingsViewModel.onEvent(SettingsEvent.SetCurrentWallpaper( - currentHomeWallpaper = currentHomeAlbum.album.homeWallpapersInQueue.firstOrNull() ?: currentHomeAlbum.wallpapers.firstOrNull()?.wallpaperUri, - currentLockWallpaper = currentLockAlbum.album.lockWallpapersInQueue.firstOrNull() ?: currentLockAlbum.wallpapers.firstOrNull()?.wallpaperUri - )) - } - } - !changeSeparately && settingsState.value.wallpaperSettings.setHomeWallpaper && settingsState.value.wallpaperSettings.setLockWallpaper -> { - if (currentHomeAlbum != null && currentLockAlbum != null) { - settingsViewModel.onEvent(SettingsEvent.SetCurrentWallpaper( - currentHomeWallpaper = currentHomeAlbum.album.homeWallpapersInQueue.firstOrNull() ?: currentHomeAlbum.wallpapers.firstOrNull()?.wallpaperUri, - currentLockWallpaper = currentHomeAlbum.album.homeWallpapersInQueue.firstOrNull() ?: currentHomeAlbum.wallpapers.firstOrNull()?.wallpaperUri - )) - } - } - settingsState.value.wallpaperSettings.setHomeWallpaper -> { - if (currentHomeAlbum != null) { - settingsViewModel.onEvent(SettingsEvent.SetCurrentWallpaper( - currentHomeWallpaper = currentHomeAlbum.album.homeWallpapersInQueue.firstOrNull() ?: currentHomeAlbum.wallpapers.firstOrNull()?.wallpaperUri, - currentLockWallpaper = null - )) - } - } - settingsState.value.wallpaperSettings.setLockWallpaper -> { - if (currentLockAlbum != null) { - settingsViewModel.onEvent(SettingsEvent.SetCurrentWallpaper( - currentHomeWallpaper = null, - currentLockWallpaper = currentLockAlbum.album.lockWallpapersInQueue.firstOrNull() ?: currentLockAlbum.wallpapers.firstOrNull()?.wallpaperUri - )) - } - } - } job?.cancel() job = scope.launch { delay(1000) @@ -619,7 +463,6 @@ fun PaperizeApp( if (settingsState.value.wallpaperSettings.enableChanger) { job?.cancel() job = scope.launch { - delay(1000) scheduler.updateWallpaper(settingsState.value.scheduleSettings.scheduleSeparately, settingsState.value.wallpaperSettings.setHomeWallpaper, settingsState.value.wallpaperSettings.setLockWallpaper) } } @@ -639,7 +482,6 @@ fun PaperizeApp( if (settingsState.value.wallpaperSettings.enableChanger) { job?.cancel() job = scope.launch { - delay(1000) scheduler.updateWallpaper(settingsState.value.scheduleSettings.scheduleSeparately, settingsState.value.wallpaperSettings.setHomeWallpaper, settingsState.value.wallpaperSettings.setLockWallpaper) } } @@ -659,7 +501,6 @@ fun PaperizeApp( if (settingsState.value.wallpaperSettings.enableChanger) { job?.cancel() job = scope.launch { - delay(1000) scheduler.updateWallpaper(settingsState.value.scheduleSettings.scheduleSeparately, settingsState.value.wallpaperSettings.setHomeWallpaper, settingsState.value.wallpaperSettings.setLockWallpaper) } } @@ -679,7 +520,6 @@ fun PaperizeApp( if (settingsState.value.wallpaperSettings.enableChanger) { job?.cancel() job = scope.launch { - delay(1000) val alarmItem = WallpaperAlarmItem( homeInterval = settingsState.value.scheduleSettings.homeInterval, lockInterval = settingsState.value.scheduleSettings.lockInterval, @@ -699,7 +539,6 @@ fun PaperizeApp( if (settingsState.value.wallpaperSettings.enableChanger) { job?.cancel() job = scope.launch { - delay(1000) val alarmItem = WallpaperAlarmItem( homeInterval = settingsState.value.scheduleSettings.homeInterval, lockInterval = settingsState.value.scheduleSettings.lockInterval, diff --git a/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/home_screen/HomeScreen.kt b/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/home_screen/HomeScreen.kt index 026afff..ac939d8 100644 --- a/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/home_screen/HomeScreen.kt +++ b/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/home_screen/HomeScreen.kt @@ -54,7 +54,6 @@ fun HomeScreen( onHomeCheckedChange: (Boolean) -> Unit, onLockCheckedChange: (Boolean) -> Unit, onScalingChange: (ScalingConstants) -> Unit, - onScheduleWallpaperChanger: () -> Unit, onSelectAlbum: (AlbumWithWallpaperAndFolder, Boolean, Boolean) -> Unit, onScheduleSeparatelyChange: (Boolean) -> Unit, onHomeTimeChange: (Int) -> Unit, @@ -147,7 +146,6 @@ fun HomeScreen( onLockCheckedChange = onLockCheckedChange, onScalingChange = onScalingChange, onScheduleSeparatelyChange = onScheduleSeparatelyChange, - onScheduleWallpaperChanger = onScheduleWallpaperChanger, onSelectAlbum = onSelectAlbum, onHomeTimeChange = onHomeTimeChange, onLockTimeChange = onLockTimeChange, diff --git a/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/settings_screen/SettingsEvent.kt b/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/settings_screen/SettingsEvent.kt index 94764db..a1ff7bb 100644 --- a/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/settings_screen/SettingsEvent.kt +++ b/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/settings_screen/SettingsEvent.kt @@ -4,7 +4,6 @@ import com.anthonyla.paperize.core.ScalingConstants sealed class SettingsEvent { - data object Refresh: SettingsEvent() data object Reset: SettingsEvent() data object SetFirstLaunch: SettingsEvent() data object RefreshNextSetTime: SettingsEvent() @@ -19,8 +18,6 @@ sealed class SettingsEvent { data class SetLock(val lock: Boolean): SettingsEvent() data class SetHome(val home: Boolean): SettingsEvent() data class SetChangeStartTime(val changeStartTime: Boolean): SettingsEvent() - data class SetCurrentHomeWallpaper(val currentHomeWallpaper: String?): SettingsEvent() - data class SetCurrentLockWallpaper(val currentLockWallpaper: String?): SettingsEvent() data class SetCurrentWallpaper(val currentHomeWallpaper: String?, val currentLockWallpaper: String?): SettingsEvent() data class SetAlbumName(val homeAlbumName: String? = null, val lockAlbumName: String? = null): SettingsEvent() data class RemoveSelectedAlbumAsType(val removeLock: Boolean = false, val removeHome: Boolean = false): SettingsEvent() @@ -34,9 +31,5 @@ sealed class SettingsEvent { data class SetGrayscalePercentage(val homeGrayscalePercentage: Int?, val lockGrayscalePercentage: Int?): SettingsEvent() data class SetChangerToggle(val toggle: Boolean): SettingsEvent() data class SetWallpaperScaling(val scaling: ScalingConstants): SettingsEvent() - data class SetNextHomeWallpaper(val nextHomeWallpaper: String?): SettingsEvent() - data class SetNextLockWallpaper(val nextLockWallpaper: String?): SettingsEvent() - data class SetNextWallpaper(val nextHomeWallpaper: String?, val nextLockWallpaper: String?): SettingsEvent() data class SetStartTime(val hour: Int, val minute: Int): SettingsEvent() - data object RefreshNextWallpaper: SettingsEvent() } \ No newline at end of file diff --git a/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/settings_screen/SettingsViewModel.kt b/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/settings_screen/SettingsViewModel.kt index 1091b59..c472ba9 100644 --- a/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/settings_screen/SettingsViewModel.kt +++ b/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/settings_screen/SettingsViewModel.kt @@ -11,9 +11,7 @@ import com.anthonyla.paperize.feature.wallpaper.presentation.settings_screen.Set import com.anthonyla.paperize.feature.wallpaper.presentation.settings_screen.SettingsState.ThemeSettings import com.anthonyla.paperize.feature.wallpaper.presentation.settings_screen.SettingsState.WallpaperSettings import dagger.hilt.android.lifecycle.HiltViewModel -import kotlinx.coroutines.Dispatchers -import kotlinx.coroutines.Job -import kotlinx.coroutines.async +import kotlinx.coroutines.flow.* import kotlinx.coroutines.flow.MutableStateFlow import kotlinx.coroutines.flow.SharingStarted import kotlinx.coroutines.flow.stateIn @@ -25,209 +23,181 @@ import java.time.format.FormatStyle import javax.inject.Inject @HiltViewModel -class SettingsViewModel @Inject constructor ( +class SettingsViewModel @Inject constructor( private val settingsDataStoreImpl: SettingsDataStore -): ViewModel() { +) : ViewModel() { private val _state = MutableStateFlow(SettingsState()) val state = _state.stateIn( viewModelScope, - SharingStarted.WhileSubscribed(5000), SettingsState() + SharingStarted.WhileSubscribed(5000), + SettingsState() ) - - private var currentGetJob: Job? = null var setKeepOnScreenCondition: Boolean = true init { - currentGetJob = viewModelScope.launch(Dispatchers.IO) { - val firstLaunch = async { settingsDataStoreImpl.getBoolean(SettingsConstants.FIRST_LAUNCH) ?: true } - val themeSettings = async { loadThemeSettings() } - val wallpaperSettings = async { loadWallpaperSettings() } - val scheduleSettings = async { loadScheduleSettings() } - val effectSettings = async { loadEffectSettings() } - _state.update { - it.copy( - firstLaunch = firstLaunch.await(), - themeSettings = themeSettings.await(), - wallpaperSettings = wallpaperSettings.await(), - scheduleSettings = scheduleSettings.await(), - effectSettings = effectSettings.await() - ) - } - setKeepOnScreenCondition = false + viewModelScope.launch { + combine( + settingsDataStoreImpl.getBooleanFlow(SettingsConstants.FIRST_LAUNCH), + loadThemeSettingsFlow(), + loadWallpaperSettingsFlow(), + loadScheduleSettingsFlow(), + loadEffectSettingsFlow() + ) { firstLaunch, themeSettings, wallpaperSettings, scheduleSettings, effectSettings -> + _state.update { + it.copy( + firstLaunch = firstLaunch ?: true, + themeSettings = themeSettings, + wallpaperSettings = wallpaperSettings, + scheduleSettings = scheduleSettings, + effectSettings = effectSettings + ) + } + setKeepOnScreenCondition = false + }.collect() } } - - private suspend fun loadThemeSettings(): ThemeSettings { - return ThemeSettings( - darkMode = settingsDataStoreImpl.getBoolean(SettingsConstants.DARK_MODE_TYPE), - amoledTheme = settingsDataStoreImpl.getBoolean(SettingsConstants.AMOLED_THEME_TYPE) ?: false, - dynamicTheming = settingsDataStoreImpl.getBoolean(SettingsConstants.DYNAMIC_THEME_TYPE) ?: false, - animate = settingsDataStoreImpl.getBoolean(SettingsConstants.ANIMATE_TYPE) ?: true + + private fun loadThemeSettingsFlow(): Flow = combine( + settingsDataStoreImpl.getBooleanFlow(SettingsConstants.DARK_MODE_TYPE), + settingsDataStoreImpl.getBooleanFlow(SettingsConstants.AMOLED_THEME_TYPE), + settingsDataStoreImpl.getBooleanFlow(SettingsConstants.DYNAMIC_THEME_TYPE), + settingsDataStoreImpl.getBooleanFlow(SettingsConstants.ANIMATE_TYPE) + ) { darkMode, amoledTheme, dynamicTheming, animate -> + ThemeSettings( + darkMode = darkMode, + amoledTheme = amoledTheme ?: false, + dynamicTheming = dynamicTheming ?: false, + animate = animate ?: true ) } - - private suspend fun loadWallpaperSettings(): WallpaperSettings { - return WallpaperSettings( - enableChanger = settingsDataStoreImpl.getBoolean(SettingsConstants.ENABLE_CHANGER) ?: false, - setHomeWallpaper = settingsDataStoreImpl.getBoolean(SettingsConstants.ENABLE_HOME_WALLPAPER) ?: false, - setLockWallpaper = settingsDataStoreImpl.getBoolean(SettingsConstants.ENABLE_LOCK_WALLPAPER) ?: false, - currentHomeWallpaper = settingsDataStoreImpl.getString(SettingsConstants.CURRENT_HOME_WALLPAPER), - currentLockWallpaper = settingsDataStoreImpl.getString(SettingsConstants.CURRENT_LOCK_WALLPAPER), - nextHomeWallpaper = settingsDataStoreImpl.getString(SettingsConstants.HOME_NEXT_SET_TIME), - nextLockWallpaper = settingsDataStoreImpl.getString(SettingsConstants.LOCK_NEXT_SET_TIME), - homeAlbumName = settingsDataStoreImpl.getString(SettingsConstants.HOME_ALBUM_NAME), - lockAlbumName = settingsDataStoreImpl.getString(SettingsConstants.LOCK_ALBUM_NAME), - wallpaperScaling = ScalingConstants.valueOf( - settingsDataStoreImpl.getString(SettingsConstants.WALLPAPER_SCALING) - ?: ScalingConstants.FILL.name - ) + + private fun loadWallpaperSettingsFlow(): Flow = combine( + settingsDataStoreImpl.getBooleanFlow(SettingsConstants.ENABLE_CHANGER), + settingsDataStoreImpl.getBooleanFlow(SettingsConstants.ENABLE_HOME_WALLPAPER), + settingsDataStoreImpl.getBooleanFlow(SettingsConstants.ENABLE_LOCK_WALLPAPER), + settingsDataStoreImpl.getStringFlow(SettingsConstants.CURRENT_HOME_WALLPAPER), + settingsDataStoreImpl.getStringFlow(SettingsConstants.CURRENT_LOCK_WALLPAPER), + settingsDataStoreImpl.getStringFlow(SettingsConstants.NEXT_HOME_WALLPAPER), + settingsDataStoreImpl.getStringFlow(SettingsConstants.NEXT_LOCK_WALLPAPER), + settingsDataStoreImpl.getStringFlow(SettingsConstants.HOME_ALBUM_NAME), + settingsDataStoreImpl.getStringFlow(SettingsConstants.LOCK_ALBUM_NAME), + settingsDataStoreImpl.getStringFlow(SettingsConstants.WALLPAPER_SCALING) + ) { flows -> + WallpaperSettings( + enableChanger = flows[0] as Boolean? ?: false, + setHomeWallpaper = flows[1] as Boolean? ?: false, + setLockWallpaper = flows[2] as Boolean? ?: false, + currentHomeWallpaper = flows[3] as String?, + currentLockWallpaper = flows[4] as String?, + nextHomeWallpaper = flows[5] as String?, + nextLockWallpaper = flows[6] as String?, + homeAlbumName = flows[7] as String?, + lockAlbumName = flows[8] as String?, + wallpaperScaling = ScalingConstants.valueOf((flows[9] as String?) ?: ScalingConstants.FILL.name) ) } - - private suspend fun loadScheduleSettings(): ScheduleSettings { - return ScheduleSettings( - scheduleSeparately = settingsDataStoreImpl.getBoolean(SettingsConstants.SCHEDULE_SEPARATELY) ?: false, - homeInterval = settingsDataStoreImpl.getInt(SettingsConstants.HOME_WALLPAPER_CHANGE_INTERVAL) ?: WALLPAPER_CHANGE_INTERVAL_DEFAULT, - lockInterval = settingsDataStoreImpl.getInt(SettingsConstants.LOCK_WALLPAPER_CHANGE_INTERVAL) ?: WALLPAPER_CHANGE_INTERVAL_DEFAULT, - lastSetTime = settingsDataStoreImpl.getString(SettingsConstants.LAST_SET_TIME), - nextSetTime = settingsDataStoreImpl.getString(SettingsConstants.NEXT_SET_TIME), - changeStartTime = settingsDataStoreImpl.getBoolean(SettingsConstants.CHANGE_START_TIME) ?: false, - startTime = Pair( - settingsDataStoreImpl.getInt(SettingsConstants.START_HOUR) ?: 0, - settingsDataStoreImpl.getInt(SettingsConstants.START_MINUTE) ?: 0 - ) + + private fun loadScheduleSettingsFlow(): Flow = combine( + settingsDataStoreImpl.getBooleanFlow(SettingsConstants.SCHEDULE_SEPARATELY), + settingsDataStoreImpl.getIntFlow(SettingsConstants.HOME_WALLPAPER_CHANGE_INTERVAL), + settingsDataStoreImpl.getIntFlow(SettingsConstants.LOCK_WALLPAPER_CHANGE_INTERVAL), + settingsDataStoreImpl.getStringFlow(SettingsConstants.LAST_SET_TIME), + settingsDataStoreImpl.getStringFlow(SettingsConstants.NEXT_SET_TIME), + settingsDataStoreImpl.getBooleanFlow(SettingsConstants.CHANGE_START_TIME), + settingsDataStoreImpl.getIntFlow(SettingsConstants.START_HOUR), + settingsDataStoreImpl.getIntFlow(SettingsConstants.START_MINUTE) + ) { flows -> + ScheduleSettings( + scheduleSeparately = flows[0] as Boolean? ?: false, + homeInterval = flows[1] as Int? ?: WALLPAPER_CHANGE_INTERVAL_DEFAULT, + lockInterval = flows[2] as Int? ?: WALLPAPER_CHANGE_INTERVAL_DEFAULT, + lastSetTime = flows[3] as String?, + nextSetTime = flows[4] as String?, + changeStartTime = flows[5] as Boolean? ?: false, + startTime = Pair(flows[6] as Int? ?: 0, flows[7] as Int? ?: 0) ) } - - private suspend fun loadEffectSettings(): EffectSettings { - return EffectSettings( - darken = settingsDataStoreImpl.getBoolean(SettingsConstants.DARKEN) ?: false, - homeDarkenPercentage = settingsDataStoreImpl.getInt(SettingsConstants.HOME_DARKEN_PERCENTAGE) ?: 100, - lockDarkenPercentage = settingsDataStoreImpl.getInt(SettingsConstants.LOCK_DARKEN_PERCENTAGE) ?: 100, - blur = settingsDataStoreImpl.getBoolean(SettingsConstants.BLUR) ?: false, - homeBlurPercentage = settingsDataStoreImpl.getInt(SettingsConstants.HOME_BLUR_PERCENTAGE) ?: 0, - lockBlurPercentage = settingsDataStoreImpl.getInt(SettingsConstants.LOCK_BLUR_PERCENTAGE) ?: 0, - vignette = settingsDataStoreImpl.getBoolean(SettingsConstants.VIGNETTE) ?: false, - homeVignettePercentage = settingsDataStoreImpl.getInt(SettingsConstants.HOME_VIGNETTE_PERCENTAGE) ?: 0, - lockVignettePercentage = settingsDataStoreImpl.getInt(SettingsConstants.LOCK_VIGNETTE_PERCENTAGE) ?: 0, - grayscale = settingsDataStoreImpl.getBoolean(SettingsConstants.GRAYSCALE) ?: false, - homeGrayscalePercentage = settingsDataStoreImpl.getInt(SettingsConstants.HOME_GRAYSCALE_PERCENTAGE) ?: 0, - lockGrayscalePercentage = settingsDataStoreImpl.getInt(SettingsConstants.LOCK_GRAYSCALE_PERCENTAGE) ?: 0 + + private fun loadEffectSettingsFlow(): Flow = combine( + settingsDataStoreImpl.getBooleanFlow(SettingsConstants.DARKEN), + settingsDataStoreImpl.getIntFlow(SettingsConstants.HOME_DARKEN_PERCENTAGE), + settingsDataStoreImpl.getIntFlow(SettingsConstants.LOCK_DARKEN_PERCENTAGE), + settingsDataStoreImpl.getBooleanFlow(SettingsConstants.BLUR), + settingsDataStoreImpl.getIntFlow(SettingsConstants.HOME_BLUR_PERCENTAGE), + settingsDataStoreImpl.getIntFlow(SettingsConstants.LOCK_BLUR_PERCENTAGE), + settingsDataStoreImpl.getBooleanFlow(SettingsConstants.VIGNETTE), + settingsDataStoreImpl.getIntFlow(SettingsConstants.HOME_VIGNETTE_PERCENTAGE), + settingsDataStoreImpl.getIntFlow(SettingsConstants.LOCK_VIGNETTE_PERCENTAGE), + settingsDataStoreImpl.getBooleanFlow(SettingsConstants.GRAYSCALE), + settingsDataStoreImpl.getIntFlow(SettingsConstants.HOME_GRAYSCALE_PERCENTAGE), + settingsDataStoreImpl.getIntFlow(SettingsConstants.LOCK_GRAYSCALE_PERCENTAGE) + ) { flows -> + EffectSettings( + darken = flows[0] as Boolean? ?: false, + homeDarkenPercentage = flows[1] as Int? ?: 100, + lockDarkenPercentage = flows[2] as Int? ?: 100, + blur = flows[3] as Boolean? ?: false, + homeBlurPercentage = flows[4] as Int? ?: 0, + lockBlurPercentage = flows[5] as Int? ?: 0, + vignette = flows[6] as Boolean? ?: false, + homeVignettePercentage = flows[7] as Int? ?: 0, + lockVignettePercentage = flows[8] as Int? ?: 0, + grayscale = flows[9] as Boolean? ?: false, + homeGrayscalePercentage = flows[10] as Int? ?: 0, + lockGrayscalePercentage = flows[11] as Int? ?: 0 ) } fun onEvent(event: SettingsEvent) { when (event) { is SettingsEvent.SetFirstLaunch -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { settingsDataStoreImpl.putBoolean(SettingsConstants.FIRST_LAUNCH, false) - _state.update { - it.copy(firstLaunch = false) - } } } is SettingsEvent.SetChangerToggle -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { settingsDataStoreImpl.putBoolean(SettingsConstants.ENABLE_CHANGER, event.toggle) - _state.update { currentState -> - currentState.copy( - wallpaperSettings = currentState.wallpaperSettings.copy( - enableChanger = event.toggle, - currentHomeWallpaper = if (!event.toggle) null else currentState.wallpaperSettings.currentHomeWallpaper, - currentLockWallpaper = if (!event.toggle) null else currentState.wallpaperSettings.currentLockWallpaper - ) - ) - } - } - } - - is SettingsEvent.Refresh -> { - currentGetJob = viewModelScope.launch(Dispatchers.IO) { - val themeSettings = async { loadThemeSettings() } - val wallpaperSettings = async { loadWallpaperSettings() } - val scheduleSettings = async { loadScheduleSettings() } - val effectSettings = async { loadEffectSettings() } - val firstLaunch = async { settingsDataStoreImpl.getBoolean(SettingsConstants.FIRST_LAUNCH) ?: true } - - _state.update { - it.copy( - firstLaunch = firstLaunch.await(), - themeSettings = themeSettings.await(), - wallpaperSettings = wallpaperSettings.await(), - scheduleSettings = scheduleSettings.await(), - effectSettings = effectSettings.await() - ) - } } } is SettingsEvent.SetDarkMode -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { when (event.darkMode) { true -> { settingsDataStoreImpl.putBoolean(SettingsConstants.DARK_MODE_TYPE, true) } false -> { settingsDataStoreImpl.putBoolean(SettingsConstants.DARK_MODE_TYPE, false) } null -> { settingsDataStoreImpl.deleteBoolean(SettingsConstants.DARK_MODE_TYPE) } } - _state.update { - it.copy( - themeSettings = it.themeSettings.copy( - darkMode = event.darkMode - ) - ) - } } } is SettingsEvent.SetAmoledTheme -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { settingsDataStoreImpl.putBoolean(SettingsConstants.AMOLED_THEME_TYPE, event.amoledTheme) if (event.amoledTheme) { settingsDataStoreImpl.putBoolean(SettingsConstants.DYNAMIC_THEME_TYPE, false) } - _state.update { - it.copy( - themeSettings = it.themeSettings.copy( - amoledTheme = event.amoledTheme, - dynamicTheming = if (event.amoledTheme) false else it.themeSettings.dynamicTheming - ) - ) - } } } is SettingsEvent.SetDynamicTheming -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { settingsDataStoreImpl.putBoolean(SettingsConstants.DYNAMIC_THEME_TYPE, event.dynamicTheming) if (event.dynamicTheming) { settingsDataStoreImpl.putBoolean(SettingsConstants.AMOLED_THEME_TYPE, false) } - _state.update { - it.copy( - themeSettings = it.themeSettings.copy( - amoledTheme = if (event.dynamicTheming) false else it.themeSettings.amoledTheme, - dynamicTheming = event.dynamicTheming - ) - ) - } } } is SettingsEvent.SetAnimate -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { settingsDataStoreImpl.putBoolean(SettingsConstants.ANIMATE_TYPE, event.animate) - _state.update { - it.copy( - themeSettings = it.themeSettings.copy( - animate = event.animate - ) - ) - } } } is SettingsEvent.SetHomeWallpaperInterval -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { settingsDataStoreImpl.putInt(SettingsConstants.HOME_WALLPAPER_CHANGE_INTERVAL, event.interval) val formatter = DateTimeFormatter.ofLocalizedDateTime(FormatStyle.SHORT) val currentTime = if (_state.value.scheduleSettings.changeStartTime) { @@ -252,20 +222,11 @@ class SettingsViewModel @Inject constructor ( settingsDataStoreImpl.putString(SettingsConstants.HOME_NEXT_SET_TIME, currentTime.plusMinutes(event.interval.toLong()).toString()) settingsDataStoreImpl.putString(SettingsConstants.LOCK_NEXT_SET_TIME, currentTime.plusMinutes(event.interval.toLong()).toString()) } - _state.update { - it.copy( - scheduleSettings = it.scheduleSettings.copy( - homeInterval = event.interval, - lastSetTime = currentTime.format(formatter), - nextSetTime = nextSetTime - ) - ) - } } } is SettingsEvent.SetLockWallpaperInterval -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { settingsDataStoreImpl.putInt(SettingsConstants.LOCK_WALLPAPER_CHANGE_INTERVAL, event.interval) val formatter = DateTimeFormatter.ofLocalizedDateTime(FormatStyle.SHORT) val currentTime = if (_state.value.scheduleSettings.changeStartTime) { @@ -290,15 +251,6 @@ class SettingsViewModel @Inject constructor ( settingsDataStoreImpl.putString(SettingsConstants.HOME_NEXT_SET_TIME, currentTime.plusMinutes(event.interval.toLong()).toString()) settingsDataStoreImpl.putString(SettingsConstants.LOCK_NEXT_SET_TIME, currentTime.plusMinutes(event.interval.toLong()).toString()) } - _state.update { - it.copy( - scheduleSettings = it.scheduleSettings.copy( - lockInterval = event.interval, - lastSetTime = currentTime.format(formatter), - nextSetTime = nextSetTime - ) - ) - } } } @@ -339,231 +291,105 @@ class SettingsViewModel @Inject constructor ( currentTime.plusMinutes(_state.value.scheduleSettings.homeInterval.toLong()) } }.format(formatter) - _state.update { - it.copy( - scheduleSettings = it.scheduleSettings.copy( - lastSetTime = LocalDateTime.now().format(formatter), - nextSetTime = nextSetTime - ) - ) - } settingsDataStoreImpl.putString(SettingsConstants.LAST_SET_TIME, LocalDateTime.now().format(formatter)) settingsDataStoreImpl.putString(SettingsConstants.NEXT_SET_TIME, nextSetTime) } } is SettingsEvent.SetHome -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { settingsDataStoreImpl.putBoolean(SettingsConstants.ENABLE_HOME_WALLPAPER, event.home) - _state.update { - it.copy( - wallpaperSettings = it.wallpaperSettings.copy( - setHomeWallpaper = event.home - ) - ) - } } } is SettingsEvent.SetLock -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { settingsDataStoreImpl.putBoolean(SettingsConstants.ENABLE_LOCK_WALLPAPER, event.lock) - _state.update { - it.copy( - wallpaperSettings = it.wallpaperSettings.copy( - setLockWallpaper = event.lock - ) - ) - } } } is SettingsEvent.SetDarken -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { settingsDataStoreImpl.putBoolean(SettingsConstants.DARKEN, event.darken) - _state.update { - it.copy( - effectSettings = it.effectSettings.copy( - darken = event.darken - ) - ) - } } } is SettingsEvent.SetWallpaperScaling -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { settingsDataStoreImpl.putString(SettingsConstants.WALLPAPER_SCALING, event.scaling.name) - _state.update { - it.copy( - wallpaperSettings = it.wallpaperSettings.copy( - wallpaperScaling = event.scaling - ) - ) - } } } is SettingsEvent.SetScheduleSeparately -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { settingsDataStoreImpl.putBoolean(SettingsConstants.SCHEDULE_SEPARATELY, event.scheduleSeparately) - _state.update { - it.copy( - scheduleSettings = it.scheduleSettings.copy( - scheduleSeparately = event.scheduleSeparately - ) - ) - } } } is SettingsEvent.SetBlur -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { settingsDataStoreImpl.putBoolean(SettingsConstants.BLUR, event.blur) - _state.update { - it.copy( - effectSettings = it.effectSettings.copy( - blur = event.blur - ) - ) - } } } is SettingsEvent.SetDarkenPercentage -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { if (event.lockDarkenPercentage != null) { settingsDataStoreImpl.putInt(SettingsConstants.LOCK_DARKEN_PERCENTAGE, event.lockDarkenPercentage) } if (event.homeDarkenPercentage != null) { settingsDataStoreImpl.putInt(SettingsConstants.HOME_DARKEN_PERCENTAGE, event.homeDarkenPercentage) } - _state.update { - it.copy( - effectSettings = it.effectSettings.copy( - homeDarkenPercentage = event.homeDarkenPercentage ?: it.effectSettings.homeDarkenPercentage, - lockDarkenPercentage = event.lockDarkenPercentage ?: it.effectSettings.lockDarkenPercentage - ) - ) - } } } is SettingsEvent.SetBlurPercentage -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { if (event.lockBlurPercentage != null) { settingsDataStoreImpl.putInt(SettingsConstants.LOCK_BLUR_PERCENTAGE, event.lockBlurPercentage) } if (event.homeBlurPercentage != null) { settingsDataStoreImpl.putInt(SettingsConstants.HOME_BLUR_PERCENTAGE, event.homeBlurPercentage) } - _state.update { - it.copy( - effectSettings = it.effectSettings.copy( - homeBlurPercentage = event.homeBlurPercentage ?: it.effectSettings.homeBlurPercentage, - lockBlurPercentage = event.lockBlurPercentage ?: it.effectSettings.lockBlurPercentage - ) - ) - } } } is SettingsEvent.SetVignette -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { settingsDataStoreImpl.putBoolean(SettingsConstants.VIGNETTE, event.vignette) - _state.update { - it.copy( - effectSettings = it.effectSettings.copy( - vignette = event.vignette - ) - ) - } } } is SettingsEvent.SetVignettePercentage -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { if (event.lockVignettePercentage != null) { settingsDataStoreImpl.putInt(SettingsConstants.LOCK_VIGNETTE_PERCENTAGE, event.lockVignettePercentage) } if (event.homeVignettePercentage != null) { settingsDataStoreImpl.putInt(SettingsConstants.HOME_VIGNETTE_PERCENTAGE, event.homeVignettePercentage) } - _state.update { - it.copy( - effectSettings = it.effectSettings.copy( - homeVignettePercentage = event.homeVignettePercentage ?: it.effectSettings.homeVignettePercentage, - lockVignettePercentage = event.lockVignettePercentage ?: it.effectSettings.lockVignettePercentage - ) - ) - } } } is SettingsEvent.SetGrayscale -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { settingsDataStoreImpl.putBoolean(SettingsConstants.GRAYSCALE, event.grayscale) - _state.update { - it.copy( - effectSettings = it.effectSettings.copy( - grayscale = event.grayscale - ) - ) - } } } is SettingsEvent.SetGrayscalePercentage -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { if (event.lockGrayscalePercentage != null) { settingsDataStoreImpl.putInt(SettingsConstants.LOCK_GRAYSCALE_PERCENTAGE, event.lockGrayscalePercentage) } if (event.homeGrayscalePercentage != null) { settingsDataStoreImpl.putInt(SettingsConstants.HOME_GRAYSCALE_PERCENTAGE, event.homeGrayscalePercentage) } - _state.update { - it.copy( - effectSettings = it.effectSettings.copy( - homeGrayscalePercentage = event.homeGrayscalePercentage ?: it.effectSettings.homeGrayscalePercentage, - lockGrayscalePercentage = event.lockGrayscalePercentage ?: it.effectSettings.lockGrayscalePercentage - ) - ) - } - } - } - - is SettingsEvent.SetCurrentHomeWallpaper -> { - viewModelScope.launch(Dispatchers.IO) { - if (event.currentHomeWallpaper != null) { - settingsDataStoreImpl.putString(SettingsConstants.CURRENT_HOME_WALLPAPER, event.currentHomeWallpaper) - } - _state.update { - it.copy( - wallpaperSettings = it.wallpaperSettings.copy( - currentHomeWallpaper = event.currentHomeWallpaper - ) - ) - } - } - } - - is SettingsEvent.SetCurrentLockWallpaper -> { - viewModelScope.launch(Dispatchers.IO) { - if (event.currentLockWallpaper != null) { - settingsDataStoreImpl.putString(SettingsConstants.CURRENT_LOCK_WALLPAPER, event.currentLockWallpaper) - } - _state.update { - it.copy( - wallpaperSettings = it.wallpaperSettings.copy( - currentLockWallpaper = event.currentLockWallpaper - ) - ) - } } } is SettingsEvent.SetCurrentWallpaper -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { if (event.currentLockWallpaper != null) { settingsDataStoreImpl.putString(SettingsConstants.CURRENT_LOCK_WALLPAPER, event.currentLockWallpaper) } @@ -582,7 +408,7 @@ class SettingsViewModel @Inject constructor ( } is SettingsEvent.SetAlbumName -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { if (event.homeAlbumName != null) { settingsDataStoreImpl.putString(SettingsConstants.HOME_ALBUM_NAME, event.homeAlbumName) } @@ -596,20 +422,11 @@ class SettingsViewModel @Inject constructor ( else -> { false } } settingsDataStoreImpl.putBoolean(SettingsConstants.ENABLE_CHANGER, enableChanger) - _state.update { - it.copy( - wallpaperSettings = it.wallpaperSettings.copy( - homeAlbumName = event.homeAlbumName ?: it.wallpaperSettings.homeAlbumName, - lockAlbumName = event.lockAlbumName ?: it.wallpaperSettings.lockAlbumName, - enableChanger = enableChanger - ) - ) - } } } is SettingsEvent.RemoveSelectedAlbumAsType -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { if (_state.value.wallpaperSettings.setLockWallpaper && _state.value.wallpaperSettings.setHomeWallpaper) { if (event.removeLock) { settingsDataStoreImpl.deleteString(SettingsConstants.LOCK_ALBUM_NAME) @@ -621,23 +438,6 @@ class SettingsViewModel @Inject constructor ( settingsDataStoreImpl.deleteString(SettingsConstants.CURRENT_HOME_WALLPAPER) settingsDataStoreImpl.deleteString(SettingsConstants.LAST_SET_TIME) settingsDataStoreImpl.deleteString(SettingsConstants.NEXT_SET_TIME) - _state.update { - it.copy( - wallpaperSettings = it.wallpaperSettings.copy( - homeAlbumName = if (event.removeHome) null else it.wallpaperSettings.homeAlbumName, - lockAlbumName = if (event.removeLock) null else it.wallpaperSettings.lockAlbumName, - currentHomeWallpaper = null, - currentLockWallpaper = null, - nextHomeWallpaper = null, - nextLockWallpaper = null, - enableChanger = false - ), - scheduleSettings = it.scheduleSettings.copy( - lastSetTime = null, - nextSetTime = null - ) - ) - } } else { if (event.removeLock) { @@ -648,23 +448,12 @@ class SettingsViewModel @Inject constructor ( settingsDataStoreImpl.deleteString(SettingsConstants.HOME_ALBUM_NAME) settingsDataStoreImpl.deleteString(SettingsConstants.CURRENT_HOME_WALLPAPER) } - _state.update { - it.copy( - wallpaperSettings = it.wallpaperSettings.copy( - homeAlbumName = if (event.removeHome) null else it.wallpaperSettings.homeAlbumName, - lockAlbumName = if (event.removeLock) null else it.wallpaperSettings.lockAlbumName, - currentHomeWallpaper = if (event.removeHome) null else it.wallpaperSettings.currentHomeWallpaper, - currentLockWallpaper = if (event.removeLock) null else it.wallpaperSettings.currentLockWallpaper, - enableChanger = false - ) - ) - } } } } is SettingsEvent.RemoveSelectedAlbumAsName -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { var enableChanger = _state.value.wallpaperSettings.enableChanger if (event.albumName == _state.value.wallpaperSettings.lockAlbumName) { settingsDataStoreImpl.deleteString(SettingsConstants.LOCK_ALBUM_NAME) @@ -677,89 +466,11 @@ class SettingsViewModel @Inject constructor ( enableChanger = false } settingsDataStoreImpl.putBoolean(SettingsConstants.ENABLE_CHANGER, enableChanger) - _state.update { - it.copy( - wallpaperSettings = it.wallpaperSettings.copy( - homeAlbumName = if (event.albumName == _state.value.wallpaperSettings.homeAlbumName) null else it.wallpaperSettings.homeAlbumName, - lockAlbumName = if (event.albumName == _state.value.wallpaperSettings.lockAlbumName) null else it.wallpaperSettings.lockAlbumName, - currentHomeWallpaper = if (event.albumName == _state.value.wallpaperSettings.homeAlbumName) null else it.wallpaperSettings.currentHomeWallpaper, - currentLockWallpaper = if (event.albumName == _state.value.wallpaperSettings.lockAlbumName) null else it.wallpaperSettings.currentLockWallpaper, - enableChanger = enableChanger - ) - ) - - } - } - } - - is SettingsEvent.SetNextHomeWallpaper -> { - viewModelScope.launch(Dispatchers.IO) { - event.nextHomeWallpaper?.let { - settingsDataStoreImpl.putString(SettingsConstants.NEXT_HOME_WALLPAPER, it) - } - _state.update { - it.copy( - wallpaperSettings = it.wallpaperSettings.copy( - nextHomeWallpaper = event.nextHomeWallpaper - ) - ) - } - } - } - - is SettingsEvent.SetNextLockWallpaper -> { - viewModelScope.launch(Dispatchers.IO) { - event.nextLockWallpaper?.let { - settingsDataStoreImpl.putString(SettingsConstants.NEXT_LOCK_WALLPAPER, it) - } - _state.update { - it.copy( - wallpaperSettings = it.wallpaperSettings.copy( - nextLockWallpaper = event.nextLockWallpaper - ) - ) - } - } - } - - is SettingsEvent.SetNextWallpaper -> { - viewModelScope.launch(Dispatchers.IO) { - if (event.nextHomeWallpaper != null) { - settingsDataStoreImpl.putString(SettingsConstants.NEXT_HOME_WALLPAPER, event.nextHomeWallpaper) - } - if (event.nextLockWallpaper != null) { - settingsDataStoreImpl.putString(SettingsConstants.NEXT_LOCK_WALLPAPER, event.nextLockWallpaper) - } - _state.update { - it.copy( - wallpaperSettings = it.wallpaperSettings.copy( - nextHomeWallpaper = event.nextHomeWallpaper ?: it.wallpaperSettings.nextHomeWallpaper, - nextLockWallpaper = event.nextLockWallpaper ?: it.wallpaperSettings.nextLockWallpaper - ) - ) - } - } - } - - is SettingsEvent.RefreshNextWallpaper -> { - viewModelScope.launch(Dispatchers.IO) { - val nextHomeWallpaper = async { settingsDataStoreImpl.getString(SettingsConstants.NEXT_HOME_WALLPAPER) } - val nextLockWallpaper = async { settingsDataStoreImpl.getString(SettingsConstants.NEXT_LOCK_WALLPAPER) } - _state.update { - it.copy( - wallpaperSettings = it.wallpaperSettings.copy( - nextHomeWallpaper = nextHomeWallpaper.await(), - nextLockWallpaper = nextLockWallpaper.await(), - currentHomeWallpaper = nextHomeWallpaper.await(), - currentLockWallpaper = nextLockWallpaper.await() - ) - ) - } } } is SettingsEvent.SetChangeStartTime -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { val formatter = DateTimeFormatter.ofLocalizedDateTime(FormatStyle.SHORT) val currentTime = if (event.changeStartTime) { LocalDateTime.now() @@ -792,35 +503,18 @@ class SettingsViewModel @Inject constructor ( nextSetTime.format(formatter) } } - _state.update { - it.copy( - scheduleSettings = it.scheduleSettings.copy( - changeStartTime = event.changeStartTime, - nextSetTime = nextSetTime - ) - ) - } settingsDataStoreImpl.putString(SettingsConstants.NEXT_SET_TIME, nextSetTime) settingsDataStoreImpl.putBoolean(SettingsConstants.CHANGE_START_TIME, event.changeStartTime) } } is SettingsEvent.SetStartTime -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { val formatter = DateTimeFormatter.ofLocalizedDateTime(FormatStyle.SHORT) val currentTime = LocalDateTime.now().withHour(event.hour).withMinute(event.minute).let { if (it.isBefore(LocalDateTime.now())) it.plusDays(1) else it } val nextSetTime = currentTime.format(formatter) - _state.update { - it.copy( - scheduleSettings = it.scheduleSettings.copy( - startTime = Pair(event.hour, event.minute), - changeStartTime = true, - nextSetTime = nextSetTime - ) - ) - } settingsDataStoreImpl.run { putString(SettingsConstants.HOME_NEXT_SET_TIME, currentTime.toString()) putString(SettingsConstants.LOCK_NEXT_SET_TIME, currentTime.toString()) @@ -833,7 +527,7 @@ class SettingsViewModel @Inject constructor ( } is SettingsEvent.Reset -> { - viewModelScope.launch(Dispatchers.IO) { + viewModelScope.launch { val keysToDelete = listOf( SettingsConstants.DARK_MODE_TYPE, SettingsConstants.AMOLED_THEME_TYPE, @@ -875,15 +569,6 @@ class SettingsViewModel @Inject constructor ( SettingsConstants.START_MINUTE ) settingsDataStoreImpl.clear(keysToDelete) - _state.update { - it.copy( - firstLaunch = true, - themeSettings = ThemeSettings(), - scheduleSettings = ScheduleSettings(), - wallpaperSettings = WallpaperSettings(), - effectSettings = EffectSettings() - ) - } } } } diff --git a/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/wallpaper_screen/WallpaperScreen.kt b/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/wallpaper_screen/WallpaperScreen.kt index 0758fc6..750e491 100644 --- a/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/wallpaper_screen/WallpaperScreen.kt +++ b/app/src/main/java/com/anthonyla/paperize/feature/wallpaper/presentation/wallpaper_screen/WallpaperScreen.kt @@ -68,7 +68,6 @@ fun WallpaperScreen( onLockCheckedChange: (Boolean) -> Unit, onScalingChange: (ScalingConstants) -> Unit, onScheduleSeparatelyChange: (Boolean) -> Unit, - onScheduleWallpaperChanger: () -> Unit, onSelectAlbum: (AlbumWithWallpaperAndFolder, Boolean, Boolean) -> Unit, onHomeTimeChange: (Int) -> Unit, onLockTimeChange: (Int) -> Unit, @@ -288,12 +287,10 @@ fun WallpaperScreen( } else { onSelectAlbum(album, lockEnabled.value, homeEnabled.value) - onScheduleWallpaperChanger() } } else { onSelectAlbum(album, lockEnabled.value, homeEnabled.value) - onScheduleWallpaperChanger() } }, onDismiss = { openBottomSheet = false },