FrmWCS_Task.cs 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272
  1. using DevComponents.DotNetBar.Controls;
  2. using DevComponents.DotNetBar.Layout;
  3. using DevComponents.DotNetBar.SuperGrid;
  4. using System;
  5. using System.Collections.Generic;
  6. using System.ComponentModel;
  7. using System.Data;
  8. using System.Drawing;
  9. using System.Linq;
  10. using System.Text;
  11. using System.Threading.Tasks;
  12. using System.Windows.Forms;
  13. using WCS.Data.Models;
  14. using WCS_Client;
  15. using WCS_Client.UC;
  16. using WCS_Client.Utility;
  17. namespace WCS_Client.Frm
  18. {
  19. public partial class FrmWCS_Task : Form
  20. {
  21. int wcs_task_no = 0;
  22. public FrmWCS_Task()
  23. {
  24. InitializeComponent();
  25. InitFrm();
  26. }
  27. private void InitFrm()
  28. {
  29. List<GridColumn> GCList = new List<GridColumn>()
  30. {
  31. SuperGridUtil.Get_GridColumn("ID", "任务ID号", 80),
  32. SuperGridUtil.Get_GridColumn("WMSTASK", "WMS任务号", 80),
  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("ADDRline", "目标产线", 100),
  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 = "ID like '%{0}%'" };
  65. LCIList.Add(LCItemUtil.Add_TextboxX("WMSTASK", "WMS任务号:", 20, SubmitMethods, null));
  66. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "WMSTASK like '%{0}%'" };
  67. LCIList.Add(LCItemUtil.Add_TextboxX("BARCODE", "条码:", 20, SubmitMethods, null));
  68. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "BARCODE like '%{0}%'" };
  69. LCIList.Add(LCItemUtil.Add_TextboxX("ADDRFROM", "起始地址:", 20, SubmitMethods, null));
  70. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "ADDRFROM like '%{0}%'" };
  71. LCIList.Add(LCItemUtil.Add_TextboxX("ADDRCURRENT", "当前地址:", 20, SubmitMethods, null));
  72. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "ADDRCURRENT like '%{0}%'" };
  73. LCIList.Add(LCItemUtil.Add_TextboxX("ADDRNEXT", "下个地址:", 20, SubmitMethods, null));
  74. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "ADDRNEXT like '%{0}%'" };
  75. LCIList.Add(LCItemUtil.Add_TextboxX("ADDRTO", "目的地址:", 20, SubmitMethods, null));
  76. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "ADDRTO like '%{0}%'" };
  77. LCIList.Add(LCItemUtil.Add_TextboxX("DEVICE", "堆垛机编号:", 20, SubmitMethods, null));
  78. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "DEVICE like '%{0}%'" };
  79. LCIList.Add(LCItemUtil.Add_ComboBoxEx("TYPE", "任务类型:", 20, null, SubmitMethods));
  80. TryCachHelper.TryExecute((db) =>
  81. {
  82. var dtsex = db.Queryable<WCS_MAPPINGENTRY> ().Where(v=>v.MEP_MAPPINGTYPE == "TYPE").ToList();
  83. DataTable dt = new DataTable();
  84. DataRow dr;
  85. dt.Columns.Add("MEP_MAPPINGNO");
  86. dt.Columns.Add("MEP_MAPPINGCHNAME");
  87. for (int i = 0; i < dtsex.Count; i++)
  88. {
  89. dr = dt.NewRow();
  90. dr["MEP_MAPPINGNO"] = dtsex[i].MEP_MAPPINGNO;
  91. dr["MEP_MAPPINGCHNAME"] = dtsex[i].MEP_MAPPINGCHNAME;
  92. dt.Rows.Add(dr);
  93. }
  94. LCItemUtil.Refresh_LCItem(LCIList[LCIList.Count - 1], dt, "MEP_MAPPINGNO", "MEP_MAPPINGCHNAME");
  95. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "TYPE like '%{0}%'" };
  96. });
  97. LCIList.Add(LCItemUtil.Add_ComboBoxEx("STATUS", "任务状态:", 20, null, SubmitMethods));
  98. TryCachHelper.TryExecute((db) =>
  99. {
  100. var dtsex = db.Queryable<WCS_MAPPINGENTRY>().Where(v => v.MEP_MAPPINGTYPE == "STATUS").ToList();
  101. DataTable dt = new DataTable();
  102. DataRow dr;
  103. dt.Columns.Add("MEP_MAPPINGNO");
  104. dt.Columns.Add("MEP_MAPPINGCHNAME");
  105. for (int i = 0; i < dtsex.Count; i++)
  106. {
  107. dr = dt.NewRow();
  108. dr["MEP_MAPPINGNO"] = dtsex[i].MEP_MAPPINGNO;
  109. dr["MEP_MAPPINGCHNAME"] = dtsex[i].MEP_MAPPINGCHNAME;
  110. dt.Rows.Add(dr);
  111. }
  112. LCItemUtil.Refresh_LCItem(LCIList[LCIList.Count - 1], dt, "MEP_MAPPINGNO", "MEP_MAPPINGCHNAME");
  113. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "STATUS like '%{0}%'" };
  114. });
  115. LCIList.Add(LCItemUtil.Add_ButtonX("btn_QDB", "查询", 100, 30, SubmitMethods));
  116. LCIList.Add(LCItemUtil.Add_ButtonX("btn_QClear", "重置", 100, 30, SubmitMethods));
  117. if (CurrentHelper.User.Use_RoleId == 1)
  118. {
  119. LCIList.Add(LCItemUtil.Add_ButtonX("btn_FinishTask", "手动完成任务", 100, 30, SubmitMethods));
  120. LCIList.Add(LCItemUtil.Add_ButtonX("btn_ClearTask", "取消任务", 100, 30, SubmitMethods));
  121. LCIList.Add(LCItemUtil.Add_ButtonX("btn_UpdatePriority", "修改优先级", 100, 30, SubmitMethods));
  122. LCIList.Add(LCItemUtil.Add_ButtonX("btn_RestartTask", "重新下发出库任务", 200, 30, SubmitMethods));
  123. }
  124. uC_QueryPage1.Init_QueryPage(86, true, true, "", GCList, LCIList, QueryPageDataMethods, RefreshRoleMethods, null, null, ClikMethod);
  125. uC_QueryPage1.ClearLCItemValue();
  126. CommonShow.ShowProcessing("正在处理中,请稍候...", this, (obj) =>
  127. {
  128. uC_QueryPage1.RefreshData(1, 0);
  129. }, null);
  130. }
  131. //获取数据集
  132. private PageData QueryPageDataMethods(int PageIndex, int PageSize)
  133. {
  134. string _SQLText = @"select t.*,m.MEP_MAPPINGCHNAME task_comtypech,me.MEP_MAPPINGCHNAME task_wkstatusch from dbo.WCS_TASK t
  135. left join WCS_MAPPINGENTRY m on t.TYPE = m.MEP_MAPPINGNO and m.MEP_MAPPINGTYPE = 'TYPE'
  136. left join WCS_MAPPINGENTRY me on t.STATUS = me.MEP_MAPPINGNO and me.MEP_MAPPINGTYPE = 'STATUS' where 1=1 and STATUS < 99 ";
  137. string _Orderby = "CREATETIME desc ";
  138. PageData pd = BaseWorkflow.QueryPageData(_SQLText, _Orderby, uC_QueryPage1.GetQueryWhere(), PageIndex, PageSize);
  139. return pd;
  140. }
  141. private void SubmitMethods(string LCName)
  142. {
  143. if (LCName == "btn_QDB")
  144. {
  145. uC_QueryPage1.RefreshData();
  146. }
  147. else if (LCName == "btn_RestartTask")
  148. {
  149. DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows();
  150. if (dt == null || dt.Rows.Count == 0)
  151. {
  152. MessageUtil.ShowTips("请选择任务。");
  153. return;
  154. }
  155. int task_no = Convert.ToInt32(dt.Rows[0]["ID"].ToString());
  156. var result = MessageUtil.ShowYesNoAndWarning(string.Format("任务[{0}]确定要重下出库任务吗(请谨慎操作)?", task_no));
  157. if (result == DialogResult.Yes)
  158. {
  159. string msg = BaseWorkflow.RestartTask(task_no);
  160. MessageUtil.ShowTips(msg);
  161. uC_QueryPage1.RefreshData(1, 0);
  162. }
  163. }
  164. else if (LCName == "btn_FinishTask")
  165. {
  166. DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows();
  167. if (dt == null || dt.Rows.Count == 0)
  168. {
  169. MessageUtil.ShowTips("请选择任务。");
  170. return;
  171. }
  172. int task_no = Convert.ToInt32(dt.Rows[0]["ID"].ToString());
  173. var result = MessageUtil.ShowYesNoAndWarning(string.Format("任务[{0}]确定要[手动完成任务]吗(请谨慎操作)?", task_no));
  174. if (result == DialogResult.Yes)
  175. {
  176. string msg = BaseWorkflow.FinishTask(task_no);
  177. MessageUtil.ShowTips(msg);
  178. uC_QueryPage1.RefreshData(1, 0);
  179. }
  180. }
  181. else if (LCName == "btn_ClearTask")
  182. {
  183. DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows();
  184. if (dt == null || dt.Rows.Count == 0)
  185. {
  186. MessageUtil.ShowTips("请选择任务。");
  187. return;
  188. }
  189. int task_no = Convert.ToInt32(dt.Rows[0]["ID"].ToString());
  190. var result = MessageUtil.ShowYesNoAndWarning(string.Format("任务[{0}]确定要[取消任务]吗(请谨慎操作)?", task_no));
  191. if (result == DialogResult.Yes)
  192. {
  193. string msg = BaseWorkflow.ClearTask(task_no);
  194. MessageUtil.ShowTips(msg);
  195. uC_QueryPage1.RefreshData(1, 0);
  196. }
  197. }
  198. else if (LCName == "btn_QClear")
  199. {
  200. uC_QueryPage1.ShowOpaqueLayer();
  201. uC_QueryPage1.ClearLCItemValue();
  202. uC_QueryPage1.RefreshData(1, 0);
  203. uC_QueryPage1.HideOpaqueLayer();
  204. }
  205. else if (LCName == "btn_CreateProInTask")
  206. {
  207. //FrmCreateTask frm = new FrmCreateTask();
  208. //frm.ShowDialog();
  209. uC_QueryPage1.RefreshData(1, 0);
  210. }
  211. else if (LCName == "btn_UpdateEndAddress")
  212. {
  213. DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows();
  214. if (dt == null || dt.Rows.Count == 0)
  215. {
  216. MessageUtil.ShowTips("请选择任务。");
  217. return;
  218. }
  219. DataRow dr = dt.Rows[0];
  220. string comtypech = dt.Rows[0]["task_comtypech"].ToString();
  221. if (comtypech.Contains("入库"))
  222. {
  223. var frmUpdateEndAddress = new FrmUpdateEndAddress(dr);
  224. frmUpdateEndAddress.ShowDialog();
  225. }
  226. else
  227. {
  228. MessageUtil.ShowTips("只有入库任务能变更目标地址。");
  229. }
  230. }
  231. else if (LCName == "btn_UpdatePriority")
  232. {
  233. DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows();
  234. if (dt == null || dt.Rows.Count == 0)
  235. {
  236. MessageUtil.ShowTips("请选择任务。");
  237. return;
  238. }
  239. DataRow dr = dt.Rows[0];
  240. var frmUpdatePriority = new FrmUpdatePriority(dr);
  241. frmUpdatePriority.ShowDialog();
  242. uC_QueryPage1.RefreshData(1, 0);
  243. }
  244. }
  245. private void RefreshRoleMethods(bool ChkValue)
  246. {
  247. //if (AppConst.CheckExtentByName("查询任务"))
  248. //
  249. }
  250. private void ClikMethod(DataRow dr)
  251. {
  252. }
  253. }
  254. }