refresh GroupContactsActivity on resume

This commit is contained in:
tibbi
2018-03-20 15:34:36 +01:00
parent 6d4f9912fd
commit c572a83bb1
2 changed files with 34 additions and 23 deletions

View File

@ -29,7 +29,6 @@ class GroupContactsActivity : SimpleActivity(), RemoveFromGroupListener {
group = intent.extras.getSerializable(GROUP) as Group group = intent.extras.getSerializable(GROUP) as Group
supportActionBar?.title = group.title supportActionBar?.title = group.title
refreshContacts()
group_contacts_fab.setOnClickListener { group_contacts_fab.setOnClickListener {
SelectContactsDialog(this, allContacts, groupContacts) { addedContacts, removedContacts -> SelectContactsDialog(this, allContacts, groupContacts) { addedContacts, removedContacts ->
ContactsHelper(this).apply { ContactsHelper(this).apply {
@ -41,6 +40,11 @@ class GroupContactsActivity : SimpleActivity(), RemoveFromGroupListener {
} }
} }
override fun onResume() {
super.onResume()
refreshContacts()
}
private fun refreshContacts() { private fun refreshContacts() {
ContactsHelper(this).getContacts { ContactsHelper(this).getContacts {
allContacts = it allContacts = it
@ -54,6 +58,8 @@ class GroupContactsActivity : SimpleActivity(), RemoveFromGroupListener {
} }
private fun updateContacts(contacts: ArrayList<Contact>) { private fun updateContacts(contacts: ArrayList<Contact>) {
val currAdapter = group_contacts_list.adapter
if (currAdapter == null) {
ContactsAdapter(this, contacts, null, LOCATION_GROUP_CONTACTS, this, group_contacts_list, group_contacts_fastscroller) { ContactsAdapter(this, contacts, null, LOCATION_GROUP_CONTACTS, this, group_contacts_list, group_contacts_fastscroller) {
when (config.onContactClick) { when (config.onContactClick) {
ON_CLICK_CALL_CONTACT -> { ON_CLICK_CALL_CONTACT -> {
@ -78,6 +84,9 @@ class GroupContactsActivity : SimpleActivity(), RemoveFromGroupListener {
val item = (group_contacts_list.adapter as ContactsAdapter).contactItems.getOrNull(it) val item = (group_contacts_list.adapter as ContactsAdapter).contactItems.getOrNull(it)
group_contacts_fastscroller.updateBubbleText(item?.getBubbleText() ?: "") group_contacts_fastscroller.updateBubbleText(item?.getBubbleText() ?: "")
} }
} else {
(currAdapter as ContactsAdapter).updateItems(contacts)
}
} }
override fun removeFromGroup(contacts: ArrayList<Contact>) { override fun removeFromGroup(contacts: ArrayList<Contact>) {

View File

@ -110,10 +110,12 @@ class ContactsAdapter(activity: SimpleActivity, var contactItems: ArrayList<Cont
} }
fun updateItems(newItems: ArrayList<Contact>) { fun updateItems(newItems: ArrayList<Contact>) {
if (newItems.hashCode() != contactItems.hashCode()) {
contactItems = newItems contactItems = newItems
notifyDataSetChanged() notifyDataSetChanged()
finishActMode() finishActMode()
} }
}
private fun editContact() { private fun editContact() {
activity.editContact(contactItems[selectedPositions.first()]) activity.editContact(contactItems[selectedPositions.first()])