FrmWCS_Task.cs 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336
  1. using DevComponents.DotNetBar.Layout;
  2. using DevComponents.DotNetBar.SuperGrid;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Data;
  6. using System.Windows.Forms;
  7. using WCS.Data.Models;
  8. using WCS_Client.UC;
  9. using WCS_Client.Utility;
  10. namespace WCS_Client.Frm
  11. {
  12. public partial class FrmWCS_Task : Form
  13. {
  14. private int wcs_task_no = 0;
  15. public FrmWCS_Task()
  16. {
  17. InitializeComponent();
  18. InitFrm();
  19. }
  20. private void InitFrm()
  21. {
  22. List<GridColumn> GCList = new List<GridColumn>()
  23. {
  24. SuperGridUtil.Get_GridColumn("ID", "任务ID号", 80),
  25. SuperGridUtil.Get_GridColumn("WMSTASK", "WMS任务号", 80),
  26. SuperGridUtil.Get_GridColumn("TaskGroupKey", "任务组编号", 140),
  27. SuperGridUtil.Get_GridColumn("task_comtypech", "任务类型", 80),
  28. SuperGridUtil.Get_GridColumn("task_wkstatusch", "任务状态", 100),
  29. SuperGridUtil.Get_GridColumn("BARCODE", "条码", 160),
  30. SuperGridUtil.Get_GridColumn("ADDRFROM", "起始地址", 100),
  31. SuperGridUtil.Get_GridColumn("ADDRCURRENT", "当前地址", 80),
  32. SuperGridUtil.Get_GridColumn("ADDRNEXT", "下个地址", 80),
  33. SuperGridUtil.Get_GridColumn("ADDRTO", "目的地址", 100),
  34. SuperGridUtil.Get_GridColumn("Position", "目标产线", 100),//ADDRline
  35. SuperGridUtil.Get_GridColumn("DEVICE", "堆垛机编号", 80),
  36. SuperGridUtil.Get_GridColumn("TUNNEL", "巷道", 70),
  37. SuperGridUtil.Get_GridColumn("Priority", "优先级", 60),
  38. //SuperGridUtil.Get_GridColumn("TASK_RGVNO", "RGV编号", 70),
  39. SuperGridUtil.Get_GridColumn("AgvTask", "AGV任务号", 100),
  40. SuperGridUtil.Get_GridColumn("TASK_ADDUSERNO", "创建用户", 100),
  41. SuperGridUtil.Get_Datetime_GridColumn("CREATETIME", "创建时间", 130),
  42. SuperGridUtil.Get_Datetime_GridColumn("STARTTIME", "开始时间", 130),
  43. SuperGridUtil.Get_Datetime_GridColumn("ENDTIME", "结束时间", 130),
  44. SuperGridUtil.Get_GridColumn("UPDATEUSER", "修改用户", 100),
  45. SuperGridUtil.Get_Datetime_GridColumn("UPDATETIME", "修改时间", 130),
  46. SuperGridUtil.Get_GridColumn("PRODLINE", "产线", 100),
  47. SuperGridUtil.Get_GridColumn("SRMSTATION", "站台号", 100),
  48. // SuperGridUtil.Get_GridColumn("SonTrayColorNo", "子托盘颜色", 100),
  49. // SuperGridUtil.Get_GridColumn("TASK_WEIGHT", "箱子重量", 100),
  50. //SuperGridUtil.Get_GridColumn("TASK_STACKINGTYPE", "垛型", 100)
  51. //SuperGridUtil.Get_CheckBoxX_GridColumn("Task_IsInventory", "是否盘点任务", 80),
  52. //SuperGridUtil.Get_CheckBoxX_GridColumn("Task_IsEmptyBox", "是否空箱", 80),
  53. };
  54. List<LayoutControlItem> LCIList = new List<LayoutControlItem>();
  55. LCIList.Add(LCItemUtil.Add_TextboxX("ID", "WCS任务号:", 10, SubmitMethods, null));
  56. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "t.ID like '%{0}%'" };
  57. LCIList.Add(LCItemUtil.Add_TextboxX("WMSTASK", "WMS任务号:", 10, SubmitMethods, null));
  58. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "WMSTASK like '%{0}%'" };
  59. LCIList.Add(LCItemUtil.Add_TextboxX("TaskGroupKey", "任务组编号:", 15, SubmitMethods, null));
  60. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "TaskGroupKey like '%{0}%'" };
  61. LCIList.Add(LCItemUtil.Add_TextboxX("BARCODE", "条码:", 15, SubmitMethods, null));
  62. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "BARCODE like '%{0}%'" };
  63. LCIList.Add(LCItemUtil.Add_TextboxX("ADDRFROM", "起始地址:", 10, SubmitMethods, null));
  64. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "ADDRFROM like '%{0}%'" };
  65. LCIList.Add(LCItemUtil.Add_TextboxX("ADDRCURRENT", "当前地址:", 10, SubmitMethods, null));
  66. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "ADDRCURRENT like '%{0}%'" };
  67. LCIList.Add(LCItemUtil.Add_TextboxX("ADDRNEXT", "下个地址:", 10, SubmitMethods, null));
  68. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "ADDRNEXT like '%{0}%'" };
  69. LCIList.Add(LCItemUtil.Add_TextboxX("ADDRTO", "目的地址:", 10, SubmitMethods, null));
  70. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "ADDRTO like '%{0}%'" };
  71. LCIList.Add(LCItemUtil.Add_TextboxX("Position", "目标产线:", 12, SubmitMethods, null));
  72. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "Position like '%{0}%'" };
  73. LCIList.Add(LCItemUtil.Add_TextboxX("DEVICE", "堆垛机编号:", 15, SubmitMethods, null));
  74. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "DEVICE like '%{0}%'" };
  75. LCIList.Add(LCItemUtil.Add_ComboBoxEx("TYPE", "任务类型:", 15, null, SubmitMethods));
  76. TryCachHelper.TryExecute((db) =>
  77. {
  78. var dtsex = db.Queryable<WCS_MAPPINGENTRY>().Where(v => v.MEP_MAPPINGTYPE == "TYPE").ToList();
  79. DataTable dt = new DataTable();
  80. DataRow dr;
  81. dt.Columns.Add("MEP_MAPPINGNO");
  82. dt.Columns.Add("MEP_MAPPINGCHNAME");
  83. for (int i = 0; i < dtsex.Count; i++)
  84. {
  85. dr = dt.NewRow();
  86. dr["MEP_MAPPINGNO"] = dtsex[i].MEP_MAPPINGNO;
  87. dr["MEP_MAPPINGCHNAME"] = dtsex[i].MEP_MAPPINGCHNAME;
  88. dt.Rows.Add(dr);
  89. }
  90. LCItemUtil.Refresh_LCItem(LCIList[LCIList.Count - 1], dt, "MEP_MAPPINGNO", "MEP_MAPPINGCHNAME");
  91. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "t.TYPE like '%{0}%'" };
  92. });
  93. LCIList.Add(LCItemUtil.Add_ComboBoxEx("ZONE", "区域:", 15, null, SubmitMethods));
  94. TryCachHelper.TryExecute((db) =>
  95. {
  96. var dtsex = db.Queryable<WCS_MAPPINGENTRY>().Where(v => v.MEP_MAPPINGTYPE == "ZONE").ToList();
  97. DataTable dt = new DataTable();
  98. DataRow dr;
  99. dt.Columns.Add("MEP_MAPPINGNO");
  100. dt.Columns.Add("MEP_MAPPINGCHNAME");
  101. for (int i = 0; i < dtsex.Count; i++)
  102. {
  103. dr = dt.NewRow();
  104. switch (dtsex[i].MEP_MAPPINGNO)
  105. {
  106. case 1:
  107. dr["MEP_MAPPINGNO"] = ".ADDRTO IN ('G1561','G1538','G1574','G1509')";
  108. break;
  109. case 2:
  110. dr["MEP_MAPPINGNO"] = ".ADDRFROM IN ('1157','1158')";
  111. break;
  112. case 3:
  113. dr["MEP_MAPPINGNO"] = ".ADDRFROM IN ('3052','3053','3005','3004')";
  114. break;
  115. case 4:
  116. dr["MEP_MAPPINGNO"] = ".ADDRFROM IN ('1028','1029')";
  117. break;
  118. case 5:
  119. dr["MEP_MAPPINGNO"] = ".ADDRFROM IN ('1386','1387','1435','1436')";
  120. break;
  121. case 6:
  122. dr["MEP_MAPPINGNO"] = ".ADDRTO IN ('G1340')";
  123. break;
  124. }
  125. dr["MEP_MAPPINGCHNAME"] = dtsex[i].MEP_MAPPINGCHNAME;
  126. dt.Rows.Add(dr);
  127. }
  128. LCItemUtil.Refresh_LCItem(LCIList[LCIList.Count - 1], dt, "MEP_MAPPINGNO", "MEP_MAPPINGCHNAME");
  129. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "t {0}" };
  130. });
  131. LCIList.Add(LCItemUtil.Add_ComboBoxEx("STATUS", "任务状态:", 15, null, SubmitMethods));
  132. TryCachHelper.TryExecute((db) =>
  133. {
  134. var dtsex = db.Queryable<WCS_MAPPINGENTRY>().Where(v => v.MEP_MAPPINGTYPE == "STATUS").ToList();
  135. DataTable dt = new DataTable();
  136. DataRow dr;
  137. dt.Columns.Add("MEP_MAPPINGNO");
  138. dt.Columns.Add("MEP_MAPPINGCHNAME");
  139. for (int i = 0; i < dtsex.Count; i++)
  140. {
  141. dr = dt.NewRow();
  142. dr["MEP_MAPPINGNO"] = dtsex[i].MEP_MAPPINGNO;
  143. dr["MEP_MAPPINGCHNAME"] = dtsex[i].MEP_MAPPINGCHNAME;
  144. dt.Rows.Add(dr);
  145. }
  146. LCItemUtil.Refresh_LCItem(LCIList[LCIList.Count - 1], dt, "MEP_MAPPINGNO", "MEP_MAPPINGCHNAME");
  147. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "t.STATUS like '%{0}%'" };
  148. });
  149. LCIList.Add(LCItemUtil.Add_ButtonX("btn_QDB", "查询", 100, 30, SubmitMethods));
  150. LCIList.Add(LCItemUtil.Add_ButtonX("btn_QClear", "重置", 100, 30, SubmitMethods));
  151. //if (CurrentHelper.User.Use_RoleId == 1)
  152. if (CurrentHelper.User.Use_Name == "超级管理员")
  153. {
  154. LCIList.Add(LCItemUtil.Add_ButtonX("btn_FinishTask", "手动完成任务", 100, 30, SubmitMethods));
  155. LCIList.Add(LCItemUtil.Add_ButtonX("btn_ClearTask", "取消任务", 100, 30, SubmitMethods));
  156. LCIList.Add(LCItemUtil.Add_ButtonX("btn_UpdatePriority", "修改优先级", 100, 30, SubmitMethods));
  157. LCIList.Add(LCItemUtil.Add_ButtonX("btn_RestartTask", "重新下发出库任务", 200, 30, SubmitMethods));
  158. }
  159. else
  160. {
  161. LCIList.Add(LCItemUtil.Add_ButtonX("btn_FinishTask", "手动完成任务", 100, 30, SubmitMethods));
  162. LCIList.Add(LCItemUtil.Add_ButtonX("btn_ClearTask", "取消任务", 100, 30, SubmitMethods));
  163. //LCIList.Add(LCItemUtil.Add_ButtonX("btn_UpdatePriority", "修改优先级", 100, 30, SubmitMethods));
  164. LCIList.Add(LCItemUtil.Add_ButtonX("btn_RestartTask", "重新下发出库任务", 200, 30, SubmitMethods));
  165. }
  166. uC_QueryPage1.Init_QueryPage(86, true, true, "", GCList, LCIList, QueryPageDataMethods, RefreshRoleMethods, null, null, ClikMethod);
  167. uC_QueryPage1.ClearLCItemValue();
  168. CommonShow.ShowProcessing("正在处理中,请稍候...", this, (obj) =>
  169. {
  170. uC_QueryPage1.RefreshData(1, 0);
  171. }, null);
  172. }
  173. //获取数据集
  174. private PageData QueryPageDataMethods(int PageIndex, int PageSize)
  175. {
  176. string _SQLText = @"select t.*,m.MEP_MAPPINGCHNAME task_comtypech,me.MEP_MAPPINGCHNAME task_wkstatusch,REPLACE(Position, 'Opp_205_', '') AS Position from dbo.WCS_TASK t
  177. left join WCS_MAPPINGENTRY m on t.TYPE = m.MEP_MAPPINGNO and m.MEP_MAPPINGTYPE = 'TYPE'
  178. left join WCS_MAPPINGENTRY me on t.STATUS = me.MEP_MAPPINGNO and me.MEP_MAPPINGTYPE = 'STATUS'
  179. left join WCS_AGVTask agv on agv.ID=t.AgvTask
  180. where 1=1 and t.STATUS < 99 ";
  181. string _Orderby = "CREATETIME desc ";
  182. PageData pd = BaseWorkflow.QueryPageData(_SQLText, _Orderby, uC_QueryPage1.GetQueryWhere(), PageIndex, PageSize);
  183. return pd;
  184. }
  185. /// <summary>
  186. /// 按钮触发事件
  187. /// </summary>
  188. /// <param name="LCName"></param>
  189. private void SubmitMethods(string LCName)
  190. {
  191. if (LCName == "btn_QDB")
  192. {
  193. uC_QueryPage1.RefreshData();
  194. }
  195. else if (LCName == "btn_RestartTask")
  196. {
  197. DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows();
  198. if (dt == null || dt.Rows.Count == 0)
  199. {
  200. MessageUtil.ShowTips("请选择任务。");
  201. return;
  202. }
  203. int task_no = Convert.ToInt32(dt.Rows[0]["ID"].ToString());
  204. var result = MessageUtil.ShowYesNoAndWarning(string.Format("任务[{0}]确定要重下出库任务吗(请谨慎操作)?", task_no));
  205. if (result == DialogResult.Yes)
  206. {
  207. string msg = BaseWorkflow.RestartTask(task_no);
  208. MessageUtil.ShowTips(msg);
  209. uC_QueryPage1.RefreshData(1, 0);
  210. }
  211. }
  212. else if (LCName == "btn_FinishTask")
  213. {
  214. DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows();
  215. if (dt == null || dt.Rows.Count == 0)
  216. {
  217. MessageUtil.ShowTips("请选择任务。");
  218. return;
  219. }
  220. int task_no = Convert.ToInt32(dt.Rows[0]["ID"].ToString());
  221. var result = MessageUtil.ShowYesNoAndWarning(string.Format("任务[{0}]确定要[手动完成任务]吗(请谨慎操作)?", task_no));
  222. if (result == DialogResult.Yes)
  223. {
  224. string msg = BaseWorkflow.FinishTask(task_no);
  225. MessageUtil.ShowTips(msg);
  226. uC_QueryPage1.RefreshData(1, 0);
  227. }
  228. }
  229. else if (LCName == "btn_ClearTask")
  230. {
  231. DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows();
  232. if (dt == null || dt.Rows.Count == 0)
  233. {
  234. MessageUtil.ShowTips("请选择任务。");
  235. return;
  236. }
  237. int task_no = Convert.ToInt32(dt.Rows[0]["ID"].ToString());
  238. var result = MessageUtil.ShowYesNoAndWarning(string.Format("任务[{0}]确定要[取消任务]吗(请谨慎操作)?", task_no));
  239. if (result == DialogResult.Yes)
  240. {
  241. string msg = BaseWorkflow.ClearTask(task_no);
  242. MessageUtil.ShowTips(msg);
  243. uC_QueryPage1.RefreshData(1, 0);
  244. }
  245. }
  246. else if (LCName == "btn_QClear")
  247. {
  248. uC_QueryPage1.ShowOpaqueLayer();
  249. uC_QueryPage1.ClearLCItemValue();
  250. uC_QueryPage1.RefreshData(1, 0);
  251. uC_QueryPage1.HideOpaqueLayer();
  252. }
  253. else if (LCName == "btn_CreateProInTask")
  254. {
  255. //FrmCreateTask frm = new FrmCreateTask();
  256. //frm.ShowDialog();
  257. uC_QueryPage1.RefreshData(1, 0);
  258. }
  259. else if (LCName == "btn_UpdateEndAddress")
  260. {
  261. DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows();
  262. if (dt == null || dt.Rows.Count == 0)
  263. {
  264. MessageUtil.ShowTips("请选择任务。");
  265. return;
  266. }
  267. DataRow dr = dt.Rows[0];
  268. string comtypech = dt.Rows[0]["task_comtypech"].ToString();
  269. if (comtypech.Contains("入库"))
  270. {
  271. var frmUpdateEndAddress = new FrmUpdateEndAddress(dr);
  272. frmUpdateEndAddress.ShowDialog();
  273. }
  274. else
  275. {
  276. MessageUtil.ShowTips("只有入库任务能变更目标地址。");
  277. }
  278. }
  279. else if (LCName == "btn_UpdatePriority")
  280. {
  281. DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows();
  282. if (dt == null || dt.Rows.Count == 0)
  283. {
  284. MessageUtil.ShowTips("请选择任务。");
  285. return;
  286. }
  287. //DataRow dr = dt.Rows[0];
  288. var frmUpdatePriority = new FrmUpdatePriority(dt);
  289. frmUpdatePriority.ShowDialog();
  290. uC_QueryPage1.RefreshData(1, 0);
  291. }
  292. }
  293. private void RefreshRoleMethods(bool ChkValue)
  294. {
  295. //if (AppConst.CheckExtentByName("查询任务"))
  296. //
  297. }
  298. private void ClikMethod(DataRow dr)
  299. {
  300. }
  301. private void uC_QueryPage1_Load(object sender, EventArgs e)
  302. {
  303. }
  304. private void uC_QueryPage1_DoubleClick(object sender, EventArgs e)
  305. {
  306. }
  307. }
  308. }