Merge pull request #81 from twain47/preference_filtering
Add a text filter to the top of preferences
This commit is contained in:
commit
610b82361a
4 changed files with 126 additions and 5 deletions
|
@ -61,6 +61,7 @@ import javax.inject.Inject
|
||||||
class MyPreferenceFragment : PreferenceFragmentCompat(), OnSharedPreferenceChangeListener, HasAndroidInjector {
|
class MyPreferenceFragment : PreferenceFragmentCompat(), OnSharedPreferenceChangeListener, HasAndroidInjector {
|
||||||
|
|
||||||
private var pluginId = -1
|
private var pluginId = -1
|
||||||
|
private var filter = ""
|
||||||
|
|
||||||
@Inject lateinit var rxBus: RxBusWrapper
|
@Inject lateinit var rxBus: RxBusWrapper
|
||||||
@Inject lateinit var resourceHelper: ResourceHelper
|
@Inject lateinit var resourceHelper: ResourceHelper
|
||||||
|
@ -115,11 +116,13 @@ class MyPreferenceFragment : PreferenceFragmentCompat(), OnSharedPreferenceChang
|
||||||
override fun setArguments(args: Bundle?) {
|
override fun setArguments(args: Bundle?) {
|
||||||
super.setArguments(args)
|
super.setArguments(args)
|
||||||
pluginId = args?.getInt("id") ?: -1
|
pluginId = args?.getInt("id") ?: -1
|
||||||
|
filter = args?.getString("filter") ?: ""
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onSaveInstanceState(outState: Bundle) {
|
override fun onSaveInstanceState(outState: Bundle) {
|
||||||
super.onSaveInstanceState(outState)
|
super.onSaveInstanceState(outState)
|
||||||
outState.putInt("id", pluginId)
|
outState.putInt("id", pluginId)
|
||||||
|
outState.putString("filter", filter)
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onDestroy() {
|
override fun onDestroy() {
|
||||||
|
@ -148,7 +151,10 @@ class MyPreferenceFragment : PreferenceFragmentCompat(), OnSharedPreferenceChang
|
||||||
override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) {
|
override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) {
|
||||||
(savedInstanceState ?: arguments)?.let { bundle ->
|
(savedInstanceState ?: arguments)?.let { bundle ->
|
||||||
if (bundle.containsKey("id")) {
|
if (bundle.containsKey("id")) {
|
||||||
pluginId = bundle.getInt("id")
|
pluginId = bundle.getInt("id") ?: -1
|
||||||
|
}
|
||||||
|
if (bundle.containsKey("filter")) {
|
||||||
|
filter = bundle.getString("filter") ?: ""
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (pluginId != -1) {
|
if (pluginId != -1) {
|
||||||
|
@ -191,6 +197,7 @@ class MyPreferenceFragment : PreferenceFragmentCompat(), OnSharedPreferenceChang
|
||||||
}
|
}
|
||||||
initSummary(preferenceScreen, pluginId != -1)
|
initSummary(preferenceScreen, pluginId != -1)
|
||||||
preprocessPreferences()
|
preprocessPreferences()
|
||||||
|
if (filter != "") updateFilterVisibility(filter, preferenceScreen)
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onSharedPreferenceChanged(sharedPreferences: SharedPreferences, key: String) {
|
override fun onSharedPreferenceChanged(sharedPreferences: SharedPreferences, key: String) {
|
||||||
|
@ -288,6 +295,33 @@ class MyPreferenceFragment : PreferenceFragmentCompat(), OnSharedPreferenceChang
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private fun updateFilterVisibility(filter: String, p: Preference): Boolean {
|
||||||
|
|
||||||
|
var visible = false
|
||||||
|
|
||||||
|
if (p is PreferenceGroup) {
|
||||||
|
for (i in 0 until p.preferenceCount) {
|
||||||
|
visible = updateFilterVisibility(filter, p.getPreference(i)) || visible
|
||||||
|
}
|
||||||
|
if (visible && p is PreferenceCategory) {
|
||||||
|
p.initialExpandedChildrenCount = Int.MAX_VALUE
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (p.key != null) {
|
||||||
|
visible = visible || p.key.contains(filter, true)
|
||||||
|
}
|
||||||
|
if (p.title != null) {
|
||||||
|
visible = visible || p.title.contains(filter, true)
|
||||||
|
}
|
||||||
|
if (p.summary != null) {
|
||||||
|
visible = visible || p.summary.contains(filter, true)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
p.isVisible = visible
|
||||||
|
return visible
|
||||||
|
}
|
||||||
|
|
||||||
private fun updatePrefSummary(pref: Preference?) {
|
private fun updatePrefSummary(pref: Preference?) {
|
||||||
if (pref is ListPreference) {
|
if (pref is ListPreference) {
|
||||||
pref.setSummary(pref.entry)
|
pref.setSummary(pref.entry)
|
||||||
|
@ -391,4 +425,9 @@ class MyPreferenceFragment : PreferenceFragmentCompat(), OnSharedPreferenceChang
|
||||||
}
|
}
|
||||||
return super.onPreferenceTreeClick(preference)
|
return super.onPreferenceTreeClick(preference)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public fun setFilter(filter: String) {
|
||||||
|
this.filter = filter
|
||||||
|
updateFilterVisibility(filter, preferenceScreen)
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -2,11 +2,15 @@ package info.nightscout.androidaps.activities
|
||||||
|
|
||||||
import android.content.Context
|
import android.content.Context
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
|
import android.text.Editable
|
||||||
|
import android.text.TextWatcher
|
||||||
import androidx.preference.PreferenceFragmentCompat
|
import androidx.preference.PreferenceFragmentCompat
|
||||||
import androidx.preference.PreferenceScreen
|
import androidx.preference.PreferenceScreen
|
||||||
import info.nightscout.androidaps.R
|
import info.nightscout.androidaps.R
|
||||||
import info.nightscout.androidaps.utils.locale.LocaleHelper
|
import info.nightscout.androidaps.utils.locale.LocaleHelper
|
||||||
import info.nightscout.androidaps.utils.resources.ResourceHelper
|
import info.nightscout.androidaps.utils.resources.ResourceHelper
|
||||||
|
import kotlinx.android.synthetic.main.activity_preferences.*
|
||||||
|
import kotlinx.android.synthetic.main.local_insight_status_item.view.*
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class PreferencesActivity : NoSplashAppCompatActivity(), PreferenceFragmentCompat.OnPreferenceStartScreenCallback {
|
class PreferencesActivity : NoSplashAppCompatActivity(), PreferenceFragmentCompat.OnPreferenceStartScreenCallback {
|
||||||
|
@ -14,18 +18,35 @@ class PreferencesActivity : NoSplashAppCompatActivity(), PreferenceFragmentCompa
|
||||||
@Inject lateinit var resourceHelper: ResourceHelper
|
@Inject lateinit var resourceHelper: ResourceHelper
|
||||||
|
|
||||||
var preferenceId = 0
|
var preferenceId = 0
|
||||||
|
var myPreferenceFragment: MyPreferenceFragment? = null
|
||||||
|
|
||||||
override fun onCreate(savedInstanceState: Bundle?) {
|
override fun onCreate(savedInstanceState: Bundle?) {
|
||||||
super.onCreate(savedInstanceState)
|
super.onCreate(savedInstanceState)
|
||||||
setContentView(R.layout.activity_single_fragment)
|
setContentView(R.layout.activity_preferences)
|
||||||
|
|
||||||
|
pref_filter.addTextChangedListener(object : TextWatcher {
|
||||||
|
override fun beforeTextChanged(s: CharSequence, start: Int, count: Int, after: Int) {}
|
||||||
|
override fun onTextChanged(s: CharSequence, start: Int, before: Int, count: Int) {
|
||||||
|
filterPreferences()
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun afterTextChanged(s: Editable) {}
|
||||||
|
})
|
||||||
|
|
||||||
|
pref_filter_clear.setOnClickListener() {
|
||||||
|
pref_filter.setText("");
|
||||||
|
}
|
||||||
|
|
||||||
title = resourceHelper.gs(R.string.nav_preferences)
|
title = resourceHelper.gs(R.string.nav_preferences)
|
||||||
supportActionBar?.setDisplayHomeAsUpEnabled(true)
|
supportActionBar?.setDisplayHomeAsUpEnabled(true)
|
||||||
supportActionBar?.setDisplayShowHomeEnabled(true)
|
supportActionBar?.setDisplayShowHomeEnabled(true)
|
||||||
val myPreferenceFragment = MyPreferenceFragment()
|
myPreferenceFragment = MyPreferenceFragment()
|
||||||
preferenceId = intent.getIntExtra("id", -1)
|
preferenceId = intent.getIntExtra("id", -1)
|
||||||
val args = Bundle()
|
val args = Bundle()
|
||||||
args.putInt("id", preferenceId)
|
args.putInt("id", preferenceId)
|
||||||
myPreferenceFragment.arguments = args
|
args.putString("filter", pref_filter.text.toString())
|
||||||
supportFragmentManager.beginTransaction().replace(R.id.frame_layout, myPreferenceFragment).commit()
|
myPreferenceFragment?.arguments = args
|
||||||
|
supportFragmentManager.beginTransaction().replace(R.id.frame_layout, myPreferenceFragment!!).commit()
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onPreferenceStartScreen(caller: PreferenceFragmentCompat, pref: PreferenceScreen): Boolean {
|
override fun onPreferenceStartScreen(caller: PreferenceFragmentCompat, pref: PreferenceScreen): Boolean {
|
||||||
|
@ -44,4 +65,8 @@ class PreferencesActivity : NoSplashAppCompatActivity(), PreferenceFragmentCompa
|
||||||
override fun attachBaseContext(newBase: Context) {
|
override fun attachBaseContext(newBase: Context) {
|
||||||
super.attachBaseContext(LocaleHelper.wrap(newBase))
|
super.attachBaseContext(LocaleHelper.wrap(newBase))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private fun filterPreferences() {
|
||||||
|
myPreferenceFragment?.setFilter(pref_filter.text.toString())
|
||||||
|
}
|
||||||
}
|
}
|
55
app/src/main/res/layout/activity_preferences.xml
Normal file
55
app/src/main/res/layout/activity_preferences.xml
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:orientation="horizontal">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginStart="10dp"
|
||||||
|
android:layout_marginEnd="10dp"
|
||||||
|
android:layout_gravity="center_vertical"
|
||||||
|
android:text="@string/filter"
|
||||||
|
android:textAppearance="@android:style/TextAppearance.Material.Medium"
|
||||||
|
android:textStyle="bold" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/pref_filter"
|
||||||
|
android:layout_width="0dp"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:layout_gravity="center_vertical"
|
||||||
|
android:inputType="text" />
|
||||||
|
|
||||||
|
<ImageView
|
||||||
|
android:id="@+id/pref_filter_clear"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_gravity="center_vertical"
|
||||||
|
android:layout_marginStart="10dp"
|
||||||
|
android:layout_marginEnd="10dp"
|
||||||
|
app:srcCompat="@android:drawable/ic_menu_close_clear_cancel" />
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
<ScrollView
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:fillViewport="true">
|
||||||
|
|
||||||
|
<FrameLayout
|
||||||
|
android:id="@+id/frame_layout"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"></FrameLayout>
|
||||||
|
|
||||||
|
</ScrollView>
|
||||||
|
|
||||||
|
</LinearLayout>
|
|
@ -1466,4 +1466,6 @@
|
||||||
<string name="uploaded_data">Uploaded Data</string>
|
<string name="uploaded_data">Uploaded Data</string>
|
||||||
<string name="the_following_data_will_be_uploaded_to_your_open_humans_account">The following data will be uploaded to your Open Humans account: Glucose values, boluses, carbs, careportal events (except notes), extended boluses, profile switches, total daily doses, temporary basals, temp targets, preferences, application version, device model and screen dimensions. Secret or private information such as your Nightscout URL or API secret will not be uploaded.</string>
|
<string name="the_following_data_will_be_uploaded_to_your_open_humans_account">The following data will be uploaded to your Open Humans account: Glucose values, boluses, carbs, careportal events (except notes), extended boluses, profile switches, total daily doses, temporary basals, temp targets, preferences, application version, device model and screen dimensions. Secret or private information such as your Nightscout URL or API secret will not be uploaded.</string>
|
||||||
<string name="setupwizard_pump_riley_link_status">RileyLink status:</string>
|
<string name="setupwizard_pump_riley_link_status">RileyLink status:</string>
|
||||||
|
<string name="filter">Filter</string>
|
||||||
|
|
||||||
</resources>
|
</resources>
|
||||||
|
|
Loading…
Reference in a new issue