mirror of
				https://github.com/9ParsonsB/Pulsar.git
				synced 2025-10-25 20:39:51 -04:00 
			
		
		
		
	Fix a couple of invalid thread exceptions in NativePopup notifications (#43)
Manipulating active notifications must be done on the Avalonia UI thread. UpdateNotification and CloseNotification were not properly doing this. Any plugin attempting to use persistent notifications would have encountered these errors. NOTE: There is not yet hooks for cleaning up persistent/infinite timeout notifications when the APP is closed.
This commit is contained in:
		| @@ -8,6 +8,7 @@ namespace Observatory.NativeNotification | |||||||
| { | { | ||||||
|     public class NativePopup |     public class NativePopup | ||||||
|     { |     { | ||||||
|  |         // TODO: This needs to be cleaned up when the app is closed. | ||||||
|         private Dictionary<Guid, NotificationView> notifications; |         private Dictionary<Guid, NotificationView> notifications; | ||||||
|  |  | ||||||
|         public NativePopup() |         public NativePopup() | ||||||
| @@ -48,13 +49,23 @@ namespace Observatory.NativeNotification | |||||||
|         public void CloseNotification(Guid guid) |         public void CloseNotification(Guid guid) | ||||||
|         { |         { | ||||||
|             if (notifications.ContainsKey(guid)) |             if (notifications.ContainsKey(guid)) | ||||||
|  |             { | ||||||
|  |                 Avalonia.Threading.Dispatcher.UIThread.InvokeAsync(() => | ||||||
|  |                 { | ||||||
|                     notifications[guid].Close(); |                     notifications[guid].Close(); | ||||||
|  |                 }); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         public void UpdateNotification(Guid guid, NotificationArgs notificationArgs) |         public void UpdateNotification(Guid guid, NotificationArgs notificationArgs) | ||||||
|         { |         { | ||||||
|             if (notifications.ContainsKey(guid)) |             if (notifications.ContainsKey(guid)) | ||||||
|  |             { | ||||||
|  |                 Avalonia.Threading.Dispatcher.UIThread.InvokeAsync(() => | ||||||
|  |                 { | ||||||
|                     notifications[guid].DataContext = new NotificationViewModel(notificationArgs); |                     notifications[guid].DataContext = new NotificationViewModel(notificationArgs); | ||||||
|  |                 }); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user