Files
@ d16a2d816aa5
Branch filter:
Location: ATITD-Tools/Desert-Paint-Codex/ViewModels/WelcomeViewModel.cs - annotation
d16a2d816aa5
1.6 KiB
text/x-csharp
Don't open the recipe generator log file on view creation - only open it if configured when starting recipe generation. Fixes a crash when importing reaction data / profile data.
40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 7117d2e703c8 7117d2e703c8 7117d2e703c8 7117d2e703c8 7117d2e703c8 7117d2e703c8 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 7117d2e703c8 7117d2e703c8 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 40eaee10ae56 | using System;
using System.Reactive;
using System.Reactive.Linq;
using DesertPaintCodex.Services;
using ReactiveUI;
namespace DesertPaintCodex.ViewModels
{
public class WelcomeViewModel : ViewModelBase
{
private SelectProfileViewModel? _selectProfileVM;
private CreateProfileViewModel? _createProfileVM;
private ViewModelBase? _profileActivity;
public ViewModelBase? ProfileActivity { get => _profileActivity; private set => this.RaiseAndSetIfChanged(ref _profileActivity, value); }
public WelcomeViewModel()
{
FinishWelcome = ReactiveCommand.Create(() => { });
if (ProfileManager.HasProfiles())
{
ShowSelectProfile();
}
else
{
ShowCreateProfile();
}
}
private void ShowSelectProfile()
{
_selectProfileVM = new SelectProfileViewModel();
_selectProfileVM.NewProfile.Subscribe(_ => ShowCreateProfile());
Observable.Merge(_selectProfileVM.Ok, _selectProfileVM.Cancel)
.Take(1)
.InvokeCommand(FinishWelcome);
ProfileActivity = _selectProfileVM;
}
private void ShowCreateProfile()
{
_createProfileVM = new CreateProfileViewModel();
Observable.Merge(_createProfileVM.Ok, _createProfileVM.Cancel).Subscribe(_ => ShowSelectProfile());
ProfileActivity = _createProfileVM;
}
public ReactiveCommand<Unit, Unit> FinishWelcome { get; }
}
}
|