From 7dae94976d2b9d70c2d3ce8e75641d790b4af70e Mon Sep 17 00:00:00 2001 From: "Jason A. Donenfeld" Date: Sun, 22 Mar 2020 01:23:23 -0600 Subject: SettingsActivity: remove from parent instead of fixed screen Signed-off-by: Jason A. Donenfeld --- .../com/wireguard/android/activity/SettingsActivity.kt | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) (limited to 'ui/src/main/java/com/wireguard/android') diff --git a/ui/src/main/java/com/wireguard/android/activity/SettingsActivity.kt b/ui/src/main/java/com/wireguard/android/activity/SettingsActivity.kt index a6bdb187..bfbbf504 100644 --- a/ui/src/main/java/com/wireguard/android/activity/SettingsActivity.kt +++ b/ui/src/main/java/com/wireguard/android/activity/SettingsActivity.kt @@ -77,8 +77,10 @@ class SettingsActivity : ThemeChangeAwareActivity() { class SettingsFragment : PreferenceFragmentCompat() { override fun onCreatePreferences(savedInstanceState: Bundle?, key: String?) { addPreferencesFromResource(R.xml.preferences) - val screen = preferenceScreen - if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) screen.removePreference(preferenceManager.findPreference("dark_theme")) + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) { + val darkTheme = preferenceManager.findPreference("dark_theme") + darkTheme?.parent?.removePreference(darkTheme) + } val wgQuickOnlyPrefs = arrayOf( preferenceManager.findPreference("tools_installer"), preferenceManager.findPreference("restore_on_boot"), @@ -89,21 +91,21 @@ class SettingsActivity : ThemeChangeAwareActivity() { if (backend is WgQuickBackend) { wgQuickOnlyPrefs.forEach { it.isVisible = true } } else { - wgQuickOnlyPrefs.forEach { screen.removePreference(it) } + wgQuickOnlyPrefs.forEach { it.parent?.removePreference(it) } } } val moduleInstaller = preferenceManager.findPreference("module_downloader") val kernelModuleDisabler = preferenceManager.findPreference("kernel_module_disabler") moduleInstaller?.isVisible = false if (ModuleLoader.isModuleLoaded()) { - screen.removePreference(moduleInstaller) + moduleInstaller?.parent?.removePreference(moduleInstaller) } else { - screen.removePreference(kernelModuleDisabler) + kernelModuleDisabler?.parent?.removePreference(kernelModuleDisabler) Application.getAsyncWorker().runAsync(Application.getRootShell()::start).whenComplete { _, e -> if (e == null) moduleInstaller?.isVisible = true else - screen.removePreference(moduleInstaller) + moduleInstaller?.parent?.removePreference(moduleInstaller) } } } -- cgit v1.2.3