From 0f95a7babef385f9fc24d41d61c8fb54d6d59ed8 Mon Sep 17 00:00:00 2001 From: topjohnwu Date: Fri, 9 Apr 2021 01:00:26 -0700 Subject: [PATCH] Do not hold resources in SuperuserViewModel --- .../topjohnwu/magisk/di/ViewModelsModule.kt | 4 +--- .../topjohnwu/magisk/events/SnackbarEvent.kt | 18 +++++++++--------- .../magisk/ui/superuser/SuperuserViewModel.kt | 11 +++++------ .../topjohnwu/magisk/utils/TransitiveText.kt | 1 - 4 files changed, 15 insertions(+), 19 deletions(-) diff --git a/app/src/main/java/com/topjohnwu/magisk/di/ViewModelsModule.kt b/app/src/main/java/com/topjohnwu/magisk/di/ViewModelsModule.kt index 63214b228..aa2722f92 100644 --- a/app/src/main/java/com/topjohnwu/magisk/di/ViewModelsModule.kt +++ b/app/src/main/java/com/topjohnwu/magisk/di/ViewModelsModule.kt @@ -23,12 +23,10 @@ val viewModelModules = module { viewModel { ModuleViewModel(get(), get()) } viewModel { SafetynetViewModel() } viewModel { SettingsViewModel(get()) } - viewModel { SuperuserViewModel(get(), get()) } + viewModel { SuperuserViewModel(get()) } viewModel { ThemeViewModel() } viewModel { InstallViewModel(get()) } viewModel { MainViewModel() } - - // Legacy viewModel { (args: FlashFragmentArgs) -> FlashViewModel(args) } viewModel { SuRequestViewModel(get(), get(), get(SUTimeout), get()) } } diff --git a/app/src/main/java/com/topjohnwu/magisk/events/SnackbarEvent.kt b/app/src/main/java/com/topjohnwu/magisk/events/SnackbarEvent.kt index 9b0cd3fd7..51f9e0911 100644 --- a/app/src/main/java/com/topjohnwu/magisk/events/SnackbarEvent.kt +++ b/app/src/main/java/com/topjohnwu/magisk/events/SnackbarEvent.kt @@ -7,31 +7,32 @@ import com.topjohnwu.magisk.arch.ActivityExecutor import com.topjohnwu.magisk.arch.BaseUIActivity import com.topjohnwu.magisk.arch.ViewEvent import com.topjohnwu.magisk.utils.TransitiveText +import com.topjohnwu.magisk.utils.asTransitive -class SnackbarEvent private constructor( +class SnackbarEvent constructor( private val msg: TransitiveText, - private val length: Int, - private val builder: Snackbar.() -> Unit + private val length: Int = Snackbar.LENGTH_SHORT, + private val builder: Snackbar.() -> Unit = {} ) : ViewEvent(), ActivityExecutor { constructor( @StringRes res: Int, length: Int = Snackbar.LENGTH_SHORT, builder: Snackbar.() -> Unit = {} - ) : this(TransitiveText.Res(res), length, builder) + ) : this(res.asTransitive(), length, builder) constructor( - message: String, + msg: String, length: Int = Snackbar.LENGTH_SHORT, builder: Snackbar.() -> Unit = {} - ) : this(TransitiveText.String(message), length, builder) + ) : this(msg.asTransitive(), length, builder) private fun snackbar( view: View, message: String, - length: Int = Snackbar.LENGTH_SHORT, - builder: Snackbar.() -> Unit = {} + length: Int, + builder: Snackbar.() -> Unit ) = Snackbar.make(view, message, length).apply(builder).show() override fun invoke(activity: BaseUIActivity<*, *>) { @@ -39,5 +40,4 @@ class SnackbarEvent private constructor( msg.getText(activity.resources).toString(), length, builder) } - } diff --git a/app/src/main/java/com/topjohnwu/magisk/ui/superuser/SuperuserViewModel.kt b/app/src/main/java/com/topjohnwu/magisk/ui/superuser/SuperuserViewModel.kt index e2ad4a764..aeb40a1ca 100644 --- a/app/src/main/java/com/topjohnwu/magisk/ui/superuser/SuperuserViewModel.kt +++ b/app/src/main/java/com/topjohnwu/magisk/ui/superuser/SuperuserViewModel.kt @@ -1,6 +1,5 @@ package com.topjohnwu.magisk.ui.superuser -import android.content.res.Resources import androidx.databinding.ObservableArrayList import androidx.lifecycle.viewModelScope import com.topjohnwu.magisk.BR @@ -19,6 +18,7 @@ import com.topjohnwu.magisk.events.SnackbarEvent import com.topjohnwu.magisk.events.dialog.BiometricEvent import com.topjohnwu.magisk.events.dialog.SuperuserRevokeDialog import com.topjohnwu.magisk.utils.Utils +import com.topjohnwu.magisk.utils.asTransitive import com.topjohnwu.magisk.view.TappableHeadlineItem import com.topjohnwu.magisk.view.TextItem import kotlinx.coroutines.Dispatchers @@ -27,8 +27,7 @@ import kotlinx.coroutines.withContext import me.tatarka.bindingcollectionadapter2.collections.MergeObservableList class SuperuserViewModel( - private val db: PolicyDao, - private val resources: Resources + private val db: PolicyDao ) : BaseViewModel(), TappableHeadlineItem.Listener { private val itemNoData = TextItem(R.string.superuser_policy_none) @@ -107,7 +106,7 @@ class SuperuserViewModel( fun updatePolicy(policy: SuPolicy, isLogging: Boolean) = viewModelScope.launch { db.update(policy) - val str = when { + val res = when { isLogging -> when { policy.logging -> R.string.su_snack_log_on else -> R.string.su_snack_log_off @@ -117,7 +116,7 @@ class SuperuserViewModel( else -> R.string.su_snack_notif_off } } - SnackbarEvent(resources.getString(str, policy.appName)).publish() + SnackbarEvent(res.asTransitive(policy.appName)).publish() } fun togglePolicy(item: PolicyRvItem, enable: Boolean) { @@ -131,7 +130,7 @@ class SuperuserViewModel( db.update(app) val res = if (app.policy == SuPolicy.ALLOW) R.string.su_snack_grant else R.string.su_snack_deny - SnackbarEvent(resources.getString(res).format(item.item.appName)).publish() + SnackbarEvent(res.asTransitive(item.item.appName)).publish() } } diff --git a/app/src/main/java/com/topjohnwu/magisk/utils/TransitiveText.kt b/app/src/main/java/com/topjohnwu/magisk/utils/TransitiveText.kt index dd5f87e25..1eff396c5 100644 --- a/app/src/main/java/com/topjohnwu/magisk/utils/TransitiveText.kt +++ b/app/src/main/java/com/topjohnwu/magisk/utils/TransitiveText.kt @@ -37,7 +37,6 @@ sealed class TransitiveText { companion object { val EMPTY = String("") } - }