From e523dddfe3f23515c8f5efbbac6c56018f87261a Mon Sep 17 00:00:00 2001 From: Fred Kuipers Date: Sun, 15 Aug 2021 17:02:05 -0400 Subject: [PATCH] Revert LogMonitor/CoreViewModel changes, implement Slider int setting Also revert the PluginType enum. Fix more whitespace --- ObservatoryCore/LogMonitor.cs | 2 - .../UI/ViewModels/CoreViewModel.cs | 30 ++----- ObservatoryCore/UI/Views/BasicUIView.axaml.cs | 87 ++++++++++++------- 3 files changed, 66 insertions(+), 53 deletions(-) diff --git a/ObservatoryCore/LogMonitor.cs b/ObservatoryCore/LogMonitor.cs index 7282314..fd57421 100644 --- a/ObservatoryCore/LogMonitor.cs +++ b/ObservatoryCore/LogMonitor.cs @@ -146,9 +146,7 @@ namespace Observatory // We found an FSD jump, buffered the lines for that system (possibly including startup logs // over a file boundary). Pump these through the plugins. - readall = true; ReportErrors(ProcessLines(lastSystemLines, "Pre-read")); - readall = false; } #endregion diff --git a/ObservatoryCore/UI/ViewModels/CoreViewModel.cs b/ObservatoryCore/UI/ViewModels/CoreViewModel.cs index 62458e0..3b8f166 100644 --- a/ObservatoryCore/UI/ViewModels/CoreViewModel.cs +++ b/ObservatoryCore/UI/ViewModels/CoreViewModel.cs @@ -55,15 +55,21 @@ namespace Observatory.UI.ViewModels public void ReadAll() { - SetWorkerReadAllState(true); + foreach (var worker in workers) + { + worker.ReadAllStarted(); + } LogMonitor.GetInstance.ReadAllJournals(); - SetWorkerReadAllState(false); + foreach (var worker in workers) + { + worker.ReadAllFinished(); + } } public void ToggleMonitor() { var logMonitor = LogMonitor.GetInstance; - + if (logMonitor.IsMonitoring()) { logMonitor.Stop(); @@ -71,10 +77,7 @@ namespace Observatory.UI.ViewModels } else { - // HACK: Find a better way of suppressing notifications when pre-reading. - SetWorkerReadAllState(true); logMonitor.Start(); - SetWorkerReadAllState(false); ToggleButtonText = "Stop Monitor"; } } @@ -120,20 +123,5 @@ namespace Observatory.UI.ViewModels { get { return tabs; } } - private void SetWorkerReadAllState(bool isReadingAll) - { - foreach (var worker in workers) - { - if (isReadingAll) - { - worker.ReadAllStarted(); - } - else - { - worker.ReadAllFinished(); - } - } - } - } } diff --git a/ObservatoryCore/UI/Views/BasicUIView.axaml.cs b/ObservatoryCore/UI/Views/BasicUIView.axaml.cs index 739d2d7..def362b 100644 --- a/ObservatoryCore/UI/Views/BasicUIView.axaml.cs +++ b/ObservatoryCore/UI/Views/BasicUIView.axaml.cs @@ -277,7 +277,7 @@ namespace Observatory.UI.Views if (!uniquePlugins.ContainsKey(plugin.Name)) { uniquePlugins.Add(plugin.Name, - new PluginView() { Name = plugin.Name, Types = new() { PluginType.Worker }, Version = plugin.Version, Status = GetStatusText(signed) }); + new PluginView() { Name = plugin.Name, Types = new() { typeof(IObservatoryWorker).Name }, Version = plugin.Version, Status = GetStatusText(signed) }); } } @@ -286,10 +286,10 @@ namespace Observatory.UI.Views if (!uniquePlugins.ContainsKey(plugin.Name)) { uniquePlugins.Add(plugin.Name, - new PluginView() { Name = plugin.Name, Types = new() { PluginType.Notifier }, Version = plugin.Version, Status = GetStatusText(signed) }); + new PluginView() { Name = plugin.Name, Types = new() { typeof(IObservatoryNotifier).Name }, Version = plugin.Version, Status = GetStatusText(signed) }); } else { - uniquePlugins[plugin.Name].Types.Add(PluginType.Notifier); + uniquePlugins[plugin.Name].Types.Add(typeof(IObservatoryNotifier).Name); } } @@ -343,7 +343,7 @@ namespace Observatory.UI.Views { settingsGrid.RowDefinitions.Add(new RowDefinition() { - Height = new GridLength(setting.Key.PropertyType != typeof(bool) ? 32 : 25), + Height = new GridLength(setting.Key.PropertyType != typeof(bool) ? 40 : 25), }); } @@ -380,21 +380,55 @@ namespace Observatory.UI.Views }; break; case int intSetting: - NumericUpDown numericUpDown = new() { Value = intSetting, AllowSpin = true }; - SettingNumericBounds attr = (SettingNumericBounds)System.Attribute.GetCustomAttribute(setting.Key, typeof(SettingNumericBounds)); - if (attr != null) + // We have two options for integer values: + // 1) A slider (explicit by way of the SettingIntegerUseSlider attribute and bounded to 0..100 by default) + // 2) A numeric up/down (default otherwise, and is unbounded by default). + // Bounds for both can be set via the SettingNumericBounds attribute, only the up/down uses Increment. + Control intControl; + SettingNumericBounds bounds = (SettingNumericBounds)System.Attribute.GetCustomAttribute(setting.Key, typeof(SettingNumericBounds)); + if (System.Attribute.IsDefined(setting.Key, typeof(SettingNumericUseSlider))) { - numericUpDown.Minimum = attr.Minimum; - numericUpDown.Maximum = attr.Maximum; - numericUpDown.Increment = attr.Increment; + // TODO: Suss the contents of this block into a function to share with non-integral numeric types as well? + Slider slider = new() + { + Value = intSetting, + Height = 40, + Width = 300, + }; + if (bounds != null) + { + slider.Minimum = bounds.Minimum; + slider.Maximum = bounds.Maximum; + }; + slider.PropertyChanged += (object sender, AvaloniaPropertyChangedEventArgs e) => + { + if (e.Property == Slider.ValueProperty) + { + setting.Key.SetValue(plugin.Settings, Convert.ToInt32(e.NewValue)); + PluginManagement.PluginManager.GetInstance.SaveSettings(plugin, plugin.Settings); + } + }; + intControl = slider; } - settingsGrid.AddControl(label, settingsGrid.RowDefinitions.Count - 1, 0); - settingsGrid.AddControl(numericUpDown, settingsGrid.RowDefinitions.Count - 1, 1); - numericUpDown.ValueChanged += (object sender, NumericUpDownValueChangedEventArgs e) => + else // Use a Numeric Up/Down { - setting.Key.SetValue(plugin.Settings, Convert.ToInt32(e.NewValue)); - PluginManagement.PluginManager.GetInstance.SaveSettings(plugin, plugin.Settings); - }; + NumericUpDown numericUpDown = new() { Value = intSetting, AllowSpin = true }; + if (bounds != null) + { + numericUpDown.Minimum = bounds.Minimum; + numericUpDown.Maximum = bounds.Maximum; + numericUpDown.Increment = bounds.Increment; + } + numericUpDown.ValueChanged += (object sender, NumericUpDownValueChangedEventArgs e) => + { + setting.Key.SetValue(plugin.Settings, Convert.ToInt32(e.NewValue)); + PluginManagement.PluginManager.GetInstance.SaveSettings(plugin, plugin.Settings); + }; + intControl = numericUpDown; + } + + settingsGrid.AddControl(label, settingsGrid.RowDefinitions.Count - 1, 0); + settingsGrid.AddControl(intControl, settingsGrid.RowDefinitions.Count - 1, 1); break; case System.IO.FileInfo fileSetting: label.Text += ": "; @@ -402,7 +436,7 @@ namespace Observatory.UI.Views TextBox settingPath = new() { Text = fileSetting.FullName, - Width = 250, + Width = 300, HorizontalAlignment = Avalonia.Layout.HorizontalAlignment.Right }; @@ -499,23 +533,16 @@ namespace Observatory.UI.Views internal class PluginView { public string Name { get; set; } - public HashSet Types { get; set; } - public string TypesString { - get - { - return string.Join(", ", Types); - } - set { } } + public HashSet Types { get; set; } + public string TypesString + { + get => string.Join(", ", Types); + set { } + } public string Version { get; set; } public string Status { get; set; } } - enum PluginType - { - Worker, - Notifier, - } - internal static class GridExtention { public static void AddControl(this Grid grid, Control control, int row, int column, int span = 1)