wabbajack/Wabbajack.App/Screens/CompilationViewModel.cs

74 lines
2.2 KiB
C#
Raw Normal View History

using System;
using System.Reactive.Disposables;
using System.Threading;
2021-10-12 05:19:13 +00:00
using System.Threading.Tasks;
using Avalonia.Threading;
using Microsoft.Extensions.DependencyInjection;
2021-10-12 05:19:13 +00:00
using Microsoft.Extensions.Logging;
using ReactiveUI;
using ReactiveUI.Fody.Helpers;
using Wabbajack.App.Messages;
using Wabbajack.App.ViewModels;
2021-10-12 05:19:13 +00:00
using Wabbajack.Common;
using Wabbajack.Compiler;
using Wabbajack.RateLimiter;
namespace Wabbajack.App.Screens;
public class CompilationViewModel : ViewModelBase
{
2021-10-23 16:51:17 +00:00
private readonly ILogger<CompilationViewModel> _logger;
private readonly IServiceProvider _provider;
private ACompiler _compiler;
2021-10-12 05:19:13 +00:00
public CompilationViewModel(ILogger<CompilationViewModel> logger, IServiceProvider provider)
{
2021-10-12 05:19:13 +00:00
_logger = logger;
_provider = provider;
Activator = new ViewModelActivator();
MessageBus.Current.Listen<StartCompilation>()
.Subscribe(Receive)
.DisposeWith(VMDisposables);
}
2021-10-23 16:51:17 +00:00
[Reactive] public string StatusText { get; set; } = "";
[Reactive] public Percent StepsProgress { get; set; } = Percent.Zero;
[Reactive] public Percent StepProgress { get; set; } = Percent.Zero;
private void Receive(StartCompilation val)
{
if (val.Settings is MO2CompilerSettings mo2)
{
var compiler = _provider.GetService<MO2Compiler>()!;
compiler.Settings = mo2;
_compiler = compiler;
_compiler.OnStatusUpdate += (sender, update) =>
{
Dispatcher.UIThread.InvokeAsync(() =>
{
StatusText = update.StatusText;
StepsProgress = update.StepsProgress;
StepProgress = update.StepProgress;
});
};
}
2021-10-23 16:51:17 +00:00
2021-10-12 05:19:13 +00:00
Compile().FireAndForget();
}
2021-10-12 05:19:13 +00:00
public async Task Compile()
{
try
{
2021-11-08 13:32:51 +00:00
var result = await Task.Run(async () => await _compiler.Begin(CancellationToken.None));
2021-10-12 05:19:13 +00:00
}
catch (Exception ex)
{
_logger.LogError(ex, "During Compilation: {Message}", ex.Message);
StatusText = $"ERRORED: {ex.Message}";
2021-10-19 23:19:06 +00:00
ErrorPageViewModel.Display("During compilation", ex);
2021-10-12 05:19:13 +00:00
}
}
}