2020-10-14 15:09:11 +08:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using Microsoft.AspNetCore.Components;
|
2020-12-26 21:39:04 +08:00
|
|
|
|
using Microsoft.AspNetCore.Components.Rendering;
|
2020-11-18 16:01:31 +08:00
|
|
|
|
using Microsoft.JSInterop;
|
2020-10-14 15:09:11 +08:00
|
|
|
|
|
|
|
|
|
namespace AntDesign
|
|
|
|
|
{
|
2020-12-26 21:39:04 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// create and open a Modal dialog
|
|
|
|
|
/// </summary>
|
|
|
|
|
public partial class ModalService: IDisposable
|
2020-10-14 15:09:11 +08:00
|
|
|
|
{
|
|
|
|
|
internal event Func<ModalRef, Task> OnModalOpenEvent;
|
|
|
|
|
internal event Func<ModalRef, Task> OnModalCloseEvent;
|
|
|
|
|
|
2020-11-18 16:01:31 +08:00
|
|
|
|
private readonly NavigationManager _navigationManager;
|
|
|
|
|
private readonly IJSRuntime _jsRuntime;
|
2020-12-26 21:39:04 +08:00
|
|
|
|
internal static HashSet<ModalRef> ReusedModals = new HashSet<ModalRef>();
|
|
|
|
|
|
2020-10-14 15:09:11 +08:00
|
|
|
|
/// <summary>
|
2020-11-18 16:01:31 +08:00
|
|
|
|
/// constructor
|
|
|
|
|
/// </summary>
|
|
|
|
|
public ModalService(NavigationManager navigationManager, IJSRuntime jsRuntime)
|
|
|
|
|
{
|
|
|
|
|
_navigationManager = navigationManager;
|
|
|
|
|
_navigationManager.LocationChanged += NavigationManager_LocationChanged;
|
|
|
|
|
_jsRuntime = jsRuntime;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Destroy all reused Modal
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="sender"></param>
|
|
|
|
|
/// <param name="e"></param>
|
|
|
|
|
private async void NavigationManager_LocationChanged(object sender, Microsoft.AspNetCore.Components.Routing.LocationChangedEventArgs e)
|
|
|
|
|
{
|
2020-12-26 23:41:02 +08:00
|
|
|
|
if (ReusedModals.Count > 0)
|
2020-11-18 16:01:31 +08:00
|
|
|
|
{
|
|
|
|
|
// Since Modal cannot be captured, it can only be removed through JS
|
|
|
|
|
await _jsRuntime.InvokeVoidAsync(JSInteropConstants.DestroyAllDialog);
|
2020-12-26 23:41:02 +08:00
|
|
|
|
ReusedModals.Clear();
|
2020-11-18 16:01:31 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Create and open a Modal
|
2020-10-14 15:09:11 +08:00
|
|
|
|
/// </summary>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
public Task<ModalRef> CreateModalAsync(ModalOptions config)
|
|
|
|
|
{
|
|
|
|
|
if (config == null)
|
|
|
|
|
{
|
|
|
|
|
throw new ArgumentNullException(nameof(config));
|
|
|
|
|
}
|
|
|
|
|
ModalRef modalRef = new ModalRef(config, this);
|
|
|
|
|
config.ModalRef = modalRef;
|
|
|
|
|
return CreateOrOpenModalAsync(modalRef);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2020-12-26 21:39:04 +08:00
|
|
|
|
/// Create and open a Modal with template
|
2020-10-14 15:09:11 +08:00
|
|
|
|
/// </summary>
|
|
|
|
|
/// <typeparam name="TComponent"></typeparam>
|
|
|
|
|
/// <typeparam name="TComponentOptions"></typeparam>
|
|
|
|
|
/// <param name="config"></param>
|
|
|
|
|
/// <param name="componentOptions"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
public Task<ModalRef> CreateModalAsync<TComponent, TComponentOptions>(ModalOptions config, TComponentOptions componentOptions) where TComponent : ModalTemplate<TComponentOptions>
|
|
|
|
|
{
|
|
|
|
|
if (config == null)
|
|
|
|
|
{
|
|
|
|
|
throw new ArgumentNullException(nameof(config));
|
|
|
|
|
}
|
|
|
|
|
ModalRef modalRef = new ModalRef(config, this);
|
|
|
|
|
|
2020-12-26 21:39:04 +08:00
|
|
|
|
void Child(RenderTreeBuilder builder)
|
2020-10-14 15:09:11 +08:00
|
|
|
|
{
|
|
|
|
|
builder.OpenComponent<TComponent>(0);
|
|
|
|
|
builder.AddAttribute(1, "ModalRef", modalRef);
|
|
|
|
|
builder.AddAttribute(2, "Options", componentOptions);
|
|
|
|
|
builder.CloseComponent();
|
|
|
|
|
}
|
|
|
|
|
config.Content = Child;
|
|
|
|
|
config.ModalRef = modalRef;
|
|
|
|
|
return CreateOrOpenModalAsync(modalRef);
|
|
|
|
|
}
|
|
|
|
|
|
2020-12-26 21:39:04 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// create or open a Modal dialog
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="modalRef"></param>
|
|
|
|
|
/// <returns></returns>
|
2020-10-14 15:09:11 +08:00
|
|
|
|
internal Task<ModalRef> CreateOrOpenModalAsync(ModalRef modalRef)
|
|
|
|
|
{
|
|
|
|
|
OnModalOpenEvent?.Invoke(modalRef);
|
2020-12-26 21:39:04 +08:00
|
|
|
|
ReusedModals.Add(modalRef);
|
2020-10-14 15:09:11 +08:00
|
|
|
|
return Task.FromResult(modalRef);
|
|
|
|
|
}
|
|
|
|
|
|
2020-12-26 21:39:04 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// close modal dialog
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="modalRef"></param>
|
|
|
|
|
/// <returns></returns>
|
2020-10-14 15:09:11 +08:00
|
|
|
|
internal Task CloseModalAsync(ModalRef modalRef)
|
|
|
|
|
{
|
|
|
|
|
if (OnModalCloseEvent != null)
|
|
|
|
|
{
|
|
|
|
|
return OnModalCloseEvent.Invoke(modalRef);
|
|
|
|
|
}
|
|
|
|
|
return Task.CompletedTask;
|
|
|
|
|
}
|
2020-11-18 16:01:31 +08:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Implement the interface IDisposable
|
|
|
|
|
/// </summary>
|
|
|
|
|
public void Dispose()
|
|
|
|
|
{
|
|
|
|
|
_navigationManager.LocationChanged -= NavigationManager_LocationChanged;
|
|
|
|
|
GC.SuppressFinalize(this);
|
|
|
|
|
}
|
2020-10-14 15:09:11 +08:00
|
|
|
|
}
|
|
|
|
|
}
|