F_TAT_0603.cs 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272
  1. /*******************************************************************************
  2. * Copyright(c) 2014 DongkeSoft All rights reserved. / Confidential
  3. * 类的信息:
  4. * 1.程序名称:F_TAT_0603.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_0603 : 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_0603(Constant.FormMode formType, int entityId)
  42. {
  43. InitializeComponent();
  44. this._formType = formType;
  45. this._entityId = entityId;
  46. this.Text = FormTitles.F_TAT_0603;
  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_0603_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.ReadOnly = true;
  67. this.dgvJobs.IsSetInputColumnsColor = false;
  68. //控件除关闭外全部不可用
  69. this.tsbtnCreateJobs.Enabled = false;
  70. this.btnSubmit.Enabled = false;
  71. }
  72. }
  73. catch (Exception ex)
  74. {
  75. // 对异常进行共通处理
  76. ExceptionManager.HandleEventException(this.ToString(),
  77. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  78. }
  79. }
  80. /// <summary>
  81. /// 关闭窗体
  82. /// </summary>
  83. /// <param name="sender"></param>
  84. /// <param name="e"></param>
  85. private void btnClose_Click(object sender, EventArgs e)
  86. {
  87. this.Close();
  88. }
  89. /// <summary>
  90. /// 窗体自适应
  91. /// </summary>
  92. /// <param name="sender"></param>
  93. /// <param name="e"></param>
  94. private void tsbtnAdaptive_Click(object sender, EventArgs e)
  95. {
  96. this.dgvJobs.AutoResizeColumns(DataGridViewAutoSizeColumnsMode.AllCells);
  97. }
  98. /// <summary>
  99. /// 提交操作
  100. /// </summary>
  101. /// <param name="sender"></param>
  102. /// <param name="e"></param>
  103. private void btnSubmit_Click(object sender, EventArgs e)
  104. {
  105. try
  106. {
  107. //提交操作
  108. ServiceResultEntity srEntity =
  109. (ServiceResultEntity)DoAsync(() =>
  110. {
  111. return TATModuleProxy.Service.EditAdminDetail(Convert.ToInt32(this._entityId), this._dsSourse);
  112. });
  113. ServiceResultEntityManager.HandleServiceResultEntity(srEntity, this.Text);
  114. if (srEntity.Status == Constant.ServiceResultStatus.Success)
  115. {
  116. this.DialogResult = DialogResult.OK;
  117. }
  118. }
  119. catch (Exception ex)
  120. {
  121. // 对异常进行共通处理
  122. ExceptionManager.HandleEventException(this.ToString(),
  123. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  124. }
  125. }
  126. /// <summary>
  127. /// 创建全部工种信息,并同时创建各工种对应的明细信息
  128. /// </summary>
  129. /// <param name="sender"></param>
  130. /// <param name="e"></param>
  131. private void tsbtnCreateJobs_Click(object sender, EventArgs e)
  132. {
  133. try
  134. {
  135. //这句话,因为新建的时候,莫名其妙会多出一个数据源不存在的空行,这样设定就不会出现了。
  136. this.dgvJobs.AllowUserToAddRows = false;
  137. //获取全部工种
  138. DataSet dsJobs = (DataSet)DoAsync(() =>
  139. {
  140. return SystemModuleProxy.Service.GetJobsData(1);
  141. });
  142. //如果获取到了工种
  143. if (dsJobs != null && dsJobs.Tables.Count != Constant.INT_IS_ZERO)
  144. {
  145. //循环生成工种信息并加入到数据源中
  146. foreach (DataRow drFor in dsJobs.Tables[Constant.INT_IS_ZERO].Rows)
  147. {
  148. //首先查看该工种在现有数据源中是否存在
  149. int JobIsHave = 0;
  150. foreach (DataRow drSourse in this._dsSourse.Tables[Constant.INT_IS_ZERO].Rows)
  151. {
  152. if (drSourse.RowState == DataRowState.Deleted)
  153. {
  154. continue;
  155. }
  156. int drForJobsId = Convert.ToInt32(drFor["JobsId"]);
  157. int drSourseJobsId = Convert.ToInt32(drSourse["JobsId"]);
  158. if (drForJobsId == drSourseJobsId)
  159. {
  160. JobIsHave++;
  161. break;
  162. }
  163. }
  164. //如果不存在才重新生成
  165. if (JobIsHave == Constant.INT_IS_ZERO && drFor["JobsId"] != DBNull.Value)
  166. {
  167. DataRow drJobs = _dsSourse.Tables[Constant.INT_IS_ZERO].NewRow();
  168. drJobs["JobsId"] = drFor["JobsId"];
  169. drJobs["JobsCode"] = drFor["JobsCode"];
  170. drJobs["JobsName"] = drFor["JobsName"];
  171. drJobs["BaseAmount"] = Constant.INT_IS_ZERO;
  172. drJobs["Isend"] = Constant.INT_IS_ZERO;
  173. this._dsSourse.Tables[0].Rows.Add(drJobs);
  174. }
  175. }
  176. //绑定
  177. this.dgvJobs.AutoGenerateColumns = false;
  178. this.dgvJobs.DataSource = this._dsSourse.Tables[Constant.INT_IS_ZERO];
  179. }
  180. //加载完毕
  181. // this._pageLoadOK = true;
  182. this.dgvJobs.AllowUserToAddRows = true;
  183. this.dgvJobs.IsSetInputColumnsColor = true;
  184. }
  185. catch (Exception ex)
  186. {
  187. // 对异常进行共通处理
  188. ExceptionManager.HandleEventException(this.ToString(),
  189. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  190. }
  191. }
  192. /// <summary>
  193. /// 工种列表值变更
  194. /// </summary>
  195. /// <param name="sender"></param>
  196. /// <param name="e"></param>
  197. private void dgvJobs_CellValueChanged(object sender, DataGridViewCellEventArgs e)
  198. {
  199. try
  200. {
  201. if (this.dgvJobs.Rows.Count <= 1 || !this._showFlag)
  202. {
  203. return;
  204. }
  205. DataGridViewRow rowItem = this.dgvJobs.Rows[e.RowIndex];
  206. DataGridViewColumn columnItem = this.dgvJobs.Columns[e.ColumnIndex];
  207. //打开多选页面进行值绑定
  208. this._showFlag = false;
  209. FormUtility.BindJobsRowDataSource(this.dgvJobs,
  210. e.RowIndex, columnItem.Name, string.Empty);
  211. this._showFlag = true;
  212. // 设置可输入单元格的颜色
  213. this.dgvJobs.IsSetInputColumnsColor = true;
  214. }
  215. catch (Exception ex)
  216. {
  217. // 对异常进行共通处理
  218. ExceptionManager.HandleEventException(this.ToString(),
  219. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  220. }
  221. }
  222. #endregion
  223. #region 私有方法/函数
  224. /// <summary>
  225. /// 绑定数据源
  226. /// </summary>
  227. private void BindData()
  228. {
  229. try
  230. {
  231. if (this._entityId != Constant.INT_IS_ZERO && this._entityId != null)
  232. {
  233. ServiceResultEntity srEntity = TATModuleProxy.Service.GetAdminDetailEntityById(Convert.ToInt32(this._entityId));
  234. if (srEntity.Data != null)
  235. {
  236. this._dsSourse = (DataSet)srEntity.Data;
  237. this.dgvJobs.DataSource = this._dsSourse.Tables[Constant.INT_IS_ZERO];
  238. this.dgvJobs.IsSetInputColumnsColor = true;
  239. }
  240. }
  241. }
  242. catch (Exception ex)
  243. {
  244. throw ex;
  245. }
  246. }
  247. #endregion
  248. }
  249. }