2022-03-13 22:47:30 +00:00
using System ;
using System.ComponentModel ;
2022-05-15 22:38:22 +00:00
using System.Linq ;
2022-03-13 22:47:30 +00:00
using System.Reactive.Linq ;
using System.Threading.Tasks ;
using System.Windows ;
2022-03-13 23:08:27 +00:00
using System.Windows.Input ;
2022-03-13 22:47:30 +00:00
using MahApps.Metro.Controls ;
using Microsoft.Extensions.Logging ;
using ReactiveUI ;
using Wabbajack.Common ;
using Wabbajack.Messages ;
using Wabbajack.Paths.IO ;
using Wabbajack.Util ;
2022-03-14 12:40:12 +00:00
using Wabbajack.Views ;
2022-03-13 22:47:30 +00:00
namespace Wabbajack
{
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : MetroWindow
{
private MainWindowVM _mwvm ;
private MainSettings _settings ;
private readonly ILogger < MainWindow > _logger ;
private readonly SystemParametersConstructor _systemParams ;
public MainWindow ( ILogger < MainWindow > logger , SystemParametersConstructor systemParams , LauncherUpdater updater , MainWindowVM vm )
{
InitializeComponent ( ) ;
_mwvm = vm ;
DataContext = _mwvm ;
_logger = logger ;
_systemParams = systemParams ;
try
{
// Wire any unhandled crashing exceptions to log before exiting
AppDomain . CurrentDomain . UnhandledException + = ( sender , e ) = >
{
// Don't do any special logging side effects
_logger . LogError ( ( Exception ) e . ExceptionObject , "Uncaught error" ) ;
Environment . Exit ( - 1 ) ;
} ;
MessageBus . Current . Listen < TaskBarUpdate > ( )
. Subscribe ( u = >
{
2022-05-17 05:26:59 +00:00
Dispatcher . Invoke ( ( ) = >
{
TaskbarItemInfo . Description = u . Description ;
TaskbarItemInfo . ProgressValue = u . ProgressValue ;
TaskbarItemInfo . ProgressState = u . State ;
} ) ;
2022-03-13 22:47:30 +00:00
} ) ;
2022-05-15 22:38:22 +00:00
MessageBus . Current . Listen < OpenBrowserTab > ( )
. Subscribe ( OnOpenBrowserTab ) ;
MessageBus . Current . Listen < CloseBrowserTab > ( )
. Subscribe ( OnCloseBrowserTab ) ;
2022-03-13 22:47:30 +00:00
_logger . LogInformation ( "Wabbajack Build - {Sha}" , ThisAssembly . Git . Sha ) ;
_logger . LogInformation ( "Running in {EntryPoint}" , KnownFolders . EntryPoint ) ;
var p = _systemParams . Create ( ) ;
_logger . LogInformation ( "Detected Windows Version: {Version}" , Environment . OSVersion . VersionString ) ;
_logger . LogInformation (
"System settings - ({MemorySize} RAM) ({PageSize} Page), Display: {ScreenWidth} x {ScreenHeight} ({Vram} VRAM - VideoMemorySizeMb={ENBVRam})" ,
p . SystemMemorySize . ToFileSizeString ( ) , p . SystemPageSize . ToFileSizeString ( ) , p . ScreenWidth , p . ScreenHeight , p . VideoMemorySize . ToFileSizeString ( ) , p . EnbLEVRAMSize ) ;
if ( p . SystemPageSize = = 0 )
_logger . LogInformation ( "Pagefile is disabled! Consider increasing to 20000MB. A disabled pagefile can cause crashes and poor in-game performance" ) ;
else if ( p . SystemPageSize < 2e+10 )
_logger . LogInformation ( "Pagefile below recommended! Consider increasing to 20000MB. A suboptimal pagefile can cause crashes and poor in-game performance" ) ;
//Warmup();
var _ = updater . Run ( ) ;
var ( settings , loadedSettings ) = MainSettings . TryLoadTypicalSettings ( ) . AsTask ( ) . Result ;
// Load settings
/ *
if ( CLIArguments . NoSettings | | ! loadedSettings )
{
_settings = new MainSettings { Version = Consts . SettingsVersion } ;
RunWhenLoaded ( DefaultSettings ) ;
}
else
{
_settings = settings ;
RunWhenLoaded ( LoadSettings ) ;
} * /
// Bring window to the front if it isn't already
this . Initialized + = ( s , e ) = >
{
this . Activate ( ) ;
this . Topmost = true ;
this . Focus ( ) ;
} ;
this . ContentRendered + = ( s , e ) = >
{
this . Topmost = false ;
} ;
2022-05-15 22:38:22 +00:00
( ( MainWindowVM ) DataContext ) . WhenAnyValue ( vm = > vm . OpenSettingsCommand )
. BindTo ( this , view = > view . SettingsButton . Command ) ;
2022-03-13 22:47:30 +00:00
}
catch ( Exception ex )
{
_logger . LogError ( ex , "During Main Window Startup" ) ;
Environment . Exit ( - 1 ) ;
}
vm . WhenAnyValue ( vm = > vm . ResourceStatus )
. BindToStrict ( this , view = > view . ResourceUsage . Text ) ;
vm . WhenAnyValue ( vm = > vm . ResourceStatus )
. Select ( x = > string . IsNullOrWhiteSpace ( x ) ? Visibility . Collapsed : Visibility . Visible )
. BindToStrict ( this , view = > view . ResourceUsage . Visibility ) ;
}
public void Init ( MainWindowVM vm , MainSettings settings )
{
DataContext = vm ;
_mwvm = vm ;
_settings = settings ;
}
/// <summary>
/// Starts some background initialization tasks spinning so they're already prepped when actually needed
/// </summary>
private void Warmup ( )
{
Task . Run ( AssociateListsWithWabbajack ) . FireAndForget ( ) ;
}
/// <summary>
/// Run logic to associate wabbajack lists with this app in the background
/// </summary>
private void AssociateListsWithWabbajack ( )
{
/ * TODO
var appPath = System . Reflection . Assembly . GetExecutingAssembly ( ) . Location ;
try
{
if ( ! ModListAssociationManager . IsAssociated ( ) | | ModListAssociationManager . NeedsUpdating ( appPath ) )
{
ModListAssociationManager . Associate ( appPath ) ;
}
}
catch ( Exception e )
{
Utils . Log ( $"ExtensionManager had an exception:\n{e}" ) ;
} * /
}
private void RunWhenLoaded ( Action a )
{
if ( IsLoaded )
{
a ( ) ;
}
else
{
this . Loaded + = ( sender , e ) = >
{
a ( ) ;
} ;
}
}
private void LoadSettings ( )
{
Width = _settings . Width ;
Height = _settings . Height ;
Left = _settings . PosX ;
Top = _settings . PosY ;
}
private void DefaultSettings ( )
{
Width = 1300 ;
Height = 960 ;
Left = 15 ;
Top = 15 ;
}
private void Window_Closing ( object sender , CancelEventArgs e )
{
_mwvm . ShutdownApplication ( ) . Wait ( ) ;
}
2022-03-13 23:08:27 +00:00
private void UIElement_OnMouseDown ( object sender , MouseButtonEventArgs e )
{
this . DragMove ( ) ;
}
2022-03-14 12:40:12 +00:00
private void OnOpenBrowserTab ( OpenBrowserTab msg )
{
var tab = new BrowserTabView ( msg . ViewModel ) ;
Tabs . Items . Add ( tab ) ;
Tabs . SelectedItem = tab ;
}
2022-05-15 22:38:22 +00:00
private void OnCloseBrowserTab ( CloseBrowserTab msg )
{
foreach ( var tab in Tabs . Items . OfType < BrowserTabView > ( ) )
{
if ( tab . DataContext ! = msg . ViewModel ) continue ;
Tabs . Items . Remove ( tab ) ;
break ;
}
}
2022-03-13 22:47:30 +00:00
}
}