📄 overtimeeditdlg.cpp
字号:
// OvertimeEditDlg.cpp : implementation file
//
#include "stdafx.h"
#include "CheckManage.h"
#include "OvertimeEditDlg.h"
#include "DepSelDlg.h"
#include "Overtime.h"
#include "COMDEF.H"
#include "Columns.h"
#include "Column.h"
#include "_Recordset.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// COvertimeEditDlg dialog
COvertimeEditDlg::COvertimeEditDlg(CWnd* pParent /*=NULL*/)
: CDialog(COvertimeEditDlg::IDD, pParent)
{
//{{AFX_DATA_INIT(COvertimeEditDlg)
m_DepName = _T("");
m_hour = 0;
m_overtime = -1;
m_checkdate = _T("");
m_describe = _T("");
//}}AFX_DATA_INIT
}
void COvertimeEditDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(COvertimeEditDlg)
DDX_Control(pDX, IDC_ADODC1, m_Adodc);
DDX_Control(pDX, IDC_DATAGRID1, m_Datagrid);
DDX_Text(pDX, IDC_DEPNAME_STATIC, m_DepName);
DDX_Text(pDX, IDC_HOUR_EDIT, m_hour);
DDX_Radio(pDX, IDC_RADIO1, m_overtime);
DDX_Text(pDX, IDC_CHECKDATE_STATIC, m_checkdate);
DDX_Text(pDX, IDC_DESCRIBE_EDIT, m_describe);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(COvertimeEditDlg, CDialog)
//{{AFX_MSG_MAP(COvertimeEditDlg)
ON_BN_CLICKED(IDC_SEL_DEP_BUTTON, OnSelDepButton)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// COvertimeEditDlg message handlers
BOOL COvertimeEditDlg::OnInitDialog()
{
CDialog::OnInitDialog();
// TODO: Add extra initialization here
// 修改状态下不用选择部门信息
if(EmpId != "")
GetDlgItem(IDC_SEL_DEP_BUTTON)->EnableWindow(FALSE);
m_checkdate = otDate;
RefreshData();
return TRUE; // return TRUE unless you set the focus to a control
// EXCEPTION: OCX Property Pages should return FALSE
}
// 刷新数据
void COvertimeEditDlg::RefreshData()
{
UpdateData(TRUE);
//根据部门编号设置SELECT语句
CString cDepId;
cDepId.Format("%d", iDepId);
// 设置SELECT语句
CString cSource = "SELECT EmpId AS 员工编号, Name AS 姓名"
" FROM EmpInfo WHERE DepId = " + cDepId;
if(EmpId != "")
cSource += " AND EmpId=" + EmpId;
//刷新ADO Data控件的记录源
m_Adodc.SetRecordSource(cSource);
m_Adodc.Refresh();
//设置列宽度
_variant_t vIndex;
vIndex = long(0);
m_Datagrid.GetColumns().GetItem(vIndex).SetWidth(0);
vIndex = long(1);
m_Datagrid.GetColumns().GetItem(vIndex).SetWidth(100);
}
// 选择部门
void COvertimeEditDlg::OnSelDepButton()
{
// TODO: Add your control notification handler code here
UpdateData(TRUE);
//打开选择部门对话框
CDepSelDlg dlg;
dlg.DoModal();
//从对话框中读取选择部门的信息
iDepId = dlg.DepId;
m_DepName = dlg.DepName;
UpdateData(FALSE);
//根据选择的部门信息,刷新表格数据
RefreshData();
}
// 确定按钮
void COvertimeEditDlg::OnOK()
{
// TODO: Add extra validation here
UpdateData(TRUE);
// 是否选择人员
if(m_Adodc.GetRecordset().GetEof())
{
MessageBox("请选择人员");
return;
}
// 是否进行添加考勤状态
if(m_overtime == -1)
{
MessageBox("请选择加班类型");
return;
}
// 赋值到COvertime对象中
COvertime cur;
cur.otDate = otDate;
cur.EmpId = atol(m_Datagrid.GetItem(0));
cur.otHour = m_hour;
cur.Describes = m_describe;
switch(m_overtime)
{
case 0:
cur.otType = "法定节假日加班";
break;
case 1:
cur.otType = "周六日加班";
break;
case 2:
cur.otType = "日常加班";
break;
}
if(EmpId == "")
{
// 在添加时,若人员有加班记录,则不允许添加
if(cur.HaveEmp(otDate, m_Datagrid.GetItem(0)))
{
MessageBox("已经有此员工的加班信息,不能添加");
return;
}
// 插入记录
cur.SqlInsert();
}
else
{
// 修改CheckInfo表记录
cur.SqlUpdate(cur.otDate, m_Datagrid.GetItem(0));
}
CDialog::OnOK();
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -