FrmMilControlLogUpdate2.cs 63 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400
  1. using com.steering.mes.zgmil.entity;
  2. using Core.Mes.Client.Comm.Control;
  3. using Core.Mes.Client.Comm.Server;
  4. using Core.Mes.Client.Comm.Tool;
  5. using Core.StlMes.Client.ZGMil.Common;
  6. using Core.StlMes.Client.ZGMil.Entity;
  7. using CoreFS.CA06;
  8. using Infragistics.Win;
  9. using Infragistics.Win.UltraWinEditors;
  10. using Infragistics.Win.UltraWinGrid;
  11. using System;
  12. using System.Collections;
  13. using System.Collections.Generic;
  14. using System.ComponentModel;
  15. using System.Data;
  16. using System.Drawing;
  17. using System.Globalization;
  18. using System.Linq;
  19. using System.Text;
  20. using System.Windows.Forms;
  21. namespace Core.StlMes.Client.ZGMil.Signature
  22. {
  23. public partial class FrmMilControlLogUpdate2 : FrmBase
  24. {
  25. private string departm = "";
  26. UltraComboEditor ucePline = new UltraComboEditor();//产线名称
  27. private string plineCode;
  28. private string userId = "";
  29. //int stratday;//开始时间日期差,天,时,分
  30. //int strathours;
  31. //int stratminutes;
  32. //int endday;//结束时间日期差,天,时,分
  33. //int endhours;
  34. //int endminutes;toolba
  35. int flag = 0;//分析时间错误
  36. int flag1 = 0;//分析相差时间
  37. private string basecodeSamll = "";//停机小类值
  38. private string basecodeReason = "";//停机原因值
  39. public FrmMilControlLogUpdate2()
  40. {
  41. InitializeComponent();
  42. this.IsLoadUserView = true;
  43. }
  44. private void FrmMilControlLogUpdate_Load(object sender, EventArgs e)
  45. {
  46. EntityHelper.ShowGridCaption<MilControlLogEntity>(ultraGrid1.DisplayLayout.Bands[0]);
  47. NativeMethodNew na = new NativeMethodNew(this.ob);
  48. departm = UserInfo.GetDepartment();
  49. userId = UserInfo.GetUserID();
  50. plineCode = na.GetPCode(departm);//获取 用户 对应的产线
  51. //cmbPline.DataSource = ServerHelper.GetData("com.steering.mes.signature.FrmTubeRollFileManage.queryPlineCode", new object[] { plineCode }, this.ob);
  52. //cmbPline.ValueMember = "PLINE_CODE";
  53. //cmbPline.DisplayMember = "PLINE_NAME";
  54. //TubeRoll.SetComboItemHeight(cmbPline);
  55. //cmbPlineE.DataSource = ServerHelper.GetData("com.steering.mes.signature.FrmTubeRollFileManage.queryPlineCode", new object[] { plineCode }, this.ob);
  56. //cmbPlineE.ValueMember = "PLINE_CODE";
  57. //cmbPlineE.DisplayMember = "PLINE_NAME";
  58. //TubeRoll.SetComboItemHeight(cmbPlineE);
  59. //cmbDate.MaxDate = DateTime.Now;
  60. cmbDate.Value = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd"));
  61. cmbDate2.Value = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd"));
  62. cmbPline.Value = na.GetPCodePline(this.ValidDataPurviewIds);
  63. TubeRoll.setUltraGridColumnInput(ultraGrid1, new string[] { "QualifiedNum", "ScrapNum" });//支数
  64. TubeRoll.setUltraGridColumnMaxInput(ultraGrid1, new string[] { "QualifiedWt", "ScrapWt" });//重量
  65. TubeRoll.SetComboItemHeight(cmbPline);
  66. TubeRoll.SetComboItemHeight(cmbBc);
  67. TubeRoll.SetComboItemHeight(cmbBz);
  68. DataTable dt = TubeRoll.GetComBaseInfo("5006", ob);
  69. cmbStop.DataSource = dt;
  70. cmbStop.ValueMember = "BASECODE";
  71. cmbStop.DisplayMember = "BASENAME";
  72. TubeRoll.SetComboItemHeight(cmbStop);
  73. }
  74. /// <summary>
  75. /// 重写基类方法
  76. /// </summary>
  77. /// <param name="sender"></param>
  78. /// <param name="ToolbarKey"></param>
  79. public override void ToolBar_Click(object sender, string ToolbarKey)
  80. {
  81. switch (ToolbarKey)
  82. {
  83. case "Query":
  84. Query();
  85. break;
  86. //case "Add":
  87. // doAdd();
  88. // break;
  89. //case "Update":
  90. // doUpdate("0");
  91. // break;
  92. case "UpdateM":
  93. doUpdate();
  94. break;
  95. //case "Delete":
  96. // doDelete();
  97. // break;
  98. case "Analysis":
  99. Query();
  100. doAnalysis();
  101. break;
  102. //case "Confirm":
  103. // doConfirm();
  104. // break;
  105. //case "UpConfirm":
  106. // UpConfirm();
  107. // break;
  108. //case "OneKeyProces":
  109. // DoOneKeyProces();
  110. // break;
  111. //case "Statistical":
  112. // DoStatistical();
  113. // break;
  114. //case "OneKeyUpdate":
  115. // DoOneKeyUpdate();
  116. // break;
  117. //case "Production":
  118. // DoProduction();
  119. // break;
  120. case "Export":
  121. GridHelper.ulGridToExcel(ultraGrid1, "轧管调度日志");
  122. break;
  123. case "Close":
  124. this.Close();
  125. break;
  126. }
  127. }
  128. /// <summary>
  129. /// 生产记录
  130. /// </summary>
  131. private void DoProduction()
  132. {
  133. FrmProductionDetails pro = new FrmProductionDetails(cmbDate.Value.ToString("yyyyMMdd"), plineCode, this.ob);
  134. pro.MaximumSize = new Size(Screen.PrimaryScreen.WorkingArea.Width, Screen.PrimaryScreen.WorkingArea.Height);
  135. pro.Text = "生产详细";
  136. pro.ShowDialog();
  137. }
  138. /// <summary>
  139. /// 查询统计数据
  140. /// </summary>
  141. private void DoStatistical()
  142. {
  143. UltraGridRow row = ultraGrid1.ActiveRow;
  144. if (row == null) { MessageUtil.ShowTips("无数据!"); return; }
  145. //foreach (UltraGridRow urg in ultraGrid1.Rows)
  146. //{
  147. // if (row.Cells["ConfirmFlag"].Text.Equals("未确认")) { MessageUtil.ShowTips("未确认,不允许此操作!"); return; }
  148. //}
  149. FrmStatistical fsta = new FrmStatistical(plineCode, ob);
  150. fsta.AutoSize = true;
  151. fsta.MaximumSize = new Size(Screen.PrimaryScreen.WorkingArea.Width, Screen.PrimaryScreen.WorkingArea.Height);
  152. fsta.Text = "统计查询";
  153. fsta.ShowDialog();
  154. }
  155. /// <summary>
  156. /// 查询
  157. /// </summary>
  158. private string[] plineCodes = { };
  159. private void Query()
  160. {
  161. plineCodes = BaseMethod.GetPlineCode(ValidDataPurviewIds, ob);
  162. ArrayList list = new ArrayList();
  163. //当天
  164. string date = "";
  165. //前一天
  166. string endDate = "";
  167. date = cmbDate.Value.ToString("yyyyMMdd");
  168. endDate = cmbDate2.Value.ToString("yyyyMMdd");
  169. //当班数据
  170. List<MilControlLogEntity> listSource = EntityHelper.GetData<MilControlLogEntity>
  171. ("com.steering.mes.signature.FrmMilControlLog.queryZC", new object[] { date, endDate, plineCodes }, this.ob);
  172. MilControlLogEntity.DataSource = listSource;
  173. GridHelper.RefreshAndAutoSize(ultraGrid1);
  174. this.ultraGrid1.DisplayLayout.Bands[0].Columns["LogsBeg"].Style = Infragistics.Win.UltraWinGrid.ColumnStyle.DateTimeWithSpin;
  175. this.ultraGrid1.DisplayLayout.Bands[0].Columns["LogsBeg"].MaskInput = "yyyy-mm-dd hh:mm";
  176. this.ultraGrid1.DisplayLayout.Bands[0].Columns["LogsEnd"].Style = Infragistics.Win.UltraWinGrid.ColumnStyle.DateTimeWithSpin;
  177. this.ultraGrid1.DisplayLayout.Bands[0].Columns["LogsEnd"].MaskInput = "yyyy-mm-dd hh:mm";
  178. }
  179. /// <summary>
  180. /// 一键处理新增(分析后五分钟以内的时间间隔)
  181. /// </summary>
  182. //private void DoOneKeyProces()
  183. //{
  184. // ultraGrid1.UpdateData();
  185. // UltraGridRow row = ultraGrid1.ActiveRow;
  186. // if (row == null) { MessageUtil.ShowTips("无数据,不允许此操作!"); return; }
  187. // int minutes = int.Parse(MinTime.Value.ToString());
  188. // if (minutes == 0) { MessageUtil.ShowTips("请输入相差时间!"); }
  189. // ArrayList pram = new ArrayList();
  190. // if (flag == 0) { MessageUtil.ShowTips("未分析,不允许此操作!"); return; }
  191. // if (flag == 1 && flag1 == 0) { MessageUtil.ShowTips("分析通过,不允许此操作!"); return; }
  192. // if (flag == 2) { MessageUtil.ShowTips("分析时间错误,不允许此操作!"); return; }
  193. // int i = 0;
  194. // try
  195. // {
  196. // foreach (UltraGridRow ugr in ultraGrid1.Rows)
  197. // {
  198. // //if (ugr.Cells["ConfirmFlag"].Text.Equals("已确认"))
  199. // //{
  200. // // MessageUtil.ShowTips("已确认数据,不允许此操作!");
  201. // // return;
  202. // //}
  203. // if (!ugr.Cells["LogsEnd"].Value.Equals(""))
  204. // {
  205. // i += 1;
  206. // }
  207. // }
  208. // for (int j = 0; j < i; j++)
  209. // {
  210. // string loagEnd = ultraGrid1.Rows[j].Cells["LogsEnd"].Text.ToString();
  211. // string loagBeg = "";
  212. // if (j + 1 < i)
  213. // {
  214. // loagBeg = ultraGrid1.Rows[j + 1].Cells["LogsBeg"].Text.ToString();
  215. // if (DateTime.Compare(Convert.ToDateTime(loagBeg), Convert.ToDateTime(loagEnd)) > 0)
  216. // {
  217. // if (TubeRoll.JudgeTimeMax(Convert.ToDateTime(loagEnd), Convert.ToDateTime(loagBeg)) <= minutes
  218. // && TubeRoll.JudgeTimeMax(Convert.ToDateTime(loagEnd), Convert.ToDateTime(loagBeg)) > 0)
  219. // {
  220. // ArrayList list = new ArrayList();
  221. // list.Add(DateTime.Parse(ultraGrid1.Rows[j].Cells["LogsEnd"].Value.ToString()).ToString("yyyyMMddHHmm"));
  222. // list.Add(DateTime.Parse(ultraGrid1.Rows[j + 1].Cells["LogsBeg"].Value.ToString()).ToString("yyyyMMddHHmm"));
  223. // list.Add(this.UserInfo.GetUserName());
  224. // list.Add(this.UserInfo.GetUserOrder());
  225. // list.Add(this.UserInfo.GetUserGroup());
  226. // list.Add(plineCode);
  227. // pram.Add(list);
  228. // }
  229. // }
  230. // }
  231. // }
  232. // if (MessageUtil.ShowYesNoAndQuestion("是否一键新增处理?") == DialogResult.No)
  233. // {
  234. // return;
  235. // }
  236. // CoreClientParam ccp = new CoreClientParam();
  237. // ccp.ServerName = "com.steering.mes.signature.FrmMilControlLog";
  238. // ccp.MethodName = "oneKeyProcesMilControlLog";
  239. // ccp.ServerParams = new object[] { pram };
  240. // ccp = this.ExecuteNonQuery(ccp, CoreInvokeType.Internal);
  241. // if (ccp.ReturnCode != -1)
  242. // {
  243. // MessageUtil.ShowTips(ccp.ReturnInfo);
  244. // if (ccp.ReturnInfo.Equals("一键处理成功!"))
  245. // {
  246. // doQuery();
  247. // doAnalysis();
  248. // }
  249. // }
  250. // }
  251. // catch (Exception ex)
  252. // {
  253. // MessageUtil.ShowTips("开始时间或结束时间不能为空!");
  254. // }
  255. //}
  256. /// <summary>
  257. /// 一键修改
  258. /// </summary>
  259. //private void DoOneKeyUpdate()
  260. //{
  261. // ultraGrid1.UpdateData();
  262. // UltraGridRow row = ultraGrid1.ActiveRow;
  263. // if (row == null) { MessageUtil.ShowTips("无数据,不允许此操作!"); return; }
  264. // ArrayList pram = new ArrayList();
  265. // if (flag == 0) { MessageUtil.ShowTips("未分析,不允许此操作!"); return; }
  266. // if (flag == 1 && flag1 == 0) { MessageUtil.ShowTips("分析通过,不允许此操作!"); return; }
  267. // //if (flag == 2) { MessageUtil.ShowTips("分析时间错误,不允许此操作!"); return; }
  268. // int i = 0;
  269. // try
  270. // {
  271. // foreach (UltraGridRow ugr in ultraGrid1.Rows)
  272. // {
  273. // //if (ugr.Cells["ConfirmFlag"].Text.Equals("已确认"))
  274. // //{
  275. // // MessageUtil.ShowTips("已确认数据,不允许此操作!");
  276. // // return;
  277. // //}
  278. // if (!ugr.Cells["LogsEnd"].Value.Equals(""))
  279. // {
  280. // i += 1;
  281. // }
  282. // }
  283. // for (int j = 0; j < i; j++)
  284. // {
  285. // string loagEnd = ultraGrid1.Rows[j].Cells["LogsEnd"].Text.ToString();
  286. // string loagBeg = "";
  287. // if (j + 1 < i)
  288. // {
  289. // loagBeg = ultraGrid1.Rows[j + 1].Cells["LogsBeg"].Text.ToString();
  290. // if (DateTime.Compare(Convert.ToDateTime(loagBeg), Convert.ToDateTime(loagEnd)) < 0)
  291. // {
  292. // ArrayList list = new ArrayList();
  293. // list.Add(DateTime.Parse(ultraGrid1.Rows[j].Cells["LogsBeg"].Value.ToString()).ToString("yyyyMMddHHmm"));
  294. // list.Add(DateTime.Parse(ultraGrid1.Rows[j].Cells["LogsEnd"].Value.ToString()).ToString("yyyyMMddHHmm"));
  295. // list.Add(DateTime.Parse(ultraGrid1.Rows[j + 1].Cells["LogsBeg"].Value.ToString()).ToString("yyyyMMddHHmm"));
  296. // list.Add(this.UserInfo.GetUserName());
  297. // list.Add(this.UserInfo.GetUserOrder());
  298. // list.Add(this.UserInfo.GetUserGroup());
  299. // list.Add(plineCode);
  300. // list.Add(ultraGrid1.Rows[j].Cells["ControlId"].Value.ToString());
  301. // pram.Add(list);
  302. // }
  303. // }
  304. // }
  305. // if (ultraGrid1.Rows.Count > 0 && ultraGrid2.Rows.Count > 0)
  306. // {
  307. // int a = ultraGrid2.Rows.Count;
  308. // string logsBeg = ultraGrid1.Rows[0].Cells["LogsBeg"].Value.ToString();
  309. // string logsEnd = ultraGrid2.Rows[a - 1].Cells["LogsEnd"].Value.ToString();
  310. // string ControlId = ultraGrid1.Rows[0].Cells["ControlId"].Value.ToString();
  311. // if (DateTime.Compare(Convert.ToDateTime(logsBeg), Convert.ToDateTime(logsEnd)) < 0)
  312. // {
  313. // logsEnd = DateTime.Parse(logsEnd).ToString("yyyyMMddHHmm");
  314. // ServerHelper.SetData("com.steering.mes.signature.FrmMilControlLog.updateOneDate", new object[] { logsEnd, ControlId }, this.ob);
  315. // }
  316. // }
  317. // if (MessageUtil.ShowYesNoAndQuestion("是否一键修改处理?") == DialogResult.No)
  318. // {
  319. // return;
  320. // }
  321. // CoreClientParam ccp = new CoreClientParam();
  322. // ccp.ServerName = "com.steering.mes.signature.FrmMilControlLog";
  323. // ccp.MethodName = "oneKeyUpdateMilControlLog";
  324. // ccp.ServerParams = new object[] { pram };
  325. // ccp = this.ExecuteNonQuery(ccp, CoreInvokeType.Internal);
  326. // if (ccp.ReturnCode != -1)
  327. // {
  328. // MessageUtil.ShowTips(ccp.ReturnInfo);
  329. // if (ccp.ReturnInfo.Equals("一键处理成功!"))
  330. // {
  331. // doQuery();
  332. // doAnalysis();
  333. // }
  334. // }
  335. // }
  336. // catch (Exception ex)
  337. // {
  338. // MessageUtil.ShowTips("开始时间或结束时间不能为空!");
  339. // }
  340. //}
  341. /// <summary>
  342. /// 新增
  343. /// </summary>
  344. //private void doAdd()
  345. //{
  346. // ultraGrid1.UpdateData();
  347. // ArrayList pram = new ArrayList();
  348. // UltraGridRow row = ultraGrid1.ActiveRow;
  349. // int count = 0;
  350. // int statrindex = 0;//第一行记录
  351. // int endindex = 0;//最后一行记录
  352. // int indexEnd = 0;//获取Grid最后一行记录
  353. // string statime = "";//新增开始时间
  354. // string endtime = "";//新增结束时间
  355. // string datetime1 = "";//获取选中第一行结束时间
  356. // string datetime2 = "";//获取选中第二行开始时间
  357. // if (row != null)
  358. // {
  359. // try
  360. // {
  361. // foreach (UltraGridRow ugr in ultraGrid1.Rows)
  362. // {
  363. // if (Convert.ToBoolean(ugr.Cells["CHK"].Text) == true)
  364. // {
  365. // //if (ugr.Cells["ConfirmFlag"].Text.Equals("已确认"))
  366. // //{
  367. // // MessageUtil.ShowTips("已确认数据,不允许此操作!");
  368. // // return;
  369. // //}
  370. // statime = DateTime.Parse(ugr.Cells["LogsEnd"].Value.ToString()).ToString("yyyyMMddHHmm");//新增开始时间
  371. // datetime1 = DateTime.Parse(ugr.Cells["LogsEnd"].Value.ToString()).ToString("yyyyMMddHHmm");
  372. // statrindex = ugr.Index;
  373. // break;
  374. // }
  375. // }
  376. // foreach (UltraGridRow ugr in ultraGrid1.Rows)
  377. // {
  378. // if (Convert.ToBoolean(ugr.Cells["CHK"].Text) == true)
  379. // {
  380. // count += 1;
  381. // endindex = ugr.Index;
  382. // endtime = DateTime.Parse(ugr.Cells["LogsBeg"].Value.ToString()).ToString("yyyyMMddHHmm");//新增结束时间
  383. // datetime2 = DateTime.Parse(ugr.Cells["LogsBeg"].Value.ToString()).ToString("yyyyMMddHHmm");
  384. // }
  385. // indexEnd = ugr.Index;
  386. // }
  387. // //判断选中的两行没有时间差,不许增加
  388. // int cnt = ultraGrid1.Rows.Where(a => a.GetValue("CHK") == "True").Count();
  389. // if (datetime2 == datetime1 && cnt > 1)
  390. // { MessageUtil.ShowTips("选中的两行没有时间差,不允许增加!"); return; }
  391. // int index = endindex - statrindex;
  392. // if (index == 0)
  393. // {
  394. // if (statrindex == 0)//获取第一行
  395. // {
  396. // if (indexEnd == 0)//如果只有一条数据
  397. // {
  398. // FrmPopupWindow win = new FrmPopupWindow();
  399. // win.AutoSize = true;
  400. // win.MaximumSize = new Size(Screen.PrimaryScreen.WorkingArea.Width, Screen.PrimaryScreen.WorkingArea.Height);
  401. // win.Text = "提示";
  402. // win.ShowDialog();
  403. // if (win.DialogResult == System.Windows.Forms.DialogResult.OK)
  404. // {
  405. // if (win.Popup == "之前")
  406. // {
  407. // pram.Add(DateTime.Parse(row.Cells["LogsBeg"].Value.ToString()).ToString("yyyyMMddHHmm"));
  408. // pram.Add(DateTime.Parse(row.Cells["LogsBeg"].Value.ToString()).ToString("yyyyMMddHHmm"));
  409. // }
  410. // else if (win.Popup == "之后")
  411. // {
  412. // pram.Add(DateTime.Parse(row.Cells["LogsEnd"].Value.ToString()).ToString("yyyyMMddHHmm"));
  413. // pram.Add(DateTime.Parse(row.Cells["LogsEnd"].Value.ToString()).ToString("yyyyMMddHHmm"));
  414. // }
  415. // else
  416. // {
  417. // return;
  418. // }
  419. // }
  420. // }
  421. // else
  422. // {
  423. // foreach (UltraGridRow ugr in ultraGrid1.Rows)
  424. // {
  425. // if (Convert.ToBoolean(ugr.Cells["CHK"].Text) == true)
  426. // {
  427. // pram.Add(DateTime.Parse(ugr.Cells["LogsBeg"].Value.ToString()).ToString("yyyyMMddHHmm"));
  428. // pram.Add(DateTime.Parse(ugr.Cells["LogsBeg"].Value.ToString()).ToString("yyyyMMddHHmm"));
  429. // }
  430. // }
  431. // }
  432. // }
  433. // else if (statrindex == indexEnd)//获取最后一行
  434. // {
  435. // foreach (UltraGridRow ugr in ultraGrid1.Rows)
  436. // {
  437. // if (Convert.ToBoolean(ugr.Cells["CHK"].Text) == true)
  438. // {
  439. // pram.Add(DateTime.Parse(ugr.Cells["LogsEnd"].Value.ToString()).ToString("yyyyMMddHHmm"));
  440. // pram.Add(DateTime.Parse(ugr.Cells["LogsEnd"].Value.ToString()).ToString("yyyyMMddHHmm"));
  441. // }
  442. // }
  443. // }
  444. // else
  445. // {
  446. // if (count == 0 || count > 2 || count < 2 && index < 2)
  447. // {
  448. // MessageUtil.ShowTips("请选择数据且选择相邻两条数据新增!");
  449. // return;
  450. // }
  451. // if (MessageUtil.ShowYesNoAndQuestion("是否新增?") == DialogResult.No)
  452. // {
  453. // return;
  454. // }
  455. // pram.Add(statime);
  456. // pram.Add(endtime);
  457. // }
  458. // }
  459. // else
  460. // {
  461. // if (count == 0 || count > 2 || count < 2 && index < 2)
  462. // {
  463. // MessageUtil.ShowTips("请选择数据且选择相邻两条数据新增!");
  464. // return;
  465. // }
  466. // if (MessageUtil.ShowYesNoAndQuestion("是否新增?") == DialogResult.No)
  467. // {
  468. // return;
  469. // }
  470. // pram.Add(statime);
  471. // pram.Add(endtime);
  472. // }
  473. // }
  474. // catch (Exception ex)
  475. // {
  476. // MessageUtil.ShowTips("开始时间或结束时间不能为空!");
  477. // return;
  478. // }
  479. // }
  480. // else//Grid 为空
  481. // {
  482. // if (MessageUtil.ShowYesNoAndQuestion("当前班次无数据是否新增?") == DialogResult.No)
  483. // {
  484. // return;
  485. // }
  486. // pram.Add(cmbDate.Value.ToString("yyyyMMdd") + DateTime.Now.ToString("HHmm"));
  487. // pram.Add(cmbDate.Value.ToString("yyyyMMdd") + DateTime.Now.ToString("HHmm"));
  488. // //pram.Add(DateTime.Now.ToString("yyyyMMddHHmm"));
  489. // //pram.Add(DateTime.Now.ToString("yyyyMMddHHmm"));
  490. // }
  491. // pram.Add(this.UserInfo.GetUserName());
  492. // pram.Add(this.UserInfo.GetUserOrder());
  493. // pram.Add(this.UserInfo.GetUserGroup());
  494. // pram.Add(plineCode);
  495. // CoreClientParam ccp = new CoreClientParam();
  496. // ccp.ServerName = "com.steering.mes.signature.FrmMilControlLog";
  497. // ccp.MethodName = "addMilControlLog";
  498. // ccp.ServerParams = new object[] { pram };
  499. // ccp = this.ExecuteNonQuery(ccp, CoreInvokeType.Internal);
  500. // if (ccp.ReturnCode != -1)
  501. // {
  502. // MessageUtil.ShowTips(ccp.ReturnInfo);
  503. // if (ccp.ReturnInfo.Equals("新增成功!"))
  504. // {
  505. // doQuery();
  506. // doAnalysis();
  507. // }
  508. // }
  509. //}
  510. /// <summary>
  511. /// 修改
  512. /// </summary>
  513. /// <param name="ifConfirm">0只能修改未确认的,1可以修改已确认的</param>
  514. private void doUpdate()
  515. {
  516. ultraGrid1.UpdateData();
  517. UltraGridRow row = ultraGrid1.ActiveRow;
  518. if (row == null) { MessageUtil.ShowTips("无数据!"); return; }
  519. int count = 0;
  520. int statrindex = 0;//选择行记录
  521. int endindex = 0;//最后一行记录
  522. //if (flag == false) { MessageUtil.ShowTips("未分析或分析后数据不通过!"); return; }
  523. ArrayList list = new ArrayList();
  524. try
  525. {
  526. foreach (UltraGridRow ugr in ultraGrid1.Rows)
  527. {
  528. if (Convert.ToBoolean(ugr.Cells["CHK"].Text) == true)
  529. {
  530. count += 1;
  531. if (ugr.Cells["ConfirmFlag"].Text.Equals("已确认"))
  532. {
  533. MessageUtil.ShowTips("已确认数据,不允许此操作!");
  534. return;
  535. }
  536. if (ugr.Cells["ProType"].Text.Equals("正常") && ugr.Cells["QualifiedNum"].Text.Equals("0") && ugr.Cells["ScrapNum"].Text.Equals("0"))
  537. {
  538. MessageUtil.ShowTips("此炉的生产支数和废品支数都为0,请联系【连轧】做【交接班】或【结炉】处理!");
  539. return;
  540. }
  541. //string plineCode1 = "";
  542. //if (!ugr.Cells["PlineCode"].Text.ToString().Equals(""))
  543. //{
  544. // plineCode1 = ugr.Cells["PlineCode"].Value.ToString();
  545. //}
  546. if (Convert.ToDateTime(ugr.Cells["LogsBeg"].Value.ToString()) > Convert.ToDateTime(ugr.Cells["LogsEnd"].Value.ToString()))
  547. {
  548. MessageUtil.ShowTips("开始时间不能大于等于结束时间!");
  549. return;
  550. }
  551. ArrayList pram = new ArrayList();
  552. pram.Add(DateTime.Parse(ugr.Cells["LogsBeg"].Value.ToString()).ToString("yyyyMMddHHmm"));//开始时间
  553. pram.Add(DateTime.Parse(ugr.Cells["LogsEnd"].Value.ToString()).ToString("yyyyMMddHHmm"));//结束时间
  554. pram.Add(DateTime.Parse(ugr.Cells["ProcDate"].Value.ToString()).ToString("yyyyMMdd"));//生产时间
  555. pram.Add(ugr.Cells["BalYearMonth"].Value.ToString());//结算时间
  556. pram.Add(ugr.Cells["QualifiedNum"].Value.ToString());//合格支数
  557. pram.Add(ugr.Cells["QualifiedWt"].Value.ToString());//合格吨
  558. pram.Add(ugr.Cells["ScrapNum"].Value.ToString());//废品支数
  559. pram.Add(ugr.Cells["ScrapWt"].Value.ToString());//废品吨
  560. pram.Add(ugr.Cells["ProBc"].Value.ToString());//班次
  561. pram.Add(ugr.Cells["ProBz"].Value.ToString());//班组
  562. pram.Add(UserInfo.GetUserName());//修改人
  563. pram.Add(DateTime.Parse(System.DateTime.Now.ToString()).ToString("yyyyMMddHHmm"));//修改时间
  564. pram.Add(ugr.Cells["ControlId"].Value.ToString());//id主键
  565. ////pram.Add(plineCode);//机组
  566. //pram.Add(ugr.Cells["Memo"].Text.ToString());//备注
  567. list.Add(pram);
  568. }
  569. }
  570. int index = endindex - statrindex;
  571. if (count == 0 || count > 1)
  572. {
  573. MessageUtil.ShowTips("请选择一条需要修改的数据!");
  574. return;
  575. }
  576. if (MessageUtil.ShowYesNoAndQuestion("是否修改?") == DialogResult.No)
  577. {
  578. return;
  579. }
  580. CoreClientParam ccp = new CoreClientParam();
  581. ccp.ServerName = "com.steering.mes.signature.FrmMilControlLog";
  582. ccp.MethodName = "updateMilControlLogZC";
  583. ccp.ServerParams = new object[] { list};
  584. ccp = this.ExecuteNonQuery(ccp, CoreInvokeType.Internal);
  585. if (ccp.ReturnCode != -1)
  586. {
  587. MessageUtil.ShowTips(ccp.ReturnInfo);
  588. if (ccp.ReturnInfo.Equals("修改成功!"))
  589. {
  590. Query();
  591. //doAnalysis();
  592. }
  593. }
  594. }
  595. catch (Exception ex)
  596. {
  597. MessageUtil.ShowTips("开始时间或结束时间不能为空!");
  598. }
  599. }
  600. /// <summary>
  601. /// 删除
  602. /// </summary>
  603. //private void doDelete()
  604. //{
  605. // ultraGrid1.UpdateData();
  606. // UltraGridRow row = ultraGrid1.ActiveRow;
  607. // if (row == null) { MessageUtil.ShowTips("无数据!"); return; }
  608. // int count = 0;
  609. // ArrayList list = new ArrayList();
  610. // foreach (UltraGridRow ugr in ultraGrid1.Rows)
  611. // {
  612. // if (Convert.ToBoolean(ugr.Cells["CHK"].Text) == true)
  613. // {
  614. // count += 1;
  615. // //只有各厂总账号可以删除正常数据,普通账号只可删除停机数据。
  616. // if (userId != "250001" && userId != "1680001" && userId != "2580001" && userId != "4600001")
  617. // {
  618. // if (ugr.Cells["ProType"].Text.Equals("正常"))
  619. // {
  620. // MessageUtil.ShowTips("请选择停机数据!");
  621. // return;
  622. // }
  623. // }
  624. // if (ugr.Cells["ConfirmFlag"].Text.Equals("已确认"))
  625. // {
  626. // MessageUtil.ShowTips("已确认数据,不允许此操作!");
  627. // return;
  628. // }
  629. // ArrayList pram = new ArrayList();
  630. // pram.Add(ugr.Cells["ControlId"].Value.ToString());
  631. // list.Add(pram);
  632. // }
  633. // }
  634. // if (count == 0)
  635. // {
  636. // MessageUtil.ShowTips("请选择要删除的停机数据!");
  637. // return;
  638. // }
  639. // if (MessageUtil.ShowYesNoAndQuestion("是否删除?") == DialogResult.No)
  640. // {
  641. // return;
  642. // }
  643. // CoreClientParam ccp = new CoreClientParam();
  644. // ccp.ServerName = "com.steering.mes.signature.FrmMilControlLog";
  645. // ccp.MethodName = "deleteMilControlLog";
  646. // ccp.ServerParams = new object[] { list };
  647. // ccp = this.ExecuteNonQuery(ccp, CoreInvokeType.Internal);
  648. // if (ccp.ReturnCode != -1)
  649. // {
  650. // MessageUtil.ShowTips(ccp.ReturnInfo);
  651. // if (ccp.ReturnInfo.Equals("删除成功!"))
  652. // {
  653. // doQuery();
  654. // doAnalysis();
  655. // }
  656. // }
  657. //}
  658. /// <summary>
  659. ///分析
  660. /// </summary>
  661. private void doAnalysis()
  662. {
  663. flag = 1;
  664. flag1 = 0;
  665. int i = 0;
  666. try
  667. {
  668. //当班数据分析
  669. foreach (UltraGridRow ugr in ultraGrid1.Rows)
  670. {
  671. if (!ugr.Cells["LogsEnd"].Value.Equals(""))
  672. { i += 1; }
  673. if (!ugr.Cells["LogsEnd"].Value.Equals(""))
  674. {
  675. if (Convert.ToDateTime(ugr.Cells["LogsBeg"].Value.ToString()) > Convert.ToDateTime(ugr.Cells["LogsEnd"].Value.ToString()))
  676. {
  677. ugr.RowSelectorAppearance.BackColor = Color.Red;
  678. //ugr.Cells["LogsBeg"].Appearance.BackHatchStyle = BackHatchStyle.None;
  679. //ugr.Cells["LogsEnd"].Appearance.BackColor = Color.Red;
  680. //ugr.Cells["LogsEnd"].Appearance.BackHatchStyle = BackHatchStyle.None;
  681. flag = 2;//分析时间错误
  682. }
  683. }
  684. }
  685. for (int j = 0; j < i; j++)
  686. {
  687. string loagEnd = ultraGrid1.Rows[j].Cells["LogsEnd"].Text.ToString();
  688. string loagBeg = "";
  689. if (j + 1 < i)
  690. {
  691. loagBeg = ultraGrid1.Rows[j + 1].Cells["LogsBeg"].Text.ToString();
  692. if (DateTime.Compare(Convert.ToDateTime(loagBeg), Convert.ToDateTime(loagEnd)) > 0)
  693. {
  694. if (TubeRoll.JudgeTime(Convert.ToDateTime(loagBeg), Convert.ToDateTime(loagEnd)) > 0)
  695. {
  696. ultraGrid1.Rows[j + 1].Cells["StopType"].Appearance.BackColor = Color.Pink;
  697. ultraGrid1.Rows[j + 1].Cells["StopType"].Appearance.BackHatchStyle = BackHatchStyle.None;
  698. ultraGrid1.Rows[j].Cells["StopType"].Appearance.BackColor = Color.Pink;
  699. ultraGrid1.Rows[j].Cells["StopType"].Appearance.BackHatchStyle = BackHatchStyle.None;
  700. flag1 = 1;//时间差
  701. }
  702. //else if (TubeRoll.JudgeTime(Convert.ToDateTime(loagBeg), Convert.ToDateTime(loagEnd)) <= 5 && TubeRoll.JudgeTime(Convert.ToDateTime(loagBeg), Convert.ToDateTime(loagEnd))>=3)
  703. //{
  704. // ultraGrid1.Rows[j + 1].Cells["StopType"].Appearance.BackColor = Color.LightGray;
  705. // ultraGrid1.Rows[j + 1].Cells["StopType"].Appearance.BackHatchStyle = BackHatchStyle.None;
  706. // ultraGrid1.Rows[j].Cells["StopType"].Appearance.BackColor = Color.LightGray;
  707. // ultraGrid1.Rows[j].Cells["StopType"].Appearance.BackHatchStyle = BackHatchStyle.None;
  708. // flag = 2;
  709. //}
  710. }
  711. else if (DateTime.Compare(Convert.ToDateTime(loagBeg), Convert.ToDateTime(loagEnd)) < 0)
  712. {
  713. ultraGrid1.Rows[j].RowSelectorAppearance.BackColor = Color.Red;
  714. //ultraGrid1.Rows[j + 1].RowSelectorAppearance.BackColor = Color.Red;
  715. //ultraGrid1.Rows[j + 1].Cells["LogsBeg"].Appearance.BackColor = Color.Orange;
  716. //ultraGrid1.Rows[j + 1].Cells["LogsBeg"].Appearance.BackHatchStyle = BackHatchStyle.None;
  717. //ultraGrid1.Rows[j].Cells["LogsBeg"].Appearance.BackColor = Color.Orange;
  718. //ultraGrid1.Rows[j].Cells["LogsBeg"].Appearance.BackHatchStyle = BackHatchStyle.None;
  719. flag = 2;
  720. }
  721. TimeSpan timeSpan = DateTime.Parse(ultraGrid1.Rows[j + 1].Cells["LogsBeg"].Value.ToString()) -
  722. DateTime.Parse(ultraGrid1.Rows[j].Cells["LogsEnd"].Value.ToString());
  723. ultraGrid1.Rows[j + 1].Cells["TimeDiff"].Value = timeSpan.TotalMinutes.ToString();
  724. }
  725. }
  726. //上班数据分析
  727. //i = 0;
  728. //foreach (UltraGridRow ugr in ultraGrid2.Rows)
  729. //{
  730. // if (!ugr.Cells["LogsBeg"].Value.Equals(""))
  731. // { i += 1; }
  732. // if (!ugr.Cells["LogsEnd"].Value.Equals(""))
  733. // {
  734. // //i += 1;
  735. // if (Convert.ToDateTime(ugr.Cells["LogsBeg"].Value.ToString()) > Convert.ToDateTime(ugr.Cells["LogsEnd"].Value.ToString()))
  736. // {
  737. // ugr.RowSelectorAppearance.BackColor = Color.Red;
  738. // flag = 2;//分析时间错误
  739. // }
  740. // }
  741. //}
  742. //for (int j = 0; j < i; j++)
  743. //{
  744. // string loagEnd = ultraGrid2.Rows[j].Cells["LogsEnd"].Text.ToString();
  745. // string loagBeg = "";
  746. // if (j + 1 < i)
  747. // {
  748. // loagBeg = ultraGrid2.Rows[j + 1].Cells["LogsBeg"].Text.ToString();
  749. // if (DateTime.Compare(Convert.ToDateTime(loagBeg), Convert.ToDateTime(loagEnd)) > 0)
  750. // {
  751. // if (TubeRoll.JudgeTime(Convert.ToDateTime(loagBeg), Convert.ToDateTime(loagEnd)) > 0)
  752. // {
  753. // ultraGrid2.Rows[j + 1].Cells["StopType"].Appearance.BackColor = Color.Pink;
  754. // ultraGrid2.Rows[j + 1].Cells["StopType"].Appearance.BackHatchStyle = BackHatchStyle.None;
  755. // ultraGrid2.Rows[j].Cells["StopType"].Appearance.BackColor = Color.Pink;
  756. // ultraGrid2.Rows[j].Cells["StopType"].Appearance.BackHatchStyle = BackHatchStyle.None;
  757. // flag1 = 1;//时间差
  758. // }
  759. // }
  760. // else if (DateTime.Compare(Convert.ToDateTime(loagBeg), Convert.ToDateTime(loagEnd)) < 0)
  761. // {
  762. // ultraGrid2.Rows[j].RowSelectorAppearance.BackColor = Color.Red;
  763. // flag = 2;
  764. // }
  765. // TimeSpan timeSpan = DateTime.Parse(ultraGrid2.Rows[j + 1].Cells["LogsBeg"].Value.ToString()) -
  766. // DateTime.Parse(ultraGrid2.Rows[j].Cells["LogsEnd"].Value.ToString());
  767. // ultraGrid2.Rows[j + 1].Cells["TimeDiff"].Value = timeSpan.TotalMinutes.ToString();
  768. // }
  769. //}
  770. //if (ultraGrid1.Rows.Count > 0 && ultraGrid2.Rows.Count > 0)
  771. //{
  772. // string logsBeg = ultraGrid1.Rows[0].Cells["LogsBeg"].Value.ToString();
  773. // string logsEnd = ultraGrid2.Rows[i - 1].Cells["LogsEnd"].Value.ToString();
  774. // if (DateTime.Compare(Convert.ToDateTime(logsBeg), Convert.ToDateTime(logsEnd)) > 0)
  775. // {
  776. // if (TubeRoll.JudgeTime(Convert.ToDateTime(logsBeg), Convert.ToDateTime(logsEnd)) > 0)
  777. // {
  778. // flag1 = 1;//时间差
  779. // }
  780. // }
  781. // else if (DateTime.Compare(Convert.ToDateTime(logsBeg), Convert.ToDateTime(logsEnd)) < 0)
  782. // {
  783. // flag = 2;
  784. // }
  785. // TimeSpan timeSpan = DateTime.Parse(logsBeg) - DateTime.Parse(logsEnd);
  786. // ultraGrid1.Rows[0].Cells["TimeDiff"].Value = timeSpan.TotalMinutes.ToString();
  787. //}
  788. }
  789. catch (Exception ex)
  790. {
  791. // MessageUtil.ShowTips(ex.Message);
  792. MessageUtil.ShowTips("开始时间或结束时间不能为空!");
  793. }
  794. }
  795. private string DateDiff(DateTime DateTime1, DateTime DateTime2)
  796. {
  797. string dateDiff = null;
  798. try
  799. {
  800. TimeSpan ts1 = new TimeSpan(DateTime1.Ticks);
  801. TimeSpan ts2 = new TimeSpan(DateTime2.Ticks);
  802. TimeSpan ts = ts1.Subtract(ts2).Duration();
  803. dateDiff = ts.Minutes.ToString();
  804. }
  805. catch
  806. {
  807. }
  808. return dateDiff;
  809. }
  810. /// <summary>
  811. ///确认
  812. /// </summary>
  813. //private void doConfirm()
  814. //{
  815. // UltraGridRow uow = ultraGrid1.ActiveRow;
  816. // if (uow == null) { MessageUtil.ShowTips("无数据!"); return; }
  817. // ArrayList list = new ArrayList();
  818. // string date = DateTime.Now.ToString();
  819. // int count = 0;
  820. // if (flag == 0) { MessageUtil.ShowTips("未分析,不允许此操作!"); return; }
  821. // if (flag1 == 1) { MessageUtil.ShowTips("有停机记录未新增,不允许此操作!"); return; }
  822. // if (flag == 2) { MessageUtil.ShowTips("分析时间错误,不允许此操作!"); return; }
  823. // foreach (UltraGridRow ugr in ultraGrid1.Rows)
  824. // {
  825. // if (Convert.ToBoolean(ugr.Cells["CHK"].Text) == true && ugr.Cells["LogsBeg"].Value.ToString().Equals(""))
  826. // {
  827. // MessageUtil.ShowTips("有开始时间为空,不允许此操作!"); return;
  828. // }
  829. // if (Convert.ToBoolean(ugr.Cells["CHK"].Text) == true && ugr.Cells["LogsEnd"].Value.ToString().Equals(""))
  830. // {
  831. // MessageUtil.ShowTips("有结束时间为空,不允许此操作!"); return;
  832. // }
  833. // }
  834. // ultraGrid1.UpdateData();
  835. // int seqmin1 = ultraGrid1.Rows.Where(a => a.GetValue("CHK") == "True").Select(a => a.Index).Count();
  836. // if (seqmin1 < 1)
  837. // {
  838. // MessageUtil.ShowTips("没有选中要确认的数据!"); return;
  839. // }
  840. // if (seqmin1 > 0 && ultraGrid1.Rows.Count > 0)
  841. // {
  842. // int seqmin = ultraGrid1.Rows.Where(a => a.GetValue("CHK") == "True").Select(a => a.Index).Min();
  843. // for (int i = 0; i < seqmin; i++)
  844. // {
  845. // if (ultraGrid1.Rows[i].Cells["ConfirmFlag"].Value.ToString().Trim().Equals("未确认"))
  846. // {
  847. // MessageBox.Show("前面有未确认的数据,请先确认!");
  848. // return;
  849. // }
  850. // }
  851. // }
  852. // //if (flag2 == 1) { MessageUtil.ShowTips("有开始时间为空,不允许此操作!"); return; }
  853. // //if (flag2 == 2) { MessageUtil.ShowTips("有结束时间为空,不允许此操作!"); return; }
  854. // //判断上班是否有未确认的数据
  855. // if (ultraGrid2.Rows.Count() < 1)
  856. // {
  857. // MessageBox.Show("上班有停机记录未新增!");
  858. // return;
  859. // }
  860. // foreach (UltraGridRow row in ultraGrid2.Rows)
  861. // {
  862. // if (row.Cells["ConfirmFlag"].Value.ToString().Trim().Equals("未确认"))
  863. // {
  864. // MessageBox.Show("上班有未确认的数据,请先确认!");
  865. // return;
  866. // }
  867. // }
  868. // string startdate = "";
  869. // string endDate = "";
  870. // if (chkDate.Checked)
  871. // {
  872. // startdate = cmbDate.Value.ToString("yyyyMMdd1800");
  873. // }
  874. // else
  875. // {
  876. // MessageUtil.ShowTips("请选择日期!");
  877. // return;
  878. // //startdate = cmbDate.Value.ToString("199901012100");
  879. // //endDate = cmbEndDate.Value.ToString("203901012100");
  880. // }
  881. // foreach (UltraGridRow ugr in ultraGrid1.Rows)
  882. // {
  883. // if (Convert.ToBoolean(ugr.Cells["CHK"].Text) == true)
  884. // {
  885. // if (ugr.Cells["ProType"].Text.ToString().Trim().Equals("停机"))
  886. // {
  887. // if (ugr.Cells["StopType"].Value.Equals("") || ugr.Cells["StopSmall"].Value.Equals("") || ugr.Cells["StopReason"].Value.Equals(""))
  888. // {
  889. // MessageUtil.ShowTips("停机大类,停机小类,停机原因不能为空!");
  890. // return;
  891. // }
  892. // }
  893. // string shift = ugr.Cells["ProBc"].Value.ToString();
  894. // string group = ugr.Cells["ProBz"].Value.ToString();
  895. // if (shift != this.UserInfo.GetUserOrder() || group != this.UserInfo.GetUserGroup())
  896. // {
  897. // MessageUtil.ShowTips("您登录的班次班组与要确认的数据班次班组不符,请重新确认!");
  898. // return;
  899. // }
  900. // count += 1;
  901. // ArrayList list1 = new ArrayList();
  902. // list1.Add(ugr.Cells["ControlId"].Text.ToString());
  903. // list1.Add(this.UserInfo.GetUserName());
  904. // list1.Add(date);
  905. // list1.Add(this.UserInfo.GetUserOrder());
  906. // list1.Add(this.UserInfo.GetUserGroup());
  907. // list1.Add(plineCode);
  908. // list1.Add(DateTime.Parse(ugr.Cells["LogsBeg"].Value.ToString()).ToString("yyyyMMddHHmm"));
  909. // list1.Add(startdate);
  910. // list1.Add(endDate);
  911. // list1.Add(ugr.Cells["JudgeStoveNo"].Text.ToString());
  912. // list.Add(list1);
  913. // }
  914. // }
  915. // if (count == 0)
  916. // {
  917. // MessageUtil.ShowTips("请选中要确认的数据!");
  918. // return;
  919. // }
  920. // string intCount = "0";//是否选择确认
  921. // if (MessageUtil.ShowYesNoAndQuestion("是否只确认选中行数据?") == DialogResult.No)
  922. // {
  923. // intCount = "0";
  924. // if (count == 2)
  925. // {
  926. // MessageUtil.ShowTips("请选择一条数据!");
  927. // return;
  928. // }
  929. // }
  930. // else
  931. // {
  932. // intCount = "1";
  933. // }
  934. // //if (MessageUtil.ShowYesNoAndQuestion("是否确认?") == DialogResult.No)
  935. // //{
  936. // // return;
  937. // //}
  938. // UltraGridRow ugr1 = ultraGrid1.ActiveRow;
  939. // if (ugr1 != null)
  940. // {
  941. // string logbeg = ugr1.Cells["LogsBeg"].Value.ToString();
  942. // }
  943. // CoreClientParam ccp = new CoreClientParam();
  944. // ccp.ServerName = "com.steering.mes.signature.FrmMilControlLog";
  945. // ccp.MethodName = "confirmMilControlLog";
  946. // ccp.ServerParams = new object[] { list, intCount };
  947. // ccp = this.ExecuteNonQuery(ccp, CoreInvokeType.Internal);
  948. // if (ccp.ReturnCode != -1)
  949. // {
  950. // MessageUtil.ShowTips(ccp.ReturnInfo);
  951. // if (ccp.ReturnInfo.Equals("确认成功!"))
  952. // {
  953. // doQuery();
  954. // doAnalysis();
  955. // }
  956. // }
  957. //}
  958. /// <summary>
  959. ///取消确认
  960. /// </summary>
  961. private void UpConfirm()
  962. {
  963. UltraGridRow uow = ultraGrid1.ActiveRow;
  964. if (uow == null) { MessageUtil.ShowTips("无数据!"); return; }
  965. ultraGrid1.UpdateData();
  966. int seqmax1 = ultraGrid1.Rows.Where(a => a.GetValue("CHK") == "True").Select(a => a.Index).Count();
  967. if (seqmax1 < 1)
  968. {
  969. MessageUtil.ShowTips("没有选中要确认的数据!"); return;
  970. }
  971. if (seqmax1 > 0 && ultraGrid1.Rows.Count() > 0)
  972. {
  973. int seqmax = ultraGrid1.Rows.Where(a => a.GetValue("CHK") == "True").Select(a => a.Index).Max();
  974. for (int i = seqmax + 1; i < ultraGrid1.Rows.Count(); i++)
  975. {
  976. if (ultraGrid1.Rows[i].Cells["ConfirmFlag"].Value.ToString().Trim().Equals("已确认"))
  977. {
  978. MessageBox.Show("后面有已确认的数据,请先取消确认!");
  979. return;
  980. }
  981. }
  982. }
  983. ArrayList list = new ArrayList();
  984. string date = DateTime.Now.ToString();
  985. int count = 0;
  986. string startdate = "";
  987. string endDate = "";
  988. if (chkDate.Checked)
  989. {
  990. startdate = cmbDate.Value.ToString("yyyyMMdd1800");
  991. }
  992. else
  993. {
  994. MessageUtil.ShowTips("请选择日期!");
  995. return;
  996. //startdate = cmbDate.Value.ToString("199901012100");
  997. //endDate = cmbEndDate.Value.ToString("203901012100");
  998. }
  999. foreach (UltraGridRow ugr in ultraGrid1.Rows)
  1000. {
  1001. if (Convert.ToBoolean(ugr.Cells["CHK"].Text) == true)
  1002. {
  1003. count += 1;
  1004. ArrayList list1 = new ArrayList();
  1005. list1.Add(ugr.Cells["ControlId"].Text.ToString());
  1006. list1.Add(this.UserInfo.GetUserOrder());
  1007. list1.Add(this.UserInfo.GetUserGroup());
  1008. list1.Add(plineCode);
  1009. list1.Add(DateTime.Parse(ugr.Cells["LogsBeg"].Value.ToString()).ToString("yyyyMMddHHmm"));
  1010. list1.Add(startdate);
  1011. list1.Add(endDate);
  1012. list1.Add(ugr.Cells["JudgeStoveNo"].Text.ToString());
  1013. list.Add(list1);
  1014. }
  1015. }
  1016. if (count == 0) { MessageUtil.ShowTips("请选中要取消确认的数据!"); return; }
  1017. string intCount = "0";//是否选择取消确认
  1018. if (MessageUtil.ShowYesNoAndQuestion("是否只取消确认选中行数据?") == DialogResult.No)
  1019. {
  1020. intCount = "0";
  1021. if (count == 2)
  1022. {
  1023. MessageUtil.ShowTips("请选择一条数据!");
  1024. return;
  1025. }
  1026. }
  1027. else
  1028. {
  1029. intCount = "1";
  1030. }
  1031. //if (MessageUtil.ShowYesNoAndQuestion("是否取消确认?") == DialogResult.No)
  1032. //{
  1033. // return;
  1034. //}
  1035. CoreClientParam ccp = new CoreClientParam();
  1036. ccp.ServerName = "com.steering.mes.signature.FrmMilControlLog";
  1037. ccp.MethodName = "upConfirmMilControlLog";
  1038. ccp.ServerParams = new object[] { list, intCount };
  1039. ccp = this.ExecuteNonQuery(ccp, CoreInvokeType.Internal);
  1040. if (ccp.ReturnCode != -1)
  1041. {
  1042. MessageUtil.ShowTips(ccp.ReturnInfo);
  1043. if (ccp.ReturnInfo.Equals("取消确认成功!"))
  1044. {
  1045. Query();
  1046. doAnalysis();
  1047. }
  1048. }
  1049. }
  1050. private void chkDate_CheckedChanged(object sender, EventArgs e)
  1051. {
  1052. if (chkDate.Checked) { cmbDate.Enabled = true; } else { cmbDate.Enabled = false; }
  1053. if (chkBc.Checked) { cmbBc.Enabled = true; } else { cmbBc.Enabled = false; }
  1054. if (chkBz.Checked) { cmbBz.Enabled = true; } else { cmbBz.Enabled = false; }
  1055. if (chkpline.Checked) { cmbPline.Enabled = true; } else { cmbPline.Enabled = false; }
  1056. }
  1057. /// <summary>
  1058. /// Grid字段修改触发事件
  1059. /// </summary>
  1060. /// <param name="sender"></param>
  1061. /// <param name="e"></param>
  1062. private void ultraGrid1_CellChange(object sender, CellEventArgs e)
  1063. {
  1064. UltraGridRow row = ultraGrid1.ActiveRow;
  1065. //string stratime = row.Cells["LogsBeg"].Value.ToString();
  1066. //string endtime = row.Cells["LogsEnd"].Value.ToString();
  1067. try
  1068. {
  1069. //string updateStratime = "";
  1070. //string updateEndtime = "";
  1071. ultraGrid1.UpdateData();
  1072. //if (e.Cell.Column.Key.Equals("LogsEnd"))
  1073. //{
  1074. // if (Convert.ToBoolean(e.Cell.Row.Cells["CHK"].Text) == true)
  1075. // {
  1076. // if (e.Cell.Value == null || e.Cell.Value.ToString().Trim().Equals(""))
  1077. // {
  1078. // return;
  1079. // }
  1080. // else
  1081. // {
  1082. // updateEndtime = e.Cell.Row.Cells["LogsEnd"].Value.ToString();
  1083. // TimeSpan midTime = DateTime.Parse(updateEndtime) - DateTime.Parse(endtime);
  1084. // stratday = midTime.Days;
  1085. // strathours = midTime.Hours;
  1086. // stratminutes = midTime.Minutes;
  1087. // int i = e.Cell.Row.Index;//h获取选中行序号
  1088. // UltraGridRow urg = ultraGrid1.Rows.AsQueryable().Where(a => a.Index == i + 1).First();//获取选择行下一行序号
  1089. // DateTime time = DateTime.Parse(urg.Cells["LogsBeg"].Value.ToString()).AddDays(stratday).AddHours(strathours).AddMinutes(stratminutes);
  1090. // urg.Cells["LogsBeg"].Value = time;
  1091. // }
  1092. // }
  1093. // else
  1094. // {
  1095. // MessageUtil.ShowTips("请选择需要修改的数据!");
  1096. // e.Cell.Row.Cells["LogsEnd"].Value = row.Cells["LogsEnd"].Value.ToString();
  1097. // return;
  1098. // }
  1099. //}
  1100. //if (e.Cell.Column.Key.Equals("LogsBeg"))
  1101. //{
  1102. // if (Convert.ToBoolean(e.Cell.Row.Cells["CHK"].Text) == true)
  1103. // {
  1104. // if (e.Cell.Value == null || e.Cell.Value.ToString().Trim().Equals(""))
  1105. // {
  1106. // return;
  1107. // }
  1108. // else
  1109. // {
  1110. // updateStratime = e.Cell.Row.Cells["LogsBeg"].Value.ToString();
  1111. // TimeSpan midTime = DateTime.Parse(updateStratime) - DateTime.Parse(stratime);
  1112. // endday = midTime.Days;
  1113. // endhours = midTime.Hours;
  1114. // endminutes = midTime.Minutes;
  1115. // int i = e.Cell.Row.Index;//h获取选中行序号
  1116. // UltraGridRow urg = ultraGrid1.Rows.AsQueryable().Where(a => a.Index == i -1).First();//获取选择行上一行序号
  1117. // //if (urg.Index < 0) return;
  1118. // DateTime time = DateTime.Parse(urg.Cells["LogsEnd"].Value.ToString()).AddDays(endday).AddHours(endhours).AddMinutes(endminutes);
  1119. // urg.Cells["LogsEnd"].Value = time;
  1120. // }
  1121. // }
  1122. // else
  1123. // {
  1124. // MessageUtil.ShowTips("请选择需要修改的数据!");
  1125. // e.Cell.Row.Cells["LogsBeg"].Value = row.Cells["LogsBeg"].Value.ToString();
  1126. // return;
  1127. // }
  1128. //}
  1129. if (e.Cell.Column.Key.Equals("QualifiedNum"))
  1130. {
  1131. if (e.Cell.Row.Cells["QualifiedNum"].Value == null)
  1132. {
  1133. e.Cell.Row.Cells["QualifiedNum"].Value = "0";
  1134. }
  1135. else
  1136. {
  1137. string actCount = e.Cell.Row.Cells["QualifiedNum"].Value.ToString();
  1138. if (!StringUtil.IsInt(actCount) || actCount == "0")//actCount == "" || int.Parse(actCount)==0
  1139. {
  1140. e.Cell.Row.Cells["QualifiedNum"].Value = "0";
  1141. }
  1142. }
  1143. }
  1144. if (e.Cell.Column.Key.Equals("QualifiedWt"))
  1145. {
  1146. if (e.Cell.Row.Cells["QualifiedWt"].Value == null)
  1147. {
  1148. e.Cell.Row.Cells["QualifiedWt"].Value = "0";
  1149. }
  1150. else
  1151. {
  1152. string actWt = e.Cell.Row.Cells["QualifiedWt"].Value.ToString();
  1153. if (!StringUtil.IsDouble(actWt) || actWt == "0")//actCount == "" || int.Parse(actCount)==0
  1154. {
  1155. e.Cell.Row.Cells["QualifiedWt"].Value = "0";
  1156. }
  1157. }
  1158. }
  1159. if (e.Cell.Column.Key.Equals("ScrapNum"))
  1160. {
  1161. if (e.Cell.Row.Cells["ScrapNum"].Value == null)
  1162. {
  1163. e.Cell.Row.Cells["ScrapNum"].Value = "0";
  1164. }
  1165. else
  1166. {
  1167. string scrpNum = e.Cell.Row.Cells["ScrapNum"].Value.ToString();
  1168. if (!StringUtil.IsInt(scrpNum) || scrpNum == "0")//actCount == "" || int.Parse(actCount)==0
  1169. {
  1170. e.Cell.Row.Cells["ScrapNum"].Value = "0";
  1171. }
  1172. }
  1173. }
  1174. if (e.Cell.Column.Key.Equals("ScrapWt"))
  1175. {
  1176. if (e.Cell.Row.Cells["ScrapWt"].Value == null)
  1177. {
  1178. e.Cell.Row.Cells["ScrapWt"].Value = "0";
  1179. }
  1180. else
  1181. {
  1182. string scrpwt = e.Cell.Row.Cells["ScrapWt"].Value.ToString();
  1183. if (!StringUtil.IsDouble(scrpwt) || scrpwt == "0")//actCount == "" || int.Parse(actCount)==0
  1184. {
  1185. e.Cell.Row.Cells["ScrapWt"].Value = "0";
  1186. }
  1187. }
  1188. }
  1189. if (e.Cell.Column.Key.Equals("StopType"))
  1190. {
  1191. e.Cell.Row.Cells["StopSmall"].Value = "";
  1192. e.Cell.Row.Cells["StopReason"].Value = "";
  1193. }
  1194. if (e.Cell.Column.Key.Equals("StopSmall"))
  1195. {
  1196. e.Cell.Row.Cells["StopReason"].Value = "";
  1197. }
  1198. }
  1199. catch (Exception ex)
  1200. {
  1201. //MessageUtil.ShowTips("您输入的时间格式不正确!");
  1202. //e.Cell.Row.Cells["LogsBeg"].Value = row.Cells["LogsBeg"].Value.ToString();
  1203. //e.Cell.Row.Cells["LogsEnd"].Value = row.Cells["LogsEnd"].Value.ToString();
  1204. return;
  1205. }
  1206. }
  1207. private void ultraGrid1_CellDataError(object sender, CellDataErrorEventArgs e)
  1208. {
  1209. e.RaiseErrorEvent = false;
  1210. MessageUtil.ShowTips("您输入的时间格式不正确!");
  1211. }
  1212. /// <summary>
  1213. /// 停机原因
  1214. /// </summary>
  1215. /// <param name="sender"></param>
  1216. /// <param name="e"></param>
  1217. private void cmbStopReason_EditorButtonClick(object sender, EditorButtonEventArgs e)
  1218. {
  1219. UltraGridRow row = ultraGrid1.ActiveRow;
  1220. if (row == null) return;
  1221. string stopSallm = basecodeSamll;
  1222. if (!row.Cells["StopSmall"].Text.Equals("")) { stopSallm = row.Cells["StopSmall"].Text; }
  1223. FrmStopSamll fpdc = new FrmStopSamll(basecodeSamll, ob);
  1224. fpdc.AutoSize = true;
  1225. fpdc.MaximumSize = new Size(Screen.PrimaryScreen.WorkingArea.Width, Screen.PrimaryScreen.WorkingArea.Height);
  1226. fpdc.Text = "停机原因";
  1227. fpdc.ShowDialog();
  1228. if (fpdc.DialogResult == System.Windows.Forms.DialogResult.OK)
  1229. {
  1230. //获取弹出窗体的属性值
  1231. row.Cells["StopReasonm"].Value = fpdc.Basename;
  1232. //cmbStopReason.Value = fpdc.Basename;
  1233. basecodeReason = fpdc.Basecode;
  1234. }
  1235. }
  1236. /// <summary>
  1237. /// 停机小类
  1238. /// </summary>
  1239. /// <param name="sender"></param>
  1240. /// <param name="e"></param>
  1241. private void cmbStopSmall_EditorButtonClick(object sender, EditorButtonEventArgs e)
  1242. {
  1243. UltraGridRow row = ultraGrid1.ActiveRow;
  1244. string stoptype = "";
  1245. if (!row.Cells["StopType"].Text.Trim().Equals(""))
  1246. {
  1247. stoptype = row.Cells["StopType"].Value.ToString();
  1248. }
  1249. FrmStopSamll fpdc = new FrmStopSamll(stoptype, ob);
  1250. fpdc.AutoSize = true;
  1251. fpdc.MaximumSize = new Size(Screen.PrimaryScreen.WorkingArea.Width, Screen.PrimaryScreen.WorkingArea.Height);
  1252. fpdc.Text = "停机小类";
  1253. fpdc.ShowDialog();
  1254. if (fpdc.DialogResult == System.Windows.Forms.DialogResult.OK)
  1255. {
  1256. //获取弹出窗体的属性值
  1257. row.Cells["StopSmallm"].Value = fpdc.Basename;
  1258. //cmbStopSmall.Value = fpdc.Basename;
  1259. basecodeSamll = fpdc.Basecode;
  1260. }
  1261. }
  1262. /// <summary>
  1263. /// 班次中文
  1264. /// </summary>
  1265. /// <param name="dtShift"></param>
  1266. /// <returns></returns>
  1267. private string changeShift(string dtShift)
  1268. {
  1269. switch (dtShift)
  1270. {
  1271. case "1":
  1272. dtShift = "早班";
  1273. break;
  1274. case "2":
  1275. dtShift = "中班";
  1276. break;
  1277. case "3":
  1278. dtShift = "夜班";
  1279. break;
  1280. }
  1281. return dtShift;
  1282. }
  1283. /// <summary>
  1284. /// 班组中文
  1285. /// </summary>
  1286. /// <param name="dtGroup"></param>
  1287. /// <returns></returns>
  1288. private string changeGroup(string dtGroup)
  1289. {
  1290. switch (dtGroup)
  1291. {
  1292. case "1":
  1293. dtGroup = "甲班";
  1294. break;
  1295. case "2":
  1296. dtGroup = "乙班";
  1297. break;
  1298. case "3":
  1299. dtGroup = "丙班";
  1300. break;
  1301. case "4":
  1302. dtGroup = "丁班";
  1303. break;
  1304. }
  1305. return dtGroup;
  1306. }
  1307. }
  1308. }