|
|
@ -6,9 +6,12 @@ using ReactiveUI; |
|
|
using Avalonia.ReactiveUI; |
|
|
using Avalonia.ReactiveUI; |
|
|
using Avalonia.UnitTests; |
|
|
using Avalonia.UnitTests; |
|
|
using Avalonia.Controls; |
|
|
using Avalonia.Controls; |
|
|
|
|
|
using Avalonia.Controls.Templates; |
|
|
using System.Collections.Generic; |
|
|
using System.Collections.Generic; |
|
|
using System.Collections.ObjectModel; |
|
|
using System.Collections.ObjectModel; |
|
|
using System.Linq; |
|
|
using System.Linq; |
|
|
|
|
|
using Avalonia.VisualTree; |
|
|
|
|
|
using Avalonia.Controls.Presenters; |
|
|
using Splat; |
|
|
using Splat; |
|
|
|
|
|
|
|
|
namespace Avalonia.ReactiveUI.UnitTests |
|
|
namespace Avalonia.ReactiveUI.UnitTests |
|
|
@ -26,7 +29,7 @@ namespace Avalonia.ReactiveUI.UnitTests |
|
|
|
|
|
|
|
|
public class ExampleView : ReactiveUserControl<ExampleViewModel> |
|
|
public class ExampleView : ReactiveUserControl<ExampleViewModel> |
|
|
{ |
|
|
{ |
|
|
public ListBox List { get; } = new ListBox(); |
|
|
public ItemsControl List { get; } = new ItemsControl(); |
|
|
|
|
|
|
|
|
public ExampleView() |
|
|
public ExampleView() |
|
|
{ |
|
|
{ |
|
|
@ -40,17 +43,48 @@ namespace Avalonia.ReactiveUI.UnitTests |
|
|
{ |
|
|
{ |
|
|
Locator.CurrentMutable.RegisterConstant(new AutoDataTemplateBindingHook(), typeof(IPropertyBindingHook)); |
|
|
Locator.CurrentMutable.RegisterConstant(new AutoDataTemplateBindingHook(), typeof(IPropertyBindingHook)); |
|
|
Locator.CurrentMutable.Register(() => new ExampleView(), typeof(IViewFor<ExampleViewModel>)); |
|
|
Locator.CurrentMutable.Register(() => new ExampleView(), typeof(IViewFor<ExampleViewModel>)); |
|
|
|
|
|
Locator.CurrentMutable.RegisterConstant(new AvaloniaActivationForViewFetcher(), typeof(IActivationForViewFetcher)); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
[Fact] |
|
|
[Fact] |
|
|
public void Should_Apply_Data_Template_Binding_When_No_Template_Is_Set() |
|
|
public void Should_Apply_Data_Template_Binding_When_No_Template_Is_Set() |
|
|
{ |
|
|
{ |
|
|
var view = new ExampleView(); |
|
|
var view = new ExampleView(); |
|
|
var root = new TestRoot |
|
|
|
|
|
{ |
|
|
|
|
|
Child = view |
|
|
|
|
|
}; |
|
|
|
|
|
Assert.NotNull(view.List.ItemTemplate); |
|
|
Assert.NotNull(view.List.ItemTemplate); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
[Fact] |
|
|
|
|
|
public void Should_Use_View_Model_View_Host_As_Data_Template() |
|
|
|
|
|
{ |
|
|
|
|
|
var view = new ExampleView(); |
|
|
|
|
|
view.ViewModel.Items.Add(new NestedViewModel()); |
|
|
|
|
|
|
|
|
|
|
|
view.List.Template = GetTemplate(); |
|
|
|
|
|
view.List.ApplyTemplate(); |
|
|
|
|
|
view.List.Presenter.ApplyTemplate(); |
|
|
|
|
|
|
|
|
|
|
|
var child = view.List.Presenter.Panel.Children[0]; |
|
|
|
|
|
var container = (ContentPresenter) child; |
|
|
|
|
|
container.UpdateChild(); |
|
|
|
|
|
|
|
|
|
|
|
Assert.IsType<ViewModelViewHost>(container.Child); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private FuncControlTemplate GetTemplate() |
|
|
|
|
|
{ |
|
|
|
|
|
return new FuncControlTemplate<ItemsControl>(parent => |
|
|
|
|
|
{ |
|
|
|
|
|
return new Border |
|
|
|
|
|
{ |
|
|
|
|
|
Background = new Media.SolidColorBrush(0xffffffff), |
|
|
|
|
|
Child = new ItemsPresenter |
|
|
|
|
|
{ |
|
|
|
|
|
Name = "PART_ItemsPresenter", |
|
|
|
|
|
MemberSelector = parent.MemberSelector, |
|
|
|
|
|
[~ItemsPresenter.ItemsProperty] = parent[~ItemsControl.ItemsProperty], |
|
|
|
|
|
} |
|
|
|
|
|
}; |
|
|
|
|
|
}); |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |