mirror of
				https://github.com/9ParsonsB/Pulsar.git
				synced 2025-10-26 04:49:50 -04:00 
			
		
		
		
	* [Framework] Add a DateTime property for CarrierJumpRequest DepartureTime (#119) Refactored out the logic backing the JournalBase TimestampDateTime property so it can be used for any DateTime type property, providing a standardized json String -> DateTime conversion for any date-time property. Implemented as an `internal static` method on JournalBase so journal objects which inherit from JournalBase or don't inherit from it can use it. Used this to provide a DepatureTimeDateTime on CarrierJumpRequest (this property was added in Update 14) and to implement the existing ExpiryDateTime on CurrentGoal. From a quick search in the journal documentation, I don't see any other applications for this. * [ObservatoryCore] UI tweaks Polishing a few rough edges: * Enable scrolling on the Plugin List view. It only fit 6 or 7. I have 13. * I fiddled a bit with column auto-sizing (left it commented out, see comment). * A whole bunch of tweaks to the settings view: * first row of controls was cut off at the top (under the window title bar) * fixing that revealed uneven spacing between columns * action buttons were teensy tiny and unreadable * settings view columns were too narrow (200 px). * added some spacing to help with readability * settings windows now start in center of current screen rather than some random place.
This commit is contained in:
		
							
								
								
									
										1
									
								
								ObservatoryCore/UI/CoreForm.Designer.cs
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										1
									
								
								ObservatoryCore/UI/CoreForm.Designer.cs
									
									
									
										generated
									
									
									
								
							| @@ -471,7 +471,6 @@ | |||||||
|             PluginList.MultiSelect = false; |             PluginList.MultiSelect = false; | ||||||
|             PluginList.Name = "PluginList"; |             PluginList.Name = "PluginList"; | ||||||
|             PluginList.OwnerDraw = true; |             PluginList.OwnerDraw = true; | ||||||
|             PluginList.Scrollable = false; |  | ||||||
|             PluginList.Size = new Size(659, 137); |             PluginList.Size = new Size(659, 137); | ||||||
|             PluginList.TabIndex = 0; |             PluginList.TabIndex = 0; | ||||||
|             PluginList.UseCompatibleStateImageBehavior = false; |             PluginList.UseCompatibleStateImageBehavior = false; | ||||||
|   | |||||||
| @@ -212,6 +212,12 @@ namespace Observatory.UI | |||||||
|  |  | ||||||
|         private void FitColumns() |         private void FitColumns() | ||||||
|         { |         { | ||||||
|  |             // This sizes to fit the column width to the text. However, when the listview is resized (by | ||||||
|  |             // expanding setting sections below the list), it causes flashing/jank. Visually, it looks cleaner | ||||||
|  |             // (because the default column sizes are too small) and helps avoid horizontal scrollbar. | ||||||
|  |             //foreach (ColumnHeader col in PluginList.Columns) | ||||||
|  |             //    col.Width = -2; | ||||||
|  |  | ||||||
|             int totalWidth = 0; |             int totalWidth = 0; | ||||||
|             foreach (ColumnHeader col in PluginList.Columns) |             foreach (ColumnHeader col in PluginList.Columns) | ||||||
|                 totalWidth += col.Width; |                 totalWidth += col.Width; | ||||||
|   | |||||||
							
								
								
									
										3
									
								
								ObservatoryCore/UI/SettingsForm.Designer.cs
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										3
									
								
								ObservatoryCore/UI/SettingsForm.Designer.cs
									
									
									
										generated
									
									
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| namespace Observatory.UI | namespace Observatory.UI | ||||||
| { | { | ||||||
|     partial class SettingsForm |     partial class SettingsForm | ||||||
|     { |     { | ||||||
| @@ -50,6 +50,7 @@ | |||||||
|             Controls.Add(PluginSettingsCloseButton); |             Controls.Add(PluginSettingsCloseButton); | ||||||
|             FormBorderStyle = FormBorderStyle.FixedSingle; |             FormBorderStyle = FormBorderStyle.FixedSingle; | ||||||
|             Name = "SettingsForm"; |             Name = "SettingsForm"; | ||||||
|  |             StartPosition = FormStartPosition.CenterScreen; | ||||||
|             Text = "SettingsForm"; |             Text = "SettingsForm"; | ||||||
|             ResumeLayout(false); |             ResumeLayout(false); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -18,6 +18,7 @@ namespace Observatory.UI | |||||||
|     { |     { | ||||||
|         private readonly IObservatoryPlugin _plugin; |         private readonly IObservatoryPlugin _plugin; | ||||||
|         private readonly List<int> _colHeight = new List<int>(); |         private readonly List<int> _colHeight = new List<int>(); | ||||||
|  |         private int _colWidth = 400; | ||||||
|  |  | ||||||
|         public SettingsForm(IObservatoryPlugin plugin) |         public SettingsForm(IObservatoryPlugin plugin) | ||||||
|         { |         { | ||||||
| @@ -51,16 +52,18 @@ namespace Observatory.UI | |||||||
|             foreach (var setting in settings) |             foreach (var setting in settings) | ||||||
|             { |             { | ||||||
|                 // Reset the column tracking for checkboxes if this isn't a checkbox |                 // Reset the column tracking for checkboxes if this isn't a checkbox | ||||||
|  |                 int addedHeight = 35; | ||||||
|                 if (setting.Key.PropertyType.Name != "Boolean") |                 if (setting.Key.PropertyType.Name != "Boolean") | ||||||
|  |                 { | ||||||
|  |                     if (recentHalfCol) _colHeight.Add(addedHeight); | ||||||
|                     recentHalfCol = false; |                     recentHalfCol = false; | ||||||
|  |                 } | ||||||
|                 int addedHeight = 29; |  | ||||||
|  |  | ||||||
|                 switch (setting.Key.GetValue(_plugin.Settings)) |                 switch (setting.Key.GetValue(_plugin.Settings)) | ||||||
|                 { |                 { | ||||||
|                     case bool: |                     case bool: | ||||||
|                         var checkBox = CreateBoolSetting(setting); |                         var checkBox = CreateBoolSetting(setting); | ||||||
|                         addedHeight = recentHalfCol ? 0 : addedHeight; |                         addedHeight = recentHalfCol ? addedHeight : 0; | ||||||
|                         checkBox.Location = GetSettingPosition(recentHalfCol); |                         checkBox.Location = GetSettingPosition(recentHalfCol); | ||||||
|  |  | ||||||
|                         recentHalfCol = !recentHalfCol; |                         recentHalfCol = !recentHalfCol; | ||||||
| @@ -111,7 +114,7 @@ namespace Observatory.UI | |||||||
|                         intLabel.Location = GetSettingPosition(); |                         intLabel.Location = GetSettingPosition(); | ||||||
|                         intControl.Location = GetSettingPosition(true); |                         intControl.Location = GetSettingPosition(true); | ||||||
|  |  | ||||||
|                         addedHeight = intControl.Height; |                         addedHeight = intControl.Height + 2; | ||||||
|                         intLabel.Height = intControl.Height; |                         intLabel.Height = intControl.Height; | ||||||
|                         intLabel.TextAlign = ContentAlignment.MiddleRight; |                         intLabel.TextAlign = ContentAlignment.MiddleRight; | ||||||
|  |  | ||||||
| @@ -125,6 +128,7 @@ namespace Observatory.UI | |||||||
|                         button.Location = GetSettingPosition(); |                         button.Location = GetSettingPosition(); | ||||||
|  |  | ||||||
|                         Controls.Add(button); |                         Controls.Add(button); | ||||||
|  |                         addedHeight = button.Height; | ||||||
|                         trackBottomEdge(button); |                         trackBottomEdge(button); | ||||||
|                         break; |                         break; | ||||||
|                     case Dictionary<string, object> dictSetting: |                     case Dictionary<string, object> dictSetting: | ||||||
| @@ -142,12 +146,14 @@ namespace Observatory.UI | |||||||
|                 } |                 } | ||||||
|                 _colHeight.Add(addedHeight); |                 _colHeight.Add(addedHeight); | ||||||
|             } |             } | ||||||
|             Height = settingsHeight + 80; |             Height = settingsHeight + 160; | ||||||
|  |             Width = _colWidth * 2 + 80; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         private Point GetSettingPosition(bool secondCol = false) |         private Point GetSettingPosition(bool secondCol = false) | ||||||
|         { |         { | ||||||
|             return new Point(10 + (secondCol ? 200 : 0), -26 + _colHeight.Sum()); |             //return new Point(10 + (secondCol ? 200 : 0), -26 + _colHeight.Sum()); | ||||||
|  |             return new Point(10 + (secondCol ? _colWidth : 0), 15 + _colHeight.Sum()); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -157,7 +163,7 @@ namespace Observatory.UI | |||||||
|             { |             { | ||||||
|                 Text = settingName + ": ", |                 Text = settingName + ": ", | ||||||
|                 TextAlign = System.Drawing.ContentAlignment.MiddleRight, |                 TextAlign = System.Drawing.ContentAlignment.MiddleRight, | ||||||
|                 Width = 200, |                 Width = _colWidth, | ||||||
|                 ForeColor = Color.LightGray |                 ForeColor = Color.LightGray | ||||||
|             }; |             }; | ||||||
|  |  | ||||||
| @@ -177,7 +183,7 @@ namespace Observatory.UI | |||||||
|  |  | ||||||
|             ComboBox comboBox = new() |             ComboBox comboBox = new() | ||||||
|             { |             { | ||||||
|                 Width = 200, |                 Width = _colWidth, | ||||||
|                 DropDownStyle = ComboBoxStyle.DropDownList |                 DropDownStyle = ComboBoxStyle.DropDownList | ||||||
|             }; |             }; | ||||||
|  |  | ||||||
| @@ -203,7 +209,9 @@ namespace Observatory.UI | |||||||
|         { |         { | ||||||
|             Button button = new() |             Button button = new() | ||||||
|             { |             { | ||||||
|                 Text = settingName |                 Text = settingName, | ||||||
|  |                 Width = Convert.ToInt32(_colWidth * 0.8), | ||||||
|  |                 Height = 35, | ||||||
|             }; |             }; | ||||||
|  |  | ||||||
|             button.Click += (sender, e) => |             button.Click += (sender, e) => | ||||||
| @@ -229,7 +237,7 @@ namespace Observatory.UI | |||||||
|                 Orientation = Orientation.Horizontal, |                 Orientation = Orientation.Horizontal, | ||||||
|                 TickStyle = TickStyle.Both, |                 TickStyle = TickStyle.Both, | ||||||
|                 TickFrequency = tickFrequency, |                 TickFrequency = tickFrequency, | ||||||
|                 Width = 200, |                 Width = _colWidth, | ||||||
|                 Minimum = minBound, |                 Minimum = minBound, | ||||||
|                 Maximum = maxBound, |                 Maximum = maxBound, | ||||||
|             }; |             }; | ||||||
| @@ -250,8 +258,7 @@ namespace Observatory.UI | |||||||
|             SettingNumericBounds? bounds = (SettingNumericBounds?)System.Attribute.GetCustomAttribute(setting, typeof(SettingNumericBounds)); |             SettingNumericBounds? bounds = (SettingNumericBounds?)System.Attribute.GetCustomAttribute(setting, typeof(SettingNumericBounds)); | ||||||
|             NumericUpDown numericUpDown = new() |             NumericUpDown numericUpDown = new() | ||||||
|             { |             { | ||||||
|  |                 Width = _colWidth, | ||||||
|                 Width = 200, |  | ||||||
|                 Minimum = Convert.ToInt32(bounds?.Minimum ?? Int32.MinValue), |                 Minimum = Convert.ToInt32(bounds?.Minimum ?? Int32.MinValue), | ||||||
|                 Maximum = Convert.ToInt32(bounds?.Maximum ?? Int32.MaxValue), |                 Maximum = Convert.ToInt32(bounds?.Maximum ?? Int32.MaxValue), | ||||||
|                 Increment = Convert.ToInt32(bounds?.Increment ?? 1) |                 Increment = Convert.ToInt32(bounds?.Increment ?? 1) | ||||||
| @@ -275,7 +282,8 @@ namespace Observatory.UI | |||||||
|                 Text = setting.Value, |                 Text = setting.Value, | ||||||
|                 TextAlign = System.Drawing.ContentAlignment.MiddleLeft, |                 TextAlign = System.Drawing.ContentAlignment.MiddleLeft, | ||||||
|                 Checked = (bool?)setting.Key.GetValue(_plugin.Settings) ?? false, |                 Checked = (bool?)setting.Key.GetValue(_plugin.Settings) ?? false, | ||||||
|                 Width = 200, |                 Height = 30, | ||||||
|  |                 Width = _colWidth, | ||||||
|                 ForeColor = Color.LightGray |                 ForeColor = Color.LightGray | ||||||
|             }; |             }; | ||||||
|  |  | ||||||
| @@ -293,7 +301,7 @@ namespace Observatory.UI | |||||||
|             TextBox textBox = new() |             TextBox textBox = new() | ||||||
|             { |             { | ||||||
|                 Text = (setting.GetValue(_plugin.Settings) ?? String.Empty).ToString(), |                 Text = (setting.GetValue(_plugin.Settings) ?? String.Empty).ToString(), | ||||||
|                 Width = 200 |                 Width = _colWidth, | ||||||
|             }; |             }; | ||||||
|  |  | ||||||
|             textBox.TextChanged += (object? sender, EventArgs e) => |             textBox.TextChanged += (object? sender, EventArgs e) => | ||||||
| @@ -312,7 +320,7 @@ namespace Observatory.UI | |||||||
|             TextBox textBox = new() |             TextBox textBox = new() | ||||||
|             { |             { | ||||||
|                 Text = fileInfo?.FullName ?? string.Empty, |                 Text = fileInfo?.FullName ?? string.Empty, | ||||||
|                 Width = 200 |                 Width = _colWidth, | ||||||
|             }; |             }; | ||||||
|  |  | ||||||
|             textBox.TextChanged += (object? sender, EventArgs e) => |             textBox.TextChanged += (object? sender, EventArgs e) => | ||||||
| @@ -328,7 +336,9 @@ namespace Observatory.UI | |||||||
|         { |         { | ||||||
|             Button button = new() |             Button button = new() | ||||||
|             { |             { | ||||||
|                 Text = "Browse" |                 Text = "Browse", | ||||||
|  |                 Height = 35, | ||||||
|  |                 Width = _colWidth / 2, | ||||||
|             }; |             }; | ||||||
|  |  | ||||||
|             button.Click += (object? sender, EventArgs e) => |             button.Click += (object? sender, EventArgs e) => | ||||||
|   | |||||||
| @@ -1,4 +1,6 @@ | |||||||
| namespace Observatory.Framework.Files.Journal | using System.Text.Json.Serialization; | ||||||
|  |  | ||||||
|  | namespace Observatory.Framework.Files.Journal | ||||||
| { | { | ||||||
|     public class CarrierJumpRequest : JournalBase |     public class CarrierJumpRequest : JournalBase | ||||||
|     { |     { | ||||||
| @@ -9,5 +11,10 @@ | |||||||
|         public string SystemName { get; init; } |         public string SystemName { get; init; } | ||||||
|         public ulong SystemID { get; init; } |         public ulong SystemID { get; init; } | ||||||
|         public string DepartureTime { get; init; } |         public string DepartureTime { get; init; } | ||||||
|  |  | ||||||
|  |         [JsonIgnore] | ||||||
|  |         public DateTime DepartureTimeDateTime { | ||||||
|  |             get => ParseDateTime(DepartureTime); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -12,10 +12,7 @@ namespace Observatory.Framework.Files.Journal | |||||||
|         [JsonIgnore] |         [JsonIgnore] | ||||||
|         public DateTime TimestampDateTime |         public DateTime TimestampDateTime | ||||||
|         { |         { | ||||||
|             get |             get => ParseDateTime(Timestamp); | ||||||
|             { |  | ||||||
|                 return DateTime.ParseExact(Timestamp, "yyyy-MM-ddTHH:mm:ssZ", null, System.Globalization.DateTimeStyles.AssumeUniversal); |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         [JsonPropertyName("event")] |         [JsonPropertyName("event")] | ||||||
| @@ -43,5 +40,17 @@ namespace Observatory.Framework.Files.Journal | |||||||
|  |  | ||||||
|         private string json; |         private string json; | ||||||
|  |  | ||||||
|  |         // For use by Journal object classes for .*DateTime properties, like TimestampeDateTime, above. | ||||||
|  |         internal static DateTime ParseDateTime(string value) | ||||||
|  |         { | ||||||
|  |             if (DateTime.TryParseExact(value, "yyyy-MM-ddTHH:mm:ssZ", null, System.Globalization.DateTimeStyles.AssumeUniversal, out DateTime dateTimeValue)) | ||||||
|  |             { | ||||||
|  |                 return dateTimeValue; | ||||||
|  |             } | ||||||
|  |             else | ||||||
|  |             { | ||||||
|  |                 return new DateTime(); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,4 +1,5 @@ | |||||||
| using Microsoft.VisualBasic.CompilerServices; | using Microsoft.VisualBasic.CompilerServices; | ||||||
|  | using Observatory.Framework.Files.Journal; | ||||||
| using System; | using System; | ||||||
| using System.Numerics; | using System.Numerics; | ||||||
|  |  | ||||||
| @@ -13,17 +14,7 @@ namespace Observatory.Framework.Files.ParameterTypes | |||||||
|         public string Expiry { get; init; } |         public string Expiry { get; init; } | ||||||
|         public DateTime ExpiryDateTime |         public DateTime ExpiryDateTime | ||||||
|         { |         { | ||||||
|             get |             get => JournalBase.ParseDateTime(Expiry); | ||||||
|             { |  | ||||||
|                 if (DateTime.TryParseExact(Expiry, "yyyy-MM-ddTHH:mm:ssZ", null, System.Globalization.DateTimeStyles.AssumeUniversal, out DateTime expiryDateTime)) |  | ||||||
|                 { |  | ||||||
|                     return expiryDateTime; |  | ||||||
|                 } |  | ||||||
|                 else |  | ||||||
|                 { |  | ||||||
|                     return new DateTime(); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
|         public bool IsComplete { get; init; } |         public bool IsComplete { get; init; } | ||||||
|         public long CurrentTotal { get; init; } |         public long CurrentTotal { get; init; } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user