F_RPT_080114.cs 18 KB

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