[성현모] Tab기능 개선
This commit is contained in:
@ -1,6 +1,9 @@
|
||||
@page "/tra"
|
||||
@rendermode InteractiveServer
|
||||
|
||||
@using System.Collections.Concurrent
|
||||
@using System.Collections.Specialized
|
||||
@using System.Collections
|
||||
@using Web.Tra.Services
|
||||
@inject CPXV2LogService CPXV2LogService
|
||||
@inject PopupService PopupService
|
||||
@ -78,33 +81,33 @@
|
||||
<!--Data Grid-->
|
||||
<RadzenTabs @ref="@tabs" Style="width:100%; height:100%;" RenderMode="TabRenderMode.Client" @bind-SelectedIndex=@SelectedTabIndex>
|
||||
<Tabs>
|
||||
@foreach (var tab in ListTabs)
|
||||
@foreach (var tab in Tabs.OrderBy(x=>x.Key.Id))
|
||||
{
|
||||
<RadzenTabsItem Text="@tab.Key.ToString()">
|
||||
<RadzenTabsItem Text="@tab.Key.TabName">
|
||||
<Template>
|
||||
<span style="margin-right: 1rem; font-size: 1.5rem;">@context.Text</span>
|
||||
<RadzenButton Size="ButtonSize.Small" Icon="close" Click="@(()=>OnClickClose(tab.Key))"></RadzenButton>
|
||||
<RadzenButton Size="ButtonSize.Small" Icon="close" Click="@(()=>OnClickClose(tab.Key.Id))"></RadzenButton>
|
||||
</Template>
|
||||
<ChildContent>
|
||||
@if (tab.Key == EnumTabs.OverviewC1.ToString())
|
||||
@if (tab.Key.EnumTab == EnumTabs.OverviewC1)
|
||||
{
|
||||
<TraGrid TDataModel="Overview" DataList="@Overviews" OnClickContextMenu="@OnClickDetailOverviewContextMenu"
|
||||
<TraGrid TDataModel="Overview" DataList="@(tab.Value.Cast<Overview>())" OnClickContextMenu="@OnClickDetailOverviewContextMenu"
|
||||
OnSelectRow="@OnSelectRowOverview" PageSize="@PageSize" DisableColums="@OverviewDisableColums"
|
||||
OnDoubleClickRow="@OnDoubleClickRowOverview" HostColumnMerge>
|
||||
</TraGrid>
|
||||
}
|
||||
|
||||
@if (tab.Key == EnumTabs.OverviewC1Detail.ToString())
|
||||
@if (tab.Key.EnumTab == EnumTabs.OverviewC1Detail)
|
||||
{
|
||||
<TraGrid TDataModel="Overview" DataList="@DetailOverviews" OnClickContextMenu="@OnClickDetailOverviewContextMenu"
|
||||
<TraGrid TDataModel="Overview" DataList="@(tab.Value.Cast<Overview>())" OnClickContextMenu="@OnClickDetailOverviewContextMenu"
|
||||
OnSelectRow="@OnSelectRowOverview" PageSize="@PageSize" DisableColums="@OverviewDisableColums"
|
||||
OnDoubleClickRow="@OnDoubleClickRowDetailOverview" HostColumnMerge>
|
||||
</TraGrid>
|
||||
}
|
||||
|
||||
@if (tab.Key.Contains(EnumTabs.TestHistoryC1.ToString()))
|
||||
@if (tab.Key.EnumTab == EnumTabs.TestHistoryC1)
|
||||
{
|
||||
<TraGrid TDataModel="TestHistory" DataList="@TestHistories.Where(x=>x.Key == tab.Key).First().Value" OnClickContextMenu="@OnClickDetailOverviewContextMenu"
|
||||
<TraGrid TDataModel="TestHistory" DataList="@(tab.Value.Cast<TestHistory>())" OnClickContextMenu="@OnClickDetailOverviewContextMenu"
|
||||
OnSelectRow="@OnSelectRowOverview" PageSize="@PageSize" DisableColums="@HistoryDisableColums"
|
||||
VisibleRowNo HostColumnMerge="false">
|
||||
</TraGrid>
|
||||
@ -135,13 +138,10 @@
|
||||
//tab
|
||||
RadzenTabs tabs;
|
||||
int SelectedTabIndex = 0;
|
||||
Dictionary<string, EnumTabs> ListTabs = new Dictionary<string, EnumTabs>();
|
||||
ConcurrentDictionary<OrderdTab, List<IDataModel>> Tabs = new ConcurrentDictionary<OrderdTab, List<IDataModel>>();
|
||||
|
||||
//search data
|
||||
List<SearchData> SearchDataOverviews = new List<SearchData>();
|
||||
List<Overview> Overviews = new List<Overview>();
|
||||
List<Overview> DetailOverviews = new List<Overview>();
|
||||
Dictionary<string,List<TestHistory>> TestHistories = new();
|
||||
|
||||
private async Task OnSearch()
|
||||
{
|
||||
@ -157,21 +157,20 @@
|
||||
SearchDataOverviews = await CPXV2LogService.GetSearchDataOverview(RequestSearch);
|
||||
await GetOverviews();
|
||||
|
||||
if (ListTabs.ContainsKey(EnumTabs.OverviewC1.ToString()) == false)
|
||||
ListTabs.Add($"{EnumTabs.OverviewC1}", EnumTabs.OverviewC1);
|
||||
|
||||
PopupService.CloseIndicator();
|
||||
}
|
||||
|
||||
private async Task GetOverviews()
|
||||
{
|
||||
List<Overview> overviews = new();
|
||||
|
||||
OverviewDisableColums.Clear();
|
||||
OverviewDisableColums.Add("rn");
|
||||
OverviewDisableColums.Add("stepversion");
|
||||
|
||||
if (IsMergePartNumberOption == false)
|
||||
{
|
||||
Overviews = await CPXV2LogService.GetOverviews(SearchDataOverviews);
|
||||
overviews = await CPXV2LogService.GetOverviews(SearchDataOverviews);
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -179,8 +178,20 @@
|
||||
OverviewDisableColums.Add("host");
|
||||
OverviewDisableColums.Add("section");
|
||||
OverviewDisableColums.Add("testlistcntid");
|
||||
Overviews = await CPXV2LogService.GetOverviewMerged(SearchDataOverviews);
|
||||
overviews = await CPXV2LogService.GetOverviewMerged(SearchDataOverviews);
|
||||
}
|
||||
|
||||
int tabId = 0;
|
||||
if(Tabs.Count > 0)
|
||||
{
|
||||
tabId = Tabs.Max(x=>x.Key.Id) + 1;
|
||||
}
|
||||
|
||||
Tabs.AddOrUpdate(
|
||||
new OrderdTab {Id = tabId, TabName = $"{EnumTabs.OverviewC1} ({tabId})" , EnumTab = EnumTabs.OverviewC1 },
|
||||
key => overviews.Cast<IDataModel>().ToList(), (key, oldValue) => overviews.Cast<IDataModel>().ToList());
|
||||
|
||||
SelectedTabIndex = Tabs.Count - 1;
|
||||
}
|
||||
|
||||
private void OnSelectRowOverview(IDataModel overview)
|
||||
@ -196,45 +207,45 @@
|
||||
|
||||
private async Task OnDoubleClickRowOverview(IDataModel row)
|
||||
{
|
||||
DetailOverviews.Clear();
|
||||
List<Overview> detailOverviews = new();
|
||||
|
||||
if (IsMergePartNumberOption == false)
|
||||
{
|
||||
DetailOverviews = await CPXV2LogService.GetDetailOverview(SearchDataOverviews, row);
|
||||
detailOverviews = await CPXV2LogService.GetDetailOverview(SearchDataOverviews, row);
|
||||
}
|
||||
else
|
||||
{
|
||||
DetailOverviews = await CPXV2LogService.GetDetailOverviewMerged(SearchDataOverviews, row);
|
||||
detailOverviews = await CPXV2LogService.GetDetailOverviewMerged(SearchDataOverviews, row);
|
||||
}
|
||||
|
||||
//tab control
|
||||
if (ListTabs.ContainsKey(EnumTabs.OverviewC1Detail.ToString()) == false)
|
||||
ListTabs.Add($"{EnumTabs.OverviewC1Detail.ToString()}", EnumTabs.OverviewC1Detail);
|
||||
int tabId = Tabs.Max(x => x.Key.Id) + 1;
|
||||
Tabs.AddOrUpdate(
|
||||
new OrderdTab { Id = tabId, TabName = $"{EnumTabs.OverviewC1Detail} ({tabId})", EnumTab = EnumTabs.OverviewC1Detail },
|
||||
key => detailOverviews.Cast<IDataModel>().ToList(), (key, oldValue) => detailOverviews.Cast<IDataModel>().ToList());
|
||||
|
||||
tabs.Reload();
|
||||
SelectedTabIndex = ListTabs.Keys.ToList().IndexOf(EnumTabs.OverviewC1Detail.ToString());
|
||||
SelectedTabIndex = Tabs.Count - 1;
|
||||
}
|
||||
|
||||
private async Task OnDoubleClickRowDetailOverview(IDataModel row)
|
||||
{
|
||||
var historyIndex = TestHistories.Count();
|
||||
string histoiresKey = $"{EnumTabs.TestHistoryC1.ToString()}({historyIndex + 1})";
|
||||
|
||||
List<TestHistory> histories = new();
|
||||
if (IsMergePartNumberOption == false)
|
||||
{
|
||||
var getHistories = await CPXV2LogService.GetTestHistory(SearchDataOverviews, row);
|
||||
TestHistories.Add(histoiresKey, getHistories);
|
||||
histories = await CPXV2LogService.GetTestHistory(SearchDataOverviews, row);
|
||||
}
|
||||
else
|
||||
{
|
||||
var getHistories = await CPXV2LogService.GetTestHistoryMerged(SearchDataOverviews, row);
|
||||
TestHistories.Add(histoiresKey, getHistories);
|
||||
histories = await CPXV2LogService.GetTestHistoryMerged(SearchDataOverviews, row);
|
||||
}
|
||||
|
||||
//tab control
|
||||
ListTabs.Add(histoiresKey, EnumTabs.TestHistoryC1);
|
||||
tabs.Reload();
|
||||
int tabId = Tabs.Max(x => x.Key.Id) + 1;
|
||||
Tabs.AddOrUpdate(
|
||||
new OrderdTab { Id = tabId, TabName = $"{EnumTabs.TestHistoryC1}({tabId})", EnumTab = EnumTabs.TestHistoryC1 },
|
||||
key => histories.Cast<IDataModel>().ToList(), (key, oldValue) => histories.Cast<IDataModel>().ToList());
|
||||
|
||||
SelectedTabIndex = ListTabs.Count - 1;
|
||||
tabs.Reload();
|
||||
SelectedTabIndex = Tabs.Count - 1;
|
||||
}
|
||||
|
||||
private void OnClickDetailOverviewContextMenu()
|
||||
@ -260,19 +271,33 @@
|
||||
// SelectedTabIndex = ListTabs.Keys.ToList().IndexOf($"{EnumTabs.TestHistoryC1}({index})");
|
||||
}
|
||||
|
||||
void OnClickClose(string tabKey)
|
||||
void OnClickClose(int tabId)
|
||||
{
|
||||
CloseTab(tabKey);
|
||||
CloseTab(tabId);
|
||||
}
|
||||
|
||||
void CloseTab(string tabKey)
|
||||
void CloseTab(int tabId)
|
||||
{
|
||||
if (ListTabs.ContainsKey(tabKey))
|
||||
var removeTab = Tabs.Where(x => x.Key.Id == tabId)?.First().Key;
|
||||
|
||||
//remove
|
||||
if (removeTab is not null)
|
||||
{
|
||||
ListTabs.Remove(tabKey);
|
||||
if (SelectedTabIndex >= ListTabs.Count)
|
||||
SelectedTabIndex = ListTabs.Count - 1;
|
||||
Tabs.TryRemove(removeTab, out var value);
|
||||
}
|
||||
|
||||
//select tab
|
||||
var currentTab = tabs.SelectedTab;
|
||||
if (Tabs.Where(x => x.Key.TabName == currentTab.Text)?.Count() > 0)
|
||||
{
|
||||
SelectedTabIndex = currentTab.Index;
|
||||
}
|
||||
else
|
||||
{
|
||||
SelectedTabIndex = Tabs.Count - 1;
|
||||
}
|
||||
|
||||
|
||||
tabs.Reload();
|
||||
}
|
||||
|
||||
@ -280,12 +305,13 @@
|
||||
{
|
||||
PopupService.OpenIndicator("");
|
||||
|
||||
foreach(var tab in ListTabs)
|
||||
{
|
||||
if (tab.Value == EnumTabs.OverviewC1)
|
||||
continue;
|
||||
CloseTab(tab.Key.ToString());
|
||||
}
|
||||
// foreach(var tab in Tabs)
|
||||
// {
|
||||
// if (tab.Value == EnumTabs.OverviewC1)
|
||||
// continue;
|
||||
|
||||
// CloseTab(tab.Key.ToString());
|
||||
// }
|
||||
|
||||
await GetOverviews();
|
||||
|
||||
|
||||
11
Projects/WebClient/Web.Tra/Model/OrderdTab.cs
Normal file
11
Projects/WebClient/Web.Tra/Model/OrderdTab.cs
Normal file
@ -0,0 +1,11 @@
|
||||
using Web.Tra.Model.Enum;
|
||||
|
||||
namespace Web.Tra.Model
|
||||
{
|
||||
public class OrderdTab
|
||||
{
|
||||
public int Id { get; set; }
|
||||
public string TabName { get; set; }
|
||||
public EnumTabs EnumTab { get; set; }
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user