ManagerVariantDialog migrate to view binding

This commit is contained in:
HaliksaR 2020-11-16 00:24:19 +07:00
parent 874b5d6f90
commit 7e05a3846f
2 changed files with 70 additions and 69 deletions

View File

@ -2,48 +2,55 @@ package com.vanced.manager.ui.dialogs
import android.os.Bundle import android.os.Bundle
import android.view.LayoutInflater import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup import android.view.ViewGroup
import androidx.core.content.edit import androidx.core.content.edit
import androidx.databinding.DataBindingUtil import androidx.preference.PreferenceManager.*
import androidx.preference.PreferenceManager.getDefaultSharedPreferences
import com.google.android.material.bottomsheet.BottomSheetDialogFragment
import com.google.android.material.radiobutton.MaterialRadioButton import com.google.android.material.radiobutton.MaterialRadioButton
import com.topjohnwu.superuser.Shell import com.topjohnwu.superuser.Shell
import com.vanced.manager.R
import com.vanced.manager.databinding.DialogManagerVariantBinding import com.vanced.manager.databinding.DialogManagerVariantBinding
import com.vanced.manager.ui.core.BindingBottomSheetDialogFragment
import com.vanced.manager.utils.Extensions.getCheckedButtonTag import com.vanced.manager.utils.Extensions.getCheckedButtonTag
class ManagerVariantDialog : BottomSheetDialogFragment() { class ManagerVariantDialog : BindingBottomSheetDialogFragment<DialogManagerVariantBinding>() {
companion object {
fun newInstance(): ManagerVariantDialog = ManagerVariantDialog().apply {
arguments = Bundle()
}
}
private lateinit var binding: DialogManagerVariantBinding
private val prefs by lazy { getDefaultSharedPreferences(requireActivity()) } private val prefs by lazy { getDefaultSharedPreferences(requireActivity()) }
override fun onCreateView( override fun binding(
inflater: LayoutInflater, inflater: LayoutInflater,
container: ViewGroup?, container: ViewGroup?,
savedInstanceState: Bundle? savedInstanceState: Bundle?
): View? { ) = DialogManagerVariantBinding.inflate(inflater, container, false)
binding = DataBindingUtil.inflate(inflater, R.layout.dialog_manager_variant, container, false)
return binding.root override fun otherSetups() {
bindData()
} }
override fun onViewCreated(view: View, savedInstanceState: Bundle?) { private fun bindData() {
super.onViewCreated(view, savedInstanceState) with(binding) {
val variant = prefs.getString("vanced_variant", "nonroot") val variant = prefs.getString("vanced_variant", "nonroot")
view.findViewWithTag<MaterialRadioButton>(variant).isChecked = true root.findViewWithTag<MaterialRadioButton>(variant).isChecked = true
binding.variantSave.setOnClickListener { variantSave.setOnClickListener {
val newPref = binding.variantRadiogroup.getCheckedButtonTag() val newPref = variantRadiogroup.getCheckedButtonTag()
if (variant != newPref) { if (variant != newPref) {
if (newPref == "root" && Shell.rootAccess()) prefs.edit {
prefs.edit { putString("vanced_variant", "root") } if (newPref == "root" && Shell.rootAccess()) {
else putString("vanced_variant", "root")
prefs.edit { putString("vanced_variant", "nonroot") } } else {
putString("vanced_variant", "nonroot")
dismiss() }
requireActivity().recreate() }
} else { dismiss()
dismiss() requireActivity().recreate()
} else {
dismiss()
}
} }
} }
} }

View File

@ -1,53 +1,47 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<layout xmlns:tools="http://schemas.android.com/tools"> <com.google.android.material.card.MaterialCardView
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
style="@style/BottomDialogCard">
<com.google.android.material.card.MaterialCardView xmlns:android="http://schemas.android.com/apk/res/android" <LinearLayout
style="@style/BottomDialogCard"> android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<LinearLayout <TextView
android:text="@string/variant"
style="@style/BottomDialogCardTitle"/>
<androidx.core.widget.NestedScrollView
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="wrap_content" android:layout_height="wrap_content">
android:orientation="vertical">
<TextView <RadioGroup
style="@style/BottomDialogCardTitle" android:id="@+id/variant_radiogroup"
android:text="@string/variant" />
<androidx.core.widget.NestedScrollView
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="wrap_content"> android:layout_height="wrap_content"
tools:ignore="HardcodedText">
<RadioGroup <com.google.android.material.radiobutton.MaterialRadioButton
android:id="@+id/variant_radiogroup"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="wrap_content" android:layout_height="wrap_content"
tools:ignore="HardcodedText"> android:tag="nonroot"
android:text="nonroot"
android:textSize="18sp"/>
<com.google.android.material.radiobutton.MaterialRadioButton <com.google.android.material.radiobutton.MaterialRadioButton
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:tag="nonroot" android:tag="root"
android:text="nonroot" android:text="root"
android:textSize="18sp" /> android:textSize="18sp"/>
</RadioGroup>
</androidx.core.widget.NestedScrollView>
<com.google.android.material.radiobutton.MaterialRadioButton <com.google.android.material.button.MaterialButton
android:layout_width="match_parent" android:id="@+id/variant_save"
android:layout_height="wrap_content" android:text="@string/save"
android:tag="root" style="@style/BottomDialogButtonStyle"/>
android:text="root" </LinearLayout>
android:textSize="18sp" /> </com.google.android.material.card.MaterialCardView>
</RadioGroup>
</androidx.core.widget.NestedScrollView>
<com.google.android.material.button.MaterialButton
android:id="@+id/variant_save"
style="@style/BottomDialogButtonStyle"
android:text="@string/save" />
</LinearLayout>
</com.google.android.material.card.MaterialCardView>
</layout>