impliment NavigateService
This commit is contained in:
@@ -1,4 +1,5 @@
|
|||||||
using Apollon.Domain.Models;
|
using Apollon.Domain.Models;
|
||||||
|
using Apollon.WPF.Services;
|
||||||
using Apollon.WPF.Stores;
|
using Apollon.WPF.Stores;
|
||||||
using Apollon.WPF.ViewModels;
|
using Apollon.WPF.ViewModels;
|
||||||
using System;
|
using System;
|
||||||
@@ -12,19 +13,23 @@ namespace Apollon.WPF.Commands
|
|||||||
public class AddTournamentCommand : AsyncCommandBase
|
public class AddTournamentCommand : AsyncCommandBase
|
||||||
{
|
{
|
||||||
private readonly TournamentsStore _tournamentStore;
|
private readonly TournamentsStore _tournamentStore;
|
||||||
private readonly NavigationStore _navigationStore;
|
private readonly NavigationService<PreparationViewModel> _navigationService;
|
||||||
private readonly ModalNavigationStore _modalNavigationStore;
|
private readonly ModalNavigationStore _modalNavigationStore;
|
||||||
private readonly SelectedTournamentsStore _selectedTournamentsStore;
|
private readonly SelectedTournamentsStore _selectedTournamentsStore;
|
||||||
private AddTournamentViewModel _addTournamentViewModel;
|
private AddTournamentViewModel _addTournamentViewModel;
|
||||||
|
|
||||||
|
public AddTournamentCommand(AddTournamentViewModel addTournamentViewModel, NavigationService<PreparationViewModel> navigationService)
|
||||||
public AddTournamentCommand(AddTournamentViewModel addTournamentViewModel, TournamentsStore tournamentStore, ModalNavigationStore modalNavigationStore, NavigationStore navigationStore, SelectedTournamentsStore selectedTournamentsStore)
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
public AddTournamentCommand(TournamentsStore tournamentStore, NavigationService<PreparationViewModel> navigationService, ModalNavigationStore modalNavigationStore,
|
||||||
|
SelectedTournamentsStore selectedTournamentsStore, AddTournamentViewModel addTournamentViewModel)
|
||||||
{
|
{
|
||||||
_addTournamentViewModel = addTournamentViewModel;
|
|
||||||
_tournamentStore = tournamentStore;
|
_tournamentStore = tournamentStore;
|
||||||
|
_navigationService = navigationService;
|
||||||
_modalNavigationStore = modalNavigationStore;
|
_modalNavigationStore = modalNavigationStore;
|
||||||
_navigationStore = navigationStore;
|
|
||||||
_selectedTournamentsStore = selectedTournamentsStore;
|
_selectedTournamentsStore = selectedTournamentsStore;
|
||||||
|
_addTournamentViewModel = addTournamentViewModel;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override async Task ExecuteAsync(object parameter)
|
public override async Task ExecuteAsync(object parameter)
|
||||||
@@ -52,7 +57,7 @@ namespace Apollon.WPF.Commands
|
|||||||
await _tournamentStore.Add(tournament);
|
await _tournamentStore.Add(tournament);
|
||||||
|
|
||||||
_modalNavigationStore.Close();
|
_modalNavigationStore.Close();
|
||||||
_navigationStore.CurrentViewModel = new PreparationViewModel(_selectedTournamentsStore, _navigationStore, _modalNavigationStore, _tournamentStore);
|
_navigationService.Navigate();
|
||||||
|
|
||||||
}
|
}
|
||||||
catch (Exception)
|
catch (Exception)
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
using Apollon.WPF.Stores;
|
using Apollon.WPF.Services;
|
||||||
|
using Apollon.WPF.Stores;
|
||||||
using Apollon.WPF.ViewModels;
|
using Apollon.WPF.ViewModels;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
@@ -11,18 +12,16 @@ namespace Apollon.WPF.Commands
|
|||||||
public class NavigateCommand<TViewModel> : CommandBase
|
public class NavigateCommand<TViewModel> : CommandBase
|
||||||
where TViewModel : ViewModelBase
|
where TViewModel : ViewModelBase
|
||||||
{
|
{
|
||||||
private readonly NavigationStore _navigationStore;
|
private readonly NavigationService<TViewModel> _navigationService;
|
||||||
private readonly Func<TViewModel> _createViewModel;
|
|
||||||
|
|
||||||
public NavigateCommand(NavigationStore navigationStore, Func<TViewModel> createViewModel)
|
public NavigateCommand(NavigationService<TViewModel> navigationService)
|
||||||
{
|
{
|
||||||
_navigationStore = navigationStore;
|
_navigationService = navigationService;
|
||||||
_createViewModel = createViewModel;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public override void Execute(object parameter)
|
public override void Execute(object parameter)
|
||||||
{
|
{
|
||||||
_navigationStore.CurrentViewModel = _createViewModel();
|
_navigationService.Navigate();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
28
Apollon.WPF/Services/NavigationService.cs
Normal file
28
Apollon.WPF/Services/NavigationService.cs
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
using Apollon.WPF.Stores;
|
||||||
|
using Apollon.WPF.ViewModels;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace Apollon.WPF.Services
|
||||||
|
{
|
||||||
|
public class NavigationService<TViewModel>
|
||||||
|
where TViewModel : ViewModelBase
|
||||||
|
{
|
||||||
|
private readonly NavigationStore _navigationStore;
|
||||||
|
private readonly Func<TViewModel> _createViewModel;
|
||||||
|
|
||||||
|
public NavigationService(NavigationStore navigationStore, Func<TViewModel> createViewModel)
|
||||||
|
{
|
||||||
|
_navigationStore = navigationStore;
|
||||||
|
_createViewModel = createViewModel;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Navigate()
|
||||||
|
{
|
||||||
|
_navigationStore.CurrentViewModel = _createViewModel();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,4 +1,5 @@
|
|||||||
using Apollon.WPF.Commands;
|
using Apollon.WPF.Commands;
|
||||||
|
using Apollon.WPF.Services;
|
||||||
using Apollon.WPF.Stores;
|
using Apollon.WPF.Stores;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
@@ -15,7 +16,7 @@ namespace Apollon.WPF.ViewModels
|
|||||||
|
|
||||||
public AddTournamentViewModel(TournamentsStore tournamentStore, ModalNavigationStore modalNavigationStore, NavigationStore navigationStore,SelectedTournamentsStore selectedTournamentsStore)
|
public AddTournamentViewModel(TournamentsStore tournamentStore, ModalNavigationStore modalNavigationStore, NavigationStore navigationStore,SelectedTournamentsStore selectedTournamentsStore)
|
||||||
{
|
{
|
||||||
ICommand submitCommand = new AddTournamentCommand(this, tournamentStore,modalNavigationStore,navigationStore, selectedTournamentsStore);
|
ICommand submitCommand = new AddTournamentCommand(this, new NavigationService<PreparationViewModel>(navigationStore, () => new PreparationViewModel( selectedTournamentsStore, navigationStore, modalNavigationStore, tournamentStore)));
|
||||||
ICommand cancelCommand = new CloseModalCommand(modalNavigationStore);
|
ICommand cancelCommand = new CloseModalCommand(modalNavigationStore);
|
||||||
AddEditDetailsViewModel = new AddEditDetailsViewModel(submitCommand, cancelCommand);
|
AddEditDetailsViewModel = new AddEditDetailsViewModel(submitCommand, cancelCommand);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
using Apollon.Domain.Models;
|
using Apollon.Domain.Models;
|
||||||
using Apollon.WPF.Commands;
|
using Apollon.WPF.Commands;
|
||||||
|
using Apollon.WPF.Services;
|
||||||
using Apollon.WPF.Stores;
|
using Apollon.WPF.Stores;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
@@ -35,7 +36,8 @@ namespace Apollon.WPF.ViewModels
|
|||||||
|
|
||||||
_selectedTournamentStore.SelectedTournamentChanged += SelectedTournamentStore_SelectedTournamentChanged;
|
_selectedTournamentStore.SelectedTournamentChanged += SelectedTournamentStore_SelectedTournamentChanged;
|
||||||
|
|
||||||
NavigateTournamentDetailsCommand = new NavigateCommand<PreparationViewModel>(navigationStore, () => new PreparationViewModel(_selectedTournamentStore,navigationStore, modalNavigationStore, tournamentsStore));
|
NavigateTournamentDetailsCommand = new NavigateCommand<PreparationViewModel>(new NavigationService<PreparationViewModel>(navigationStore,() => new PreparationViewModel(
|
||||||
|
selectedTournamentStore,navigationStore,modalNavigationStore, tournamentsStore)));
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void Dispose()
|
protected override void Dispose()
|
||||||
|
|||||||
@@ -7,6 +7,7 @@ using System.Linq;
|
|||||||
using System.Text;
|
using System.Text;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using System.Windows.Input;
|
using System.Windows.Input;
|
||||||
|
using Apollon.WPF.Services;
|
||||||
|
|
||||||
namespace Apollon.WPF.ViewModels
|
namespace Apollon.WPF.ViewModels
|
||||||
{
|
{
|
||||||
@@ -58,7 +59,7 @@ namespace Apollon.WPF.ViewModels
|
|||||||
|
|
||||||
LoadTournamentsCommand = new LoadTournamentsCommand(this, tournamentStore);
|
LoadTournamentsCommand = new LoadTournamentsCommand(this, tournamentStore);
|
||||||
AddTournamentCommand = new OpenAddTournamentCommand(tournamentStore, modalNavigationStore, navigationStore, selectedTournamentStore);
|
AddTournamentCommand = new OpenAddTournamentCommand(tournamentStore, modalNavigationStore, navigationStore, selectedTournamentStore);
|
||||||
NavigateNameListCommand = new NavigateCommand<NameListViewModel>(navigationStore, () => new NameListViewModel());
|
NavigateNameListCommand = new NavigateCommand<NameListViewModel>(new NavigationService<NameListViewModel>(navigationStore, () => new NameListViewModel()));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
using Apollon.Domain.Models;
|
using Apollon.Domain.Models;
|
||||||
using Apollon.WPF.Commands;
|
using Apollon.WPF.Commands;
|
||||||
|
using Apollon.WPF.Services;
|
||||||
using Apollon.WPF.Stores;
|
using Apollon.WPF.Stores;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
@@ -21,7 +22,8 @@ namespace Apollon.WPF.ViewModels
|
|||||||
{
|
{
|
||||||
TournamentDetailsViewModel = new TournamentDetailsViewModel(selectedTournamentStore);
|
TournamentDetailsViewModel = new TournamentDetailsViewModel(selectedTournamentStore);
|
||||||
|
|
||||||
NavigateOverviewCommand = new NavigateCommand<OverviewViewModel>(navigationStore, () => OverviewViewModel.LoadViewModel(selectedTournamentStore, modalNavigationStore, tournamentsStore, navigationStore));
|
NavigateOverviewCommand = new NavigateCommand<OverviewViewModel>(new NavigationService<OverviewViewModel>(navigationStore, () => OverviewViewModel.LoadViewModel(selectedTournamentStore, modalNavigationStore, tournamentsStore, navigationStore)));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user