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

📄 usermandlg.cpp

📁 人事工资管理系统是非常通用的管理信息系统
💻 CPP
字号:
// UserManDlg.cpp : implementation file
//

#include "stdafx.h"
#include "HrSys.h"
#include "UserManDlg.h"
#include "UserEditDlg.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

/////////////////////////////////////////////////////////////////////////////
// CUserManDlg dialog


CUserManDlg::CUserManDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CUserManDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CUserManDlg)
	//}}AFX_DATA_INIT
}


void CUserManDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CUserManDlg)
	DDX_Control(pDX, IDC_ADODC1, m_adodc);
	DDX_Control(pDX, IDC_DATAGRID1, m_datagrid);
	//}}AFX_DATA_MAP
}


BEGIN_MESSAGE_MAP(CUserManDlg, CDialog)
	//{{AFX_MSG_MAP(CUserManDlg)
	ON_BN_CLICKED(IDC_ADD_BUTTON, OnAddButton)
	ON_BN_CLICKED(IDC_MODI_BUTTON, OnModiButton)
	ON_BN_CLICKED(IDC_DEL_BUTTON, OnDelButton)
	ON_BN_CLICKED(IDC_RESET_BUTTON, OnResetButton)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CUserManDlg message handlers

void CUserManDlg::OnAddButton() 
{
	CUserEditDlg dlg;
	dlg.iUserType = 2;
	if (dlg.DoModal() == IDOK)
		RefreshData(); 
}

void CUserManDlg::OnModiButton() 
{
	UpdateData(TRUE);
	// TODO: Add your control notification handler code here
	if (m_adodc.GetRecordset().GetEof()) 
	{
		MessageBox("请选择要修改的记录");
		return;
	}
	//编辑用户信息
	CUserEditDlg dlg;
	
	dlg.cUserName = m_datagrid.GetItem(0);
	dlg.lEmpId = atol(m_datagrid.GetItem(4));
	dlg.m_UserName = m_datagrid.GetItem(0);
	dlg.m_EmpName = m_datagrid.GetItem(1);
	dlg.m_DepName = m_datagrid.GetItem(2);
	if(m_datagrid.GetItem(3) == "系统管理员")
		dlg.iUserType = 1;
	else
		dlg.iUserType = 2;
	if (dlg.DoModal() == IDOK)
		RefreshData(); 
}

void CUserManDlg::OnDelButton() 
{
	UpdateData(TRUE);
	// TODO: Add your control notification handler code here
	if (m_adodc.GetRecordset().GetEof()) 
	{
		MessageBox("请选择要修改的记录");
		return;
	}

	if (m_datagrid.GetItem(0) == "Admin")
	{
		MessageBox("不能删除Admin用户");
		return;
	}
	if (MessageBox("是否删除当前用户","请确认", MB_YESNO) == IDYES)
	{
		CUsers usr;
		usr.sql_delete(m_datagrid.GetItem(0));
		RefreshData();
	}
}

void CUserManDlg::OnResetButton() 
{
	UpdateData(TRUE);
	//将用户密码复位成原始密码
	if (m_adodc.GetRecordset().GetEof()) 
	{
		MessageBox("请选择要修改的记录");
		return;
	}

	if (MessageBox("是否复位当前用户的密码","请确认", MB_YESNO) == IDYES)
	{
		CUsers usr;
		usr.UserPwd = "111111";
		usr.sql_updatePassword(m_datagrid.GetItem(0));
		RefreshData();
	}
}
//刷新数据
void CUserManDlg::RefreshData()
{
	//设置记录源
	CString cSource;
	cSource = "SELECT u.UserName AS 用户名, ISNULL(e.EmpName,'') AS 员工姓名,"
		" ISNULL(d.DepName,'') AS 部门名称,u.UserType AS 用户类型,u.EmpId"
		" FROM Users u LEFT JOIN Employees e ON u.EmpId=e.EmpId"
		" LEFT JOIN Departments d ON e.DepId=d.DepId ORDER BY u.UserName";

	m_adodc.SetRecordSource(cSource);
	m_adodc.Refresh();
	//设置表格列宽度
	_variant_t vIndex;
	vIndex = long(0);
	m_datagrid.GetColumns().GetItem(vIndex).SetWidth(60);
	vIndex = long(1);
	m_datagrid.GetColumns().GetItem(vIndex).SetWidth(60);
	vIndex = long(2);
	m_datagrid.GetColumns().GetItem(vIndex).SetWidth(80);
	vIndex = long(3);
	m_datagrid.GetColumns().GetItem(vIndex).SetWidth(170);
	vIndex = long(4);
	m_datagrid.GetColumns().GetItem(vIndex).SetWidth(0);
}

BOOL CUserManDlg::OnInitDialog() 
{
	CDialog::OnInitDialog();
	
	// TODO: Add extra initialization here
	RefreshData();
	return TRUE;  // return TRUE unless you set the focus to a control
	              // EXCEPTION: OCX Property Pages should return FALSE
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -