📄 projectexhibitform.cpp
字号:
// ProjectExhibitForm.cpp : implementation file
//
#include "stdafx.h"
#include "ClientRelationship.h"
#include "ProjectExhibitForm.h"
#include "ProjectExhibit.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CProjectExhibitForm dialog
CProjectExhibitForm::CProjectExhibitForm(CWnd* pParent /*=NULL*/)
: CDialog(CProjectExhibitForm::IDD, pParent)
{
//{{AFX_DATA_INIT(CProjectExhibitForm)
m_exhibitDate = COleDateTime::GetCurrentTime();
m_chargePerson = _T("");
m_exhibitProject = _T("");
m_address = _T("");
m_summary = _T("");
m_projectExhibitID = _T("");
is_search=0;
//}}AFX_DATA_INIT
}
void CProjectExhibitForm::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CProjectExhibitForm)
DDX_Control(pDX, IDC_chargePerson, m_staffNameCombo);
DDX_Control(pDX, IDC_LIST1, m_list);
DDX_DateTimeCtrl(pDX, IDC_exhibitDate, m_exhibitDate);
DDX_CBString(pDX, IDC_chargePerson, m_chargePerson);
DDX_Text(pDX, IDC_exhibitProject, m_exhibitProject);
DDX_Text(pDX, IDC_address, m_address);
DDX_Text(pDX, IDC_summary, m_summary);
DDX_Text(pDX, IDC_projectExhibitID, m_projectExhibitID);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CProjectExhibitForm, CDialog)
//{{AFX_MSG_MAP(CProjectExhibitForm)
ON_BN_CLICKED(IDC_add, OnAdd)
ON_BN_CLICKED(IDC_delete, OnDelete)
ON_BN_CLICKED(IDC_modify, OnModify)
ON_BN_CLICKED(IDC_save, OnSave)
ON_BN_CLICKED(IDC_cancelation, OnCancelation)
ON_BN_CLICKED(IDC_exit, OnExit)
ON_NOTIFY(NM_CLICK, IDC_LIST1, OnClickList1)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CProjectExhibitForm message handlers
void CProjectExhibitForm::OnAdd()
{
CString m_formID;
int formID=((CClientRelationshipApp*)AfxGetApp())->m_pIDRecordset->GetCollect("projectExhibitID").intVal;
if(formID<10)
m_formID.Format("KHYG0000%d",formID);
else if(formID<100&&formID>9)
m_formID.Format("KHYG000%d",formID);
else if(formID<1000&&formID>99)
m_formID.Format("KHYG00%d",formID);
CString str;
str.Format("%d",formID+1);
((CClientRelationshipApp*)AfxGetApp())->m_pIDRecordset->PutCollect("projectExhibitID",_variant_t(str));
((CClientRelationshipApp*)AfxGetApp())->m_pIDRecordset->Update();
m_exhibitDate = COleDateTime::GetCurrentTime();
m_chargePerson = _T("");
m_exhibitProject = _T("");
m_address = _T("");
m_summary = _T("");
m_projectExhibitID = m_formID;
tx_exhibitDate->EnableWindow(true);
tx_chargePerson->EnableWindow(true);
tx_exhibitProject->EnableWindow(true);
tx_address->EnableWindow(true);
tx_summary->EnableWindow(true);
tx_projectExhibitID->EnableWindow(false);
bt_add->EnableWindow(false);
bt_delete->EnableWindow(false);
bt_modify->EnableWindow(false);
bt_cancelation->EnableWindow(true);
bt_save->EnableWindow(true);
flag=1;
UpdateData(false);
}
void CProjectExhibitForm::OnDelete()
{
CProjectExhibit projectExhibit;
projectExhibit.sqlDelete(m_projectExhibitID);
Refresh();
m_exhibitDate = COleDateTime::GetCurrentTime();
m_chargePerson = _T("");
m_exhibitProject = _T("");
m_address = _T("");
m_summary = _T("");
m_projectExhibitID = _T("");
tx_exhibitDate->EnableWindow(false);
tx_chargePerson->EnableWindow(false);
tx_exhibitProject->EnableWindow(false);
tx_address->EnableWindow(false);
tx_summary->EnableWindow(false);
tx_projectExhibitID->EnableWindow(false);
bt_add->EnableWindow(true);
bt_delete->EnableWindow(false);
bt_modify->EnableWindow(false);
bt_cancelation->EnableWindow(false);
bt_save->EnableWindow(false);
UpdateData(false);
}
void CProjectExhibitForm::OnModify()
{
tx_exhibitDate->EnableWindow(true);
tx_chargePerson->EnableWindow(true);
tx_exhibitProject->EnableWindow(true);
tx_address->EnableWindow(true);
tx_summary->EnableWindow(true);
tx_projectExhibitID->EnableWindow(false);
bt_add->EnableWindow(false);
bt_delete->EnableWindow(false);
bt_modify->EnableWindow(false);
bt_cancelation->EnableWindow(false);
bt_save->EnableWindow(true);
flag=2;
UpdateData(false);
}
void CProjectExhibitForm::OnSave()
{
UpdateData(true);
CProjectExhibit projectExhibit;
projectExhibit.SetProjectExhibitID(m_projectExhibitID);
projectExhibit.SetExhibitDate(m_exhibitDate);
projectExhibit.SetChargePerson(m_chargePerson);
projectExhibit.SetExhibitProject(m_exhibitProject);
projectExhibit.SetAddress(m_address);
projectExhibit.SetSummary(m_summary);
if(flag==1)
{
projectExhibit.sqlInsert();
int i=m_list.GetItemCount();
CString str;
m_list.InsertItem(i,m_projectExhibitID);
str.Format("%d-%d-%d",m_exhibitDate.GetYear(),m_exhibitDate.GetMonth(),m_exhibitDate.GetDay());
m_list.SetItemText(i,1,str);
m_list.SetItemText(i,2,m_chargePerson);
m_list.SetItemText(i,3,m_exhibitProject);
m_list.SetItemText(i,4,m_address);
m_list.SetItemText(i,5,m_summary);
}
else if(flag==2)
{
projectExhibit.sqlUpdate(m_projectExhibitID);
Refresh();
}
tx_exhibitDate->EnableWindow(false);
tx_chargePerson->EnableWindow(false);
tx_exhibitProject->EnableWindow(false);
tx_address->EnableWindow(false);
tx_summary->EnableWindow(false);
tx_projectExhibitID->EnableWindow(false);
bt_add->EnableWindow(true);
bt_delete->EnableWindow(true);
bt_modify->EnableWindow(true);
bt_cancelation->EnableWindow(false);
bt_save->EnableWindow(false);
UpdateData(false);
}
void CProjectExhibitForm::OnCancelation()
{
m_exhibitDate = COleDateTime::GetCurrentTime();
m_chargePerson = _T("");
m_exhibitProject = _T("");
m_address = _T("");
m_summary = _T("");
m_projectExhibitID = _T("");
tx_exhibitDate->EnableWindow(false);
tx_chargePerson->EnableWindow(false);
tx_exhibitProject->EnableWindow(false);
tx_address->EnableWindow(false);
tx_summary->EnableWindow(false);
tx_projectExhibitID->EnableWindow(false);
bt_add->EnableWindow(true);
bt_delete->EnableWindow(false);
bt_modify->EnableWindow(false);
bt_cancelation->EnableWindow(false);
bt_save->EnableWindow(false);
CString m_formID;
int formID=((CClientRelationshipApp*)AfxGetApp())->m_pIDRecordset->GetCollect("projectExhibitID").intVal;
if(formID<10)
m_formID.Format("KHYG0000%d",formID);
else if(formID<100&&formID>9)
m_formID.Format("KHYG000%d",formID);
else if(formID<1000&&formID>99)
m_formID.Format("KHYG00%d",formID);
CString str;
str.Format("%d",formID-1);
((CClientRelationshipApp*)AfxGetApp())->m_pIDRecordset->PutCollect("projectExhibitID",_variant_t(str));
((CClientRelationshipApp*)AfxGetApp())->m_pIDRecordset->Update();
UpdateData(false);
}
void CProjectExhibitForm::OnExit()
{
this->OnCancel();
}
BOOL CProjectExhibitForm::OnInitDialog()
{
CDialog::OnInitDialog();
DWORD style;
style=m_list.GetExStyle();
style=(style|LVS_EX_GRIDLINES|LVS_EX_FULLROWSELECT)&(~LVS_EX_CHECKBOXES) ;
m_list.SetExtendedStyle(style);
m_list.InsertColumn(0,"参展编号",LVCFMT_LEFT,100);
m_list.InsertColumn(1,"参展日期",LVCFMT_LEFT,100);
m_list.InsertColumn(2,"负责人",LVCFMT_LEFT,100);
m_list.InsertColumn(3,"参展项目",LVCFMT_LEFT,100);
m_list.InsertColumn(4,"地点",LVCFMT_LEFT,100);
m_list.InsertColumn(5,"总结",LVCFMT_LEFT,100);
CString strSQL;
_RecordsetPtr m_pRecordset;
HRESULT hTRes;
hTRes = m_pRecordset.CreateInstance(_T("ADODB.Recordset"));
strSQL="select distinct staffName from staff";
hTRes = m_pRecordset->Open((LPTSTR)strSQL.GetBuffer(130),
((CClientRelationshipApp*)AfxGetApp())->m_pConn.GetInterfacePtr(),
adOpenDynamic,adLockPessimistic,adCmdText);
int i=0;
while(!(m_pRecordset->adoEOF))
{
m_staffNameCombo.InsertString(i,((CClientRelationshipApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("staffName")));
m_pRecordset->MoveNext();
i++;
}
m_pRecordset->Close();
strSQL="select * from projectExhibit ";
hTRes = m_pRecordset.CreateInstance(_T("ADODB.Recordset"));
hTRes = m_pRecordset->Open((LPTSTR)strSQL.GetBuffer(130),
((CClientRelationshipApp*)AfxGetApp())->m_pConn.GetInterfacePtr(),
adOpenDynamic,adLockPessimistic,adCmdText);
CString str;
i=0;
while(!(m_pRecordset->adoEOF))
{
m_list.InsertItem(i,((CClientRelationshipApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("projectExhibitID")));
COleDateTime exhibitDate= m_pRecordset->GetCollect("exhibitDate");
str.Format("%d-%d-%d",exhibitDate.GetYear(),exhibitDate.GetMonth(),exhibitDate.GetDay());
m_list.SetItemText(i,1,str);
m_list.SetItemText(i,2, ((CClientRelationshipApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("chargePerson")));
m_list.SetItemText(i,3, ((CClientRelationshipApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("exhibitProject")));
m_list.SetItemText(i,4, ((CClientRelationshipApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("address")));
m_list.SetItemText(i,5, ((CClientRelationshipApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("summary")));
m_pRecordset->MoveNext();
i++;
}
tx_exhibitDate=GetDlgItem(IDC_exhibitDate);
tx_chargePerson=GetDlgItem(IDC_chargePerson);
tx_exhibitProject=GetDlgItem(IDC_exhibitProject);
tx_address=GetDlgItem(IDC_address);
tx_summary=GetDlgItem(IDC_summary);
tx_projectExhibitID=GetDlgItem(IDC_projectExhibitID);
bt_add=GetDlgItem(IDC_add);
bt_delete=GetDlgItem(IDC_delete);
bt_modify=GetDlgItem(IDC_modify);
bt_cancelation=GetDlgItem(IDC_cancelation);
bt_save=GetDlgItem(IDC_save);
tx_exhibitDate->EnableWindow(false);
tx_chargePerson->EnableWindow(false);
tx_exhibitProject->EnableWindow(false);
tx_address->EnableWindow(false);
tx_summary->EnableWindow(false);
tx_projectExhibitID->EnableWindow(false);
if(is_search==0)
{
bt_add->EnableWindow(true);
bt_delete->EnableWindow(false);
bt_modify->EnableWindow(false);
bt_cancelation->EnableWindow(false);
bt_save->EnableWindow(false);
}
else if(is_search==1)
{
CProjectExhibit projectExhibit;
projectExhibit.GetData(m_projectExhibitID);
m_exhibitDate = projectExhibit.GetExhibitDate();
m_chargePerson = projectExhibit.GetChargePerson();
m_exhibitProject = projectExhibit.GetExhibitProject();
m_address = projectExhibit.GetAddress();
m_summary = projectExhibit.GetSummary();
bt_add->EnableWindow(true);
bt_delete->EnableWindow(true);
bt_modify->EnableWindow(true);
bt_cancelation->EnableWindow(false);
bt_save->EnableWindow(false);
}
UpdateData(false);
return TRUE; // return TRUE unless you set the focus to a control
// EXCEPTION: OCX Property Pages should return FALSE
}
void CProjectExhibitForm::OnClickList1(NMHDR* pNMHDR, LRESULT* pResult)
{
UpdateData(true);
POSITION pos = m_list.GetFirstSelectedItemPosition();
if(pos)
{
int nFirstSelItem = m_list.GetNextSelectedItem(pos);
m_projectExhibitID=m_list.GetItemText(nFirstSelItem,0);
}
CProjectExhibit projectExhibit;
projectExhibit.GetData(m_projectExhibitID);
m_exhibitDate = projectExhibit.GetExhibitDate();
m_chargePerson = projectExhibit.GetChargePerson();
m_exhibitProject = projectExhibit.GetExhibitProject();
m_address = projectExhibit.GetAddress();
m_summary = projectExhibit.GetSummary();
tx_exhibitDate->EnableWindow(false);
tx_chargePerson->EnableWindow(false);
tx_exhibitProject->EnableWindow(false);
tx_address->EnableWindow(false);
tx_summary->EnableWindow(false);
tx_projectExhibitID->EnableWindow(false);
bt_add->EnableWindow(true);
bt_delete->EnableWindow(true);
bt_modify->EnableWindow(true);
bt_cancelation->EnableWindow(false);
bt_save->EnableWindow(false);
UpdateData(false);
*pResult = 0;
}
void CProjectExhibitForm::Refresh()
{
m_list.DeleteAllItems();
CString strSQL;
_RecordsetPtr m_pRecordset;
HRESULT hTRes;
strSQL="select * from projectExhibit ";
hTRes = m_pRecordset.CreateInstance(_T("ADODB.Recordset"));
hTRes = m_pRecordset->Open((LPTSTR)strSQL.GetBuffer(130),
((CClientRelationshipApp*)AfxGetApp())->m_pConn.GetInterfacePtr(),
adOpenDynamic,adLockPessimistic,adCmdText);
CString str;
int i=0;
while(!(m_pRecordset->adoEOF))
{
m_list.InsertItem(i,((CClientRelationshipApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("projectExhibitID")));
COleDateTime exhibitDate= m_pRecordset->GetCollect("exhibitDate");
str.Format("%d-%d-%d",exhibitDate.GetYear(),exhibitDate.GetMonth(),exhibitDate.GetDay());
m_list.SetItemText(i,1,str);
m_list.SetItemText(i,2, ((CClientRelationshipApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("chargePerson")));
m_list.SetItemText(i,3, ((CClientRelationshipApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("exhibitProject")));
m_list.SetItemText(i,4, ((CClientRelationshipApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("address")));
m_list.SetItemText(i,5, ((CClientRelationshipApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("summary")));
m_pRecordset->MoveNext();
i++;
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -