From 078578303dd58cdc93e9ea89bbf4d5bca1513fb8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kayra=20=C3=96zenalp?= Date: Tue, 10 Oct 2023 23:13:44 +0300 Subject: [PATCH] #7 - Add DataStoreRepository to Data --- .../io1/data/datastore/DataStoreRepository.kt | 46 +++++++++++++++++++ 1 file changed, 46 insertions(+) create mode 100644 data/src/main/java/com/io1/data/datastore/DataStoreRepository.kt diff --git a/data/src/main/java/com/io1/data/datastore/DataStoreRepository.kt b/data/src/main/java/com/io1/data/datastore/DataStoreRepository.kt new file mode 100644 index 0000000..2790a21 --- /dev/null +++ b/data/src/main/java/com/io1/data/datastore/DataStoreRepository.kt @@ -0,0 +1,46 @@ +package com.io1.data.datastore + +import android.content.Context +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.preferencesDataStore +import kotlinx.coroutines.flow.Flow +import kotlinx.coroutines.flow.catch +import kotlinx.coroutines.flow.map +import java.io.IOException + +val Context.dataStore: DataStore by preferencesDataStore(name = "on_boarding_pref") + + +class DataStoreRepository(context: Context) { + + private object PreferencesKey { + val onBoardingKey = booleanPreferencesKey(name = "on_boarding_completed") + } + + private val dataStore = context.dataStore + + suspend fun saveOnBoardingState(completed: Boolean) { + dataStore.edit { preferences -> + preferences[PreferencesKey.onBoardingKey] = completed + } + } + + fun readOnBoardingState(): Flow { + return dataStore.data + .catch { exception -> + if (exception is IOException) { + emit(emptyPreferences()) + } else { + throw exception + } + } + .map { preferences -> + val onBoardingState = preferences[PreferencesKey.onBoardingKey] ?: false + onBoardingState + } + } +} \ No newline at end of file