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