mirror of
https://github.com/9ParsonsB/Pulsar.git
synced 2025-04-05 17:39:39 -04:00
Show notification with genetic sampling status while in progress (#51)
* Show notification with genetic sampling status while in progress When first sample is taken, the notification is displayed showing what was sampled and number of samples taken. Number of samples taken is updated on the second sample. Notification is removed when the final sample is taken. * Add setting and additional notification cleanup conditions As requested: - Added a setting to control the genetic sampler overlay. - Added a few more conditions (FSDJump, LeaveBody, Shutdown) to clean up the notification.
This commit is contained in:
parent
fcf60f6776
commit
9367114cff
@ -30,7 +30,11 @@ namespace Observatory.Botanist
|
||||
ObservableCollection<object> GridCollection;
|
||||
private PluginUI pluginUI;
|
||||
private bool readAllInProgress = false;
|
||||
|
||||
private Guid? samplerStatusNotification = null;
|
||||
private BotanistSettings botanistSettings = new()
|
||||
{
|
||||
OverlayEnabled = true,
|
||||
};
|
||||
public string Name => "Observatory Botanist";
|
||||
|
||||
public string ShortName => "Botanist";
|
||||
@ -39,7 +43,7 @@ namespace Observatory.Botanist
|
||||
|
||||
public PluginUI PluginUI => pluginUI;
|
||||
|
||||
public object Settings { get => null; set { } }
|
||||
public object Settings { get => botanistSettings; set { botanistSettings = (BotanistSettings)value; } }
|
||||
|
||||
public void JournalEvent<TJournal>(TJournal journal) where TJournal : JournalBase
|
||||
{
|
||||
@ -98,6 +102,25 @@ namespace Observatory.Botanist
|
||||
{
|
||||
case ScanOrganicType.Log:
|
||||
case ScanOrganicType.Sample:
|
||||
if (!readAllInProgress && botanistSettings.OverlayEnabled)
|
||||
{
|
||||
NotificationArgs args = new()
|
||||
{
|
||||
Title = scanOrganic.Species_Localised,
|
||||
Detail = string.Format("Sample {0} of 3", scanOrganic.ScanType == ScanOrganicType.Log ? 1 : 2),
|
||||
Rendering = NotificationRendering.NativeVisual,
|
||||
Timeout = 0,
|
||||
};
|
||||
if (samplerStatusNotification == null)
|
||||
{
|
||||
samplerStatusNotification = Core.SendNotification(args);
|
||||
}
|
||||
else
|
||||
{
|
||||
Core.UpdateNotification(samplerStatusNotification.Value, args);
|
||||
}
|
||||
}
|
||||
|
||||
if (!bioPlanet.speciesFound.Contains(scanOrganic.Species_Localised))
|
||||
{
|
||||
bioPlanet.speciesFound.Add(scanOrganic.Species_Localised);
|
||||
@ -108,12 +131,30 @@ namespace Observatory.Botanist
|
||||
{
|
||||
bioPlanet.speciesAnalysed.Add(scanOrganic.Species_Localised);
|
||||
}
|
||||
MaybeCloseSamplerStatusNotification();
|
||||
break;
|
||||
}
|
||||
}
|
||||
UpdateUIGrid();
|
||||
}
|
||||
break;
|
||||
case LeaveBody:
|
||||
case FSDJump:
|
||||
case Shutdown:
|
||||
// These are all good reasons to kill any open notification. Note that SupercruiseEntry is NOT a
|
||||
// suitable reason to close the notification as the player hopping out only to double check the
|
||||
// DSS map for another location. Note that a game client crash will not close the status notification.
|
||||
MaybeCloseSamplerStatusNotification();
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
private void MaybeCloseSamplerStatusNotification()
|
||||
{
|
||||
if (samplerStatusNotification != null)
|
||||
{
|
||||
Core.CancelNotification(samplerStatusNotification.Value);
|
||||
samplerStatusNotification = null;
|
||||
}
|
||||
}
|
||||
|
||||
|
15
ObservatoryBotanist/BotanistSettings.cs
Normal file
15
ObservatoryBotanist/BotanistSettings.cs
Normal file
@ -0,0 +1,15 @@
|
||||
using Observatory.Framework;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace Observatory.Botanist
|
||||
{
|
||||
class BotanistSettings
|
||||
{
|
||||
[SettingDisplayName("Enable Sampler Status Overlay")]
|
||||
public bool OverlayEnabled { get; set; }
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user