F_TAT_0503.cs 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274
  1. /*******************************************************************************
  2. * Copyright(c) 2014 DongkeSoft All rights reserved. / Confidential
  3. * 类的信息:
  4. * 1.程序名称:F_TAT_0503.cs
  5. * 2.功能描述:进度考核明细
  6. * 编辑履历:
  7. * 作者 日期 版本 修改内容
  8. * 宋扬 2014/12/16 1.00 新建
  9. *******************************************************************************/
  10. using System;
  11. using System.Data;
  12. using System.Windows.Forms;
  13. using Dongke.IBOSS.PRD.Basics.BaseControls;
  14. using Dongke.IBOSS.PRD.Basics.BaseResources;
  15. using Dongke.IBOSS.PRD.Client.CommonModule;
  16. using Dongke.IBOSS.PRD.Client.Controls;
  17. using Dongke.IBOSS.PRD.WCF.DataModels;
  18. using Dongke.IBOSS.PRD.WCF.Proxys;
  19. using Dongke.IBOSS.PRD.WCF.Proxys.SystemModuleService;
  20. using Dongke.IBOSS.PRD.WCF.Proxys.TATModuleService;
  21. namespace Dongke.IBOSS.PRD.Client.TATModule
  22. {
  23. public partial class F_TAT_0503 : FormBase
  24. {
  25. #region 成员变量
  26. // 窗体模式ID
  27. private Constant.FormMode _formType;
  28. // 操作实体ID
  29. private int? _entityId;
  30. // 选择窗体弹出标识
  31. private bool _showFlag = true;
  32. // 数据源
  33. private DataSet _dsSourse;
  34. #endregion
  35. #region 构造函数
  36. /// <summary>
  37. /// 窗体构造
  38. /// </summary>
  39. /// <param name="formType">窗体开启模式</param>
  40. /// <param name="entityId">操作实体ID</param>
  41. public F_TAT_0503(Constant.FormMode formType, int entityId)
  42. {
  43. InitializeComponent();
  44. this._formType = formType;
  45. this._entityId = entityId;
  46. this.Text = FormTitles.F_TAT_0503;
  47. }
  48. #endregion
  49. #region 事件处理
  50. /// <summary>
  51. /// 窗体加载
  52. /// </summary>
  53. /// <param name="sender"></param>
  54. /// <param name="e"></param>
  55. private void F_TAT_0503_Load(object sender, EventArgs e)
  56. {
  57. try
  58. {
  59. this.dgvJobs.AutoGenerateColumns = false;
  60. //绑定数据源与列表
  61. this.BindData();
  62. //如果是审核及观看模式
  63. if (this._formType == Constant.FormMode.Display)
  64. {
  65. //不能删除
  66. this.dgvJobs.AllowUserToDeleteRows = false;
  67. //列表设置为只读
  68. this.dgvJobs.ReadOnly = true;
  69. this.dgvJobs.IsSetInputColumnsColor = false;
  70. //控件除关闭外全部不可用
  71. this.tsbtnCreateJobs.Enabled = false;
  72. this.btnSubmit.Enabled = false;
  73. }
  74. }
  75. catch (Exception ex)
  76. {
  77. // 对异常进行共通处理
  78. ExceptionManager.HandleEventException(this.ToString(),
  79. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  80. }
  81. }
  82. /// <summary>
  83. /// 关闭窗体
  84. /// </summary>
  85. /// <param name="sender"></param>
  86. /// <param name="e"></param>
  87. private void btnClose_Click(object sender, EventArgs e)
  88. {
  89. this.Close();
  90. }
  91. /// <summary>
  92. /// 窗体自适应
  93. /// </summary>
  94. /// <param name="sender"></param>
  95. /// <param name="e"></param>
  96. private void tsbtnAdaptive_Click(object sender, EventArgs e)
  97. {
  98. this.dgvJobs.AutoResizeColumns(DataGridViewAutoSizeColumnsMode.AllCells);
  99. }
  100. /// <summary>
  101. /// 提交操作
  102. /// </summary>
  103. /// <param name="sender"></param>
  104. /// <param name="e"></param>
  105. private void btnSubmit_Click(object sender, EventArgs e)
  106. {
  107. try
  108. {
  109. //提交操作
  110. ServiceResultEntity srEntity =
  111. (ServiceResultEntity)DoAsync(() =>
  112. {
  113. return TATModuleProxy.Service.EditProgressDetail(Convert.ToInt32(this._entityId), this._dsSourse);
  114. });
  115. ServiceResultEntityManager.HandleServiceResultEntity(srEntity, this.Text);
  116. if (srEntity.Status == Constant.ServiceResultStatus.Success)
  117. {
  118. this.DialogResult = DialogResult.OK;
  119. }
  120. }
  121. catch (Exception ex)
  122. {
  123. // 对异常进行共通处理
  124. ExceptionManager.HandleEventException(this.ToString(),
  125. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  126. }
  127. }
  128. /// <summary>
  129. /// 工种列表值变更
  130. /// </summary>
  131. /// <param name="sender"></param>
  132. /// <param name="e"></param>
  133. private void dgvJobs_CellValueChanged(object sender, DataGridViewCellEventArgs e)
  134. {
  135. try
  136. {
  137. if (this.dgvJobs.Rows.Count <= 1 || !this._showFlag)
  138. {
  139. return;
  140. }
  141. DataGridViewRow rowItem = this.dgvJobs.Rows[e.RowIndex];
  142. DataGridViewColumn columnItem = this.dgvJobs.Columns[e.ColumnIndex];
  143. //打开多选页面进行值绑定
  144. this._showFlag = false;
  145. FormUtility.BindJobsRowDataSource(this.dgvJobs,
  146. e.RowIndex, columnItem.Name, string.Empty);
  147. this._showFlag = true;
  148. // 设置可输入单元格的颜色
  149. this.dgvJobs.IsSetInputColumnsColor = true;
  150. }
  151. catch (Exception ex)
  152. {
  153. // 对异常进行共通处理
  154. ExceptionManager.HandleEventException(this.ToString(),
  155. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  156. }
  157. }
  158. /// <summary>
  159. /// 创建全部工种信息,并同时创建各工种对应的明细信息
  160. /// </summary>
  161. /// <param name="sender"></param>
  162. /// <param name="e"></param>
  163. private void tsbtnCreateJobs_Click(object sender, EventArgs e)
  164. {
  165. try
  166. {
  167. //这句话,因为新建的时候,莫名其妙会多出一个数据源不存在的空行,这样设定就不会出现了。
  168. this.dgvJobs.AllowUserToAddRows = false;
  169. //获取全部工种
  170. DataSet dsJobs = (DataSet)DoAsync(() =>
  171. {
  172. return SystemModuleProxy.Service.GetJobsData(1);
  173. });
  174. //如果获取到了工种
  175. if (dsJobs != null && dsJobs.Tables.Count != Constant.INT_IS_ZERO)
  176. {
  177. //循环生成工种信息并加入到数据源中
  178. foreach (DataRow drFor in dsJobs.Tables[Constant.INT_IS_ZERO].Rows)
  179. {
  180. //首先查看该工种在现有数据源中是否存在
  181. int JobIsHave = 0;
  182. foreach (DataRow drSourse in this._dsSourse.Tables[Constant.INT_IS_ZERO].Rows)
  183. {
  184. if (drSourse.RowState == DataRowState.Deleted)
  185. {
  186. continue;
  187. }
  188. int drForJobsId = Convert.ToInt32(drFor["JobsId"]);
  189. int drSourseJobsId = Convert.ToInt32(drSourse["JobsId"]);
  190. if (drForJobsId == drSourseJobsId)
  191. {
  192. JobIsHave++;
  193. break;
  194. }
  195. }
  196. //如果不存在才重新生成
  197. if (JobIsHave == Constant.INT_IS_ZERO && drFor["JobsId"] != DBNull.Value)
  198. {
  199. DataRow drJobs = _dsSourse.Tables[Constant.INT_IS_ZERO].NewRow();
  200. drJobs["JobsId"] = drFor["JobsId"];
  201. drJobs["JobsCode"] = drFor["JobsCode"];
  202. drJobs["JobsName"] = drFor["JobsName"];
  203. drJobs["BaseAmount"] = Constant.INT_IS_ZERO;
  204. drJobs["Isend"] = Constant.INT_IS_ZERO;
  205. this._dsSourse.Tables[Constant.INT_IS_ZERO].Rows.Add(drJobs);
  206. }
  207. }
  208. //绑定
  209. this.dgvJobs.AutoGenerateColumns = false;
  210. this.dgvJobs.DataSource = this._dsSourse.Tables[Constant.INT_IS_ZERO];
  211. }
  212. //加载完毕
  213. this.dgvJobs.AllowUserToAddRows = true;
  214. this.dgvJobs.IsSetInputColumnsColor = true;
  215. }
  216. catch (Exception ex)
  217. {
  218. // 对异常进行共通处理
  219. ExceptionManager.HandleEventException(this.ToString(),
  220. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  221. }
  222. }
  223. #endregion
  224. #region 私有方法/函数
  225. /// <summary>
  226. /// 绑定数据源
  227. /// </summary>
  228. private void BindData()
  229. {
  230. try
  231. {
  232. if (this._entityId != 0 && this._entityId != null)
  233. {
  234. ServiceResultEntity srEntity = TATModuleProxy.Service.GetProgressDetailById(Convert.ToInt32(this._entityId));
  235. if (srEntity.Data != null)
  236. {
  237. this._dsSourse = (DataSet)srEntity.Data;
  238. this.dgvJobs.DataSource = this._dsSourse.Tables[Constant.INT_IS_ZERO];
  239. this.dgvJobs.IsSetInputColumnsColor = true;
  240. }
  241. }
  242. }
  243. catch (Exception ex)
  244. {
  245. throw ex;
  246. }
  247. }
  248. #endregion
  249. }
  250. }