mirror of
				https://github.com/9ParsonsB/Pulsar.git
				synced 2025-10-25 04:39:49 -04:00 
			
		
		
		
	Add new Rendering controls for notifications, add missing forwarding (#47)
Plugins authors can now optionally specify what ways their notifications are rendered (subject, of course, to user preferences/settings). The default is to render notifications in all available channels. Examples: - Show native pop-up window only (ie. no voice/plugin notifiers) - Disallow other plugin notifiers This does not support selection of notifier plugins. Furthermore, persistent notification updates were not previously being forwarded to anything but the native popup notifier. Now plugins and native voice are also supported (subject to user preferences) and respect the new rendering controls added here. There is currently no concept of closing notifications for the native voice or plugin-based notifiers.
This commit is contained in:
		| @@ -36,15 +36,18 @@ namespace Observatory.PluginManagement | |||||||
|  |  | ||||||
|             if (!LogMonitor.GetInstance.ReadAllInProgress()) |             if (!LogMonitor.GetInstance.ReadAllInProgress()) | ||||||
|             { |             { | ||||||
|                 var handler = Notification; |                 if (notificationArgs.Rendering.HasFlag(NotificationRendering.PluginNotifier)) | ||||||
|                 handler?.Invoke(this, notificationArgs); |                 { | ||||||
|  |                     var handler = Notification; | ||||||
|  |                     handler?.Invoke(this, notificationArgs); | ||||||
|  |                 } | ||||||
|  |  | ||||||
|                 if (Properties.Core.Default.NativeNotify) |                 if (Properties.Core.Default.NativeNotify && notificationArgs.Rendering.HasFlag(NotificationRendering.NativeVisual)) | ||||||
|                 { |                 { | ||||||
|                     guid = NativePopup.InvokeNativeNotification(notificationArgs); |                     guid = NativePopup.InvokeNativeNotification(notificationArgs); | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 if (Properties.Core.Default.VoiceNotify) |                 if (Properties.Core.Default.VoiceNotify && notificationArgs.Rendering.HasFlag(NotificationRendering.NativeVocal)) | ||||||
|                 { |                 { | ||||||
|                     NativeVoice.EnqueueAndAnnounce(notificationArgs); |                     NativeVoice.EnqueueAndAnnounce(notificationArgs); | ||||||
|                 } |                 } | ||||||
| @@ -60,7 +63,23 @@ namespace Observatory.PluginManagement | |||||||
|  |  | ||||||
|         public void UpdateNotification(Guid id, NotificationArgs notificationArgs) |         public void UpdateNotification(Guid id, NotificationArgs notificationArgs) | ||||||
|         { |         { | ||||||
|             NativePopup.UpdateNotification(id, notificationArgs); |             if (!LogMonitor.GetInstance.ReadAllInProgress()) | ||||||
|  |             { | ||||||
|  |  | ||||||
|  |                 if (notificationArgs.Rendering.HasFlag(NotificationRendering.PluginNotifier)) | ||||||
|  |                 { | ||||||
|  |                     var handler = Notification; | ||||||
|  |                     handler?.Invoke(this, notificationArgs); | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 if (notificationArgs.Rendering.HasFlag(NotificationRendering.NativeVisual)) | ||||||
|  |                     NativePopup.UpdateNotification(id, notificationArgs); | ||||||
|  |  | ||||||
|  |                 if (Properties.Core.Default.VoiceNotify && notificationArgs.Rendering.HasFlag(NotificationRendering.NativeVocal)) | ||||||
|  |                 { | ||||||
|  |                     NativeVoice.EnqueueAndAnnounce(notificationArgs); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         /// <summary> |         /// <summary> | ||||||
|   | |||||||
| @@ -54,5 +54,19 @@ namespace Observatory.Framework | |||||||
|         /// Specify window Y position as a percentage from upper left corner (overrides Core setting). Default -1.0 (use Core setting). |         /// Specify window Y position as a percentage from upper left corner (overrides Core setting). Default -1.0 (use Core setting). | ||||||
|         /// </summary> |         /// </summary> | ||||||
|         public double YPos = -1.0; |         public double YPos = -1.0; | ||||||
|  |         /// <summary> | ||||||
|  |         /// Specifies the desired renderings of the notification. | ||||||
|  |         /// </summary> | ||||||
|  |         public NotificationRendering Rendering = NotificationRendering.All; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     [Flags] | ||||||
|  |     public enum NotificationRendering | ||||||
|  |     { | ||||||
|  |         // These need to be multiples of 2 as they're used via masking. | ||||||
|  |         NativeVisual = 1, | ||||||
|  |         NativeVocal = 2, | ||||||
|  |         PluginNotifier = 4, | ||||||
|  |         All = (NativeVisual | NativeVocal | PluginNotifier) | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user