From 13029e3047cf021ff98ea816008e0f514b79fc0c Mon Sep 17 00:00:00 2001 From: sudden6 Date: Sun, 7 May 2017 13:41:17 +0200 Subject: [PATCH] fix(groupinvite): prevent multiple groupinvites to the same group from showing up fix #2305 --- src/widget/form/groupinviteform.cpp | 11 ++++++++++- src/widget/form/groupinviteform.h | 2 +- src/widget/widget.cpp | 4 +++- 3 files changed, 14 insertions(+), 3 deletions(-) diff --git a/src/widget/form/groupinviteform.cpp b/src/widget/form/groupinviteform.cpp index 9219dee9f..6e6afc897 100644 --- a/src/widget/form/groupinviteform.cpp +++ b/src/widget/form/groupinviteform.cpp @@ -114,9 +114,16 @@ void GroupInviteForm::show(ContentLayout* contentLayout) * @param friendId Id of a friend that invited you * @param type Type of the invitation - text or AV * @param invite Information that invited person needs to see an invitation + * @return true if notification is needed, false otherwise */ -void GroupInviteForm::addGroupInvite(int32_t friendId, uint8_t type, QByteArray invite) +bool GroupInviteForm::addGroupInvite(int32_t friendId, uint8_t type, QByteArray invite) { + // supress duplicate invite messages + for (GroupInviteWidget* existing : invites) { + if (existing->getInviteInfo().getInvite() == invite) { + return false; + } + } GroupInviteWidget* widget = new GroupInviteWidget(this, GroupInvite(friendId, type, invite)); scroll->widget()->layout()->addWidget(widget); invites.append(widget); @@ -129,7 +136,9 @@ void GroupInviteForm::addGroupInvite(int32_t friendId, uint8_t type, QByteArray [this](const GroupInvite& inviteInfo) { deleteInviteWidget(inviteInfo); }); if (isVisible()) { emit groupInvitesSeen(); + return false; } + return true; } void GroupInviteForm::showEvent(QShowEvent* event) diff --git a/src/widget/form/groupinviteform.h b/src/widget/form/groupinviteform.h index 0e576b395..14ca807ac 100644 --- a/src/widget/form/groupinviteform.h +++ b/src/widget/form/groupinviteform.h @@ -46,7 +46,7 @@ public: ~GroupInviteForm(); void show(ContentLayout* contentLayout); - void addGroupInvite(int32_t friendId, uint8_t type, QByteArray invite); + bool addGroupInvite(int32_t friendId, uint8_t type, QByteArray invite); bool isShown() const; signals: diff --git a/src/widget/widget.cpp b/src/widget/widget.cpp index 030324f2e..e6a73d019 100644 --- a/src/widget/widget.cpp +++ b/src/widget/widget.cpp @@ -1565,10 +1565,12 @@ void Widget::onGroupInviteReceived(int32_t friendId, uint8_t type, QByteArray in if (Settings::getInstance().getAutoGroupInvite(f->getPublicKey())) { onGroupInviteAccepted(friendId, type, invite); } else { + if (!groupInviteForm->addGroupInvite(friendId, type, invite)) { + return; + } ++unreadGroupInvites; groupInvitesUpdate(); newMessageAlert(window(), isActiveWindow(), true, true); - groupInviteForm->addGroupInvite(friendId, type, invite); } } else { qWarning() << "onGroupInviteReceived: Unknown groupchat type:" << type;