mirror of
https://gitee.com/ant-design-blazor/ant-design-blazor.git
synced 2024-12-14 17:01:18 +08:00
11bfaef22e
* feat(module: upload): support drag * fix button text * add tests * delete useless field
144 lines
4.0 KiB
C#
144 lines
4.0 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Threading.Tasks;
|
|
using Microsoft.AspNetCore.Components;
|
|
using Microsoft.AspNetCore.Components.Web;
|
|
|
|
namespace AntDesign
|
|
{
|
|
public partial class Upload : AntDomComponentBase
|
|
{
|
|
[Parameter]
|
|
public Func<UploadFileItem, bool> BeforeUpload { get; set; }
|
|
|
|
[Parameter]
|
|
public Func<List<UploadFileItem>, Task<bool>> BeforeAllUploadAsync { get; set; }
|
|
|
|
[Parameter]
|
|
public Func<List<UploadFileItem>, bool> BeforeAllUpload { get; set; }
|
|
|
|
[Parameter]
|
|
public string Name { get; set; }
|
|
|
|
[Parameter]
|
|
public string Action { get; set; }
|
|
|
|
[Parameter]
|
|
public bool Disabled { get; set; }
|
|
|
|
[Parameter]
|
|
public Dictionary<string, object> Data { get; set; }
|
|
|
|
[Parameter]
|
|
public string ListType { get; set; } = "text";
|
|
|
|
[Parameter]
|
|
public bool Directory { get; set; }
|
|
|
|
[Parameter]
|
|
public bool Multiple { get; set; }
|
|
|
|
[Parameter]
|
|
public string Accept { get; set; }
|
|
|
|
[Parameter]
|
|
public bool ShowUploadList { get; set; } = true;
|
|
|
|
[Parameter]
|
|
public List<UploadFileItem> FileList { get; set; } = new List<UploadFileItem>();
|
|
|
|
[Parameter]
|
|
public UploadLocale Locale { get; set; } = LocaleProvider.CurrentLocale.Upload;
|
|
|
|
[Parameter]
|
|
public EventCallback<List<UploadFileItem>> FileListChanged { get; set; }
|
|
|
|
[Parameter]
|
|
public List<UploadFileItem> DefaultFileList { get; set; } = new List<UploadFileItem>();
|
|
|
|
[Parameter]
|
|
public Dictionary<string, string> Headers { get; set; }
|
|
|
|
[Parameter]
|
|
public EventCallback<UploadInfo> OnSingleCompleted { get; set; }
|
|
|
|
[Parameter]
|
|
public EventCallback<UploadInfo> OnCompleted { get; set; }
|
|
|
|
[Parameter]
|
|
public EventCallback<UploadInfo> OnChange { get; set; }
|
|
|
|
[Parameter]
|
|
public Func<UploadFileItem, Task<bool>> OnRemove { get; set; }
|
|
|
|
[Parameter]
|
|
public EventCallback<UploadFileItem> OnPreview { get; set; }
|
|
|
|
[Parameter]
|
|
public EventCallback<UploadFileItem> OnDownload { get; set; }
|
|
|
|
[Parameter]
|
|
public RenderFragment ChildContent { get; set; }
|
|
|
|
[Parameter]
|
|
public bool ShowButton { get; set; } = true;
|
|
|
|
[Parameter]
|
|
public bool Drag { get; set; }
|
|
|
|
private bool IsText => ListType == "text";
|
|
private bool IsPicture => ListType == "picture";
|
|
private bool IsPictureCard => ListType == "picture-card";
|
|
|
|
private ClassMapper _listClassMapper = new ClassMapper();
|
|
|
|
internal bool _dragHover;
|
|
|
|
protected override void OnInitialized()
|
|
{
|
|
base.OnInitialized();
|
|
|
|
var prefixCls = "ant-upload";
|
|
|
|
_listClassMapper
|
|
.Add($"{prefixCls}-list")
|
|
.Get(() => $"{prefixCls}-list-{ListType}")
|
|
.If($"{prefixCls}-list-rtl", () => RTL);
|
|
|
|
FileList.InsertRange(0, DefaultFileList);
|
|
}
|
|
|
|
private void HandleDrag(DragEventArgs args)
|
|
{
|
|
_dragHover = args.Type == "dragover";
|
|
}
|
|
|
|
private async Task RemoveFile(UploadFileItem item)
|
|
{
|
|
var canRemove = OnRemove == null || await OnRemove.Invoke(item);
|
|
if (canRemove)
|
|
{
|
|
this.FileList.Remove(item);
|
|
await this.FileListChanged.InvokeAsync(this.FileList);
|
|
StateHasChanged();
|
|
}
|
|
}
|
|
|
|
private async Task PreviewFile(UploadFileItem item)
|
|
{
|
|
if (item.State == UploadState.Success && OnPreview.HasDelegate)
|
|
{
|
|
await OnPreview.InvokeAsync(item);
|
|
}
|
|
}
|
|
|
|
private async Task DownloadFile(UploadFileItem item)
|
|
{
|
|
if (item.State == UploadState.Success && OnDownload.HasDelegate)
|
|
{
|
|
await OnDownload.InvokeAsync(item);
|
|
}
|
|
}
|
|
}
|
|
}
|