Merge pull request '작업 조건/시간 분석 창 재 활성화 시 설비 데이터 정합성 유지' (#120) from dev/jym/250718_00 into main

Reviewed-on: http://220.90.135.190:3000/UVCXR/ChunilENG/pulls/120
This commit was merged in pull request #120.
This commit is contained in:
jym
2025-07-18 12:46:17 +09:00
4 changed files with 164 additions and 14 deletions

View File

@@ -151,4 +151,12 @@ public class UI_Calendar : UIBase
curDateTime = curDateTime.AddMonths(1); curDateTime = curDateTime.AddMonths(1);
SetCalendar(); SetCalendar();
} }
public void SetCalendarData(TextMeshProUGUI target, string dateText)
{
DateTime.TryParseExact(dateText, "yyyyMMdd", CultureInfo.InvariantCulture, DateTimeStyles.None, out var date);
curDateTime = date;
SetCalendar();
target.text = date.ToString("yyyy-MM-dd");
}
} }

View File

@@ -11,14 +11,18 @@ using System.Linq;
namespace CHN namespace CHN
{ {
public enum DataColumn public class PreviousWorkConditionData
{ {
, public string startDate;
, public string endDate;
, public WorkItemCodeData itemCodeDatas;
public string workItemCode;
public int workItemCodeIndex;
} }
public class Panel_WorkConditionAnalysis : PanelBase, ISingle public class Panel_WorkConditionAnalysis : PanelBase, ISingle
{ {
public Dictionary<string, PreviousWorkConditionData> workConditionDatas = new Dictionary<string, PreviousWorkConditionData>();
private Button Button_StartDay; private Button Button_StartDay;
private Button Button_EndDay; private Button Button_EndDay;
private TextMeshProUGUI Text_StartDay; private TextMeshProUGUI Text_StartDay;
@@ -44,10 +48,10 @@ namespace CHN
public WorkConditionsData data; public WorkConditionsData data;
public WorkItemCodeData itemCodeData; public WorkItemCodeData itemCodeData;
public Action<string> onClose; public Action<string> onClose;
public float fadeTime; public float fadeTime;
public string todayDate;
public string startDate; public string startDate;
public string endDate; public string endDate;
public string facilityCode; public string facilityCode;
@@ -66,6 +70,7 @@ namespace CHN
ui_Calendar.Close(); ui_Calendar.Close();
todayDate = DateTime.Now.ToString("yyyyMMdd");
Text_StartDay.text = DateTime.Now.ToString("yyyy-MM-dd"); Text_StartDay.text = DateTime.Now.ToString("yyyy-MM-dd");
Text_EndDay.text = DateTime.Now.ToString("yyyy-MM-dd"); Text_EndDay.text = DateTime.Now.ToString("yyyy-MM-dd");
@@ -128,14 +133,49 @@ namespace CHN
public void SetFacilityCode(SimpleField simple, Machine machine) public void SetFacilityCode(SimpleField simple, Machine machine)
{ {
facilityCode = machine.code; facilityCode = machine.code;
if (workConditionDatas.ContainsKey(facilityCode))
{
this.startDate = workConditionDatas[facilityCode].startDate;
this.endDate = workConditionDatas[facilityCode].endDate;
ui_Calendar.SetCalendarData(Text_StartDay, workConditionDatas[facilityCode].startDate);
ui_Calendar.SetCalendarData(Text_EndDay, workConditionDatas[facilityCode].endDate);
DateTime startDate = Convert.ToDateTime(Text_StartDay.text);
DateTime endDate = Convert.ToDateTime(Text_EndDay.text);
string startDateString = startDate.ToString("yyyy-MM-ddTHH:mm:ssZ");
string endDateString = endDate.ToString("yyyy-MM-ddTHH:mm:ssZ");
SetWorkItemCodeDropDown(workConditionDatas[facilityCode].itemCodeDatas);
Dropdown_WorkOrderNumber.value = workConditionDatas[facilityCode].workItemCodeIndex;
var workItemCode = Dropdown_WorkOrderNumber.options[Dropdown_WorkOrderNumber.value].text;
onSearchData?.Invoke(startDateString, endDateString, facilityCode, workItemCode);
}
else
{
this.startDate = todayDate;
this.endDate = todayDate;
ui_Calendar.SetCalendarData(Text_StartDay, todayDate);
ui_Calendar.SetCalendarData(Text_EndDay, todayDate);
Dropdown_WorkOrderNumber.ClearOptions();
ChartDatas.gameObject.SetActive(false);
Panel_NotData.gameObject.SetActive(false);
}
} }
public void SetWorkItemCodeDropDown(WorkItemCodeData itemCodeData) public void SetWorkItemCodeDropDown(WorkItemCodeData itemCodeData)
{ {
Dropdown_WorkOrderNumber.ClearOptions();
this.itemCodeData = itemCodeData; this.itemCodeData = itemCodeData;
Dropdown_WorkOrderNumber.ClearOptions();
List<string> data = new List<string>(); List<string> data = new List<string>();
foreach(var workOrderNumber in itemCodeData.data) foreach(var workOrderNumber in this.itemCodeData.data)
{ {
data.Add(workOrderNumber.wordno); data.Add(workOrderNumber.wordno);
} }
@@ -169,11 +209,13 @@ namespace CHN
{ {
Panel_NotData.gameObject.SetActive(true); Panel_NotData.gameObject.SetActive(true);
ChartDatas.gameObject.SetActive(false); ChartDatas.gameObject.SetActive(false);
return;
} }
Panel_NotData.gameObject.SetActive(false); else
ChartDatas.gameObject.SetActive(true); {
Panel_NotData.gameObject.SetActive(false);
ChartDatas.gameObject.SetActive(true);
}
data = workConditionsData; data = workConditionsData;
if (data.data.rows.Length > 0) if (data.data.rows.Length > 0)
@@ -181,6 +223,29 @@ namespace CHN
ITEMCD.text = data.data.rows[0].ITEMCD; ITEMCD.text = data.data.rows[0].ITEMCD;
} }
if (!workConditionDatas.ContainsKey(facilityCode))
{
var newWorkConditionData = new PreviousWorkConditionData();
newWorkConditionData.startDate = startDate;
newWorkConditionData.endDate = endDate;
newWorkConditionData.itemCodeDatas = itemCodeData;
newWorkConditionData.workItemCode = Dropdown_WorkOrderNumber.options[Dropdown_WorkOrderNumber.value].text;
newWorkConditionData.workItemCodeIndex = Dropdown_WorkOrderNumber.value;
workConditionDatas.Add(facilityCode, newWorkConditionData);
}
else
{
var newWorkConditionData = new PreviousWorkConditionData();
newWorkConditionData.startDate = startDate;
newWorkConditionData.endDate = endDate;
newWorkConditionData.itemCodeDatas = itemCodeData;
newWorkConditionData.workItemCode = Dropdown_WorkOrderNumber.options[Dropdown_WorkOrderNumber.value].text;
newWorkConditionData.workItemCodeIndex = Dropdown_WorkOrderNumber.value;
workConditionDatas[facilityCode] = newWorkConditionData;
}
SetDataColumnDropDown(); SetDataColumnDropDown();
OnDropdownValueChanged(0); OnDropdownValueChanged(0);
} }

View File

@@ -9,8 +9,18 @@ using System.Globalization;
namespace CHN namespace CHN
{ {
public class PreviousWorkTimeData
{
public string startDate;
public string endDate;
public WorkItemCodeData itemCodeDatas;
public string workItemCode;
public int workItemCodeIndex;
}
public class Panel_WorkTimeAnalysis : PanelBase, ISingle public class Panel_WorkTimeAnalysis : PanelBase, ISingle
{ {
public Dictionary<string, PreviousWorkTimeData> workTimeDatas = new Dictionary<string, PreviousWorkTimeData>();
private Button Button_StartDay; private Button Button_StartDay;
private Button Button_EndDay; private Button Button_EndDay;
private TextMeshProUGUI Text_StartDay; private TextMeshProUGUI Text_StartDay;
@@ -25,11 +35,13 @@ namespace CHN
private RectTransform ChartData; private RectTransform ChartData;
public UI_BarChart barChart; public UI_BarChart barChart;
private WorkItemCodeData itemCodeData;
public Action<string, string, string, string> onSearchData; public Action<string, string, string, string> onSearchData;
public Action<string> onClose; public Action<string> onClose;
public float fadeTime; public float fadeTime;
public string todayDate;
public string startDate; public string startDate;
public string endDate; public string endDate;
public string facilityCode; public string facilityCode;
@@ -46,6 +58,7 @@ namespace CHN
ui_Calendar.Close(); ui_Calendar.Close();
todayDate = DateTime.Now.ToString("yyyyMMdd");
Text_StartDay.text = DateTime.Now.ToString("yyyy-MM-dd"); Text_StartDay.text = DateTime.Now.ToString("yyyy-MM-dd");
Text_EndDay.text = DateTime.Now.ToString("yyyy-MM-dd"); Text_EndDay.text = DateTime.Now.ToString("yyyy-MM-dd");
@@ -111,9 +124,44 @@ namespace CHN
public void SetFacilityCode(SimpleField simple, Machine machine) public void SetFacilityCode(SimpleField simple, Machine machine)
{ {
facilityCode = machine.code; facilityCode = machine.code;
if (workTimeDatas.ContainsKey(facilityCode))
{
this.startDate = workTimeDatas[facilityCode].startDate;
this.endDate = workTimeDatas[facilityCode].endDate;
ui_Calendar.SetCalendarData(Text_StartDay, workTimeDatas[facilityCode].startDate);
ui_Calendar.SetCalendarData(Text_EndDay, workTimeDatas[facilityCode].endDate);
DateTime startDate = Convert.ToDateTime(Text_StartDay.text);
DateTime endDate = Convert.ToDateTime(Text_EndDay.text);
string startDateString = startDate.ToString("yyyy-MM-ddTHH:mm:ssZ");
string endDateString = endDate.ToString("yyyy-MM-ddTHH:mm:ssZ");
SetWorkItemCodeDropDown(workTimeDatas[facilityCode].itemCodeDatas);
Dropdown_WorkOrderNumber.value = workTimeDatas[facilityCode].workItemCodeIndex;
var workItemCode = Dropdown_WorkOrderNumber.options[Dropdown_WorkOrderNumber.value].text;
onSearchData?.Invoke(startDateString, endDateString, facilityCode, workItemCode);
}
else
{
this.startDate = todayDate;
this.endDate = todayDate;
ui_Calendar.SetCalendarData(Text_StartDay, todayDate);
ui_Calendar.SetCalendarData(Text_EndDay, todayDate);
Dropdown_WorkOrderNumber.ClearOptions();
ChartData.gameObject.SetActive(false);
Panel_NotData.gameObject.SetActive(false);
}
} }
public void SetWorkItemCodeDropDown(WorkItemCodeData itemCodeData) public void SetWorkItemCodeDropDown(WorkItemCodeData itemCodeData)
{ {
this.itemCodeData = itemCodeData;
Dropdown_WorkOrderNumber.ClearOptions(); Dropdown_WorkOrderNumber.ClearOptions();
List<string> data = new List<string>(); List<string> data = new List<string>();
@@ -151,16 +199,42 @@ namespace CHN
{ {
Panel_NotData.gameObject.SetActive(true); Panel_NotData.gameObject.SetActive(true);
ChartData.gameObject.SetActive(false); ChartData.gameObject.SetActive(false);
return;
} }
Panel_NotData.gameObject.SetActive(false); else
ChartData.gameObject.SetActive(true); {
Panel_NotData.gameObject.SetActive(false);
ChartData.gameObject.SetActive(true);
}
if (barChartData.Count > 0) if (barChartData.Count > 0)
{ {
ITEMCD.text = barChartData[0].itemcd; ITEMCD.text = barChartData[0].itemcd;
} }
if (!workTimeDatas.ContainsKey(facilityCode))
{
var newWorkConditionData = new PreviousWorkTimeData();
newWorkConditionData.startDate = startDate;
newWorkConditionData.endDate = endDate;
newWorkConditionData.itemCodeDatas = itemCodeData;
newWorkConditionData.workItemCode = Dropdown_WorkOrderNumber.options[Dropdown_WorkOrderNumber.value].text;
newWorkConditionData.workItemCodeIndex = Dropdown_WorkOrderNumber.value;
workTimeDatas.Add(facilityCode, newWorkConditionData);
}
else
{
var newWorkConditionData = new PreviousWorkTimeData();
newWorkConditionData.startDate = startDate;
newWorkConditionData.endDate = endDate;
newWorkConditionData.itemCodeDatas = itemCodeData;
newWorkConditionData.workItemCode = Dropdown_WorkOrderNumber.options[Dropdown_WorkOrderNumber.value].text;
newWorkConditionData.workItemCodeIndex = Dropdown_WorkOrderNumber.value;
workTimeDatas[facilityCode] = newWorkConditionData;
}
barChart.SetChartData(barChartData); barChart.SetChartData(barChartData);
} }
IEnumerator ScaleUp() IEnumerator ScaleUp()

View File

@@ -98,6 +98,9 @@ public class UI_GraphChart : UIBase, IPointerClickHandler
} }
private void SetDataValue(GraphChartData graphData) private void SetDataValue(GraphChartData graphData)
{ {
if (graphData.chartData.Count <= 0)
return;
min = graphData.chartData.Min(); min = graphData.chartData.Min();
max = graphData.chartData.Max(); max = graphData.chartData.Max();
ave = graphData.chartData.Average(); ave = graphData.chartData.Average();