MBtn_AgvTask.cs 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  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 MBtn_AgvTask : Form
  13. {
  14. private int wcs_task_no = 0;
  15. public MBtn_AgvTask()
  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("AGVID", "AGV任务号", 180),
  26. SuperGridUtil.Get_GridColumn("AgvTaskTypeCh", "任务类型", 80),
  27. SuperGridUtil.Get_GridColumn("StatusCh", "任务状态", 80),
  28. SuperGridUtil.Get_GridColumn("AgvStatusCh", "AGV任务状态", 100),
  29. SuperGridUtil.Get_GridColumn("Workshop", "车间", 80),
  30. SuperGridUtil.Get_GridColumn("Station", "站台地址", 100),
  31. SuperGridUtil.Get_GridColumn("Position", "起始地址", 80),
  32. SuperGridUtil.Get_GridColumn("CreateTime", "创建时间", 180),
  33. SuperGridUtil.Get_GridColumn("UpdateTime", "修改时间", 180),
  34. SuperGridUtil.Get_GridColumn("AGVUpdateTime", "AGV修改时间", 180),
  35. };
  36. List<LayoutControlItem> LCIList = new List<LayoutControlItem>();
  37. LCIList.Add(LCItemUtil.Add_TextboxX("ID", "ID:", 20, SubmitMethods, null));
  38. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.ID like '%{0}%'" };
  39. LCIList.Add(LCItemUtil.Add_TextboxX("AGVID", "AGV任务号:", 20, SubmitMethods, null));
  40. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.AGVID like '%{0}%'" }; ;
  41. LCIList.Add(LCItemUtil.Add_TextboxX("Position", "起始地址:", 20, SubmitMethods, null));
  42. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.Position like '%{0}%'" };
  43. LCIList.Add(LCItemUtil.Add_TextboxX("Station", "站台地址:", 20, SubmitMethods, null));
  44. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.Station like '%{0}%'" };
  45. LCIList.Add(LCItemUtil.Add_TextboxX("Workshop", "车间:", 20, SubmitMethods, null));
  46. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.Workshop like '%{0}%'" };
  47. LCIList.Add(LCItemUtil.Add_ComboBoxEx("TaskType", "任务类型:", 20, null, SubmitMethods));
  48. TryCachHelper.TryExecute((db) =>
  49. {
  50. var dtsex = db.Queryable<WCS_MAPPINGENTRY>().Where(v => v.MEP_MAPPINGTYPE == "TaskType").ToList();
  51. DataTable dt = new DataTable();
  52. DataRow dr;
  53. dt.Columns.Add("MEP_MAPPINGNO");
  54. dt.Columns.Add("MEP_MAPPINGCHNAME");
  55. for (int i = 0; i < dtsex.Count; i++)
  56. {
  57. dr = dt.NewRow();
  58. dr["MEP_MAPPINGNO"] = dtsex[i].MEP_MAPPINGNO;
  59. dr["MEP_MAPPINGCHNAME"] = dtsex[i].MEP_MAPPINGCHNAME;
  60. dt.Rows.Add(dr);
  61. }
  62. LCItemUtil.Refresh_LCItem(LCIList[LCIList.Count - 1], dt, "MEP_MAPPINGNO", "MEP_MAPPINGCHNAME");
  63. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.TaskType like '%{0}%'" };
  64. });
  65. LCIList.Add(LCItemUtil.Add_ComboBoxEx("AGVStatus", "任务状态:", 20, null, SubmitMethods));
  66. TryCachHelper.TryExecute((db) =>
  67. {
  68. var dtsex = db.Queryable<WCS_MAPPINGENTRY>().Where(v => v.MEP_MAPPINGTYPE == "AGVStatus").ToList();
  69. DataTable dt = new DataTable();
  70. DataRow dr;
  71. dt.Columns.Add("MEP_MAPPINGNO");
  72. dt.Columns.Add("MEP_MAPPINGCHNAME");
  73. for (int i = 0; i < dtsex.Count; i++)
  74. {
  75. dr = dt.NewRow();
  76. dr["MEP_MAPPINGNO"] = dtsex[i].MEP_MAPPINGNO;
  77. dr["MEP_MAPPINGCHNAME"] = dtsex[i].MEP_MAPPINGCHNAME;
  78. dt.Rows.Add(dr);
  79. }
  80. LCItemUtil.Refresh_LCItem(LCIList[LCIList.Count - 1], dt, "MEP_MAPPINGNO", "MEP_MAPPINGCHNAME");
  81. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.STATUS like '%{0}%'" };
  82. });
  83. LCIList.Add(LCItemUtil.Add_ButtonX("btn_QDB", "查询", 80, 30, SubmitMethods));
  84. LCIList.Add(LCItemUtil.Add_ButtonX("btn_QClear", "重置", 80, 30, SubmitMethods));
  85. if (CurrentHelper.User.Use_RoleId == 1)
  86. {
  87. LCIList.Add(LCItemUtil.Add_ButtonX("btn_CancelAgvTask", "AGV任务取消", 100, 30, SubmitMethods));
  88. LCIList.Add(LCItemUtil.Add_ButtonX("btn_FinishAgvTask", "AGV任务完成", 100, 30, SubmitMethods));
  89. //LCIList.Add(LCItemUtil.Add_ButtonX("btn_CancelAgvTask_F", "允许放货", 100, 30, SubmitMethods));
  90. //LCIList.Add(LCItemUtil.Add_ButtonX("btn_CancelAgvTask_F", "允许放货", 100, 30, SubmitMethods));
  91. //LCIList.Add(LCItemUtil.Add_ButtonX("btn_CMBYWorkShop", "车间叫料", 100, 30, SubmitMethods));
  92. }
  93. uC_QueryPage1.Init_QueryPage(60, true, true, "", GCList, LCIList, QueryPageDataMethods, RefreshRoleMethods, DoubleClikMethod, null, null);
  94. uC_QueryPage1.ClearLCItemValue();
  95. CommonShow.ShowProcessing("正在处理中,请稍候...", this, (obj) =>
  96. {
  97. uC_QueryPage1.RefreshData(1, 0);
  98. }, null);
  99. }
  100. private PageData QueryPageDataMethods(int PageIndex, int PageSize)
  101. {
  102. string _SQLText = @"SELECT a.*,b.MEP_MAPPINGCHNAME AgvTaskTypeCh,c.MEP_MAPPINGCHNAME StatusCh,d.MEP_MAPPINGCHNAME AgvStatusCh FROM dbo.WCS_AGVTask a
  103. left join dbo.WCS_MAPPINGENTRY b on a.TaskType=b.MEP_MAPPINGNO and b.MEP_MAPPINGTYPE='TaskType'
  104. left join dbo.WCS_MAPPINGENTRY c on a.Status=c.MEP_MAPPINGNO and c.MEP_MAPPINGTYPE='AGVStatus'
  105. left join dbo.WCS_MAPPINGENTRY d on a.AGVStatus=d.MEP_MAPPINGNO and d.MEP_MAPPINGTYPE='AGVStatus' Where 1=1 and Status < (case when b.MEP_MAPPINGCHNAME='入库' then 100 else 99 end) ";
  106. string _Orderby = "a.CreateTime desc";
  107. PageData pd = BaseWorkflow.QueryPageData(_SQLText, _Orderby, uC_QueryPage1.GetQueryWhere(), PageIndex, PageSize);
  108. return pd;
  109. }
  110. private void SubmitMethods(string LCName)
  111. {
  112. //查询
  113. if (LCName == "btn_QDB")
  114. {
  115. uC_QueryPage1.RefreshData();
  116. }
  117. //清除
  118. else if (LCName == "btn_QClear")
  119. {
  120. uC_QueryPage1.ShowOpaqueLayer();
  121. uC_QueryPage1.ClearLCItemValue();
  122. uC_QueryPage1.RefreshData(1, 0);
  123. uC_QueryPage1.HideOpaqueLayer();
  124. }
  125. else if (LCName == "btn_SendAgv")
  126. {
  127. DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows();
  128. if (dt == null || dt.Rows.Count == 0)
  129. {
  130. MessageUtil.ShowTips("请选择任务。");
  131. return;
  132. }
  133. int id = Convert.ToInt32(dt.Rows[0]["Task_Id"].ToString());
  134. var result = MessageUtil.ShowYesNoAndWarning(string.Format("id[{0}]的任务确定要重下吗(请谨慎操作)?", id));
  135. if (result == DialogResult.Yes)
  136. {
  137. string msg = TryCachHelper.TryExecute((db) =>
  138. {
  139. string out_id = id.ToString();
  140. //var wcstask = db.Queryable<WCS_TASK>().First(v => v.TASK_ITEM8 == out_id);
  141. //if (wcstask == null)
  142. //{
  143. // throw new Exception(string.Format("AGV任务ID[{0}]未查询到对应的WMS任务", out_id));
  144. //}
  145. var agvtask = db.Queryable<Middle_AGVTask>().First(v => v.Task_Id == id);
  146. agvtask.Task_WcsStatus = 1;
  147. agvtask.Task_AgvStatus = 0;
  148. db.Updateable(agvtask).UpdateColumns(it => new { it.Task_WcsStatus, it.Task_AgvStatus }).ExecuteCommand();
  149. });
  150. if (string.IsNullOrWhiteSpace(msg)) msg = string.Format("ID[{0}]任务重下成功", id);
  151. MessageUtil.ShowTips(msg);
  152. uC_QueryPage1.RefreshData(1, 0);
  153. }
  154. }
  155. //取消任务
  156. else if (LCName == "btn_CancelAgvTask")
  157. {
  158. DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows();
  159. if (dt == null || dt.Rows.Count == 0)
  160. {
  161. MessageUtil.ShowTips("请选择任务。");
  162. return;
  163. }
  164. int id = Convert.ToInt32(dt.Rows[0]["ID"].ToString());
  165. var result = MessageUtil.ShowYesNoAndWarning(string.Format("id[{0}]的任务确定要取消吗(请谨慎操作)?", id));
  166. if (result == DialogResult.Yes)
  167. {
  168. string msg = TryCachHelper.TryExecute((db) =>
  169. {
  170. var agvtask = db.Queryable<WCS_AGVTask>().First(v => v.ID == id);
  171. if (agvtask.Status == Frm.AGVTaskStatus.新建)
  172. {
  173. agvtask.Status = Frm.AGVTaskStatus.取消;
  174. db.Updateable(agvtask).UpdateColumns(it => new { it.Status }).ExecuteCommand();
  175. }
  176. else
  177. {
  178. throw new Exception("该类型任务(或非初始状态)暂时不支持取消动作。");
  179. }
  180. });
  181. if (string.IsNullOrWhiteSpace(msg)) msg = string.Format("ID[{0}]任务取消成功", id);
  182. MessageUtil.ShowTips(msg);
  183. uC_QueryPage1.RefreshData(1, 0);
  184. }
  185. }
  186. //完成任务
  187. else if (LCName == "btn_FinishAgvTask")
  188. {
  189. DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows();
  190. if (dt == null || dt.Rows.Count == 0)
  191. {
  192. MessageUtil.ShowTips("请选择任务。");
  193. return;
  194. }
  195. int id = Convert.ToInt32(dt.Rows[0]["ID"].ToString());
  196. var result = MessageUtil.ShowYesNoAndWarning(string.Format("id[{0}]的任务要手动完成吗(请谨慎操作)?", id));
  197. if (result == DialogResult.Yes)
  198. {
  199. string msg = TryCachHelper.TryExecute((db) =>
  200. {
  201. var agvtask = db.Queryable<WCS_AGVTask>().First(v => v.ID == id);
  202. if (agvtask.TaskType == AGVTaskType.入库)
  203. {
  204. agvtask.Status = AGVTaskStatus.完成扫码;
  205. agvtask.AGVStatus = AGVTaskStatus.完成扫码;
  206. }
  207. else
  208. {
  209. agvtask.Status = AGVTaskStatus.完成;
  210. agvtask.AGVStatus = AGVTaskStatus.完成;
  211. }
  212. agvtask.UpdateTime = DateTime.Now;
  213. db.Updateable(agvtask).UpdateColumns(it => new { it.Status, it.AGVStatus, it.UpdateTime }).ExecuteCommand();
  214. });
  215. if (string.IsNullOrWhiteSpace(msg)) msg = string.Format("ID[{0}]手动完成成功", id);
  216. MessageUtil.ShowTips(msg);
  217. uC_QueryPage1.RefreshData(1, 0);
  218. }
  219. }
  220. else if (LCName == "btn_CMBYWorkShop")
  221. {
  222. var frmCMByWorkShop = new FrmCMByWorkShop();
  223. frmCMByWorkShop.ShowDialog();
  224. uC_QueryPage1.RefreshData(1, 0);
  225. }
  226. }
  227. private void DoubleClikMethod(DataRow dr)
  228. {
  229. //wcs_task_no = Convert.ToInt32(dr["TASK_NO"].ToString());
  230. //FrmWCS_TaskDIS_DTL Frm = new FrmWCS_TaskDIS_DTL(wcs_task_no);
  231. //Frm.Show();
  232. }
  233. private void RefreshRoleMethods(bool ChkValue)
  234. {
  235. }
  236. }
  237. }