mirror of
https://github.com/9ParsonsB/Pulsar.git
synced 2025-04-05 17:39:39 -04:00
Add a setting to control pre-reading behavior
Also makes adding new rows to the settings grid a little more dynamic.
This commit is contained in:
parent
1ce63c40fc
commit
13fecfa395
@ -103,8 +103,9 @@ namespace Observatory
|
|||||||
|
|
||||||
public void PrereadJournals()
|
public void PrereadJournals()
|
||||||
{
|
{
|
||||||
// TODO: use the configured journal path, not the "default" detected path.
|
if (!Properties.Core.Default.TryPrimeSystemContextOnStartMonitor) return;
|
||||||
DirectoryInfo logDirectory = GetJournalFolder(String.Empty);
|
|
||||||
|
DirectoryInfo logDirectory = GetJournalFolder(Properties.Core.Default.JournalFolder);
|
||||||
var files = logDirectory.GetFiles("Journal.????????????.??.log");
|
var files = logDirectory.GetFiles("Journal.????????????.??.log");
|
||||||
|
|
||||||
// Read at most the last two files (in case we were launched after the game and the latest
|
// Read at most the last two files (in case we were launched after the game and the latest
|
||||||
|
15
ObservatoryCore/Properties/Core.Designer.cs
generated
15
ObservatoryCore/Properties/Core.Designer.cs
generated
@ -58,5 +58,20 @@ namespace Observatory.Properties {
|
|||||||
this["NativeNotify"] = value;
|
this["NativeNotify"] = value;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[global::System.Configuration.UserScopedSettingAttribute()]
|
||||||
|
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
|
||||||
|
[global::System.Configuration.DefaultSettingValueAttribute("True")]
|
||||||
|
public bool TryPrimeSystemContextOnStartMonitor
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return ((bool)(this["TryPrimeSystemContextOnStartMonitor"]));
|
||||||
|
}
|
||||||
|
set
|
||||||
|
{
|
||||||
|
this["TryPrimeSystemContextOnStartMonitor"] = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -136,15 +136,20 @@ namespace Observatory.UI.Views
|
|||||||
|
|
||||||
RowDefinitions rows = new()
|
RowDefinitions rows = new()
|
||||||
{
|
{
|
||||||
|
new RowDefinition() { Height = new GridLength(0, GridUnitType.Auto) },
|
||||||
new RowDefinition() { Height = new GridLength(0, GridUnitType.Auto) },
|
new RowDefinition() { Height = new GridLength(0, GridUnitType.Auto) },
|
||||||
new RowDefinition() { Height = new GridLength(0, GridUnitType.Auto) },
|
new RowDefinition() { Height = new GridLength(0, GridUnitType.Auto) },
|
||||||
new RowDefinition() { Height = new GridLength(0, GridUnitType.Auto) }
|
new RowDefinition() { Height = new GridLength(0, GridUnitType.Auto) }
|
||||||
};
|
};
|
||||||
corePanel.RowDefinitions = rows;
|
corePanel.RowDefinitions = rows;
|
||||||
|
|
||||||
|
SettingRowTracker rowTracker = new SettingRowTracker(corePanel);
|
||||||
|
|
||||||
#region Native Settings
|
#region Native Settings
|
||||||
|
|
||||||
TextBlock nativeNotifyLabel = new() { Text = "Basic Notification" }; ;
|
#region Notification settings
|
||||||
|
|
||||||
|
TextBlock nativeNotifyLabel = new() { Text = "Basic Notification" };
|
||||||
CheckBox nativeNotifyCheckbox = new() { IsChecked = Properties.Core.Default.NativeNotify, Content = nativeNotifyLabel };
|
CheckBox nativeNotifyCheckbox = new() { IsChecked = Properties.Core.Default.NativeNotify, Content = nativeNotifyLabel };
|
||||||
|
|
||||||
nativeNotifyCheckbox.Checked += (object sender, RoutedEventArgs e) =>
|
nativeNotifyCheckbox.Checked += (object sender, RoutedEventArgs e) =>
|
||||||
@ -159,8 +164,30 @@ namespace Observatory.UI.Views
|
|||||||
Properties.Core.Default.Save();
|
Properties.Core.Default.Save();
|
||||||
};
|
};
|
||||||
|
|
||||||
corePanel.AddControl(nativeNotifyCheckbox, 1, 0, 2);
|
corePanel.AddControl(nativeNotifyCheckbox, rowTracker.NextIndex(), 0, 2);
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region System Context Priming setting
|
||||||
|
|
||||||
|
TextBlock primeSystemContextLabel = new() { Text = "Try re-load current system information when starting monitor" };
|
||||||
|
CheckBox primeSystemContexCheckbox = new() { IsChecked = Properties.Core.Default.TryPrimeSystemContextOnStartMonitor, Content = primeSystemContextLabel };
|
||||||
|
|
||||||
|
primeSystemContexCheckbox.Checked += (object sender, RoutedEventArgs e) =>
|
||||||
|
{
|
||||||
|
Properties.Core.Default.TryPrimeSystemContextOnStartMonitor = true;
|
||||||
|
Properties.Core.Default.Save();
|
||||||
|
};
|
||||||
|
|
||||||
|
primeSystemContexCheckbox.Unchecked += (object sender, RoutedEventArgs e) =>
|
||||||
|
{
|
||||||
|
Properties.Core.Default.TryPrimeSystemContextOnStartMonitor = false;
|
||||||
|
Properties.Core.Default.Save();
|
||||||
|
};
|
||||||
|
|
||||||
|
corePanel.AddControl(primeSystemContexCheckbox, rowTracker.NextIndex(), 0, 2);
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
@ -207,9 +234,10 @@ namespace Observatory.UI.Views
|
|||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
corePanel.AddControl(journalPathLabel, 2, 0);
|
int journalPathRowIndex = rowTracker.NextIndex();
|
||||||
corePanel.AddControl(journalPath, 2, 1);
|
corePanel.AddControl(journalPathLabel, journalPathRowIndex, 0);
|
||||||
corePanel.AddControl(journalBrowse, 2, 2);
|
corePanel.AddControl(journalPath, journalPathRowIndex, 1);
|
||||||
|
corePanel.AddControl(journalBrowse, journalPathRowIndex, 2);
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
@ -249,7 +277,7 @@ namespace Observatory.UI.Views
|
|||||||
}
|
}
|
||||||
|
|
||||||
pluginList.Items = allPlugins;
|
pluginList.Items = allPlugins;
|
||||||
corePanel.AddControl(pluginList, 0, 0, 2);
|
corePanel.AddControl(pluginList, SettingRowTracker.PLUGIN_LIST_ROW_INDEX, 0, 2);
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
@ -451,4 +479,33 @@ namespace Observatory.UI.Views
|
|||||||
Grid.SetRow(control, row);
|
Grid.SetRow(control, row);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal class SettingRowTracker
|
||||||
|
{
|
||||||
|
public const int PLUGIN_LIST_ROW_INDEX = 0;
|
||||||
|
private int nextSettingRowIndex;
|
||||||
|
|
||||||
|
private Grid settingPanel;
|
||||||
|
|
||||||
|
public SettingRowTracker(Grid settingPanel)
|
||||||
|
{
|
||||||
|
this.settingPanel = settingPanel;
|
||||||
|
Reset();
|
||||||
|
}
|
||||||
|
|
||||||
|
public int NextIndex()
|
||||||
|
{
|
||||||
|
if (nextSettingRowIndex > settingPanel.RowDefinitions.Count)
|
||||||
|
{
|
||||||
|
throw new IndexOutOfRangeException("Trying to add more settings than rows in the settings grid.");
|
||||||
|
}
|
||||||
|
return nextSettingRowIndex++;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void Reset()
|
||||||
|
{
|
||||||
|
nextSettingRowIndex = PLUGIN_LIST_ROW_INDEX + 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user