/******************************************************************************* * Copyright(c) 2014 DongkeSoft All rights reserved. / Confidential * 类的信息: * 1.程序名称:F_HR_1103.cs * 2.功能描述:行政奖惩审批 * 编辑履历: * 作者 日期 版本 修改内容 * 张国印 2014/09/25 1.00 新建 *******************************************************************************/ using System; using System.Data; using System.Windows.Forms; using Dongke.IBOSS.PRD.Basics.BaseResources; using Dongke.IBOSS.PRD.Basics.DockPanel; 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.Proxys; using Dongke.IBOSS.PRD.WCF.Proxys.HRModuleService; namespace Dongke.IBOSS.PRD.Client.HRModule { /// /// 行政奖惩审批 /// public partial class F_HR_1103 : DockPanelBase { #region 成员变量 // 窗体的单例模式 private static F_HR_1103 _instance; //Grid当前选中的行 private int _selectedRowIndex; #endregion #region 构造函数 /// /// 构造函数 /// public F_HR_1103() { InitializeComponent(); this.SetFromTitleInfo(); } #endregion #region 单例模式 /// /// 单例模式,防止重复创建窗体 /// public static F_HR_1103 Instance { get { if (_instance == null) { _instance = new F_HR_1103(); } return _instance; } } #endregion #region 事件 /// /// 窗体加载事件 /// /// /// private void F_HR_1103_Load(object sender, EventArgs e) { try { #region 绑定数据源 this.dkStaffName.WhereCondition = "(StaffStatus = 1 Or StaffStatus = 2) AND ValueFlag = 1"; this.comRAPType.DataSource = GetRAPTypeInfo(); this.comRAPType.DisplayMember = "TypeName"; this.comRAPType.ValueMember = "TypeID"; this.comSettlementFlag.DataSource = GetSettlementFlagInfo(); this.comSettlementFlag.DisplayMember = "SettlementFlagName"; this.comSettlementFlag.ValueMember = "SettlementFlagID"; this.comAdministrationType.DataSource = DataDictionaryInfo(); this.comAdministrationType.DisplayMember = "DictionaryValue"; this.comAdministrationType.ValueMember = "DictionaryID"; #endregion FormPermissionManager.FormPermissionControl(this.Name, this, LogInUserInfo.CurrentUser.CurrentUserEntity.UserRightData, LogInUserInfo.CurrentUser.CurrentUserEntity.FunctionData); } catch (Exception ex) { // 对异常进行共通处理 ExceptionManager.HandleEventException(this.ToString(), System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex); } } /// /// 窗体关闭事件 /// /// /// private void F_HR_1103_FormClosed(object sender, FormClosedEventArgs e) { _instance = null; } /// /// 行获取焦点后查看明细 /// /// /// private void dgvStaff_CellEnter(object sender, DataGridViewCellEventArgs e) { try { if (this.dgvStaff.CurrentCell != null) { // 记录最后选择行 this._selectedRowIndex = this.dgvStaff.CurrentCell.RowIndex; } } catch (Exception ex) { // 对异常进行共通处理 ExceptionManager.HandleEventException(this.ToString(), System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex); } } /// /// 单元格鼠标双击事件 /// /// /// private void dgvStaff_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 tsbtnApprover_Click(object sender, EventArgs e) { try { if (this.dgvStaff.CurrentRow != null) { int intRAPID = Convert.ToInt32(this.dgvStaff.CurrentRow.Cells["RAPID"].Value); DateTime sopTimeStamp = Convert.ToDateTime(this.dgvStaff.CurrentRow.Cells["OPTIMESTAMP"].Value); HRAdminRAPEntity aminRapEntity = new HRAdminRAPEntity(); aminRapEntity.RAPID = intRAPID; aminRapEntity.OPTimeStamp = sopTimeStamp; S_CMN_012 frmCMN012 = new S_CMN_012(); if (frmCMN012.ShowDialog() == DialogResult.OK) { bool bolState = frmCMN012.HRApprovalState; HRResultEntity resultStaff = (HRResultEntity)DoAsync(new AsyncMethod(() => { return HRModuleProxy.Service.SaveStaffAdminRAPApprovalInfo(aminRapEntity, bolState); })); //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_W003, "行政奖惩"), 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 { // 提示信息 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); } } /// /// 自动适应列宽 /// /// /// private void tsbtnAdaptive_Click(object sender, EventArgs e) { this.dgvStaff.AutoResizeColumns(DataGridViewAutoSizeColumnsMode.AllCells); } /// /// 关闭按钮事件 /// /// /// private void tsbtnClose_Click(object sender, EventArgs e) { this.Close(); } /// /// 查询按钮 /// /// /// private void btnSearch_Click(object sender, EventArgs e) { try { // 记录当前选中行 int selectRowIndex = this._selectedRowIndex; SearchAdminRAPEntity searchAdminRAPEntity = SetSearchAdminRAPEntity(); DataSet dsResultStaff = (DataSet)DoAsync(new AsyncMethod(() => { return HRModuleProxy.Service.SearcStaffAdminRAPInfo(searchAdminRAPEntity); })); if (dsResultStaff != null) { base.DataSource = dsResultStaff; if (this.DataSource != null && this.DataSource.Tables.Count > Constant.INT_IS_ZERO) { this.dgvStaff.DataSource = this.DataSource.Tables[0]; if (this.DataSource.Tables[0].Rows.Count <= Constant.INT_IS_ZERO) { // 提示未查找到数据 MessageBox.Show(Messages.MSG_CMN_I002, this.Text, MessageBoxButtons.OK, MessageBoxIcon.Information); } else { #region 选择原有行 if (selectRowIndex >= Constant.INT_IS_ZERO) { if (selectRowIndex >= dsResultStaff.Tables[0].Rows.Count) { this.dgvStaff.Rows[this.dgvStaff.Rows.Count - 1].Selected = true; this.dgvStaff.CurrentCell = this.dgvStaff.Rows[this.dgvStaff.Rows.Count - 1].Cells["StaffName"]; } else { this.dgvStaff.Rows[selectRowIndex].Selected = true; this.dgvStaff.CurrentCell = this.dgvStaff.Rows[selectRowIndex].Cells["StaffName"]; } } #endregion } } } } catch (Exception ex) { // 对异常进行共通处理 ExceptionManager.HandleEventException(this.ToString(), System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex); } } /// /// 清空条件 /// /// /// private void btnClearCondition_Click(object sender, EventArgs e) { this.dkStaffName.UserID = null; this.dkStaffName.UserName = string.Empty; this.dkStaffName.UserCode = string.Empty; this.dkStaffName.StaffEntity = null; this.comRAPType.SelectedIndex = 0; this.comSettlementFlag.SelectedIndex = 0; this.comAdministrationType.SelectedIndex = 0; } #endregion #region 私有方法 /// /// 设置窗体按钮的文本信息 /// private void SetFromTitleInfo() { this.Text = FormTitles.F_HR_1103; this.tsbtnApprover.Text = ButtonText.TSBTN_APPROVER; this.tsbtnAdaptive.Text = ButtonText.TSBTN_ADAPTIVE; this.tsbtnClose.Text = ButtonText.TSBTN_CLOSE; this.btnSearch.Text = ButtonText.BTN_SEARCH; this.btnClearCondition.Text = ButtonText.BTN_CLEARCONDITION; this.gbxCondition.Text = Constant.LABEL_QUERY_CONDITIONS; } /// /// 获取奖惩类型数据源 /// /// private DataTable GetRAPTypeInfo() { //1:奖励;-1:惩罚 DataTable dtRAPType = new DataTable(); dtRAPType.Columns.Add("TypeID"); dtRAPType.Columns.Add("TypeName"); DataRow newRowType = dtRAPType.NewRow(); newRowType["TypeID"] = Constant.CBO_SELECT_ALL_VALUE; newRowType["TypeName"] = Constant.CBO_SELECT_ALL_NAME; dtRAPType.Rows.Add(newRowType); newRowType = dtRAPType.NewRow(); newRowType["TypeID"] = "1"; newRowType["TypeName"] = "奖励"; dtRAPType.Rows.Add(newRowType); newRowType = dtRAPType.NewRow(); newRowType["TypeID"] = "-1"; newRowType["TypeName"] = "惩罚"; dtRAPType.Rows.Add(newRowType); return dtRAPType; } /// /// 工资结算标识数据源 /// /// private DataTable GetSettlementFlagInfo() { //1:已经结算 0:未结算 DataTable dtRAPType = new DataTable(); dtRAPType.Columns.Add("SettlementFlagID"); dtRAPType.Columns.Add("SettlementFlagName"); DataRow newRowType = dtRAPType.NewRow(); newRowType["SettlementFlagID"] = Constant.CBO_SELECT_ALL_VALUE; newRowType["SettlementFlagName"] = Constant.CBO_SELECT_ALL_NAME; dtRAPType.Rows.Add(newRowType); newRowType = dtRAPType.NewRow(); newRowType["SettlementFlagID"] = "0"; newRowType["SettlementFlagName"] = "未结算"; dtRAPType.Rows.Add(newRowType); newRowType = dtRAPType.NewRow(); newRowType["SettlementFlagID"] = "1"; newRowType["SettlementFlagName"] = "已经结算"; dtRAPType.Rows.Add(newRowType); return dtRAPType; } /// /// 获取行政考核类别数据源 /// /// public DataTable DataDictionaryInfo() { DataTable dtDicInfo = (DataTable)DoAsync(new AsyncMethod(() => { return CommonModuleProxy.Service.GetDataDictionaryByType(Constant.ASE_ASE001); })); DataRow newRowDic = dtDicInfo.NewRow(); newRowDic["DictionaryID"] = Constant.CBO_SELECT_ALL_VALUE; newRowDic["DictionaryValue"] = Constant.CBO_SELECT_ALL_NAME; dtDicInfo.Rows.InsertAt(newRowDic, 0); return dtDicInfo; } /// /// 根据查询条件 形成查询实体 /// /// public SearchAdminRAPEntity SetSearchAdminRAPEntity() { SearchAdminRAPEntity searchAdminRAPEntity = new SearchAdminRAPEntity(); searchAdminRAPEntity.ValueFlag = Constant.ValueFlag.Effective.GetHashCode().ToString(); searchAdminRAPEntity.AuditStatus = Constant.ApprovalStatus.Pending.GetHashCode(); if (this.dkStaffName.UserID != null) { searchAdminRAPEntity.StaffID = this.dkStaffName.UserID; } if (this.comRAPType.SelectedValue != null && !Constant.CBO_SELECT_ALL_VALUE.Equals(this.comRAPType.SelectedValue.ToString())) { searchAdminRAPEntity.RAPType = Convert.ToDouble(this.comRAPType.SelectedValue); } if (this.comSettlementFlag.SelectedValue != null && !Constant.CBO_SELECT_ALL_VALUE.Equals(this.comSettlementFlag.SelectedValue.ToString())) { searchAdminRAPEntity.SettlementFlag = this.comSettlementFlag.SelectedValue.ToString(); } if (this.comAdministrationType.SelectedValue != null && !Constant.CBO_SELECT_ALL_VALUE.Equals(this.comAdministrationType.SelectedValue.ToString())) { searchAdminRAPEntity.AdministrationType = Convert.ToInt32(this.comAdministrationType.SelectedValue); } return searchAdminRAPEntity; } #endregion } }