FormSet.cs 20 KB

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