mirror of
https://github.com/9ParsonsB/Pulsar.git
synced 2025-04-05 17:39:39 -04:00
Merge pull request #10 from fredjk-gh/PreReadAsReadAllSettingsUIFixes
Implement int settings; de-dupe plugin table and show types, etc
This commit is contained in:
commit
e9a4f873b5
@ -10,6 +10,7 @@ using Avalonia.Interactivity;
|
|||||||
using Avalonia.VisualTree;
|
using Avalonia.VisualTree;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.ObjectModel;
|
using System.Collections.ObjectModel;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
|
||||||
namespace Observatory.UI.Views
|
namespace Observatory.UI.Views
|
||||||
{
|
{
|
||||||
@ -252,6 +253,12 @@ namespace Observatory.UI.Views
|
|||||||
Binding = new Binding("Name")
|
Binding = new Binding("Name")
|
||||||
});
|
});
|
||||||
|
|
||||||
|
pluginList.Columns.Add(new DataGridTextColumn()
|
||||||
|
{
|
||||||
|
Header = "Types",
|
||||||
|
Binding = new Binding("TypesString")
|
||||||
|
});
|
||||||
|
|
||||||
pluginList.Columns.Add(new DataGridTextColumn()
|
pluginList.Columns.Add(new DataGridTextColumn()
|
||||||
{
|
{
|
||||||
Header = "Version",
|
Header = "Version",
|
||||||
@ -264,19 +271,29 @@ namespace Observatory.UI.Views
|
|||||||
Binding = new Binding("Status")
|
Binding = new Binding("Status")
|
||||||
});
|
});
|
||||||
|
|
||||||
System.Collections.Generic.List<PluginView> allPlugins = new();
|
Dictionary<string, PluginView> uniquePlugins = new();
|
||||||
|
|
||||||
foreach(var (plugin, signed) in pluginManager.workerPlugins)
|
foreach(var (plugin, signed) in pluginManager.workerPlugins)
|
||||||
{
|
{
|
||||||
allPlugins.Add(new PluginView() { Name = plugin.Name, Version = plugin.Version, Status = GetStatusText(signed) });
|
if (!uniquePlugins.ContainsKey(plugin.Name))
|
||||||
|
{
|
||||||
|
uniquePlugins.Add(plugin.Name,
|
||||||
|
new PluginView() { Name = plugin.Name, Types = new() { typeof(IObservatoryWorker).Name }, Version = plugin.Version, Status = GetStatusText(signed) });
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach (var (plugin, signed) in pluginManager.notifyPlugins)
|
foreach (var (plugin, signed) in pluginManager.notifyPlugins)
|
||||||
{
|
{
|
||||||
allPlugins.Add(new PluginView() { Name = plugin.Name, Version = plugin.Version, Status = GetStatusText(signed) });
|
if (!uniquePlugins.ContainsKey(plugin.Name))
|
||||||
|
{
|
||||||
|
uniquePlugins.Add(plugin.Name,
|
||||||
|
new PluginView() { Name = plugin.Name, Types = new() { typeof(IObservatoryNotifier).Name }, Version = plugin.Version, Status = GetStatusText(signed) });
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
uniquePlugins[plugin.Name].Types.Add(typeof(IObservatoryNotifier).Name);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pluginList.Items = allPlugins;
|
pluginList.Items = uniquePlugins.Values;
|
||||||
corePanel.AddControl(pluginList, SettingRowTracker.PLUGIN_LIST_ROW_INDEX, 0, 2);
|
corePanel.AddControl(pluginList, SettingRowTracker.PLUGIN_LIST_ROW_INDEX, 0, 2);
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
@ -324,10 +341,13 @@ namespace Observatory.UI.Views
|
|||||||
{
|
{
|
||||||
if (setting.Key.PropertyType != typeof(bool) || settingsGrid.Children.Count % 2 == 0)
|
if (setting.Key.PropertyType != typeof(bool) || settingsGrid.Children.Count % 2 == 0)
|
||||||
{
|
{
|
||||||
settingsGrid.RowDefinitions.Add(new RowDefinition() { Height = new GridLength(21) });
|
settingsGrid.RowDefinitions.Add(new RowDefinition()
|
||||||
|
{
|
||||||
|
Height = new GridLength(setting.Key.PropertyType != typeof(bool) ? 40 : 25),
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
TextBlock label = new() { Text = setting.Value };
|
TextBlock label = new() { Text = setting.Value, VerticalAlignment = Avalonia.Layout.VerticalAlignment.Center };
|
||||||
|
|
||||||
switch (setting.Key.GetValue(plugin.Settings))
|
switch (setting.Key.GetValue(plugin.Settings))
|
||||||
{
|
{
|
||||||
@ -351,13 +371,64 @@ namespace Observatory.UI.Views
|
|||||||
break;
|
break;
|
||||||
case string stringSetting:
|
case string stringSetting:
|
||||||
TextBox textBox = new() { Text = stringSetting };
|
TextBox textBox = new() { Text = stringSetting };
|
||||||
settingsGrid.Children.Add(label);
|
settingsGrid.AddControl(label, settingsGrid.RowDefinitions.Count - 1, 0);
|
||||||
settingsGrid.Children.Add(textBox);
|
settingsGrid.AddControl(textBox, settingsGrid.RowDefinitions.Count - 1, 1);
|
||||||
|
textBox.TextInput += (object sender, Avalonia.Input.TextInputEventArgs e) =>
|
||||||
|
{
|
||||||
|
setting.Key.SetValue(plugin.Settings, e.Text);
|
||||||
|
PluginManagement.PluginManager.GetInstance.SaveSettings(plugin, plugin.Settings);
|
||||||
|
};
|
||||||
break;
|
break;
|
||||||
case int intSetting:
|
case int intSetting:
|
||||||
NumericUpDown numericUpDown = new() { Text = intSetting.ToString(), AllowSpin = true };
|
// We have two options for integer values:
|
||||||
settingsGrid.Children.Add(label);
|
// 1) A slider (explicit by way of the SettingIntegerUseSlider attribute and bounded to 0..100 by default)
|
||||||
settingsGrid.Children.Add(numericUpDown);
|
// 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)))
|
||||||
|
{
|
||||||
|
// 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;
|
||||||
|
}
|
||||||
|
else // Use a Numeric Up/Down
|
||||||
|
{
|
||||||
|
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;
|
break;
|
||||||
case System.IO.FileInfo fileSetting:
|
case System.IO.FileInfo fileSetting:
|
||||||
label.Text += ": ";
|
label.Text += ": ";
|
||||||
@ -365,7 +436,7 @@ namespace Observatory.UI.Views
|
|||||||
TextBox settingPath = new()
|
TextBox settingPath = new()
|
||||||
{
|
{
|
||||||
Text = fileSetting.FullName,
|
Text = fileSetting.FullName,
|
||||||
Width = 250,
|
Width = 300,
|
||||||
HorizontalAlignment = Avalonia.Layout.HorizontalAlignment.Right
|
HorizontalAlignment = Avalonia.Layout.HorizontalAlignment.Right
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -404,7 +475,7 @@ namespace Observatory.UI.Views
|
|||||||
stackPanel.Children.Add(label);
|
stackPanel.Children.Add(label);
|
||||||
stackPanel.Children.Add(settingPath);
|
stackPanel.Children.Add(settingPath);
|
||||||
|
|
||||||
settingsGrid.RowDefinitions.Add(new RowDefinition() { Height = new GridLength(21) });
|
settingsGrid.RowDefinitions.Add(new RowDefinition() { Height = new GridLength(32) });
|
||||||
settingsGrid.AddControl(stackPanel, settingsGrid.RowDefinitions.Count - 1, 0, 2);
|
settingsGrid.AddControl(stackPanel, settingsGrid.RowDefinitions.Count - 1, 0, 2);
|
||||||
settingsGrid.AddControl(settingBrowse, settingsGrid.RowDefinitions.Count - 1, 2);
|
settingsGrid.AddControl(settingBrowse, settingsGrid.RowDefinitions.Count - 1, 2);
|
||||||
|
|
||||||
@ -462,13 +533,16 @@ namespace Observatory.UI.Views
|
|||||||
internal class PluginView
|
internal class PluginView
|
||||||
{
|
{
|
||||||
public string Name { get; set; }
|
public string Name { get; set; }
|
||||||
|
public HashSet<string> Types { get; set; }
|
||||||
|
public string TypesString
|
||||||
|
{
|
||||||
|
get => string.Join(", ", Types);
|
||||||
|
set { }
|
||||||
|
}
|
||||||
public string Version { get; set; }
|
public string Version { get; set; }
|
||||||
public string Status { get; set; }
|
public string Status { get; set; }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
internal static class GridExtention
|
internal static class GridExtention
|
||||||
{
|
{
|
||||||
public static void AddControl(this Grid grid, Control control, int row, int column, int span = 1)
|
public static void AddControl(this Grid grid, Control control, int row, int column, int span = 1)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user