FrmCraftInfo.cs 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399
  1.  using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel;
  4. using System.Data;
  5. using System.Diagnostics;
  6. using System.Drawing;
  7. using System.IO;
  8. using System.Linq;
  9. using System.Text;
  10. using System.Windows.Forms;
  11. using Core.Mes.Client.Comm.Control;
  12. using Core.Mes.Client.Comm.Server;
  13. using Core.Mes.Client.Comm.Tool;
  14. using Core.StlMes.Client.PlnSaleOrd.炼钢计划;
  15. using Core.StlMes.Client.PlnSaleOrd.炼钢计划.entity;
  16. using CoreFS.CA06;
  17. using Infragistics.Win.UltraWinGrid;
  18. using Infragistics.Win.UltraWinGrid.ExcelExport;
  19. namespace Core.StlMes.Client.PlnSaleOrd
  20. {
  21. public partial class FrmCraftInfo : FrmBase
  22. {
  23. public FrmCraftInfo()
  24. {
  25. InitializeComponent();
  26. this.IsLoadUserView = true;
  27. }
  28. private List<ComMscStdCicEntity> ComMscStdCicEntitys = new DataSourceList<ComMscStdCicEntity>();
  29. private int _height = 300;
  30. protected override void OnLoad(EventArgs e)
  31. {
  32. base.OnLoad(e);
  33. EntityHelper.ShowGridCaption<CraftLg2MEntity>(ultraGridLgM.DisplayLayout.Bands[0]);
  34. SteelHelper.InitGrade(uceGrade, this.ob);
  35. EntityHelper.ShowGridCaption<CraftLg2CicEntity>(ultraGridLgCic.DisplayLayout.Bands[0]);
  36. EntityHelper.ShowGridCaption<CraftLg2TarCicEntity>(ultraGridLgTarCic.DisplayLayout.Bands[0]);
  37. EntityHelper.ShowGridCaption<CraftLg2CcmEntity>(ultraGridLgCcm.DisplayLayout.Bands[0]);
  38. EntityHelper.ShowGridCaption<CraftLg2TemperatureEntity>(ultraGridLhTem.DisplayLayout.Bands[0]);
  39. EntityHelper.ShowGridCaption<CraftLg2AlloyEntity>(ultraGridhJ.DisplayLayout.Bands[0]);
  40. EntityHelper.ShowGridCaption<ComBaseGradeEntity>(ugGrade.DisplayLayout.Bands[0]);
  41. EntityHelper.ShowGridCaption<ComMscStdCicEntity>(ugStdCic.DisplayLayout.Bands[0]);
  42. EntityHelper.ShowGridCaption<ComMscStdChemEntity>(ugStdCic.DisplayLayout.Bands[1]);
  43. }
  44. public override void ToolBar_Click(object sender, string toolbarKey)
  45. {
  46. switch (toolbarKey)
  47. {
  48. case "Query": //查询
  49. if (tabMain.SelectedTab.Index ==0)
  50. Query();
  51. else if (tabMain.SelectedTab.Index == 1)
  52. QueryStd();
  53. else
  54. QueryAll();
  55. break;
  56. case "Export":
  57. Export();
  58. break;
  59. case "Close": //关闭
  60. Close();
  61. break;
  62. }
  63. }
  64. private void Export()
  65. {
  66. PlanComm.WaitFromOpen(this.Cursor);
  67. try
  68. {
  69. QueryAll();
  70. ulGridToExcel(ugAllChem, "索引码汇总");
  71. }
  72. finally
  73. {
  74. PlanComm.WaitFromColse(this.Cursor);
  75. }
  76. }
  77. private void QueryStd()
  78. {
  79. ComMscStdCicEntitys = EntityHelper.GetData<ComMscStdCicEntity>
  80. ("com.steering.pss.plnsaleord.steelMarkingPlan.FrmSteelProcessCard.queryMscStd", new object[] { }, ob);
  81. List<ComBaseGradeEntity> listSource = EntityHelper.GetData<ComBaseGradeEntity>
  82. ("com.steering.pss.plnsaleord.steelMarkingPlan.FrmSteelProcessCard.queryAllGrade", new object[] {}, ob);
  83. comBaseGradeEntityBindingSource.DataSource = listSource;
  84. GridHelper.RefreshAndAutoSize(ugGrade);
  85. /*
  86. List<ComMscStdChemEntity> listSource1 = EntityHelper.GetData<ComMscStdChemEntity>
  87. ("com.steering.pss.plnsaleord.steelMarkingPlan.FrmSteelProcessCard.queryMscStdChem", new object[] { ComMscStdCicEntitys.Select(p=>p.Cic).ToArray()}, ob);
  88. ComMscStdCicEntitys.ForEach(p => p.ComMscStdChemEntitys = listSource1.Where(q=>q.Cic==p.Cic).ToList());*/
  89. }
  90. private void Query()
  91. {
  92. List<CraftLg2MEntity> listSource = EntityHelper.GetData<CraftLg2MEntity>
  93. ("com.steering.pss.plnsaleord.steelMarkingPlan.FrmSteelProcessCard.queryLgMCondition", new object[] {
  94. chcCraftNo.Checked?chcCraftNo.Text:""
  95. ,chcCIC.Checked?uteCIC.Text.Trim():"", chcGrade.Checked? (uceGrade.SelectedIndex == -1 ? "" : uceGrade.SelectedItem.DataValue.ToString()):""
  96. }, ob);
  97. CraftLg2MEntityBindingSource.DataSource = listSource;
  98. GridHelper.RefreshAndAutoSize(ultraGridLgM);
  99. }
  100. private void egbLocationInfo_ExpandedStateChanged(object sender, EventArgs e)
  101. {
  102. if (scMain.Panel2Collapsed) return;
  103. if (egbCraftInfo.Expanded)
  104. {
  105. scMain.SplitterDistance = scMain.Size.Height - _height;
  106. }
  107. else
  108. {
  109. _height = scMain.Panel2.Size.Height;
  110. scMain.SplitterDistance = scMain.Size.Height - 25;
  111. }
  112. }
  113. private void scMain_SizeChanged(object sender, EventArgs e)
  114. {
  115. if (scMain.Panel2Collapsed) return;
  116. if (egbCraftInfo.Expanded)
  117. {
  118. scMain.SplitterDistance = scMain.Size.Height - _height;
  119. }
  120. else
  121. {
  122. scMain.SplitterDistance = scMain.Size.Height - 25;
  123. }
  124. }
  125. /// <summary>
  126. /// 查询工艺成分信息
  127. /// </summary>
  128. private void QueryLgCic(string cicGid)
  129. {
  130. CraftLg2CicEntityBindingSource.DataSource = EntityHelper.GetData<CraftLg2CicEntity>
  131. ("com.steering.pss.plnsaleord.steelMarkingPlan.FrmSteelProcessCard.queryLgCic", new object[] { cicGid }, ob); ;
  132. // GridHelper.RefreshAndAutoSize(ultraGridLgCic);
  133. }
  134. /// <summary>
  135. /// 查询目标工艺成分信息
  136. /// </summary>
  137. private void QueryLgTarCic(string tarCicGid)
  138. {
  139. CraftLg2TarCicEntityBindingSource.DataSource = EntityHelper.GetData<CraftLg2TarCicEntity>
  140. ("com.steering.pss.plnsaleord.steelMarkingPlan.FrmSteelProcessCard.queryLgTarCic", new object[] { tarCicGid }, ob);
  141. // GridHelper.RefreshAndAutoSize(ultraGridLgTarCic);
  142. }
  143. /// <summary>
  144. /// 查询CCM信息
  145. /// </summary>
  146. private void QueryLgCcm(string ccmGid)
  147. {
  148. CraftLg2CcmEntityBindingSource.DataSource = EntityHelper.GetData<CraftLg2CcmEntity>
  149. ("com.steering.pss.plnsaleord.steelMarkingPlan.FrmSteelProcessCard.queryLgCcm", new object[] { ccmGid }, ob);
  150. // GridHelper.RefreshAndAutoSize(ultraGridLgCcm);
  151. }
  152. /// <summary>
  153. /// 查询温度信息
  154. /// </summary>
  155. private void QueryLgtTem(string tepGid)
  156. {
  157. CraftLg2TemperatureEntitySource.DataSource = EntityHelper.GetData<CraftLg2TemperatureEntity>
  158. ("com.steering.pss.plnsaleord.steelMarkingPlan.FrmSteelProcessCard.queryLgtTem", new object[] { tepGid }, ob);
  159. // GridHelper.RefreshAndAutoSize(ultraGridLhTem);
  160. }
  161. private void QueryLgHj(string alloyGid)
  162. {
  163. CraftLg2AlloyEntityBindingSource.DataSource = EntityHelper.GetData<CraftLg2AlloyEntity>
  164. ("com.steering.pss.plnsaleord.steelMarkingPlan.FrmSteelProcessCard.queryLgtHj", new object[] { alloyGid }, ob);
  165. // GridHelper.RefreshAndAutoSize(ultraGridhJ);
  166. }
  167. private void ultraGridLgM_AfterRowActivate(object sender, EventArgs e)
  168. {
  169. CraftLg2MEntity CraftLg2MEntity = ultraGridLgM.ActiveRow.ListObject as CraftLg2MEntity;
  170. if (CraftLg2MEntity != null)
  171. {
  172. QueryLgCic(CraftLg2MEntity.CicGid);
  173. QueryLgTarCic(CraftLg2MEntity.TarCicGid);
  174. QueryLgCcm(CraftLg2MEntity.CcmGid);
  175. QueryLgtTem(CraftLg2MEntity.TepGid);
  176. QueryLgHj(CraftLg2MEntity.AlloyGid);
  177. }
  178. }
  179. private void ugGrade_AfterRowActivate(object sender, EventArgs e)
  180. {
  181. ComBaseGradeEntity ComBaseGradeEntity = ugGrade.ActiveRow.ListObject as ComBaseGradeEntity;
  182. if(ComBaseGradeEntity==null) return;
  183. List<ComMscStdCicEntity> list = ComMscStdCicEntitys.Where(p => p.Gradecode == ComBaseGradeEntity.Gradecode).ToList();
  184. if (list.Any())
  185. {
  186. List<ComMscStdChemEntity> listSource1 = EntityHelper.GetData<ComMscStdChemEntity>
  187. ("com.steering.pss.plnsaleord.steelMarkingPlan.FrmSteelProcessCard.queryMscStdChem", new object[] { list.Select(p => p.Cic).ToArray() }, ob);
  188. list.ForEach(p => p.ComMscStdChemEntitys = listSource1.Where(q => q.Cic == p.Cic).ToList());
  189. comMscStdCicEntityBindingSource.DataSource = list;
  190. }
  191. else
  192. {
  193. comMscStdCicEntityBindingSource.Clear();
  194. }
  195. this.ugStdCic.Rows.ExpandAll(true);
  196. // GridHelper.RefreshAndAutoSize(ugStdCic);
  197. }
  198. private DataTable dtBaseCode = null;
  199. private void QueryAll()
  200. {
  201. if (dtBaseCode == null)
  202. {
  203. dtBaseCode = ServerHelper.GetData("com.steering.pss.plnsaleord.steelMarkingPlan.FrmSteelProcessCard.queryBaseChem",
  204. new object[] {}, ob);
  205. for (var i = 0; i < dtBaseCode.Rows.Count; i++)
  206. {
  207. DataRow row = dtBaseCode.Rows[i];
  208. string ChemCode = row["CHEM_CODE"].ToString();
  209. string ChemName = row["CHEM_NAME"].ToString();
  210. AddNewGroup(ChemCode, ChemName);
  211. }
  212. }
  213. foreach (var ultraGridGroup in ugAllChem.DisplayLayout.Bands[0].Groups)
  214. {
  215. ultraGridGroup.Hidden = true;
  216. }
  217. DataTable dt = ServerHelper.GetData("com.steering.pss.plnsaleord.steelMarkingPlan.FrmSteelProcessCard.queryAllMscStdChem",
  218. new object[] { }, ob);
  219. dt = dt.AsEnumerable().GroupBy(p => new
  220. {
  221. GRADENAME = p["GRADENAME"].ToString(),
  222. CIC = p["CIC"].ToString()
  223. }).Select(p =>
  224. {
  225. DataRow dr = dataTable1.NewRow();
  226. dr["GRADENAME"] = p.Key.GRADENAME;
  227. dr["CIC"] = p.Key.CIC;
  228. foreach (var dataRow in p)
  229. {
  230. string chemCode = dataRow["CHEM_CODE"].ToString();
  231. dr[chemCode + "MIN"] = dataRow["STDMIN"];
  232. dr[chemCode + "MAX"] = dataRow["STDMAX"];
  233. ugAllChem.DisplayLayout.Bands[0].Groups[chemCode].Hidden = false;
  234. }
  235. return dr;
  236. }
  237. ).CopyToDataTable();
  238. GridHelper.CopyDataToDatatable(dt, dataTable1, true);
  239. }
  240. private void AddNewGroup(string ChemCode, string ChemName)
  241. {
  242. int ColumsCount = dataTable1.Columns.Count;
  243. DataColumn dcMin = new DataColumn(ChemCode + "MIN");
  244. DataColumn dcMax = new DataColumn(ChemCode + "MAX");
  245. dcMin.Caption = "下限";
  246. dcMax.Caption = "上限";
  247. dataTable1.Columns.Add(dcMin);
  248. dataTable1.Columns.Add(dcMax);
  249. int Groupcount = ugAllChem.DisplayLayout.Bands[0].Groups.Count;
  250. UltraGridGroup gp = new UltraGridGroup();
  251. gp.Key = ChemCode;
  252. gp.Header.Caption = ChemName;
  253. gp.RowLayoutGroupInfo.LabelSpan = 1;
  254. gp.RowLayoutGroupInfo.OriginX = 4*(Groupcount + 1);
  255. gp.RowLayoutGroupInfo.OriginY = 0;
  256. gp.RowLayoutGroupInfo.PreferredLabelSize = new System.Drawing.Size(0, 20);
  257. gp.RowLayoutGroupInfo.SpanX = 4;
  258. gp.RowLayoutGroupInfo.SpanY = 2;
  259. ugAllChem.DisplayLayout.Bands[0].Groups.Add(gp);
  260. var columsMin = ugAllChem.DisplayLayout.Bands[0].Columns[ColumsCount];
  261. var columsMax = ugAllChem.DisplayLayout.Bands[0].Columns[ColumsCount + 1];
  262. columsMin.Header.VisiblePosition = ColumsCount;
  263. columsMin.RowLayoutColumnInfo.OriginX = 0;
  264. columsMin.RowLayoutColumnInfo.OriginY = 0;
  265. columsMin.RowLayoutColumnInfo.ParentGroup = gp;
  266. columsMin.RowLayoutColumnInfo.PreferredLabelSize = new System.Drawing.Size(0, 20);
  267. columsMin.RowLayoutColumnInfo.SpanX = 2;
  268. columsMin.RowLayoutColumnInfo.SpanY = 1;
  269. columsMax.Header.VisiblePosition = ColumsCount + 1;
  270. columsMax.RowLayoutColumnInfo.OriginX = 2;
  271. columsMax.RowLayoutColumnInfo.OriginY = 0;
  272. columsMax.RowLayoutColumnInfo.ParentGroup = gp;
  273. columsMax.RowLayoutColumnInfo.PreferredLabelSize = new System.Drawing.Size(0, 20);
  274. columsMax.RowLayoutColumnInfo.SpanX = 2;
  275. columsMax.RowLayoutColumnInfo.SpanY = 1;
  276. }
  277. public void ulGridToExcel(Infragistics.Win.UltraWinGrid.UltraGrid ulGrid, string sFileName)
  278. {
  279. try
  280. {
  281. Infragistics.Win.UltraWinGrid.ExcelExport.UltraGridExcelExporter ulGridExt = new Infragistics.Win.UltraWinGrid.ExcelExport.UltraGridExcelExporter();
  282. ulGridExt.CellExported += ultraGridExcelExporter1_CellExported;
  283. System.Windows.Forms.SaveFileDialog saveFileDialog1 = new SaveFileDialog();
  284. if (ulGrid.Rows.Count == 0)
  285. {
  286. MessageBox.Show("没有数据,无法导出!", "提示信息", MessageBoxButtons.OK, MessageBoxIcon.Warning);
  287. return;
  288. }
  289. saveFileDialog1.FileName = sFileName + DateTime.Now.ToString("yyMMdd");
  290. saveFileDialog1.Filter = "Excel文件(*.xls)|*.xls";
  291. if (saveFileDialog1.ShowDialog() == DialogResult.OK)
  292. {
  293. string sFullName = saveFileDialog1.FileName;
  294. ulGridExt.Export(ulGrid, sFullName);
  295. ProcessStartInfo p = new ProcessStartInfo(sFullName);
  296. p.WorkingDirectory = Path.GetDirectoryName(sFullName);
  297. Process.Start(p);
  298. }
  299. }
  300. catch (Exception ex)
  301. {
  302. MessageBox.Show("导出失败,原因:" + ex.Message, "错误信息", MessageBoxButtons.OK, MessageBoxIcon.Error);
  303. }
  304. }
  305. private void ultraGridExcelExporter1_CellExported(object sender, Infragistics.Win.UltraWinGrid.ExcelExport.CellExportedEventArgs e)
  306. {
  307. // Get the cell being exporter
  308. UltraGridCell cell = e.GridRow.Cells[e.GridColumn];
  309. // Get the Merged cells.
  310. UltraGridCell[] mergedCells = cell.GetMergedCells();
  311. // Check to see if there are any merged cells. If not, we don't need to do anything.
  312. if (mergedCells != null)
  313. {
  314. // There are merged cells. Check to see if the cell being exported is the first one.
  315. bool isFirstCell = true;
  316. foreach (UltraGridCell mergedCell in mergedCells)
  317. {
  318. if (cell.Row.Index > mergedCell.Row.Index)
  319. {
  320. // If the cell being exported has a higher index that any of the cells
  321. // it is merged with, them it's not the first cell and we should already
  322. // have handled the merge.
  323. isFirstCell = false;
  324. break;
  325. }
  326. }
  327. // If it is the first cell, merge this cell with the cells below it based on the
  328. // count of the merged cells.
  329. if (isFirstCell)
  330. {
  331. int rowIndex = e.CurrentRowIndex;
  332. int colIndex = e.CurrentColumnIndex;
  333. e.CurrentWorksheet.MergedCellsRegions.Add(
  334. rowIndex,
  335. colIndex,
  336. rowIndex + (mergedCells.Length -1),
  337. colIndex);
  338. }
  339. }
  340. }
  341. }
  342. }