Make_Repair67F.cs 63 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061
  1. using System;
  2. using System.Collections;
  3. using System.Collections.Generic;
  4. using System.Data;
  5. using System.Drawing;
  6. using System.Text;
  7. using System.Windows.Forms;
  8. using UAS_MES_NEW.CustomControl.DataGrid_View;
  9. using UAS_MES_NEW.CustomControl.TextBoxWithIcon;
  10. using UAS_MES_NEW.DataOperate;
  11. using UAS_MES_NEW.Entity;
  12. using UAS_MES_NEW.PublicMethod;
  13. namespace UAS_MES_NEW.Make
  14. {
  15. public partial class Make_Repair67F : Form
  16. {
  17. string mb_id = "";
  18. string mbr_id = "";
  19. /// <summary>
  20. /// 存放父节点信息
  21. /// </summary>
  22. Dictionary<string, Dictionary<string, string>> BadInf_1 = new Dictionary<string, Dictionary<string, string>>();
  23. /// <summary>
  24. /// 存放子节点信息
  25. /// </summary>
  26. Dictionary<string, Dictionary<string, string>> BadInf_2 = new Dictionary<string, Dictionary<string, string>>();
  27. DataHelper dh = null;
  28. LogStringBuilder sql = new LogStringBuilder();
  29. List<string> sqls = new List<string>();
  30. DataTable dt = null;
  31. AutoSizeFormClass asc = new AutoSizeFormClass();
  32. string macode;
  33. string msid = "";
  34. string ifrework = "";
  35. string reworkstatus = "";
  36. string firstsn = "";
  37. string ms_stepcode = "";
  38. DataTable Dbfind;
  39. string ms_paststep = "";
  40. string ma_bomversion = "";
  41. public Make_Repair67F()
  42. {
  43. InitializeComponent();
  44. }
  45. private void Make_Repair_Load(object sender, EventArgs e)
  46. {
  47. //为DBFind配置Call和Form的名称
  48. cr_code.FormName = Name;
  49. cr_code.TableName = "craft";
  50. cr_code.SelectField = "cr_name # 工艺名称,cr_code # 工艺编号,cr_prodcode # 物料编号";
  51. cr_code.SetValueField = new string[] { "cr_code" };
  52. cr_code.DBTitle = "回流工艺";
  53. cr_code.DbChange += Cr_code_DbChange;
  54. cd_stepcode.FormName = Name;
  55. cd_stepcode.TableName = "craftdetail left join step on st_code=cd_stepcode left join craft on cd_crid=cr_id";
  56. cd_stepcode.SetValueField = new string[] { "cd_stepcode" };
  57. cd_stepcode.SelectField = "cd_stepname # 工序名称 ,cd_stepcode # 工序编号,cd_stepno # 执行顺序";
  58. cd_stepcode.DBTitle = "回流工序";
  59. cd_stepcode.DbChange += Cd_stepcode_DbChange;
  60. bd_soncode.FormName = Name;
  61. bd_soncode.TableName = "bom left join bomdetail on bd_bomid=bo_id left join product on bd_soncode=pr_code";
  62. bd_soncode.SetValueField = new string[] { "bd_soncode" };
  63. bd_soncode.SelectField = "bd_soncode # 子件编号,pr_detail # 物料名称,pr_spec # 物料规格,bd_location # 位号";
  64. bd_soncode.DBTitle = "不良零件";
  65. bd_soncode.DbChange += Prodcode_DbChange;
  66. //nrg_name.BringToFront();
  67. nrg_name.TableName = "(select nrg_name,nrg_code from QUA_NGREASONGROUP left join DATAINPUTRECORD ON NRG_NAME = DIR_COMMENT AND DIR_GROUP = '不良原因组' and DIR_SOURCECODE = '" + User.UserSourceCode + "' ORDER BY NVL(DIR_NUMBER,0) DESC)";
  68. nrg_name.Field = "nrg_name";
  69. nrg_name.ValueField = "nrg_code";
  70. nrg_name.Condition = " 1=1 ORDER BY ROWNUM asc";
  71. nr_name.TableName = "QUA_NGREASONGROUPDET left join QUA_NGREASONGROUP on nrgd_nrgid=nrg_id left join QUA_NGReason on nrgd_nrcode=nr_code left join DATAINPUTRECORD ON nr_name = DIR_COMMENT AND DIR_GROUP = '不良原因' and DIR_SOURCECODE = '" + User.UserSourceCode + "' ";
  72. nr_name.Field = "nr_name";
  73. nr_name.ValueField = "nr_code";
  74. mbr_dutyname.TableName = "(select nd_name,nd_code from ngduty left join DATAINPUTRECORD ON nd_name = DIR_COMMENT AND DIR_GROUP = '责任别' and DIR_SOURCECODE = '" + User.UserSourceCode + "' ORDER BY NVL(DIR_NUMBER,0) DESC) ";
  75. mbr_dutyname.Field = "nd_name";
  76. mbr_dutyname.ValueField = "nd_code";
  77. mbr_dutyname.Condition = " 1=1 ORDER BY ROWNUM asc";
  78. so_name.TableName = "(select so_name,so_code from solution left join DATAINPUTRECORD ON so_name = DIR_COMMENT AND DIR_GROUP = '解决方案' and DIR_SOURCECODE = '" + User.UserSourceCode + "' ORDER BY NVL(DIR_NUMBER,0) DESC)";
  79. so_name.Field = "so_name";
  80. so_name.ValueField = "so_code";
  81. so_name.Condition = " 1=1 ORDER BY ROWNUM asc";
  82. asc.controllInitializeSize(this);
  83. mbc_component.SendToBack();
  84. so_name.SendToBack();
  85. mbl_loc.SendToBack();
  86. bd_soncode.SendToBack();
  87. mbp_partdgv.SendToBack();
  88. mbp_part_label.SendToBack();
  89. dh = SystemInf.dh;
  90. GetSNCode.Focus();
  91. }
  92. private void Prodcode_DbChange(object sender, EventArgs e)
  93. {
  94. Dbfind = bd_soncode.ReturnData;
  95. BaseUtil.SetFormValue(this.Controls, Dbfind);
  96. if (bd_soncode.Text != "")
  97. {
  98. if (mbr_id != "")
  99. {
  100. if (!dh.CheckExist("makebadrspart", "mbp_sncode='" + GetSNCode.Text + "' and mbp_part='" + bd_soncode.Text + "' and mbp_badcode='" + bc_code.Text + "'"))
  101. {
  102. sql.Clear();
  103. sql.Append("insert into makebadrspart(mbp_id,mbp_mbrid,mbp_part,mbp_badcode,");
  104. sql.Append("mbp_brcode,mbp_sncode,mbp_makecode,mbp_indate,mbp_inman)");
  105. sql.Append("select makebadrspart_seq.nextval," + mbr_id + ",'" + bd_soncode.Text + "',");
  106. sql.Append("'" + bc_code.Text + "','" + nr_code.Text + "','" + GetSNCode.Text + "','" + macode + "',");
  107. sql.Append("sysdate,'" + User.UserCode + "' from dual");
  108. dh.ExecuteSql(sql.GetString(), "insert");
  109. DataTable dt = (DataTable)dh.ExecuteSql("select mbp_id,mbp_part from makebadrspart where mbp_mbrid=" + mbr_id, "select");
  110. BaseUtil.FillDgvWithDataTable(mbp_partdgv, dt);
  111. }
  112. }
  113. else OperatResult.AppendText(">>请先选择不良原因\n", Color.Red);
  114. }
  115. else OperatResult.AppendText(">>不良零件不能为空\n", Color.Red);
  116. }
  117. private void Cd_stepcode_DbChange(object sender, EventArgs e)
  118. {
  119. Dbfind = cd_stepcode.ReturnData;
  120. BaseUtil.SetFormValue(this.Controls, Dbfind);
  121. }
  122. private void Cr_code_DbChange(object sender, EventArgs e)
  123. {
  124. Dbfind = cr_code.ReturnData;
  125. BaseUtil.SetFormValue(this.Controls, Dbfind);
  126. }
  127. private void GetSNCode_KeyDown(object sender, KeyEventArgs e)
  128. {
  129. if (e.KeyCode == Keys.Enter)
  130. {
  131. if (GetSNCode.Text == "")
  132. {
  133. OperatResult.AppendText(">>序列号不允许为空\n", Color.Red);
  134. BaseUtil.CleanForm(this);
  135. BadCodeTree.Nodes.Clear();
  136. return;
  137. }
  138. dt = (DataTable)dh.ExecuteSql("select ms_sncode from makeserial where ms_imei1='" + GetSNCode.Text + "' order by ms_id desc", "select");
  139. if (dt.Rows.Count > 0)
  140. {
  141. GetSNCode.Text = dt.Rows[0]["ms_sncode"].ToString();
  142. }
  143. else
  144. {
  145. dt = (DataTable)dh.ExecuteSql("select ms_sncode from makeserial where ms_imei2='" + GetSNCode.Text + "' order by ms_id desc", "select");
  146. if (dt.Rows.Count > 0)
  147. {
  148. GetSNCode.Text = dt.Rows[0]["ms_sncode"].ToString();
  149. }
  150. else
  151. {
  152. dt = (DataTable)dh.ExecuteSql("select mil_sncode from makeimeilist where mil_imei1='" + GetSNCode.Text + "' order by mil_id desc", "select");
  153. if (dt.Rows.Count > 0)
  154. {
  155. GetSNCode.Text = dt.Rows[0]["mil_sncode"].ToString();
  156. }
  157. else
  158. {
  159. dt = (DataTable)dh.ExecuteSql("select mil_sncode from makeimeilist where mil_imei2='" + GetSNCode.Text + "' order by mil_id desc", "select");
  160. if (dt.Rows.Count > 0)
  161. {
  162. GetSNCode.Text = dt.Rows[0]["mil_sncode"].ToString();
  163. }
  164. }
  165. }
  166. }
  167. sql.Clear();
  168. sql.Append("select ms_sncode,ms_status,ms_outboxcode,ms_paststep,ms_reworkstatus,nvl(ms_ifrework,0)ms_ifrework from makeserial left join make ");
  169. sql.Append("on ms_makecode=ma_code where ms_sncode = '" + GetSNCode.Text + "' or ms_firstsn='" + GetSNCode.Text + "' order by ms_id desc");
  170. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  171. if (dt.Rows.Count > 0)
  172. {
  173. GetSNCode.Text = dt.Rows[0]["ms_sncode"].ToString();
  174. string ms_status = dt.Rows[0]["ms_status"].ToString();
  175. ms_paststep = dt.Rows[0]["ms_paststep"].ToString();
  176. ifrework = dt.Rows[0]["ms_ifrework"].ToString();
  177. reworkstatus = dt.Rows[0]["ms_reworkstatus"].ToString();
  178. if (dt.Rows[0]["ms_outboxcode"].ToString() != "")
  179. {
  180. OperatResult.AppendText(">>序列号:" + GetSNCode.Text + "已装箱,请先进行拆箱\n", Color.Red);
  181. BaseUtil.CleanForm(this);
  182. BadCodeTree.Nodes.Clear();
  183. return;
  184. }
  185. //如果不是返修序列号执行原来的步骤
  186. if (ifrework == "0")
  187. {
  188. if (ms_status == "4")
  189. {
  190. OperatResult.AppendText(">>序列号:" + GetSNCode.Text + "已处于报废状态\n", Color.Red);
  191. BaseUtil.CleanForm(this);
  192. BadCodeTree.Nodes.Clear();
  193. return;
  194. }
  195. if (ms_status != "3")
  196. {
  197. OperatResult.AppendText(">>序列号:" + GetSNCode.Text + "不处于维修状态\n", Color.Red);
  198. BaseUtil.CleanForm(this);
  199. BadCodeTree.Nodes.Clear();
  200. return;
  201. }
  202. }
  203. else
  204. {
  205. if (reworkstatus == "4")
  206. {
  207. OperatResult.AppendText(">>序列号:" + GetSNCode.Text + "已处于报废状态\n", Color.Red);
  208. BaseUtil.CleanForm(this);
  209. BadCodeTree.Nodes.Clear();
  210. return;
  211. }
  212. if (reworkstatus != "0" && reworkstatus != "3")
  213. {
  214. OperatResult.AppendText(">>序列号:" + GetSNCode.Text + "不处于维修状态\n", Color.Red);
  215. BaseUtil.CleanForm(this);
  216. BadCodeTree.Nodes.Clear();
  217. return;
  218. }
  219. }
  220. }
  221. else
  222. {
  223. OperatResult.AppendText(">>序列号:" + GetSNCode.Text + "不存在\n", Color.Red);
  224. BaseUtil.CleanForm(this);
  225. BadCodeTree.Nodes.Clear();
  226. return;
  227. }
  228. //dt = (DataTable)dh.ExecuteSql("select mb_stepcode from makebad where mb_sncode='" + GetSNCode.Text + "' and mb_status=0 order by mb_id desc", "select");
  229. ////打不良的资源和当前资源相等可以快速维修,无须登录维修资源
  230. //bool QuickRepair = false;
  231. //if (dt.Rows.Count > 0)
  232. //{
  233. // if (dt.Rows[0]["mb_stepcode"].ToString() == User.CurrentStepCode)
  234. // {
  235. // QuickRepair = true;
  236. // }
  237. //}
  238. string ErrorMessage = "";
  239. //验证工序是否正确
  240. if (LogicHandler.CheckStepAttribute(Tag.ToString(), User.UserSourceCode, out ErrorMessage))
  241. {
  242. BadInf_1.Clear();
  243. string oStatus = "";
  244. if (LogicHandler.GetMakeInfo(GetSNCode.Text, out macode, out oStatus, out ErrorMessage))
  245. {
  246. //验证makeserial或者ms_firstsn表序列号是否存在
  247. sql.Clear();
  248. sql.Append("select max(ms_id) ms_id,ms_makecode,ma_craftcode,ms_stepcode,ms_firstsn,ms_prodcode,ms_sncode,ma_bomversion,pr_detail,ms_craftcode,ms_checkno,ms_ifrework,ms_reworkcheckno ");
  249. sql.Append("from makeserial left join make on ms_makecode=ma_code left join product on pr_code=ms_prodcode where ms_makecode ='" + macode + "' and ms_sncode in(");
  250. sql.Append("select '" + GetSNCode.Text + "' from dual union select firstsn from makesnrelation where ");
  251. sql.Append("sn='" + GetSNCode.Text + "') group by ms_makecode,ms_stepcode,ms_prodcode,ma_craftcode,ms_sncode,ma_bomversion,pr_detail,ms_firstsn,ms_craftcode,ms_checkno,ms_ifrework,ms_reworkcheckno");
  252. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  253. if (dt.Rows.Count > 0)
  254. {
  255. msid = dt.Rows[0]["ms_id"].ToString();
  256. ms_stepcode = dt.Rows[0]["ms_stepcode"].ToString();
  257. BaseUtil.SetFormValue(this.Controls, dt);
  258. //判断是否当前工单途程的上料记录
  259. firstsn = dt.Rows[0]["ms_firstsn"].ToString();
  260. ma_bomversion = dt.Rows[0]["ma_bomversion"].ToString();
  261. string cdstepcode = "";
  262. //sql.Clear();
  263. //sql.Append("select cm_craftcode,cm_stepcode,cm_soncode,min(cm_indate)cm_indate,sum(case when cm_status=-1 ");
  264. //sql.Append("then 0 else 1 end)qty from craftmaterial left join product on pr_code=cm_soncode where(cm_sncode ");
  265. //sql.Append("in (select sn from makesnrelation where firstsn='" + firstsn + "' union select '" + firstsn + "' from dual)) ");
  266. //sql.Append("and cm_craftcode='" + cr_code.Text + "'and nvl(cm_lastdeco,0)<>0 group by cm_craftcode,cm_stepcode,cm_soncode having ");
  267. //sql.Append("sum(case when cm_status=-1 then 0 else 1 end)=0 order by cm_indate");
  268. sql.Clear();
  269. sql.Append("select sp_stepcode cm_stepcode,sp_craftcode cm_craftcode from stepproduct left join product on pr_code=sp_fsoncode where sp_bomversion='" + ma_bomversion + "' and ");
  270. sql.Append("sp_craftcode='" + cr_code.Text + "' And sp_mothercode ='" + ms_prodcode.Text + "' and sp_tracekind=1 ");
  271. //sql.Append("sp_craftcode=v_v_mscraftcode and sp_stepcode='' And sp_mothercode ='"+ms_prodcode.Text+"' and sp_tracekind=1");
  272. sql.Append("and not exists(select 1 from craftmaterial where cm_sncode in (select '" + firstsn + "' from dual union ");
  273. sql.Append("select sn from makesnrelation where firstsn='" + firstsn + "') and cm_makecode='" + macode + "' and ");
  274. sql.Append("cm_fsoncode=sp_fsoncode and cm_status=0) and instr((select ms_paststep from makeserial where ms_firstsn='" + firstsn + "' and ms_makecode='" + macode + "'),sp_stepcode)>0 order by SP_DETNO asc");
  275. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  276. if (dt.Rows.Count > 0)
  277. {
  278. //cdstepcode = dt.Rows[0]["cm_stepcode"].ToString();
  279. //如果本工序包含老化则默认选择本工序,否则选择上料的后一道工序
  280. //if (dh.getFieldDataByCondition("craft left join craftdetail on cr_id=cd_crid", "nvl(cd_ifburnin,0)", "cr_code='" + cr_code.Text + "' and cr_prodcode='" + ms_prodcode.Text + "' and cd_stepcode='" + dt.Rows[0]["cm_stepcode"].ToString() + "'").ToString() != "0")
  281. // cdstepcode = dt.Rows[0]["cm_stepcode"].ToString();
  282. //else
  283. //{
  284. //string nextstep = LogicHandler.GetNextStep(dt.Rows[0]["cm_craftcode"].ToString(), dt.Rows[0]["cm_stepcode"].ToString(), ms_prodcode.Text);
  285. // if (ms_paststep.Contains(nextstep))
  286. // {
  287. // cdstepcode = nextstep;
  288. // }
  289. // else
  290. // {
  291. // cdstepcode = dt.Rows[0]["cm_stepcode"].ToString();
  292. // }
  293. //}
  294. }
  295. else
  296. {
  297. sql.Clear();
  298. sql.Append("select cm_craftcode,cm_stepcode,cm_soncode,min(cm_indate)cm_indate,sum(case when cm_status=-1 ");
  299. sql.Append("then 0 else 1 end)qty from craftmaterial left join product on pr_code=cm_soncode where(cm_sncode ");
  300. sql.Append("in (select sn from makesnrelation where firstsn='" + firstsn + "' union select '" + firstsn + "' from dual)) ");
  301. sql.Append("and cm_craftcode='" + cr_code.Text + "' group by cm_craftcode,cm_stepcode,cm_soncode having ");
  302. sql.Append("sum(case when cm_status=-1 then 0 else 1 end)=0 order by cm_indate");
  303. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  304. if (dt.Rows.Count > 0)
  305. {
  306. cdstepcode = dt.Rows[0]["cm_stepcode"].ToString();
  307. }
  308. }
  309. if (cdstepcode == "")
  310. {
  311. //序号小于等于当前不良的序号
  312. string currentdetno = dh.getFieldDataByCondition("craft left join craftdetail on cr_id=cd_crid", "cd_detno", "cr_code='" + cr_code.Text + "' and cr_prodcode='" + ms_prodcode.Text + "' and cd_stepcode='" + ms_stepcode + "'").ToString();
  313. sql.Clear();
  314. sql.Append("select cd_stepcode from craft left join craftdetail on cr_id =cd_crid where ");
  315. sql.Append("cr_code='" + cr_code.Text + "' and cr_prodcode='" + ms_prodcode.Text + "' and ");
  316. sql.Append("nvl(cd_ifspc,0)<>0 and cd_detno <='" + currentdetno + "' order by cd_detno desc");
  317. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  318. if (dt.Rows.Count > 0)
  319. {
  320. cdstepcode = dt.Rows[0][0].ToString();
  321. }
  322. }
  323. //如果ms_stepcode和扣料工序均没有查到返修的工序
  324. if (cdstepcode == "")
  325. {
  326. string flowback = dh.getFieldDataByCondition("craftdetail left JOIN craft on cr_id = cd_crid", "cd_stepcode", "cr_code= '" + cr_code.Text + "' and cr_prodcode = '" + ms_prodcode.Text + "' and nvl(cd_ifflowback,0)=-1").ToString();
  327. if (flowback != "")
  328. {
  329. cdstepcode = flowback;
  330. }
  331. else
  332. {
  333. cdstepcode = ms_stepcode;
  334. }
  335. }
  336. dt = (DataTable)dh.ExecuteSql("select MB_RETURNSTEP from makebad where mb_sncode='" + GetSNCode.Text + "' and mb_status=0 order by mb_id desc", "select");
  337. if (dt.Rows.Count > 0)
  338. {
  339. if (dt.Rows[0]["MB_RETURNSTEP"].ToString() != "")
  340. {
  341. cdstepcode = dt.Rows[0]["MB_RETURNSTEP"].ToString();
  342. }
  343. }
  344. cd_stepcode.Text = cdstepcode;
  345. cd_stepcode.Condition = "ST_STATUSCODE='AUDITED' and cr_code='" + cr_code.Text + "' and cr_prodcode='" + ms_prodcode.Text + "' and instr('"+ ms_paststep + "',cd_stepcode)>0 order by cd_stepno";
  346. //if (dh.getFieldDataByCondition("craftdetail left JOIN craft on cr_id = cd_crid", "nvl(cd_ifinput,0)cd_ifinput", "cr_code= '" + cr_code.Text + "' and cr_prodcode = '" + ms_prodcode.Text + "' and cd_stepcode = '" + cd_stepcode.Text + "'").ToString() == "-1")
  347. // cd_stepcode.Enabled = false;
  348. //else
  349. // cd_stepcode.Enabled = true;
  350. LoadBadInfTree(sender, e);
  351. }
  352. else OperatResult.AppendText(">>" + ErrorMessage + "\n", Color.Red);
  353. }
  354. else OperatResult.AppendText(">>" + ErrorMessage + "\n", Color.Red);
  355. }
  356. else OperatResult.AppendText(">>" + ErrorMessage + "\n", Color.Red);
  357. }
  358. }
  359. private void Make_Repair_SizeChanged(object sender, EventArgs e)
  360. {
  361. mbc_component.BringToFront();
  362. so_name.BringToFront();
  363. mbl_loc.BringToFront();
  364. bd_soncode.BringToFront();
  365. mbp_partdgv.BringToFront();
  366. mbp_part_label.BringToFront();
  367. asc.controlAutoSize(this);
  368. mbc_component.SendToBack();
  369. so_name.SendToBack();
  370. mbl_loc.SendToBack();
  371. bd_soncode.SendToBack();
  372. mbp_partdgv.SendToBack();
  373. mbp_part_label.SendToBack();
  374. }
  375. private void BadCodeTree_NodeMouseClick(object sender, TreeNodeMouseClickEventArgs e)
  376. {
  377. if (e.Node.Level == 0)
  378. {
  379. mb_id = e.Node.Tag.ToString();
  380. BaseUtil.CleanControlsText(bc_name, bc_code, bg_name, bg_code, mb_badremark, nrg_name, nrg_code, nr_name, nr_code, so_name, so_code, mbr_dutyname, mbr_dutycode, mbc_component);
  381. mbl_locdgv.DataSource = null;
  382. mbp_partdgv.DataSource = null;
  383. bc_name.Text = BadInf_1[mb_id]["bc_name"];
  384. bc_code.Text = BadInf_1[mb_id]["mb_badcode"];
  385. bg_name.Text = BadInf_1[mb_id]["bg_name"];
  386. bg_code.Text = BadInf_1[mb_id]["mb_bgcode"];
  387. mb_badremark.Text = BadInf_1[mb_id]["mb_badremark"];
  388. mbr_id = "";
  389. SaveRepairInf.Enabled = true;
  390. }
  391. if (e.Node.Level == 1)
  392. {
  393. //展示父节点信息
  394. mb_id = e.Node.Parent.Tag.ToString();
  395. bc_code.Text = BadInf_1[mb_id]["mb_badcode"];
  396. bc_name.Text = BadInf_1[mb_id]["bc_name"];
  397. bg_code.Text = BadInf_1[mb_id]["mb_bgcode"];
  398. bg_name.Text = BadInf_1[mb_id]["bg_name"];
  399. //展示子节点信息
  400. mbr_id = e.Node.Tag.ToString();
  401. nrg_code.Text = BadInf_2[mbr_id]["nrg_code"];
  402. nrg_name.Text = BadInf_2[mbr_id]["nrg_name"];
  403. nr_code.Text = BadInf_2[mbr_id]["nr_code"];
  404. nr_name.Text = BadInf_2[mbr_id]["nr_name"];
  405. so_code.Text = BadInf_2[mbr_id]["so_code"];
  406. so_name.Text = BadInf_2[mbr_id]["so_name"];
  407. mbr_dutycode.Text = BadInf_2[mbr_id]["mbr_dutycode"];
  408. mbr_dutyname.Text = BadInf_2[mbr_id]["mbr_dutyname"];
  409. mbc_component.Text = dh.getFieldDataByCondition("makebadrscom", "mbc_component", "mbc_mbrid=" + mbr_id).ToString();
  410. //加载两个Grid的数据源
  411. DataTable dt = (DataTable)dh.ExecuteSql("select mbp_id,mbp_part from makebadrspart where mbp_mbrid=" + mbr_id, "select");
  412. BaseUtil.FillDgvWithDataTable(mbp_partdgv, dt);
  413. dt = (DataTable)dh.ExecuteSql("select mbl_id,mbl_loc from makebadrsloc where mbl_mbrid=" + mbr_id, "select");
  414. BaseUtil.FillDgvWithDataTable(mbl_locdgv, dt);
  415. SaveRepairInf.Enabled = false;
  416. }
  417. }
  418. private void LoadBadInfTree(object sender, EventArgs e)
  419. {
  420. BadCodeTree.Nodes.Clear();
  421. sql.Clear();
  422. //不是返工工单时的取当前工单
  423. sql.Append("select mb_id,mb_sncode,mb_badcode,mb_bgcode,nvl(bc_name,mb_badcode) bc_name,nvl(bg_name,mb_bgcode) bg_name,");
  424. sql.Append("mb_badremark from makebad left join badcode on bc_code=mb_badcode left join badgroup ");
  425. sql.Append("on bg_code=mb_bgcode where (mb_sncode='" + (GetSNCode.Text == "" ? ms_sncode.Text : GetSNCode.Text) + "' or mb_mscode='" + (GetSNCode.Text == "" ? ms_sncode.Text : GetSNCode.Text) + "' ) and mb_makecode='" + macode + "' and mb_status=0");
  426. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  427. if (dt.Rows.Count == 0)
  428. {
  429. sql.Clear();
  430. sql.Append("select mb_id,mb_sncode,mb_badcode,mb_bgcode,nvl(bc_name,mb_badcode) bc_name,nvl(bg_name,mb_bgcode) bg_name, ");
  431. sql.Append("mb_badremark from makebad left join badcode on bc_code=mb_badcode left join badgroup on bg_code=mb_bgcode ");
  432. sql.Append("left join make on ma_code=mb_makecode where mb_sncode='" + (GetSNCode.Text == "" ? ms_sncode.Text : GetSNCode.Text) + "' and mb_makecode<>'" + macode + "' and mb_status=0");
  433. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  434. }
  435. for (int i = 0; i < dt.Rows.Count; i++)
  436. {
  437. //添加根节点
  438. TreeNode tnode_0 = new TreeNode();
  439. string bg_name = dt.Rows[i]["bg_name"].ToString();
  440. string bc_name = dt.Rows[i]["bc_name"].ToString();
  441. string mb_badcode = dt.Rows[i]["mb_badcode"].ToString();
  442. string mb_bgcode = dt.Rows[i]["mb_bgcode"].ToString();
  443. tnode_0.Text = (bg_name == "" ? mb_bgcode : bg_name) + ":" + (bc_name == "" ? mb_bgcode : bc_name);
  444. tnode_0.Name = dt.Rows[i]["mb_bgcode"].ToString();
  445. //作为Dictionary的主标识
  446. string mb_id = dt.Rows[i]["mb_id"].ToString();
  447. tnode_0.Tag = mb_id;
  448. Dictionary<string, string> dic = new Dictionary<string, string>();
  449. dic.Add("mb_id", mb_id);
  450. dic.Add("mb_sncode", dt.Rows[i]["mb_sncode"].ToString());
  451. dic.Add("mb_badcode", dt.Rows[i]["mb_badcode"].ToString());
  452. dic.Add("mb_bgcode", dt.Rows[i]["mb_bgcode"].ToString());
  453. dic.Add("bc_name", dt.Rows[i]["bc_name"].ToString());
  454. dic.Add("bg_name", dt.Rows[i]["bg_name"].ToString());
  455. dic.Add("mb_badremark", dt.Rows[i]["mb_badremark"].ToString());
  456. if (!BadInf_1.ContainsKey(tnode_0.Tag.ToString()))
  457. BadInf_1.Add(tnode_0.Tag.ToString(), dic);
  458. BadCodeTree.Nodes.Add(tnode_0);
  459. BadCodeTree.SelectedNode = BadCodeTree.Nodes[0];
  460. //添加子节点
  461. sql.Clear();
  462. sql.Append("select mbr_id,mbr_brcode,mbr_brgcode,mbr_solutioncode,so_code,so_name,mbr_dutycode,mbr_dutyname,nd_name,nrg_name");
  463. sql.Append(",nr_name,nr_code,nrg_code from makebadreason left join QUA_NGReason on nr_code=mbr_brcode left join ");
  464. sql.Append("QUA_NGREASONGROUPdet on nrgd_nrcode=nr_code left join QUA_NGREASONGROUP on nrg_id=nrgd_nrgid and ");
  465. sql.Append("mbr_brgcode=nrg_code left join solution on so_code=mbr_solutioncode left join ngduty on nd_code=mbr_dutycode ");
  466. sql.Append("where mbr_mbid=" + mb_id);
  467. DataTable dt1 = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  468. for (int j = 0; j < dt1.Rows.Count; j++)
  469. {
  470. TreeNode tnode_1 = new TreeNode();
  471. //存放子节点的信息
  472. Dictionary<string, string> dic1 = new Dictionary<string, string>();
  473. string mbr_id = dt1.Rows[j]["mbr_id"].ToString();
  474. tnode_1.Tag = mbr_id;
  475. dic1.Add("mbr_id", mbr_id);
  476. dic1.Add("mbr_brcode", dt1.Rows[j]["mbr_id"].ToString());
  477. dic1.Add("mbr_brgcode", dt1.Rows[j]["mbr_brcode"].ToString());
  478. dic1.Add("mbr_solutioncode", dt1.Rows[j]["mbr_solutioncode"].ToString());
  479. dic1.Add("mbr_dutycode", dt1.Rows[j]["mbr_dutycode"].ToString());
  480. dic1.Add("mbr_dutyname", dt1.Rows[j]["mbr_dutyname"].ToString());
  481. dic1.Add("nd_name", dt1.Rows[j]["nd_name"].ToString());
  482. dic1.Add("so_name", dt1.Rows[j]["so_name"].ToString());
  483. dic1.Add("so_code", dt1.Rows[j]["so_code"].ToString());
  484. dic1.Add("nrg_name", dt1.Rows[j]["nrg_name"].ToString());
  485. dic1.Add("nrg_code", dt1.Rows[j]["nrg_code"].ToString());
  486. dic1.Add("nr_name", dt1.Rows[j]["nr_name"].ToString());
  487. dic1.Add("nr_code", dt1.Rows[j]["nr_code"].ToString());
  488. tnode_1.Text = dt1.Rows[j]["nr_name"].ToString();
  489. if (!BadInf_2.ContainsKey(mbr_id))
  490. BadInf_2.Add(mbr_id, dic1);
  491. tnode_0.Nodes.Add(tnode_1);
  492. }
  493. }
  494. try
  495. {
  496. if (bg_code.Text != "")
  497. BadCodeTree.Nodes[bg_code.Text].Expand();
  498. }
  499. catch (Exception) { }
  500. }
  501. private void RefreshTreeView_Click(object sender, EventArgs e)
  502. {
  503. LoadBadInfTree(sender, e);
  504. }
  505. private void RepairComplete_Click(object sender, EventArgs e)
  506. {
  507. if (ms_sncode.Text == "")
  508. {
  509. OperatResult.AppendText(">>序列号不允许为空\n", Color.Red);
  510. return;
  511. }
  512. if (ifrework != "0" && reworkstatus == "0")
  513. {
  514. if (dh.getRowCount("Makebad", "mb_sncode='" + ms_sncode.Text + "' and mb_makecode='" + ms_makecode.Text + "' and mb_status=0") == 0)
  515. {
  516. OperatResult.AppendText(">>维修必须维护不良代码\n", Color.Red);
  517. return;
  518. }
  519. }
  520. //判断是否所有的不良信息都有维护不良原因
  521. DataTable dt = (DataTable)dh.ExecuteSql("select mb_id,bc_name,mbr_mbid from makebad left join makebadreason on mbr_mbid=mb_id left join badcode on mb_badcode=bc_code where mb_sncode='" + ms_sncode.Text + "' and mb_makecode='" + ms_makecode.Text + "' and mb_status=0", "select");
  522. string ErrorMessage = "";
  523. for (int i = 0; i < dt.Rows.Count; i++)
  524. {
  525. if (dt.Rows[i]["mb_id"].ToString() != dt.Rows[i]["mbr_mbid"].ToString())
  526. ErrorMessage += "【" + dt.Rows[i]["bc_name"].ToString() + "】";
  527. }
  528. if (ErrorMessage != "")
  529. {
  530. OperatResult.AppendText(">>" + ErrorMessage + "未维护不良原因\n", Color.Red);
  531. return;
  532. }
  533. //如果岗位资源对应工序的版面不为空的时候
  534. if (dh.getFieldDataByCondition("makeserial left join step on ms_stepcode=st_code", "st_table", "ms_id='" + msid + "'").ToString() != "")
  535. {
  536. if (!dh.CheckExist("makebadrsloc", "mbl_mbrid='" + mbr_id + "' and mbl_makecode='" + ms_makecode.Text + "' and mbl_sncode='" + GetSNCode.Text + "' "))
  537. {
  538. OperatResult.AppendText(">>工序存在版面必须维护不良位置\n", Color.Red);
  539. return;
  540. }
  541. }
  542. sql.Clear();
  543. sql.Append("select max(pr_lightbox)pr_lightbox,sp_id,max(sp_detno)sp_detno,min(sp_ifrepeat)sp_ifrepeat,max(sp_checkbarcode)sp_checkbarcode,min(sp_checksalecode)sp_checksalecode,");
  544. sql.Append("sp_fsoncode,max(sp_barcoderule)sp_barcoderule,wm_concat(sp_soncode) sp_soncode,max(sp_ifuseregex)sp_ifuseregex,max(sp_ifforsn)");
  545. sql.Append("sp_ifforsn,max(sp_length)sp_length,max(sp_type)sp_type,replace(wm_concat(sp_prefix),',','|')sp_prefix,max(sp_regex)");
  546. sql.Append("sp_regex,max(pr_detail)pr_detail,max(substr(pr_spec,0,20))pr_spec from stepproduct left join product on pr_code=sp_fsoncode where ");
  547. sql.Append("sp_bomversion='" + ma_bomversion + "' and sp_craftcode='" + cr_code.Text + "' and instr('" + ms_paststep + "',sp_stepcode)>0 ");
  548. sql.Append("And sp_mothercode ='" + ms_prodcode.Text + "' and sp_tracekind=1 and nvl(pr_prodtype,' ')<>'包装物料' and not exists(select 1 from craftmaterial left join makematerial on cm_makecode=mm_code and (cm_fsoncode=mm_prodcode or instr(mm_repprodcode,cm_fsoncode)>0) where ");
  549. sql.Append("cm_sncode in (select '" + firstsn + "' from dual union select sn from makesnrelation where firstsn='" + firstsn + "') and cm_makecode='" + ms_makecode.Text + "' and ");
  550. sql.Append("(sp_fsoncode=mm_prodcode or sp_fsoncode=mm_repprodcode or cm_fsoncode=sp_fsoncode) and cm_status=0 and cm_stepcode=sp_stepcode) group by sp_fsoncode,sp_id order by SP_DETNO asc");
  551. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  552. //查询拆解的物料
  553. //sql.Clear();
  554. //sql.Append("select distinct cm_soncode,pr_detail from craftmaterial left join product on pr_code=cm_fsoncode where cm_sncode in (select '" + firstsn + "' from dual union ");
  555. //sql.Append("select sn from makesnrelation where firstsn='" + firstsn + "') and nvl(pr_prodtype,' ')<>'包装物料' and cm_craftcode='" + cr_code.Text + "' and cm_makecode='" + ms_makecode.Text + "' and cm_status=-1 ");
  556. //dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  557. ////如果含有序列号物料有被拆解过
  558. if (dt.Rows.Count > 0)
  559. {
  560. string prdetail = "";
  561. for (int i = 0; i < dt.Rows.Count; i++)
  562. {
  563. prdetail += "'" + dt.Rows[i]["pr_detail"].ToString() + "',";
  564. }
  565. OperatResult.AppendText(">>" + prdetail.Replace("'", "") + "物料尚未备料,不允许回流\n", Color.Red);
  566. return;
  567. }
  568. dt = (DataTable)dh.ExecuteSql("select cr_id from craft where cr_statuscode='AUDITED' and cr_code='" + cr_code.Text + "' and cr_prodcode='"+ms_prodcode.Text+"'", "select");
  569. if (dt.Rows.Count == 0)
  570. OperatResult.AppendText(">>回流工序不存在\n", Color.Red);
  571. else
  572. {
  573. string cr_id = dt.Rows[0]["cr_id"].ToString();
  574. dt = (DataTable)dh.ExecuteSql("select cd_ifinput from craftdetail left join step on st_code=cd_stepcode where cd_crid='" + cr_id + "' and cd_stepcode='" + cd_stepcode.Text + "' and st_statuscode='AUDITED'", "select");
  575. if (dt.Rows.Count == 0)
  576. OperatResult.AppendText(">>回流工序不在回流工艺中\n", Color.Red);
  577. else
  578. {
  579. dt = dh.getFieldsDataByCondition("makeserial", new string[] { "nvl(ms_ifrework,0) ms_ifrework", "ms_paststep" }, "ms_sncode='" + ms_sncode.Text + "' and ms_makecode='" + macode + "'");
  580. List<string> SQLS = new List<string>();
  581. if (dt.Rows.Count > 0)
  582. {
  583. string ms_ifrework = dt.Rows[0]["ms_ifrework"].ToString();
  584. string ms_paststep = dt.Rows[0]["ms_paststep"].ToString();
  585. //如果回流的执行过的工序为空
  586. if (!ms_paststep.Contains(cd_stepcode.Text) && ms_paststep != "")
  587. {
  588. OperatResult.AppendText(">>不允许回流到未执行的工序\n", Color.Red);
  589. return;
  590. }
  591. if (ms_ifrework == "0")
  592. SQLS.Add("update makeserial set ms_checkno='',ms_paststep = ms_paststep || case when instr(','||ms_paststep||',','" + User.CurrentStepCode + "')=0 then ','||'" + User.CurrentStepCode + "' end , ms_nextstepcode ='" + cd_stepcode.Text + "',ms_craftcode='" + cr_code.Text + "',ms_stepcode='" + User.CurrentStepCode + "',ms_status=1,ms_qccheck=-1 where ms_id='" + msid + "'");
  593. else
  594. SQLS.Add("update makeserial set ms_checkno='',ms_paststep = ms_paststep || case when instr(','||ms_paststep||',','" + User.CurrentStepCode + "')=0 then ','||'" + User.CurrentStepCode + "' end , ms_nextstepcode ='" + cd_stepcode.Text + "',ms_craftcode='" + cr_code.Text + "',ms_stepcode='" + User.CurrentStepCode + "',ms_reworkstatus=1,ms_qccheck=-1 where ms_id='" + msid + "'");
  595. }
  596. SQLS.Add("update makebad set mb_status=-1 where (mb_sncode='" + ms_sncode.Text + "' or mb_mscode='" + ms_sncode.Text + "') and mb_makecode='" + ms_makecode.Text + "'");
  597. //取消最近拆解部件
  598. SQLS.Add("update craftmaterial set cm_lastdeco=0 where cm_sncode='" + ms_sncode.Text + "' and cm_makecode='" + ms_makecode.Text + "' and nvl(cm_lastdeco,0)<>0");
  599. // SQLS.Add("update MakeBadCount set mbc_status=-1 where mbc_sncode='" + ms_sncode.Text + "'");
  600. dh.ExecuteSQLTran(SQLS.ToArray());
  601. LogicHandler.InsertMakeProcess(ms_sncode.Text, ms_makecode.Text, User.UserSourceCode, "回流工序", "完成维修回流", User.UserCode);
  602. LogicHandler.DoCommandLog(Tag.ToString(), User.UserCode, macode, User.UserLineCode, User.UserSourceCode, "回流工序", "完成维修回流", ms_sncode.Text, ms_checkno.Text);
  603. OperatResult.AppendText(">>序列号" + ms_sncode.Text + "回流成功\n", Color.Green);
  604. cd_stepcode.Enabled = true;
  605. BaseUtil.CleanForm(this);
  606. BadCodeTree.Nodes.Clear();
  607. GetSNCode.Clear();
  608. GetSNCode.Focus();
  609. }
  610. }
  611. }
  612. private void Scrap_Click(object sender, EventArgs e)
  613. {
  614. if (ms_sncode.Text != "")
  615. {
  616. //判断是否有无法维修的记录
  617. int ScrapNum = int.Parse(dh.getFieldDataByCondition("makebadreason left join makebad on mb_id=mbr_mbid", "count(0) cn", "mb_sncode='" + ms_sncode.Text + "' and mb_status=0").ToString());
  618. if (ScrapNum == 0)
  619. OperatResult.AppendText(">>" + ms_sncode.Text + "报废必须维护不良原因\n", Color.Red);
  620. else
  621. {
  622. string confirm = MessageBox.Show(this.ParentForm, "此操作不可撤销,是否确认报废", "提示", MessageBoxButtons.YesNo, MessageBoxIcon.Asterisk).ToString();
  623. if (confirm == "Yes")
  624. {
  625. DataTable dt = dh.getFieldsDataByCondition("makeserial", new string[] { "nvl(ms_ifrework,0)ms_ifrework", "ms_reworkcode" }, "ms_sncode='" + ms_sncode.Text + "' and ms_makecode='" + macode + "'");
  626. if (dt.Rows.Count > 0)
  627. {
  628. string ms_ifrework = dt.Rows[0]["ms_ifrework"].ToString();
  629. string reworkcode = dt.Rows[0]["ms_reworkcode"].ToString();
  630. if (ms_ifrework == "0")
  631. {
  632. dh.UpdateByCondition("makeserial", "ms_paststep = ms_paststep ||'," + User.CurrentStepCode + "',ms_status=4,ms_nextstepcode='',ms_stepcode='" + User.CurrentStepCode + "'", "ms_sncode='" + ms_sncode.Text + "' and ms_makecode='" + macode + "'");
  633. }
  634. else
  635. {
  636. sqls.Clear();
  637. sqls.Add("update makeserial set ms_paststep = ms_paststep ||'," + User.CurrentStepCode + "',ms_status=4,ms_reworkstatus= 4,ms_nextstepcode='',ms_stepcode='" + User.CurrentStepCode + "' where ms_sncode='" + ms_sncode.Text + "' and ms_makecode='" + macode + "'");
  638. sqls.Add("update oqcbatch set ob_nowcheckqty=ob_nowcheckqty-1 where ob_checkno='" + ms_reworkcheckno.Text + "'");
  639. sqls.Add("delete from oqcbatchdetail where obd_sncode='" + ms_sncode.Text + "' and obd_checkno='" + ms_reworkcheckno.Text + "'");
  640. sqls.Add("update ReworkDetail set rd_rwstatus='报废' where rd_reid=(select re_id from rework where re_code='" + reworkcode + "') and rd_sncode='" + reworkcode + "'");
  641. dh.ExecuteSQLTran(sqls.ToArray());
  642. }
  643. }
  644. dh.UpdateByCondition("makecraftdetail", "mcd_inqty=mcd_inqty-1,mcd_outqty=mcd_outqty-1", "mcd_macode='" + ms_makecode.Text + "' and mcd_stepcode='" + ms_stepcode + "'");
  645. dh.UpdateByCondition("make", "MA_NGMADEQTY=nvl(MA_NGMADEQTY,0)+1", "ma_code='" + macode + "'");
  646. LogicHandler.InsertMakeProcess(ms_sncode.Text, ms_makecode.Text, User.UserSourceCode, "报废", "序列号报废", User.UserCode);
  647. LogicHandler.DoCommandLog(Tag.ToString(), User.UserCode, macode, User.UserLineCode, User.UserSourceCode, "报废", "序列号报废", ms_sncode.Text, ms_checkno.Text);
  648. OperatResult.AppendText(">>报废成功\n", Color.Green);
  649. GetSNCode.Clear();
  650. BaseUtil.CleanForm(this);
  651. BadCodeTree.Nodes.Clear();
  652. }
  653. }
  654. }
  655. else OperatResult.AppendText(">>序列号不允许为空\n", Color.Red);
  656. }
  657. private void NewBadCode_Click(object sender, EventArgs e)
  658. {
  659. if (GetSNCode.Text == "" || macode == null || macode == "")
  660. {
  661. OperatResult.AppendText(">>序列号和工单号不允许为空\n", Color.Red);
  662. }
  663. else
  664. {
  665. Make_NewBadCode badcode = new Make_NewBadCode(GetSNCode.Text, macode);
  666. badcode.FormClosed += LoadBadInfTree;
  667. BaseUtil.SetFormCenter(badcode);
  668. badcode.ShowDialog();
  669. }
  670. }
  671. private void NewRepairInf_Click(object sender, EventArgs e)
  672. {
  673. if (bg_name.Text == "" && bc_name.Text == "")
  674. {
  675. OperatResult.AppendText(">>不良代码组和不良代码不能为空\n", Color.Red);
  676. }
  677. else
  678. {
  679. Make_NewMatainInf mataininf = new Make_NewMatainInf(bg_name.Text, bg_code.Text, bc_name.Text, bc_code.Text, GetSNCode.Text, msid, mb_id);
  680. mataininf.FormClosed += LoadBadInfTree;
  681. BaseUtil.SetFormCenter(mataininf);
  682. mataininf.ShowDialog();
  683. }
  684. }
  685. private void SaveRepairInf_Click(object sender, EventArgs e)
  686. {
  687. string ErrorMessage = "";
  688. if (bg_name.Text == "" || bc_name.Text == "")
  689. {
  690. OperatResult.AppendText(">>不良代码组和不良代码不能为空\n", Color.Red);
  691. return;
  692. }
  693. if (nrg_name.Text == "")
  694. ErrorMessage += " 不良原因组 ";
  695. if (nr_name.Text == "")
  696. ErrorMessage += " 不良原因 ";
  697. if (mbr_dutyname.Text == "")
  698. ErrorMessage += " 责任别 ";
  699. if (mbr_dutyname.Text == "物料问题" && mbc_component.Text == "")
  700. ErrorMessage += "责任别为物料问题时必须选择不良零件";
  701. if (ErrorMessage != "")
  702. {
  703. ErrorMessage += "不能为空";
  704. OperatResult.AppendText(">>" + ErrorMessage + "\n", Color.Red);
  705. return;
  706. }
  707. string mbr_id = dh.GetSEQ("makebadreason_seq");
  708. //存在不良组件进行提示
  709. if (dh.CheckExist("makebadreason left join makebad on mbr_mbid=mb_id and mbr_sncode=mb_sncode", "mbr_badcode='" + bc_code.Text + "' and mbr_sncode='" + ms_sncode.Text + "' and mbr_brcode='" + nr_code.Text + "' and mb_status=0"))
  710. {
  711. OperatResult.AppendText(">>不良代码【" + bc_name.Text + "】已存在不良原因【" + nr_name.Text + "】\n", Color.Red);
  712. return;
  713. }
  714. if (!dh.CheckExist("QUA_NGREASONGROUP", "nrg_name='" + nrg_name.Text + "'"))
  715. {
  716. OperatResult.AppendText(">>不良原因组不存在\n", Color.Red);
  717. return;
  718. }
  719. if (!dh.CheckExist("QUA_NGReason", "nr_name='" + nr_name.Text + "'"))
  720. {
  721. OperatResult.AppendText(">>不良原因不存在\n", Color.Red);
  722. return;
  723. }
  724. if (!dh.CheckExist("ngduty", "nd_name='" + mbr_dutyname.Text + "'"))
  725. {
  726. OperatResult.AppendText(">>责任别不存在\n", Color.Red);
  727. return;
  728. }
  729. if (!dh.CheckExist("solution", "so_name='" + so_name.Text + "'"))
  730. {
  731. OperatResult.AppendText(">>解决方案不存在\n", Color.Red);
  732. return;
  733. }
  734. //保存选择记录至后台,根据岗位资源代码记录
  735. dh.ExecuteSql("merge into DATAINPUTRECORD using (select NRG_NAME from QUA_NGREASONGROUP where NRG_NAME = '" + nrg_name.Text + "') ON (NRG_NAME = DIR_COMMENT AND DIR_GROUP = '不良原因组' and DIR_SOURCECODE = '" + User.UserSourceCode + "') when matched then update set DIR_NUMBER = DIR_NUMBER +1 when not matched then insert (DIR_COMMENT,DIR_NUMBER,DIR_SOURCECODE,DIR_GROUP) VALUES (NRG_NAME,1,'" + User.UserSourceCode + "','不良原因组')", "select");
  736. dh.ExecuteSql("merge into DATAINPUTRECORD using (select nr_name from QUA_NGReason left join QUA_NGREASONGROUPDET on nrgd_nrcode=nr_code left join QUA_NGREASONGROUP on nrgd_nrgid=nrg_id where nr_name = '" + nr_name.Text + "' and NRG_NAME = '" + nrg_name.Text + "') ON (nr_name = DIR_COMMENT AND DIR_GROUP = '不良原因' and DIR_SOURCECODE = '" + User.UserSourceCode + "') when matched then update set DIR_NUMBER = DIR_NUMBER +1 when not matched then insert (DIR_COMMENT,DIR_NUMBER,DIR_SOURCECODE,DIR_GROUP) VALUES (nr_name,1,'" + User.UserSourceCode + "','不良原因')", "select");
  737. dh.ExecuteSql("merge into DATAINPUTRECORD using (select nd_name from ngduty where nd_name = '" + mbr_dutyname.Text + "') ON (nd_name = DIR_COMMENT AND DIR_GROUP = '责任别' and DIR_SOURCECODE = '" + User.UserSourceCode + "') when matched then update set DIR_NUMBER = DIR_NUMBER +1 when not matched then insert (DIR_COMMENT,DIR_NUMBER,DIR_SOURCECODE,DIR_GROUP) VALUES (nd_name,1,'" + User.UserSourceCode + "','责任别')", "select");
  738. dh.ExecuteSql("merge into DATAINPUTRECORD using (select so_name from solution where so_name = '" + so_name.Text + "') ON (so_name = DIR_COMMENT AND DIR_GROUP = '解决方案' and DIR_SOURCECODE = '" + User.UserSourceCode + "') when matched then update set DIR_NUMBER = DIR_NUMBER +1 when not matched then insert (DIR_COMMENT,DIR_NUMBER,DIR_SOURCECODE,DIR_GROUP) VALUES (so_name,1,'" + User.UserSourceCode + "','解决方案')", "select");
  739. //保存不良原因
  740. sql.Clear();
  741. sql.Append("insert into makebadreason (mbr_mbid,mbr_id,mbr_brcode,mbr_solutioncode,");
  742. sql.Append("mbr_dutycode,mbr_brgcode,mbr_badcode,mbr_sncode,mbr_makecode,mbr_indate,");
  743. sql.Append("mbr_inman,mbr_brname,mbr_solutionname,mbr_badname,mbr_brgname,mbr_dutyname,mbr_remark) select '" + mb_id + "','" + mbr_id + "','" + nr_code.Text + "',");
  744. sql.Append("'" + so_code.Text + "','" + mbr_dutyname.Text + "','" + nrg_code.Text + "','" + bc_code.Text + "',");
  745. sql.Append("'" + ms_sncode.Text + "','" + ms_makecode.Text + "',sysdate,'" + User.UserCode + "','" + nr_name.Text + "','" + so_name.Text + "','" + bc_name.Text + "','" + nrg_name.Text + "','" + mbr_dutyname.Text + "','" + mb_badremark.Text + "' from dual");
  746. dh.ExecuteSql(sql.GetString(), "insert");
  747. if (mbc_component.Text != "")
  748. {
  749. sql.Clear();
  750. sql.Append("insert into makebadrscom (mbc_id,mbc_mbrid,mbc_component,mbc_badcode,");
  751. sql.Append("mbc_brcode,mbc_sncode,mbc_makecode,mbc_indate,mbc_inman ) values ");
  752. sql.Append("(makebadrscom_seq.nextval,'" + mbr_id + "' ,'" + mbc_component.Text + "',");
  753. sql.Append("'" + bc_code.Text + "','" + nr_code.Text + "','" + ms_sncode.Text + "','" + ms_makecode.Text + "',sysdate,'" + User.UserCode + "')");
  754. dh.ExecuteSql(sql.GetString(), "insert");
  755. }
  756. OperatResult.AppendText(">>不良原因保存成功\n", Color.Green);
  757. SaveRepairInf.Enabled = false;
  758. LoadBadInfTree(sender, e);
  759. }
  760. private void DeleteRepairInf_Click(object sender, EventArgs e)
  761. {
  762. DataTable dt = (DataTable)dh.ExecuteSql("select ms_makecode from makeserial where ms_id='" + msid + "' and ms_sncode='" + GetSNCode.Text + "' and ms_status=3", "select");
  763. if (dt.Rows.Count > 0)
  764. {
  765. if (mbr_id != "")
  766. {
  767. string delete1 = "delete from makebadrsloc where mbl_mbrid='" + mbr_id + "'";
  768. string delete2 = "delete from makebadrspart where mbp_mbrid='" + mbr_id + "'";
  769. string delete3 = "delete from makebadrscom where mbc_mbrid='" + mbr_id + "'";
  770. string delete4 = "delete from makebadreason where mbr_id='" + mbr_id + "'";
  771. dh.ExecuteSQLTran(delete1, delete2, delete3, delete4);
  772. OperatResult.AppendText(">>删除成功\n", Color.Green);
  773. BaseUtil.CleanControlsText(bc_name, bc_code, bg_name, bg_code, mb_badremark, nrg_name, nrg_code, nr_name, nr_code, so_name, so_code, mbr_dutyname, mbr_dutycode, mbc_component);
  774. mbp_partdgv.DataSource = null;
  775. mbl_locdgv.DataSource = null;
  776. mbr_id = "";
  777. //删除后重新加载Tree的信息
  778. LoadBadInfTree(sender, e);
  779. }
  780. else OperatResult.AppendText(">>必须选择不良原因\n", Color.Red);
  781. }
  782. else OperatResult.AppendText(">>" + GetSNCode.Text + "序列号错误,不存在或者不处于维修状态\n", Color.Red);
  783. }
  784. private void SaveBadLocation_Click(object sender, EventArgs e)
  785. {
  786. DataTable dt = (DataTable)dh.ExecuteSql("select ms_makecode from makeserial where ms_id='" + msid + "' and ms_sncode='" + GetSNCode.Text + "' and ms_status=3", "select");
  787. if (dt.Rows.Count > 0)
  788. {
  789. if (mbl_loc.Text != "")
  790. {
  791. if (mbr_id != "")
  792. {
  793. if (!dh.CheckExist("makebadrsloc", "mbl_mbrid='" + mbr_id + "' and mbl_sncode='" + GetSNCode.Text + "' and mbl_loc='" + mbl_loc.Text.ToUpper() + "'"))
  794. {
  795. sql.Clear();
  796. sql.Append("insert into makebadrsloc(mbl_id,mbl_mbrid,mbl_loc,mbl_badcode,mbl_brcode,");
  797. sql.Append("mbl_sncode,mbl_makecode,mbl_indate ,mbl_inman) select makebadrsloc_seq.nextval," + mbr_id);
  798. sql.Append(",'" + mbl_loc.Text.ToUpper() + "','" + bc_code.Text + "','" + nr_code.Text + "','" + GetSNCode.Text + "','" + macode + "',");
  799. sql.Append("sysdate,'" + User.UserCode + "' from dual");
  800. dh.ExecuteSql(sql.GetString(), "insert");
  801. dt = (DataTable)dh.ExecuteSql("select mbl_id,mbl_loc from makebadrsloc where mbl_mbrid=" + mbr_id, "select");
  802. BaseUtil.FillDgvWithDataTable(mbl_locdgv, dt);
  803. sql.Clear();
  804. sql.Append("with temp1 as (select bd_soncode,bd_location from bomdetail,bom where bo_id=bd_bomid ");
  805. sql.Append(" start with bo_mothercode='" + ms_prodcode.Text + "' connect by bo_mothercode= prior bd_soncode) ");
  806. sql.Append("select bd_soncode from temp1 where instr(','||bd_location||',','," + mbl_loc.Text.ToUpper() + ",')>0");
  807. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  808. if (dt.Rows.Count > 0)
  809. {
  810. sql.Clear();
  811. sql.Append("insert into makebadrspart(mbp_id,mbp_mbrid,mbp_part,mbp_badcode,");
  812. sql.Append("mbp_brcode,mbp_sncode,mbp_makecode,mbp_indate,mbp_inman)");
  813. sql.Append("select makebadrspart_seq.nextval," + mbr_id + ",'" + dt.Rows[0][0].ToString() + "',");
  814. sql.Append("'" + bc_code.Text + "','" + nr_code.Text + "','" + GetSNCode.Text + "','" + macode + "',");
  815. sql.Append("sysdate,'" + User.UserCode + "' from dual");
  816. dh.ExecuteSql(sql.GetString(), "insert");
  817. dt = (DataTable)dh.ExecuteSql("select mbp_id,mbp_part from makebadrspart where mbp_mbrid=" + mbr_id, "select");
  818. BaseUtil.FillDgvWithDataTable(mbp_partdgv, dt);
  819. mbl_loc.Clear();
  820. }
  821. }
  822. else OperatResult.AppendText(">>已存在该不良位置\n", Color.Red);
  823. }
  824. else OperatResult.AppendText(">>请先选择不良原因\n", Color.Red);
  825. }
  826. else OperatResult.AppendText(">>不良位置不能为空\n", Color.Red);
  827. }
  828. else OperatResult.AppendText(">>" + GetSNCode.Text + "序列号错误,不存在或者不处于维修状态\n", Color.Red);
  829. }
  830. private void nr_name_TextChanged(object sender, EventArgs e)
  831. {
  832. if (nr_name.Text == "")
  833. SaveBadLocation.Enabled = false;
  834. else
  835. SaveBadLocation.Enabled = true;
  836. }
  837. private void mbl_loc_KeyDown(object sender, KeyEventArgs e)
  838. {
  839. if (e.KeyCode == Keys.Enter)
  840. SaveBadLocation_Click(sender, e);
  841. }
  842. private void prodcode_TextKeyDown(object sender, KeyEventArgs e)
  843. {
  844. if (e.KeyCode == Keys.Enter)
  845. {
  846. if (bd_soncode.Text != "")
  847. {
  848. if (mbr_id != "")
  849. {
  850. sql.Clear();
  851. sql.Append("insert into makebadrspart(mbp_id,mbp_mbrid,mbp_part,mbp_badcode,");
  852. sql.Append("mbp_brcode,mbp_sncode,mbp_makecode,mbp_indate,mbp_inman)");
  853. sql.Append("select makebadrspart_seq.nextval," + mbr_id + ",'" + bd_soncode.Text + "',");
  854. sql.Append("'" + bc_code.Text + "','" + nr_code.Text + "','" + GetSNCode.Text + "','" + macode + "',");
  855. sql.Append("sysdate,'" + User.UserCode + "' from dual");
  856. dh.ExecuteSql(sql.GetString(), "insert");
  857. DataTable dt = (DataTable)dh.ExecuteSql("select mbp_id,mbp_part from makebadrspart where mbp_mbrid=" + mbr_id, "select");
  858. BaseUtil.FillDgvWithDataTable(mbp_partdgv, dt);
  859. }
  860. else OperatResult.AppendText(">>请先选择不良原因\n", Color.Red);
  861. }
  862. else OperatResult.AppendText(">>不良零件不能为空\n", Color.Red);
  863. }
  864. }
  865. private void cr_code_UserControlTextChanged(object sender, EventArgs e)
  866. {
  867. cd_stepcode.Condition = "ST_STATUSCODE='AUDITED' and cr_code='" + cr_code.Text + "' and cr_prodcode='" + ms_prodcode.Text + "' order by cd_stepno";
  868. }
  869. private void Clean_Click(object sender, EventArgs e)
  870. {
  871. OperatResult.Clear();
  872. }
  873. private void mbl_locdgv_CellContentClick(object sender, DataGridViewCellEventArgs e)
  874. {
  875. if (e.RowIndex >= 0)
  876. {
  877. if (mbl_locdgv.Columns[e.ColumnIndex].Name == "DeletePos")
  878. {
  879. dh.ExecuteSql("delete from makebadrsloc where mbl_id='" + mbl_locdgv.Rows[e.RowIndex].Cells["mbl_id"].Value.ToString() + "'", "insert");
  880. dt = (DataTable)dh.ExecuteSql("select mbl_id,mbl_loc from makebadrsloc where mbl_mbrid=" + mbr_id, "select");
  881. BaseUtil.FillDgvWithDataTable(mbl_locdgv, dt);
  882. }
  883. }
  884. }
  885. private void mbp_partdgv_CellContentClick(object sender, DataGridViewCellEventArgs e)
  886. {
  887. if (e.RowIndex >= 0)
  888. {
  889. if (mbp_partdgv.Columns[e.ColumnIndex].Name == "DeleteCom")
  890. {
  891. dh.ExecuteSql("delete from makebadrspart where mbp_id='" + mbp_partdgv.Rows[e.RowIndex].Cells["mbp_id"].Value.ToString() + "'", "insert");
  892. DataTable dt = (DataTable)dh.ExecuteSql("select mbp_id,mbp_part from makebadrspart where mbp_mbrid=" + mbr_id, "select");
  893. BaseUtil.FillDgvWithDataTable(mbp_partdgv, dt);
  894. }
  895. }
  896. }
  897. private void Make_Repair_FormClosing(object sender, FormClosingEventArgs e)
  898. {
  899. dh.Dispose();
  900. }
  901. private void ms_prodcode_TextChanged(object sender, EventArgs e)
  902. {
  903. if (ms_prodcode.Text != "")
  904. cr_code.Condition = "cr_prodcode='" + ms_prodcode.Text + "'";
  905. else
  906. cr_code.Condition = "";
  907. bd_soncode.Condition = "bd_mothercode='" + ms_prodcode.Text + "' and NVL(bd_usestatus,' ')<>'DISABLE'";
  908. //设置工序的条件
  909. cd_stepcode.Condition = "ST_STATUSCODE='AUDITED' and cr_code='" + cr_code.Text + "' and cr_prodcode='" + ms_prodcode.Text + "' order by cd_stepno";
  910. }
  911. public void RefreshData()
  912. {
  913. GetSNCode_KeyDown(new object(), new KeyEventArgs(Keys.Enter));
  914. }
  915. private void nr_name_UserControlTextChanged(object sender, EventArgs e)
  916. {
  917. if (nr_name.Text != "")
  918. {
  919. SaveBadLocation.Enabled = true;
  920. if (nrg_name.Text == "")
  921. {
  922. OperatResult.AppendText(">>请先填写不良代码组\n", Color.Red);
  923. nr_name.Text = "";
  924. }
  925. else
  926. {
  927. if (nr_code.Text == "" || (nr_code.Text != "" && nr_code.Text != nr_name.Value))
  928. nr_code.Text = nr_name.Value;
  929. }
  930. }
  931. else SaveBadLocation.Enabled = false;
  932. }
  933. private void nrg_name_UserControlTextChanged(object sender, EventArgs e)
  934. {
  935. if (nrg_code.Text == "" || (nrg_code.Text != "" && nrg_code.Text != nrg_name.Value))
  936. nrg_code.Text = nrg_name.Value;
  937. nr_name.Condition = "nrg_code in('" + (nrg_code.Text == "" ? "''" : nrg_code.Text) + "')";
  938. }
  939. private void mbr_dutyname_UserControlTextChanged(object sender, EventArgs e)
  940. {
  941. if (mbr_dutycode.Text == "" || (mbr_dutycode.Text != "" && mbr_dutycode.Text != mbr_dutyname.Value))
  942. mbr_dutycode.Text = mbr_dutyname.Value;
  943. }
  944. private void mbc_component_UserControlTextChanged(object sender, EventArgs e)
  945. {
  946. }
  947. private void so_name_UserControlTextChanged(object sender, EventArgs e)
  948. {
  949. if (so_code.Text == "" || (so_code.Text != "" && so_code.Text != so_name.Value))
  950. so_code.Text = so_name.Value;
  951. }
  952. private void BadCodeTree_AfterSelect(object sender, TreeViewEventArgs e)
  953. {
  954. if (e.Node.Level == 0)
  955. {
  956. mb_id = e.Node.Tag.ToString();
  957. BaseUtil.CleanControlsText(bc_name, bc_code, bg_name, bg_code, mb_badremark, nrg_name, nrg_code, nr_name, nr_code, so_name, so_code, mbr_dutyname, mbr_dutycode, mbc_component);
  958. mbl_locdgv.DataSource = null;
  959. mbp_partdgv.DataSource = null;
  960. bc_name.Text = BadInf_1[mb_id]["bc_name"];
  961. bc_code.Text = BadInf_1[mb_id]["mb_badcode"];
  962. bg_name.Text = BadInf_1[mb_id]["bg_name"];
  963. bg_code.Text = BadInf_1[mb_id]["mb_bgcode"];
  964. mb_badremark.Text = BadInf_1[mb_id]["mb_badremark"];
  965. mbr_id = "";
  966. SaveRepairInf.Enabled = true;
  967. }
  968. if (e.Node.Level == 1)
  969. {
  970. //展示父节点信息
  971. mb_id = e.Node.Parent.Tag.ToString();
  972. bc_code.Text = BadInf_1[mb_id]["mb_badcode"];
  973. bc_name.Text = BadInf_1[mb_id]["bc_name"];
  974. bg_code.Text = BadInf_1[mb_id]["mb_bgcode"];
  975. bg_name.Text = BadInf_1[mb_id]["bg_name"];
  976. //展示子节点信息
  977. mbr_id = e.Node.Tag.ToString();
  978. nrg_code.Text = BadInf_2[mbr_id]["nrg_code"];
  979. nrg_name.Text = BadInf_2[mbr_id]["nrg_name"];
  980. nr_code.Text = BadInf_2[mbr_id]["nr_code"];
  981. nr_name.Text = BadInf_2[mbr_id]["nr_name"];
  982. so_code.Text = BadInf_2[mbr_id]["so_code"];
  983. so_name.Text = BadInf_2[mbr_id]["so_name"];
  984. mbr_dutycode.Text = BadInf_2[mbr_id]["mbr_dutycode"];
  985. mbr_dutyname.Text = BadInf_2[mbr_id]["mbr_dutyname"];
  986. mbc_component.Text = dh.getFieldDataByCondition("makebadrscom", "mbc_component", "mbc_mbrid=" + mbr_id).ToString();
  987. //加载两个Grid的数据源
  988. DataTable dt = (DataTable)dh.ExecuteSql("select mbp_id,mbp_part from makebadrspart where mbp_mbrid=" + mbr_id, "select");
  989. BaseUtil.FillDgvWithDataTable(mbp_partdgv, dt);
  990. dt = (DataTable)dh.ExecuteSql("select mbl_id,mbl_loc from makebadrsloc where mbl_mbrid=" + mbr_id, "select");
  991. BaseUtil.FillDgvWithDataTable(mbl_locdgv, dt);
  992. SaveRepairInf.Enabled = false;
  993. }
  994. }
  995. }
  996. }