I search for a smart way to instantiate one View and ViewModel multiple times in a Tabcontrol with slightly different behavior. In best case by using Prism7.1
My current solution is;
in my MainView
<TabControl
ItemsSource="{Binding TabItemCollection}"
SelectedItem="{Binding SelectedTabItem}"
ItemContainerStyle="{DynamicResource ItemSize20_HeaderBinding}"
mah:TabControlHelper.Underlined="SelectedTabItem">
<TabControl.Resources>
<DataTemplate DataType="{x:Type vm:MaskingCreationViewModel}" >
<local:MaskingCreation/>
</DataTemplate>
</TabControl.Resources>
</TabControl>
in my MainViewModel
public class MainViewModel
{
public ObservableCollection<MaskingCreationViewModel> TabItemCollection { get; set; }
public MaskingCreationViewModel SelectedTabItem { get; set; }
public MainViewModel()
{
TabItemCollection = new ObservableCollection<MaskingCreationViewModel>();
TabItemCollection.Add(new MaskingCreationViewModel(new TabBehaviorA()));
TabItemCollection.Add(new MaskingCreationViewModel(new TabBehaviorB()));
SelectedTabItem = TabItemCollection[0];
}
}
Here I want to inject the "TabBehavior" in my ViewModel provide the different behavior. I tried that already with Prism to register the "MaskingCreation" in the TabControl via Region, but with that I get two problems.
regionManager.RegisterViewWithRegion(Regions.Masking, typeof(MaskingCreation));
regionManager.RegisterViewWithRegion(Regions.Masking, () =>
{
var vm = ServiceLocator.Current.GetInstance<MaskingCreationViewModel>();
vm.Behavior = new TabBehaviorB();
return vm.GetView();
});
Did anybody know a smart solution that fits in the MVVM pattern?
In the view model, I'd inject a factory for MaskingCreationViewModel
and all the tab behaviors:
internal class MainViewModel : BindableBase
{
public MainViewModel( IMaskingCreationViewModelFactory maskingCreationViewModelFactory, IEnumerable<ITabBehavior> tabBehaviors )
{
foreach (var tabBehavior in tabBehaviors)
TabItemCollection.Add( maskingCreationViewModelFactory.Create( tabBehavior ) );
SelectedTabItem = TabItemCollection.FirstOrDefault();
}
public ObservableCollection<MaskingCreationViewModel> TabItemCollection { get; } = new ObservableCollection<MaskingCreationViewModel>();
public MaskingCreationViewModel SelectedTabItem { get => _selectedTabItem; set => SetProperty( ref _selectedTabItem, value ); }
private MaskingCreationViewModel _selectedTabItem;
}