1
0
Fork 0
mirror of https://github.com/M66B/FairEmail.git synced 2025-01-04 06:20:26 +00:00

Update notifications on device only

This commit is contained in:
M66B 2019-10-17 17:14:46 +02:00
parent c1c3f25029
commit 6aae8c4270

View file

@ -2653,8 +2653,8 @@ class Core {
// Difference // Difference
for (long group : groupMessages.keySet()) { for (long group : groupMessages.keySet()) {
int new_messages = 0;
List<Long> add = new ArrayList<>(); List<Long> add = new ArrayList<>();
List<Long> update = new ArrayList<>();
List<Long> remove = new ArrayList<>(groupNotifying.get(group)); List<Long> remove = new ArrayList<>(groupNotifying.get(group));
for (TupleMessageEx message : groupMessages.get(group)) { for (TupleMessageEx message : groupMessages.get(group)) {
long id = (message.content ? message.id : -message.id); long id = (message.content ? message.id : -message.id);
@ -2664,14 +2664,16 @@ class Core {
} else { } else {
add.add(id); add.add(id);
boolean existing = remove.contains(-id); boolean existing = remove.contains(-id);
if (existing) if (existing) {
update.add(id);
remove.remove(-id); remove.remove(-id);
else }
new_messages++;
Log.i("Notify adding=" + id + " existing=" + existing); Log.i("Notify adding=" + id + " existing=" + existing);
} }
} }
int new_messages = add.size() - update.size();
if (notify_summary if (notify_summary
? remove.size() + new_messages == 0 ? remove.size() + new_messages == 0
: remove.size() + add.size() == 0) { : remove.size() + add.size() == 0) {
@ -2680,7 +2682,7 @@ class Core {
} }
// Build notifications // Build notifications
List<Notification> notifications = getNotificationUnseen(context, List<NotificationCompat.Builder> notifications = getNotificationUnseen(context,
group, groupMessages.get(group), group, groupMessages.get(group),
notify_summary, new_messages, notify_summary, new_messages,
biometrics && !biometric_notify); biometrics && !biometric_notify);
@ -2711,10 +2713,13 @@ class Core {
db.message().setMessageNotifying(Math.abs(id), (int) Math.signum(id)); db.message().setMessageNotifying(Math.abs(id), (int) Math.signum(id));
} }
for (Notification notification : notifications) { for (NotificationCompat.Builder builder : notifications) {
long id = notification.extras.getLong("id", 0); long id = builder.getExtras().getLong("id", 0);
if ((id == 0 && add.size() + remove.size() > 0) || add.contains(id)) { if ((id == 0 && add.size() + remove.size() > 0) || add.contains(id)) {
if (update.contains(id))
builder.setLocalOnly(true);
String tag = "unseen." + group + "." + Math.abs(id); String tag = "unseen." + group + "." + Math.abs(id);
Notification notification = builder.build();
Log.i("Notifying tag=" + tag + " id=" + id + Log.i("Notifying tag=" + tag + " id=" + id +
(Build.VERSION.SDK_INT < Build.VERSION_CODES.O ? "" : " channel=" + notification.getChannelId())); (Build.VERSION.SDK_INT < Build.VERSION_CODES.O ? "" : " channel=" + notification.getChannelId()));
nm.notify(tag, 1, notification); nm.notify(tag, 1, notification);
@ -2723,11 +2728,11 @@ class Core {
} }
} }
private static List<Notification> getNotificationUnseen( private static List<NotificationCompat.Builder> getNotificationUnseen(
Context context, Context context,
long group, List<TupleMessageEx> messages, long group, List<TupleMessageEx> messages,
boolean notify_summary, int new_messages, boolean redacted) { boolean notify_summary, int new_messages, boolean redacted) {
List<Notification> notifications = new ArrayList<>(); List<NotificationCompat.Builder> notifications = new ArrayList<>();
// Android 7+ N https://developer.android.com/training/notify-user/group // Android 7+ N https://developer.android.com/training/notify-user/group
// Android 8+ O https://developer.android.com/training/notify-user/channels // Android 8+ O https://developer.android.com/training/notify-user/channels
@ -2842,7 +2847,7 @@ class Core {
.setSummaryText(title)); .setSummaryText(title));
} }
notifications.add(builder.build()); notifications.add(builder);
} }
if (notify_summary) if (notify_summary)
@ -3099,7 +3104,7 @@ class Core {
mbuilder.setColorized(true); mbuilder.setColorized(true);
} }
notifications.add(mbuilder.build()); notifications.add(mbuilder);
} }
return notifications; return notifications;