mirror of
https://github.com/9ParsonsB/Pulsar.git
synced 2025-04-05 17:39:39 -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:
parent
d061275e36
commit
dce2516414
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; }
|
||||||
|
Loading…
x
Reference in New Issue
Block a user