F_PC_0402.cs 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544
  1. /*******************************************************************************
  2. * Copyright(c) 2014 dongke All rights reserved. / Confidential
  3. * 类的信息:
  4. * 1.程序名称:F_PC_0402.cs
  5. * 2.功能描述:班次配置新建\编辑
  6. * 编辑履历:
  7. * 作者 日期 版本 修改内容
  8. * 冯雪 2014/09/22 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.ConfigModule;
  18. using Dongke.IBOSS.PRD.WCF.DataModels.PCModule;
  19. using Dongke.IBOSS.PRD.WCF.Proxys;
  20. using Dongke.IBOSS.PRD.WCF.Proxys.PCModuleService;
  21. namespace Dongke.IBOSS.PRD.Client.PCModule
  22. {
  23. /// <summary>
  24. /// 班次配置新建\编辑窗体
  25. /// </summary>
  26. public partial class F_PC_0402 : FormBase
  27. {
  28. #region 成员变量
  29. // 班次配置ID
  30. private int _classesSettingID;
  31. // 窗体状态的枚举 新建/编辑
  32. private Constant.FormMode _editStatus;
  33. // 选中的员工编码
  34. private string _staffCode;
  35. // 工号ID
  36. private int _userId;
  37. // 工号名称
  38. private string _userName;
  39. // 工号编号
  40. private string _userCode;
  41. // 备注
  42. private string _remark;
  43. //保存影响行
  44. private int _returnRow = Constant.INT_IS_ZERO;
  45. // 打开选择窗体的标识
  46. private bool _showFromFlag = true;
  47. // 当前工号的工种集合
  48. private DataTable _userJobsTable = new DataTable();
  49. #endregion
  50. #region 属性
  51. /// <summary>
  52. /// 备注
  53. /// </summary>
  54. public string Remark
  55. {
  56. get { return _remark; }
  57. set { _remark = value; }
  58. }
  59. /// <summary>
  60. /// 工号名称
  61. /// </summary>
  62. public string UserName1
  63. {
  64. get { return _userName; }
  65. set { _userName = value; }
  66. }
  67. /// <summary>
  68. /// 班次配置ID
  69. /// </summary>
  70. public int ClassesSettingID
  71. {
  72. get { return _classesSettingID; }
  73. set { _classesSettingID = value; }
  74. }
  75. /// <summary>
  76. /// 工号ID
  77. /// </summary>
  78. public int UserId
  79. {
  80. get { return _userId; }
  81. set { _userId = value; }
  82. }
  83. /// <summary>
  84. /// 工号编号
  85. /// </summary>
  86. public string UserCode
  87. {
  88. get { return _userCode; }
  89. set { _userCode = value; }
  90. }
  91. #endregion
  92. #region 构造函数
  93. /// <summary>
  94. /// 构造函数
  95. /// </summary>
  96. /// <param name="editStatus">新建/编辑</param>
  97. /// <param name="pUserId">要编辑的员工编号</param>
  98. public F_PC_0402(Constant.FormMode editStatus)
  99. {
  100. InitializeComponent();
  101. this._editStatus = editStatus;
  102. this.tsbtnAdaptive.Text = ButtonText.TSBTN_ADAPTIVE;
  103. this.tsbtnClose.Text = ButtonText.TSBTN_CLOSE;
  104. this.btnSave.Text = ButtonText.BTN_SAVE;
  105. this.btnCancel.Text = ButtonText.BTN_CANCEL;
  106. if (this._editStatus == Constant.FormMode.Add)
  107. {
  108. this.Text = FormTitles.F_PC_0402_ADD;
  109. }
  110. else
  111. {
  112. this.Text = FormTitles.F_PC_0402_EDIT;
  113. // wangx 2016-06-20
  114. this.dkUserInfo.Enabled = false;
  115. this.dtpAccountDate.Enabled = false;
  116. this.txtRemarks.Enabled = false;
  117. // wangx 2016-06-20 end
  118. }
  119. }
  120. #endregion
  121. #region 事件
  122. /// <summary>
  123. /// 页面加载事件
  124. /// </summary>
  125. /// <param name="sender"></param>
  126. /// <param name="e"></param>
  127. private void F_PC_0402_Load(object sender, EventArgs e)
  128. {
  129. try
  130. {
  131. if (this._editStatus == Constant.FormMode.Edit)
  132. {
  133. this.dkUserInfo.UserID = this._userId;
  134. this.dkUserInfo.UserName = this._userName;
  135. this.dkUserInfo.UserCode = this._userCode;
  136. BindUserJobs();
  137. DataSet result = (DataSet)DoAsync(() =>
  138. {
  139. return PCModuleProxy.Service.SearchClassesDetail(this._classesSettingID);
  140. });
  141. this.dgvClassesDetail.AutoGenerateColumns = false;
  142. this.dgvClassesDetail.IsSetInputColumnsColor = true;
  143. // 绑定明细数据
  144. this.dgvClassesDetail.DataSource = result.Tables[0];
  145. // 允许编辑行
  146. this.dgvClassesDetail.AllowUserToAddRows = true;
  147. this.dgvClassesDetail.IsSetInputColumnsColor = true;
  148. }
  149. }
  150. catch (Exception ex)
  151. {
  152. // 对异常进行共通处理
  153. ExceptionManager.HandleEventException(this.ToString(),
  154. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  155. }
  156. }
  157. /// <summary>
  158. /// 自动适应列宽
  159. /// </summary>
  160. /// <param name="sender"></param>
  161. /// <param name="e"></param>
  162. private void tsbtnAdaptive_Click(object sender, EventArgs e)
  163. {
  164. this.dgvClassesDetail.AutoResizeColumns(DataGridViewAutoSizeColumnsMode.AllCells);
  165. }
  166. /// <summary>
  167. /// 关闭按钮事件
  168. /// </summary>
  169. /// <param name="sender"></param>
  170. /// <param name="e"></param>
  171. private void tsbtnClose_Click(object sender, EventArgs e)
  172. {
  173. this.Close();
  174. }
  175. /// <summary>
  176. /// 工号ValueChanged事件
  177. /// </summary>
  178. /// <param name="sender"></param>
  179. /// <param name="e"></param>
  180. private void dkUserInfo_UserValueChanged(object sender, Controls.SearchTextBox.dkUserInfoSearchBox.TextChangeEventArgs e)
  181. {
  182. try
  183. {
  184. int userId = this.dkUserInfo.UserID.Value;
  185. BindUserJobs();
  186. DataSet result = (DataSet)DoAsync(() =>
  187. {
  188. return HRModuleProxy.Service.SearchHrStaffInfo(userId);
  189. });
  190. this.dgvClassesDetail.AutoGenerateColumns = false;
  191. // 绑定明细数据
  192. this.dgvClassesDetail.DataSource = result.Tables[0];
  193. // 允许编辑行
  194. this.dgvClassesDetail.AllowUserToAddRows = true;
  195. }
  196. catch (Exception ex)
  197. {
  198. // 对异常进行共通处理
  199. ExceptionManager.HandleEventException(this.ToString(),
  200. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  201. }
  202. }
  203. /// <summary>
  204. /// 员工编号值改变事件
  205. /// </summary>
  206. /// <param name="sender"></param>
  207. /// <param name="e"></param>
  208. private void dgvClassesDetail_CellValueChanged(object sender, DataGridViewCellEventArgs e)
  209. {
  210. try
  211. {
  212. if (this.dgvClassesDetail.Rows.Count <= Constant.INT_IS_ONE || !_showFromFlag)
  213. {
  214. return;
  215. }
  216. DataGridViewRow rowItem = this.dgvClassesDetail.Rows[e.RowIndex];
  217. DataGridViewColumn columnItem = this.dgvClassesDetail.Columns[e.ColumnIndex];
  218. // 用编号获取员工信息
  219. if ("StaffCode".Equals(columnItem.Name)
  220. && !string.IsNullOrEmpty(this.dgvClassesDetail.Rows[e.RowIndex].Cells[columnItem.Name].Value + ""))
  221. {
  222. this._showFromFlag = false;
  223. FormUtility.BindStaffRowDataSource(this.dgvClassesDetail,
  224. e.RowIndex, columnItem.Name, this._staffCode, this.dkUserInfo.UserID.Value, true);
  225. this._showFromFlag = true;
  226. // 设置可输入单元格的颜色
  227. this.dgvClassesDetail.IsSetInputColumnsColor = true;
  228. // 不可出现重复的人员
  229. //for (int i = 0; i < this.dgvClassesDetail.Rows.Count; i++)
  230. //{
  231. // if (i != e.RowIndex)
  232. // {
  233. // if (this.dgvClassesDetail.Rows[i].IsNewRow == true)
  234. // {
  235. // return;
  236. // }
  237. // String NowStaffID = this.dgvClassesDetail.Rows[e.RowIndex].Cells["StaffID"].Value.ToString();
  238. // if (NowStaffID == string.Empty)
  239. // {
  240. // this.dgvClassesDetail.Rows.RemoveAt(e.RowIndex);
  241. // return;
  242. // }
  243. // String ForStaffID = "";
  244. // if (this.dgvClassesDetail.Rows[i].Cells["StaffID"].Value != null)
  245. // {
  246. // ForStaffID = this.dgvClassesDetail.Rows[i].Cells["StaffID"].Value.ToString();
  247. // }
  248. // if (NowStaffID == ForStaffID)
  249. // {
  250. // ((DataTable)this.dgvClassesDetail.DataSource).Rows[e.RowIndex].Delete();
  251. // //仅限当前页面,工号间的待修改
  252. // MessageBox.Show("员工信息不可重复配置!", this.Text,
  253. // MessageBoxButtons.OK, MessageBoxIcon.Warning);
  254. // return;
  255. // }
  256. // }
  257. //}
  258. }
  259. if (columnItem.Name == "UJobsId")
  260. {
  261. string JobsId = this.dgvClassesDetail.Rows[e.RowIndex].Cells[e.ColumnIndex].Value.ToString();
  262. if (JobsId == string.Empty)
  263. {
  264. if (((DataTable)this.dgvClassesDetail.DataSource).Rows[e.RowIndex]["UJobsId", DataRowVersion.Original] != null)
  265. {
  266. string OValue = ((DataTable)this.dgvClassesDetail.DataSource).Rows[e.RowIndex]["UJobsId", DataRowVersion.Original].ToString();
  267. ((DataTable)this.dgvClassesDetail.DataSource).Rows[e.RowIndex]["UJobsId"] = OValue;
  268. }
  269. else
  270. {
  271. ((DataTable)this.dgvClassesDetail.DataSource).Rows[e.RowIndex].Delete();
  272. }
  273. }
  274. }
  275. }
  276. catch (Exception ex)
  277. {
  278. this._showFromFlag = 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 dgvClassesDetail_CellBeginEdit(object sender, DataGridViewCellCancelEventArgs e)
  290. {
  291. try
  292. {
  293. if (this.dgvClassesDetail.Rows.Count <= Constant.INT_IS_ONE)
  294. {
  295. return;
  296. }
  297. DataGridViewColumn columnItem = this.dgvClassesDetail.Columns[e.ColumnIndex];
  298. if ("StaffCode".Equals(columnItem.Name))
  299. {
  300. this._staffCode = this.dgvClassesDetail.Rows[e.RowIndex].Cells[columnItem.Name].Value + "";
  301. }
  302. }
  303. catch (Exception ex)
  304. {
  305. // 对异常进行共通处理
  306. ExceptionManager.HandleEventException(this.ToString(),
  307. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  308. }
  309. }
  310. /// <summary>
  311. /// 保存按钮事件
  312. /// </summary>
  313. /// <param name="sender"></param>
  314. /// <param name="e"></param>
  315. private void btnSave_Click(object sender, EventArgs e)
  316. {
  317. try
  318. {
  319. // 至少有一条明细信息
  320. if (isWhiteTable() == true)
  321. {
  322. MessageBox.Show("至少要有一条班次配置明细信息!",
  323. this.Text, MessageBoxButtons.OK, MessageBoxIcon.Information, MessageBoxDefaultButton.Button1);
  324. return;
  325. }
  326. // 验证界面必录项的录入;
  327. if (!this.CheckInputValidity())
  328. {
  329. return;
  330. }
  331. // 不可更改帐务日期之前的班次配置
  332. DateTime accountDate = CommonModuleProxy.Service.GetAccountDate();
  333. if (Convert.ToDateTime(this.dtpAccountDate.Text) < accountDate)
  334. {
  335. SearchClassesSettingEntity scsEntity = new SearchClassesSettingEntity();
  336. scsEntity.UserCode = this.dkUserInfo.UserCode;
  337. scsEntity.UserID = this.dkUserInfo.UserID;
  338. scsEntity.StartAccountDate = Convert.ToDateTime(Convert.ToDateTime(this.dtpAccountDate.Text).ToString("yyyy-MM-dd"));
  339. scsEntity.EndAccountDate = Convert.ToDateTime(scsEntity.StartAccountDate).AddHours(23)
  340. .AddMinutes(59).AddSeconds(59);
  341. //查询
  342. DataSet dsResult = (DataSet)DoAsync(new BaseAsyncMethod(() =>
  343. {
  344. return WCF.Proxys.PCModuleProxy.Service.SearchClassesSetting(scsEntity);
  345. }));
  346. if (dsResult.Tables[0].Rows.Count > Constant.INT_IS_ZERO)
  347. {
  348. MessageBox.Show("选择日期已存在班次配置,不可再次补录!",
  349. this.Text, MessageBoxButtons.OK, MessageBoxIcon.Information, MessageBoxDefaultButton.Button1);
  350. return;
  351. }
  352. }
  353. // 保存
  354. ClassesSettingEntity setEntity = new ClassesSettingEntity();
  355. setEntity.UserID = this.dkUserInfo.UserID.Value;
  356. setEntity.UserCode = this.dkUserInfo.UserCode;
  357. setEntity.UserName = this.dkUserInfo.UserName;
  358. setEntity.AccountDate = Convert.ToDateTime(this.dtpAccountDate.Text);
  359. setEntity.ClassesSettingID = this._classesSettingID;
  360. DataTable dTable = (DataTable)this.dgvClassesDetail.DataSource;
  361. dTable.AcceptChanges();
  362. // 修改table中的工号为当前配置的工号
  363. foreach (DataRow row in dTable.Rows)
  364. {
  365. row["UserID"] = this.dkUserInfo.UserID.Value;
  366. row["UserCode"] = this.dkUserInfo.UserCode;
  367. if (row["UJobsId"].ToString() == string.Empty && row["StaffCode"].ToString() == string.Empty)
  368. {
  369. continue;
  370. }
  371. if (row["UJobsId"].ToString() == string.Empty)
  372. {
  373. MessageBox.Show("请为所有员工配置工种!",
  374. this.Text, MessageBoxButtons.OK, MessageBoxIcon.Information, MessageBoxDefaultButton.Button1);
  375. return;
  376. }
  377. if (row["StaffCode"].ToString() == "")
  378. {
  379. MessageBox.Show("请为已选择工种配置员工!",
  380. this.Text, MessageBoxButtons.OK, MessageBoxIcon.Information, MessageBoxDefaultButton.Button1);
  381. return;
  382. }
  383. }
  384. this._returnRow = (int)DoAsync(new BaseAsyncMethod(() =>
  385. {
  386. return PCModuleProxy.Service.SaveClassesSetting(setEntity, dTable);
  387. }));
  388. if (this._returnRow > Constant.INT_IS_ZERO)
  389. {
  390. // 保存成功提示信息
  391. MessageBox.Show(string.Format(Messages.MSG_CMN_I001, "班次配置", "保存"),
  392. this.Text, MessageBoxButtons.OK, MessageBoxIcon.Information);
  393. this.InitializationForm();
  394. }
  395. }
  396. catch (Exception ex)
  397. {
  398. // 对异常进行共通处理
  399. ExceptionManager.HandleEventException(this.ToString(),
  400. System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
  401. }
  402. }
  403. /// <summary>
  404. /// 取消按钮
  405. /// </summary>
  406. /// <param name="sender"></param>
  407. /// <param name="e"></param>
  408. private void btnCancel_Click(object sender, EventArgs e)
  409. {
  410. if (this._returnRow > Constant.INT_IS_ZERO)
  411. {
  412. this.DialogResult = System.Windows.Forms.DialogResult.OK;
  413. }
  414. else
  415. {
  416. this.DialogResult = System.Windows.Forms.DialogResult.Cancel;
  417. }
  418. }
  419. #endregion
  420. #region 私有方法
  421. /// <summary>
  422. /// 验证输入格式是否正确
  423. /// </summary>
  424. /// <returns></returns>
  425. private bool CheckInputValidity()
  426. {
  427. // 验证员工信息是否录入;
  428. if (string.IsNullOrEmpty(this.dkUserInfo.Text.Trim()))
  429. {
  430. MessageBox.Show(string.Format(Messages.MSG_CMN_W005, "工号"),
  431. this.Text, MessageBoxButtons.OK, MessageBoxIcon.Warning, MessageBoxDefaultButton.Button1);
  432. this.dkUserInfo.Focus();
  433. return false;
  434. }
  435. if (this.dgvClassesDetail.RowCount <= Constant.INT_IS_ONE)
  436. {
  437. MessageBox.Show(string.Format(Messages.MSG_CMN_W005, "员工信息"),
  438. this.Text, MessageBoxButtons.OK, MessageBoxIcon.Warning, MessageBoxDefaultButton.Button1);
  439. this.dgvClassesDetail.Focus();
  440. return false;
  441. }
  442. return true;
  443. }
  444. /// <summary>
  445. /// 清空输入项
  446. /// </summary>
  447. private void InitializationForm()
  448. {
  449. if (this._editStatus == Constant.FormMode.Add)
  450. {
  451. this.dkUserInfo.Text = "";
  452. this.txtRemarks.Clear();
  453. this.dgvClassesDetail.DataSource = null;
  454. }
  455. else
  456. {
  457. this.DialogResult = System.Windows.Forms.DialogResult.OK;
  458. }
  459. }
  460. /// <summary>
  461. /// 绑定用户工种
  462. /// </summary>
  463. private void BindUserJobs()
  464. {
  465. try
  466. {
  467. //获取可选择的工种数据源
  468. DataSet userJobsData = (DataSet)DoAsync(new BaseAsyncMethod(GetUserRowData));
  469. this.UJobsId.DisplayMember = "UserJobsName";
  470. this.UJobsId.ValueMember = "UserJobsId";
  471. this.UJobsId.DataSource = userJobsData.Tables[0];
  472. this._userJobsTable = userJobsData.Tables[0];
  473. }
  474. catch (Exception ex)
  475. {
  476. throw ex;
  477. }
  478. }
  479. /// <summary>
  480. /// 根据工号ID获取该工号的工种关联
  481. /// </summary>
  482. /// <returns></returns>
  483. private DataSet GetUserRowData()
  484. {
  485. try
  486. {
  487. return SystemModuleProxy.Service.GetJobByUserId(Convert.ToInt32(this.dkUserInfo.UserID));
  488. }
  489. catch (Exception ex)
  490. {
  491. throw ex;
  492. }
  493. }
  494. /// <summary>
  495. /// 是否空表
  496. /// </summary>
  497. /// <returns></returns>
  498. private bool isWhiteTable()
  499. {
  500. foreach (DataGridViewRow gvrFor in this.dgvClassesDetail.Rows)
  501. {
  502. if ((gvrFor.Cells["UJobsId"].Value != null && gvrFor.Cells["UJobsId"].Value.ToString() != "")
  503. || (gvrFor.Cells["StaffCode"].Value != null && gvrFor.Cells["StaffCode"].Value.ToString() != ""))
  504. {
  505. return false;
  506. }
  507. }
  508. return true;
  509. }
  510. #endregion
  511. }
  512. }