F_RPT_080114.cs 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482
  1. /*******************************************************************************
  2. * Copyright(c) 2015 DongkeSoft All rights reserved. / Confidential
  3. * 类的信息:
  4. * 1.程序名称:F_RPT_080114.cs
  5. * 2.功能描述:QC检验数据明细表
  6. * 编辑履历:
  7. * 作者 日期 版本 修改内容
  8. * 秦祺 2022/12/09 1.00 新建
  9. *******************************************************************************/
  10. using System;
  11. using System.Collections.Generic;
  12. using System.Data;
  13. using System.Linq;
  14. using System.Windows.Forms;
  15. using Dongke.IBOSS.PRD.Basics.BaseResources;
  16. using Dongke.IBOSS.PRD.Client.CommonModule;
  17. using Dongke.IBOSS.PRD.Client.Controls;
  18. using Dongke.IBOSS.PRD.Client.DataModels;
  19. using Dongke.IBOSS.PRD.Client.PMModule;
  20. using Dongke.IBOSS.PRD.WCF.DataModels;
  21. using Dongke.IBOSS.PRD.WCF.Proxys;
  22. namespace Dongke.IBOSS.PRD.Client.ReportModule
  23. {
  24. public partial class F_RPT_080114 : DKDockPanelBase
  25. {
  26. #region 成员变量
  27. // 窗体的单例模式
  28. private static F_RPT_080114 _instance;
  29. #region 定义数据类型
  30. //输入模糊查询字段之后,返回的关键词
  31. List<cbinpectname> listNew = new List<cbinpectname>();
  32. //下拉框初始化数据绑定
  33. List<cbinpectname> listOnit = new List<cbinpectname>();
  34. //数据库查询原始数据
  35. List<cbinpectnameType> selectList = new List<cbinpectnameType>();
  36. /// <summary>
  37. /// 空间所需类
  38. /// </summary>
  39. public class cbinpectname
  40. {
  41. /// <summary>
  42. /// id
  43. /// </summary>
  44. public string ITEMSID { get; set; }
  45. /// <summary>
  46. /// 检验类型
  47. /// </summary>
  48. public string INSPECTTYPE { get; set; }
  49. /// <summary>
  50. /// 名称
  51. /// </summary>
  52. public string INSPECTNAME { get; set; }
  53. }
  54. /// <summary>
  55. /// 数据库查询数据返回类
  56. /// </summary>
  57. public class cbinpectnameType : cbinpectname
  58. {
  59. /// <summary>
  60. /// 版本号
  61. /// </summary>
  62. public string INSPECTVERSION { get; set; }
  63. /// <summary>
  64. /// 是否有效
  65. /// </summary>
  66. public string VALUEFLAG { get; set; }
  67. }
  68. #endregion
  69. #endregion
  70. #region 构造函数
  71. public F_RPT_080114()
  72. {
  73. InitializeComponent();
  74. // 窗体显示的Title
  75. this.Text = "QC检验数据明细表";
  76. this.btnSearch.Text = ButtonText.BTN_SEARCH;
  77. this.tsbtnAdaptive.Text = ButtonText.TSBTN_ADAPTIVE;
  78. this.tsbtnClose.Text = ButtonText.TSBTN_CLOSE;
  79. this.btnClearCondition.Text = ButtonText.BTN_CLEARCONDITION;
  80. this.gbxCondition.Text = Constant.LABEL_QUERY_CONDITIONS;
  81. }
  82. #endregion
  83. #region 单例模式
  84. /// <summary>
  85. /// 单例模式,防止重复创建窗体
  86. /// </summary>
  87. public static F_RPT_080114 Instance
  88. {
  89. get
  90. {
  91. if (_instance == null || _instance.IsDisposed)
  92. {
  93. _instance = new F_RPT_080114();
  94. }
  95. return _instance;
  96. }
  97. }
  98. #endregion
  99. #region 事件处理
  100. /// <summary>
  101. /// 窗体加载事件
  102. /// </summary>
  103. /// <param name="sender"></param>
  104. /// <param name="e"></param>
  105. private void F_RPT_080114_Load(object sender, EventArgs e)
  106. {
  107. try
  108. {
  109. // 加载权限
  110. FormPermissionManager.FormPermissionControl(this.Name, this,
  111. LogInUserInfo.CurrentUser.CurrentUserEntity.UserRightData,
  112. LogInUserInfo.CurrentUser.CurrentUserEntity.FunctionData);
  113. this.dtpCreateTimeBegin.Value = DateTime.Now.Date;
  114. this.dtpCreateTimeEnd.Value = DateTime.Now.Date.AddDays(1).AddSeconds(-1);
  115. // 设置表格不自动创建列
  116. this.dgvQCdata.AutoGenerateColumns = false;
  117. // 检验标准名称
  118. //绑定检验类型
  119. ClientRequestEntity cre = new ClientRequestEntity();
  120. cre.NameSpace = "F_RPT_080116";
  121. cre.Name = "GetInspectName";
  122. ServiceResultEntity sre = DoAsync(() =>
  123. {
  124. return PCModuleProxyNew.Service.HandleRequest(cre);
  125. });
  126. if (sre.Data != null && sre.Data.Tables.Count > 0 && sre.Data.Tables[0].Rows.Count > 0)
  127. {
  128. //将查询的数据转换成List
  129. DataTable dt = sre.Data.Tables[0];
  130. for (int i = 0; i < dt.Rows.Count; i++)
  131. {
  132. var item = dt.Rows[i];
  133. selectList.Add(new cbinpectnameType
  134. {
  135. ITEMSID = item.ItemArray[0].ToString(),
  136. INSPECTTYPE = item.ItemArray[1].ToString(),
  137. INSPECTNAME = item.ItemArray[2].ToString(),
  138. INSPECTVERSION = item.ItemArray[3].ToString(),
  139. VALUEFLAG = item.ItemArray[4].ToString()
  140. });
  141. }
  142. this.cbInpectName.DisplayMember = "INSPECTNAME";
  143. this.cbInpectName.ValueMember = "ITEMSID";
  144. handle(radioButton1.Checked, radioButton3.Checked);
  145. }
  146. }
  147. catch (Exception ex)
  148. {
  149. // 对异常进行共通处理
  150. ExceptionManager.HandleEventException(this.ToString(),
  151. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  152. }
  153. }
  154. /// <summary>
  155. /// 自动适应列宽
  156. /// </summary>
  157. /// <param name="sender"></param>
  158. /// <param name="e"></param>
  159. private void tsbtnAdaptive_Click(object sender, EventArgs e)
  160. {
  161. this.dgvQCdata.AutoResizeColumns();
  162. }
  163. /// <summary>
  164. /// 窗体关闭事件
  165. /// </summary>
  166. /// <param name="sender"></param>
  167. /// <param name="e"></param>
  168. private void F_RPT_080114_FormClosed(object sender, FormClosedEventArgs e)
  169. {
  170. _instance = null;
  171. }
  172. /// <summary>
  173. /// 关闭按钮
  174. /// </summary>
  175. /// <param name="sender"></param>
  176. /// <param name="e"></param>
  177. private void tsbtnClose_Click(object sender, EventArgs e)
  178. {
  179. this.Close();
  180. }
  181. /// <summary>
  182. /// 查询按钮事件
  183. /// </summary>
  184. /// <param name="sender"></param>
  185. /// <param name="e"></param>
  186. private void btnSearch_Click(object sender, EventArgs e)
  187. {
  188. if (this.tabControl1.SelectedIndex == 1 && this.cbInpectName.Text.Length == 0)
  189. {
  190. MessageBox.Show("请选择检验标准名称", this.Text,
  191. MessageBoxButtons.OK, MessageBoxIcon.Information);
  192. return;
  193. }
  194. try
  195. {
  196. this.dgvBarcode.DataSource = null;
  197. this.dgvQCdata.DataSource = null;
  198. // 我们要保留的列名
  199. List<string> columnsToKeep = new List<string> { "检验依据", "检验项目" };
  200. // 遍历DataTable的列(反向遍历以避免索引问题)
  201. for (int i = dgvQCdata.Columns.Count - 1; i >= 0; i--)
  202. {
  203. if (!columnsToKeep.Contains(dgvQCdata.Columns[i].Name))
  204. {
  205. // 如果列名不在保留列表中,则删除该列
  206. dgvQCdata.Columns.RemoveAt(i);
  207. }
  208. }
  209. ClientRequestEntity cre = new ClientRequestEntity();
  210. cre.NameSpace = "F_RPT_080114";
  211. cre.Name = "GetBarCodeData";
  212. cre.Properties["BarCode"] = this.txtBarCode.Text.Trim();
  213. cre.Properties["CreateTimeBegin"] = this.dtpCreateTimeBegin.Value;
  214. cre.Properties["CreateTimeEnd"] = Convert.ToDateTime(this.dtpCreateTimeEnd.Value).AddSeconds(1);
  215. if (this.cbInpectName.Text.Length > 0)
  216. {
  217. cre.Properties["InpectName"] = listOnit.Where(ex => ex.INSPECTNAME == this.cbInpectName.Text).FirstOrDefault().ITEMSID;
  218. }
  219. if (this.radioButton3.Checked)
  220. {
  221. cre.Properties["InpectType"] = 615;
  222. }
  223. ServiceResultEntity sre = DoAsync(() =>
  224. {
  225. return PCModuleProxyNew.Service.HandleRequest(cre);
  226. });
  227. if (sre.Data != null && sre.Data.Tables.Count > 0 && sre.Data.Tables[0].Rows.Count > 0)
  228. {
  229. //if (tabControl1.SelectedIndex == 0)
  230. //{
  231. if (this.cbInpectName.Text.Length > 0)
  232. {
  233. List<string> ss = new List<string>();
  234. for (int j = 0; j < this.dgvQCdata.Columns.Count; j++)
  235. {
  236. if (!sre.Data.Tables[0].Columns.Contains(this.dgvQCdata.Columns[j].Name))
  237. {
  238. ss.Add(this.dgvQCdata.Columns[j].Name);
  239. }
  240. }
  241. for (int y = 0; y < ss.Count; y++)
  242. {
  243. this.dgvQCdata.Columns.Remove(ss[y]);
  244. }
  245. dgvBarcode.DataSource = sre.Data.Tables[1];
  246. for (int i = 0; i < sre.Data.Tables[0].Columns.Count; i++)
  247. {
  248. string columns = sre.Data.Tables[0].Columns[i].ColumnName;
  249. if (!this.dgvQCdata.Columns.Contains(columns))
  250. {
  251. DataGridViewTextBoxColumn d = new DataGridViewTextBoxColumn();
  252. this.dgvQCdata.Columns.AddRange(new DataGridViewColumn[] { d });
  253. d.DataPropertyName = columns;
  254. d.HeaderText = columns;
  255. d.Name = columns;
  256. d.ReadOnly = true;
  257. }
  258. }
  259. dgvQCdata.DataSource = sre.Data.Tables[0];
  260. }
  261. else
  262. {
  263. dgvBarcode.DataSource = sre.Data.Tables[0];
  264. }
  265. tsbtnAdaptive_Click(null, null);
  266. }
  267. else
  268. {
  269. // 提示未查找到数据
  270. MessageBox.Show(Messages.MSG_CMN_I002, this.Text,
  271. MessageBoxButtons.OK, MessageBoxIcon.Information);
  272. }
  273. }
  274. catch (Exception ex)
  275. {
  276. this.btnSearch.Enabled = true;
  277. this.btnClearCondition.Enabled = true;
  278. // 对异常进行共通处理
  279. ExceptionManager.HandleEventException(this.ToString(),
  280. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  281. }
  282. }
  283. /// <summary>
  284. /// 清空条件按钮事件
  285. /// </summary>
  286. /// <param name="sender"></param>
  287. /// <param name="e"></param>
  288. private void btnClearCondition_Click(object sender, EventArgs e)
  289. {
  290. this.dtpCreateTimeBegin.Value = DateTime.Now.Date;
  291. this.dtpCreateTimeEnd.Value = DateTime.Now.Date.AddDays(1).AddSeconds(-1);
  292. this.txtBarCode.Text = "";
  293. this.cbInpectName.Text = "";
  294. //清空combobox
  295. this.cbInpectName.Items.Clear();
  296. this.cbInpectName.Items.AddRange(listOnit.ToArray());
  297. }
  298. /// <summary>
  299. /// 导出
  300. /// </summary>
  301. /// <param name="sender"></param>
  302. /// <param name="e"></param>
  303. private void tsbtnEdit_Click(object sender, EventArgs e)
  304. {
  305. try
  306. {
  307. if (this.dgvBarcode.CurrentCell != null)
  308. {
  309. DataRowView dr = (DataRowView)this.dgvBarcode.CurrentRow.DataBoundItem;
  310. string barcode = dr["BARCODE"].ToString();
  311. string inspectname = dr["inspectname"].ToString();
  312. string goUrl = "http://172.18.32.32:9100/main/excel/excelRW.ashx";
  313. System.Diagnostics.Process.Start(goUrl + "?barcode=" + barcode + "&inspectname=" + inspectname);
  314. }
  315. }
  316. catch (Exception ex)
  317. {
  318. this.btnSearch.Enabled = true;
  319. this.btnClearCondition.Enabled = true;
  320. // 对异常进行共通处理
  321. ExceptionManager.HandleEventException(this.ToString(),
  322. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  323. }
  324. }
  325. /// <summary>
  326. /// 双击编辑
  327. /// </summary>
  328. /// <param name="sender"></param>
  329. /// <param name="e"></param>
  330. private void dgvBarcodeIdnrk_CellDoubleClick(object sender, DataGridViewCellEventArgs e)
  331. {
  332. try
  333. {
  334. if (this.dgvQCdata.CurrentCell != null)
  335. {
  336. tsbtnEdit_Click(null, null);
  337. }
  338. }
  339. catch (Exception ex)
  340. {
  341. this.btnSearch.Enabled = true;
  342. this.btnClearCondition.Enabled = true;
  343. // 对异常进行共通处理
  344. ExceptionManager.HandleEventException(this.ToString(),
  345. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  346. }
  347. }
  348. #region 模糊查询 历史版本和型式检验 及数据处理
  349. /// <summary>
  350. /// 模糊查询
  351. /// </summary>
  352. /// <param name="sender"></param>
  353. /// <param name="e"></param>
  354. private void cbInpectNameText_Updata(object sender, EventArgs e)
  355. {
  356. //清空combobox
  357. this.cbInpectName.Items.Clear();
  358. //清空listNew
  359. listNew.Clear();
  360. //遍历全部备查数据
  361. foreach (var item in listOnit)
  362. {
  363. if (item.INSPECTNAME.Contains(this.cbInpectName.Text))
  364. {
  365. //符合,插入ListNew
  366. listNew.Add(item);
  367. }
  368. }
  369. //combobox添加已经查到的关键词
  370. this.cbInpectName.Items.AddRange(listNew.ToArray());
  371. //设置光标位置,否则光标位置始终保持在第一列,造成输入关键词的倒序排列
  372. this.cbInpectName.SelectionStart = this.cbInpectName.Text.Length;
  373. //保持鼠标指针原来状态,有时候鼠标指针会被下拉框覆盖,所以要进行一次设置。
  374. Cursor = Cursors.Default;
  375. //自动弹出下拉框
  376. this.cbInpectName.DroppedDown = true;
  377. }
  378. /// <summary>
  379. /// 数据处理
  380. /// </summary>
  381. /// <param name="a">是否显示历史版本</param>
  382. /// <param name="b">是否显示型式检验</param>
  383. private void handle(bool a, bool b)
  384. {
  385. //清除初始数据
  386. this.cbInpectName.Items.Clear();
  387. listOnit.Clear();
  388. //赋值数据以便筛选
  389. var list = selectList;
  390. //不显示历史版本
  391. if (!a)
  392. {
  393. list = list.Where(ex => ex.VALUEFLAG == "1").ToList();
  394. }
  395. // 型式检验
  396. list = !b ? list.Where(ex => ex.INSPECTTYPE != "615").ToList() : list.Where(ex => ex.INSPECTTYPE == "615").ToList();
  397. //遍历符合数据
  398. foreach (var item in list)
  399. {
  400. //按要求将数据装入listOnit中
  401. listOnit.Add(new cbinpectname
  402. {
  403. ITEMSID = item.ITEMSID,
  404. INSPECTTYPE = item.INSPECTTYPE,
  405. INSPECTNAME = a ? item.INSPECTNAME + "[版本:" + item.INSPECTVERSION + "]" : item.INSPECTNAME
  406. });
  407. }
  408. //赋值给控件
  409. this.cbInpectName.Items.AddRange(listOnit.ToArray());
  410. this.cbInpectName.Text = string.Empty;
  411. }
  412. /// <summary>
  413. /// 是否按钮数据切换
  414. /// </summary>
  415. /// <param name="sender"></param>
  416. /// <param name="e"></param>
  417. private void RadioButton_CheckedChanged(object sender, EventArgs e)
  418. {
  419. //滤除第一遍的请求
  420. if (!((RadioButton)sender).Checked)
  421. {
  422. return;
  423. }
  424. handle(radioButton1.Checked, radioButton3.Checked);
  425. }
  426. #endregion
  427. }
  428. #endregion
  429. }