MBtn_AgvTask.cs 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378
  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 MBtn_AgvTask : Form
  19. {
  20. int wcs_task_no = 0;
  21. public MBtn_AgvTask()
  22. {
  23. InitializeComponent();
  24. InitFrm();
  25. }
  26. private void InitFrm()
  27. {
  28. List<GridColumn> GCList = new List<GridColumn>()
  29. {
  30. SuperGridUtil.Get_GridColumn("Task_Id", "ID", 80),
  31. SuperGridUtil.Get_GridColumn("Task_AgvNo", "Agv任务号", 100),
  32. SuperGridUtil.Get_GridColumn("Task_Remark", "WCS任务号", 80),
  33. SuperGridUtil.Get_GridColumn("Task_No", "WMS任务号", 80),
  34. SuperGridUtil.Get_GridColumn("AgvTaskTypeCh", "任务类型", 100),
  35. SuperGridUtil.Get_GridColumn("Task_Whid", "仓库", 80),
  36. SuperGridUtil.Get_GridColumn("Task_BreakTrayNo", "条码", 100),
  37. SuperGridUtil.Get_GridColumn("Task_BreakBarCode_1", "退料条码1", 80),
  38. SuperGridUtil.Get_GridColumn("Task_BreakBarCode_2", "退料条码2", 80),
  39. SuperGridUtil.Get_GridColumn("Task_WorkshopNo", "车间", 80),
  40. SuperGridUtil.Get_GridColumn("Task_ProLineNo", "生产线", 80),
  41. SuperGridUtil.Get_GridColumn("Task_PosidFrom", "上料点", 120),
  42. SuperGridUtil.Get_GridColumn("Task_PosidTo", "下料点", 120),
  43. SuperGridUtil.Get_GridColumn("AgvStatusCh", "Agv状态", 100),
  44. SuperGridUtil.Get_GridColumn("WcsStatusCh", "Wcs状态", 100),
  45. SuperGridUtil.Get_GridColumn("Task_CreateUser", "创建用户", 80),
  46. SuperGridUtil.Get_GridColumn("Task_CreateDate", "创建时间", 150),
  47. SuperGridUtil.Get_GridColumn("Task_UpdateUser", "修改用户", 80),
  48. SuperGridUtil.Get_GridColumn("Task_UpdateDate", "修改时间", 150)
  49. };
  50. List<LayoutControlItem> LCIList = new List<LayoutControlItem>();
  51. LCIList.Add(LCItemUtil.Add_TextboxX("Task_Id", "ID:", 20, SubmitMethods, null));
  52. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.Task_Id like '%{0}%'" };
  53. LCIList.Add(LCItemUtil.Add_TextboxX("TASK_NO", "WCS任务号:", 20, SubmitMethods, null));
  54. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.Task_Remark like '%{0}%'" };
  55. LCIList.Add(LCItemUtil.Add_TextboxX("TASK_WMSNO", "WMS任务号:", 20, SubmitMethods, null));
  56. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.Task_No like '%{0}%'" };
  57. LCIList.Add(LCItemUtil.Add_TextboxX("TASK_BOXBARCODE", "条码:", 20, SubmitMethods, null));
  58. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.Task_BreakTrayNo like '%{0}%'" };
  59. LCIList.Add(LCItemUtil.Add_TextboxX("TASK_POSIDFROM", "起始地址:", 20, SubmitMethods, null));
  60. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.TASK_POSIDFROM like '%{0}%'" };
  61. LCIList.Add(LCItemUtil.Add_TextboxX("TASK_POSIDTO", "目标地址:", 20, SubmitMethods, null));
  62. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.TASK_POSIDTO like '%{0}%'" };
  63. LCIList.Add(LCItemUtil.Add_TextboxX("TASK_WHID", "仓库:", 20, SubmitMethods, null));
  64. LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.Task_Whid like '%{0}%'" };
  65. //LCIList.Add(LCItemUtil.Add_ComboBoxEx("Task_ComType", "任务类型:", 20, null, SubmitMethods));
  66. //TryCachHelper.TryExecute((db) =>
  67. //{
  68. // var dtsex = db.Queryable<WCS_DICTIONARY>().Where(v => v.DIC_PARENT_CODE == "TaskType").ToList();
  69. // DataTable dt = new DataTable();
  70. // DataRow dr;
  71. // dt.Columns.Add("DIC_SORT");
  72. // dt.Columns.Add("DIC_NAME");
  73. // for (int i = 0; i < dtsex.Count; i++)
  74. // {
  75. // dr = dt.NewRow();
  76. // dr["DIC_SORT"] = dtsex[i].DIC_SORT;
  77. // dr["DIC_NAME"] = dtsex[i].DIC_NAME;
  78. // dt.Rows.Add(dr);
  79. // }
  80. // LCItemUtil.Refresh_LCItem(LCIList[LCIList.Count - 1], dt, "DIC_SORT", "DIC_NAME");
  81. // LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "TASK_COMTYPE like '%{0}%'" };
  82. //});
  83. //LCIList.Add(LCItemUtil.Add_ComboBoxEx("task_wkstatusch", "任务状态:", 20, null, SubmitMethods));
  84. //TryCachHelper.TryExecute((db) =>
  85. //{
  86. // var dtsex = db.Queryable<WCS_DICTIONARY>().Where(v => v.DIC_PARENT_CODE == "TaskStatus").ToList();
  87. // DataTable dt = new DataTable();
  88. // DataRow dr;
  89. // dt.Columns.Add("DIC_SORT");
  90. // dt.Columns.Add("DIC_NAME");
  91. // for (int i = 0; i < dtsex.Count; i++)
  92. // {
  93. // dr = dt.NewRow();
  94. // dr["DIC_SORT"] = dtsex[i].DIC_SORT;
  95. // dr["DIC_NAME"] = dtsex[i].DIC_NAME;
  96. // dt.Rows.Add(dr);
  97. // }
  98. // LCItemUtil.Refresh_LCItem(LCIList[LCIList.Count - 1], dt, "DIC_SORT", "DIC_NAME");
  99. // LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "TASK_WKSTATUS like '%{0}%'" };
  100. //});
  101. LCIList.Add(LCItemUtil.Add_ButtonX("btn_QDB", "查询", 80, 30, SubmitMethods));
  102. LCIList.Add(LCItemUtil.Add_ButtonX("btn_QClear", "重置", 80, 30, SubmitMethods));
  103. if (CurrentHelper.User.Use_RoleId == 1)
  104. {
  105. LCIList.Add(LCItemUtil.Add_ButtonX("btn_SendAgv", "AGV任务重下", 100, 30, SubmitMethods));
  106. LCIList.Add(LCItemUtil.Add_ButtonX("btn_CancelAgvTask", "AGV任务取消", 100, 30, SubmitMethods));
  107. LCIList.Add(LCItemUtil.Add_ButtonX("btn_FinishAgvTask", "AGV任务完成", 100, 30, SubmitMethods));
  108. LCIList.Add(LCItemUtil.Add_ButtonX("btn_UpdateStatus_F", "允许放货", 100, 30, SubmitMethods));
  109. LCIList.Add(LCItemUtil.Add_ButtonX("btn_UpdateStatus_Q", "允许取货", 100, 30, SubmitMethods));
  110. LCIList.Add(LCItemUtil.Add_ButtonX("btn_UpdateStatus_L", "允许离开", 100, 30, SubmitMethods));
  111. LCIList.Add(LCItemUtil.Add_ButtonX("btn_CallWorkShopTask", "车间叫料", 100, 30, SubmitMethods));
  112. }
  113. uC_QueryPage1.Init_QueryPage(60, true, true, "", GCList, LCIList, QueryPageDataMethods, RefreshRoleMethods, DoubleClikMethod, null, null);
  114. uC_QueryPage1.ClearLCItemValue();
  115. CommonShow.ShowProcessing("正在处理中,请稍候...", this, (obj) =>
  116. {
  117. uC_QueryPage1.RefreshData(1, 0);
  118. }, null);
  119. }
  120. private PageData QueryPageDataMethods(int PageIndex, int PageSize)
  121. {
  122. string _SQLText = @"SELECT a.*,b.DIC_NAME AgvTaskTypeCh,c.DIC_NAME AgvStatusCh,d.DIC_NAME WcsStatusCh
  123. FROM [YONGGUAN_WCS].[dbo].[Middle_AGVTask] a
  124. left join dbo.WCS_DICTIONARY b on a.Task_Type=b.DIC_SORT and b.DIC_PARENT_CODE='AgvTaskType'
  125. left join dbo.WCS_DICTIONARY c on a.Task_AgvStatus=c.DIC_SORT and c.DIC_PARENT_CODE='AgvStatus'
  126. left join dbo.WCS_DICTIONARY d on a.Task_WcsStatus=d.DIC_SORT and d.DIC_PARENT_CODE='WcsStatus'
  127. where Task_Whid in('PVC原膜立库','PVC普通立库')";
  128. string _Orderby = "a.Task_Id asc";
  129. PageData pd = BaseWorkflow.QueryPageData(_SQLText, _Orderby, uC_QueryPage1.GetQueryWhere(), PageIndex, PageSize);
  130. return pd;
  131. }
  132. private void SubmitMethods(string LCName)
  133. {
  134. if (LCName == "btn_QDB")
  135. {
  136. uC_QueryPage1.RefreshData();
  137. }
  138. else if (LCName == "btn_QClear")
  139. {
  140. uC_QueryPage1.ShowOpaqueLayer();
  141. uC_QueryPage1.ClearLCItemValue();
  142. uC_QueryPage1.RefreshData(1, 0);
  143. uC_QueryPage1.HideOpaqueLayer();
  144. }
  145. else if (LCName == "btn_SendAgv")
  146. {
  147. DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows();
  148. if (dt == null || dt.Rows.Count == 0)
  149. {
  150. MessageUtil.ShowTips("请选择任务。");
  151. return;
  152. }
  153. int id = Convert.ToInt32(dt.Rows[0]["Task_Id"].ToString());
  154. var result = MessageUtil.ShowYesNoAndWarning(string.Format("id[{0}]的任务确定要重下吗(请谨慎操作)?", id));
  155. if (result == DialogResult.Yes)
  156. {
  157. string msg = TryCachHelper.TryExecute((db) =>
  158. {
  159. string out_id = id.ToString();
  160. var wcstask = db.Queryable<WCS_TASK>().First(v => v.TASK_ITEM8 == out_id);
  161. if (wcstask == null)
  162. {
  163. throw new Exception(string.Format("AGV任务ID[{0}]未查询到对应的WMS任务", out_id));
  164. }
  165. var agvtask = db.Queryable<Middle_AGVTask>().First(v => v.Task_Id == id);
  166. agvtask.Task_WcsStatus = 1;
  167. agvtask.Task_AgvStatus = 0;
  168. db.Updateable(agvtask).UpdateColumns(it => new { it.Task_WcsStatus, it.Task_AgvStatus }).ExecuteCommand();
  169. });
  170. if (string.IsNullOrWhiteSpace(msg)) msg = string.Format("ID[{0}]任务重下成功", id);
  171. MessageUtil.ShowTips(msg);
  172. uC_QueryPage1.RefreshData(1, 0);
  173. }
  174. }
  175. else if (LCName == "btn_CancelAgvTask")
  176. {
  177. DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows();
  178. if (dt == null || dt.Rows.Count == 0)
  179. {
  180. MessageUtil.ShowTips("请选择任务。");
  181. return;
  182. }
  183. int id = Convert.ToInt32(dt.Rows[0]["Task_Id"].ToString());
  184. var result = MessageUtil.ShowYesNoAndWarning(string.Format("id[{0}]的任务确定要取消吗(请谨慎操作)?", id));
  185. if (result == DialogResult.Yes)
  186. {
  187. string msg = TryCachHelper.TryExecute((db) =>
  188. {
  189. var agvtask = db.Queryable<Middle_AGVTask>().First(v => v.Task_Id == id);
  190. if (agvtask.Task_Type == 1 && agvtask.Task_WcsStatus == 0 && agvtask.Task_AgvStatus == 0)
  191. {
  192. string agvid = id.ToString();
  193. if (db.Queryable<WCS_TASK>().Any(v => v.TASK_ITEM8 == agvid) == false)
  194. {
  195. agvtask.Task_WcsStatus = 106;
  196. db.Updateable(agvtask).UpdateColumns(it => new { it.Task_WcsStatus }).ExecuteCommand();
  197. }
  198. else
  199. {
  200. throw new Exception("该任务存在WCS任务,暂时不支持取消动作。");
  201. }
  202. }
  203. else if (agvtask.Task_Type == 2 && agvtask.Task_WcsStatus == 0 && agvtask.Task_AgvStatus == 0)
  204. {
  205. string agvid = id.ToString();
  206. if (db.Queryable<WCS_TASK>().Any(v => v.TASK_ITEM8 == agvid) == false)
  207. {
  208. agvtask.Task_WcsStatus = 106;
  209. db.Updateable(agvtask).UpdateColumns(it => new { it.Task_WcsStatus }).ExecuteCommand();
  210. }
  211. else
  212. {
  213. throw new Exception("该任务存在WCS任务,暂时不支持取消动作。");
  214. }
  215. }
  216. else if (agvtask.Task_Type == 4 && agvtask.Task_WcsStatus == 0 && agvtask.Task_AgvStatus == 0)
  217. {
  218. agvtask.Task_WcsStatus = 106;
  219. db.Updateable(agvtask).UpdateColumns(it => new { it.Task_WcsStatus }).ExecuteCommand();
  220. }
  221. else
  222. {
  223. throw new Exception("该类型任务(或非初始状态)暂时不支持取消动作。");
  224. }
  225. });
  226. if (string.IsNullOrWhiteSpace(msg)) msg = string.Format("ID[{0}]任务取消成功", id);
  227. MessageUtil.ShowTips(msg);
  228. uC_QueryPage1.RefreshData(1, 0);
  229. }
  230. }
  231. else if (LCName == "btn_FinishAgvTask")
  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. int id = Convert.ToInt32(dt.Rows[0]["Task_Id"].ToString());
  240. var result = MessageUtil.ShowYesNoAndWarning(string.Format("id[{0}]的任务要手动完成吗(请谨慎操作)?", id));
  241. if (result == DialogResult.Yes)
  242. {
  243. string msg = TryCachHelper.TryExecute((db) =>
  244. {
  245. var agvtask = db.Queryable<Middle_AGVTask>().First(v => v.Task_Id == id);
  246. agvtask.Task_WcsStatus = 99;
  247. agvtask.Task_UpdateUser = "wcs";
  248. agvtask.Task_UpdateDate = DateTime.Now;
  249. db.Updateable(agvtask).UpdateColumns(it => new { it.Task_WcsStatus, it.Task_UpdateUser, it.Task_UpdateDate }).ExecuteCommand();
  250. });
  251. if (string.IsNullOrWhiteSpace(msg)) msg = string.Format("ID[{0}]手动完成成功", id);
  252. MessageUtil.ShowTips(msg);
  253. uC_QueryPage1.RefreshData(1, 0);
  254. }
  255. }
  256. else if (LCName == "btn_UpdateStatus_F")
  257. {
  258. DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows();
  259. if (dt == null || dt.Rows.Count == 0)
  260. {
  261. MessageUtil.ShowTips("请选择任务。");
  262. return;
  263. }
  264. int id = Convert.ToInt32(dt.Rows[0]["Task_Id"].ToString());
  265. var result = MessageUtil.ShowYesNoAndWarning(string.Format("id[{0}]的任务确定要修改状态为允许放货吗(请谨慎操作)?", id));
  266. if (result == DialogResult.Yes)
  267. {
  268. string msg = TryCachHelper.TryExecute((db) =>
  269. {
  270. var agvtask = db.Queryable<Middle_AGVTask>().First(v => v.Task_Id == id);
  271. if (agvtask.Task_AgvStatus == 2)
  272. {
  273. agvtask.Task_WcsStatus = 2;
  274. db.Updateable(agvtask).UpdateColumns(it => new { it.Task_WcsStatus }).ExecuteCommand();
  275. }
  276. else
  277. {
  278. throw new Exception("该类型的AGV状态不为请求放货(2)暂时不支持更为允许放货,请检查!。");
  279. }
  280. });
  281. if (string.IsNullOrWhiteSpace(msg)) msg = string.Format("ID[{0}]任务AGV状态修改成功!", id);
  282. MessageUtil.ShowTips(msg);
  283. uC_QueryPage1.RefreshData(1, 0);
  284. }
  285. }
  286. else if (LCName == "btn_UpdateStatus_Q")
  287. {
  288. DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows();
  289. if (dt == null || dt.Rows.Count == 0)
  290. {
  291. MessageUtil.ShowTips("请选择任务。");
  292. return;
  293. }
  294. int id = Convert.ToInt32(dt.Rows[0]["Task_Id"].ToString());
  295. var result = MessageUtil.ShowYesNoAndWarning(string.Format("id[{0}]的任务确定要修改状态为允许取货吗(请谨慎操作)?", id));
  296. if (result == DialogResult.Yes)
  297. {
  298. string msg = TryCachHelper.TryExecute((db) =>
  299. {
  300. var agvtask = db.Queryable<Middle_AGVTask>().First(v => v.Task_Id == id);
  301. if (agvtask.Task_AgvStatus == 4)
  302. {
  303. agvtask.Task_WcsStatus = 3;
  304. db.Updateable(agvtask).UpdateColumns(it => new { it.Task_WcsStatus }).ExecuteCommand();
  305. }
  306. else
  307. {
  308. throw new Exception("该类型的AGV状态不为请求取货(4)暂时不支持更为允许取货,请检查!。");
  309. }
  310. });
  311. if (string.IsNullOrWhiteSpace(msg)) msg = string.Format("ID[{0}]任务AGV状态修改成功!", id);
  312. MessageUtil.ShowTips(msg);
  313. uC_QueryPage1.RefreshData(1, 0);
  314. }
  315. }
  316. else if (LCName == "btn_UpdateStatus_L")
  317. {
  318. DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows();
  319. if (dt == null || dt.Rows.Count == 0)
  320. {
  321. MessageUtil.ShowTips("请选择任务。");
  322. return;
  323. }
  324. int id = Convert.ToInt32(dt.Rows[0]["Task_Id"].ToString());
  325. var result = MessageUtil.ShowYesNoAndWarning(string.Format("id[{0}]的任务确定要修改状态为允许离开吗(请谨慎操作)?", id));
  326. if (result == DialogResult.Yes)
  327. {
  328. string msg = TryCachHelper.TryExecute((db) =>
  329. {
  330. var agvtask = db.Queryable<Middle_AGVTask>().First(v => v.Task_Id == id);
  331. if (agvtask.Task_AgvStatus == 5)
  332. {
  333. agvtask.Task_WcsStatus = 4;
  334. db.Updateable(agvtask).UpdateColumns(it => new { it.Task_WcsStatus }).ExecuteCommand();
  335. }
  336. else
  337. {
  338. throw new Exception("该类型的AGV状态不为取货完成(5)暂时不支持更为允许离开,请检查!。");
  339. }
  340. });
  341. if (string.IsNullOrWhiteSpace(msg)) msg = string.Format("ID[{0}]任务AGV状态修改成功!", id);
  342. MessageUtil.ShowTips(msg);
  343. uC_QueryPage1.RefreshData(1, 0);
  344. }
  345. }
  346. else if (LCName == "btn_CallWorkShopTask")
  347. {
  348. var frmAddWorkshopTask = new FrmAddWorkshopTask();
  349. frmAddWorkshopTask.ShowDialog();
  350. uC_QueryPage1.RefreshData(1, 0);
  351. }
  352. }
  353. private void DoubleClikMethod(DataRow dr)
  354. {
  355. //wcs_task_no = Convert.ToInt32(dr["TASK_NO"].ToString());
  356. //FrmWCS_TaskDIS_DTL Frm = new FrmWCS_TaskDIS_DTL(wcs_task_no);
  357. //Frm.Show();
  358. }
  359. private void RefreshRoleMethods(bool ChkValue)
  360. {
  361. }
  362. }
  363. }