feat: add TryGetXXManager to WindowXXManager.

This commit is contained in:
Zhang Dian
2025-03-27 23:36:32 +08:00
parent f6f01ae1d9
commit 89b17752f3
8 changed files with 65 additions and 9 deletions

View File

@@ -1,8 +1,11 @@
using System;
using Avalonia;
using Avalonia.Controls;
using Avalonia.Controls.Notifications;
using Avalonia.Controls.Primitives;
using Avalonia.VisualTree;
using Ursa.Controls;
using WindowNotificationManager = Ursa.Controls.WindowNotificationManager;
namespace Ursa.Demo.Dialogs;
@@ -25,6 +28,13 @@ public partial class CustomDemoDialog : UserControl
_viewModel.NotificationManager = new WindowNotificationManager(visualLayerManager) { MaxItems = 3 };
_viewModel.ToastManager = new WindowToastManager(visualLayerManager) { MaxItems = 3 };
}
WindowNotificationManager.TryGetNotificationManager(visualLayerManager, out var manager);
if (manager is not null && _viewModel is not null)
{
Console.WriteLine(ReferenceEquals(_viewModel.NotificationManager, manager));
manager.Position = NotificationPosition.TopCenter;
}
}
protected override void OnDetachedFromVisualTree(VisualTreeAttachmentEventArgs e)