/******************************************************************************* * Copyright(c) 2014 dongke All rights reserved. / Confidential * 类的信息: * 1.程序名称:F_HR_0603.cs * 2.功能描述:职务调整审核 * 编辑履历: * 作者 日期 版本 修改内容 * 冯雪 2014/09/16 1.00 新建 *******************************************************************************/ using System; using System.Data; using System.Windows.Forms; using Dongke.IBOSS.PRD.Basics.BaseControls; using Dongke.IBOSS.PRD.Basics.BaseResources; using Dongke.IBOSS.PRD.Basics.DockPanel; using Dongke.IBOSS.PRD.Basics.Library; using Dongke.IBOSS.PRD.Client.CommonModule; using Dongke.IBOSS.PRD.Client.Controls; using Dongke.IBOSS.PRD.Client.DataModels; using Dongke.IBOSS.PRD.WCF.DataModels; using Dongke.IBOSS.PRD.WCF.DataModels.HRModule; using Dongke.IBOSS.PRD.WCF.Proxys; using Dongke.IBOSS.PRD.WCF.Proxys.HRModuleService; namespace Dongke.IBOSS.PRD.Client.HRModule { /// /// 职务调整审核 /// public partial class F_HR_0603 : DockPanelBase { #region 成员变量 // 窗体的单例模式 private static F_HR_0603 _instance; //选中的行 private int _selectedRowIndex; // 查询条件实体 private HR_CMN_StaffEntity _staffEntity = new HR_CMN_StaffEntity(); #endregion #region 构造函数 /// /// 构造函数 /// public F_HR_0603() { InitializeComponent(); FormPermissionManager.FormPermissionControl(this.Name, this, LogInUserInfo.CurrentUser.CurrentUserEntity.UserRightData, LogInUserInfo.CurrentUser.CurrentUserEntity.FunctionData); this.SetFromTitleInfo(); } #endregion #region 单例模式 /// /// 单例模式,防止重复创建窗体 /// public static F_HR_0603 Instance { get { if (_instance == null) { _instance = new F_HR_0603(); } return _instance; } } #endregion #region 事件 /// /// 页面加载事件 /// /// /// private void F_HR_0603_Load(object sender, EventArgs e) { try { // 加载权限 FormPermissionManager.FormPermissionControl(this.Name, this, LogInUserInfo.CurrentUser.CurrentUserEntity.UserRightData, LogInUserInfo.CurrentUser.CurrentUserEntity.FunctionData); // 设置表格不自动创建列 this.dgvStaffRecord.AutoGenerateColumns = false; } catch (Exception ex) { // 对异常进行共通处理 ExceptionManager.HandleEventException(this.ToString(), System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex); } } /// /// 窗体关闭事件 /// /// /// private void F_HR_0603_FormClosed(object sender, FormClosedEventArgs e) { _instance = null; } /// /// 行获取焦点后查看明细 /// /// /// private void dgvStaffRecord_CellEnter(object sender, DataGridViewCellEventArgs e) { try { if (this.dgvStaffRecord.CurrentCell != null) { // 记录最后选择行 this._selectedRowIndex = this.dgvStaffRecord.CurrentCell.RowIndex; } } catch (Exception ex) { // 对异常进行共通处理 ExceptionManager.HandleEventException(this.ToString(), System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex); } } /// /// 单元格鼠标双击事件 /// /// /// private void dgvStaffRecord_CellMouseDoubleClick(object sender, DataGridViewCellMouseEventArgs e) { if (Constant.INT_IS_NEGATIE_ONE < e.RowIndex && Constant.INT_IS_NEGATIE_ONE < e.ColumnIndex && this.tsbtnApprover.Enabled && this.tsbtnApprover.Visible) { this.tsbtnApprover_Click(sender, e); } } /// /// 更多条件按钮 /// /// /// private void tsbtnMoreCondition_Click(object sender, EventArgs e) { HR_CMN_001 frmCMN001 = new HR_CMN_001(); frmCMN001.StaffEntity = _staffEntity; if (frmCMN001.ShowDialog() == DialogResult.OK) { this.txtOther.Text = frmCMN001.StaffEntity.GetSqlDispText(); this._staffEntity = frmCMN001.StaffEntity; } } /// /// 清空条件 /// /// /// private void btnClearCondition_Click(object sender, EventArgs e) { this.txtStaffCode.Clear(); this.txtStaffName.Clear(); this.txtOther.Clear(); this._staffEntity.ClearEntityValue(); } /// /// 关闭按钮事件 /// /// /// private void tsbtnClose_Click(object sender, EventArgs e) { this.Close(); } /// /// 自动适应列宽 /// /// /// private void tsbtnAdaptive_Click(object sender, EventArgs e) { this.dgvStaffRecord.AutoResizeColumns(DataGridViewAutoSizeColumnsMode.AllCells); } /// /// 查询按钮 /// /// /// private void btnSearch_Click(object sender, EventArgs e) { try { this.GetDataGridViewInfo(); if (((DataTable)this.dgvStaffRecord.DataSource).Rows.Count <= Constant.INT_IS_ZERO) { // 提示未查找到数据 MessageBox.Show(Messages.MSG_CMN_I002, this.Text, MessageBoxButtons.OK, MessageBoxIcon.Information); } } catch (Exception ex) { // 对异常进行共通处理 ExceptionManager.HandleEventException(this.ToString(), System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex); } } /// /// 审批按钮 /// /// /// private void tsbtnApprover_Click(object sender, EventArgs e) { try { if (this.dgvStaffRecord.CurrentRow != null) { int intStaffID = Convert.ToInt32(this.dgvStaffRecord.CurrentRow.Cells["StaffID"].Value); DateTime sopTimeStamp = Convert.ToDateTime(this.dgvStaffRecord.CurrentRow.Cells["SOPTIMESTAMP"].Value); int intStaffRecordID = Convert.ToInt32(this.dgvStaffRecord.CurrentRow.Cells["StaffRecordID"].Value); DateTime ropTimeStamp = Convert.ToDateTime(this.dgvStaffRecord.CurrentRow.Cells["ROPTIMESTAMP"].Value); StaffRecordEntity staffRecordEntity = new StaffRecordEntity(); staffRecordEntity.StaffRecordID = intStaffRecordID; staffRecordEntity.OPTimeStamp = ropTimeStamp; staffRecordEntity.StaffID = intStaffID; staffRecordEntity.TargetPost = Convert.ToInt32(this.dgvStaffRecord.CurrentRow.Cells["TargetPost"].Value); S_CMN_011 frmCMN011 = new S_CMN_011(); if (frmCMN011.ShowDialog() == System.Windows.Forms.DialogResult.OK) { bool bolState = frmCMN011.HRApprovalState; string strMemo = frmCMN011.ApprovalMemo; HRResultEntity resultStaff = (HRResultEntity)DoAsync(new AsyncMethod(() => { return HRModuleProxy.Service.SaveHRStaffPostApprovalInfo(intStaffID, sopTimeStamp, staffRecordEntity, bolState, strMemo); })); //0 没有数据被修改 -1员工档案被其他用户修改 -2存在待审批履历 -3员工履历被其他用户修改 if (resultStaff.OperateStatus > Constant.INT_IS_ZERO) { // 提示信息 MessageBox.Show(string.Format(Messages.MSG_CMN_I001, "职务调整", "审核"), this.Text, MessageBoxButtons.OK, MessageBoxIcon.Information); this.btnSearch_Click(sender, e); } else if (resultStaff.OperateStatus == Constant.INT_IS_NEGATIE_ONE) { // 提示信息 MessageBox.Show(string.Format(Messages.MSG_HR_W006, "职务调整", "审核"), this.Text, MessageBoxButtons.OK, MessageBoxIcon.Warning); } else if (resultStaff.OperateStatus == Constant.INT_IS_NEGATIE_TWO) { // 提示信息 MessageBox.Show(Messages.MSG_CMN_W012, this.Text, MessageBoxButtons.OK, MessageBoxIcon.Warning); } else if (resultStaff.OperateStatus == Constant.INT_IS_NEGATIE_THREE) { // 提示信息 MessageBox.Show(Messages.MSG_CMN_W012, this.Text, MessageBoxButtons.OK, MessageBoxIcon.Warning); } else { // 提示信息 MessageBox.Show(string.Format(Messages.MSG_CMN_W001, "职务调整", "审核"), this.Text, MessageBoxButtons.OK, MessageBoxIcon.Warning); } } } } catch (Exception ex) { // 对异常进行共通处理 ExceptionManager.HandleEventException(this.ToString(), System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex); } } #endregion #region 私有方法 /// /// 设置窗体按钮的文本信息 /// private void SetFromTitleInfo() { this.tsrOperate.BackgroundImage = global::Dongke.IBOSS.PRD.Client.HRModule.Properties.Resources.functionbackground; this.tsrOperate.Height = 35; this.toolStripSeparator1.Height = 25; this.toolStripSeparator1.Width = 6; this.tsbtnApprover.Height = 25; this.tsbtnMoreCondition.Height = 25; this.tsbtnAdaptive.Height = 25; this.tsbtnClose.Height = 25; this.btnSearch.Height = 30; this.btnSearch.Width = 85; this.btnClearCondition.Height = 30; this.btnClearCondition.Width = 85; this.dgvStaffRecord.ColumnHeadersHeight = 23; this.dgvStaffRecord.SelectionMode = DataGridViewSelectionMode.FullRowSelect; this.dgvStaffRecord.AutoGenerateColumns = false; this.dgvStaffRecord.AutoGenerateColumns = false; this.Text = FormTitles.F_HR_0603; this.tsbtnApprover.Text = ButtonText.TSBTN_APPROVER; this.tsbtnAdaptive.Text = ButtonText.TSBTN_ADAPTIVE; this.tsbtnClose.Text = ButtonText.TSBTN_CLOSE; this.tsbtnMoreCondition.Text = ButtonText.TSBTN_MORECONDITION; this.btnSearch.Text = ButtonText.BTN_SEARCH; this.btnClearCondition.Text = ButtonText.BTN_CLEARCONDITION; this.gbxCondition.Text = Constant.LABEL_QUERY_CONDITIONS; } /// /// 获取职务调整信息 /// private void GetDataGridViewInfo() { try { SearchStaffEntity searchStaffEntity = new SearchStaffEntity(); DataConvert.Convert(this._staffEntity, searchStaffEntity); searchStaffEntity.StaffCode = this.txtStaffCode.Text.Trim(); searchStaffEntity.StaffName = this.txtStaffName.Text.Trim(); searchStaffEntity.Recordtype = Convert.ToInt32(Constant.StaffRecordType.AdjustPost); searchStaffEntity.RValueflag = Convert.ToInt32(Constant.ValueFlag.Effective); //查询 DataSet dsResult = (DataSet)DoAsync(new Dongke.IBOSS.PRD.Basics.DockPanel.AsyncMethod(() => { return WCF.Proxys.HRModuleProxy.Service.SearchHrStaffApprove(searchStaffEntity); })); if (dsResult != null && dsResult.Tables.Count > Constant.INT_IS_ZERO) { // 记录最后选择行 int selectRowIndex = this._selectedRowIndex; this.dgvStaffRecord.DataSource = dsResult.Tables[0]; if (dsResult.Tables[0].Rows.Count > Constant.INT_IS_ZERO) { // 定位当前行 if (this.dgvStaffRecord.Rows.Count > selectRowIndex) { this._selectedRowIndex = selectRowIndex; this.dgvStaffRecord.Rows[selectRowIndex].Selected = true; } else if (this.dgvStaffRecord.Rows.Count <= selectRowIndex) { this._selectedRowIndex = dgvStaffRecord.Rows.Count - 1; this.dgvStaffRecord.Rows[dgvStaffRecord.Rows.Count - 1].Selected = true; } } } else { // 清空明细中的数据 this.dgvStaffRecord.DataSource = null; // 提示未查找到数据 MessageBox.Show(Messages.MSG_CMN_I002, this.Text, MessageBoxButtons.OK, MessageBoxIcon.Warning); } } catch (Exception ex) { throw ex; } } #endregion } }