From f43f1c2d178adac0b7d06c8383f4888471078977 Mon Sep 17 00:00:00 2001 From: deeppp15 Date: Thu, 12 Dec 2024 16:54:12 -0500 Subject: [PATCH 1/3] onConfigChanged better logic --- .../ole/planet/myplanet/MainApplication.kt | 22 +++++++++++++------ 1 file changed, 15 insertions(+), 7 deletions(-) diff --git a/app/src/main/java/org/ole/planet/myplanet/MainApplication.kt b/app/src/main/java/org/ole/planet/myplanet/MainApplication.kt index a14ce8359e..39029e1065 100644 --- a/app/src/main/java/org/ole/planet/myplanet/MainApplication.kt +++ b/app/src/main/java/org/ole/planet/myplanet/MainApplication.kt @@ -55,7 +55,7 @@ class MainApplication : Application(), Application.ActivityLifecycleCallbacks { private const val AUTO_SYNC_WORK_TAG = "autoSyncWork" private const val STAY_ONLINE_WORK_TAG = "stayOnlineWork" private const val TASK_NOTIFICATION_WORK_TAG = "taskNotificationWork" - lateinit var context: Context + lateinit var context: Context lateinit var mRealm: Realm lateinit var service: DatabaseService var preferences: SharedPreferences? = null @@ -218,10 +218,8 @@ class MainApplication : Application(), Application.ActivityLifecycleCallbacks { registerActivityLifecycleCallbacks(this) onAppStarted() - val sharedPreferences = getSharedPreferences("app_preferences", MODE_PRIVATE) - val themeMode = sharedPreferences.getString("theme_mode", ThemeMode.FOLLOW_SYSTEM) - - applyThemeMode(themeMode) + val savedThemeMode = getCurrentThemeMode() + applyThemeMode(savedThemeMode) isNetworkConnectedFlow.onEach { isConnected -> if (isConnected) { @@ -274,7 +272,12 @@ class MainApplication : Application(), Application.ActivityLifecycleCallbacks { override fun onConfigurationChanged(newConfig: android.content.res.Configuration) { super.onConfigurationChanged(newConfig) - LocaleHelper.onAttach(this) + + val savedThemeMode = getCurrentThemeMode() + if (savedThemeMode != ThemeMode.FOLLOW_SYSTEM) { + return + } + val currentNightMode = newConfig.uiMode and android.content.res.Configuration.UI_MODE_NIGHT_MASK when (currentNightMode) { android.content.res.Configuration.UI_MODE_NIGHT_NO -> { @@ -286,6 +289,11 @@ class MainApplication : Application(), Application.ActivityLifecycleCallbacks { } } + private fun getCurrentThemeMode(): String { + val sharedPreferences = context.getSharedPreferences(PREFS_NAME, MODE_PRIVATE) + return sharedPreferences.getString("theme_mode", ThemeMode.FOLLOW_SYSTEM) ?: ThemeMode.FOLLOW_SYSTEM + } + override fun onActivityCreated(activity: Activity, bundle: Bundle?) {} override fun onActivityStarted(activity: Activity) { @@ -320,7 +328,7 @@ class MainApplication : Application(), Application.ActivityLifecycleCallbacks { } } } - + private fun onAppBackgrounded() {} private fun onAppStarted() { From 6e29dbb96da619e9fefa9d0261ed7da0dc406b21 Mon Sep 17 00:00:00 2001 From: deeppp15 Date: Tue, 17 Dec 2024 15:23:12 -0500 Subject: [PATCH 2/3] synced prefs and commit --- .../java/org/ole/planet/myplanet/MainApplication.kt | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/app/src/main/java/org/ole/planet/myplanet/MainApplication.kt b/app/src/main/java/org/ole/planet/myplanet/MainApplication.kt index 39029e1065..70c0049d1f 100644 --- a/app/src/main/java/org/ole/planet/myplanet/MainApplication.kt +++ b/app/src/main/java/org/ole/planet/myplanet/MainApplication.kt @@ -5,6 +5,7 @@ import android.app.Application import android.content.Context import android.content.Intent import android.content.SharedPreferences +import android.content.res.Configuration import android.os.Bundle import android.os.StrictMode import android.os.StrictMode.VmPolicy @@ -111,10 +112,10 @@ class MainApplication : Application(), Application.ActivityLifecycleCallbacks { } fun setThemeMode(themeMode: String) { - val sharedPreferences = context.getSharedPreferences("app_preferences", MODE_PRIVATE) + val sharedPreferences = context.getSharedPreferences(PREFS_NAME, MODE_PRIVATE) with(sharedPreferences.edit()) { putString("theme_mode", themeMode) - apply() + commit() } applyThemeMode(themeMode) } @@ -272,13 +273,17 @@ class MainApplication : Application(), Application.ActivityLifecycleCallbacks { override fun onConfigurationChanged(newConfig: android.content.res.Configuration) { super.onConfigurationChanged(newConfig) - + val currentNightMode = context.resources.configuration.uiMode and Configuration.UI_MODE_NIGHT_MASK + val isSystemNight= when (currentNightMode) { + Configuration.UI_MODE_NIGHT_YES -> true + Configuration.UI_MODE_NIGHT_NO -> false + else -> false + } val savedThemeMode = getCurrentThemeMode() if (savedThemeMode != ThemeMode.FOLLOW_SYSTEM) { return } - val currentNightMode = newConfig.uiMode and android.content.res.Configuration.UI_MODE_NIGHT_MASK when (currentNightMode) { android.content.res.Configuration.UI_MODE_NIGHT_NO -> { applyThemeMode(ThemeMode.LIGHT) From 374a13a0338291f314eda2ae7e4271a421cc3791 Mon Sep 17 00:00:00 2001 From: dogi Date: Wed, 18 Dec 2024 14:27:51 -0500 Subject: [PATCH 3/3] Update build.gradle --- app/build.gradle | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/app/build.gradle b/app/build.gradle index 402b2213cd..e489f37262 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -10,8 +10,8 @@ android { applicationId "org.ole.planet.myplanet" minSdkVersion 26 targetSdkVersion 34 - versionCode 2142 - versionName "0.21.42" + versionCode 2143 + versionName "0.21.43" ndkVersion '21.3.6528147' testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" vectorDrawables.useSupportLibrary = true