mirror of
https://github.com/wabbajack-tools/wabbajack.git
synced 2024-08-30 18:42:17 +00:00
Add active navigation bar color
This commit is contained in:
parent
e3301407fd
commit
f77b29ec08
@ -2,10 +2,8 @@ using ReactiveUI;
|
|||||||
|
|
||||||
namespace Wabbajack.Messages;
|
namespace Wabbajack.Messages;
|
||||||
|
|
||||||
public class NavigateToGlobal
|
public enum ScreenType
|
||||||
{
|
{
|
||||||
public enum ScreenType
|
|
||||||
{
|
|
||||||
Home,
|
Home,
|
||||||
ModListGallery,
|
ModListGallery,
|
||||||
Installer,
|
Installer,
|
||||||
@ -13,7 +11,10 @@ public class NavigateToGlobal
|
|||||||
Compiler,
|
Compiler,
|
||||||
ModListContents,
|
ModListContents,
|
||||||
WebBrowser
|
WebBrowser
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public class NavigateToGlobal
|
||||||
|
{
|
||||||
|
|
||||||
public ScreenType Screen { get; }
|
public ScreenType Screen { get; }
|
||||||
|
|
||||||
|
@ -1,18 +0,0 @@
|
|||||||
using ReactiveUI;
|
|
||||||
using System.Windows.Input;
|
|
||||||
using Wabbajack.Messages;
|
|
||||||
|
|
||||||
namespace Wabbajack.Models;
|
|
||||||
|
|
||||||
public abstract class ANavigationItem : INavigationItem
|
|
||||||
{
|
|
||||||
public ICommand GoToCommand { get; }
|
|
||||||
public virtual NavigateToGlobal.ScreenType Screen { get; }
|
|
||||||
|
|
||||||
public virtual bool MainMenuItem { get; }
|
|
||||||
|
|
||||||
public ANavigationItem()
|
|
||||||
{
|
|
||||||
GoToCommand = ReactiveCommand.Create(() => NavigateToGlobal.Send(Screen));
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,11 +0,0 @@
|
|||||||
using System.Windows.Input;
|
|
||||||
using Wabbajack.Messages;
|
|
||||||
|
|
||||||
namespace Wabbajack.Models;
|
|
||||||
|
|
||||||
public interface INavigationItem
|
|
||||||
{
|
|
||||||
public ICommand GoToCommand { get; }
|
|
||||||
public NavigateToGlobal.ScreenType Screen { get; }
|
|
||||||
public bool MainMenuItem { get; }
|
|
||||||
}
|
|
@ -1,24 +0,0 @@
|
|||||||
using Wabbajack.Messages;
|
|
||||||
|
|
||||||
namespace Wabbajack.Models;
|
|
||||||
|
|
||||||
public class HomeNI : ANavigationItem
|
|
||||||
{
|
|
||||||
public override NavigateToGlobal.ScreenType Screen => NavigateToGlobal.ScreenType.Home;
|
|
||||||
public override bool MainMenuItem => true;
|
|
||||||
}
|
|
||||||
public class ModlistGalleryNI : ANavigationItem
|
|
||||||
{
|
|
||||||
public override NavigateToGlobal.ScreenType Screen => NavigateToGlobal.ScreenType.ModListGallery;
|
|
||||||
public override bool MainMenuItem => true;
|
|
||||||
}
|
|
||||||
public class CompileNI : ANavigationItem
|
|
||||||
{
|
|
||||||
public override NavigateToGlobal.ScreenType Screen => NavigateToGlobal.ScreenType.Compiler;
|
|
||||||
public override bool MainMenuItem => true;
|
|
||||||
}
|
|
||||||
public class SettingsNI : ANavigationItem
|
|
||||||
{
|
|
||||||
public override NavigateToGlobal.ScreenType Screen => NavigateToGlobal.ScreenType.Settings;
|
|
||||||
public override bool MainMenuItem => true;
|
|
||||||
}
|
|
@ -26,6 +26,7 @@
|
|||||||
|
|
||||||
<!-- Colors -->
|
<!-- Colors -->
|
||||||
<Color x:Key="WindowBackgroundColor">#222531</Color>
|
<Color x:Key="WindowBackgroundColor">#222531</Color>
|
||||||
|
<Color x:Key="WindowHoverBackgroundColor">#2A2B41</Color>
|
||||||
<Color x:Key="DarkBackgroundColor">#3c3652</Color>
|
<Color x:Key="DarkBackgroundColor">#3c3652</Color>
|
||||||
<Color x:Key="DarkHoverBackgroundColor">#4e4571</Color>
|
<Color x:Key="DarkHoverBackgroundColor">#4e4571</Color>
|
||||||
<Color x:Key="LightBackgroundColor">#424242</Color>
|
<Color x:Key="LightBackgroundColor">#424242</Color>
|
||||||
@ -118,6 +119,7 @@
|
|||||||
<SolidColorBrush x:Key="DimForegroundBrush" Color="{StaticResource DimForegroundColor}" />
|
<SolidColorBrush x:Key="DimForegroundBrush" Color="{StaticResource DimForegroundColor}" />
|
||||||
<SolidColorBrush x:Key="MouseOverForegroundBrush" Color="{StaticResource DarkBackgroundColor}" />
|
<SolidColorBrush x:Key="MouseOverForegroundBrush" Color="{StaticResource DarkBackgroundColor}" />
|
||||||
<SolidColorBrush x:Key="WindowBackgroundBrush" Color="{StaticResource WindowBackgroundColor}" />
|
<SolidColorBrush x:Key="WindowBackgroundBrush" Color="{StaticResource WindowBackgroundColor}" />
|
||||||
|
<SolidColorBrush x:Key="WindowHoverBackgroundBrush" Color="{StaticResource WindowHoverBackgroundColor}" />
|
||||||
<SolidColorBrush x:Key="BorderInterestBrush" Color="{StaticResource HeatedBorderColor}" />
|
<SolidColorBrush x:Key="BorderInterestBrush" Color="{StaticResource HeatedBorderColor}" />
|
||||||
<SolidColorBrush x:Key="HeatedBorderBrush" Color="{StaticResource HeatedBorderColor}" />
|
<SolidColorBrush x:Key="HeatedBorderBrush" Color="{StaticResource HeatedBorderColor}" />
|
||||||
|
|
||||||
@ -1196,8 +1198,8 @@
|
|||||||
<Style.Resources>
|
<Style.Resources>
|
||||||
<Style TargetType="ic:SymbolIcon">
|
<Style TargetType="ic:SymbolIcon">
|
||||||
<Style.Triggers>
|
<Style.Triggers>
|
||||||
<DataTrigger Binding="{Binding RelativeSource={RelativeSource AncestorType=Button, AncestorLevel=1}, Path=IsMouseOver}" Value="True">
|
<DataTrigger Binding="{Binding RelativeSource={RelativeSource AncestorType=Button}, Path=IsMouseOver}" Value="True">
|
||||||
<Setter Property="IsFilled" Value="True" />
|
<Setter Property="IsFilled" Value="True"/>
|
||||||
</DataTrigger>
|
</DataTrigger>
|
||||||
</Style.Triggers>
|
</Style.Triggers>
|
||||||
</Style>
|
</Style>
|
||||||
@ -1260,7 +1262,29 @@
|
|||||||
</Style>
|
</Style>
|
||||||
</Style.Resources>
|
</Style.Resources>
|
||||||
</Style>
|
</Style>
|
||||||
<Style BasedOn="{StaticResource MainButtonStyle}" TargetType="{x:Type Button}" />
|
<Style x:Key="MainNavButtonStyle" BasedOn="{StaticResource MainButtonStyle}" TargetType="{x:Type Button}">
|
||||||
|
<Setter Property="Background" Value="{StaticResource WindowBackgroundBrush}"/>
|
||||||
|
<Setter Property="BorderBrush" Value="Transparent"/>
|
||||||
|
<Style.Resources>
|
||||||
|
<Style TargetType="Button">
|
||||||
|
<Style.Triggers>
|
||||||
|
<Trigger Property="IsMouseOver" Value="True">
|
||||||
|
<Setter Property="Background" Value="{StaticResource DarkHoverBackgroundBrush}" />
|
||||||
|
</Trigger>
|
||||||
|
</Style.Triggers>
|
||||||
|
</Style>
|
||||||
|
</Style.Resources>
|
||||||
|
</Style>
|
||||||
|
<Style x:Key="ActiveNavButtonStyle" BasedOn="{StaticResource MainButtonStyle}" TargetType="{x:Type Button}">
|
||||||
|
<Setter Property="BorderBrush" Value="Transparent"/>
|
||||||
|
<Setter Property="Background" Value="{StaticResource WindowHoverBackgroundBrush}"/>
|
||||||
|
<Setter Property="Foreground" Value="{StaticResource PrimaryBrush}"/>
|
||||||
|
<Style.Resources>
|
||||||
|
<Style TargetType="ic:SymbolIcon">
|
||||||
|
<Setter Property="IsFilled" Value="True"/>
|
||||||
|
</Style>
|
||||||
|
</Style.Resources>
|
||||||
|
</Style>
|
||||||
|
|
||||||
<Style
|
<Style
|
||||||
x:Key="CircleButtonStyle"
|
x:Key="CircleButtonStyle"
|
||||||
|
@ -124,7 +124,7 @@ namespace Wabbajack
|
|||||||
ReactiveCommand.CreateFromTask(async () =>
|
ReactiveCommand.CreateFromTask(async () =>
|
||||||
{
|
{
|
||||||
await SaveSettingsFile();
|
await SaveSettingsFile();
|
||||||
NavigateToGlobal.Send(NavigateToGlobal.ScreenType.Home);
|
NavigateToGlobal.Send(ScreenType.Home);
|
||||||
});
|
});
|
||||||
|
|
||||||
SubCompilerVM = new MO2CompilerVM(this);
|
SubCompilerVM = new MO2CompilerVM(this);
|
||||||
|
@ -106,7 +106,7 @@ namespace Wabbajack
|
|||||||
BackCommand = ReactiveCommand.Create(
|
BackCommand = ReactiveCommand.Create(
|
||||||
() =>
|
() =>
|
||||||
{
|
{
|
||||||
NavigateToGlobal.Send(NavigateToGlobal.ScreenType.Home);
|
NavigateToGlobal.Send(ScreenType.Home);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
@ -148,7 +148,7 @@ namespace Wabbajack
|
|||||||
if (await _maintainer.HaveModList(Metadata))
|
if (await _maintainer.HaveModList(Metadata))
|
||||||
{
|
{
|
||||||
LoadModlistForInstalling.Send(_maintainer.ModListPath(Metadata), Metadata);
|
LoadModlistForInstalling.Send(_maintainer.ModListPath(Metadata), Metadata);
|
||||||
NavigateToGlobal.Send(NavigateToGlobal.ScreenType.Installer);
|
NavigateToGlobal.Send(ScreenType.Installer);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -27,7 +27,7 @@ namespace Wabbajack
|
|||||||
public HomeVM(Client wjClient)
|
public HomeVM(Client wjClient)
|
||||||
{
|
{
|
||||||
_wjClient = wjClient;
|
_wjClient = wjClient;
|
||||||
BrowseCommand = ReactiveCommand.Create(() => NavigateToGlobal.Send(NavigateToGlobal.ScreenType.ModListGallery));
|
BrowseCommand = ReactiveCommand.Create(() => NavigateToGlobal.Send(ScreenType.ModListGallery));
|
||||||
VisitModlistWizardCommand = ReactiveCommand.Create(() =>
|
VisitModlistWizardCommand = ReactiveCommand.Create(() =>
|
||||||
{
|
{
|
||||||
ProcessStartInfo processStartInfo = new(Consts.WabbajackModlistWizardUri.ToString())
|
ProcessStartInfo processStartInfo = new(Consts.WabbajackModlistWizardUri.ToString())
|
||||||
|
@ -172,7 +172,7 @@ public class InstallerVM : BackNavigatingVM, IBackNavigatingVM, ICpuStatusVM
|
|||||||
|
|
||||||
Installer = new MO2InstallerVM(this);
|
Installer = new MO2InstallerVM(this);
|
||||||
|
|
||||||
BackCommand = ReactiveCommand.Create(() => NavigateToGlobal.Send(NavigateToGlobal.ScreenType.Home));
|
BackCommand = ReactiveCommand.Create(() => NavigateToGlobal.Send(ScreenType.Home));
|
||||||
|
|
||||||
BeginCommand = ReactiveCommand.Create(() => BeginInstall().FireAndForget());
|
BeginCommand = ReactiveCommand.Create(() => BeginInstall().FireAndForget());
|
||||||
|
|
||||||
|
@ -121,12 +121,12 @@ namespace Wabbajack
|
|||||||
if (IsStartingFromModlist(out var path))
|
if (IsStartingFromModlist(out var path))
|
||||||
{
|
{
|
||||||
LoadModlistForInstalling.Send(path, null);
|
LoadModlistForInstalling.Send(path, null);
|
||||||
NavigateToGlobal.Send(NavigateToGlobal.ScreenType.Installer);
|
NavigateToGlobal.Send(ScreenType.Installer);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Start on mode selection
|
// Start on mode selection
|
||||||
NavigateToGlobal.Send(NavigateToGlobal.ScreenType.Home);
|
NavigateToGlobal.Send(ScreenType.Home);
|
||||||
}
|
}
|
||||||
|
|
||||||
try
|
try
|
||||||
@ -223,18 +223,18 @@ namespace Wabbajack
|
|||||||
window.Show();
|
window.Show();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void HandleNavigateTo(NavigateToGlobal.ScreenType s)
|
private void HandleNavigateTo(ScreenType s)
|
||||||
{
|
{
|
||||||
if (s is NavigateToGlobal.ScreenType.Settings)
|
if (s is ScreenType.Settings)
|
||||||
PreviousPanes.Add(ActivePane);
|
PreviousPanes.Add(ActivePane);
|
||||||
|
|
||||||
ActivePane = s switch
|
ActivePane = s switch
|
||||||
{
|
{
|
||||||
NavigateToGlobal.ScreenType.Home => HomeVM,
|
ScreenType.Home => HomeVM,
|
||||||
NavigateToGlobal.ScreenType.ModListGallery => Gallery,
|
ScreenType.ModListGallery => Gallery,
|
||||||
NavigateToGlobal.ScreenType.Installer => Installer,
|
ScreenType.Installer => Installer,
|
||||||
NavigateToGlobal.ScreenType.Compiler => Compiler,
|
ScreenType.Compiler => Compiler,
|
||||||
NavigateToGlobal.ScreenType.Settings => SettingsPane,
|
ScreenType.Settings => SettingsPane,
|
||||||
_ => ActivePane
|
_ => ActivePane
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@ -271,20 +271,6 @@ namespace Wabbajack
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
public void NavigateTo(ViewModel vm)
|
|
||||||
{
|
|
||||||
ActivePane = vm;
|
|
||||||
}*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
public void NavigateTo<T>(T vm)
|
|
||||||
where T : ViewModel, IBackNavigatingVM
|
|
||||||
{
|
|
||||||
vm.NavigateBackTarget = ActivePane;
|
|
||||||
ActivePane = vm;
|
|
||||||
}*/
|
|
||||||
|
|
||||||
public async Task ShutdownApplication()
|
public async Task ShutdownApplication()
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
|
@ -26,35 +26,27 @@ namespace Wabbajack
|
|||||||
{
|
{
|
||||||
private readonly ILogger<NavigationVM> _logger;
|
private readonly ILogger<NavigationVM> _logger;
|
||||||
[Reactive]
|
[Reactive]
|
||||||
public NavigateToGlobal.ScreenType ActiveScreen { get; set; }
|
public ScreenType ActiveScreen { get; set; }
|
||||||
[Reactive]
|
|
||||||
public List<INavigationItem> NavigationItems { get; set; }
|
|
||||||
public NavigationVM(ILogger<NavigationVM> logger)
|
public NavigationVM(ILogger<NavigationVM> logger)
|
||||||
{
|
{
|
||||||
_logger = logger;
|
_logger = logger;
|
||||||
HomeCommand = ReactiveCommand.Create(() => NavigateToGlobal.Send(NavigateToGlobal.ScreenType.Home));
|
HomeCommand = ReactiveCommand.Create(() => NavigateToGlobal.Send(ScreenType.Home));
|
||||||
BrowseCommand = ReactiveCommand.Create(() => NavigateToGlobal.Send(NavigateToGlobal.ScreenType.ModListGallery));
|
BrowseCommand = ReactiveCommand.Create(() => NavigateToGlobal.Send(ScreenType.ModListGallery));
|
||||||
InstallCommand = ReactiveCommand.Create(() =>
|
InstallCommand = ReactiveCommand.Create(() =>
|
||||||
{
|
{
|
||||||
LoadLastLoadedModlist.Send();
|
LoadLastLoadedModlist.Send();
|
||||||
NavigateToGlobal.Send(NavigateToGlobal.ScreenType.Installer);
|
NavigateToGlobal.Send(ScreenType.Installer);
|
||||||
});
|
});
|
||||||
CompileCommand = ReactiveCommand.Create(() => NavigateToGlobal.Send(NavigateToGlobal.ScreenType.Compiler));
|
CompileCommand = ReactiveCommand.Create(() => NavigateToGlobal.Send(ScreenType.Compiler));
|
||||||
SettingsCommand = ReactiveCommand.Create(
|
SettingsCommand = ReactiveCommand.Create(
|
||||||
/*
|
/*
|
||||||
canExecute: this.WhenAny(x => x.ActivePane)
|
canExecute: this.WhenAny(x => x.ActivePane)
|
||||||
.Select(active => !object.ReferenceEquals(active, SettingsPane)),
|
.Select(active => !object.ReferenceEquals(active, SettingsPane)),
|
||||||
*/
|
*/
|
||||||
execute: () => NavigateToGlobal.Send(NavigateToGlobal.ScreenType.Settings));
|
execute: () => NavigateToGlobal.Send(ScreenType.Settings));
|
||||||
MessageBus.Current.Listen<NavigateToGlobal>()
|
MessageBus.Current.Listen<NavigateToGlobal>()
|
||||||
.Subscribe(x => ActiveScreen = x.Screen);
|
.Subscribe(x => ActiveScreen = x.Screen)
|
||||||
/*
|
.DisposeWith(CompositeDisposable);
|
||||||
this.WhenActivated(dispose =>
|
|
||||||
{
|
|
||||||
this.WhenAny(x => x.ActiveScreen)
|
|
||||||
.
|
|
||||||
})
|
|
||||||
*/
|
|
||||||
|
|
||||||
var processLocation = Process.GetCurrentProcess().MainModule?.FileName ?? throw new Exception("Process location is unavailable!");
|
var processLocation = Process.GetCurrentProcess().MainModule?.FileName ?? throw new Exception("Process location is unavailable!");
|
||||||
var assembly = Assembly.GetExecutingAssembly();
|
var assembly = Assembly.GetExecutingAssembly();
|
||||||
@ -62,6 +54,7 @@ namespace Wabbajack
|
|||||||
var fvi = FileVersionInfo.GetVersionInfo(string.IsNullOrWhiteSpace(assemblyLocation) ? processLocation : assemblyLocation);
|
var fvi = FileVersionInfo.GetVersionInfo(string.IsNullOrWhiteSpace(assemblyLocation) ? processLocation : assemblyLocation);
|
||||||
Version = $"{fvi.FileVersion}";
|
Version = $"{fvi.FileVersion}";
|
||||||
}
|
}
|
||||||
|
|
||||||
public ICommand HomeCommand { get; }
|
public ICommand HomeCommand { get; }
|
||||||
public ICommand BrowseCommand { get; }
|
public ICommand BrowseCommand { get; }
|
||||||
public ICommand InstallCommand { get; }
|
public ICommand InstallCommand { get; }
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
using ReactiveUI;
|
using ReactiveUI;
|
||||||
using System;
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
using System.Reactive.Disposables;
|
using System.Reactive.Disposables;
|
||||||
using System.Reactive.Linq;
|
using System.Reactive.Linq;
|
||||||
@ -15,9 +16,16 @@ namespace Wabbajack
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public partial class NavigationView : ReactiveUserControl<NavigationVM>
|
public partial class NavigationView : ReactiveUserControl<NavigationVM>
|
||||||
{
|
{
|
||||||
|
public Dictionary<ScreenType, Button> ScreenButtonDictionary { get; set; }
|
||||||
public NavigationView()
|
public NavigationView()
|
||||||
{
|
{
|
||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
|
ScreenButtonDictionary = new() {
|
||||||
|
{ ScreenType.Home, HomeButton },
|
||||||
|
{ ScreenType.ModListGallery, BrowseButton },
|
||||||
|
{ ScreenType.Compiler, CompileButton },
|
||||||
|
{ ScreenType.Settings, SettingsButton },
|
||||||
|
};
|
||||||
this.WhenActivated(dispose =>
|
this.WhenActivated(dispose =>
|
||||||
{
|
{
|
||||||
this.BindCommand(ViewModel, vm => vm.BrowseCommand, v => v.BrowseButton)
|
this.BindCommand(ViewModel, vm => vm.BrowseCommand, v => v.BrowseButton)
|
||||||
@ -33,6 +41,12 @@ namespace Wabbajack
|
|||||||
.Select(version => $"v{version}")
|
.Select(version => $"v{version}")
|
||||||
.BindToStrict(this, v => v.VersionTextBlock.Text)
|
.BindToStrict(this, v => v.VersionTextBlock.Text)
|
||||||
.DisposeWith(dispose);
|
.DisposeWith(dispose);
|
||||||
|
|
||||||
|
|
||||||
|
this.WhenAny(x => x.ViewModel.ActiveScreen)
|
||||||
|
.Subscribe(x => SetActiveScreen(x))
|
||||||
|
.DisposeWith(dispose);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
this.WhenAny(x => x.ViewModel.InstallCommand)
|
this.WhenAny(x => x.ViewModel.InstallCommand)
|
||||||
.BindToStrict(this, x => x.InstallButton.Command)
|
.BindToStrict(this, x => x.InstallButton.Command)
|
||||||
@ -43,5 +57,30 @@ namespace Wabbajack
|
|||||||
*/
|
*/
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void SetActiveScreen(ScreenType activeScreen)
|
||||||
|
{
|
||||||
|
var activeButtonStyle = (Style)Application.Current.Resources["ActiveNavButtonStyle"];
|
||||||
|
var mainButtonStyle = (Style)Application.Current.Resources["MainNavButtonStyle"];
|
||||||
|
foreach(var (screen, button) in ScreenButtonDictionary)
|
||||||
|
{
|
||||||
|
if (screen == activeScreen)
|
||||||
|
button.Style = activeButtonStyle;
|
||||||
|
else
|
||||||
|
button.Style = mainButtonStyle;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
{
|
||||||
|
var activeStyle = (Style)Application.Current.Resources["ActiveButton"];
|
||||||
|
switch(x)
|
||||||
|
{
|
||||||
|
case ScreenType.Home:
|
||||||
|
HomeButton.Style = activeStyle;
|
||||||
|
default:
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user