F_TAT_0201.cs 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547
  1. /*******************************************************************************
  2. * Copyright(c) 2014 DongkeSoft All rights reserved. / Confidential
  3. * 类的信息:
  4. * 1.程序名称:F_TAT_0201.cs
  5. * 2.功能描述:工价策略一览
  6. * 编辑履历:
  7. * 作者 日期 版本 修改内容
  8. * 庄天威 2014/11/18 1.00 新建
  9. *******************************************************************************/
  10. using System;
  11. using System.Data;
  12. using System.Windows.Forms;
  13. using Dongke.IBOSS.PRD.Basics.BaseResources;
  14. using Dongke.IBOSS.PRD.Basics.DockPanel;
  15. using Dongke.IBOSS.PRD.Client.CommonModule;
  16. using Dongke.IBOSS.PRD.WCF.DataModels;
  17. using Dongke.IBOSS.PRD.WCF.Proxys;
  18. using Dongke.IBOSS.PRD.WCF.Proxys.TATModuleService;
  19. namespace Dongke.IBOSS.PRD.Client.TATModule
  20. {
  21. /// <summary>
  22. /// 工价策略一览
  23. /// </summary>
  24. public partial class F_TAT_0201 : DockPanelBase
  25. {
  26. #region 成员变量
  27. // 单例模式
  28. private static F_TAT_0201 _instance;
  29. // 检索用加载条件实体
  30. private WagesEntity _wagesEntity = new WagesEntity();
  31. // 审核状态选择值
  32. private int? _auditStatusValue;
  33. // 策略类型选择值
  34. private int? _salaryTypeValue;
  35. #endregion
  36. #region 构造函数
  37. /// <summary>
  38. /// 窗体构造
  39. /// </summary>
  40. public F_TAT_0201()
  41. {
  42. InitializeComponent();
  43. }
  44. #endregion
  45. #region 单例模式
  46. /// <summary>
  47. /// 单例模式
  48. /// </summary>
  49. public static F_TAT_0201 Instance
  50. {
  51. get
  52. {
  53. if (_instance == null)
  54. {
  55. _instance = new F_TAT_0201();
  56. }
  57. return _instance;
  58. }
  59. }
  60. #endregion
  61. #region 事件处理
  62. /// <summary>
  63. /// 窗体加载
  64. /// </summary>
  65. /// <param name="sender"></param>
  66. /// <param name="e"></param>
  67. private void F_TAT_0201_Load(object sender, EventArgs e)
  68. {
  69. try
  70. {
  71. this.Text = FormTitles.F_TAT_0201;
  72. this.dgvWages.AutoGenerateColumns = false;
  73. //绑定页面各查询条件的数据源
  74. this.BindSelectData();
  75. }
  76. catch (Exception ex)
  77. {
  78. // 对异常进行共通处理
  79. ExceptionManager.HandleEventException(this.ToString(),
  80. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  81. }
  82. }
  83. /// <summary>
  84. /// 查询一览
  85. /// </summary>
  86. /// <param name="sender"></param>
  87. /// <param name="e"></param>
  88. private void btnSelect_Click(object sender, EventArgs e)
  89. {
  90. try
  91. {
  92. //绑定下拉框数据
  93. this.BindSelectedData();
  94. //获取数据源
  95. ServiceResultEntity srEntity = (ServiceResultEntity)DoAsync(this.GetDate);
  96. if (srEntity.Data != null && srEntity.Data.Tables.Count != 0)
  97. {
  98. this.BindGridView(srEntity.Data.Tables[0]);
  99. }
  100. //服务实体共通处理
  101. ServiceResultEntityManager.HandleServiceResultEntity(srEntity, this.Text);
  102. }
  103. catch (Exception ex)
  104. {
  105. // 对异常进行共通处理
  106. ExceptionManager.HandleEventException(this.ToString(),
  107. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  108. }
  109. }
  110. /// <summary>
  111. /// 清空条件
  112. /// </summary>
  113. /// <param name="sender"></param>
  114. /// <param name="e"></param>
  115. private void btnClear_Click(object sender, EventArgs e)
  116. {
  117. this.txtWagesName.Text = string.Empty;
  118. this.lbxAuditStatus.Text = string.Empty;
  119. this._auditStatusValue = null;
  120. this.txtRemarks.Text = string.Empty;
  121. this.cbStartTime.Checked = false;
  122. this.cbEndTime.Checked = false;
  123. this.lbxSalaryType.Text = string.Empty;
  124. this._salaryTypeValue = null;
  125. }
  126. /// <summary>
  127. /// 选中行改变
  128. /// </summary>
  129. /// <param name="sender"></param>
  130. /// <param name="e"></param>
  131. private void dgvWages_SelectionChanged(object sender, EventArgs e)
  132. {
  133. DataGridViewRow gvrNow = this.dgvWages.CurrentRow;
  134. if (gvrNow != null)
  135. {
  136. //如果是待审核就可以进行修改,审核,停用
  137. if (Convert.ToInt32(gvrNow.Cells["colAuditStatus"].Value)
  138. == Convert.ToInt32(Constant.AuditStatus.Pending))
  139. {
  140. this.tsbtnEdit.Enabled = true;
  141. this.tsbtnApprover.Enabled = true;
  142. this.tsbtnDisable.Enabled = true;
  143. }
  144. else //否则不可以
  145. {
  146. //如果是审批通过的则不可以删除
  147. if (Convert.ToInt32(gvrNow.Cells["colAuditStatus"].Value)
  148. == Convert.ToInt32(Constant.AuditStatus.Agree))
  149. {
  150. this.tsbtnDisable.Enabled = false;
  151. }
  152. else
  153. {
  154. this.tsbtnDisable.Enabled = true;
  155. }
  156. this.tsbtnEdit.Enabled = false;
  157. this.tsbtnApprover.Enabled = false;
  158. }
  159. }
  160. }
  161. /// <summary>
  162. /// 添加信息
  163. /// </summary>
  164. /// <param name="sender"></param>
  165. /// <param name="e"></param>
  166. private void tsbtnAdd_Click(object sender, EventArgs e)
  167. {
  168. try
  169. {
  170. //以新建模式打开信息窗体
  171. F_TAT_0202 frmTAT0202 = new F_TAT_0202(Constant.FormMode.Add, 0);
  172. DialogResult dialogResult = frmTAT0202.ShowDialog();
  173. //操作成功后刷新数据源
  174. if (dialogResult == DialogResult.OK)
  175. {
  176. this.dgvWages.DataSource = null;
  177. this.BindSelectedData();
  178. ServiceResultEntity srEntity = (ServiceResultEntity)DoAsync(this.GetDate);
  179. if (srEntity.Data != null && srEntity.Data.Tables.Count != 0)
  180. {
  181. this.BindGridView(srEntity.Data.Tables[0]);
  182. }
  183. //服务实体共通处理
  184. ServiceResultEntityManager.HandleServiceResultEntity(srEntity, this.Text);
  185. }
  186. }
  187. catch (Exception ex)
  188. {
  189. // 对异常进行共通处理
  190. ExceptionManager.HandleEventException(this.ToString(),
  191. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  192. }
  193. }
  194. /// <summary>
  195. /// 添加并复制明细
  196. /// </summary>
  197. /// <param name="sender"></param>
  198. /// <param name="e"></param>
  199. private void tsbtnCopy_Click(object sender, EventArgs e)
  200. {
  201. try
  202. {
  203. DataGridViewRow currentRow = this.dgvWages.CurrentRow;
  204. if (currentRow != null)
  205. {
  206. //获取需要添加明细的信息ID
  207. int entityId = Convert.ToInt32(currentRow.Cells["colWagesID"].Value);
  208. //以复制模式打开信息窗体
  209. F_TAT_0202 frmTAT0202 = new F_TAT_0202(Constant.FormMode.CopyAndAdd, entityId);
  210. DialogResult dialogResult = frmTAT0202.ShowDialog();
  211. //操作成功后刷新数据源
  212. if (dialogResult == DialogResult.OK)
  213. {
  214. this.dgvWages.DataSource = null;
  215. this.BindSelectedData();
  216. ServiceResultEntity srEntity = (ServiceResultEntity)DoAsync(this.GetDate);
  217. if (srEntity.Data != null && srEntity.Data.Tables.Count != 0)
  218. {
  219. this.BindGridView(srEntity.Data.Tables[0]);
  220. }
  221. //服务实体共通处理
  222. ServiceResultEntityManager.HandleServiceResultEntity(srEntity, this.Text);
  223. }
  224. }
  225. }
  226. catch (Exception ex)
  227. {
  228. // 对异常进行共通处理
  229. ExceptionManager.HandleEventException(this.ToString(),
  230. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  231. }
  232. }
  233. /// <summary>
  234. /// 编辑信息
  235. /// </summary>
  236. /// <param name="sender"></param>
  237. /// <param name="e"></param>
  238. private void tsbtnEdit_Click(object sender, EventArgs e)
  239. {
  240. try
  241. {
  242. DataGridViewRow currentRow = this.dgvWages.CurrentRow;
  243. if (currentRow != null)
  244. {
  245. //获取需要添加明细的信息ID
  246. int entityId = Convert.ToInt32(currentRow.Cells["colWagesID"].Value);
  247. //以编辑模式打开信息窗体
  248. F_TAT_0202 frmTAT0202 = new F_TAT_0202(Constant.FormMode.Edit, entityId);
  249. DialogResult dialogResult = frmTAT0202.ShowDialog();
  250. //操作成功后刷新数据源
  251. if (dialogResult == DialogResult.OK)
  252. {
  253. this.dgvWages.DataSource = null;
  254. this.BindSelectedData();
  255. ServiceResultEntity srEntity = (ServiceResultEntity)DoAsync(this.GetDate);
  256. if (srEntity.Data != null && srEntity.Data.Tables.Count != 0)
  257. {
  258. this.BindGridView(srEntity.Data.Tables[0]);
  259. }
  260. //服务实体共通处理
  261. ServiceResultEntityManager.HandleServiceResultEntity(srEntity, this.Text);
  262. }
  263. }
  264. }
  265. catch (Exception ex)
  266. {
  267. // 对异常进行共通处理
  268. ExceptionManager.HandleEventException(this.ToString(),
  269. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  270. }
  271. }
  272. /// <summary>
  273. /// 审批信息
  274. /// </summary>
  275. /// <param name="sender"></param>
  276. /// <param name="e"></param>
  277. private void tsbtnApprover_Click(object sender, EventArgs e)
  278. {
  279. try
  280. {
  281. DataGridViewRow currentRow = this.dgvWages.CurrentRow;
  282. if (currentRow != null)
  283. {
  284. //获取需审核的信息ID
  285. int entityId = Convert.ToInt32(currentRow.Cells["colWagesID"].Value);
  286. //编辑窗体以审核模式开启
  287. F_TAT_0202 frmTAT0202 = new F_TAT_0202(Constant.FormMode.Display, entityId);
  288. DialogResult dialogResult = frmTAT0202.ShowDialog();
  289. //操作成功后刷新数据源与列表
  290. if (dialogResult == DialogResult.OK)
  291. {
  292. this.dgvWages.DataSource = null;
  293. this.BindSelectedData();
  294. ServiceResultEntity srEntity = (ServiceResultEntity)DoAsync(this.GetDate);
  295. if (srEntity.Data != null && srEntity.Data.Tables.Count != 0)
  296. {
  297. this.BindGridView(srEntity.Data.Tables[0]);
  298. }
  299. //服务实体共通处理
  300. ServiceResultEntityManager.HandleServiceResultEntity(srEntity, this.Text);
  301. }
  302. }
  303. }
  304. catch (Exception ex)
  305. {
  306. // 对异常进行共通处理
  307. ExceptionManager.HandleEventException(this.ToString(),
  308. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  309. }
  310. }
  311. /// <summary>
  312. /// 删除信息
  313. /// </summary>
  314. /// <param name="sender"></param>
  315. /// <param name="e"></param>
  316. private void tsbtnDisable_Click(object sender, EventArgs e)
  317. {
  318. try
  319. {
  320. DataGridViewRow currentRow = this.dgvWages.CurrentRow;
  321. if (currentRow != null)
  322. {
  323. WagesEntity wagesEntity = new WagesEntity();
  324. //获取ID以及时间戳
  325. wagesEntity.WagesID = Convert.ToInt32(currentRow.Cells["colWagesID"].Value);
  326. wagesEntity.OPTimeStamp = Convert.ToDateTime(currentRow.Cells["colOPTimeStamp"].Value);
  327. ServiceResultEntity srEntity = (ServiceResultEntity)DoAsync(() =>
  328. {
  329. return TATModuleProxy.Service.StopWages(wagesEntity);
  330. });
  331. //服务实体共通处理
  332. ServiceResultEntityManager.HandleServiceResultEntity(srEntity, this.Text);
  333. //成功后刷新数据源
  334. if (srEntity.Status == Constant.ServiceResultStatus.Success)
  335. {
  336. this.dgvWages.DataSource = null;
  337. this.BindSelectedData();
  338. srEntity = (ServiceResultEntity)DoAsync(this.GetDate);
  339. if (srEntity.Data != null && srEntity.Data.Tables.Count != 0)
  340. {
  341. this.BindGridView(srEntity.Data.Tables[0]);
  342. }
  343. //服务实体共通处理
  344. ServiceResultEntityManager.HandleServiceResultEntity(srEntity, this.Text);
  345. }
  346. }
  347. }
  348. catch (Exception ex)
  349. {
  350. // 对异常进行共通处理
  351. ExceptionManager.HandleEventException(this.ToString(),
  352. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  353. }
  354. }
  355. /// <summary>
  356. /// 自适应列宽
  357. /// </summary>
  358. /// <param name="sender"></param>
  359. /// <param name="e"></param>
  360. private void tsbtnAdaptive_Click(object sender, EventArgs e)
  361. {
  362. this.dgvWages.AutoResizeColumns(DataGridViewAutoSizeColumnsMode.AllCells);
  363. }
  364. /// <summary>
  365. /// 窗体关闭
  366. /// </summary>
  367. /// <param name="sender"></param>
  368. /// <param name="e"></param>
  369. private void tsbtnClose_Click(object sender, EventArgs e)
  370. {
  371. this.Close();
  372. }
  373. /// <summary>
  374. /// 开始时间启用/关闭
  375. /// </summary>
  376. /// <param name="sender"></param>
  377. /// <param name="e"></param>
  378. private void cbStartTime_CheckedChanged(object sender, EventArgs e)
  379. {
  380. this.dtpStartTimeBetween.Enabled = this.cbStartTime.Checked;
  381. this.dtpStartTimeAfter.Enabled = this.cbStartTime.Checked;
  382. }
  383. /// <summary>
  384. /// 结束时间启用/关闭
  385. /// </summary>
  386. /// <param name="sender"></param>
  387. /// <param name="e"></param>
  388. private void cbEndTime_CheckedChanged(object sender, EventArgs e)
  389. {
  390. this.dtpEndTimeBetween.Enabled = this.cbEndTime.Checked;
  391. this.dtpEndTimeAfter.Enabled = this.cbEndTime.Checked;
  392. }
  393. /// <summary>
  394. /// 窗体关闭后
  395. /// </summary>
  396. /// <param name="sender"></param>
  397. /// <param name="e"></param>
  398. private void F_TAT_0201_FormClosed(object sender, FormClosedEventArgs e)
  399. {
  400. _instance = null;
  401. }
  402. #endregion
  403. #region 私有方法/函数
  404. /// <summary>
  405. /// 绑定检索条件数据
  406. /// </summary>
  407. private void BindSelectData()
  408. {
  409. try
  410. {
  411. //绑定审核状态
  412. DataSet dsStatus = SystemModuleProxy.Service.GetAuditStatus();
  413. this.lbxAuditStatus.DataSource = dsStatus.Tables[0];
  414. this.lbxAuditStatus.ValueMember = "AuditStatusID";
  415. this.lbxAuditStatus.DisplayMember = "AuditStatusName";
  416. this.lbxAuditStatus.Text = "";
  417. //绑定策略类型
  418. DataTable dtSalaryType = new DataTable();
  419. dtSalaryType.Columns.Add("SalaryTypeValue");
  420. dtSalaryType.Columns.Add("SalaryTypeName");
  421. Type SalaryTypeEnum = typeof(Constant.SalaryType);
  422. Array SalaryTypeArray = Enum.GetValues(SalaryTypeEnum);
  423. for (int i = 0; i < Constant.SalaryTypeName.Length; i++)
  424. {
  425. dtSalaryType.Rows.Add(Convert.ToInt32(SalaryTypeArray.GetValue(i)), Constant.SalaryTypeName[i]);
  426. }
  427. this.lbxSalaryType.DisplayMember = "SalaryTypeName";
  428. this.lbxSalaryType.ValueMember = "SalaryTypeValue";
  429. this.lbxSalaryType.DataSource = dtSalaryType;
  430. this.lbxSalaryType.Text = "";
  431. }
  432. catch (Exception ex)
  433. {
  434. throw ex;
  435. }
  436. }
  437. /// <summary>
  438. /// 获取页面的输入值
  439. /// </summary>
  440. private void BindSelectedData()
  441. {
  442. try
  443. {
  444. if (this.lbxSalaryType.SelectedValue != null)
  445. {
  446. this._salaryTypeValue = Convert.ToInt32(this.lbxSalaryType.SelectedValue);
  447. }
  448. else
  449. {
  450. this._salaryTypeValue = null;
  451. }
  452. if (this.lbxAuditStatus.SelectedValue != null)
  453. {
  454. this._auditStatusValue = Convert.ToInt32(this.lbxAuditStatus.SelectedValue);
  455. }
  456. else
  457. {
  458. this._auditStatusValue = null;
  459. }
  460. //为查询用实体赋值
  461. this._wagesEntity = new WagesEntity();
  462. if (!string.IsNullOrWhiteSpace(this.txtWagesName.Text))
  463. {
  464. this._wagesEntity.WagesName = this.txtWagesName.Text.Trim();
  465. }
  466. if (this._auditStatusValue != null)
  467. {
  468. this._wagesEntity.AuditStatus = this._auditStatusValue;
  469. }
  470. if (!string.IsNullOrWhiteSpace(this.txtRemarks.Text))
  471. {
  472. this._wagesEntity.Remarks = this.txtRemarks.Text;
  473. }
  474. if (this.cbStartTime.Checked)
  475. {
  476. this._wagesEntity.BeginAccountMonth = this.dtpStartTimeBetween.Value.Date;
  477. this._wagesEntity.BeginAccountMonthEnd = this.dtpStartTimeAfter.Value.Date
  478. .AddHours(23).AddMinutes(59).AddSeconds(59);
  479. }
  480. if (this.cbEndTime.Checked)
  481. {
  482. this._wagesEntity.EndAccountMonth = this.dtpEndTimeBetween.Value.Date;
  483. this._wagesEntity.EndAccountMonthEnd = this.dtpEndTimeAfter.Value.Date
  484. .AddHours(23).AddMinutes(59).AddSeconds(59);
  485. }
  486. if (this._salaryTypeValue != null)
  487. {
  488. this._wagesEntity.SalaryType = Convert.ToInt32(this._salaryTypeValue);
  489. }
  490. }
  491. catch (Exception ex)
  492. {
  493. throw ex;
  494. }
  495. }
  496. /// <summary>
  497. /// 绑定列表查询数据
  498. /// </summary>
  499. private ServiceResultEntity GetDate()
  500. {
  501. try
  502. {
  503. return TATModuleProxy.Service.GetWages(this._wagesEntity);
  504. }
  505. catch (Exception ex)
  506. {
  507. throw ex;
  508. }
  509. }
  510. /// <summary>
  511. /// 绑定页面数据源
  512. /// </summary>
  513. /// <param name="dtSourse">数据源TABLE</param>
  514. private void BindGridView(DataTable dtSourse)
  515. {
  516. this.dgvWages.DataSource = dtSourse;
  517. this.dgvWages.ReadOnly = true;
  518. }
  519. #endregion
  520. }
  521. }