| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762 |
- /*******************************************************************************
- * Copyright(c) 2014 DongkeSoft All rights reserved. / Confidential
- * 类的信息:
- * 1.程序名称:F_HR_1002.cs
- * 2.功能描述:员工考勤编辑
- * 编辑履历:
- * 作者 日期 版本 修改内容
- * 任海 2014/09/24 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.DataModels;
- using Dongke.IBOSS.PRD.WCF.Proxys;
- using Dongke.IBOSS.PRD.WCF.Proxys.HRModuleService;
- using Dongke.IBOSS.PRD.Client.Controls.FormCommon;
- using Dongke.IBOSS.PRD.Basics.BaseControls;
- using Dongke.IBOSS.PRD.Basics.Library;
- using Dongke.IBOSS.PRD.WCF.DataModels;
- using Dongke.IBOSS.PRD.WCF.DataModels.HRModule;
- namespace Dongke.IBOSS.PRD.Client.HRModule
- {
- /// <summary>
- /// 员工考勤编辑
- /// </summary>
- public partial class F_HR_1002 : FormBase
- {
- #region 成员变量
- // 单例模式
- private static F_HR_1002 _instance;
- //// 最后选择行
- //private int _selecedRow;
- //// 员工ID
- //private int _staffID;
- // Grid当前选中的行
- private int _selectedRowIndex;
- // 用户编辑的ID集合
- int[] _staffIDList;
- // 查询条件实体
- private HR_CMN_StaffEntity _staffEntity = new HR_CMN_StaffEntity();
- // 格式刷是否开启
- private bool _isBrushIsOpen = false;
- // 记录考勤卡号
- private string _cardNumber;
- // 记录出勤状态
- private string _attendanceStatus;
- // 记录缺勤原因
- private string _absenceReason;
- // 记录迟到次数
- private string _tardinessTimes;
- // 记录备注
- private string _remarks;
- // 列索引
- private int _columnIndex = -1;
- #endregion
- #region 构造函数
- public F_HR_1002()
- {
- InitializeComponent();
- this.Text = FormTitles.F_HR_1002;
- this.tsbtnImport.Text = ButtonText.TSBTN_IMPORT;
- this.tsbtnBrush.Text = ButtonText.TSBTN_BRUSH;
- 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.btnSave.Text = ButtonText.BTN_SAVE;
- this.btnCancel.Text = ButtonText.BTN_CANCEL;
- this.gbxCondition.Text = Constant.LABEL_QUERY_CONDITIONS;
- }
- #endregion
- #region 单例模式
- /// <summary>
- /// 单例模式,防止重复创建窗体
- /// </summary>
- public static F_HR_1002 Instance
- {
- get
- {
- if (_instance == null)
- {
- _instance = new F_HR_1002();
- }
- return _instance;
- }
- }
- #endregion
- #region 事件
- /// <summary>
- /// 窗体加载事件
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void F_HR_1002_Load(object sender, EventArgs e)
- {
- try
- {
- #region 绑定数据源
- this.dkStaffName.WhereCondition = "(StaffStatus = 1 Or StaffStatus = 2) AND ValueFlag = 1";
- //dtpmonth
- this.dtpmonth.Value = new DateTime(DateTime.Now.Year, DateTime.Now.Month, DateTime.Now.Day);
- //获取出勤状态数据源
- this.AttendanceStatusName.DisplayMember = "AttendanceStatusName";
- this.AttendanceStatusName.ValueMember = "AttendanceStatus";
- this.AttendanceStatusName.DataSource = this.GetAttendanceStatusInfo();
- //获取缺勤原因数据源
- this.AbsenceReasonName.ValueMember = "AbsenceReason";
- this.AbsenceReasonName.DisplayMember = "AbsenceReasonName";
- this.AbsenceReasonName.DataSource = this.GetAbsenceReasonInfo();
- //获取迟到早退次数数据源
- this.TardinessTimes.ValueMember = "TardinessTimes";
- this.TardinessTimes.DisplayMember = "TardinessTimesName";
- this.TardinessTimes.DataSource = this.GetTardinessTimesInfo();
- FormPermissionManager.FormPermissionControl(this.Name, this,
- LogInUserInfo.CurrentUser.CurrentUserEntity.UserRightData, LogInUserInfo.CurrentUser.CurrentUserEntity.FunctionData);
- this.dgvStaffAttendance.SelectionMode = DataGridViewSelectionMode.RowHeaderSelect;
- this.btnSave.Enabled = false;
- #endregion
- }
- catch (Exception ex)
- {
- // 对异常进行共通处理
- ExceptionManager.HandleEventException(this.ToString(),
- System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
- }
- }
- /// <summary>
- /// 导入按钮
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void tsbtnImport_Click(object sender, EventArgs e)
- {
- try
- {
- this.oFileDialog.Filter = "Excel文件(*.xlsx)|*.xlsx";
- this.oFileDialog.FileName = string.Empty;
- if (this.oFileDialog.ShowDialog() == DialogResult.OK)
- {
- DataTable dtStaffMeal = ExcelLayer.GetDataTable(this.oFileDialog.FileName, 1);
- #region 对数据进行验证
- if (dtStaffMeal == null && dtStaffMeal.Rows.Count <= 0)
- {
- // 提示信息
- MessageBox.Show(string.Format(Messages.MSG_CMN_W007, "数据表中没有数据!"),
- this.Text, MessageBoxButtons.OK, MessageBoxIcon.Warning);
- return;
- }
- #endregion
- DataSet dsResultStaff = (DataSet)DoAsync(new BaseAsyncMethod(() =>
- {
- return HRModuleProxy.Service.GetStaffAttendanceInfoForExcel(dtStaffMeal);
- }));
- if (dsResultStaff != null)
- {
- base.DataSource = dsResultStaff;
- if (this.DataSource != null && this.DataSource.Tables.Count > Constant.INT_IS_ZERO)
- {
- this.dgvStaffAttendance.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.Warning);
- }
- }
- }
- }
- }
- catch (Exception ex)
- {
- // 对异常进行共通处理
- ExceptionManager.HandleEventException(this.ToString(),
- System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
- }
- }
- /// <summary>
- /// 数据刷
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void tsbtnBrush_Click(object sender, EventArgs e)
- {
- try
- {
- if (this.dgvStaffAttendance.CurrentCell == null
- || this.dgvStaffAttendance.Rows.Count < Constant.INT_IS_ONE)
- {
- return;
- }
- DataGridViewCell currentCell = this.dgvStaffAttendance.CurrentCell;
- if ("CardNumber".Equals(dgvStaffAttendance.Columns[currentCell.ColumnIndex].Name))
- {
- if (!_isBrushIsOpen)
- {
- this.tsbtnBrush.Checked = true;
- this._isBrushIsOpen = true;
- this.dgvStaffAttendance.Cursor = Cursors.Hand;
- this.dgvStaffAttendance.MultiSelect = true;
- this._cardNumber = dgvStaffAttendance.CurrentRow.Cells[currentCell.ColumnIndex].Value + "";
- }
- else
- {
- this.dgvStaffAttendance.Cursor = Cursors.Default;
- this.dgvStaffAttendance.MultiSelect = false;
- this.tsbtnBrush.Checked = false;
- this._isBrushIsOpen = false;
- }
- }
- else if ("AttendanceStatusName".Equals(dgvStaffAttendance.Columns[currentCell.ColumnIndex].Name))
- {
- if (!_isBrushIsOpen)
- {
- this.tsbtnBrush.Checked = true;
- this._isBrushIsOpen = true;
- this.dgvStaffAttendance.Cursor = Cursors.Hand;
- this.dgvStaffAttendance.MultiSelect = true;
- this._attendanceStatus = dgvStaffAttendance.CurrentRow.Cells[currentCell.ColumnIndex].Value + "";
- }
- else
- {
- this.dgvStaffAttendance.Cursor = Cursors.Default;
- this.dgvStaffAttendance.MultiSelect = false;
- this.tsbtnBrush.Checked = false;
- this._isBrushIsOpen = false;
- }
- }
- else if ("AbsenceReasonName".Equals(dgvStaffAttendance.Columns[currentCell.ColumnIndex].Name))
- {
- if (!_isBrushIsOpen)
- {
- this.tsbtnBrush.Checked = true;
- this._isBrushIsOpen = true;
- this.dgvStaffAttendance.Cursor = Cursors.Hand;
- this.dgvStaffAttendance.MultiSelect = true;
- this._absenceReason = dgvStaffAttendance.CurrentRow.Cells[currentCell.ColumnIndex].Value + "";
- }
- else
- {
- this.dgvStaffAttendance.Cursor = Cursors.Default;
- this.dgvStaffAttendance.MultiSelect = false;
- this.tsbtnBrush.Checked = false;
- this._isBrushIsOpen = false;
- }
- }
- else if ("TardinessTimes".Equals(dgvStaffAttendance.Columns[currentCell.ColumnIndex].Name))
- {
- if (!_isBrushIsOpen)
- {
- this.tsbtnBrush.Checked = true;
- this._isBrushIsOpen = true;
- this.dgvStaffAttendance.Cursor = Cursors.Hand;
- this.dgvStaffAttendance.MultiSelect = true;
- this._tardinessTimes = dgvStaffAttendance.CurrentRow.Cells[currentCell.ColumnIndex].Value + "";
- }
- else
- {
- this.dgvStaffAttendance.Cursor = Cursors.Default;
- this.dgvStaffAttendance.MultiSelect = false;
- this.tsbtnBrush.Checked = false;
- this._isBrushIsOpen = false;
- }
- }
- else if ("Remarks".Equals(dgvStaffAttendance.Columns[currentCell.ColumnIndex].Name))
- {
- if (!_isBrushIsOpen)
- {
- this.tsbtnBrush.Checked = true;
- this._isBrushIsOpen = true;
- this.dgvStaffAttendance.Cursor = Cursors.Hand;
- this.dgvStaffAttendance.MultiSelect = true;
- this._remarks = dgvStaffAttendance.CurrentRow.Cells[currentCell.ColumnIndex].Value + "";
- }
- else
- {
- this.dgvStaffAttendance.Cursor = Cursors.Default;
- this.dgvStaffAttendance.MultiSelect = false;
- this.tsbtnBrush.Checked = false;
- this._isBrushIsOpen = false;
- }
- }
- }
- catch (Exception ex)
- {
- // 对异常进行共通处理
- ExceptionManager.HandleEventException(this.ToString(),
- System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
- }
- }
- /// <summary>
- /// 数据刷刷数据
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void dgvStaffAttendance_CellMouseMove(object sender, DataGridViewCellMouseEventArgs e)
- {
- try
- {
- if (this.dgvStaffAttendance.CurrentCell == null
- || this.dgvStaffAttendance.Rows.Count < Constant.INT_IS_ONE)
- {
- return;
- }
- DataGridViewCell currentCell = this.dgvStaffAttendance.CurrentCell;
- if (_columnIndex != -Constant.INT_IS_ONE && _columnIndex != currentCell.ColumnIndex)
- {
- this.SetBrushNotEnable();
- }
- if ("CardNumber".Equals(dgvStaffAttendance.Columns[currentCell.ColumnIndex].Name))
- {
- if (_isBrushIsOpen)
- {
- dgvStaffAttendance.CurrentRow.Cells[currentCell.ColumnIndex].Value = _cardNumber;
- }
- this._columnIndex = currentCell.ColumnIndex;
- }
- else if ("AttendanceStatusName".Equals(dgvStaffAttendance.Columns[currentCell.ColumnIndex].Name))
- {
- if (_isBrushIsOpen && !dgvStaffAttendance.CurrentRow.Cells[currentCell.ColumnIndex].ReadOnly)
- {
- dgvStaffAttendance.CurrentRow.Cells[currentCell.ColumnIndex].Value = _attendanceStatus;
- }
- this._columnIndex = currentCell.ColumnIndex;
- }
- else if ("AbsenceReasonName".Equals(dgvStaffAttendance.Columns[currentCell.ColumnIndex].Name))
- {
- if (_isBrushIsOpen && !dgvStaffAttendance.CurrentRow.Cells[currentCell.ColumnIndex].ReadOnly)
- {
- dgvStaffAttendance.CurrentRow.Cells[currentCell.ColumnIndex].Value = _absenceReason;
- }
- this._columnIndex = currentCell.ColumnIndex;
- }
- else if ("TardinessTimes".Equals(dgvStaffAttendance.Columns[currentCell.ColumnIndex].Name))
- {
- if (_isBrushIsOpen && !dgvStaffAttendance.CurrentRow.Cells[currentCell.ColumnIndex].ReadOnly)
- {
- dgvStaffAttendance.CurrentRow.Cells[currentCell.ColumnIndex].Value = _tardinessTimes;
- }
- this._columnIndex = currentCell.ColumnIndex;
- }
- else if ("Remarks".Equals(dgvStaffAttendance.Columns[currentCell.ColumnIndex].Name))
- {
- if (_isBrushIsOpen && !dgvStaffAttendance.CurrentRow.Cells[currentCell.ColumnIndex].ReadOnly)
- {
- dgvStaffAttendance.CurrentRow.Cells[currentCell.ColumnIndex].Value = _remarks;
- }
- this._columnIndex = currentCell.ColumnIndex;
- }
- this.btnSave.Enabled = true;
- }
- catch (Exception ex)
- {
- // 对异常进行共通处理
- ExceptionManager.HandleEventException(this.ToString(),
- System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
- }
- }
- /// <summary>
- /// 窗体关闭事件
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void F_HR_1002_FormClosed(object sender, FormClosedEventArgs e)
- {
- _instance = null;
- }
- /// <summary>
- /// 关闭按钮事件
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void tsbtnClose_Click(object sender, EventArgs e)
- {
- this.Close();
- }
- /// <summary>
- /// 自动适应列宽
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void tsbtnAdaptive_Click(object sender, EventArgs e)
- {
- this.dgvStaffAttendance.AutoResizeColumns(DataGridViewAutoSizeColumnsMode.AllCells);
- }
- /// <summary>
- /// 清空条件
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void btnClearCondition_Click(object sender, EventArgs e)
- {
- this.dkStaffName.UserID = null;
- this.dkStaffName.UserCode = string.Empty;
- this.dkStaffName.UserName = string.Empty;
- this.dkStaffName.StaffEntity = null;
- }
- /// <summary>
- /// 查询按钮事件
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void btnSearch_Click(object sender, EventArgs e)
- {
- try
- {
- if (this.dkStaffName.StaffEntity.StaffCode == null)
- {
- MessageBox.Show(string.Format(Messages.MSG_CMN_W005, "员工名称"),
- this.Text, MessageBoxButtons.OK, MessageBoxIcon.Information);
- return;
- }
- this._staffIDList = null;
- // 记录当前选中行
- int selectRowIndex = this._selectedRowIndex;
- SearchAttendanceEntity SearchAttendanceEntity = SetSearchAttendanceEntity();
- //DataTable dtResultStaff = GetStaffAttendance();
- DataSet dsResultStaff = (DataSet)DoAsync(new BaseAsyncMethod(() =>
- {
- return HRModuleProxy.Service.SearcStaffAttendanceForEdit(SearchAttendanceEntity);
- }));
- if (dsResultStaff != null)
- {
- base.DataSource = dsResultStaff;
- if (this.DataSource != null && this.DataSource.Tables.Count > Constant.INT_IS_ZERO)
- {
- this.dgvStaffAttendance.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.Warning);
- }
- }
- }
- }
- catch (Exception ex)
- {
- // 对异常进行共通处理
- ExceptionManager.HandleEventException(this.ToString(),
- System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
- }
- }
- /// <summary>
- /// 保存按钮事件
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void btnSave_Click(object sender, EventArgs e)
- {
- try
- {
- DataGridViewRow row = dgvStaffAttendance.CurrentRow;
- if (row.Cells["CardNumber"].Value == null
- || string.IsNullOrEmpty(row.Cells["CardNumber"].Value + string.Empty))
- {
- // 单元格的错误消息
- MessageBox.Show(string.Format(Messages.MSG_CMN_W005, "考勤卡号"),
- this.Text, MessageBoxButtons.OK, MessageBoxIcon.Information);
- this.btnSave.Enabled = false;
- return;
- }
- // 保存
- this.btnSave.Enabled = false;
- this.btnCancel.Enabled = false;
- DataTable dTable = (DataTable)this.dgvStaffAttendance.DataSource;
- dTable.AcceptChanges();
- HRResultEntity resultEntity = (HRResultEntity)DoAsync(new BaseAsyncMethod(() =>
- {
- return HRModuleProxy.Service.SaveStaffAttendanceInfo(dTable);
- }));
- this.btnSave.Enabled = true;
- this.btnCancel.Enabled = true;
- if (!string.IsNullOrEmpty(resultEntity.OperateLogInfo))
- {
- MessageBox.Show(resultEntity.OperateLogInfo,
- this.Text, MessageBoxButtons.OK, MessageBoxIcon.Information);
- this.btnSave.Enabled = false;
- }
- else if (resultEntity.OperateStatus > Constant.INT_IS_ZERO)
- {
- // 保存成功提示信息
- MessageBox.Show(string.Format(Messages.MSG_CMN_I001, "员工考勤", "保存"),
- this.Text, MessageBoxButtons.OK, MessageBoxIcon.Information);
- this.btnSave.Enabled = false;
- }
- 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);
- }
- }
- /// <summary>
- /// 关闭按钮事件
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void btnCancel_Click(object sender, EventArgs e)
- {
- this.DialogResult = DialogResult.Cancel;
- this.Close();
- }
- #endregion
- #region 私有方法
- /// <summary>
- /// 设置窗体按钮的文本信息
- /// </summary>
- private void SetFromTitleInfo()
- {
- this.tsbtnImport.Text = ButtonText.TSBTN_IMPORT;
- this.tsbtnBrush.Text = ButtonText.TSBTN_BRUSH;
- 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.btnSave.Text = ButtonText.BTN_SAVE;
- this.btnCancel.Text = ButtonText.BTN_CANCEL;
- this.gbxCondition.Text = Constant.LABEL_QUERY_CONDITIONS;
- this.Text = FormTitles.F_HR_1002;
- // 设置表格不自动创建列
- this.dgvStaffAttendance.AutoGenerateColumns = false;
- }
- /// <summary>
- /// 根据查询条件 形成查询实体
- /// </summary>
- /// <returns></returns>
- public SearchAttendanceEntity SetSearchAttendanceEntity()
- {
- SearchAttendanceEntity searchAttendanceEntity = new SearchAttendanceEntity();
- if (this.dkStaffName.UserID != null)
- {
- searchAttendanceEntity.StaffID = this.dkStaffName.UserID;
- }
- DateTime time = this.dtpmonth.Value;
- searchAttendanceEntity.StartAttendanceDate = new DateTime(time.Year, time.Month, 1);
- searchAttendanceEntity.EndAttendanceDate = new DateTime(time.Year, time.Month, DateTime.DaysInMonth(time.Year, time.Month));
- return searchAttendanceEntity;
- }
- /// <summary>
- /// 工资结算标识数据源
- /// </summary>
- /// <returns></returns>
- private DataTable GetSettlementFlagInfo()
- {
- //1:已经结算 0:未结算
- DataTable dtRAPType = new DataTable();
- dtRAPType.Columns.Add("SettlementFlag");
- dtRAPType.Columns.Add("SettlementFlagName");
- DataRow newRowType = dtRAPType.NewRow();
- newRowType = dtRAPType.NewRow();
- newRowType["SettlementFlag"] = "0";
- newRowType["SettlementFlagName"] = "未结算";
- dtRAPType.Rows.Add(newRowType);
- newRowType = dtRAPType.NewRow();
- newRowType["SettlementFlag"] = "1";
- newRowType["SettlementFlagName"] = "已经结算";
- dtRAPType.Rows.Add(newRowType);
- return dtRAPType;
- }
- /// <summary>
- /// 出勤状态数据源
- /// </summary>
- /// <returns></returns>
- private DataTable GetAttendanceStatusInfo()
- {
- DataTable dtAttendanceStatus = new DataTable();
- dtAttendanceStatus.Columns.Add("AttendanceStatus");
- dtAttendanceStatus.Columns.Add("AttendanceStatusName");
- DataRow rowAttendanceStatus = dtAttendanceStatus.NewRow();
- rowAttendanceStatus["AttendanceStatus"] = "1";
- rowAttendanceStatus["AttendanceStatusName"] = "全天";
- dtAttendanceStatus.Rows.Add(rowAttendanceStatus);
- rowAttendanceStatus = dtAttendanceStatus.NewRow();
- rowAttendanceStatus["AttendanceStatus"] = "2";
- rowAttendanceStatus["AttendanceStatusName"] = "半天";
- dtAttendanceStatus.Rows.Add(rowAttendanceStatus);
- rowAttendanceStatus = dtAttendanceStatus.NewRow();
- rowAttendanceStatus["AttendanceStatus"] = "3";
- rowAttendanceStatus["AttendanceStatusName"] = "缺勤";
- dtAttendanceStatus.Rows.Add(rowAttendanceStatus);
- return dtAttendanceStatus;
- }
- /// <summary>
- /// 缺勤原因数据源
- /// </summary>
- /// <returns></returns>
- private DataTable GetAbsenceReasonInfo()
- {
- DataTable dtAbsenceReason = new DataTable();
- dtAbsenceReason.Columns.Add("AbsenceReason");
- dtAbsenceReason.Columns.Add("AbsenceReasonName");
- DataRow rowAbsenceReason = dtAbsenceReason.NewRow();
- rowAbsenceReason["AbsenceReason"] = "0";
- rowAbsenceReason["AbsenceReasonName"] = "休息";
- dtAbsenceReason.Rows.Add(rowAbsenceReason);
- rowAbsenceReason = dtAbsenceReason.NewRow();
- rowAbsenceReason["AbsenceReason"] = "1";
- rowAbsenceReason["AbsenceReasonName"] = "病假";
- dtAbsenceReason.Rows.Add(rowAbsenceReason);
- rowAbsenceReason = dtAbsenceReason.NewRow();
- rowAbsenceReason["AbsenceReason"] = "2";
- rowAbsenceReason["AbsenceReasonName"] = "事假";
- dtAbsenceReason.Rows.Add(rowAbsenceReason);
- rowAbsenceReason = dtAbsenceReason.NewRow();
- rowAbsenceReason["AbsenceReason"] = "3";
- rowAbsenceReason["AbsenceReasonName"] = "旷工";
- dtAbsenceReason.Rows.Add(rowAbsenceReason);
- //缺勤原因可为空
- rowAbsenceReason = dtAbsenceReason.NewRow();
- rowAbsenceReason["AbsenceReason"] = "4";
- rowAbsenceReason["AbsenceReasonName"] = "其它";
- dtAbsenceReason.Rows.Add(rowAbsenceReason);
- return dtAbsenceReason;
- }
- /// <summary>
- /// 迟到早退次数数据源
- /// </summary>
- /// <returns></returns>
- private DataTable GetTardinessTimesInfo()
- {
- DataTable dtTardinessTimes = new DataTable();
- dtTardinessTimes.Columns.Add("TardinessTimes");
- dtTardinessTimes.Columns.Add("TardinessTimesName");
- DataRow rowTardinessTimes = dtTardinessTimes.NewRow();
- rowTardinessTimes["TardinessTimes"] = "0";
- rowTardinessTimes["TardinessTimesName"] = "0";
- dtTardinessTimes.Rows.Add(rowTardinessTimes);
- rowTardinessTimes = dtTardinessTimes.NewRow();
- rowTardinessTimes["TardinessTimes"] = "1";
- rowTardinessTimes["TardinessTimesName"] = "1";
- dtTardinessTimes.Rows.Add(rowTardinessTimes);
- rowTardinessTimes = dtTardinessTimes.NewRow();
- rowTardinessTimes["TardinessTimes"] = "2";
- rowTardinessTimes["TardinessTimesName"] = "2";
- dtTardinessTimes.Rows.Add(rowTardinessTimes);
- rowTardinessTimes = dtTardinessTimes.NewRow();
- rowTardinessTimes["TardinessTimes"] = "3";
- rowTardinessTimes["TardinessTimesName"] = "3";
- dtTardinessTimes.Rows.Add(rowTardinessTimes);
- rowTardinessTimes = dtTardinessTimes.NewRow();
- rowTardinessTimes["TardinessTimes"] = "4";
- rowTardinessTimes["TardinessTimesName"] = "4";
- dtTardinessTimes.Rows.Add(rowTardinessTimes);
- return dtTardinessTimes;
- }
- /// <summary>
- /// 获取员工考勤
- /// </summary>
- /// <returns></returns>
- private DataTable GetStaffAttendance()
- {
- SearchAttendanceEntity searchAttendanceEntity = SetSearchAttendanceEntity();
- DataSet staffAttendance = (DataSet)DoAsync(new BaseAsyncMethod(() =>
- {
- return HRModuleProxy.Service.SearcStaffAttendance(searchAttendanceEntity);
- }));
- SearchStaffEntity searchStaff = new SearchStaffEntity();
- if (this.dkStaffName.UserID != null)
- {
- searchStaff.StaffID = this.dkStaffName.UserID;
- }
- DataSet resultStaff = (DataSet)DoAsync(new BaseAsyncMethod(() =>
- {
- return HRModuleProxy.Service.SearchHrStaff(searchStaff);
- }));
- DateTime dtBegin = searchAttendanceEntity.StartAttendanceDate.Value;
- DateTime dtEnd = searchAttendanceEntity.EndAttendanceDate.Value;
- if (dtEnd >= DateTime.Now)
- {
- dtEnd = new DateTime(DateTime.Now.Year, DateTime.Now.Month, DateTime.Now.Day);
- }
- DataTable dtStaffAtt = staffAttendance.Tables[0].Clone();
- for (DateTime dtItem = dtBegin; dtItem <= dtEnd; dtItem = dtItem.AddDays(1))
- {
- DataRow newRowAtt = dtStaffAtt.NewRow();
- newRowAtt["StaffID"] = resultStaff.Tables[0].Rows[0]["StaffID"].ToString();
- newRowAtt["StaffCode"] = resultStaff.Tables[0].Rows[0]["StaffCode"].ToString();
- newRowAtt["StaffName"] = resultStaff.Tables[0].Rows[0]["StaffName"].ToString();
- newRowAtt["IDCardNo"] = resultStaff.Tables[0].Rows[0]["IDCardNo"].ToString();
- newRowAtt["AttendanceDate"] = dtItem;
- newRowAtt["CardNumber"] = 1;
- newRowAtt["AttendanceStatus"] = 1;
- newRowAtt["AbsenceReason"] = 4;
- newRowAtt["TardinessTimes"] = 0;
- newRowAtt["SettlementFlag"] = "未结算";
- if (staffAttendance != null && staffAttendance.Tables.Count > Constant.INT_IS_ZERO)
- {
- string strWhere = "StaffID = " + resultStaff.Tables[0].Rows[0]["StaffID"].ToString()
- + " And AttendanceDate = '" + dtItem + "'";
- DataRow[] rowAttendances = staffAttendance.Tables[0].Select(strWhere);
- if (rowAttendances != null & rowAttendances.Length > Constant.INT_IS_ZERO)
- {
- newRowAtt["CardNumber"] = rowAttendances[0]["CardNumber"].ToString();
- newRowAtt["AttendanceStatus"] = rowAttendances[0]["AttendanceStatus"].ToString();
- newRowAtt["AbsenceReason"] = rowAttendances[0]["AbsenceReason"].ToString();
- newRowAtt["TardinessTimes"] = rowAttendances[0]["TardinessTimes"].ToString();
- newRowAtt["SettlementFlag"] = rowAttendances[0]["SettlementFlag"].ToString() == "0" ? "未结算" : "已结算";
- }
- }
- dtStaffAtt.Rows.Add(newRowAtt);
- }
- return dtStaffAtt;
- }
- /// <summary>
- /// 使格式刷不可用
- /// </summary>
- private void SetBrushNotEnable()
- {
- this._isBrushIsOpen = false;
- this.tsbtnBrush.Checked = false;
- this.dgvStaffAttendance.Cursor = Cursors.Default;
- this.dgvStaffAttendance.MultiSelect = false;
- }
- #endregion
- }
- }
|