mirror of
https://gitee.com/ant-design-blazor/ant-design-blazor.git
synced 2024-12-15 17:31:42 +08:00
4036be867d
* feat: add list resposive * Remove the comments Co-authored-by: Setli <set_li@163.com>
139 lines
4.2 KiB
C#
139 lines
4.2 KiB
C#
using Microsoft.AspNetCore.Components;
|
|
using System;
|
|
using System.Collections;
|
|
using System.Collections.Generic;
|
|
using System.Reflection;
|
|
using System.Text;
|
|
using System.Threading.Tasks;
|
|
using AntDesign.JsInterop;
|
|
|
|
namespace AntDesign
|
|
{
|
|
public partial class AntListItem : AntDomComponentBase
|
|
{
|
|
public string PrefixName { get; set; } = "ant-list-item";
|
|
|
|
[Parameter] public string Content { get; set; }
|
|
|
|
[Parameter] public RenderFragment Extra { get; set; }
|
|
|
|
[Parameter] public List<RenderFragment> Actions { get; set; }
|
|
|
|
[Parameter] public AntDirectionVHType ItemLayout { get; set; }
|
|
|
|
[Parameter] public ListGridType Grid { get; set; }
|
|
|
|
[Parameter] public RenderFragment ChildContent { get; set; }
|
|
|
|
[Parameter] public string ColStyle { get; set; }
|
|
|
|
[Parameter] public int ItemCount { get; set; }
|
|
|
|
[Inject]
|
|
public DomEventService DomEventService { get; set; }
|
|
|
|
public bool IsVerticalAndExtra()
|
|
{
|
|
return this.ItemLayout == AntDirectionVHType.Vertical && this.Extra != null;
|
|
}
|
|
|
|
protected override async Task OnInitializedAsync()
|
|
{
|
|
SetClassMap();
|
|
|
|
if (Grid != null)
|
|
{
|
|
await this.SetGutterStyle();
|
|
DomEventService.AddEventListener<object>("window", "resize", async _ => await this.SetGutterStyle());
|
|
}
|
|
|
|
await base.OnInitializedAsync();
|
|
}
|
|
|
|
protected override void OnParametersSet()
|
|
{
|
|
base.OnParametersSet();
|
|
SetClassMap();
|
|
}
|
|
|
|
private static Hashtable _gridResponsiveMap = new Hashtable()
|
|
{
|
|
[nameof(BreakpointEnum.xs)] = "(max-width: 575px)",
|
|
[nameof(BreakpointEnum.sm)] = "(max-width: 576px)",
|
|
[nameof(BreakpointEnum.md)] = "(max-width: 768px)",
|
|
[nameof(BreakpointEnum.lg)] = "(max-width: 992px)",
|
|
[nameof(BreakpointEnum.xl)] = "(max-width: 1200px)",
|
|
[nameof(BreakpointEnum.xxl)] = "(max-width: 1600px)",
|
|
};
|
|
|
|
private async Task SetGutterStyle()
|
|
{
|
|
string breakPoint = null;
|
|
|
|
await typeof(BreakpointEnum).GetEnumNames().ForEachAsync(async bp =>
|
|
{
|
|
if (await JsInvokeAsync<bool>(JSInteropConstants.matchMedia, _gridResponsiveMap[bp]))
|
|
{
|
|
Console.WriteLine(bp);
|
|
breakPoint = bp;
|
|
}
|
|
});
|
|
|
|
var column = GetColumn(breakPoint);
|
|
|
|
int columnCount = column > 0 ? column : (Grid?.Column ?? 0);
|
|
if (Grid != null && columnCount > 0)
|
|
{
|
|
ColStyle = $"width:{100 / columnCount}%;max-width:{100 / columnCount}%";
|
|
}
|
|
|
|
InvokeStateHasChanged();
|
|
}
|
|
|
|
private int GetColumn(string breakPoint)
|
|
{
|
|
var column = 0;
|
|
if (Grid != null && !string.IsNullOrEmpty(breakPoint))
|
|
{
|
|
var value = GetModelValue(breakPoint, Grid);
|
|
int.TryParse(value, out column);
|
|
return column;
|
|
}
|
|
return column;
|
|
}
|
|
|
|
protected void SetClassMap()
|
|
{
|
|
ClassMapper.Clear()
|
|
.Add(PrefixName)
|
|
.If($"{PrefixName}-no-flex", () => !IsFlexMode());
|
|
}
|
|
|
|
private bool IsFlexMode()
|
|
{
|
|
if (ItemLayout == AntDirectionVHType.Vertical)
|
|
{
|
|
return Extra != null;
|
|
}
|
|
|
|
return (Actions != null || Grid != null) && ItemCount > 1;
|
|
}
|
|
|
|
private string GetModelValue(string fieldName, object obj)
|
|
{
|
|
try
|
|
{
|
|
if (obj == null || string.IsNullOrEmpty(fieldName)) return null;
|
|
var o = obj.GetType().GetProperty(fieldName, BindingFlags.Public | BindingFlags.IgnoreCase | BindingFlags.Instance).GetValue(obj, null);
|
|
var value = o?.ToString() ?? null;
|
|
if (string.IsNullOrEmpty(value)) return null;
|
|
return value;
|
|
}
|
|
catch (Exception)
|
|
{
|
|
return null;
|
|
}
|
|
}
|
|
}
|
|
}
|