📄 usermandlg.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 + -