Form_SystemSet.cs 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331
  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 WCS_Client.Models;
  11. namespace WCS_Client.From
  12. {
  13. public partial class Form_SystemSet : Form
  14. {
  15. public Form_SystemSet()
  16. {
  17. InitializeComponent();
  18. Init();
  19. }
  20. private static Form_SystemSet childFromInstanc;
  21. public static Form_SystemSet ChildFromInstanc
  22. {
  23. get
  24. {
  25. if (childFromInstanc == null || childFromInstanc.IsDisposed)
  26. {
  27. childFromInstanc = new Form_SystemSet();
  28. }
  29. return childFromInstanc;
  30. }
  31. }
  32. private void Init()
  33. {
  34. TryCachHelper.TryExecute((db) =>
  35. {
  36. var wcs_sysset = db.Queryable<WCS_SYSSET>().ToList();
  37. var wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "srm01");
  38. if (wcs_sys_srm.SET_VALUE == "0")
  39. {
  40. rdoBtnEnable_01.Checked = true;
  41. }
  42. else
  43. {
  44. rdoBtnDisable_01.Checked = true;
  45. }
  46. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "srm02");
  47. if (wcs_sys_srm.SET_VALUE == "0")
  48. {
  49. rdoBtnEnable_02.Checked = true;
  50. }
  51. else
  52. {
  53. rdoBtnDisable_02.Checked = true;
  54. }
  55. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "srm03");
  56. if (wcs_sys_srm.SET_VALUE == "0")
  57. {
  58. rdoBtnEnable_03.Checked = true;
  59. }
  60. else
  61. {
  62. rdoBtnDisable_03.Checked = true;
  63. }
  64. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "srm04");
  65. if (wcs_sys_srm.SET_VALUE == "0")
  66. {
  67. rdoBtnEnable_04.Checked = true;
  68. }
  69. else
  70. {
  71. rdoBtnDisable_04.Checked = true;
  72. }
  73. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "srm05");
  74. if (wcs_sys_srm.SET_VALUE == "0")
  75. {
  76. rdoBtnEnable_05.Checked = true;
  77. }
  78. else
  79. {
  80. rdoBtnDisable_05.Checked = true;
  81. }
  82. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "srm06");
  83. if (wcs_sys_srm.SET_VALUE == "0")
  84. {
  85. rdoBtnEnable_06.Checked = true;
  86. }
  87. else
  88. {
  89. rdoBtnDisable_06.Checked = true;
  90. }
  91. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "srm07");
  92. if (wcs_sys_srm.SET_VALUE == "0")
  93. {
  94. rdoBtnEnable_07.Checked = true;
  95. }
  96. else
  97. {
  98. rdoBtnDisable_07.Checked = true;
  99. }
  100. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "srm08");
  101. if (wcs_sys_srm.SET_VALUE == "0")
  102. {
  103. rdoBtnEnable_08.Checked = true;
  104. }
  105. else
  106. {
  107. rdoBtnDisable_08.Checked = true;
  108. }
  109. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "Rgv02_Mode");
  110. if (wcs_sys_srm.SET_VALUE == "3")
  111. {
  112. rdoBtnRGV2Mode_03.Checked = true;
  113. }
  114. else if (wcs_sys_srm.SET_VALUE == "4")
  115. {
  116. rdoBtnRGV2Mode_04.Checked = true;
  117. }
  118. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "ConveyorBox_1F");
  119. if (wcs_sys_srm.SET_VALUE == "0")
  120. {
  121. rdoBtnEnableAGV_01.Checked = true;
  122. }
  123. else
  124. {
  125. rdoBtnDisableAGV_01.Checked = true;
  126. }
  127. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "ConveyorBox_2F");
  128. if (wcs_sys_srm.SET_VALUE == "0")
  129. {
  130. rdoBtnEnableAGV_02.Checked = true;
  131. }
  132. else
  133. {
  134. rdoBtnDisableAGV_02.Checked = true;
  135. }
  136. });
  137. }
  138. private void btnCancel_Click(object sender, EventArgs e)
  139. {
  140. this.Close();
  141. }
  142. private void btnSave_Click(object sender, EventArgs e)
  143. {
  144. string result = TryCachHelper.TryTranExecute((db) =>
  145. {
  146. var wcs_sysset = db.Queryable<WCS_SYSSET>().ToList();
  147. var wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "srm01");
  148. if (rdoBtnEnable_01.Checked && wcs_sys_srm.SET_VALUE == "1")
  149. {
  150. wcs_sys_srm.SET_VALUE = "0";
  151. //更新
  152. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  153. }
  154. else if (rdoBtnDisable_01.Checked && wcs_sys_srm.SET_VALUE == "0")
  155. {
  156. wcs_sys_srm.SET_VALUE = "1";
  157. //更新
  158. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  159. }
  160. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "srm02");
  161. if (rdoBtnEnable_02.Checked && wcs_sys_srm.SET_VALUE == "1")
  162. {
  163. wcs_sys_srm.SET_VALUE = "0";
  164. //更新
  165. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  166. }
  167. else if (rdoBtnDisable_02.Checked && wcs_sys_srm.SET_VALUE == "0")
  168. {
  169. wcs_sys_srm.SET_VALUE = "1";
  170. //更新
  171. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  172. }
  173. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "srm03");
  174. if (rdoBtnEnable_03.Checked && wcs_sys_srm.SET_VALUE == "1")
  175. {
  176. wcs_sys_srm.SET_VALUE = "0";
  177. //更新
  178. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  179. }
  180. else if (rdoBtnDisable_03.Checked && wcs_sys_srm.SET_VALUE == "0")
  181. {
  182. wcs_sys_srm.SET_VALUE = "1";
  183. //更新
  184. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  185. }
  186. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "srm04");
  187. if (rdoBtnEnable_04.Checked && wcs_sys_srm.SET_VALUE == "1")
  188. {
  189. wcs_sys_srm.SET_VALUE = "0";
  190. //更新
  191. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  192. }
  193. else if (rdoBtnDisable_04.Checked && wcs_sys_srm.SET_VALUE == "0")
  194. {
  195. wcs_sys_srm.SET_VALUE = "1";
  196. //更新
  197. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  198. }
  199. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "srm05");
  200. if (rdoBtnEnable_05.Checked && wcs_sys_srm.SET_VALUE == "1")
  201. {
  202. wcs_sys_srm.SET_VALUE = "0";
  203. //更新
  204. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  205. }
  206. else if (rdoBtnDisable_05.Checked && wcs_sys_srm.SET_VALUE == "0")
  207. {
  208. wcs_sys_srm.SET_VALUE = "1";
  209. //更新
  210. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  211. }
  212. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "srm06");
  213. if (rdoBtnEnable_06.Checked && wcs_sys_srm.SET_VALUE == "1")
  214. {
  215. wcs_sys_srm.SET_VALUE = "0";
  216. //更新
  217. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  218. }
  219. else if (rdoBtnDisable_06.Checked && wcs_sys_srm.SET_VALUE == "0")
  220. {
  221. wcs_sys_srm.SET_VALUE = "1";
  222. //更新
  223. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  224. }
  225. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "srm07");
  226. if (rdoBtnEnable_07.Checked && wcs_sys_srm.SET_VALUE == "1")
  227. {
  228. wcs_sys_srm.SET_VALUE = "0";
  229. //更新
  230. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  231. }
  232. else if (rdoBtnDisable_07.Checked && wcs_sys_srm.SET_VALUE == "0")
  233. {
  234. wcs_sys_srm.SET_VALUE = "1";
  235. //更新
  236. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  237. }
  238. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "srm08");
  239. if (rdoBtnEnable_08.Checked && wcs_sys_srm.SET_VALUE == "1")
  240. {
  241. wcs_sys_srm.SET_VALUE = "0";
  242. //更新
  243. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  244. }
  245. else if (rdoBtnDisable_08.Checked && wcs_sys_srm.SET_VALUE == "0")
  246. {
  247. wcs_sys_srm.SET_VALUE = "1";
  248. //更新
  249. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  250. }
  251. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "Rgv02_Mode");
  252. if (rdoBtnRGV2Mode_03.Checked && wcs_sys_srm.SET_VALUE != "3")
  253. {
  254. wcs_sys_srm.SET_VALUE = "3";
  255. //更新
  256. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  257. }
  258. else if (rdoBtnRGV2Mode_04.Checked && wcs_sys_srm.SET_VALUE != "4")
  259. {
  260. wcs_sys_srm.SET_VALUE = "4";
  261. //更新
  262. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  263. }
  264. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "ConveyorBox_1F");
  265. if(rdoBtnEnableAGV_01.Checked && wcs_sys_srm.SET_VALUE != "0")
  266. {
  267. wcs_sys_srm.SET_VALUE = "0";
  268. //更新
  269. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  270. }
  271. else if (rdoBtnDisableAGV_01.Checked && wcs_sys_srm.SET_VALUE != "1")
  272. {
  273. //检测是否存在未完成的出库任务,存在则不可启用
  274. var agvtasks = db.Queryable<WCS_AGVTASKS>().Where(v => v.TASKTYPE.Trim() == "1" && v.WKSTATUS < 99);
  275. if (agvtasks.Where(v => v.STARTPOS.Contains("2285") || v.STARTPOS.Contains("2284") || v.STARTPOS.Contains("2275") || v.STARTPOS.Contains("2274")).Count() > 0)
  276. {
  277. throw new Exception(string.Format("一楼存在未完成的出库AGV任务,不可禁用。"));
  278. }
  279. else
  280. {
  281. wcs_sys_srm.SET_VALUE = "1";
  282. //更新
  283. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  284. }
  285. }
  286. wcs_sys_srm = wcs_sysset.FirstOrDefault(v => v.SET_ID == "ConveyorBox_2F");
  287. if (rdoBtnEnableAGV_02.Checked && wcs_sys_srm.SET_VALUE != "0")
  288. {
  289. wcs_sys_srm.SET_VALUE = "0";
  290. //更新
  291. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  292. }
  293. else if (rdoBtnDisableAGV_02.Checked && wcs_sys_srm.SET_VALUE != "1")
  294. {
  295. //检测是否存在未完成的出库任务,存在则不可启用
  296. var agvtasks = db.Queryable<WCS_AGVTASKS>().Where(v => v.TASKTYPE.Trim() == "1" && v.WKSTATUS < 99);
  297. if (agvtasks.Where(v => v.STARTPOS.Contains("2390") || v.STARTPOS.Contains("2383") || v.STARTPOS.Contains("2375") || v.STARTPOS.Contains("2373")).Count() > 0)
  298. {
  299. throw new Exception(string.Format("二楼存在未完成的出库AGV任务,不可禁用。"));
  300. }
  301. else
  302. {
  303. wcs_sys_srm.SET_VALUE = "1";
  304. //更新
  305. db.Updateable(wcs_sys_srm).UpdateColumns(it => new { it.SET_VALUE }).ExecuteCommand();
  306. }
  307. }
  308. });
  309. if (string.IsNullOrWhiteSpace(result))
  310. {
  311. MessageBox.Show("系统配置更新成功");
  312. }
  313. else
  314. {
  315. MessageBox.Show(result);
  316. Init();
  317. }
  318. }
  319. }
  320. }