feat: add TryGetXXManager to WindowXXManager.
This commit is contained in:
@@ -1,11 +1,28 @@
|
||||
using Avalonia;
|
||||
using Avalonia.Controls;
|
||||
using Ursa.Controls;
|
||||
using Ursa.Demo.ViewModels;
|
||||
|
||||
namespace Ursa.Demo.Views;
|
||||
|
||||
public partial class MainView : UserControl
|
||||
{
|
||||
private MainViewViewModel? _viewModel;
|
||||
|
||||
public MainView()
|
||||
{
|
||||
InitializeComponent();
|
||||
}
|
||||
|
||||
protected override void OnAttachedToVisualTree(VisualTreeAttachmentEventArgs e)
|
||||
{
|
||||
base.OnAttachedToVisualTree(e);
|
||||
_viewModel = DataContext as MainViewViewModel;
|
||||
var topLevel = TopLevel.GetTopLevel(this);
|
||||
WindowNotificationManager.TryGetNotificationManager(topLevel, out var manager);
|
||||
if (manager is not null && _viewModel is not null)
|
||||
{
|
||||
_viewModel.NotificationManager = manager;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -5,9 +5,12 @@ namespace Ursa.Demo.Views;
|
||||
|
||||
public partial class MainWindow : UrsaWindow
|
||||
{
|
||||
public WindowNotificationManager? NotificationManager { get; set; }
|
||||
|
||||
public MainWindow()
|
||||
{
|
||||
InitializeComponent();
|
||||
NotificationManager = new WindowNotificationManager(this) { MaxItems = 3 };
|
||||
}
|
||||
|
||||
protected override async Task<bool> CanClose()
|
||||
|
||||
Reference in New Issue
Block a user