mirror of
				https://github.com/KDE/kdeconnect-android
				synced 2025-10-25 14:58:36 +00:00 
			
		
		
		
	Introduced NotificationHelper
This commit is contained in:
		| @@ -37,6 +37,7 @@ import android.util.Log; | ||||
| import org.kde.kdeconnect.Backends.BaseLink; | ||||
| import org.kde.kdeconnect.Backends.BasePairingHandler; | ||||
| import org.kde.kdeconnect.Backends.LanBackend.LanLinkProvider; | ||||
| import org.kde.kdeconnect.Helpers.NotificationHelper; | ||||
| import org.kde.kdeconnect.Helpers.SecurityHelpers.SslHelper; | ||||
| import org.kde.kdeconnect.Plugins.Plugin; | ||||
| import org.kde.kdeconnect.Plugins.PluginFactory; | ||||
| @@ -382,14 +383,9 @@ public class Device implements BaseLink.PackageReceiver { | ||||
|                 .build(); | ||||
|  | ||||
|         final NotificationManager notificationManager = (NotificationManager) getContext().getSystemService(Context.NOTIFICATION_SERVICE); | ||||
|         NotificationHelper.notifyCompat(notificationManager, notificationId, noti); | ||||
|  | ||||
|         try { | ||||
|         BackgroundService.addGuiInUseCounter(context); | ||||
|             notificationManager.notify(notificationId, noti); | ||||
|         } catch(Exception e) { | ||||
|             //4.1 will throw an exception about not having the VIBRATE permission, ignore it. | ||||
|             //https://android.googlesource.com/platform/frameworks/base/+/android-4.2.1_r1.2%5E%5E!/ | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     public void hidePairingNotification() { | ||||
|   | ||||
							
								
								
									
										25
									
								
								src/org/kde/kdeconnect/Helpers/NotificationHelper.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								src/org/kde/kdeconnect/Helpers/NotificationHelper.java
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,25 @@ | ||||
| package org.kde.kdeconnect.Helpers; | ||||
|  | ||||
| import android.app.Notification; | ||||
| import android.app.NotificationManager; | ||||
|  | ||||
| public class NotificationHelper { | ||||
|  | ||||
|     public static void notifyCompat(NotificationManager notificationManager, int notificationId, Notification notification) { | ||||
|         try { | ||||
|             notificationManager.notify(notificationId, notification); | ||||
|         } catch(Exception e) { | ||||
|             //4.1 will throw an exception about not having the VIBRATE permission, ignore it. | ||||
|             //https://android.googlesource.com/platform/frameworks/base/+/android-4.2.1_r1.2%5E%5E!/ | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     public static void notifyCompat(NotificationManager notificationManager, String tag, int notificationId, Notification notification) { | ||||
|         try { | ||||
|             notificationManager.notify(tag, notificationId, notification); | ||||
|         } catch(Exception e) { | ||||
|             //4.1 will throw an exception about not having the VIBRATE permission, ignore it. | ||||
|             //https://android.googlesource.com/platform/frameworks/base/+/android-4.2.1_r1.2%5E%5E!/ | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -30,6 +30,7 @@ import android.support.v4.app.NotificationCompat; | ||||
| import android.support.v4.app.TaskStackBuilder; | ||||
| import android.util.Log; | ||||
|  | ||||
| import org.kde.kdeconnect.Helpers.NotificationHelper; | ||||
| import org.kde.kdeconnect.NetworkPackage; | ||||
| import org.kde.kdeconnect.Plugins.Plugin; | ||||
| import org.kde.kdeconnect.UserInterface.MaterialActivity; | ||||
| @@ -89,12 +90,7 @@ public class PingPlugin extends Plugin { | ||||
|                 .build(); | ||||
|  | ||||
|         NotificationManager notificationManager = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE); | ||||
|         try { | ||||
|             notificationManager.notify(id, noti); | ||||
|         } catch(Exception e) { | ||||
|             //4.1 will throw an exception about not having the VIBRATE permission, ignore it. | ||||
|             //https://android.googlesource.com/platform/frameworks/base/+/android-4.2.1_r1.2%5E%5E!/ | ||||
|         } | ||||
|         NotificationHelper.notifyCompat(notificationManager, id, noti); | ||||
|  | ||||
|         return true; | ||||
|  | ||||
|   | ||||
| @@ -32,6 +32,7 @@ import android.support.v4.app.NotificationCompat; | ||||
| import android.support.v4.app.TaskStackBuilder; | ||||
| import android.util.Log; | ||||
|  | ||||
| import org.kde.kdeconnect.Helpers.NotificationHelper; | ||||
| import org.kde.kdeconnect.NetworkPackage; | ||||
| import org.kde.kdeconnect.Plugins.Plugin; | ||||
| import org.kde.kdeconnect.UserInterface.MaterialActivity; | ||||
| @@ -114,13 +115,8 @@ public class ReceiveNotificationsPlugin extends Plugin { | ||||
|                     .build(); | ||||
|  | ||||
|             NotificationManager notificationManager = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE); | ||||
|             try { | ||||
|                 // tag all incoming notifications | ||||
|                 notificationManager.notify("kdeconnectId:" + np.getString("id", "0"), np.getInt("id", 0), noti); | ||||
|             } catch (Exception e) { | ||||
|                 //4.1 will throw an exception about not having the VIBRATE permission, ignore it. | ||||
|                 //https://android.googlesource.com/platform/frameworks/base/+/android-4.2.1_r1.2%5E%5E!/ | ||||
|             } | ||||
|             NotificationHelper.notifyCompat(notificationManager, "kdeconnectId:" + np.getString("id", "0"), np.getInt("id", 0), noti); | ||||
|  | ||||
|         } | ||||
|  | ||||
|         return true; | ||||
|   | ||||
| @@ -46,6 +46,7 @@ import android.widget.Toast; | ||||
|  | ||||
| import org.kde.kdeconnect.Device; | ||||
| import org.kde.kdeconnect.Helpers.FilesHelper; | ||||
| import org.kde.kdeconnect.Helpers.NotificationHelper; | ||||
| import org.kde.kdeconnect.NetworkPackage; | ||||
| import org.kde.kdeconnect.Plugins.Plugin; | ||||
| import org.kde.kdeconnect_tp.R; | ||||
| @@ -139,12 +140,7 @@ public class SharePlugin extends Plugin { | ||||
|                         .setOngoing(true) | ||||
|                         .setProgress(100,0,true); | ||||
|  | ||||
|                 try { | ||||
|                     notificationManager.notify(notificationId,builder.build()); | ||||
|                 } catch(Exception e) { | ||||
|                     //4.1 will throw an exception about not having the VIBRATE permission, ignore it. | ||||
|                     //https://android.googlesource.com/platform/frameworks/base/+/android-4.2.1_r1.2%5E%5E!/ | ||||
|                 } | ||||
|                 NotificationHelper.notifyCompat(notificationManager,notificationId, builder.build()); | ||||
|  | ||||
|                 new Thread(new Runnable() { | ||||
|                     @Override | ||||
| @@ -165,12 +161,7 @@ public class SharePlugin extends Plugin { | ||||
|                                     if (progressPercentage != prevProgressPercentage) { | ||||
|                                         prevProgressPercentage = progressPercentage; | ||||
|                                         builder.setProgress(100, (int) progressPercentage, false); | ||||
|                                         try { | ||||
|                                             notificationManager.notify(notificationId,builder.build()); | ||||
|                                         } catch(Exception e) { | ||||
|                                             //4.1 will throw an exception about not having the VIBRATE permission, ignore it. | ||||
|                                             //https://android.googlesource.com/platform/frameworks/base/+/android-4.2.1_r1.2%5E%5E!/ | ||||
|                                         } | ||||
|                                         NotificationHelper.notifyCompat(notificationManager, notificationId, builder.build()); | ||||
|                                     } | ||||
|                                 } | ||||
|                                 //else Log.e("SharePlugin", "Infinite loop? :D"); | ||||
| @@ -225,12 +216,7 @@ public class SharePlugin extends Plugin { | ||||
|                                 builder.setDefaults(Notification.DEFAULT_ALL); | ||||
|                             } | ||||
|  | ||||
|                             try { | ||||
|                                 notificationManager.notify(notificationId,builder.build()); | ||||
|                             } catch(Exception e) { | ||||
|                                 //4.1 will throw an exception about not having the VIBRATE permission, ignore it. | ||||
|                                 //https://android.googlesource.com/platform/frameworks/base/+/android-4.2.1_r1.2%5E%5E!/ | ||||
|                             } | ||||
|                             NotificationHelper.notifyCompat(notificationManager, notificationId, builder.build()); | ||||
|  | ||||
|                         } catch (Exception e) { | ||||
|                             Log.e("SharePlugin", "Receiver thread exception"); | ||||
| @@ -283,12 +269,7 @@ public class SharePlugin extends Plugin { | ||||
|                             .build(); | ||||
|  | ||||
|                     NotificationManager notificationManager = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE); | ||||
|                     try { | ||||
|                         notificationManager.notify((int) System.currentTimeMillis(), noti); | ||||
|                     } catch (Exception e) { | ||||
|                         //4.1 will throw an exception about not having the VIBRATE permission, ignore it. | ||||
|                         //https://android.googlesource.com/platform/frameworks/base/+/android-4.2.1_r1.2%5E%5E!/ | ||||
|                     } | ||||
|                     NotificationHelper.notifyCompat(notificationManager, (int) System.currentTimeMillis(), noti); | ||||
|                 } | ||||
|             } else { | ||||
|                 Log.e("SharePlugin", "Error: Nothing attached!"); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user