From 77e07d405ef02236594160a57c8b5bce09bee244 Mon Sep 17 00:00:00 2001 From: tibbi Date: Fri, 19 Nov 2021 18:56:49 +0100 Subject: [PATCH] lets ignore photos at comparing if a contact details changed, to avoid redraws --- .../pro/fragments/MyViewPagerFragment.kt | 9 +++- .../contacts/pro/models/Contact.kt | 49 +++++++++++++++---- 2 files changed, 47 insertions(+), 11 deletions(-) diff --git a/app/src/main/kotlin/com/simplemobiletools/contacts/pro/fragments/MyViewPagerFragment.kt b/app/src/main/kotlin/com/simplemobiletools/contacts/pro/fragments/MyViewPagerFragment.kt index fd5415f4..6818d3eb 100644 --- a/app/src/main/kotlin/com/simplemobiletools/contacts/pro/fragments/MyViewPagerFragment.kt +++ b/app/src/main/kotlin/com/simplemobiletools/contacts/pro/fragments/MyViewPagerFragment.kt @@ -127,9 +127,14 @@ abstract class MyViewPagerFragment(context: Context, attributeSet: AttributeSet) } } - if (filtered.hashCode() != lastHashCode || skipHashComparing) { + var currentHash = 0 + filtered.forEach { + currentHash += it.getHashWithoutPrivatePhoto() + } + + if (currentHash != lastHashCode || skipHashComparing) { skipHashComparing = false - lastHashCode = filtered.hashCode() + lastHashCode = currentHash activity?.runOnUiThread { setupContacts(filtered) } diff --git a/app/src/main/kotlin/com/simplemobiletools/contacts/pro/models/Contact.kt b/app/src/main/kotlin/com/simplemobiletools/contacts/pro/models/Contact.kt index 6f5dc1d1..748e09c4 100644 --- a/app/src/main/kotlin/com/simplemobiletools/contacts/pro/models/Contact.kt +++ b/app/src/main/kotlin/com/simplemobiletools/contacts/pro/models/Contact.kt @@ -7,11 +7,13 @@ import com.simplemobiletools.commons.extensions.normalizeString import com.simplemobiletools.commons.helpers.* import com.simplemobiletools.contacts.pro.helpers.SMT_PRIVATE -data class Contact(var id: Int, var prefix: String, var firstName: String, var middleName: String, var surname: String, var suffix: String, var nickname: String, - var photoUri: String, var phoneNumbers: ArrayList, var emails: ArrayList, var addresses: ArrayList
, - var events: ArrayList, var source: String, var starred: Int, var contactId: Int, var thumbnailUri: String, var photo: Bitmap?, var notes: String, - var groups: ArrayList, var organization: Organization, var websites: ArrayList, var IMs: ArrayList, var mimetype: String, - var ringtone: String?) : +data class Contact( + var id: Int, var prefix: String, var firstName: String, var middleName: String, var surname: String, var suffix: String, var nickname: String, + var photoUri: String, var phoneNumbers: ArrayList, var emails: ArrayList, var addresses: ArrayList
, + var events: ArrayList, var source: String, var starred: Int, var contactId: Int, var thumbnailUri: String, var photo: Bitmap?, var notes: String, + var groups: ArrayList, var organization: Organization, var websites: ArrayList, var IMs: ArrayList, var mimetype: String, + var ringtone: String? +) : Comparable { companion object { var sorting = 0 @@ -121,10 +123,38 @@ data class Contact(var id: Int, var prefix: String, var firstName: String, var m } } + // photos stored locally always have different hashcodes. Avoid constantly refreshing the contact lists as the app thinks something changed. + fun getHashWithoutPrivatePhoto(): Int { + val photoToUse = if (isPrivate()) null else photo + return copy(photo = photoToUse).hashCode() + } + fun getStringToCompare(): String { - return copy(id = 0, prefix = "", firstName = getNameToDisplay().toLowerCase(), middleName = "", surname = "", suffix = "", nickname = "", photoUri = "", - phoneNumbers = ArrayList(), emails = ArrayList(), events = ArrayList(), source = "", addresses = ArrayList(), starred = 0, contactId = 0, - thumbnailUri = "", notes = "", groups = ArrayList(), websites = ArrayList(), organization = Organization("", ""), IMs = ArrayList(), ringtone = "").toString() + return copy( + id = 0, + prefix = "", + firstName = getNameToDisplay().toLowerCase(), + middleName = "", + surname = "", + suffix = "", + nickname = "", + photoUri = "", + phoneNumbers = ArrayList(), + emails = ArrayList(), + events = ArrayList(), + source = "", + addresses = ArrayList(), + starred = 0, + contactId = 0, + thumbnailUri = "", + photo = null, + notes = "", + groups = ArrayList(), + websites = ArrayList(), + organization = Organization("", ""), + IMs = ArrayList(), + ringtone = "" + ).toString() } fun getHashToCompare() = getStringToCompare().hashCode() @@ -135,7 +165,8 @@ data class Contact(var id: Int, var prefix: String, var firstName: String, var m return fullOrganization.trim().trimEnd(',') } - fun isABusinessContact() = prefix.isEmpty() && firstName.isEmpty() && middleName.isEmpty() && surname.isEmpty() && suffix.isEmpty() && organization.isNotEmpty() + fun isABusinessContact() = + prefix.isEmpty() && firstName.isEmpty() && middleName.isEmpty() && surname.isEmpty() && suffix.isEmpty() && organization.isNotEmpty() fun doesContainPhoneNumber(text: String, convertLetters: Boolean): Boolean { return if (text.isNotEmpty()) {