2020-10-14 15:09:11 +08:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Text;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using Microsoft.AspNetCore.Components;
|
|
|
|
|
using Microsoft.AspNetCore.Components.Web;
|
|
|
|
|
using OneOf;
|
|
|
|
|
|
|
|
|
|
namespace AntDesign
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// the options of Modal dialog box
|
|
|
|
|
/// </summary>
|
2020-12-26 21:39:04 +08:00
|
|
|
|
public class ModalOptions : DialogOptionsBase
|
2020-10-14 15:09:11 +08:00
|
|
|
|
{
|
2020-12-26 21:39:04 +08:00
|
|
|
|
public ModalOptions()
|
2020-10-14 15:09:11 +08:00
|
|
|
|
{
|
2020-12-26 21:39:04 +08:00
|
|
|
|
_onCancel = DefaultOnCancelOrOk;
|
|
|
|
|
_onOk = DefaultOnCancelOrOk;
|
|
|
|
|
Width = 520;
|
|
|
|
|
MaskClosable = true;
|
|
|
|
|
}
|
2020-10-14 15:09:11 +08:00
|
|
|
|
|
2020-12-26 21:39:04 +08:00
|
|
|
|
internal ModalRef ModalRef;
|
2020-10-14 15:09:11 +08:00
|
|
|
|
|
2020-12-26 21:39:04 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// trigger after Dialog is closed
|
|
|
|
|
/// </summary>
|
2020-11-22 21:33:07 +08:00
|
|
|
|
public Func<Task> AfterClose { get; set; } = () => Task.CompletedTask;
|
2020-10-14 15:09:11 +08:00
|
|
|
|
|
2021-04-21 22:31:47 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// ant-modal style
|
|
|
|
|
/// </summary>
|
|
|
|
|
public string Style { get; set; }
|
|
|
|
|
|
2020-12-26 21:39:04 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// ant-modal-body style
|
|
|
|
|
/// </summary>
|
2020-10-14 15:09:11 +08:00
|
|
|
|
public string BodyStyle { get; set; }
|
|
|
|
|
|
2020-12-26 21:39:04 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// show ant-modal-closer
|
|
|
|
|
/// </summary>
|
2020-10-14 15:09:11 +08:00
|
|
|
|
public bool Closable { get; set; } = true;
|
|
|
|
|
|
2020-12-26 21:39:04 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Draggable modal
|
|
|
|
|
/// </summary>
|
2020-10-14 15:09:11 +08:00
|
|
|
|
public bool Draggable { get; set; }
|
|
|
|
|
|
2020-12-26 21:39:04 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Drag and drop only within the Viewport
|
|
|
|
|
/// </summary>
|
2020-10-14 15:09:11 +08:00
|
|
|
|
public bool DragInViewport { get; set; } = true;
|
|
|
|
|
|
2020-12-26 21:39:04 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// closer icon RenderFragment, the default is a "X"
|
|
|
|
|
/// </summary>
|
|
|
|
|
public RenderFragment CloseIcon { get; set; } = DialogOptions.DefaultCloseIcon;
|
2020-10-14 15:09:11 +08:00
|
|
|
|
|
2020-12-26 21:39:04 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Whether to apply loading visual effect for OK button or not
|
|
|
|
|
/// </summary>
|
2021-04-04 15:40:54 +08:00
|
|
|
|
public bool ConfirmLoading
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
if (OkButtonProps != null)
|
|
|
|
|
{
|
|
|
|
|
return OkButtonProps.Loading;
|
|
|
|
|
}
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
set
|
|
|
|
|
{
|
|
|
|
|
if (OkButtonProps == null)
|
|
|
|
|
{
|
|
|
|
|
OkButtonProps = new ButtonProps();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
OkButtonProps.Loading = true;
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-10-14 15:09:11 +08:00
|
|
|
|
|
2020-12-26 21:39:04 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Whether to remove Modal from DOM after the Modal closed
|
|
|
|
|
/// </summary>
|
2020-10-14 15:09:11 +08:00
|
|
|
|
public bool DestroyOnClose { get; set; }
|
|
|
|
|
|
2020-12-26 21:39:04 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Modal footer. If Footer==null, the dialog will not have a footer
|
|
|
|
|
/// </summary>
|
|
|
|
|
public OneOf<string, RenderFragment>? Footer { get; set; } = DialogOptions.DefaultFooter;
|
2020-10-14 15:09:11 +08:00
|
|
|
|
|
2020-12-26 21:39:04 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
///
|
|
|
|
|
/// </summary>
|
2020-10-14 15:09:11 +08:00
|
|
|
|
public bool Visible { get; set; } = true;
|
|
|
|
|
|
2020-12-26 21:39:04 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// The class name of the container of the modal dialog
|
|
|
|
|
/// </summary>
|
2020-10-14 15:09:11 +08:00
|
|
|
|
public string WrapClassName { get; set; }
|
|
|
|
|
|
2020-11-22 21:33:07 +08:00
|
|
|
|
private Func<MouseEventArgs, Task> _onCancel;
|
2020-10-14 15:09:11 +08:00
|
|
|
|
|
2020-12-26 21:39:04 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Specify a function that will be called when a user clicks mask, close button on top right or Cancel button.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public Func<MouseEventArgs, Task> OnCancel { get => _onCancel; set => _onCancel = value; }
|
2020-10-14 15:09:11 +08:00
|
|
|
|
|
2020-11-22 21:33:07 +08:00
|
|
|
|
private Func<MouseEventArgs, Task> _onOk;
|
|
|
|
|
|
2020-12-26 21:39:04 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Specify a function that will be called when a user clicks the OK button
|
|
|
|
|
/// </summary>
|
|
|
|
|
public Func<MouseEventArgs, Task> OnOk { get => _onOk; set => _onOk = value; }
|
2020-10-14 15:09:11 +08:00
|
|
|
|
|
2020-12-26 21:39:04 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// ChildContent
|
|
|
|
|
/// </summary>
|
|
|
|
|
public RenderFragment Content { get; set; } = null;
|
|
|
|
|
|
|
|
|
|
#region internal
|
2020-11-22 21:33:07 +08:00
|
|
|
|
|
|
|
|
|
internal async Task DefaultOnCancelOrOk(MouseEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
await (ModalRef?.CloseAsync() ?? Task.CompletedTask);
|
2020-10-14 15:09:11 +08:00
|
|
|
|
}
|
|
|
|
|
|
2020-12-26 21:39:04 +08:00
|
|
|
|
#endregion
|
2020-10-14 15:09:11 +08:00
|
|
|
|
}
|
|
|
|
|
}
|