华恒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.

298 lines
12 KiB

5 months ago
  1. using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel;
  4. using System.Data;
  5. using System.Data.Linq;
  6. using System.Linq;
  7. using System.Drawing;
  8. using System.Text;
  9. using System.Windows.Forms;
  10. using DevExpress.XtraEditors;
  11. using DevExpress.XtraGrid.Views.BandedGrid;
  12. using DevExpress.XtraGrid.Columns;
  13. using DevExpress.XtraGrid;
  14. using System.IO;
  15. using System.Threading;
  16. using ICSSoft.Base.Language.Tool;
  17. using ICSSoft.Base.Config.AppConfig;
  18. using ICSSoft.Base.UserControl.MessageControl;
  19. using ICSSoft.Base.Config.DBHelper;
  20. using ICSSoft.Base.Report.Filter;
  21. using ICSSoft.Base.UserControl.FormControl;
  22. using ICSSoft.Base.Report.GridReport;
  23. using ICSSoft.Base.ReferForm.AppReferForm;
  24. using ICSSoft.Frame.Data.BLL;
  25. using ICSSoft.Base.Lable.PrintTool;
  26. using DevExpress.XtraPrinting;
  27. using ICSSoft.Frame.Common;
  28. namespace ICSSoft.Frame.APP
  29. {
  30. public partial class FormICSGaugeBack : DevExpress.XtraEditors.XtraForm
  31. {
  32. String guid = AppConfig.GetGuid();
  33. private string MoId = "";
  34. private string MoCode = "";
  35. private decimal Qty = 0.00m;
  36. #region 构造函数
  37. public FormICSGaugeBack()
  38. {
  39. InitializeComponent();
  40. this.MaximumSize = new Size(Screen.PrimaryScreen.WorkingArea.Width, Screen.PrimaryScreen.WorkingArea.Height);
  41. this.WindowState = FormWindowState.Maximized;
  42. }
  43. public FormICSGaugeBack(string moID, string moCode, decimal qty)
  44. {
  45. InitializeComponent();
  46. this.MaximumSize = new Size(Screen.PrimaryScreen.WorkingArea.Width, Screen.PrimaryScreen.WorkingArea.Height);
  47. this.WindowState = FormWindowState.Maximized;
  48. MoId = moID;
  49. MoCode = moCode;
  50. Qty = qty;
  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. List<Control> ControlList = new List<Control>();
  65. ControlList.Add(btnPrint);
  66. ControlList.Add(btnOutPut);
  67. foreach (Control ctr in ControlList)
  68. {
  69. if (ctr.GetType() == typeof(SimpleButton))
  70. {
  71. DataRow dr = rData.NewRow();
  72. dr["BtnName"] = ctr.Name;
  73. dr["ActionName"] = ctr.Text;
  74. rData.Rows.Add(dr);
  75. }
  76. }
  77. rData.AcceptChanges();
  78. return rData;
  79. }
  80. public DataTable RightOfData()// 数据权限
  81. {
  82. DataTable rData = new DataTable();
  83. rData.Columns.Add("BodyName");
  84. rData.Columns.Add("ControlName");
  85. rData.Columns.Add("ControlCaption");
  86. rData.AcceptChanges();
  87. return rData;
  88. }
  89. #endregion
  90. #region 退出
  91. private void btnClose_Click(object sender, EventArgs e)
  92. {
  93. AppConfig.CloseFormShow(this.Text);
  94. this.Close();
  95. }
  96. private void btnExit_Click(object sender, EventArgs e)
  97. {
  98. AppConfig.CloseFormShow(this.Text);
  99. this.Close();
  100. }
  101. #endregion
  102. #region 移动窗体
  103. private const int WM_NCHITTEST = 0x84;
  104. private const int HTCLIENT = 0x1;
  105. private const int HTCAPTION = 0x2;
  106. //首先必须了解Windows的消息传递机制,当有鼠标活动消息时,
  107. //系统发送WM_NCHITTEST 消息给窗体作为判断消息发生地的根据。 nchittest
  108. //假如你点击的是标题栏,窗体收到的消息值就是 HTCAPTION ,
  109. //同样地,若接受到的消息是 HTCLIENT,说明用户点击的是客户区,也就是鼠标消息发生在客户区。
  110. //重写窗体,使窗体可以不通过自带标题栏实现移动
  111. protected override void WndProc(ref Message m)
  112. {
  113. //当重载窗体的 WndProc 方法时,可以截获 WM_NCHITTEST 消息并改些该消息,
  114. //当判断鼠标事件发生在客户区时,改写改消息,发送 HTCAPTION 给窗体,
  115. //这样,窗体收到的消息就时 HTCAPTION ,在客户区通过鼠标来拖动窗体就如同通过标题栏来拖动一样。
  116. //注意:当你重载 WndProc 并改写鼠标事件后,整个窗体的鼠标事件也就随之改变了。
  117. switch (m.Msg)
  118. {
  119. case WM_NCHITTEST:
  120. base.WndProc(ref m);
  121. if ((int)m.Result == HTCLIENT)
  122. m.Result = (IntPtr)HTCAPTION;
  123. return;
  124. }
  125. //拦截双击标题栏、移动窗体的系统消息
  126. if (m.Msg != 0xA3)
  127. {
  128. base.WndProc(ref m);
  129. }
  130. }
  131. #endregion
  132. #region 列表
  133. private void grvDetail_CustomDrawRowIndicator(object sender, DevExpress.XtraGrid.Views.Grid.RowIndicatorCustomDrawEventArgs e)
  134. {
  135. if (e.Info.IsRowIndicator && e.RowHandle >= 0)
  136. e.Info.DisplayText = (e.RowHandle + 1).ToString();
  137. }
  138. #endregion
  139. //加载
  140. private void FormICSGauge_Load(object sender, EventArgs e)
  141. {
  142. init();
  143. }
  144. public bool Search(string TransferNO)
  145. {
  146. bool Search = false;
  147. string sql = @"SELECT DISTINCT TransferNO AS [生产订单号] FROM ICSTransferNOBack WHERE 1=1 AND TransferNO = '{0}' ORDER BY TransferNO DESC ";
  148. sql = string.Format(sql, TransferNO);
  149. DataTable dt = DBHelper.ExecuteDataset(AppConfig.AppConnectString.ToString(), CommandType.Text, sql).Tables[0];
  150. if (dt.Rows.Count > 0)
  151. {
  152. Search = true;
  153. }
  154. return Search;
  155. }
  156. #region 初始化查询条件
  157. private void init()
  158. {
  159. #region 生产订单号
  160. string sql = @"SELECT DISTINCT B.TransferNO AS [单据号] FROM ICSTransferNOBack B WHERE 1=1 AND B.TransferNO IS NOT NULL AND B.Status = '已审核' ORDER BY B.TransferNO DESC";
  161. sql = string.Format(sql, AppConfig.WorkPointCode);
  162. DataTable dt = DBHelper.ExecuteDataset(AppConfig.AppConnectString.ToString(), CommandType.Text, sql).Tables[0];
  163. txtMOCode.Properties.ValueMember = "单据号";
  164. txtMOCode.Properties.DisplayMember = "单据号";
  165. txtMOCode.Properties.DataSource = dt;
  166. txtMOCode.Properties.NullText = "";//空时的值
  167. txtMOCode.Properties.ImmediatePopup = true;//输入值是否马上弹出窗体
  168. txtMOCode.Properties.ValidateOnEnterKey = true;//回车确认
  169. txtMOCode.Properties.TextEditStyle = DevExpress.XtraEditors.Controls.TextEditStyles.Standard;//要使用户可以输入,这里须设为Standard
  170. txtMOCode.Properties.AllowNullInput = DevExpress.Utils.DefaultBoolean.True; //可用Ctrl + Delete清空选择內容
  171. //自适应宽度
  172. txtMOCode.Properties.BestFitMode = DevExpress.XtraEditors.Controls.BestFitMode.BestFitResizePopup;
  173. #endregion
  174. }
  175. #endregion
  176. private void txtMOCode_EditValueChanged(object sender, EventArgs e)
  177. {
  178. string sql = @"SELECT '' AS isSelect, A.TransferNO, A.TransLine, A.INVCode, B.INVUOM, A.INVName, A.QTY, A.Status, A.MUSER, A.MUSERName, A.MTIME, A.LotNO, A.StatusX
  179. FROM ICSTransferNOBack A
  180. LEFT JOIN ICSINVENTORY B ON A.INVCode = B.INVCODE
  181. WHERE 1=1 and A.Status = '' AND A.TransferNO = '{0}' ";
  182. sql = string.Format(sql, txtMOCode.Text.Trim());
  183. DataTable dt = DBHelper.ExecuteDataset(AppConfig.AppConnectString.ToString(), CommandType.Text, sql).Tables[0];
  184. grdDetail.DataSource = dt;
  185. grvDetail.BestFitColumns();
  186. }
  187. #region 导出
  188. private void btnOutPut_Click(object sender, EventArgs e)
  189. {
  190. try
  191. {
  192. FormOutExcel foe = new FormOutExcel(this.Tag.ToString(), grdDetail);
  193. foe.ShowDialog();
  194. }
  195. catch (Exception ex)
  196. {
  197. MessageBox.Show("异常:" + ex.Message, "异常", MessageBoxButtons.OK, MessageBoxIcon.Error);
  198. }
  199. //SimpleButton btntemp = (SimpleButton)sender;
  200. //if (AppConfig.GetUserExcuteRight(this.Tag.ToString(), btntemp.Name) == false)
  201. //{
  202. // ICSBaseSimpleCode.AppshowMessageBox("对不起您没有:" + btntemp.Text + "权限,请联系系统管理员!");
  203. // return;
  204. //}
  205. //FormOutExcel foe = new FormOutExcel();
  206. //if (foe.ShowDialog() == DialogResult.OK)
  207. //{
  208. // try
  209. // {
  210. // string outtype = foe._OutType;
  211. // string exceltype = foe._ExcelType;
  212. // string filename = foe._FileName;
  213. // string url = foe._Url;
  214. // string sheetname = foe._SheetName;
  215. // if (outtype.ToLower() == "excel")
  216. // {
  217. // DevExpress.XtraPrinting.XlsExportOptions op = new DevExpress.XtraPrinting.XlsExportOptions();
  218. // op.SheetName = sheetname;
  219. // grdDetail.MainView.ExportToXls((url + "\\" + filename + (exceltype == "2003" ? ".xls" : ".xlsx")), op);
  220. // }
  221. // else
  222. // {
  223. // grdDetail.MainView.ExportToPdf(url + "\\" + filename + ".pdf");
  224. // }
  225. // MessageBox.Show("导出成功", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
  226. // }
  227. // catch (Exception ex)
  228. // {
  229. // MessageBox.Show("异常:" + ex.Message, "异常", MessageBoxButtons.OK, MessageBoxIcon.Error);
  230. // }
  231. //}
  232. }
  233. #endregion
  234. #region 打印
  235. private void btnPrint_Click(object sender, EventArgs e)
  236. {
  237. try
  238. {
  239. #region
  240. SimpleButton btntemp = (SimpleButton)sender;
  241. if (AppConfig.GetUserExcuteRight(this.Tag.ToString(), btntemp.Name) == false)
  242. {
  243. ICSBaseSimpleCode.AppshowMessageBox("对不起您没有:" + btntemp.Text + "权限,请联系系统管理员!");
  244. return;
  245. }
  246. if (string.IsNullOrWhiteSpace(txtMOCode.EditValue.ToString()))
  247. {
  248. ICSBaseSimpleCode.AppshowMessageBox("请选择退料单!");
  249. return;
  250. }
  251. string code = txtMOCode.EditValue.ToString();
  252. List<PrintPara> parasList = new List<PrintPara>();
  253. PrintPara para = new PrintPara();
  254. para.PrintKey = "TransferNO";
  255. para.PrintValues = new object[] { txtMOCode.Text };
  256. parasList.Add(para);
  257. if (parasList.Count == 0)
  258. {
  259. ICSBaseSimpleCode.AppshowMessageBox("请选择数据!");
  260. return;
  261. }
  262. FormPrintDialog f = new FormPrintDialog("015", this.Text, parasList, false, null);
  263. f.ShowDialog();
  264. #endregion
  265. }
  266. catch (Exception ex)
  267. {
  268. MessageBox.Show(ex.ToString());
  269. }
  270. }
  271. #endregion
  272. private void btnRePrint_Click(object sender, EventArgs e)
  273. {
  274. }
  275. }
  276. }