FrmWCS_TaskDIS.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  1. using DevComponents.DotNetBar.Layout;
  2. using DevComponents.DotNetBar.SuperGrid;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.ComponentModel;
  6. using System.Data;
  7. using System.Drawing;
  8. using System.Linq;
  9. using System.Text;
  10. using System.Threading.Tasks;
  11. using System.Windows.Forms;
  12. using WCS.Data.Models;
  13. using WCS_Client;
  14. using WCS_Client.UC;
  15. using WCS_Client.Utility;
  16. namespace WCS_Client.Frm
  17. {
  18. public partial class FrmWCS_TaskDIS : Form
  19. {
  20. int wcs_task_no = 0;
  21. public FrmWCS_TaskDIS()
  22. {
  23. InitializeComponent();
  24. InitFrm();
  25. }
  26. private void InitFrm()
  27. {
  28. List<GridColumn> GCList = new List<GridColumn>()
  29. {
  30. SuperGridUtil.Get_GridColumn("ID", "任务ID号", 80),
  31. SuperGridUtil.Get_GridColumn("WMSTASK", "WMS任务号", 80),
  32. SuperGridUtil.Get_GridColumn("TaskGroupKey", "任务组编号", 140),
  33. SuperGridUtil.Get_GridColumn("task_comtypech", "任务类型", 80),
  34. SuperGridUtil.Get_GridColumn("task_wkstatusch", "任务状态", 100),
  35. SuperGridUtil.Get_GridColumn("BARCODE", "条码", 160),
  36. SuperGridUtil.Get_GridColumn("ADDRFROM", "起始地址", 100),
  37. SuperGridUtil.Get_GridColumn("ADDRCURRENT", "当前地址", 80),
  38. SuperGridUtil.Get_GridColumn("ADDRNEXT", "下个地址", 80),
  39. SuperGridUtil.Get_GridColumn("ADDRTO", "目的地址", 100),
  40. SuperGridUtil.Get_GridColumn("Position", "目标产线", 100),//ADDRline
  41. SuperGridUtil.Get_GridColumn("DEVICE", "堆垛机编号", 80),
  42. SuperGridUtil.Get_GridColumn("TUNNEL", "巷道", 70),
  43. SuperGridUtil.Get_GridColumn("Priority", "优先级", 60),
  44. SuperGridUtil.Get_GridColumn("PALLETTYPE", "托盘类型", 80),
  45. //SuperGridUtil.Get_GridColumn("TASK_RGVNO", "RGV编号", 70),
  46. SuperGridUtil.Get_GridColumn("GROUPTASK", "分组编号", 80),
  47. SuperGridUtil.Get_GridColumn("AgvTask", "AGV任务号", 100),
  48. SuperGridUtil.Get_GridColumn("TASK_ADDUSERNO", "创建用户", 100),
  49. SuperGridUtil.Get_Datetime_GridColumn("CREATETIME", "创建时间", 130),
  50. SuperGridUtil.Get_Datetime_GridColumn("STARTTIME", "开始时间", 130),
  51. SuperGridUtil.Get_Datetime_GridColumn("ENDTIME", "结束时间", 130),
  52. SuperGridUtil.Get_GridColumn("UPDATEUSER", "修改用户", 100),
  53. SuperGridUtil.Get_Datetime_GridColumn("UPDATETIME", "修改时间", 130),
  54. SuperGridUtil.Get_GridColumn("PRODLINE", "产线", 100),
  55. SuperGridUtil.Get_GridColumn("SCSTATION", "站台号", 100),
  56. // SuperGridUtil.Get_GridColumn("SonTrayColorNo", "子托盘颜色", 100),
  57. // SuperGridUtil.Get_GridColumn("TASK_WEIGHT", "箱子重量", 100),
  58. //SuperGridUtil.Get_GridColumn("TASK_STACKINGTYPE", "垛型", 100)
  59. //SuperGridUtil.Get_CheckBoxX_GridColumn("Task_IsInventory", "是否盘点任务", 80),
  60. //SuperGridUtil.Get_CheckBoxX_GridColumn("Task_IsEmptyBox", "是否空箱", 80),
  61. };
  62. List<LayoutControlItem> LCIList = new List<LayoutControlItem>();
  63. LCIList.Add(LCItemUtil.Add_TextboxX("ID", "WCS任务号:", 20, SubmitMethods, null));
  64. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "t.ID like '%{0}%'" };
  65. LCIList.Add(LCItemUtil.Add_TextboxX("WMSTASK", "WMS任务号:", 20, SubmitMethods, null));
  66. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "t.WMSTASK like '%{0}%'" };
  67. LCIList.Add(LCItemUtil.Add_TextboxX("TaskGroupKey", "任务组编号:", 20, SubmitMethods, null));
  68. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "t.TaskGroupKey like '%{0}%'" };
  69. LCIList.Add(LCItemUtil.Add_TextboxX("BARCODE", "条码:", 20, SubmitMethods, null));
  70. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "t.BARCODE like '%{0}%'" };
  71. LCIList.Add(LCItemUtil.Add_TextboxX("ADDRFROM", "起始地址:", 20, SubmitMethods, null));
  72. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "t.ADDRFROM like '%{0}%'" };
  73. LCIList.Add(LCItemUtil.Add_TextboxX("ADDRCURRENT", "当前地址:", 20, SubmitMethods, null));
  74. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "t.ADDRCURRENT like '%{0}%'" };
  75. LCIList.Add(LCItemUtil.Add_TextboxX("ADDRNEXT", "下个地址:", 20, SubmitMethods, null));
  76. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "t.ADDRNEXT like '%{0}%'" };
  77. LCIList.Add(LCItemUtil.Add_TextboxX("ADDRTO", "目的地址:", 20, SubmitMethods, null));
  78. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "t.ADDRTO like '%{0}%'" };
  79. LCIList.Add(LCItemUtil.Add_TextboxX("Position", "目标产线:", 20, SubmitMethods, null));
  80. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "Position like '%{0}%'" };
  81. LCIList.Add(LCItemUtil.Add_TextboxX("DEVICE", "堆垛机编号:", 20, SubmitMethods, null));
  82. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "t.DEVICE like '%{0}%'" };
  83. LCIList.Add(LCItemUtil.Add_ComboBoxEx("TYPE", "任务类型:", 10, null, SubmitMethods));
  84. TryCachHelper.TryExecute((db) =>
  85. {
  86. var dtsex = db.Queryable<WCS_MAPPINGENTRY>().Where(v => v.MEP_MAPPINGTYPE == "TYPE").ToList();
  87. DataTable dt = new DataTable();
  88. DataRow dr;
  89. dt.Columns.Add("MEP_MAPPINGNO");
  90. dt.Columns.Add("MEP_MAPPINGCHNAME");
  91. for (int i = 0; i < dtsex.Count; i++)
  92. {
  93. dr = dt.NewRow();
  94. dr["MEP_MAPPINGNO"] = dtsex[i].MEP_MAPPINGNO;
  95. dr["MEP_MAPPINGCHNAME"] = dtsex[i].MEP_MAPPINGCHNAME;
  96. dt.Rows.Add(dr);
  97. }
  98. LCItemUtil.Refresh_LCItem(LCIList[LCIList.Count - 1], dt, "MEP_MAPPINGNO", "MEP_MAPPINGCHNAME");
  99. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "t.TYPE like '%{0}%'" };
  100. });
  101. LCIList.Add(LCItemUtil.Add_ComboBoxEx("ZONE", "区域:", 15, null, SubmitMethods));
  102. TryCachHelper.TryExecute((db) =>
  103. {
  104. var dtsex = db.Queryable<WCS_MAPPINGENTRY>().Where(v => v.MEP_MAPPINGTYPE == "ZONE").ToList();
  105. DataTable dt = new DataTable();
  106. DataRow dr;
  107. dt.Columns.Add("MEP_MAPPINGNO");
  108. dt.Columns.Add("MEP_MAPPINGCHNAME");
  109. for (int i = 0; i < dtsex.Count; i++)
  110. {
  111. dr = dt.NewRow();
  112. switch (dtsex[i].MEP_MAPPINGNO)
  113. {
  114. case 1:
  115. dr["MEP_MAPPINGNO"] = ".ADDRTO IN ('G1561','G1538','G1574','G1509','G1469')";
  116. break;
  117. case 2:
  118. dr["MEP_MAPPINGNO"] = ".ADDRFROM IN ('1157','1158')";
  119. break;
  120. case 3:
  121. dr["MEP_MAPPINGNO"] = ".ADDRFROM IN ('3052','3053','3005','3004')";
  122. break;
  123. case 4:
  124. dr["MEP_MAPPINGNO"] = ".ADDRFROM IN ('1028','1029')";
  125. break;
  126. case 5:
  127. dr["MEP_MAPPINGNO"] = ".ADDRFROM IN ('1386','1387','1435','1436')";
  128. break;
  129. case 6:
  130. dr["MEP_MAPPINGNO"] = ".ADDRTO IN ('G1340')";
  131. break;
  132. }
  133. dr["MEP_MAPPINGCHNAME"] = dtsex[i].MEP_MAPPINGCHNAME;
  134. dt.Rows.Add(dr);
  135. }
  136. LCItemUtil.Refresh_LCItem(LCIList[LCIList.Count - 1], dt, "MEP_MAPPINGNO", "MEP_MAPPINGCHNAME");
  137. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "t {0}" };
  138. });
  139. LCIList.Add(LCItemUtil.Add_ComboBoxEx("STATUS", "任务状态:", 15, null, SubmitMethods));
  140. TryCachHelper.TryExecute((db) =>
  141. {
  142. var dtsex = db.Queryable<WCS_MAPPINGENTRY>().Where(v => v.MEP_MAPPINGTYPE == "STATUS").ToList();
  143. DataTable dt = new DataTable();
  144. DataRow dr;
  145. dt.Columns.Add("MEP_MAPPINGNO");
  146. dt.Columns.Add("MEP_MAPPINGCHNAME");
  147. for (int i = 0; i < dtsex.Count; i++)
  148. {
  149. dr = dt.NewRow();
  150. dr["MEP_MAPPINGNO"] = dtsex[i].MEP_MAPPINGNO;
  151. dr["MEP_MAPPINGCHNAME"] = dtsex[i].MEP_MAPPINGCHNAME;
  152. dt.Rows.Add(dr);
  153. }
  154. LCItemUtil.Refresh_LCItem(LCIList[LCIList.Count - 1], dt, "MEP_MAPPINGNO", "MEP_MAPPINGCHNAME");
  155. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "t.STATUS like '%{0}%'" };
  156. });
  157. LCIList.Add(LCItemUtil.Add_ButtonX("btn_QDB", "查询", 80, 30, SubmitMethods));
  158. LCIList.Add(LCItemUtil.Add_ButtonX("btn_QClear", "重置", 80, 30, SubmitMethods));
  159. uC_QueryPage1.Init_QueryPage(86, true, true, "", GCList, LCIList, QueryPageDataMethods, RefreshRoleMethods, DoubleClikMethod, null, null);
  160. uC_QueryPage1.ClearLCItemValue();
  161. CommonShow.ShowProcessing("正在处理中,请稍候...", this, (obj) =>
  162. {
  163. uC_QueryPage1.RefreshData(1, 0);
  164. }, null);
  165. }
  166. private PageData QueryPageDataMethods(int PageIndex, int PageSize)
  167. {
  168. string _SQLText = @"select t.*,m.MEP_MAPPINGCHNAME task_comtypech,me.MEP_MAPPINGCHNAME task_wkstatusch,REPLACE(Position, 'Opp_205_', '') AS Position from (SELECT A.ID,A.ADDRFROM,A.ADDRNEXT,A.ADDRTO,A.AgvTask,A.BARCODE,A.CREATETIME,A.DEVICE,A.DOCID,A.ENABLED,A.ENDTIME,A.FLOOR,A.FULLQTY,A.HEIGHT,
  169. A.PRODLINE,A.ManualRemarks,A.PALLETTYPE,A.Priority,A.SRMSTATION,A.STARTTIME,A.STATUS,A.TaskGroupKey,A.TUNNEL,A.TYPE,A.UPDATETIME,A.UPDATEUSER,
  170. A.UPLOADED,A.WMSTASK
  171. FROM WCS_TASK A
  172. UNION SELECT B.ID,B.ADDRFROM,B.ADDRNEXT,B.ADDRTO,B.AgvTask,B.BARCODE,B.CREATETIME,B.DEVICE,B.DOCID,B.ENABLED,B.ENDTIME,B.FLOOR,B.FULLQTY,B.HEIGHT,
  173. B.PRODLINE,B.ManualRemarks,B.PALLETTYPE,B.Priority,B.SRMSTATION,B.STARTTIME,B.STATUS,B.TaskGroupKey,B.TUNNEL,B.TYPE,B.UPDATETIME,B.UPDATEUSER,
  174. B.UPLOADED,B.WMSTASK
  175. FROM WCS_TASK_OLD B) t
  176. left join WCS_MAPPINGENTRY m on t.TYPE = m.MEP_MAPPINGNO and m.MEP_MAPPINGTYPE = 'TYPE'
  177. left join WCS_MAPPINGENTRY me on t.STATUS = me.MEP_MAPPINGNO and me.MEP_MAPPINGTYPE = 'STATUS'
  178. left join WCS_AGVTASK a on a.ID=t.AgvTask
  179. where 1=1 and t.STATUS > 98 ";
  180. string _Orderby = "CREATETIME desc ";
  181. PageData pd = BaseWorkflow.QueryPageData(_SQLText, _Orderby, uC_QueryPage1.GetQueryWhere(), PageIndex, PageSize);
  182. return pd;
  183. }
  184. private void SubmitMethods(string LCName)
  185. {
  186. if (LCName == "btn_QDB")
  187. {
  188. uC_QueryPage1.RefreshData();
  189. }
  190. else if (LCName == "btn_QClear")
  191. {
  192. uC_QueryPage1.ShowOpaqueLayer();
  193. uC_QueryPage1.ClearLCItemValue();
  194. uC_QueryPage1.RefreshData(1, 0);
  195. uC_QueryPage1.HideOpaqueLayer();
  196. }
  197. }
  198. private void DoubleClikMethod(DataRow dr)
  199. {
  200. wcs_task_no = Convert.ToInt32(dr["TASK_NO"].ToString());
  201. FrmWCS_TaskDIS_DTL Frm = new FrmWCS_TaskDIS_DTL(wcs_task_no);
  202. Frm.Show();
  203. }
  204. private void RefreshRoleMethods(bool ChkValue)
  205. {
  206. }
  207. }
  208. }