华恒Mes鼎捷代码
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

218 lines
9.1 KiB

5 months ago
  1. using System;
  2. using System.Data;
  3. using System.Drawing;
  4. using System.Windows.Forms;
  5. using ICSSoft.Base.Config.AppConfig;
  6. using ICSSoft.Base.Config.DBHelper;
  7. namespace ICSSoft.Frame.APP
  8. {
  9. public partial class FormICSMO2SendSearchNew : DevExpress.XtraEditors.XtraForm
  10. {
  11. private string sqltxt = "";
  12. private string sqlconn = "";
  13. String guid = AppConfig.GetGuid();
  14. private DataTable dataSource = null;
  15. public FormICSMO2SendSearchNew()
  16. {
  17. InitializeComponent();
  18. this.MaximumSize = new Size(Screen.PrimaryScreen.WorkingArea.Width, Screen.PrimaryScreen.WorkingArea.Height);
  19. this.WindowState = FormWindowState.Maximized;
  20. textBoxCode.Text = AppConfig.UserCode;
  21. textBoxName.Text = AppConfig.UserName;
  22. }
  23. #region 移动窗体
  24. private const int WM_NCHITTEST = 0x84;
  25. private const int HTCLIENT = 0x1;
  26. private const int HTCAPTION = 0x2;
  27. //首先必须了解Windows的消息传递机制,当有鼠标活动消息时,
  28. //系统发送WM_NCHITTEST 消息给窗体作为判断消息发生地的根据。 nchittest
  29. //假如你点击的是标题栏,窗体收到的消息值就是 HTCAPTION ,
  30. //同样地,若接受到的消息是 HTCLIENT,说明用户点击的是客户区,也就是鼠标消息发生在客户区。
  31. //重写窗体,使窗体可以不通过自带标题栏实现移动
  32. protected override void WndProc(ref Message m)
  33. {
  34. //当重载窗体的 WndProc 方法时,可以截获 WM_NCHITTEST 消息并改些该消息,
  35. //当判断鼠标事件发生在客户区时,改写改消息,发送 HTCAPTION 给窗体,
  36. //这样,窗体收到的消息就时 HTCAPTION ,在客户区通过鼠标来拖动窗体就如同通过标题栏来拖动一样。
  37. //注意:当你重载 WndProc 并改写鼠标事件后,整个窗体的鼠标事件也就随之改变了。
  38. switch (m.Msg)
  39. {
  40. case WM_NCHITTEST:
  41. base.WndProc(ref m);
  42. if ((int)m.Result == HTCLIENT)
  43. m.Result = (IntPtr)HTCAPTION;
  44. return;
  45. }
  46. //拦截双击标题栏、移动窗体的系统消息
  47. if (m.Msg != 0xA3)
  48. {
  49. base.WndProc(ref m);
  50. }
  51. }
  52. #endregion
  53. #region 操作权限
  54. public DataTable RightOfExute()
  55. {
  56. DataTable rData = new DataTable();
  57. rData.Columns.Add("BtnName");
  58. rData.Columns.Add("ActionName");
  59. //查看权限(必须有)
  60. DataRow seeRow = rData.NewRow();
  61. seeRow["BtnName"] = "see";
  62. seeRow["ActionName"] = "查看";
  63. rData.Rows.Add(seeRow);
  64. rData.AcceptChanges();
  65. return rData;
  66. }
  67. public DataTable RightOfData()// 数据权限
  68. {
  69. DataTable rData = new DataTable();
  70. rData.Columns.Add("BodyName");
  71. rData.Columns.Add("ControlName");
  72. rData.Columns.Add("ControlCaption");
  73. rData.AcceptChanges();
  74. return rData;
  75. }
  76. #endregion
  77. private void btnFilter_Click(object sender, EventArgs e)
  78. {
  79. Search();
  80. }
  81. private void btnClose_Click(object sender, EventArgs e)
  82. {
  83. AppConfig.CloseFormShow(this.Text);
  84. this.Close();
  85. }
  86. private void btnExit_Click(object sender, EventArgs e)
  87. {
  88. AppConfig.CloseFormShow(this.Text);
  89. this.Close();
  90. }
  91. private void Search()
  92. {
  93. string code = textBoxCode.Text;
  94. #region sql语句原型
  95. //string sql = string.Format(@"
  96. //select eqpname as 设备型号,
  97. //C.ProjectCode AS 项目号,
  98. //C.MOCODE AS 生产订单号,
  99. //G.ROUTECODE as 途程编码,
  100. //A.OPCODE,
  101. //B.LOTSEQ AS 行号,
  102. // A.LOTNO AS 产品跟踪单号,
  103. //C.ITEMCODE AS 料品编码,
  104. //d.ItemName as 料品名称,
  105. //D.ItemStd AS 规格型号,
  106. // G.OPSEQ AS 工序次序,
  107. //h.opseq as 上一工序次序,
  108. //I.OPCODE AS 上一工序编码,
  109. //i.OPNAME as 上一工序,
  110. //e.OPNAME as 工序名称,
  111. //q.OPNAME as 当前工序,
  112. //ww.begindate,
  113. //ww.enddate,
  114. //b.lotqty as 数量,
  115. //P.STIME AS 单件工时,
  116. // CONVERT(DECIMAL(10,2),P.STIME*B.LOTQTY/60 ) AS 预估加工工时,
  117. //A.SendPlanDate AS 派工时间,
  118. //MOPLANSTARTDATE AS 预计开工时间,
  119. //MOPLANENDDATE AS 预计完工时间,
  120. //dbo.GetOpStatus(A.LOTNO,A.OPCODE,G.ROUTECODE,I.OPCODE ) as 状态
  121. //FROM ICSMO2User A
  122. //LEFT JOIN ICSMO2LOT B ON B.LOTNO=A.LOTNO
  123. //LEFT JOIN ICSMO C ON C.MOCODE=B.MOCODE
  124. //left join Base_Inventory d on d.ItemCode=C.ITEMCODE
  125. //LEFT JOIN ICSMO2ROUTE F on F.MOCODE = a.MOCODE AND F.ROUTECODE=A.RouteCode
  126. //left join icsroute2op G on G.ROUTECODE = F.ROUTECODE AND G.OPCODE=A.OPCODE
  127. //left join ICSOP E on A.OPCODE=E.OPCODE
  128. //left JOIN ICSLOTONWIP WW ON WW.LOTNO=A.LOTNO AND WW.OPCODE=A.OPCODE and ww.ACTION='good'
  129. //left join (select * from icsroute2op )H on h.ROUTECODE=f.ROUTECODE and h.OPSEQ=(select max(opseq) from icsroute2op where icsroute2op.ROUTECODE=h.ROUTECODE and icsroute2op.opseq<g.OPSEQ)
  130. //left join (select * from ICSOP) i on i.OPCODE=h.OPCODE
  131. //left join ICSEQPSTPEMODEL p ON P.ITEMCODE=C.ITEMCODE AND P.OPCODE=A.OPCODE AND P.EQPCODE=G.MainResources
  132. //left join (select ICSLOTSIMULATION.opcode,opname,lotno,BeginDate,EndDate from ICSLOTSIMULATION left join icsop on icsop.OPCODE=ICSLOTSIMULATION.OPCODE) q on q.lotno=a.lotno
  133. //where usercode='{0}'
  134. //AND NOT EXISTS(SELECT 1 FROM ICSLOTONWIP ww where ww.lotno=A.LOTNO AND isnull(ww.EndTime,'')!=''and ww.opcode=A.OPCODE)
  135. //ORDER BY A.LOTNO"
  136. //,
  137. //code);
  138. #endregion
  139. #region 新的sql
  140. string sql = string.Format(@"
  141. select
  142. A.eqpname as ,
  143. C.MOCODE AS ,
  144. A.MOSEQ AS ,
  145. B.LOTNO AS ,
  146. C.ITEMCODE AS ,
  147. d.INVNAME as ,
  148. d.invstd AS ,
  149. '' as , --
  150. G.OPSEQ AS ,
  151. e.OPDESC as ,
  152. --P.STIME AS ,
  153. 0 AS ,
  154. B.LOTQTY as ,
  155. --CONVERT(DECIMAL(10,2),P.STIME*B.LOTQTY/60 ) AS ,
  156. A.mtime AS ,
  157. A.STARTPLANDATE AS ,
  158. A.ENDPLANDATE AS ,
  159. case
  160. when ww.ACTIONRESULT is null and G.OPSEQ=(select min(OPSEQ) from ICSITEMROUTE2OPLot where lotno=a.LOTNO) then ''
  161. when ww.actionresult='COLLECT_BEGIN' then ''
  162. when ww1.actionresult='COLLECT_BEGIN' or (check1.result<>'' or check1.Result is null) then ''
  163. when ((ww1.actionresult='COLLECT_END' and check1.result='') OR (WW1.ACTIONRESULT IS NULL)) and ww.actionresult is null then ''
  164. END AS ,
  165. G.OPTIONALOP as ,
  166. case
  167. when G.OPTIONALOP='' or G.OPTIONALOP is null then null
  168. else CONVERT(DECIMAL(10,2),CONVERT(DECIMAL,h.OPTIONALOP)*B.LOTQTY/60 )
  169. end AS
  170. FROM ICSMO2User A
  171. LEFT JOIN ICSITEMLot B ON B.LOTNO=A.LOTNO
  172. left JOIN ICSMO C ON C.MOCODE=A.MOCODE AND c.MOSEQ=a.MOSEQ
  173. left join ICSINVENTORY d on d.INVCODE=C.ITEMCODE
  174. left join ICSOP E on A.OPCODE=E.OPCODE
  175. left JOIN ICSMO2ROUTE F on F.MOCODE = a.MOCODE AND F.ROUTECODE=A.RouteCode
  176. left join ICSITEMROUTE2OPlot G on G.lotno = a.lotno AND G.routecode=A.routecode and g.opcode=a.opcode
  177. left JOIN ICSLOTONWIP WW ON WW.LOTNO=A.LOTNO and WW.OPCODE=A.OPCODE
  178. left join (select * from ICSITEMROUTE2OPlot )H on h.lotno=a.lotno and h.OPSEQ=(select max(opseq) from ICSITEMROUTE2OPlot where ICSITEMROUTE2OPlot.lotno=h.lotno and ICSITEMROUTE2OPlot.opseq<g.OPSEQ)
  179. left join ICSLOTONWIP WW1 on ww1.lotno=a.lotno and ww1.opcode=H.opcode
  180. left join ICSLOTONWIPCheck check1 on check1.onwipid=ww1.id
  181. left join ICSOP i on i.OPCODE=h.OPCODE
  182. left join (select ICSLOTSIMULATION.opcode,opname,lotno,BeginTime,EndTime from ICSLOTSIMULATION left join icsop on icsop.OPCODE=ICSLOTSIMULATION.OPCODE) q on q.lotno=a.lotno
  183. where usercode='{0}' and (ww.ACTIONRESULT<>'COLLECT_END' or ww.ACTIONRESULT is null)
  184. ORDER BY A.LOTNO ", code);
  185. #endregion
  186. DataTable datasource = DBHelper.ExecuteDataset(AppConfig.AppConnectString, CommandType.Text, sql).Tables[0];
  187. grdDetail.DataSource = datasource;
  188. }
  189. private void grvDetail_CustomDrawRowIndicator(object sender, DevExpress.XtraGrid.Views.Grid.RowIndicatorCustomDrawEventArgs e)
  190. {
  191. if (e.Info.IsRowIndicator && e.RowHandle >= 0)
  192. e.Info.DisplayText = (e.RowHandle + 1).ToString();
  193. }
  194. }
  195. }