comm.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327
  1. using System;
  2. using System.Collections;
  3. using System.Collections.Generic;
  4. using System.Data;
  5. using System.Linq;
  6. using System.Text;
  7. using System.Text.RegularExpressions;
  8. using Infragistics.Win;
  9. using Infragistics.Win.UltraWinEditors;
  10. using Infragistics.Win.UltraWinGrid;
  11. using Core.Mes.Client.Comm.Server;
  12. using CoreFS.CA06;
  13. namespace Core.StlMes.Client.Mcp.Mch
  14. {
  15. public class comm
  16. {
  17. /// <summary>
  18. /// 绑定combobox
  19. /// </summary>
  20. /// <param name="cmbx">控件名</param>
  21. /// <param name="dset">数据源ds</param>
  22. /// <param name="strVal">值</param>
  23. /// <param name="strName">显示名</param>
  24. /// <param name="filCondition">筛选条件</param>
  25. /// <param name="tips">是否新增</param>
  26. /// <param name="addItem">新增itemName</param>
  27. public static void FilComboboxAdd(UltraComboEditor cmbx, DataTable dt, string strVal, string strName, string filCondition, Boolean tips, String addItemName, String addItemValue)
  28. {
  29. if (dt.Columns.Count > 1)
  30. {
  31. DataView dvw = dt.DefaultView;
  32. //dvw.RowFilter = filCondition;
  33. ArrayList aryTmp = new ArrayList();
  34. if (tips == true)
  35. {
  36. aryTmp.Add(new ValueListItem(addItemValue, addItemName));
  37. }
  38. for (int i = 0; i < dvw.Count; i++)
  39. {
  40. aryTmp.Add(new ValueListItem(dvw[i][strVal].ToString(), dvw[i][strName].ToString()));
  41. }
  42. cmbx.DataSource = aryTmp;
  43. cmbx.DisplayMember = "DisplayText";
  44. cmbx.ValueMember = "DataValue";
  45. }
  46. }
  47. /// <summary>
  48. /// 激活输入当前值行数据
  49. /// </summary>
  50. /// <param name="ug">ultragrid</param>
  51. /// <param name="strColumn">列名</param>
  52. /// <param name="strKey">列值</param>
  53. public static string doActiveSelRow(UltraGrid ug, string strColumn, string strKey)
  54. {
  55. try
  56. {
  57. if (strKey != "")
  58. {
  59. foreach (UltraGridRow row in ug.Rows)
  60. {
  61. if (row.Cells[strColumn].Text.ToString() == strKey)
  62. {
  63. row.Activated = true;
  64. if (row.ChildBands != null)
  65. row.Expanded = true;
  66. }
  67. }
  68. }
  69. return "";
  70. }
  71. catch (Exception ex)
  72. {
  73. return ex.ToString();
  74. }
  75. }
  76. /// <summary>
  77. /// 获取产线
  78. /// </summary>
  79. /// <param name="arr1"></param>
  80. /// <returns></returns>
  81. public static string[] GetPlineCode(string[] arr1,OpeBase ob)
  82. {
  83. string[] arr = null;
  84. DataTable dt = ServerHelper.GetData("com.steering.mes.mcp.Vrp.FrmComm.getPlineCode", new Object[] { arr1 }, ob);
  85. if (dt != null && dt.Rows.Count > 0)
  86. {
  87. arr = new string[dt.Rows.Count];
  88. for (int i = 0; i < dt.Rows.Count; i++)
  89. {
  90. arr[i] = dt.Rows[i][0].ToString();
  91. }
  92. return arr;
  93. }
  94. else
  95. {
  96. return new string[1] { "" };
  97. }
  98. }
  99. /// <summary>
  100. /// 获取产线 ,加销售
  101. /// </summary>
  102. /// <param name="arr1"></param>
  103. /// <param name="ob"></param>
  104. /// <returns></returns>
  105. public static string[] GetPlineCode2(string[] arr1, OpeBase ob)
  106. {
  107. string[] arr = null;
  108. DataTable dt = ServerHelper.GetData("com.steering.mes.mcp.Vrp.FrmComm.getPlineCode", new Object[] { arr1 }, ob);
  109. if (dt != null && dt.Rows.Count > 0)
  110. {
  111. arr = new string[dt.Rows.Count +2];
  112. for (int i = 0; i < dt.Rows.Count; i++)
  113. {
  114. arr[i] = dt.Rows[i][0].ToString();
  115. }
  116. arr[dt.Rows.Count ] = "100101";
  117. arr[dt.Rows.Count + 1] = "100102";
  118. return arr;
  119. }
  120. else
  121. {
  122. return new string[1] { "" };
  123. }
  124. }
  125. /// <summary>
  126. /// 获取产线
  127. /// </summary>
  128. /// <param name="arr1"></param>
  129. /// <returns></returns>
  130. public static string[] GetPlineCode(string[] arr1,string ProcessCode, string custominfo, OpeBase ob)
  131. {
  132. if (ob==null || string.IsNullOrEmpty(ob.MainUrl)) return new string[]{};
  133. string[] arr = null;
  134. DataTable dt = ServerHelper.GetData("com.steering.mes.mcp.Vrp.FrmComm.getPlineCode", new Object[] { arr1, ProcessCode }, ob);
  135. arr = new string[dt.Rows.Count];
  136. if (custominfo != null && !custominfo.Equals(""))
  137. {
  138. string[] custominfos = custominfo.Split(',');
  139. for (int i = 0; i < custominfos.Length; i++)
  140. {
  141. arr[i] = custominfos[i].ToString();
  142. }
  143. return arr;
  144. }
  145. else if(dt != null && dt.Rows.Count > 0)
  146. {
  147. DataRow[] filteredRows = dt.Select($"PLINE_CODE NOT IN ('C109','C108')");
  148. DataTable filteredDt = filteredRows.CopyToDataTable();
  149. for (int i = 0; i < filteredDt.Rows.Count; i++)
  150. {
  151. arr[i] = filteredDt.Rows[i][0].ToString();
  152. }
  153. return arr;
  154. }
  155. else
  156. {
  157. return new string[1] { "" };
  158. }
  159. }
  160. /// <summary>
  161. /// 获取产线
  162. /// </summary>
  163. /// <param name="arr1"></param>
  164. /// <returns></returns>
  165. public static void GetPlineCode(string ProcessCode, UltraComboEditor ugc, OpeBase ob)
  166. {
  167. if (ob == null || string.IsNullOrEmpty(ob.MainUrl)) return;
  168. string[] arr = null;
  169. DataTable dt = ServerHelper.GetData("com.steering.mes.mcp.Vrp.FrmComm.getPlineCode", new Object[] { ProcessCode }, ob);
  170. if (dt != null && dt.Rows.Count > 0)
  171. {
  172. ugc.DataSource = dt;
  173. ugc.ValueMember = "PLINE_CODE";
  174. ugc.DisplayMember = "PLINE_NAME";
  175. }
  176. }
  177. public static string[] InitDropPlinePower(string processCode, UltraComboEditor ugc, string[] validDataPurviewIds,string custominfo ,OpeBase ob)
  178. {
  179. DataTable dt = ServerHelper.GetData("com.steering.mes.mcp.Vrp.FrmComm.getPlineCode", new object[] { validDataPurviewIds,processCode }, ob);
  180. if (dt != null && dt.Rows.Count > 0)
  181. {
  182. ugc.DataSource = dt;
  183. ugc.ValueMember = "PLINE_CODE";
  184. ugc.DisplayMember = "PLINE_NAME";
  185. string[] plineArr = new string[dt.Rows.Count];
  186. if (custominfo != null && !custominfo.Equals(""))
  187. {
  188. string[] custominfos = custominfo.Split(',');
  189. for (int i = 0; i< custominfos.Length; i++)
  190. {
  191. plineArr[i] = custominfos[i].ToString();
  192. }
  193. }
  194. else
  195. {
  196. //string dplineCode = ;
  197. DataRow[] filteredRows = dt.Select($"PLINE_CODE NOT IN ('C109','C108')");
  198. DataTable filteredDt = filteredRows.CopyToDataTable();
  199. for (int i = 0; i < filteredDt.Rows.Count; i++)
  200. {
  201. plineArr[i] = filteredDt.Rows[i]["PLINE_CODE"].ToString();
  202. }
  203. }
  204. return plineArr;
  205. }
  206. else
  207. {
  208. return null;
  209. }
  210. }
  211. public static string[] InitDroCheckStation(string processCode, UltraComboEditor ugc, string[] validDataPurviewIds, OpeBase ob)
  212. {
  213. DataTable dt = ServerHelper.GetData("com.steering.mes.mcp.Vrp.FrmComm.getCheckStation", new object[] { validDataPurviewIds, processCode }, ob);
  214. if (dt != null && dt.Rows.Count > 0)
  215. {
  216. ugc.DataSource = dt;
  217. ugc.ValueMember = "BASECODE";
  218. ugc.DisplayMember = "BASENAME";
  219. string[] plineArr = new string[dt.Rows.Count];
  220. for (int i = 0; i < dt.Rows.Count; i++)
  221. {
  222. plineArr[i] = dt.Rows[i]["BASECODE"].ToString();
  223. }
  224. return plineArr;
  225. }
  226. else
  227. {
  228. return null;
  229. }
  230. }
  231. public static string[] InitDropPlineCodePower(string processCode, UltraComboEditor ugc, string[] validDataPurviewIds, OpeBase ob)
  232. {
  233. DataTable dt = ServerHelper.GetData("com.steering.mes.mcp.Vrp.FrmComm.getPlineCodeName", new object[] { validDataPurviewIds, processCode }, ob);
  234. if (dt != null && dt.Rows.Count > 0)
  235. {
  236. ugc.DataSource = dt;
  237. ugc.ValueMember = "PLINE_CODE";
  238. ugc.DisplayMember = "PLINE_NAME";
  239. string[] plineArr = new string[dt.Rows.Count];
  240. for (int i = 0; i < dt.Rows.Count; i++)
  241. {
  242. plineArr[i] = dt.Rows[i]["PLINE_CODE"].ToString();
  243. }
  244. return plineArr;
  245. }
  246. else
  247. {
  248. return null;
  249. }
  250. }
  251. /// <summary>
  252. /// 刷新Grid数据并根据数据调整Grid列宽
  253. /// </summary>
  254. /// <param name="ultraGrid">需要处理的Grid</param>
  255. public static void RefreshAndAutoSize(Infragistics.Win.UltraWinGrid.UltraGrid ultraGrid, string[] unSizeColumns = null)
  256. {
  257. try
  258. {
  259. ultraGrid.DataBind();
  260. ultraGrid.UpdateData();
  261. ultraGrid.Refresh();
  262. foreach (Infragistics.Win.UltraWinGrid.UltraGridBand band in ultraGrid.DisplayLayout.Bands)
  263. {
  264. foreach (Infragistics.Win.UltraWinGrid.UltraGridColumn column in band.Columns)
  265. {
  266. if (unSizeColumns == null || !unSizeColumns.Contains(column.Key))
  267. column.PerformAutoResize(Infragistics.Win.UltraWinGrid.PerformAutoSizeType.AllRowsInBand, true);
  268. }
  269. }
  270. ultraGrid.Refresh();
  271. }
  272. catch { }
  273. }
  274. /// <summary>
  275. /// UltraGrid可读(非主从结构)
  276. /// </summary>
  277. /// <param name="ugr">UltraGrid</param>
  278. /// <param name="keys">可编辑列</param>
  279. public static void setOtherColumnReadOnly(UltraGrid ugr, string[] keys, int BandInt = 0)
  280. {
  281. if (keys == null || keys.Length == 0)
  282. {
  283. foreach (UltraGridColumn ugc in ugr.DisplayLayout.Bands[BandInt].Columns)
  284. {
  285. ugc.CellActivation = Activation.ActivateOnly;
  286. }
  287. }
  288. else
  289. {
  290. keys.ToArray();
  291. foreach (UltraGridColumn ugc in ugr.DisplayLayout.Bands[BandInt].Columns)
  292. {
  293. if (!keys.Contains(ugc.Key))
  294. {
  295. ugc.CellActivation = Activation.ActivateOnly;
  296. }
  297. }
  298. }
  299. }
  300. }
  301. }