0
0
Fork 0
mirror of https://github.com/YTVanced/VancedManager synced 2024-11-29 22:43:01 +00:00

AppVersionSelectorDialog and VancedThemeSelectorDialog migrate to view binding

This commit is contained in:
HaliksaR 2020-11-15 23:48:22 +07:00
parent a1d4cdbbe5
commit a3767e4c9e
5 changed files with 139 additions and 110 deletions

View file

@ -2,72 +2,91 @@ package com.vanced.manager.ui.dialogs
import android.content.DialogInterface import android.content.DialogInterface
import android.os.Bundle import android.os.Bundle
import android.util.Log
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 com.google.android.material.bottomsheet.BottomSheetDialogFragment
import com.google.android.material.radiobutton.MaterialRadioButton import com.google.android.material.radiobutton.MaterialRadioButton
import com.vanced.manager.R import com.vanced.manager.R
import com.vanced.manager.databinding.DialogBottomRadioButtonBinding import com.vanced.manager.databinding.DialogBottomRadioButtonBinding
import com.vanced.manager.ui.core.BindingBottomSheetDialogFragment
import com.vanced.manager.utils.Extensions.getCheckedButtonTag import com.vanced.manager.utils.Extensions.getCheckedButtonTag
import com.vanced.manager.utils.Extensions.getDefaultPrefs import com.vanced.manager.utils.Extensions.getDefaultPrefs
import com.vanced.manager.utils.Extensions.show import com.vanced.manager.utils.Extensions.show
class AppVersionSelectorDialog( class AppVersionSelectorDialog : BindingBottomSheetDialogFragment<DialogBottomRadioButtonBinding>() {
private val versions: List<String>?,
private val app: String
) : BottomSheetDialogFragment() {
private lateinit var binding: DialogBottomRadioButtonBinding
private val prefs by lazy { requireActivity().getDefaultPrefs() } private val prefs by lazy { requireActivity().getDefaultPrefs() }
override fun onCreateView( companion object {
private const val TAG_VERSIONS = "TAG_VERSIONS"
private const val TAG_APP = "TAG_APP"
fun newInstance(
versions: List<String>?,
app: String
): AppVersionSelectorDialog = AppVersionSelectorDialog().apply {
arguments = Bundle().apply {
val arrayList = arrayListOf<String>()
versions?.let { arrayList.addAll(it) }
putStringArrayList(TAG_VERSIONS, arrayList)
putString(TAG_APP, app)
}
}
}
override fun binding(
inflater: LayoutInflater, inflater: LayoutInflater,
container: ViewGroup?, container: ViewGroup?,
savedInstanceState: Bundle? savedInstanceState: Bundle?
): View? { ) = DialogBottomRadioButtonBinding.inflate(inflater, container, false)
binding = DataBindingUtil.inflate(inflater, R.layout.dialog_bottom_radio_button, 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) {
loadBoxes() loadBoxes()?.forEach { mrb ->
val tag = view.findViewWithTag<MaterialRadioButton>(prefs.getString("${app}_version", "latest")) dialogRadiogroup.addView(
mrb,
ViewGroup.LayoutParams.MATCH_PARENT,
ViewGroup.LayoutParams.WRAP_CONTENT
)
}
val tag = root.findViewWithTag<MaterialRadioButton>(
prefs.getString("${arguments?.getString(TAG_APP)}_version", "latest")
)
if (tag != null) { if (tag != null) {
tag.isChecked = true tag.isChecked = true
} }
binding.dialogTitle.text = requireActivity().getString(R.string.version) dialogTitle.text = getString(R.string.version)
binding.dialogSave.setOnClickListener { dialogSave.setOnClickListener {
val checkedTag = binding.dialogRadiogroup.getCheckedButtonTag() val checkedTag = dialogRadiogroup.getCheckedButtonTag()
if (checkedTag != null) if (checkedTag != null) {
prefs.edit { putString("${app}_version", checkedTag) } prefs.edit { putString("${arguments?.getString(TAG_APP)}_version", checkedTag) }
}
dismiss() dismiss()
} }
} }
}
private fun loadBoxes() { private fun loadBoxes() =
requireActivity().runOnUiThread { arguments?.getStringArrayList(TAG_VERSIONS)?.map { version ->
versions?.forEach { version -> MaterialRadioButton(requireActivity()).apply {
val rb = MaterialRadioButton(requireActivity()).apply {
text = version text = version
tag = version tag = version
textSize = 18f textSize = 18f
} }
binding.dialogRadiogroup.addView(rb, ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT)
}
}
} }
override fun onDismiss(dialog: DialogInterface) { override fun onDismiss(dialog: DialogInterface) {
super.onDismiss(dialog) super.onDismiss(dialog)
if (app == "vanced") if (arguments?.getString(TAG_APP) == "vanced") {
VancedPreferencesDialog().show(requireActivity()) VancedPreferencesDialog().show(requireActivity())
else } else {
MusicPreferencesDialog().show(requireActivity()) MusicPreferencesDialog().show(requireActivity())
} }
}
} }

