comm.cs 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497
  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 System.Windows.Forms;
  12. using CoreFS.CA06;
  13. using Core.Mes.Client.Comm.Tool;
  14. using System.Drawing;
  15. using com.hnshituo.pur.vo;
  16. using System.Threading;
  17. namespace Pur.require_plan
  18. {
  19. class comm
  20. {
  21. /// <summary>
  22. /// 绑定combobox
  23. /// </summary>
  24. /// <param name="cmbx">控件名</param>
  25. /// <param name="dset">数据源ds</param>
  26. /// <param name="strVal">值</param>
  27. /// <param name="strName">显示名</param>
  28. /// <param name="filCondition">筛选条件</param>
  29. /// <param name="tips">是否新增</param>
  30. /// <param name="addItem">新增itemName</param>
  31. public static void FilComboboxAdd(UltraComboEditor cmbx, DataTable dt, string strVal, string strName, string filCondition, Boolean tips, String addItemName, String addItemValue)
  32. {
  33. if (dt.Columns.Count > 1)
  34. {
  35. DataView dvw = dt.DefaultView;
  36. dvw.RowFilter = filCondition;
  37. ArrayList aryTmp = new ArrayList();
  38. if (tips == true)
  39. {
  40. aryTmp.Add(new ValueListItem(addItemValue, addItemName));
  41. }
  42. for (int i = 0; i < dvw.Count; i++)
  43. {
  44. aryTmp.Add(new ValueListItem(dvw[i][strVal].ToString(), dvw[i][strName].ToString()));
  45. }
  46. cmbx.DataSource = aryTmp;
  47. cmbx.DisplayMember = "DisplayText";
  48. cmbx.ValueMember = "DataValue";
  49. SetComboItemHeight(cmbx);
  50. }
  51. }
  52. /// <summary>
  53. /// 激活输入当前值行数据
  54. /// </summary>
  55. /// <param name="ug">ultragrid</param>
  56. /// <param name="strColumn">列名</param>
  57. /// <param name="strKey">列值</param>
  58. public static string doActiveSelRow(UltraGrid ug, string strColumn, string strKey)
  59. {
  60. try
  61. {
  62. if (strKey != "")
  63. {
  64. foreach (UltraGridRow row in ug.Rows)
  65. {
  66. if (row.Cells[strColumn].Text.ToString() == strKey)
  67. {
  68. row.Activated = true;
  69. //if (row.ChildBands != null)
  70. //row.Expanded = true;
  71. }
  72. }
  73. }
  74. return "";
  75. }
  76. catch (Exception ex)
  77. {
  78. return ex.ToString();
  79. }
  80. }
  81. /// <summary>
  82. /// 删除子表中在父表中不存在的行
  83. /// </summary>
  84. /// <param name="dtChilds"></param>
  85. /// <param name="dtParents"></param>
  86. public static void delChildsNotExisPar(ref DataTable dtChilds, DataTable dtParents)
  87. {
  88. for (int i = 0; i < dtChilds.Rows.Count; )
  89. {
  90. bool blExist = false;
  91. foreach (DataRow drP in dtParents.Rows)
  92. {
  93. if (dtChilds.Rows[i]["ITEMCODE"].ToString() == drP["ITEMCODE"].ToString())
  94. {
  95. blExist = true;
  96. break;
  97. }
  98. }
  99. if (blExist == false)
  100. {
  101. dtChilds.Rows.RemoveAt(i);
  102. }
  103. else
  104. {
  105. i++;
  106. }
  107. }
  108. //return dtChilds;
  109. }
  110. /// <summary>
  111. /// 设置UltraComboEditor中的中文和非中文统一高度。
  112. /// </summary>
  113. /// <param name="cmb"></param>
  114. public static void SetComboItemHeight(UltraComboEditor cmb)
  115. {
  116. foreach (ValueListItem item in cmb.Items)
  117. {
  118. if (Regex.IsMatch(item.DisplayText, @"[\u4e00-\u9fa5]+"))
  119. {
  120. item.Appearance.FontData.SizeInPoints = 9.0F;
  121. }
  122. else
  123. {
  124. item.Appearance.FontData.SizeInPoints = 10.5F;
  125. }
  126. }
  127. }
  128. /// <summary>
  129. /// 绑定UltraComboEditor
  130. /// </summary>
  131. /// <param name="ucbE">控件对象</param>
  132. /// <param name="dt">绑定表</param>
  133. /// <param name="strDisplayMember">显示名称</param>
  134. /// <param name="strValueMember">值</param>
  135. public static void setUltraComboEditorBind(UltraComboEditor ucbE, DataTable dt, string strDisplayMember, string strValueMember)
  136. {
  137. strDisplayMember = strDisplayMember.Trim().ToUpper();
  138. strValueMember = strValueMember.Trim().ToUpper();
  139. if (strDisplayMember == strValueMember)
  140. {
  141. strDisplayMember = strDisplayMember + "1";
  142. }
  143. DataTable dtnew = new DataTable();
  144. DataColumn dcDisplayMember = new DataColumn(strDisplayMember);
  145. DataColumn dcValueMember = new DataColumn(strValueMember);
  146. dtnew.Columns.Add(dcDisplayMember);
  147. dtnew.Columns.Add(dcValueMember);
  148. Core.Mes.Client.Comm.Control.GridHelper.CopyDataToDatatable(ref dt, ref dtnew, false);
  149. //dtnew = getDtGroupBy_reDt(dtnew, strValueMember);
  150. ucbE.DataSource = dtnew;
  151. ucbE.DisplayMember = strDisplayMember;
  152. ucbE.ValueMember = strValueMember;
  153. SetComboItemHeight(ucbE);
  154. }
  155. /// <summary>
  156. /// 绑定UltraComboEditor
  157. /// </summary>
  158. /// <param name="ucbE">控件对象</param>
  159. /// <param name="dt">绑定表</param>
  160. /// <param name="strDisplayMember">显示名称</param>
  161. /// <param name="strValueMember">值</param>
  162. public static void setUltraComboEditorBind(UltraComboEditor ucbE, DataTable dt, string strDisplayMember, string strValueMember, string strFirstItemName, string strFirstItemValue)
  163. {
  164. strDisplayMember = strDisplayMember.Trim().ToUpper();
  165. strValueMember = strValueMember.Trim().ToUpper();
  166. if (strDisplayMember == strValueMember)
  167. {
  168. strDisplayMember = strDisplayMember + "1";
  169. }
  170. DataTable dtnew = new DataTable();
  171. DataColumn dcDisplayMember = new DataColumn(strDisplayMember);
  172. DataColumn dcValueMember = new DataColumn(strValueMember);
  173. dtnew.Columns.Add(dcDisplayMember);
  174. dtnew.Columns.Add(dcValueMember);
  175. DataRow dr = dtnew.NewRow();
  176. dr[strDisplayMember] = strFirstItemName;
  177. dr[strValueMember] = strFirstItemValue;
  178. dtnew.Rows.Add(dr);
  179. Core.Mes.Client.Comm.Control.GridHelper.CopyDataToDatatable(ref dt, ref dtnew, false);
  180. //dtnew = getDtGroupBy_reDt(dtnew, strValueMember);
  181. ucbE.DataSource = dtnew;
  182. ucbE.DisplayMember = strDisplayMember;
  183. ucbE.ValueMember = strValueMember;
  184. SetComboItemHeight(ucbE);
  185. }
  186. /// <summary>
  187. /// 绑定所有的下拉列表的数据
  188. /// </summary>
  189. public static void getUltcmbBindValueList(UltraComboEditor ultcmb, DataTable dt, string strDisplayMember, string strValueMember)
  190. {
  191. for (int i = 0; i < dt.Rows.Count; i++)
  192. {
  193. ValueListItem vlItem = new ValueListItem(dt.Rows[i][strValueMember].ToString().Trim(), dt.Rows[i][strDisplayMember].ToString().Trim());
  194. ultcmb.Items.Add(vlItem);
  195. }
  196. SetComboItemHeight(ultcmb);
  197. }
  198. /// <summary>
  199. /// 绑定所有的下拉列表的数据
  200. /// </summary>
  201. public static void getUltcmbBindValueList1(UltraComboEditor ultcmb, DataTable dt, string strDisplayMember, string strValueMember)
  202. {
  203. for (int i = 0; i < dt.Rows.Count; i++)
  204. {
  205. ValueListItem vlItem = new ValueListItem(dt.Rows[i][strValueMember].ToString().Trim(), dt.Rows[i][strDisplayMember].ToString().Trim());
  206. ultcmb.Items.Add(vlItem);
  207. }
  208. ValueListItem vlItem1 = new ValueListItem("", "/");
  209. ultcmb.Items.Add(vlItem1);
  210. SetComboItemHeight(ultcmb);
  211. }
  212. /// <summary>
  213. /// 判断UltraGrid是否存在相同的行
  214. /// </summary>
  215. /// <param name="ugr"></param>
  216. /// <param name="strColumn"></param>
  217. public static bool hasRepeatUgr(RowsCollection ugr, string strColumn)
  218. {
  219. foreach (UltraGridRow ugr1 in ugr)
  220. {
  221. UltraGridRow[] rows = null;
  222. IQueryable<UltraGridRow> queryableRow = ugr.AsQueryable();
  223. queryableRow = from q in queryableRow
  224. where q.Cells[strColumn].Value.ToString().ToUpper() == ugr1.Cells[strColumn].Value.ToString().ToUpper()
  225. select q;
  226. rows = queryableRow.ToArray();
  227. if (rows != null)
  228. {
  229. if (rows.Count<UltraGridRow>() > 1)
  230. {
  231. return true;
  232. }
  233. }
  234. }
  235. return false;
  236. }
  237. /// <summary>
  238. /// 去掉datatable某列重复值
  239. /// </summary>
  240. /// <param name="dt"></param>
  241. /// <param name="strColumn"></param>
  242. /// <returns>返回分组列的dataTable</returns>
  243. public static DataTable getDtGroupBy_reDt(DataTable dt, string strColumn)
  244. {
  245. if(dt==null || dt.Rows.Count==0)
  246. { return new DataTable(); }
  247. DataView dv = dt.DefaultView;
  248. dv.Sort = strColumn;
  249. dt = dv.ToTable();
  250. for (int i = 0; i < dt.Rows.Count; )
  251. {
  252. if (i != dt.Rows.Count-1)
  253. {
  254. if (dt.Rows[i][strColumn].ToString() == dt.Rows[i + 1][strColumn].ToString())
  255. {
  256. dt.Rows.RemoveAt(i + 1);
  257. }
  258. else
  259. {
  260. i++;
  261. }
  262. }
  263. else
  264. {
  265. break;
  266. }
  267. }
  268. return dt;
  269. }
  270. /// <summary>
  271. /// 去掉datatable某列重复值
  272. /// </summary>
  273. /// <param name="dt"></param>
  274. /// <param name="strColumn"></param>
  275. /// <returns>返回某一列的值</returns>
  276. public static ArrayList getDtGroupBy_reAl(DataTable dt, string strColumn)
  277. {
  278. ArrayList al = new ArrayList();
  279. var query = from t in dt.AsEnumerable()
  280. group t by new { t1 = t.Field<string>(strColumn) } into m
  281. select new
  282. {
  283. DeliverySubId = m.Key.t1,
  284. };
  285. if (query.ToList().Count > 0)
  286. {
  287. query.ToList().ForEach(q =>
  288. {
  289. if (!al.Contains(q.DeliverySubId))
  290. {
  291. al.Add(q.DeliverySubId);
  292. }
  293. });
  294. }
  295. return al;
  296. }
  297. /// <summary>
  298. /// 获取datatable某列值的ArrayList
  299. /// </summary>
  300. /// <param name="dt"></param>
  301. /// <param name="strColumn"></param>
  302. /// <param name="strConditionColumn">条件参数列</param>
  303. /// <param name="strCondition">条件</param>
  304. /// <returns>返回某一列的值</returns>
  305. public static ArrayList getDtColumnBy_reAl(DataTable dt, string strColumn,string strConditionColumn,string strCondition)
  306. {
  307. ArrayList al = new ArrayList();
  308. var query = from t in dt.AsEnumerable()
  309. where t.Field<string>(strConditionColumn) == strCondition
  310. select t;
  311. if (query.ToList().Count > 0)
  312. {
  313. query.ToList().ForEach(q =>
  314. {
  315. //if (!al.Contains(q.Field<string>(strColumn)))
  316. //{
  317. al.Add(q.Field<string>(strColumn));
  318. //}
  319. });
  320. }
  321. return al;
  322. }
  323. ///<summary>
  324. /// 键盘输入事件,控制只能输入数字
  325. /// </summary>
  326. /// <param name="sender"></param>
  327. /// <param name="e"></param>
  328. public static void txt_QTY_KeyPress(object sender, KeyPressEventArgs e)
  329. {
  330. if (!char.IsNumber(e.KeyChar) && e.KeyChar != (char)8)
  331. {
  332. e.Handled = true;
  333. }
  334. }
  335. public static string strStatu<T>(CoreFS.CA06.OpeBase ob, string strJavaPackName, object obj, params string[] strProperty)
  336. {
  337. string strPropertyName = "";
  338. if (strProperty.Length == 0)
  339. {
  340. strPropertyName = "Status";
  341. }
  342. else
  343. {
  344. strPropertyName = strProperty[0];
  345. }
  346. FrmBase frm = new FrmBase();
  347. frm.ob = ob;
  348. object o = frm.GetJsonService().execute<T>(strJavaPackName, "findById", new object[] { obj });
  349. string strStatu = o.GetType().GetProperty(strPropertyName).GetValue(o, null).ToString();
  350. return strStatu;
  351. }
  352. /// <summary>
  353. /// 打印报表预览
  354. /// </summary>
  355. /// <param name="ob"></param>
  356. /// <param name="strurl"></param>
  357. public static CoreResult printReport(CoreFS.CA06.OpeBase ob, string strurl, string strWindowName)
  358. {
  359. CoreResult core = new CoreResult();
  360. try
  361. {
  362. Thread.Sleep(500);
  363. core.Resultcode = 0;
  364. core.Resultdata = "";
  365. FrmRepExcel fBug = new FrmRepExcel(ob, strurl);
  366. fBug.AutoSize = true;
  367. fBug.MaximumSize = new Size(Screen.PrimaryScreen.WorkingArea.Width, Screen.PrimaryScreen.WorkingArea.Height);
  368. fBug.WindowState = FormWindowState.Maximized;
  369. fBug.Text = strWindowName;
  370. fBug.ShowDialog();
  371. return core;
  372. }
  373. catch (Exception e)
  374. {
  375. core.Resultcode = 0;
  376. core.Resultdata = "";
  377. core.Resultmsg = "预览失败:" + e.Message;
  378. return core;
  379. }
  380. }
  381. /// <summary>
  382. /// 获取自动生成下拉列表控件
  383. /// </summary>
  384. /// <returns></returns>
  385. public static UltraComboEditor getNewUltraComboEditor(Form frm)
  386. {
  387. UltraComboEditor cmb = new UltraComboEditor();
  388. cmb.DropDownStyle = DropDownStyle.DropDownList;
  389. cmb.Visible = false;
  390. frm.Controls.Add(cmb);
  391. return cmb;
  392. }
  393. /// <summary>
  394. /// 再次确认操作
  395. /// </summary>
  396. /// <returns></returns>
  397. public static Boolean ConfirmOption(string strTips)
  398. {
  399. if (strTips.LastIndexOf('?') + 1 != strTips.Length && strTips.LastIndexOf('?') + 1 != strTips.Length)
  400. {
  401. strTips += "?";
  402. }
  403. if (MessageUtil.ShowYesNoAndTips(strTips).Equals(DialogResult.Yes))
  404. {
  405. return true;
  406. }
  407. else
  408. {
  409. return false;
  410. }
  411. }
  412. /// <summary>
  413. /// 刷新Grid数据并根据数据调整Grid列宽(输入不需要调整列宽的列)
  414. /// </summary>
  415. /// <param name="ultraGrid">需要处理的Grid</param>
  416. /// <param name="cols">不需要调整列宽的列,或band的key值</param>
  417. public static void RefreshAndAutoSizeExceptColumns(Infragistics.Win.UltraWinGrid.UltraGrid ultraGrid, params string[] cols)
  418. {
  419. try
  420. {
  421. //转化为大写
  422. for (int i=0;i<cols.Length;i++)
  423. {
  424. cols[i] = cols[i].ToUpper();
  425. }
  426. //ultraGrid.DataBind();
  427. foreach (Infragistics.Win.UltraWinGrid.UltraGridBand band in ultraGrid.DisplayLayout.Bands)
  428. {
  429. if (cols.Contains(band.Key.ToUpper()))
  430. {
  431. continue;
  432. }
  433. foreach (Infragistics.Win.UltraWinGrid.UltraGridColumn column in band.Columns)
  434. {
  435. if (cols.Contains(column.Key.ToUpper()))
  436. {
  437. continue;
  438. }
  439. column.PerformAutoResize(Infragistics.Win.UltraWinGrid.PerformAutoSizeType.AllRowsInBand);
  440. }
  441. }
  442. //ultraGrid.Refresh();
  443. }
  444. catch { }
  445. }
  446. /// <summary>
  447. /// 刷新Grid数据并根据数据调整Grid列宽(输入需要调整列宽的列)
  448. /// </summary>
  449. /// <param name="ultraGrid">需要处理的Grid</param>
  450. /// <param name="cols">需要调整列宽的列</param>
  451. public static void RefreshAndAutoSizeColumns(Infragistics.Win.UltraWinGrid.UltraGrid ultraGrid, params string[] cols)
  452. {
  453. try
  454. {
  455. //ultraGrid.DataBind();
  456. //转化为大写
  457. for (int i = 0; i < cols.Length; i++)
  458. {
  459. cols[i] = cols[i].ToUpper();
  460. }
  461. foreach (Infragistics.Win.UltraWinGrid.UltraGridBand band in ultraGrid.DisplayLayout.Bands)
  462. {
  463. foreach (Infragistics.Win.UltraWinGrid.UltraGridColumn column in band.Columns)
  464. {
  465. if (!cols.Contains(column.Key.ToUpper()))
  466. {
  467. continue;
  468. }
  469. column.PerformAutoResize(Infragistics.Win.UltraWinGrid.PerformAutoSizeType.AllRowsInBand);
  470. }
  471. }
  472. //ultraGrid.Refresh();
  473. }
  474. catch { }
  475. }
  476. }
  477. }