2020-07-17 16:35:39 +02:00
|
|
|
package sushi.hardcore.droidfs
|
|
|
|
|
|
|
|
import android.os.Bundle
|
2020-08-29 21:20:15 +02:00
|
|
|
import android.view.MenuItem
|
2020-08-07 22:40:13 +02:00
|
|
|
import androidx.core.content.ContextCompat
|
2020-07-17 16:35:39 +02:00
|
|
|
import androidx.preference.Preference
|
|
|
|
import androidx.preference.PreferenceFragmentCompat
|
2020-08-07 22:40:13 +02:00
|
|
|
import com.jaredrummler.android.colorpicker.ColorPreferenceCompat
|
2020-07-17 16:35:39 +02:00
|
|
|
import kotlinx.android.synthetic.main.toolbar.*
|
2020-08-07 22:40:13 +02:00
|
|
|
import sushi.hardcore.droidfs.widgets.SimpleActionPreference
|
2020-07-21 15:05:05 +02:00
|
|
|
import sushi.hardcore.droidfs.widgets.ThemeColor
|
2020-07-17 16:35:39 +02:00
|
|
|
|
2020-07-21 15:05:05 +02:00
|
|
|
class SettingsActivity : BaseActivity(), PreferenceFragmentCompat.OnPreferenceStartFragmentCallback {
|
2020-07-17 16:35:39 +02:00
|
|
|
|
|
|
|
override fun onCreate(savedInstanceState: Bundle?) {
|
|
|
|
super.onCreate(savedInstanceState)
|
|
|
|
setContentView(R.layout.activity_settings)
|
|
|
|
setSupportActionBar(toolbar)
|
|
|
|
supportActionBar?.setDisplayHomeAsUpEnabled(true)
|
|
|
|
val screen = intent.extras?.getString("screen") ?: "main"
|
2020-08-29 21:20:15 +02:00
|
|
|
val fragment = if (screen == "UnsafeFeaturesSettingsFragment") {
|
2020-07-17 16:35:39 +02:00
|
|
|
UnsafeFeaturesSettingsFragment()
|
|
|
|
} else {
|
2020-08-29 21:20:15 +02:00
|
|
|
MainSettingsFragment()
|
2020-07-17 16:35:39 +02:00
|
|
|
}
|
|
|
|
supportFragmentManager
|
|
|
|
.beginTransaction()
|
|
|
|
.replace(R.id.settings, fragment)
|
|
|
|
.commit()
|
|
|
|
}
|
|
|
|
|
2020-08-29 21:20:15 +02:00
|
|
|
override fun onOptionsItemSelected(item: MenuItem): Boolean {
|
|
|
|
return when (item.itemId){
|
|
|
|
android.R.id.home -> {
|
|
|
|
onBackPressed() //return to the previous fragment rather than the activity
|
|
|
|
true
|
|
|
|
}
|
|
|
|
else -> super.onOptionsItemSelected(item)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class MainSettingsFragment : PreferenceFragmentCompat() {
|
2020-07-17 16:35:39 +02:00
|
|
|
override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) {
|
|
|
|
setPreferencesFromResource(R.xml.root_preferences, rootKey)
|
2020-07-21 15:05:05 +02:00
|
|
|
ThemeColor.tintPreferenceIcons(preferenceScreen, ThemeColor.getThemeColor(requireContext()))
|
2020-08-07 22:40:13 +02:00
|
|
|
var originalThemeColor: Int? = null
|
|
|
|
context?.let {
|
|
|
|
originalThemeColor = ContextCompat.getColor(it, R.color.themeColor)
|
|
|
|
}
|
|
|
|
findPreference<ColorPreferenceCompat>("themeColor")?.let { colorPicker ->
|
|
|
|
colorPicker.onPreferenceChangeListener = Preference.OnPreferenceChangeListener{ _, _ ->
|
|
|
|
(activity as SettingsActivity).changeThemeColor()
|
|
|
|
true
|
|
|
|
}
|
|
|
|
findPreference<SimpleActionPreference>("resetThemeColor")?.onClick = {
|
|
|
|
originalThemeColor?.let {
|
|
|
|
colorPicker.saveValue(it)
|
|
|
|
val settingsActivity = (activity as SettingsActivity)
|
|
|
|
Thread {
|
|
|
|
settingsActivity.sharedPrefs.edit().commit()
|
|
|
|
settingsActivity.runOnUiThread { settingsActivity.changeThemeColor() }
|
|
|
|
}.start()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-07-17 16:35:39 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class UnsafeFeaturesSettingsFragment : PreferenceFragmentCompat() {
|
|
|
|
override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) {
|
|
|
|
setPreferencesFromResource(R.xml.unsafe_features_preferences, rootKey)
|
2020-07-21 15:05:05 +02:00
|
|
|
ThemeColor.tintPreferenceIcons(preferenceScreen, ThemeColor.getThemeColor(requireContext()))
|
2020-07-17 16:35:39 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
override fun onPreferenceStartFragment(caller: PreferenceFragmentCompat, pref: Preference): Boolean {
|
|
|
|
val fragment = supportFragmentManager.fragmentFactory.instantiate(classLoader, pref.fragment)
|
|
|
|
fragment.arguments = pref.extras
|
|
|
|
fragment.setTargetFragment(caller, 0)
|
|
|
|
supportFragmentManager.beginTransaction().replace(R.id.settings, fragment).addToBackStack(null).commit()
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|