/*******************************************************************************
* 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
}
}