mirror of
https://github.com/9ParsonsB/Pulsar.git
synced 2025-04-05 17:39:39 -04:00
* Add file association for .eop, prompt for install dir * Handle .eop or .aip file passed as arg. * VS2022 version bump * Filter neutron stars and black holes from fast spinning criteria. * Adjustments for new "high value" check * Refactor herald cache * Fix element order and namespaces for voice moods. * Add explicit .Stop() between audio player calls. * Use nullsafe member access instead of skipping * Don't queue up a title that's already queued. * Improve body ordinal handling for explorer speech titles. * Escape strings being inserted into xml * Handle flip-flopping JSON type * Converter for flip-flopping property type * Use the converter * Escape characters *before* we wrap it in xml. * Give Eahlstan his clear button. :D * Exclude all stars from fast rotation check. * Close outstanding popup notifications on exit. * TO DONE * [Herald] Suppress duplicate notification titles for spoken notifications If you have notifications from multiple plugins producing notifications with the same title in quick succession (ie. "Body A 1 e" from both Explorer and BioInsights), the title on successive notifications will not be spoken again to save the breath of our friendly Azure speakers. * Doc update * Remove unintended member hiding * Fix export errors when exporting BioInsights data, cleanup Discovered a couple issues with exporting BioInsights data resulting from using two different types of objects in the data grid; improved error handling as well. Also cleaned up some old-style read all code. * Add read-all on launch setting * Updated framework xml * Improve high-value body description text Co-authored-by: Fred Kuipers <mr.fredk@gmail.com>
180 lines
5.8 KiB
C#
180 lines
5.8 KiB
C#
using Observatory.Framework;
|
|
using Observatory.Framework.Files;
|
|
using Observatory.Framework.Interfaces;
|
|
using Observatory.NativeNotification;
|
|
using System;
|
|
using System.IO;
|
|
|
|
namespace Observatory.PluginManagement
|
|
{
|
|
public class PluginCore : IObservatoryCore
|
|
{
|
|
|
|
private readonly NativeVoice NativeVoice;
|
|
private readonly NativePopup NativePopup;
|
|
|
|
public PluginCore()
|
|
{
|
|
NativeVoice = new();
|
|
NativePopup = new();
|
|
}
|
|
|
|
public string Version => System.Reflection.Assembly.GetEntryAssembly().GetName().Version.ToString();
|
|
|
|
public Action<Exception, String> GetPluginErrorLogger(IObservatoryPlugin plugin)
|
|
{
|
|
return (ex, context) =>
|
|
{
|
|
ObservatoryCore.LogError(ex, $"from plugin {plugin.ShortName} {context}");
|
|
};
|
|
}
|
|
|
|
public Status GetStatus()
|
|
{
|
|
throw new NotImplementedException();
|
|
}
|
|
|
|
public Guid SendNotification(string title, string text)
|
|
{
|
|
return SendNotification(new NotificationArgs() { Title = title, Detail = text });
|
|
}
|
|
|
|
public Guid SendNotification(NotificationArgs notificationArgs)
|
|
{
|
|
var guid = Guid.Empty;
|
|
|
|
if (!IsLogMonitorBatchReading)
|
|
{
|
|
if (notificationArgs.Rendering.HasFlag(NotificationRendering.PluginNotifier))
|
|
{
|
|
var handler = Notification;
|
|
handler?.Invoke(this, notificationArgs);
|
|
}
|
|
|
|
if (Properties.Core.Default.NativeNotify && notificationArgs.Rendering.HasFlag(NotificationRendering.NativeVisual))
|
|
{
|
|
guid = NativePopup.InvokeNativeNotification(notificationArgs);
|
|
}
|
|
|
|
if (Properties.Core.Default.VoiceNotify && notificationArgs.Rendering.HasFlag(NotificationRendering.NativeVocal))
|
|
{
|
|
NativeVoice.EnqueueAndAnnounce(notificationArgs);
|
|
}
|
|
}
|
|
|
|
return guid;
|
|
}
|
|
|
|
public void CancelNotification(Guid id)
|
|
{
|
|
NativePopup.CloseNotification(id);
|
|
}
|
|
|
|
public void UpdateNotification(Guid id, NotificationArgs notificationArgs)
|
|
{
|
|
if (!IsLogMonitorBatchReading)
|
|
{
|
|
|
|
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>
|
|
/// Adds an item to the datagrid on UI thread to ensure visual update.
|
|
/// </summary>
|
|
/// <param name="worker"></param>
|
|
/// <param name="item"></param>
|
|
public void AddGridItem(IObservatoryWorker worker, object item)
|
|
{
|
|
Avalonia.Threading.Dispatcher.UIThread.InvokeAsync(() =>
|
|
{
|
|
worker.PluginUI.DataGrid.Add(item);
|
|
|
|
//Hacky removal of original empty object if one was used to populate columns
|
|
if (worker.PluginUI.DataGrid.Count == 2)
|
|
{
|
|
bool allNull = true;
|
|
Type itemType = worker.PluginUI.DataGrid[0].GetType();
|
|
foreach (var property in itemType.GetProperties())
|
|
{
|
|
if (property.GetValue(worker.PluginUI.DataGrid[0], null) != null)
|
|
{
|
|
allNull = false;
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (allNull)
|
|
worker.PluginUI.DataGrid.RemoveAt(0);
|
|
}
|
|
|
|
});
|
|
}
|
|
|
|
public void ClearGrid(IObservatoryWorker worker, object templateItem)
|
|
{
|
|
Avalonia.Threading.Dispatcher.UIThread.InvokeAsync(() =>
|
|
{
|
|
worker.PluginUI.DataGrid.Add(templateItem);
|
|
while (worker.PluginUI.DataGrid.Count > 1)
|
|
worker.PluginUI.DataGrid.RemoveAt(0);
|
|
});
|
|
}
|
|
|
|
public void ExecuteOnUIThread(Action action)
|
|
{
|
|
Avalonia.Threading.Dispatcher.UIThread.InvokeAsync(action);
|
|
}
|
|
|
|
public System.Net.Http.HttpClient HttpClient
|
|
{
|
|
get => Observatory.HttpClient.Client;
|
|
}
|
|
|
|
public LogMonitorState CurrentLogMonitorState
|
|
{
|
|
get => LogMonitor.GetInstance.CurrentState;
|
|
}
|
|
|
|
public bool IsLogMonitorBatchReading
|
|
{
|
|
get => LogMonitorStateChangedEventArgs.IsBatchRead(LogMonitor.GetInstance.CurrentState);
|
|
}
|
|
|
|
public event EventHandler<NotificationArgs> Notification;
|
|
|
|
public string PluginStorageFolder
|
|
{
|
|
get
|
|
{
|
|
var context = new System.Diagnostics.StackFrame(1).GetMethod();
|
|
|
|
string folderLocation = Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData)
|
|
+ $"{Path.DirectorySeparatorChar}ObservatoryCore{Path.DirectorySeparatorChar}{context.DeclaringType.Assembly.GetName().Name}{Path.DirectorySeparatorChar}";
|
|
|
|
if (!Directory.Exists(folderLocation))
|
|
Directory.CreateDirectory(folderLocation);
|
|
|
|
return folderLocation;
|
|
}
|
|
}
|
|
|
|
internal void Shutdown()
|
|
{
|
|
NativePopup.CloseAll();
|
|
}
|
|
}
|
|
}
|