mirror of
				https://github.com/9ParsonsB/Pulsar.git
				synced 2025-10-25 20:39:51 -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:
		| @@ -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; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user