Merge pull request #729 from naveensingh/fix_adapter_crash

Avoid modifying items while list is being updated
This commit is contained in:
Tibor Kaputa 2023-08-22 16:43:50 +02:00 committed by GitHub
commit 166998f86e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 9 additions and 6 deletions

View File

@ -51,24 +51,27 @@ class AutoCompleteTextViewAdapter(val activity: SimpleActivity, val contacts: Ar
override fun performFiltering(constraint: CharSequence?): FilterResults { override fun performFiltering(constraint: CharSequence?): FilterResults {
val filterResults = FilterResults() val filterResults = FilterResults()
if (constraint != null) { if (constraint != null) {
resultList.clear() val results = mutableListOf<SimpleContact>()
val searchString = constraint.toString().normalizeString() val searchString = constraint.toString().normalizeString()
contacts.forEach { contacts.forEach {
if (it.doesContainPhoneNumber(searchString) || it.name.contains(searchString, true)) { if (it.doesContainPhoneNumber(searchString) || it.name.contains(searchString, true)) {
resultList.add(it) results.add(it)
} }
} }
resultList.sortWith(compareBy { !it.name.startsWith(searchString, true) }) results.sortWith(compareBy { !it.name.startsWith(searchString, true) })
filterResults.values = resultList filterResults.values = results
filterResults.count = resultList.size filterResults.count = results.size
} }
return filterResults return filterResults
} }
override fun publishResults(constraint: CharSequence?, results: FilterResults?) { override fun publishResults(constraint: CharSequence?, results: FilterResults?) {
if ((results?.count ?: -1) > 0) { if (results != null && results.count > 0) {
resultList.clear()
@Suppress("UNCHECKED_CAST")
resultList.addAll(results.values as List<SimpleContact>)
notifyDataSetChanged() notifyDataSetChanged()
} else { } else {
notifyDataSetInvalidated() notifyDataSetInvalidated()