Эх сурвалжийг харах

Cancel notification when no new chapters are found. Closes #121

inorichi 9 жил өмнө
parent
commit
945625d3ad

+ 31 - 5
app/src/main/java/eu/kanade/tachiyomi/data/sync/LibraryUpdateService.java

@@ -111,7 +111,7 @@ public class LibraryUpdateService extends Service {
                     .toList().toBlocking().single();
 
         return Observable.from(mangas)
-                .doOnNext(manga -> showNotification(
+                .doOnNext(manga -> showProgressNotification(
                         getString(R.string.notification_update_progress,
                                 count.incrementAndGet(), mangas.size()), manga.title))
                 .concatMap(manga -> updateManga(manga)
@@ -123,8 +123,14 @@ public class LibraryUpdateService extends Service {
                         .filter(pair -> pair.first > 0)
                         .map(pair -> new MangaUpdate(manga, pair.first)))
                 .doOnNext(updates::add)
-                .doOnCompleted(() -> showBigNotification(getString(R.string.notification_update_completed),
-                        getUpdatedMangas(updates, failedUpdates)));
+                .doOnCompleted(() -> {
+                    if (updates.isEmpty()) {
+                        cancelNotification();
+                    } else {
+                        showResultNotification(getString(R.string.notification_update_completed),
+                                getUpdatedMangasResult(updates, failedUpdates));
+                    }
+                });
     }
 
     private Observable<Pair<Integer, Integer>> updateManga(Manga manga) {
@@ -133,7 +139,7 @@ public class LibraryUpdateService extends Service {
                 .flatMap(chapters -> db.insertOrRemoveChapters(manga, chapters));
     }
 
-    private String getUpdatedMangas(List<MangaUpdate> updates, List<Manga> failedUpdates) {
+    private String getUpdatedMangasResult(List<MangaUpdate> updates, List<Manga> failedUpdates) {
         final StringBuilder result = new StringBuilder();
         if (updates.isEmpty()) {
             result.append(getString(R.string.notification_no_new_chapters)).append("\n");
@@ -185,7 +191,20 @@ public class LibraryUpdateService extends Service {
         notificationManager.notify(UPDATE_NOTIFICATION_ID, builder.build());
     }
 
-    private void showBigNotification(String title, String body) {
+    private void showProgressNotification(String title, String body) {
+        NotificationCompat.Builder builder = new NotificationCompat.Builder(this)
+                .setSmallIcon(R.drawable.ic_action_refresh)
+                .setContentTitle(title)
+                .setContentText(body)
+                .setOngoing(true);
+
+        NotificationManager notificationManager =
+                (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
+
+        notificationManager.notify(UPDATE_NOTIFICATION_ID, builder.build());
+    }
+
+    private void showResultNotification(String title, String body) {
         NotificationCompat.Builder builder = new NotificationCompat.Builder(this)
                 .setSmallIcon(R.drawable.ic_action_refresh)
                 .setContentTitle(title)
@@ -199,6 +218,13 @@ public class LibraryUpdateService extends Service {
         notificationManager.notify(UPDATE_NOTIFICATION_ID, builder.build());
     }
 
+    private void cancelNotification() {
+        NotificationManager notificationManager =
+                (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
+
+        notificationManager.cancel(UPDATE_NOTIFICATION_ID);
+    }
+
     private PendingIntent getNotificationIntent() {
         Intent intent = new Intent(this, MainActivity.class);
         intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_SINGLE_TOP);