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:
parent
c1c3f25029
commit
6aae8c4270
1 changed files with 16 additions and 11 deletions
|
@ -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;
|
||||||
|
|
Loading…
Reference in a new issue