锐腾搅拌上料功能
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.

263 lines
10 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. SimpleButton btntemp = (SimpleButton)sender;
  191. if (AppConfig.GetUserExcuteRight(this.Tag.ToString(), btntemp.Name) == false)
  192. {
  193. ICSBaseSimpleCode.AppshowMessageBox("对不起您没有:" + btntemp.Text + "权限,请联系系统管理员!");
  194. return;
  195. }
  196. FormOutExcel foe = new FormOutExcel(this.Tag.ToString(), grdDetail);
  197. foe.ShowDialog();
  198. }
  199. #endregion
  200. #region 打印
  201. private void btnPrint_Click(object sender, EventArgs e)
  202. {
  203. try
  204. {
  205. #region
  206. SimpleButton btntemp = (SimpleButton)sender;
  207. if (AppConfig.GetUserExcuteRight(this.Tag.ToString(), btntemp.Name) == false)
  208. {
  209. ICSBaseSimpleCode.AppshowMessageBox("对不起您没有:" + btntemp.Text + "权限,请联系系统管理员!");
  210. return;
  211. }
  212. if (string.IsNullOrWhiteSpace(txtMOCode.EditValue.ToString()))
  213. {
  214. ICSBaseSimpleCode.AppshowMessageBox("请选择退料单!");
  215. return;
  216. }
  217. string code = txtMOCode.EditValue.ToString();
  218. List<PrintPara> parasList = new List<PrintPara>();
  219. PrintPara para = new PrintPara();
  220. para.PrintKey = "TransferNO";
  221. para.PrintValues = new object[] { txtMOCode.Text };
  222. parasList.Add(para);
  223. if (parasList.Count == 0)
  224. {
  225. ICSBaseSimpleCode.AppshowMessageBox("请选择数据!");
  226. return;
  227. }
  228. FormPrintDialog f = new FormPrintDialog("015", this.Text, parasList, false, null);
  229. f.ShowDialog();
  230. #endregion
  231. }
  232. catch (Exception ex)
  233. {
  234. MessageBox.Show(ex.ToString());
  235. }
  236. }
  237. #endregion
  238. private void btnRePrint_Click(object sender, EventArgs e)
  239. {
  240. }
  241. }
  242. }