@typeparam TDataModel
@if (VisibleRowNo == true)
{
@(DataList.ToList().IndexOf(context) + 1)
}
@foreach (var col in typeof(TDataModel).GetProperties())
{
if (col.Name.ToLower().Contains("navigation") || col.Name.ToLower().Contains("stepversion") || col.Name.ToLower().Contains("isglobal")
|| col.Name.ToLower().Contains("updatedt") || col.Name.ToLower().Contains("enable"))
continue;
if (col.Name.ToLower().Equals("testdate"))
{
@Convert.ToDateTime(col.GetValue(context)).ToString("yyyy-MM-dd")
}
else if (col.Name.ToLower().Equals("testdatetime"))
{
@Convert.ToDateTime(col.GetValue(context)).ToString("yyyy-MM-dd HH:mm:ss")
}
else if (col.Name.ToLower().Equals("ok"))
{
@col.GetValue(context)
}
else if (col.Name.ToLower().Equals("ng"))
{
@col.GetValue(context)
}
else if (col.Name.ToLower().Contains("cntid") || col.Name.ToLower().Contains("reqid"))
{
@col.GetValue(context)
}
else if (col.Name.ToLower().Contains("activate"))
{
}
else
{
@col.GetValue(context)
}
}
@code {
[Parameter]
public IEnumerable DataList { get; set; }
[Parameter]
public EventCallback OnSelectRow { get; set; }
[Parameter]
public EventCallback OnDoubleClickRow{ get; set; }
[Parameter]
public bool VisibleRowNo { get; set; }
[Parameter]
public bool HostColumnMerge { get; set; }
private IList SelectedRow;
private string SummaryTestResult = string.Empty;
private string SummaryTestTime = string.Empty;
private void CellRender(DataGridCellRenderEventArgs args)
{
if (args.Column.Property == null)
return;
var cellData = args.Data as Overview;
if (cellData is null)
return;
if ((args.Column.Property.ToLower().Equals("testdate") || args.Column.Property.ToLower().Equals("host")) == false)
return;
int index = DataList.ToList().FindIndex(x => x.Equals(args.Data));
//testdate 컬럼일때 날짜 병합
if (args.Column.Property.ToLower().Equals("testdate"))
{
int rowCount = 0;
var take = DataList.Skip(index).Cast();
foreach (var r in take)
{
if (r.TestDate.Value.Date == cellData.TestDate.Value.Date)
{
if (r.ModelName == cellData.ModelName)
{
rowCount += 1;
}
}
else
{
break;
}
}
args.Attributes.Clear();
if (rowCount > 0)
args.Attributes.Add("rowspan", rowCount);
}
if (args.Column.Property.ToLower().Equals("host"))
{
if (HostColumnMerge == false)
return;
int rowCount = 0;
var take = DataList.Skip(index).Cast();
foreach (var r in take)
{
if (r.Host == cellData.Host)
{
rowCount += 1;
}
else
{
break;
}
}
args.Attributes.Clear();
if (rowCount > 0)
args.Attributes.Add("rowspan", rowCount);
}
}
private async Task SelectRow(TDataModel data)
{
await OnSelectRow.InvokeAsync(data);
}
private async Task OnRowDoublClick(DataGridRowMouseEventArgs args)
{
await OnDoubleClickRow.InvokeAsync(args.Data);
}
}