Skip to content

Commit

Permalink
Merge pull request #5851 from nextcloud/feature/remove-seen-talk-noti…
Browse files Browse the repository at this point in the history
…fications

Remove seen Talk notificatios from Tray window.
  • Loading branch information
allexzander committed Jul 6, 2023
2 parents 88b4c7e + b56200e commit 4cc1395
Show file tree
Hide file tree
Showing 4 changed files with 21 additions and 0 deletions.
9 changes: 9 additions & 0 deletions src/gui/tray/activitylistmodel.cpp
Expand Up @@ -689,6 +689,15 @@ void ActivityListModel::removeActivityFromActivityList(const Activity &activity)
}
}

void ActivityListModel::checkAndRemoveSeenActivities(const OCC::ActivityList &newActivities)
{
for (const auto &activity : _finalList) {
if (activity._objectType == QStringLiteral("chat") && !newActivities.contains(activity)) {
removeActivityFromActivityList(activity);
}
}
}

void ActivityListModel::slotTriggerDefaultAction(const int activityIndex)
{
if (activityIndex < 0 || activityIndex >= _finalList.size()) {
Expand Down
2 changes: 2 additions & 0 deletions src/gui/tray/activitylistmodel.h
Expand Up @@ -134,6 +134,8 @@ public slots:
void removeActivityFromActivityList(int row);
void removeActivityFromActivityList(const OCC::Activity &activity);

void checkAndRemoveSeenActivities(const OCC::ActivityList &newActivities);

void setAccountState(OCC::AccountState *state);
void setReplyMessageSent(const int activityIndex, const QString &message);
void setCurrentItem(const int currentItem);
Expand Down
8 changes: 8 additions & 0 deletions src/gui/tray/usermodel.cpp
Expand Up @@ -221,13 +221,21 @@ void User::slotBuildNotificationDisplay(const ActivityList &list)
return;
}

auto chatNotificationsReceivedCount = 0;

for(const auto &activity : qAsConst(toNotifyList)) {
if (activity._objectType == QStringLiteral("chat")) {
++chatNotificationsReceivedCount;
showDesktopTalkNotification(activity);
} else {
showDesktopNotification(activity);
}
}

if (chatNotificationsReceivedCount < _lastChatNotificationsReceivedCount) {
_activityModel->checkAndRemoveSeenActivities(toNotifyList);
}
_lastChatNotificationsReceivedCount = chatNotificationsReceivedCount;
}

void User::slotBuildIncomingCallDialogs(const ActivityList &list)
Expand Down
2 changes: 2 additions & 0 deletions src/gui/tray/usermodel.h
Expand Up @@ -182,6 +182,8 @@ private slots:
// number of currently running notification requests. If non zero,
// no query for notifications is started.
int _notificationRequestsRunning = 0;

int _lastChatNotificationsReceivedCount = 0;
};

class UserModel : public QAbstractListModel
Expand Down

0 comments on commit 4cc1395

Please sign in to comment.