mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-11 06:47:01 +00:00
fix(Contacts): Resolve edge cases while addind/removing a contact
This commit is contained in:
parent
e160e70121
commit
8ff42d0868
@ -129,22 +129,20 @@ proc addItemToAppropriateModel(self: Module, item: UserItem) =
|
|||||||
if(singletonInstance.userProfile.getPubKey() == item.pubKey):
|
if(singletonInstance.userProfile.getPubKey() == item.pubKey):
|
||||||
return
|
return
|
||||||
let contact = self.controller.getContact(item.pubKey())
|
let contact = self.controller.getContact(item.pubKey())
|
||||||
if(contact.isContactRemoved()):
|
|
||||||
return
|
if contact.isBlocked():
|
||||||
elif(contact.isBlocked()):
|
|
||||||
self.view.blockedContactsModel().addItem(item)
|
self.view.blockedContactsModel().addItem(item)
|
||||||
elif(contact.isContact()):
|
return
|
||||||
|
|
||||||
|
case contact.requestState:
|
||||||
|
of ContactRequestState.Received:
|
||||||
|
self.view.receivedContactRequestsModel().addItem(item)
|
||||||
|
of ContactRequestState.Sent:
|
||||||
|
self.view.sentContactRequestsModel().addItem(item)
|
||||||
|
of ContactRequestState.Mutual:
|
||||||
self.view.myMutualContactsModel().addItem(item)
|
self.view.myMutualContactsModel().addItem(item)
|
||||||
else:
|
else:
|
||||||
if(contact.isContactRequestReceived() and not contact.isContactRequestSent()):
|
return
|
||||||
self.view.receivedContactRequestsModel().addItem(item)
|
|
||||||
elif(contact.isContactRequestSent() and not contact.isContactRequestReceived()):
|
|
||||||
self.view.sentContactRequestsModel().addItem(item)
|
|
||||||
# Temporary commented until we provide appropriate flags on the `status-go` side to cover all sections.
|
|
||||||
# elif(contact.isContactRequestReceived() and contact.isReceivedContactRequestRejected()):
|
|
||||||
# self.view.receivedButRejectedContactRequestsModel().addItem(item)
|
|
||||||
# elif(contact.isContactRequestSent() and contact.isSentContactRequestRejected()):
|
|
||||||
# self.view.sentButRejectedContactRequestsModel().addItem(item)
|
|
||||||
|
|
||||||
proc removeItemWithPubKeyFromAllModels(self: Module, publicKey: string) =
|
proc removeItemWithPubKeyFromAllModels(self: Module, publicKey: string) =
|
||||||
self.view.myMutualContactsModel().removeItemById(publicKey)
|
self.view.myMutualContactsModel().removeItemById(publicKey)
|
||||||
@ -172,9 +170,6 @@ method contactUnblocked*(self: Module, publicKey: string) =
|
|||||||
method contactRemoved*(self: Module, publicKey: string) =
|
method contactRemoved*(self: Module, publicKey: string) =
|
||||||
self.removeIfExistsAndAddToAppropriateModel(publicKey)
|
self.removeIfExistsAndAddToAppropriateModel(publicKey)
|
||||||
|
|
||||||
method contactRequestRejectionRemoved*(self: Module, publicKey: string) =
|
|
||||||
self.removeIfExistsAndAddToAppropriateModel(publicKey)
|
|
||||||
|
|
||||||
method contactUpdated*(self: Module, publicKey: string) =
|
method contactUpdated*(self: Module, publicKey: string) =
|
||||||
self.removeIfExistsAndAddToAppropriateModel(publicKey)
|
self.removeIfExistsAndAddToAppropriateModel(publicKey)
|
||||||
|
|
||||||
|
@ -48,6 +48,9 @@ QtObject:
|
|||||||
self.endResetModel()
|
self.endResetModel()
|
||||||
self.countChanged()
|
self.countChanged()
|
||||||
|
|
||||||
|
for item in items:
|
||||||
|
self.itemChanged(item.pubKey)
|
||||||
|
|
||||||
proc `$`*(self: Model): string =
|
proc `$`*(self: Model): string =
|
||||||
for i in 0 ..< self.items.len:
|
for i in 0 ..< self.items.len:
|
||||||
result &= fmt"""User Model:
|
result &= fmt"""User Model:
|
||||||
|
@ -358,6 +358,10 @@ Pane {
|
|||||||
if (d.isCurrentUser)
|
if (d.isCurrentUser)
|
||||||
return btnEditProfileComponent
|
return btnEditProfileComponent
|
||||||
|
|
||||||
|
// blocked contact
|
||||||
|
if (d.isBlocked)
|
||||||
|
return btnUnblockUserComponent
|
||||||
|
|
||||||
// contact request, outgoing, rejected
|
// contact request, outgoing, rejected
|
||||||
if (!d.isContact && d.isContactRequestSent && d.outgoingVerificationStatus === Constants.verificationStatus.declined)
|
if (!d.isContact && d.isContactRequestSent && d.outgoingVerificationStatus === Constants.verificationStatus.declined)
|
||||||
return txtRejectedContactRequestComponent
|
return txtRejectedContactRequestComponent
|
||||||
@ -388,10 +392,6 @@ Pane {
|
|||||||
if (!d.isContact && !d.isBlocked && !d.isContactRequestSent)
|
if (!d.isContact && !d.isBlocked && !d.isContactRequestSent)
|
||||||
return btnSendContactRequestComponent
|
return btnSendContactRequestComponent
|
||||||
|
|
||||||
// blocked contact
|
|
||||||
if (d.isBlocked)
|
|
||||||
return btnUnblockUserComponent
|
|
||||||
|
|
||||||
// send message
|
// send message
|
||||||
if (d.isContact && !d.isBlocked)
|
if (d.isContact && !d.isBlocked)
|
||||||
return btnSendMessageComponent
|
return btnSendMessageComponent
|
||||||
|
Loading…
x
Reference in New Issue
Block a user