FormSet.cs 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471
  1. using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel;
  4. using System.Data;
  5. using System.Drawing;
  6. using System.Linq;
  7. using System.Text;
  8. using System.Threading.Tasks;
  9. using System.Windows.Forms;
  10. using Newtonsoft.Json.Linq;
  11. using WCS.Data.Models;
  12. using WCS_Client.UC;
  13. using WCS_Client;
  14. using WCS_Client.Utility;
  15. namespace WCS_Client.Frm.MBtn_Sys
  16. {
  17. public partial class FormSet : Form
  18. {
  19. public FormSet()
  20. {
  21. InitializeComponent();
  22. Init();
  23. }
  24. private void Init()
  25. {
  26. string result = TryCachHelper.TryExecute((db) =>
  27. {
  28. var sets = db.Queryable<WCS_SYSSET>().Where(v => v.SET_TYPE == "AgvDisable" || v.SET_TYPE == "MatureRoom").ToList();
  29. foreach (var item in sets)
  30. {
  31. if (item.SET_ID.Trim() == "Agv_4#")
  32. {
  33. if (item.SET_VALUE.Trim() == "0")
  34. {
  35. rdoBtn4RoomEnable.Checked = true;
  36. rdoBtn4RoomDisable.Checked = false;
  37. }
  38. else
  39. {
  40. rdoBtn4RoomEnable.Checked = false;
  41. rdoBtn4RoomDisable.Checked = true;
  42. }
  43. }
  44. else if (item.SET_ID.Trim() == "Agv_5#")
  45. {
  46. if (item.SET_VALUE.Trim() == "0")
  47. {
  48. rdoBtn5RoomEnable.Checked = true;
  49. rdoBtn5RoomDisable.Checked = false;
  50. }
  51. else
  52. {
  53. rdoBtn5RoomEnable.Checked = false;
  54. rdoBtn5RoomDisable.Checked = true;
  55. }
  56. }
  57. else if (item.SET_ID.Trim() == "Agv_6#")
  58. {
  59. if (item.SET_VALUE.Trim() == "0")
  60. {
  61. rdoBtn6RoomEnable.Checked = true;
  62. rdoBtn6RoomDisable.Checked = false;
  63. }
  64. else
  65. {
  66. rdoBtn6RoomEnable.Checked = false;
  67. rdoBtn6RoomDisable.Checked = true;
  68. }
  69. }
  70. else if (item.SET_ID.Trim() == "Agv_7#")
  71. {
  72. if (item.SET_VALUE.Trim() == "0")
  73. {
  74. rdoBtn7RoomEnable.Checked = true;
  75. rdoBtn7RoomDisable.Checked = false;
  76. }
  77. else
  78. {
  79. rdoBtn7RoomEnable.Checked = false;
  80. rdoBtn7RoomDisable.Checked = true;
  81. }
  82. }
  83. else if (item.SET_ID.Trim() == "Agv_18#")
  84. {
  85. if (item.SET_VALUE.Trim() == "0")
  86. {
  87. rdoBtn18RoomEnable.Checked = true;
  88. rdoBtn18RoomDisable.Checked = false;
  89. }
  90. else
  91. {
  92. rdoBtn18RoomEnable.Checked = false;
  93. rdoBtn18RoomDisable.Checked = true;
  94. }
  95. }
  96. else if (item.SET_ID.Trim() == "1508")
  97. {
  98. if (item.SET_VALUE.Trim() == "0")
  99. {
  100. rdoBtnMatureRAEnable.Checked = true;
  101. rdoBtnMRADisable.Checked = false;
  102. }
  103. else
  104. {
  105. rdoBtnMatureRAEnable.Checked = false;
  106. rdoBtnMRADisable.Checked = true;
  107. }
  108. }
  109. else if (item.SET_ID.Trim() == "1509")
  110. {
  111. if (item.SET_VALUE.Trim() == "0")
  112. {
  113. rdoBtnMatureRBEnable.Checked = true;
  114. rdoBtnMRBDisable.Checked = false;
  115. }
  116. else
  117. {
  118. rdoBtnMatureRBEnable.Checked = false;
  119. rdoBtnMRBDisable.Checked = true;
  120. }
  121. }
  122. }
  123. });
  124. }
  125. /// <summary>
  126. /// 获取入库任务
  127. /// </summary>
  128. /// <param name="param"></param>
  129. public void CreateInTask(GetInTaskParam param)
  130. {
  131. //WCS_TASK wcstask = null;
  132. //string result = TryCachHelper.TryExecute((db) => {
  133. // wcstask = db.Queryable<WCS_TASK>().First(v => v.TASK_BOXBARCODE == param.ContainerBarCode);
  134. // if (wcstask == null)
  135. // {
  136. // var reply = I_WCS_GetInTask(param);
  137. // if (reply.ResType)
  138. // {
  139. // //添加wcs任务
  140. // wcstask = new WCS_TASK();
  141. // wcstask.TASK_WMSNO = reply.WMSTaskNum;
  142. // wcstask.TASK_COMTYPE = reply.TaskType;
  143. // wcstask.TASK_SYSTYPE = "WMS";
  144. // wcstask.TASK_POSIDFROM = param.EquipmentNo;//起点地址
  145. // wcstask.TASK_POSIDCUR = param.EquipmentNo;
  146. // wcstask.TASK_POSIDNEXT = param.EquipmentNo;
  147. // wcstask.TASK_POSIDMOVE = "";
  148. // wcstask.TASK_PRIORITY = reply.Priority;
  149. // wcstask.TASK_WKSTATUS = 0;
  150. // wcstask.TASK_WHID = reply.WareHouseName;
  151. // wcstask.TASK_ADDUSERNO = "WMS";
  152. // wcstask.TASK_ADDDATETIME = DateTime.Now;
  153. // wcstask.TASK_EDITUSERNO = "WMS";
  154. // wcstask.TASK_EDITDATETIME = DateTime.Now;
  155. // wcstask.TASK_NOTES = "";
  156. // wcstask.TASK_RGVNO = "";
  157. // wcstask.TASK_BOXBARCODE = param.ContainerBarCode;
  158. // if (string.IsNullOrWhiteSpace(reply.TunnelNum))
  159. // {
  160. // wcstask.TASK_POSIDTO = reply.EndPostion;
  161. // wcstask.TASK_SRMNO = reply.EndPostion;
  162. // }
  163. // //else
  164. // //{
  165. // // wcstask.TASK_EndTunnelNum = ConveyorHelper.AssignSrm(param.EquipmentNo, reply.TunnelNum);
  166. // // wcstask.TASK_POSIDTO = wcstask.TASK_EndTunnelNum;
  167. // // wcstask.TASK_SRMNO = wcstask.TASK_EndTunnelNum;
  168. // //}
  169. // int id = db.Insertable(wcstask).ExecuteReturnIdentity();
  170. // if (id <= 0)
  171. // {
  172. // throw new Exception(string.Format("WMS任务[{0}]添加WCS任务失败", reply.WMSTaskNum));
  173. // }
  174. // else
  175. // {
  176. // wcstask.TASK_NO = id;
  177. // }
  178. // }
  179. // else
  180. // {
  181. // throw new Exception(reply.ResMessage);
  182. // }
  183. // }
  184. //});
  185. //if (string.IsNullOrWhiteSpace(result))
  186. //{
  187. // MessageBox.Show("添加空盘入库任务成功");
  188. //}
  189. //else
  190. //{
  191. // MessageBox.Show("添加空盘入库任务失败.原因:[{0}]", result);
  192. //}
  193. }
  194. public GetInTaskReply I_WCS_GetInTask(GetInTaskParam param)
  195. {
  196. GetInTaskReply reply = null;
  197. try
  198. {
  199. //Log4netHelper.Logger_Info.Info(string.Format("开始:WCS调用WMS接口函数I_WCS_GetInTask。参数:[{0}]", WebApiHelper.GetJson(param)));
  200. JArray ja = new JArray();
  201. ja.Add(WebApiHelper.GetJson(param));
  202. //调用MES接口
  203. JObject jobj = WebApiHelper.SendInfoToWebAPI("http://192.168.16.2:8081/api/Task/I_WCS_GetInTask", "", "Post", ja);
  204. reply = WebApiHelper.ParseFromJson<GetInTaskReply>(jobj.ToString());
  205. //Log4netHelper.Logger_Info.Info(string.Format("结束:WCS调用WMS接口函数I_WCS_GetInTask。参数:[{0}]反馈结果:[{1}]", WebApiHelper.GetJson(param), WebApiHelper.GetJson(reply)));
  206. }
  207. catch (Exception ex)
  208. {
  209. MessageBox.Show(ex.ToString());
  210. //Log4netHelper.Logger_Error.ErrorFormat(ex.ToString());
  211. }
  212. return reply;
  213. }
  214. private void btnSave_Click(object sender, EventArgs e)
  215. {
  216. if (CurrentHelper.User.Use_RoleId == 1)
  217. {
  218. string result = TryCachHelper.TryExecute((db) =>
  219. {
  220. var tasks = db.Queryable<Middle_AGVTask>().ToList();
  221. var sets = db.Queryable<WCS_SYSSET>().Where(v => v.SET_TYPE == "AgvDisable" || v.SET_TYPE == "MatureRoom").ToList();
  222. foreach (var item in sets)
  223. {
  224. if (item.SET_ID.Trim() == "Agv_4#")
  225. {
  226. if (rdoBtn4RoomEnable.Checked)
  227. {
  228. item.SET_VALUE = "0";
  229. }
  230. else if (rdoBtn4RoomDisable.Checked)
  231. {
  232. if (tasks.Any(v => v.Task_Workshop == item.SET_ID) && item.SET_VALUE != "1")
  233. {
  234. throw new Exception(string.Format("4车间当前存在AGV任务,请将任务执行完成,再禁用AGV。"));
  235. }
  236. else
  237. {
  238. item.SET_VALUE = "1";
  239. }
  240. }
  241. }
  242. else if (item.SET_ID.Trim() == "Agv_5#")
  243. {
  244. if (rdoBtn5RoomEnable.Checked)
  245. {
  246. item.SET_VALUE = "0";
  247. }
  248. else if (rdoBtn5RoomDisable.Checked)
  249. {
  250. if (tasks.Any(v => v.Task_Workshop == item.SET_ID) && item.SET_VALUE != "1")
  251. {
  252. throw new Exception(string.Format("5车间当前存在AGV任务,请将任务执行完成,再禁用AGV。"));
  253. }
  254. else
  255. {
  256. item.SET_VALUE = "1";
  257. }
  258. }
  259. }
  260. else if (item.SET_ID.Trim() == "Agv_6#")
  261. {
  262. if (rdoBtn6RoomEnable.Checked)
  263. {
  264. item.SET_VALUE = "0";
  265. }
  266. else if (rdoBtn6RoomDisable.Checked)
  267. {
  268. if (tasks.Any(v => v.Task_Workshop == item.SET_ID) && item.SET_VALUE != "1")
  269. {
  270. throw new Exception(string.Format("6车间当前存在AGV任务,请将任务执行完成,再禁用AGV。"));
  271. }
  272. else
  273. {
  274. item.SET_VALUE = "1";
  275. }
  276. }
  277. }
  278. else if (item.SET_ID.Trim() == "Agv_7#")
  279. {
  280. if (rdoBtn7RoomEnable.Checked)
  281. {
  282. item.SET_VALUE = "0";
  283. }
  284. else if (rdoBtn7RoomDisable.Checked)
  285. {
  286. if (tasks.Any(v => v.Task_Workshop == item.SET_ID) && item.SET_VALUE != "1")
  287. {
  288. throw new Exception(string.Format("7车间当前存在AGV任务,请将任务执行完成,再禁用AGV。"));
  289. }
  290. else
  291. {
  292. item.SET_VALUE = "1";
  293. }
  294. }
  295. }
  296. else if (item.SET_ID.Trim() == "Agv_18#")
  297. {
  298. if (rdoBtn18RoomEnable.Checked)
  299. {
  300. item.SET_VALUE = "0";
  301. }
  302. else if (rdoBtn18RoomDisable.Checked)
  303. {
  304. if (tasks.Any(v => v.Task_Workshop == item.SET_ID) && item.SET_VALUE != "1")
  305. {
  306. throw new Exception(string.Format("18车间当前存在AGV任务,请将任务执行完成,再禁用AGV。"));
  307. }
  308. else
  309. {
  310. item.SET_VALUE = "1";
  311. }
  312. }
  313. }
  314. else if (item.SET_ID.Trim() == "1508")
  315. {
  316. if (rdoBtnMatureRAEnable.Checked)
  317. {
  318. item.SET_VALUE = "0";
  319. }
  320. else if (rdoBtnMRADisable.Checked)
  321. {
  322. item.SET_VALUE = "1";
  323. }
  324. }
  325. else if (item.SET_ID.Trim() == "1509")
  326. {
  327. if (rdoBtnMatureRBEnable.Checked)
  328. {
  329. item.SET_VALUE = "0";
  330. }
  331. else if (rdoBtnMRBDisable.Checked)
  332. {
  333. item.SET_VALUE = "1";
  334. }
  335. }
  336. db.Updateable(item).UpdateColumns(it => it.SET_VALUE).ExecuteCommand();
  337. }
  338. });
  339. if (string.IsNullOrWhiteSpace(result))
  340. {
  341. Init();
  342. MessageUtil.ShowTips("配置修改成功。");
  343. }
  344. else
  345. {
  346. MessageUtil.ShowTips(string.Format("配置修改失败,原因[{0}]", result));
  347. }
  348. }
  349. else
  350. {
  351. MessageBox.Show("请悉知,该操作只有管理员权限才能进行更改!");
  352. }
  353. }
  354. //private void btnCreateOutInTask_Click(object sender, EventArgs e)
  355. //{
  356. // string barcode = string.Empty;
  357. // string loc_no = string.Empty;
  358. // string srmno = string.Empty;
  359. // string fromTunnelNum = string.Empty;
  360. // if (radioButton1.Checked)
  361. // {
  362. // loc_no = "AR-14-1-1-1";
  363. // barcode = "TPA00001";
  364. // srmno = "srm05";
  365. // fromTunnelNum = "6";
  366. // }
  367. // else if (radioButton2.Checked)
  368. // {
  369. // loc_no = "AR-12-1-1-1";
  370. // barcode = "TPA00005";
  371. // srmno = "srm04";
  372. // fromTunnelNum = "5";
  373. // }
  374. // if (radioButton3.Checked)
  375. // {
  376. // loc_no = "AR-15-1-1-1";
  377. // barcode = "TPA00006";
  378. // srmno = "srm05";
  379. // fromTunnelNum = "6";
  380. // }
  381. // else if (radioButton4.Checked)
  382. // {
  383. // loc_no = "AR-13-1-1-1";
  384. // barcode = "TPA00007";
  385. // srmno = "srm04";
  386. // fromTunnelNum = "5";
  387. // }
  388. // if (radioButton5.Checked)
  389. // {
  390. // loc_no = "AR-14-2-1-1";
  391. // barcode = "TPA00008";
  392. // srmno = "srm05";
  393. // fromTunnelNum = "6";
  394. // }
  395. // else if (radioButton6.Checked)
  396. // {
  397. // loc_no = "AR-15-2-1-1";
  398. // barcode = "TPA00009";
  399. // srmno = "srm05";
  400. // fromTunnelNum = "6";
  401. // }
  402. // if (string.IsNullOrWhiteSpace(barcode))
  403. // {
  404. // MessageUtil.ShowTips("请选择要生成环线任务的条码");
  405. // return;
  406. // }
  407. // WCS_TASK wcstask = null;
  408. // string result = TryCachHelper.TryExecute((db) =>
  409. // {
  410. // var task = db.Queryable<WCS_TASK>().First(v => v.TASK_BOXBARCODE == barcode);
  411. // if (task == null)
  412. // {
  413. // //添加wcs任务
  414. // wcstask = new WCS_TASK();
  415. // wcstask.TASK_WMSNO = barcode;
  416. // wcstask.TASK_COMTYPE = 2;
  417. // wcstask.TASK_SYSTYPE = "WMS";
  418. // wcstask.TASK_POSIDFROM = loc_no;
  419. // wcstask.TASK_POSIDCUR = loc_no;
  420. // wcstask.TASK_POSIDNEXT = loc_no;
  421. // wcstask.TASK_POSIDTO = "1117";
  422. // wcstask.TASK_POSIDMOVE = "";
  423. // wcstask.TASK_PRIORITY = 1;
  424. // wcstask.TASK_WKSTATUS = 0;
  425. // wcstask.TASK_WHID = "PVC原膜立库";
  426. // wcstask.TASK_SRMNO = srmno;
  427. // wcstask.TASK_ADDUSERNO = "WMS";
  428. // wcstask.TASK_ADDDATETIME = DateTime.Now;
  429. // wcstask.TASK_EDITUSERNO = "WMS";
  430. // wcstask.TASK_EDITDATETIME = DateTime.Now;
  431. // wcstask.TASK_NOTES = "";
  432. // wcstask.TASK_RGVNO = "";
  433. // wcstask.TASK_BOXBARCODE = barcode;
  434. // wcstask.TASK_FromTunnelNum = fromTunnelNum;
  435. // wcstask.TASK_ITEM2 = "2";
  436. // wcstask.TASK_ITEM3 = "1";
  437. // int id = db.Insertable(wcstask).ExecuteReturnIdentity();
  438. // if (id <= 0)
  439. // {
  440. // throw new Exception(string.Format("条码[{0}]添加WCS任务出库失败", barcode));
  441. // }
  442. // else
  443. // {
  444. // wcstask.TASK_NO = id;
  445. // }
  446. // }
  447. // else
  448. // {
  449. // throw new Exception(string.Format("条码[{0}]存在环线任务。", barcode));
  450. // }
  451. // });
  452. // if (string.IsNullOrWhiteSpace(result))
  453. // {
  454. // MessageUtil.ShowTips("添加环线任务成功");
  455. // }
  456. // else
  457. // {
  458. // MessageUtil.ShowError(string.Format("添加环线任务失败.原因:[{0}]", result));
  459. // }
  460. //}
  461. }
  462. }