2021-06-09 17:51:24 +08:00
|
|
|
|
using System;
|
|
|
|
|
using System.Text.Json;
|
2021-06-02 10:46:58 +08:00
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using AntDesign.JsInterop;
|
|
|
|
|
using Microsoft.AspNetCore.Components;
|
2021-06-22 23:55:14 +08:00
|
|
|
|
using OneOf;
|
2020-05-09 11:09:07 +08:00
|
|
|
|
|
2020-05-29 00:33:49 +08:00
|
|
|
|
namespace AntDesign
|
2020-05-09 11:09:07 +08:00
|
|
|
|
{
|
2020-05-18 14:46:42 +08:00
|
|
|
|
public class DropdownButton : Dropdown
|
2020-05-09 11:09:07 +08:00
|
|
|
|
{
|
2021-06-02 10:46:58 +08:00
|
|
|
|
/// <summary>
|
2021-06-09 17:51:24 +08:00
|
|
|
|
/// Option to fit button width to its parent width
|
2021-06-02 10:46:58 +08:00
|
|
|
|
/// </summary>
|
2021-06-09 17:51:24 +08:00
|
|
|
|
[Parameter]
|
|
|
|
|
public new bool Block
|
2021-06-02 10:46:58 +08:00
|
|
|
|
{
|
2021-06-09 17:51:24 +08:00
|
|
|
|
get => base.Block;
|
|
|
|
|
set => base.Block = value;
|
2021-06-02 10:46:58 +08:00
|
|
|
|
}
|
|
|
|
|
|
2021-06-09 17:51:24 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Fully customizable button.
|
|
|
|
|
/// </summary>
|
|
|
|
|
[Parameter]
|
|
|
|
|
public new Func<RenderFragment, RenderFragment, RenderFragment> ButtonsRender
|
2021-06-02 10:46:58 +08:00
|
|
|
|
{
|
2021-06-09 17:51:24 +08:00
|
|
|
|
get => base.ButtonsRender;
|
|
|
|
|
set => base.ButtonsRender = value;
|
2021-06-02 10:46:58 +08:00
|
|
|
|
}
|
|
|
|
|
|
2021-06-22 23:55:14 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Allows to set each button's css class either to the same string
|
|
|
|
|
/// or separately.
|
|
|
|
|
/// </summary>
|
|
|
|
|
[Parameter]
|
|
|
|
|
public OneOf<string, (string LeftButton, string RightButton)> ButtonsClass
|
|
|
|
|
{
|
|
|
|
|
get =>_buttonsClass;
|
|
|
|
|
set
|
|
|
|
|
{
|
|
|
|
|
_buttonsClass = value;
|
|
|
|
|
_buttonsClass.Switch(
|
|
|
|
|
single =>
|
|
|
|
|
{
|
|
|
|
|
ChangeButtonClass(single, single);
|
|
|
|
|
},
|
|
|
|
|
both =>
|
|
|
|
|
{
|
|
|
|
|
ChangeButtonClass(both.LeftButton, both.RightButton);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Allows to set each button's style either to the same string
|
|
|
|
|
/// or separately.
|
|
|
|
|
/// </summary>
|
|
|
|
|
[Parameter]
|
|
|
|
|
public OneOf<string, (string LeftButton, string RightButton)> ButtonsStyle
|
|
|
|
|
{
|
|
|
|
|
get => _buttonsStyle;
|
|
|
|
|
set
|
|
|
|
|
{
|
|
|
|
|
_buttonsStyle = value;
|
|
|
|
|
_buttonsStyle.Switch(
|
|
|
|
|
single =>
|
|
|
|
|
{
|
|
|
|
|
ChangeButtonStyles(single, single);
|
|
|
|
|
},
|
|
|
|
|
both =>
|
|
|
|
|
{
|
|
|
|
|
ChangeButtonStyles(both.LeftButton, both.RightButton);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-06-09 17:51:24 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Set the danger status of button
|
|
|
|
|
/// </summary>
|
|
|
|
|
[Parameter]
|
|
|
|
|
public bool Danger
|
2021-06-02 10:46:58 +08:00
|
|
|
|
{
|
2021-06-09 17:51:24 +08:00
|
|
|
|
get => _danger;
|
|
|
|
|
set
|
2021-06-02 10:46:58 +08:00
|
|
|
|
{
|
2021-06-09 17:51:24 +08:00
|
|
|
|
_danger = value;
|
|
|
|
|
ChangeButtonDanger(value);
|
2021-06-02 10:46:58 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-06-09 17:51:24 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Used in situations with complex background, home pages usually.
|
|
|
|
|
/// </summary>
|
2020-05-09 11:09:07 +08:00
|
|
|
|
[Parameter]
|
2021-06-09 17:51:24 +08:00
|
|
|
|
public bool Ghost
|
2020-05-09 11:09:07 +08:00
|
|
|
|
{
|
2021-06-09 17:51:24 +08:00
|
|
|
|
get => _ghost;
|
2021-06-02 10:46:58 +08:00
|
|
|
|
set
|
2020-05-09 11:09:07 +08:00
|
|
|
|
{
|
2021-06-09 17:51:24 +08:00
|
|
|
|
_ghost = value;
|
|
|
|
|
ChangeButtonGhost(value);
|
2020-05-09 11:09:07 +08:00
|
|
|
|
}
|
2021-06-02 10:46:58 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private string _icon = "ellipsis";
|
2021-06-09 17:51:24 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Icon that will be rendered in the right
|
|
|
|
|
/// button.
|
|
|
|
|
/// </summary>
|
2021-06-02 10:46:58 +08:00
|
|
|
|
[Parameter]
|
|
|
|
|
public string Icon
|
|
|
|
|
{
|
|
|
|
|
get => _icon;
|
2020-05-09 11:09:07 +08:00
|
|
|
|
set
|
|
|
|
|
{
|
2021-06-09 17:51:24 +08:00
|
|
|
|
_icon = value;
|
|
|
|
|
ChangeRightButtonIcon(value);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Indicates if loading icon is going to be included.
|
|
|
|
|
/// If set to true, then dropdown will not be active.
|
|
|
|
|
/// </summary>
|
|
|
|
|
[Parameter]
|
|
|
|
|
public bool Loading
|
|
|
|
|
{
|
|
|
|
|
get => _loading;
|
|
|
|
|
set
|
|
|
|
|
{
|
|
|
|
|
_loading = value;
|
|
|
|
|
ChangeButtonLoading(value);
|
2020-05-09 11:09:07 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private string _size = AntSizeLDSType.Default;
|
2021-06-09 17:51:24 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Button size.
|
|
|
|
|
/// </summary>
|
2020-05-09 11:09:07 +08:00
|
|
|
|
[Parameter]
|
|
|
|
|
public string Size
|
|
|
|
|
{
|
2021-06-02 10:46:58 +08:00
|
|
|
|
get => _size;
|
2020-05-09 11:09:07 +08:00
|
|
|
|
set
|
|
|
|
|
{
|
|
|
|
|
_size = value;
|
|
|
|
|
ChangeButtonSize(value);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-06-09 17:51:24 +08:00
|
|
|
|
/// <summary>
|
2021-06-22 23:55:14 +08:00
|
|
|
|
/// Allows to set each button's type either to the same string
|
|
|
|
|
/// or separately. Use AntDesign.ButtonType helper class.
|
2021-06-09 17:51:24 +08:00
|
|
|
|
/// </summary>
|
2020-05-09 11:09:07 +08:00
|
|
|
|
[Parameter]
|
2021-06-22 23:55:14 +08:00
|
|
|
|
public OneOf<string, (string LeftButton, string RightButton)> Type
|
|
|
|
|
|
2020-05-09 11:09:07 +08:00
|
|
|
|
{
|
2021-06-22 23:55:14 +08:00
|
|
|
|
get => _buttonsType;
|
2020-05-09 11:09:07 +08:00
|
|
|
|
set
|
|
|
|
|
{
|
2021-06-22 23:55:14 +08:00
|
|
|
|
_buttonsType = value;
|
|
|
|
|
_buttonsType.Switch(
|
|
|
|
|
single =>
|
|
|
|
|
{
|
|
|
|
|
ChangeButtonType(single, single);
|
|
|
|
|
},
|
|
|
|
|
both =>
|
|
|
|
|
{
|
|
|
|
|
ChangeButtonType(both.LeftButton, both.RightButton);
|
|
|
|
|
});
|
2020-05-09 11:09:07 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-06-22 23:55:14 +08:00
|
|
|
|
private bool _loading;
|
|
|
|
|
private bool _danger;
|
|
|
|
|
private bool _ghost = false;
|
|
|
|
|
private OneOf<string, (string LeftButton, string RightButton)> _buttonsStyle;
|
|
|
|
|
private OneOf<string, (string LeftButton, string RightButton)> _buttonsClass;
|
|
|
|
|
private OneOf<string, (string LeftButton, string RightButton)> _buttonsType = ButtonType.Default;
|
|
|
|
|
|
2021-06-02 10:46:58 +08:00
|
|
|
|
public DropdownButton() => IsButton = true;
|
2021-06-09 17:51:24 +08:00
|
|
|
|
|
|
|
|
|
protected override void OnInitialized()
|
|
|
|
|
{
|
|
|
|
|
string prefixCls = "ant-btn";
|
|
|
|
|
ClassMapper.Clear();
|
2021-09-10 19:06:50 +08:00
|
|
|
|
Placement = Placement.BottomRight;
|
2021-06-09 17:51:24 +08:00
|
|
|
|
base.OnInitialized();
|
|
|
|
|
ClassMapper.If($"{prefixCls}-block", () => Block);
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Force overlay trigger to be attached to wrapping element of
|
|
|
|
|
/// the right button. Right button has to be wrapped,
|
|
|
|
|
/// because overlay will be looking for first child
|
|
|
|
|
/// element of the overlay trigger to calculate the overlay position.
|
|
|
|
|
/// If the right button was the trigger, then its first child
|
|
|
|
|
/// would be the icon/ellipsis and the overlay would have been
|
|
|
|
|
/// rendered too high.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="firstRender"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
protected override Task OnAfterRenderAsync(bool firstRender)
|
|
|
|
|
{
|
|
|
|
|
if (firstRender)
|
|
|
|
|
{
|
|
|
|
|
Ref = RefBack.Current;
|
2021-09-09 12:56:11 +08:00
|
|
|
|
|
|
|
|
|
DomEventListener.AddExclusive<JsonElement>(Ref, "click", OnUnboundClick);
|
|
|
|
|
DomEventListener.AddExclusive<JsonElement>(Ref, "mouseover", OnUnboundMouseEnter);
|
|
|
|
|
DomEventListener.AddExclusive<JsonElement>(Ref, "mouseout", OnUnboundMouseLeave);
|
|
|
|
|
DomEventListener.AddExclusive<JsonElement>(Ref, "focusin", OnUnboundFocusIn);
|
|
|
|
|
DomEventListener.AddExclusive<JsonElement>(Ref, "focusout", OnUnboundFocusOut);
|
|
|
|
|
DomEventListener.AddExclusive<JsonElement>(Ref, "contextmenu", OnContextMenu, true);
|
2021-06-09 17:51:24 +08:00
|
|
|
|
}
|
|
|
|
|
return base.OnAfterRenderAsync(firstRender);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected override void Dispose(bool disposing)
|
|
|
|
|
{
|
2021-09-09 12:56:11 +08:00
|
|
|
|
DomEventListener.DisposeExclusive();
|
2021-06-09 17:51:24 +08:00
|
|
|
|
base.Dispose(disposing);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
internal override async Task Show(int? overlayLeft = null, int? overlayTop = null)
|
|
|
|
|
{
|
|
|
|
|
if (!Loading)
|
|
|
|
|
{
|
|
|
|
|
await _overlay.Show(overlayLeft, overlayTop);
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-05-09 11:09:07 +08:00
|
|
|
|
}
|
|
|
|
|
}
|