From df401e90b02f9502b485a845aa4346fc7ca8e0f9 Mon Sep 17 00:00:00 2001 From: Konrad Pozniak Date: Sun, 26 May 2019 08:45:25 +0200 Subject: [PATCH] improve performance when clearing notifications (#1283) --- .../tusky/util/NotificationHelper.java | 22 +++++++++++++------ 1 file changed, 15 insertions(+), 7 deletions(-) diff --git a/app/src/main/java/com/keylesspalace/tusky/util/NotificationHelper.java b/app/src/main/java/com/keylesspalace/tusky/util/NotificationHelper.java index 21841212..1de3b912 100644 --- a/app/src/main/java/com/keylesspalace/tusky/util/NotificationHelper.java +++ b/app/src/main/java/com/keylesspalace/tusky/util/NotificationHelper.java @@ -65,6 +65,9 @@ import java.util.LinkedHashSet; import java.util.List; import java.util.concurrent.ExecutionException; +import io.reactivex.Single; +import io.reactivex.schedulers.Schedulers; + public class NotificationHelper { private static int notificationId = 0; @@ -465,13 +468,18 @@ public class NotificationHelper { public static void clearNotificationsForActiveAccount(@NonNull Context context, @NonNull AccountManager accountManager) { AccountEntity account = accountManager.getActiveAccount(); - if (account != null) { - account.setActiveNotifications("[]"); - accountManager.saveAccount(account); - - NotificationManager notificationManager = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE); - //noinspection ConstantConditions - notificationManager.cancel((int) account.getId()); + if (account != null && !account.getActiveNotifications().equals("[]")) { + Single.fromCallable(() -> { + account.setActiveNotifications("[]"); + accountManager.saveAccount(account); + + NotificationManager notificationManager = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE); + //noinspection ConstantConditions + notificationManager.cancel((int) account.getId()); + return true; + }) + .subscribeOn(Schedulers.io()) + .subscribe(); } }