⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 overtimeeditdlg.cpp

📁 visual c++与sql Server数据库开发考勤管理系统
💻 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 + -