View file

@ -37,7 +37,10 @@ class MusicPreferencesDialog : BottomSheetDialogFragment() {
binding.openVersionSelector.setOnClickListener { binding.openVersionSelector.setOnClickListener {
dismiss() dismiss()
AppVersionSelectorDialog(musicVersionsConv, "music").show(requireActivity()) AppVersionSelectorDialog.newInstance(
versions = musicVersionsConv,
app = "music"
).show(requireActivity())
} }
binding.musicInstall.setOnClickListener { binding.musicInstall.setOnClickListener {
dismiss() dismiss()

View file

@ -56,7 +56,10 @@ class VancedPreferencesDialog : BottomSheetDialogFragment() {
binding.openVersionSelector.setOnClickListener { binding.openVersionSelector.setOnClickListener {
dismiss() dismiss()
AppVersionSelectorDialog(vancedVersionsConv, "vanced").show(requireActivity()) AppVersionSelectorDialog.newInstance(
versions = vancedVersionsConv,
app = "vanced"
).show(requireActivity())
} }
binding.openLanguageSelector.setOnClickListener { binding.openLanguageSelector.setOnClickListener {

View file

@ -12,57 +12,67 @@ import com.google.android.material.bottomsheet.BottomSheetDialogFragment
import com.google.android.material.radiobutton.MaterialRadioButton import com.google.android.material.radiobutton.MaterialRadioButton
import com.vanced.manager.R import com.vanced.manager.R
import com.vanced.manager.databinding.DialogBottomRadioButtonBinding import com.vanced.manager.databinding.DialogBottomRadioButtonBinding
import com.vanced.manager.ui.core.BindingBottomSheetDialogFragment
import com.vanced.manager.utils.Extensions.convertToAppTheme import com.vanced.manager.utils.Extensions.convertToAppTheme
import com.vanced.manager.utils.Extensions.getCheckedButtonTag import com.vanced.manager.utils.Extensions.getCheckedButtonTag
import com.vanced.manager.utils.Extensions.show import com.vanced.manager.utils.Extensions.show
import com.vanced.manager.utils.InternetTools.vanced import com.vanced.manager.utils.InternetTools.vanced
class VancedThemeSelectorDialog : BottomSheetDialogFragment() { class VancedThemeSelectorDialog : BindingBottomSheetDialogFragment<DialogBottomRadioButtonBinding>() {
companion object {
fun newInstance(): VancedThemeSelectorDialog = VancedThemeSelectorDialog().apply {
arguments = Bundle()
}
}
private lateinit var binding: DialogBottomRadioButtonBinding
private val prefs by lazy { requireActivity().getSharedPreferences("installPrefs", Context.MODE_PRIVATE) } private val prefs by lazy { requireActivity().getSharedPreferences("installPrefs", Context.MODE_PRIVATE) }
override fun onCreateView( override fun binding(
inflater: LayoutInflater, inflater: LayoutInflater,
container: ViewGroup?, container: ViewGroup?,
savedInstanceState: Bundle? savedInstanceState: Bundle?
): View? { ) = DialogBottomRadioButtonBinding.inflate(inflater, container, false)
binding = DataBindingUtil.inflate(inflater, R.layout.dialog_bottom_radio_button, container, false)
return binding.root override fun otherSetups() {
bindData()
} }
override fun onViewCreated(view: View, savedInstanceState: Bundle?) { private fun bindData() {
loadButtons() with(binding) {
binding.dialogTitle.text = requireActivity().getString(R.string.theme) loadButtons()?.forEach { mrb ->
val tag = view.findViewWithTag<MaterialRadioButton>(prefs.getString("theme", "dark")) dialogRadiogroup.addView(
mrb,
ViewGroup.LayoutParams.MATCH_PARENT,
ViewGroup.LayoutParams.WRAP_CONTENT
)
}
dialogTitle.text = requireActivity().getString(R.string.theme)
val tag = root.findViewWithTag<MaterialRadioButton>(prefs.getString("theme", "dark"))
if (tag != null) { if (tag != null) {
tag.isChecked = true tag.isChecked = true
} }
binding.dialogSave.setOnClickListener { dialogSave.setOnClickListener {
val checkedTag = binding.dialogRadiogroup.getCheckedButtonTag() val checkedTag = binding.dialogRadiogroup.getCheckedButtonTag()
if (checkedTag != null) if (checkedTag != null) {
prefs.edit { putString("theme", checkedTag) } prefs.edit { putString("theme", checkedTag) }
}
dismiss() dismiss()
} }
} }
}
private fun loadButtons() { private fun loadButtons() = vanced.get()?.array<String>("themes")?.value?.map {theme ->
requireActivity().runOnUiThread { MaterialRadioButton(requireActivity()).apply {
vanced.get()?.array<String>("themes")?.value?.forEach { theme ->
val rb = MaterialRadioButton(requireActivity()).apply {
text = theme.convertToAppTheme(requireActivity()) text = theme.convertToAppTheme(requireActivity())
tag = theme tag = theme
textSize = 18f textSize = 18f
} }
binding.dialogRadiogroup.addView(rb, ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT)
}
}
} }
override fun onDismiss(dialog: DialogInterface) { override fun onDismiss(dialog: DialogInterface) {
super.onDismiss(dialog) super.onDismiss(dialog)
VancedPreferencesDialog().show(requireActivity()) VancedPreferencesDialog().show(requireActivity())
} }
} }

View file

@ -1,7 +1,6 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<layout> <com.google.android.material.card.MaterialCardView
xmlns:android="http://schemas.android.com/apk/res/android"
<com.google.android.material.card.MaterialCardView xmlns:android="http://schemas.android.com/apk/res/android"
style="@style/BottomDialogCard"> style="@style/BottomDialogCard">
<LinearLayout <LinearLayout
@ -11,7 +10,7 @@
<TextView <TextView
android:id="@+id/dialog_title" android:id="@+id/dialog_title"
style="@style/BottomDialogCardTitle" /> style="@style/BottomDialogCardTitle"/>
<androidx.core.widget.NestedScrollView <androidx.core.widget.NestedScrollView
android:layout_width="match_parent" android:layout_width="match_parent"
@ -23,16 +22,11 @@
android:layout_height="wrap_content"> android:layout_height="wrap_content">
</RadioGroup> </RadioGroup>
</androidx.core.widget.NestedScrollView> </androidx.core.widget.NestedScrollView>
<com.google.android.material.button.MaterialButton <com.google.android.material.button.MaterialButton
android:id="@+id/dialog_save" android:id="@+id/dialog_save"
style="@style/BottomDialogButtonStyle" android:text="@string/save"
android:text="@string/save" /> style="@style/BottomDialogButtonStyle"/>
</LinearLayout> </LinearLayout>
</com.google.android.material.card.MaterialCardView>
</com.google.android.material.card.MaterialCardView>
</layout>