mirror of
https://github.com/wabbajack-tools/wabbajack.git
synced 2024-08-30 18:42:17 +00:00
Add validation and errors to compiler settings
This commit is contained in:
parent
8b6d4651f4
commit
653c83d7dd
@ -1,4 +1,6 @@
|
|||||||
using System;
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
|
||||||
namespace Wabbajack
|
namespace Wabbajack
|
||||||
{
|
{
|
||||||
@ -95,6 +97,13 @@ namespace Wabbajack
|
|||||||
}
|
}
|
||||||
return ErrorResponse.Success;
|
return ErrorResponse.Success;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static ErrorResponse Combine(List<ErrorResponse> errors)
|
||||||
|
{
|
||||||
|
if (errors.All(e => e.Succeeded) || !errors.Any())
|
||||||
|
return Success;
|
||||||
|
return Fail(string.Join("\n", errors.Where(e => e.Failed).Select(e => e.Reason)));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public interface IErrorResponse
|
public interface IErrorResponse
|
||||||
|
@ -1,14 +1,11 @@
|
|||||||
using System;
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
using System.Collections.ObjectModel;
|
using System.Collections.ObjectModel;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Reactive;
|
using System.Reactive;
|
||||||
using System.Windows.Media.Imaging;
|
|
||||||
using Microsoft.Extensions.Logging;
|
using Microsoft.Extensions.Logging;
|
||||||
using Wabbajack.Extensions;
|
|
||||||
using Wabbajack.Interventions;
|
|
||||||
using Wabbajack.Messages;
|
using Wabbajack.Messages;
|
||||||
using Wabbajack.RateLimiter;
|
|
||||||
using ReactiveUI;
|
using ReactiveUI;
|
||||||
using System.Reactive.Disposables;
|
using System.Reactive.Disposables;
|
||||||
using System.Reactive.Linq;
|
using System.Reactive.Linq;
|
||||||
@ -17,24 +14,16 @@ using System.Threading;
|
|||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using System.Windows.Media;
|
using System.Windows.Media;
|
||||||
using DynamicData;
|
using DynamicData;
|
||||||
using DynamicData.Binding;
|
|
||||||
using Microsoft.Extensions.DependencyInjection;
|
|
||||||
using Microsoft.WindowsAPICodePack.Dialogs;
|
using Microsoft.WindowsAPICodePack.Dialogs;
|
||||||
using ReactiveUI.Fody.Helpers;
|
using ReactiveUI.Fody.Helpers;
|
||||||
using Wabbajack.Common;
|
using Wabbajack.Common;
|
||||||
using Wabbajack.Compiler;
|
using Wabbajack.Compiler;
|
||||||
using Wabbajack.Downloaders;
|
|
||||||
using Wabbajack.Downloaders.GameFile;
|
|
||||||
using Wabbajack.DTOs;
|
using Wabbajack.DTOs;
|
||||||
using Wabbajack.DTOs.Interventions;
|
|
||||||
using Wabbajack.DTOs.JsonConverters;
|
using Wabbajack.DTOs.JsonConverters;
|
||||||
using Wabbajack.Installer;
|
|
||||||
using Wabbajack.Models;
|
using Wabbajack.Models;
|
||||||
using Wabbajack.Networking.WabbajackClientApi;
|
|
||||||
using Wabbajack.Paths;
|
using Wabbajack.Paths;
|
||||||
using Wabbajack.Paths.IO;
|
using Wabbajack.Paths.IO;
|
||||||
using Wabbajack.Services.OSIntegrated;
|
using Wabbajack.Services.OSIntegrated;
|
||||||
using Wabbajack.VFS;
|
|
||||||
|
|
||||||
namespace Wabbajack
|
namespace Wabbajack
|
||||||
{
|
{
|
||||||
@ -101,6 +90,9 @@ namespace Wabbajack
|
|||||||
public LogStream LoggerProvider { get; }
|
public LogStream LoggerProvider { get; }
|
||||||
public ReadOnlyObservableCollection<CPUDisplayVM> StatusList => _resourceMonitor.Tasks;
|
public ReadOnlyObservableCollection<CPUDisplayVM> StatusList => _resourceMonitor.Tasks;
|
||||||
|
|
||||||
|
[Reactive]
|
||||||
|
public ErrorResponse ErrorState { get; private set; }
|
||||||
|
|
||||||
public CompilerVM(ILogger<CompilerVM> logger, DTOSerializer dtos, SettingsManager settingsManager,
|
public CompilerVM(ILogger<CompilerVM> logger, DTOSerializer dtos, SettingsManager settingsManager,
|
||||||
IServiceProvider serviceProvider, LogStream loggerProvider, ResourceMonitor resourceMonitor,
|
IServiceProvider serviceProvider, LogStream loggerProvider, ResourceMonitor resourceMonitor,
|
||||||
CompilerSettingsInferencer inferencer) : base(logger)
|
CompilerSettingsInferencer inferencer) : base(logger)
|
||||||
@ -124,26 +116,27 @@ namespace Wabbajack
|
|||||||
|
|
||||||
ExecuteCommand = ReactiveCommand.CreateFromTask(async () => await StartCompilation());
|
ExecuteCommand = ReactiveCommand.CreateFromTask(async () => await StartCompilation());
|
||||||
|
|
||||||
ModlistLocation = new FilePickerVM()
|
ModlistLocation = new FilePickerVM
|
||||||
{
|
{
|
||||||
ExistCheckOption = FilePickerVM.CheckOptions.On,
|
ExistCheckOption = FilePickerVM.CheckOptions.On,
|
||||||
PathType = FilePickerVM.PathTypeOptions.File,
|
PathType = FilePickerVM.PathTypeOptions.File,
|
||||||
PromptTitle = "Select a config file or a modlist.txt file"
|
PromptTitle = "Select a config file or a modlist.txt file"
|
||||||
};
|
};
|
||||||
|
|
||||||
DownloadLocation = new FilePickerVM()
|
DownloadLocation = new FilePickerVM
|
||||||
{
|
{
|
||||||
ExistCheckOption = FilePickerVM.CheckOptions.On,
|
ExistCheckOption = FilePickerVM.CheckOptions.On,
|
||||||
PathType = FilePickerVM.PathTypeOptions.Folder,
|
PathType = FilePickerVM.PathTypeOptions.Folder,
|
||||||
PromptTitle = "Location where the downloads for this list are stored"
|
PromptTitle = "Location where the downloads for this list are stored"
|
||||||
};
|
};
|
||||||
|
|
||||||
OutputLocation = new FilePickerVM()
|
OutputLocation = new FilePickerVM
|
||||||
{
|
{
|
||||||
ExistCheckOption = FilePickerVM.CheckOptions.On,
|
ExistCheckOption = FilePickerVM.CheckOptions.Off,
|
||||||
PathType = FilePickerVM.PathTypeOptions.Folder,
|
PathType = FilePickerVM.PathTypeOptions.File,
|
||||||
PromptTitle = "Location where the compiled modlist will be stored"
|
PromptTitle = "Location where the compiled modlist will be stored"
|
||||||
};
|
};
|
||||||
|
OutputLocation.Filters.Add(new CommonFileDialogFilter(".wabbajack", "*.wabbajack"));
|
||||||
|
|
||||||
ModlistLocation.Filters.AddRange(new []
|
ModlistLocation.Filters.AddRange(new []
|
||||||
{
|
{
|
||||||
@ -161,10 +154,32 @@ namespace Wabbajack
|
|||||||
.Subscribe(p => InferModListFromLocation(p).FireAndForget())
|
.Subscribe(p => InferModListFromLocation(p).FireAndForget())
|
||||||
.DisposeWith(disposables);
|
.DisposeWith(disposables);
|
||||||
|
|
||||||
|
|
||||||
|
this.WhenAnyValue(x => x.DownloadLocation.TargetPath)
|
||||||
|
.CombineLatest(this.WhenAnyValue(x => x.ModlistLocation.TargetPath),
|
||||||
|
this.WhenAnyValue(x => x.OutputLocation.TargetPath),
|
||||||
|
this.WhenAnyValue(x => x.DownloadLocation.ErrorState),
|
||||||
|
this.WhenAnyValue(x => x.ModlistLocation.ErrorState),
|
||||||
|
this.WhenAnyValue(x => x.OutputLocation.ErrorState),
|
||||||
|
this.WhenAnyValue(x => x.ModListName),
|
||||||
|
this.WhenAnyValue(x => x.Version))
|
||||||
|
.Select(_ => Validate())
|
||||||
|
.BindToStrict(this, vm => vm.ErrorState)
|
||||||
|
.DisposeWith(disposables);
|
||||||
|
|
||||||
LoadLastSavedSettings().FireAndForget();
|
LoadLastSavedSettings().FireAndForget();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private ErrorResponse Validate()
|
||||||
|
{
|
||||||
|
var errors = new List<ErrorResponse>();
|
||||||
|
errors.Add(DownloadLocation.ErrorState);
|
||||||
|
errors.Add(ModlistLocation.ErrorState);
|
||||||
|
errors.Add(OutputLocation.ErrorState);
|
||||||
|
return ErrorResponse.Combine(errors);
|
||||||
|
}
|
||||||
|
|
||||||
private async Task InferModListFromLocation(AbsolutePath path)
|
private async Task InferModListFromLocation(AbsolutePath path)
|
||||||
{
|
{
|
||||||
using var _ = LoadingLock.WithLoading();
|
using var _ = LoadingLock.WithLoading();
|
||||||
|
@ -71,6 +71,30 @@ namespace Wabbajack
|
|||||||
|
|
||||||
UserInterventionsControl.Visibility = Visibility.Collapsed;
|
UserInterventionsControl.Visibility = Visibility.Collapsed;
|
||||||
|
|
||||||
|
// Errors
|
||||||
|
this.WhenAnyValue(view => view.ViewModel.ErrorState)
|
||||||
|
.Select(x => !x.Failed)
|
||||||
|
.BindToStrict(this, view => view.BeginButton.IsEnabled)
|
||||||
|
.DisposeWith(disposables);
|
||||||
|
|
||||||
|
this.WhenAnyValue(view => view.ViewModel.ErrorState)
|
||||||
|
.Select(x => x.Failed ? Visibility.Visible : Visibility.Hidden)
|
||||||
|
.BindToStrict(this, view => view.ErrorSummaryIcon.Visibility)
|
||||||
|
.DisposeWith(disposables);
|
||||||
|
|
||||||
|
this.WhenAnyValue(view => view.ViewModel.ErrorState)
|
||||||
|
.Select(x => x.Failed ? Visibility.Visible : Visibility.Hidden)
|
||||||
|
.BindToStrict(this, view => view.ErrorSummaryIconGlow.Visibility)
|
||||||
|
.DisposeWith(disposables);
|
||||||
|
|
||||||
|
this.WhenAnyValue(view => view.ViewModel.ErrorState)
|
||||||
|
.Select(x => x.Reason)
|
||||||
|
.BindToStrict(this, view => view.ErrorSummaryIcon.ToolTip)
|
||||||
|
.DisposeWith(disposables);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Settings
|
// Settings
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user