📄 materialoutputform.cpp
字号:
// MaterialOutputForm.cpp : implementation file
//
#include "stdafx.h"
#include "Store.h"
#include "MaterialOutputForm.h"
#include "SelectMaterial.h"
#include "Affirm.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CMaterialOutputForm dialog
CMaterialOutputForm::CMaterialOutputForm(CWnd* pParent /*=NULL*/)
: CDialog(CMaterialOutputForm::IDD, pParent)
{
//{{AFX_DATA_INIT(CMaterialOutputForm)
m_materialGetID = _T("");
m_storeHouse = _T("");
m_materialOutputFormID = _T("");
m_department = _T("");
m_dealer = _T("");
m_projectID = _T("");
m_projectName = _T("");
m_houseOutType = _T("");
m_formDate = COleDateTime::GetCurrentTime();
m_remark = _T("");
is_search=0;
flag=1;
//}}AFX_DATA_INIT
}
void CMaterialOutputForm::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CMaterialOutputForm)
DDX_Control(pDX, IDC_houseOutType, m_houseOutTypeCombo);
DDX_Control(pDX, IDC_projectName, m_projectNameCombo);
DDX_Control(pDX, IDC_projectID, m_projectIDCombo);
DDX_Control(pDX, IDC_dealer, m_dealerCombo);
DDX_Control(pDX, IDC_department, m_departmentCombo);
DDX_Control(pDX, IDC_storeHouse, m_storeHouseCombo);
DDX_Control(pDX, IDC_materialGetID, m_materialGetIDCombo);
DDX_Control(pDX, IDC_LIST1, m_list);
DDX_CBString(pDX, IDC_materialGetID, m_materialGetID);
DDX_CBString(pDX, IDC_storeHouse, m_storeHouse);
DDX_Text(pDX, IDC_materialOutputFormID, m_materialOutputFormID);
DDX_CBString(pDX, IDC_department, m_department);
DDX_CBString(pDX, IDC_dealer, m_dealer);
DDX_CBString(pDX, IDC_projectID, m_projectID);
DDX_CBString(pDX, IDC_projectName, m_projectName);
DDX_CBString(pDX, IDC_houseOutType, m_houseOutType);
DDX_DateTimeCtrl(pDX, IDC_formDate, m_formDate);
DDX_Text(pDX, IDC_remark, m_remark);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CMaterialOutputForm, CDialog)
//{{AFX_MSG_MAP(CMaterialOutputForm)
ON_NOTIFY(NM_CLICK, IDC_LIST1, OnClickList)
ON_BN_CLICKED(IDC_add, OnAdd)
ON_BN_CLICKED(IDC_modify, OnModify)
ON_BN_CLICKED(IDC_delete, OnDelete)
ON_BN_CLICKED(IDC_addLine, OnAddLine)
ON_BN_CLICKED(IDC_deleteLine, OnDeleteLine)
ON_BN_CLICKED(IDC_save, OnSave)
ON_BN_CLICKED(IDC_cancelation, OnCancelation)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CMaterialOutputForm message handlers
BOOL CMaterialOutputForm::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);
m_list.InsertColumn(6,"金额",LVCFMT_LEFT,100);
CWnd* tx_materialOutputFormID;
tx_materialOutputFormID=GetDlgItem(IDC_materialOutputFormID);
tx_materialOutputFormID->EnableWindow(false);
bt_add=GetDlgItem(IDC_add);
bt_delete=GetDlgItem(IDC_delete);
bt_modify=GetDlgItem(IDC_modify);
bt_addLine=GetDlgItem(IDC_addLine);
bt_deleteLine=GetDlgItem(IDC_deleteLine);
bt_save=GetDlgItem(IDC_save);
bt_cancelation=GetDlgItem(IDC_cancelation);
tx_materialGetID=GetDlgItem(IDC_materialGetID);
tx_storeHouse=GetDlgItem(IDC_storeHouse);
tx_department=GetDlgItem(IDC_department);
tx_dealer=GetDlgItem(IDC_dealer);
tx_projectID=GetDlgItem(IDC_projectID);
tx_projectName=GetDlgItem(IDC_projectName);
tx_houseOutType=GetDlgItem(IDC_houseOutType);
tx_formDate=GetDlgItem(IDC_formDate);
tx_remark=GetDlgItem(IDC_remark);
HRESULT hTRes;
_RecordsetPtr m_pRecordset;
CString strSQL;
strSQL="select distinct staffName from staff";
hTRes = m_pRecordset.CreateInstance(_T("ADODB.Recordset"));
if (SUCCEEDED(hTRes))
{
//----------------------------------------------------
hTRes = m_pRecordset->Open((LPTSTR)strSQL.GetBuffer(130),
((CStoreApp*)AfxGetApp())->m_pConn.GetInterfacePtr(),
adOpenDynamic,adLockPessimistic,adCmdText);
if(SUCCEEDED(hTRes))
{
while(!(m_pRecordset->adoEOF))
{
m_dealerCombo.AddString(((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("staffName")));
m_pRecordset->MoveNext();
}
}
}
m_pRecordset->Close();
strSQL="select distinct departmentName from department";
hTRes = m_pRecordset.CreateInstance(_T("ADODB.Recordset"));
if (SUCCEEDED(hTRes))
{
//----------------------------------------------------
hTRes = m_pRecordset->Open((LPTSTR)strSQL.GetBuffer(130),
((CStoreApp*)AfxGetApp())->m_pConn.GetInterfacePtr(),
adOpenDynamic,adLockPessimistic,adCmdText);
if(SUCCEEDED(hTRes))
{
while(!(m_pRecordset->adoEOF))
{
m_departmentCombo.AddString(((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("departmentName")));
m_pRecordset->MoveNext();
}
}
}
m_pRecordset->Close();
strSQL="select distinct houseOutTypeName from houseOutType";
hTRes = m_pRecordset.CreateInstance(_T("ADODB.Recordset"));
if (SUCCEEDED(hTRes))
{
//----------------------------------------------------
hTRes = m_pRecordset->Open((LPTSTR)strSQL.GetBuffer(130),
((CStoreApp*)AfxGetApp())->m_pConn.GetInterfacePtr(),
adOpenDynamic,adLockPessimistic,adCmdText);
if(SUCCEEDED(hTRes))
{
while(!(m_pRecordset->adoEOF))
{
m_houseOutTypeCombo.AddString(((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("houseOutTypeName")));
m_pRecordset->MoveNext();
}
}
}
m_pRecordset->Close();
strSQL="select distinct projectName from project";
hTRes = m_pRecordset.CreateInstance(_T("ADODB.Recordset"));
if (SUCCEEDED(hTRes))
{
//----------------------------------------------------
hTRes = m_pRecordset->Open((LPTSTR)strSQL.GetBuffer(130),
((CStoreApp*)AfxGetApp())->m_pConn.GetInterfacePtr(),
adOpenDynamic,adLockPessimistic,adCmdText);
if(SUCCEEDED(hTRes))
{
while(!(m_pRecordset->adoEOF))
{
m_projectNameCombo.AddString(((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("projectName")));
m_pRecordset->MoveNext();
}
}
}
m_pRecordset->Close();
strSQL="select distinct storeHouseName from storeHouse";
hTRes = m_pRecordset.CreateInstance(_T("ADODB.Recordset"));
if (SUCCEEDED(hTRes))
{
//----------------------------------------------------
hTRes = m_pRecordset->Open((LPTSTR)strSQL.GetBuffer(130),
((CStoreApp*)AfxGetApp())->m_pConn.GetInterfacePtr(),
adOpenDynamic,adLockPessimistic,adCmdText);
if(SUCCEEDED(hTRes))
{
while(!(m_pRecordset->adoEOF))
{
m_storeHouseCombo.AddString(((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("storeHouseName")));
m_pRecordset->MoveNext();
}
}
}
m_pRecordset->Close();
if(is_search==1)
{
bt_add->EnableWindow(true);
bt_delete->EnableWindow(true);
bt_modify->EnableWindow(true);
bt_addLine->EnableWindow(false);
bt_deleteLine->EnableWindow(false);
bt_save->EnableWindow(false);
bt_cancelation->EnableWindow(false);
CString strSQL;
_RecordsetPtr m_pRecordset; //用于创建一个查询记录集
_RecordsetPtr m_pMaterialOutputFormRecordset;
strSQL="select * from materialOutputForm where materialOutputFormID='";
strSQL=strSQL+m_materialOutputFormID+"'";
HRESULT hTRes;
hTRes = m_pMaterialOutputFormRecordset.CreateInstance(_T("ADODB.Recordset"));
hTRes = m_pMaterialOutputFormRecordset->Open((LPTSTR)strSQL.GetBuffer(130),
((CStoreApp*)AfxGetApp())->m_pConn.GetInterfacePtr(),
adOpenDynamic,adLockPessimistic,adCmdText);
if(!(m_pMaterialOutputFormRecordset->adoEOF))
{
DATE dt;
COleDateTime da;
dt=m_pMaterialOutputFormRecordset->GetCollect("formDate").date;
da=COleDateTime(dt);
m_formDate.SetDate(da.GetYear(),da.GetMonth(),da.GetDay());
m_materialGetID = ((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pMaterialOutputFormRecordset->GetCollect("materialReceiveFormID"));
m_storeHouse = ((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pMaterialOutputFormRecordset->GetCollect("storeHouse"));
m_department = ((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pMaterialOutputFormRecordset->GetCollect("receiveDepartment"));
m_dealer = ((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pMaterialOutputFormRecordset->GetCollect("dealer"));
m_projectID = ((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pMaterialOutputFormRecordset->GetCollect("projectID"));
m_projectName = ((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pMaterialOutputFormRecordset->GetCollect("projectName"));
m_houseOutType = ((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pMaterialOutputFormRecordset->GetCollect("houseOutputType"));
m_remark = ((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pMaterialOutputFormRecordset->GetCollect("remark"));
strSQL="select * from materialOutputFormView where materialOutputFormID='";
strSQL=strSQL+m_materialOutputFormID+"'";
hTRes = m_pRecordset.CreateInstance(_T("ADODB.Recordset"));
hTRes = m_pRecordset->Open((LPTSTR)strSQL.GetBuffer(130),
((CStoreApp*)AfxGetApp())->m_pConn.GetInterfacePtr(),
adOpenDynamic,adLockPessimistic,adCmdText);
int i=0;
while(!(m_pRecordset->adoEOF))
{
m_list.InsertItem(i,((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("materialID")));
m_list.SetItemText(i,1,((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("materialName")));
m_list.SetItemText(i,2,((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("unit")));
m_list.SetItemText(i,3,((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("model")));
m_list.SetItemText(i,4,((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("num")));
m_list.SetItemText(i,5,((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("price")));
m_list.SetItemText(i,6,((CStoreApp*)AfxGetApp())->GetStringFromVariant(m_pRecordset->GetCollect("total")));
i++;
m_pRecordset->MoveNext();
}
}
tx_materialGetID->EnableWindow(false);
tx_storeHouse->EnableWindow(false);
tx_department->EnableWindow(false);
tx_dealer->EnableWindow(false);
tx_projectID->EnableWindow(false);
tx_projectName->EnableWindow(false);
tx_houseOutType->EnableWindow(false);
tx_formDate->EnableWindow(false);
tx_remark->EnableWindow(false);
}
else
{
bt_add->EnableWindow(false);
bt_delete->EnableWindow(false);
bt_modify->EnableWindow(false);
bt_addLine->EnableWindow(true);
bt_deleteLine->EnableWindow(true);
bt_save->EnableWindow(true);
bt_cancelation->EnableWindow(true);
tx_materialGetID->EnableWindow(true);
tx_storeHouse->EnableWindow(true);
tx_department->EnableWindow(true);
tx_dealer->EnableWindow(true);
tx_projectID->EnableWindow(true);
tx_projectName->EnableWindow(true);
tx_houseOutType->EnableWindow(true);
tx_formDate->EnableWindow(true);
tx_remark->EnableWindow(true);
int formID=((CStoreApp*)AfxGetApp())->m_pIDRecordset->GetCollect("materialOutputFormID").intVal;
if(formID<10)
m_materialOutputFormID.Format("CLCK0000%d",formID);
else if(formID<100&&formID>9)
m_materialOutputFormID.Format("CLCK000%d",formID);
else if(formID<1000&&formID>99)
m_materialOutputFormID.Format("CLCK00%d",formID);
CString str;
str.Format("%d",formID+1);
((CStoreApp*)AfxGetApp())->m_pIDRecordset->PutCollect("materialOutputFormID",_variant_t(str));
((CStoreApp*)AfxGetApp())->m_pIDRecordset->Update();
}
UpdateData(false);
return TRUE; // return TRUE unless you set the focus to a control
// EXCEPTION: OCX Property Pages should return FALSE
}
void CMaterialOutputForm::OnClickList(NMHDR* pNMHDR, LRESULT* pResult)
{
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -