mirror of
https://github.com/moparisthebest/k-9
synced 2025-01-09 12:48:02 -05:00
keep track of stacked notifications when updating existing (summary-) notifications.
This commit is contained in:
parent
e5b8b669c2
commit
8d6d0c7d37
@ -222,7 +222,7 @@ public class MessagingController implements Runnable {
|
|||||||
/**
|
/**
|
||||||
* Stacked notifications that share this notification as ther summary-notification.
|
* Stacked notifications that share this notification as ther summary-notification.
|
||||||
*/
|
*/
|
||||||
List<Integer> stackdNotifications;
|
Map<String, Integer> stackdNotifications;
|
||||||
/**
|
/**
|
||||||
* List of references for messages that the user is still to be notified of,
|
* List of references for messages that the user is still to be notified of,
|
||||||
* but which don't fit into the inbox style anymore. It's sorted from newest
|
* but which don't fit into the inbox style anymore. It's sorted from newest
|
||||||
@ -265,19 +265,55 @@ public class MessagingController implements Runnable {
|
|||||||
messages.addFirst(m);
|
messages.addFirst(m);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addStackedChildNotification(final int notificationId) {
|
/**
|
||||||
|
* Add a stacked notification that this is a summary notification for.
|
||||||
|
* @param ref
|
||||||
|
* @param notificationId
|
||||||
|
*/
|
||||||
|
public void addStackedChildNotification(final MessageReference ref, final int notificationId) {
|
||||||
if (stackdNotifications == null) {
|
if (stackdNotifications == null) {
|
||||||
stackdNotifications = new LinkedList<Integer>();
|
stackdNotifications = new HashMap<String, Integer>();
|
||||||
}
|
}
|
||||||
stackdNotifications.add(new Integer(notificationId));
|
stackdNotifications.put(ref.getUid(), new Integer(notificationId));
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* Add a stacked notification that this is a summary notification for.
|
||||||
|
* @param msg
|
||||||
|
* @param notificationId
|
||||||
|
*/
|
||||||
|
public void addStackedChildNotification(final Message msg, final int notificationId) {
|
||||||
|
if (stackdNotifications == null) {
|
||||||
|
stackdNotifications = new HashMap<String, Integer>();
|
||||||
|
}
|
||||||
|
stackdNotifications.put(msg.getUid(), new Integer(notificationId));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return the IDs of all stacked notifications this is a summary notification for.
|
||||||
|
*/
|
||||||
|
public Collection<Integer> getStackedChildNotifications() {
|
||||||
|
return stackdNotifications.values();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param ref
|
||||||
|
* @return null or the notification ID of a stacked notification for the given message
|
||||||
|
*/
|
||||||
|
public Integer getStackedChildNotification(final MessageReference ref) {
|
||||||
|
return stackdNotifications.get(ref.getUid());
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* @param msg
|
||||||
|
* @return null or the notification ID of a stacked notification for the given message
|
||||||
|
*/
|
||||||
|
public Integer getStackedChildNotification(final Message msg) {
|
||||||
|
return stackdNotifications.get(msg.getUid());
|
||||||
}
|
}
|
||||||
public List<Integer> getStackedChildNotifications() {
|
|
||||||
return stackdNotifications;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Remove a certain message from the message list.
|
* Remove a certain message from the message list.
|
||||||
*
|
* @see #getStackedChildNotification(com.fsck.k9.activity.MessageReference) for stacked
|
||||||
|
* notifications you may consider to cancel.
|
||||||
* @param context A context.
|
* @param context A context.
|
||||||
* @param ref Reference of the message to remove
|
* @param ref Reference of the message to remove
|
||||||
* @return true if message was found and removed, false otherwise
|
* @return true if message was found and removed, false otherwise
|
||||||
@ -1848,12 +1884,23 @@ public class MessagingController implements Runnable {
|
|||||||
synchronized (data) {
|
synchronized (data) {
|
||||||
MessageReference ref = localMessage.makeMessageReference();
|
MessageReference ref = localMessage.makeMessageReference();
|
||||||
if (data.removeMatchingMessage(context, ref)) {
|
if (data.removeMatchingMessage(context, ref)) {
|
||||||
|
synchronized (data) {
|
||||||
|
// if we remove a single message from the notification,
|
||||||
|
// maybe there is a stacked notification active for that one message
|
||||||
|
Integer childNotification = data.getStackedChildNotification(ref);
|
||||||
|
if (childNotification != null) {
|
||||||
|
NotificationManager notificationManager =
|
||||||
|
(NotificationManager)context.getSystemService(Context.NOTIFICATION_SERVICE);
|
||||||
|
notificationManager.cancel(childNotification);
|
||||||
|
}
|
||||||
|
// update the (summary-) notification
|
||||||
notifyAccountWithDataLocked(context, account, null, data);
|
notifyAccountWithDataLocked(context, account, null, data);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
progress.incrementAndGet();
|
progress.incrementAndGet();
|
||||||
for (MessagingListener l : getListeners()) {
|
for (MessagingListener l : getListeners()) {
|
||||||
l.synchronizeMailboxProgress(account, folder, progress.get(), todo);
|
l.synchronizeMailboxProgress(account, folder, progress.get(), todo);
|
||||||
@ -4784,11 +4831,11 @@ public class MessagingController implements Runnable {
|
|||||||
/**
|
/**
|
||||||
* Build the specific notification actions for a single message on Android Wear.
|
* Build the specific notification actions for a single message on Android Wear.
|
||||||
*/
|
*/
|
||||||
private void addWearActions(final NotificationCompat.Builder builder, final Account account, final Message messages) {
|
private void addWearActions(final NotificationCompat.Builder builder, final Account account, final Message message) {
|
||||||
ArrayList<MessageReference> subAllRefs = new ArrayList<MessageReference>();
|
ArrayList<MessageReference> subAllRefs = new ArrayList<MessageReference>();
|
||||||
subAllRefs.add(new MessageReference(account.getUuid(), messages.getFolder().getName(), messages.getUid(), messages.getFlags().size()==0?null:messages.getFlags().iterator().next()));
|
subAllRefs.add(new MessageReference(account.getUuid(), message.getFolder().getName(), message.getUid(), message.getFlags().size()==0?null:message.getFlags().iterator().next()));
|
||||||
LinkedList<Message> msgList = new LinkedList<Message>();
|
LinkedList<Message> msgList = new LinkedList<Message>();
|
||||||
msgList.add(messages);
|
msgList.add(message);
|
||||||
addWearActions(builder, 1, account, subAllRefs, msgList);
|
addWearActions(builder, 1, account, subAllRefs, msgList);
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
@ -4931,8 +4978,12 @@ public class MessagingController implements Runnable {
|
|||||||
|
|
||||||
// this must be done before the summary notification
|
// this must be done before the summary notification
|
||||||
nID = 1000 + nID;
|
nID = 1000 + nID;
|
||||||
|
Integer realnID = data.getStackedChildNotification(m);
|
||||||
|
if (realnID == null) {
|
||||||
|
realnID = nID;
|
||||||
|
}
|
||||||
notifMgr.notify(nID, subBuilder.build());
|
notifMgr.notify(nID, subBuilder.build());
|
||||||
data.addStackedChildNotification(nID);
|
data.addStackedChildNotification(m, realnID);
|
||||||
}
|
}
|
||||||
if (!data.droppedMessages.isEmpty()) {
|
if (!data.droppedMessages.isEmpty()) {
|
||||||
style.setSummaryText(context.getString(R.string.notification_additional_messages,
|
style.setSummaryText(context.getString(R.string.notification_additional_messages,
|
||||||
@ -5287,7 +5338,7 @@ public class MessagingController implements Runnable {
|
|||||||
// cancel stacked notifications on Android Wear that share this as a summary notification
|
// cancel stacked notifications on Android Wear that share this as a summary notification
|
||||||
NotificationData data = notificationData.get(account.getAccountNumber());
|
NotificationData data = notificationData.get(account.getAccountNumber());
|
||||||
if (data != null) {
|
if (data != null) {
|
||||||
List<Integer> stackedChildNotifications = data.getStackedChildNotifications();
|
Collection<Integer> stackedChildNotifications = data.getStackedChildNotifications();
|
||||||
if (stackedChildNotifications != null) {
|
if (stackedChildNotifications != null) {
|
||||||
for (Integer stackedNotificationId : stackedChildNotifications) {
|
for (Integer stackedNotificationId : stackedChildNotifications) {
|
||||||
notificationManager.cancel(stackedNotificationId);
|
notificationManager.cancel(stackedNotificationId);
|
||||||
|
Loading…
Reference in New Issue
Block a user