frmEntrustZCData.cs 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Windows.Forms;
  5. using Core.Mes.Client.Comm.Control;
  6. using Core.Mes.Client.Comm.Tool;
  7. using Core.StlMes.Client.Mcp.Treatment.Entity;
  8. using CoreFS.CA06;
  9. using Infragistics.Win.UltraWinGrid;
  10. namespace Core.StlMes.Client.Mcp.Treatment.HeatTreatment
  11. {
  12. public partial class frmEntrustZCData : FrmBase
  13. {
  14. protected string _plineCode = "";
  15. private string[] plineCodes = {};
  16. public frmEntrustZCData()
  17. {
  18. InitializeComponent();
  19. IsLoadUserView = true;
  20. }
  21. public override void ToolBar_Click(object sender, string ToolbarKey)
  22. {
  23. switch (ToolbarKey)
  24. {
  25. case "Query":
  26. QueryOffline();
  27. break;
  28. case "Apply":
  29. Apply();
  30. break;
  31. case "CancelApply":
  32. CancelApply();
  33. break;
  34. case "Close":
  35. Close();
  36. break;
  37. case "Export":
  38. Export();
  39. break;
  40. }
  41. }
  42. private void Export()
  43. {
  44. string title = "";
  45. title += "成品余材明细";
  46. GridHelper.ulGridToExcel(ultraGrid1, title);
  47. }
  48. protected override void OnLoad(EventArgs e)
  49. {
  50. base.OnLoad(e);
  51. StartTime.Value =
  52. DateTime.Parse(DateTime.Now.AddDays(1 - DateTime.Now.Day).AddDays(-1).ToString("yyyy-MM-dd 21:00"));
  53. EndTime.Value =
  54. DateTime.Parse(
  55. DateTime.Now.AddDays(1 - DateTime.Now.Day).AddMonths(1).AddDays(-1).ToString("yyyy-MM-dd 20:59"));
  56. plineCodes = comm.GetPlineCodeWithOther(ValidDataPurviewIds, ob);
  57. EntityHelper.ShowGridCaption<OfflineResultEntity>(ultraGrid1.DisplayLayout.Bands[0]);
  58. comm.RefreshAndAutoSize(ultraGrid1, true);
  59. }
  60. private void QueryOffline()
  61. {
  62. var wf = new WaitingForm2("正在查询,请稍候....");
  63. try
  64. {
  65. Cursor = Cursors.WaitCursor;
  66. var startTime = "";
  67. var endTime = "";
  68. var judgeNo = "";
  69. var orderNo = "";
  70. if (chkTim.Checked)
  71. if (DateTime.Parse(StartTime.Value.ToString()) > DateTime.Parse(EndTime.Value.ToString()))
  72. {
  73. MessageUtil.ShowTips("选择时间区间错误,请重新选择!");
  74. return;
  75. }
  76. else
  77. {
  78. startTime = StartTime.Value.ToString("yyyy-MM-dd HH:mm:ss");
  79. endTime = EndTime.Value.ToString("yyyy-MM-dd HH:mm:ss");
  80. }
  81. // else if (!chkJugeHeatNo.Checked)
  82. // if (MessageUtil.ShowYesNoAndQuestion("未加时间条件,查询时间可能比较长,请确定是否继续查询?") == DialogResult.No) return;
  83. if (chkJugeHeatNo.Checked)
  84. judgeNo = txtJugeNo.Text.Trim();
  85. if (chkOrderNo.Checked)
  86. orderNo = txtOrderNo.Text.Trim();
  87. List<OfflineResultEntity> listSource = EntityHelper.GetData<OfflineResultEntity>(
  88. "com.steering.mes.mcp.common.frmEntrust.doQueryZc",
  89. new object[] { startTime, endTime, judgeNo, plineCodes, upStatus0.CheckedItem.DataValue.ToString(), orderNo }, ob);
  90. offlineResultEntityBindingSource.DataSource = listSource;
  91. comm.RefreshAndAutoSize(ultraGrid1, new[] {"StdName"});
  92. }
  93. catch (Exception ex)
  94. {
  95. if (ex.Message.ToString2() != "")
  96. MessageBox.Show(ex.Message);
  97. }
  98. finally
  99. {
  100. wf.Close();
  101. Cursor = Cursors.Default;
  102. }
  103. }
  104. private void Apply()
  105. {
  106. ultraGrid1.UpdateData();
  107. var list = offlineResultEntityBindingSource.DataSource as List<OfflineResultEntity>;
  108. list = list.Where(p => p.Chk).ToList();
  109. if (!list.Any())
  110. {
  111. MessageBox.Show("请选择需要申请的数据");
  112. return;
  113. }
  114. if (list.Select(p => p.Process).Distinct().Count() != 1)
  115. {
  116. MessageBox.Show("只能同时申请同工序的数据");
  117. return;
  118. }
  119. if (list.Select(p => p.PlineCode).Distinct().Count() != 1)
  120. {
  121. MessageBox.Show("只能同时申请同产线的数据");
  122. return;
  123. }
  124. var FrmEntrustApply = new FrmEntrustApplyNew(ob, FrmEntrustApplyNew.ApplyType.ApplyProject,
  125. list, list[0].Process, list[0].PlineCode, null, null, this.CustomInfo.ToString());
  126. if (FrmEntrustApply.ShowDialog() == DialogResult.OK)
  127. {
  128. // var Type = FrmEntrustApply.Type;
  129. // var Note = FrmEntrustApply.Note;
  130. FrmEntrustApply.Dispose();
  131. QueryOffline();
  132. }
  133. }
  134. private void CancelApply()
  135. {
  136. ultraGrid1.UpdateData();
  137. var list = offlineResultEntityBindingSource.DataSource as List<OfflineResultEntity>;
  138. list = list.Where(p => p.Chk).ToList();
  139. if (!list.Any())
  140. {
  141. MessageBox.Show("请选择需要撤销申请的数据");
  142. return;
  143. }
  144. if (list.Select(p => p.Process).Distinct().Count() != 1)
  145. {
  146. MessageBox.Show("只能同时撤销申请同工序的数据");
  147. return;
  148. }
  149. if (list.Any(p => p.Type != "00"))
  150. {
  151. MessageBox.Show("只能撤销已申请的数据!");
  152. return;
  153. }
  154. if (MessageUtil.ShowYesNoAndQuestion("是否撤销申请委外?") == DialogResult.No)
  155. return;
  156. var ccp = new CoreClientParam();
  157. ccp.ServerName = "com.steering.mes.mcp.common.frmEntrust";
  158. ccp.MethodName = "CancelApply";
  159. ccp.ServerParams = new object[]
  160. {
  161. list.Select(p => p.SubcontractNo).Distinct().ToList(), list[0].Process
  162. };
  163. ccp = ExecuteNonQuery(ccp, CoreInvokeType.Internal);
  164. if (ccp.ReturnCode != -1)
  165. {
  166. MessageUtil.ShowTips(ccp.ReturnInfo);
  167. if (ccp.ReturnInfo.Equals("撤销申请成功!"))
  168. QueryOffline();
  169. }
  170. }
  171. public void SetFillerHeaderCheck(UltraGrid ug, string name)
  172. {
  173. ug.DisplayLayout.Bands[0].Columns[name].Header.CheckBoxVisibility = HeaderCheckBoxVisibility.Always;
  174. ug.DisplayLayout.Bands[0].Columns[name].Header.CheckBoxSynchronization = HeaderCheckBoxSynchronization.None;
  175. var _isInCellChange = 0;
  176. ug.AfterHeaderCheckStateChanged += (sender, e) =>
  177. {
  178. if (_isInCellChange > 0) return; //更新状态时 不执行全选或全不选
  179. var isChecked = e.Column.GetHeaderCheckedState(e.Rows) == CheckState.Checked;
  180. foreach (var filteredInNonGroupByRow in e.Rows.GetFilteredInNonGroupByRows())
  181. filteredInNonGroupByRow.Cells[e.Column].SetValue(isChecked, false);
  182. };
  183. ug.CellChange += (sender, e) =>
  184. {
  185. ug.UpdateData();
  186. if (e.Cell.Column.Key == name)
  187. {
  188. _isInCellChange++;
  189. var allTrue = true;
  190. var allFalse = true;
  191. foreach (var row in ug.Rows.GetFilteredInNonGroupByRows())
  192. if ((bool) row.Cells[name].Value)
  193. allFalse = false;
  194. else
  195. allTrue = false;
  196. if (allFalse)
  197. ug.DisplayLayout.Bands[0].Columns[name].SetHeaderCheckedState(ug.Rows, false);
  198. else if (allTrue)
  199. ug.DisplayLayout.Bands[0].Columns[name].SetHeaderCheckedState(ug.Rows, true);
  200. else
  201. ug.DisplayLayout.Bands[0].Columns[name].SetHeaderCheckedState(ug.Rows, false); // 当前版本无法直接更新Indeterminate 状态 改成不勾选
  202. _isInCellChange--;
  203. }
  204. };
  205. ug.AfterRowFilterChanged += (sender, e) =>
  206. {
  207. _isInCellChange++;
  208. var allTrue = true;
  209. var allFalse = true;
  210. foreach (var row in ug.Rows.GetFilteredInNonGroupByRows())
  211. if ((bool) row.Cells[name].Value)
  212. allFalse = false;
  213. else
  214. allTrue = false;
  215. if (allFalse)
  216. ug.DisplayLayout.Bands[0].Columns[name].SetHeaderCheckedState(ug.Rows, false);
  217. else if (allTrue)
  218. ug.DisplayLayout.Bands[0].Columns[name].SetHeaderCheckedState(ug.Rows, true);
  219. else
  220. ug.DisplayLayout.Bands[0].Columns[name].SetHeaderCheckedState(ug.Rows, false); // 当前版本无法直接更新Indeterminate 状态 改成不勾选
  221. _isInCellChange--;
  222. };
  223. }
  224. }
  225. }