ClientManDlg.cpp
上传用户:fangwenmm
上传日期:2014-06-18
资源大小:6955k
文件大小:5k
源码类别:

企业管理

开发平台:

Visual C++

  1. // ClientManDlg.cpp : implementation file
  2. //
  3. #include "stdafx.h"
  4. #include "Stock.h"
  5. #include "ClientManDlg.h"
  6. #include "COMDEF.H"
  7. #include "Columns.h"
  8. #include "Column.h"
  9. #include "ClientEditDlg.h"
  10. #include "_recordset.h"
  11. #include "Client.h"
  12. #include "StoreIn.h"
  13. #include "TakeOut.h"
  14. #include "ProInStore.h"
  15. #ifdef _DEBUG
  16. #define new DEBUG_NEW
  17. #undef THIS_FILE
  18. static char THIS_FILE[] = __FILE__;
  19. #endif
  20. /////////////////////////////////////////////////////////////////////////////
  21. // CClientManDlg dialog
  22. CClientManDlg::CClientManDlg(CWnd* pParent /*=NULL*/)
  23. : CDialog(CClientManDlg::IDD, pParent)
  24. {
  25. //{{AFX_DATA_INIT(CClientManDlg)
  26. // NOTE: the ClassWizard will add member initialization here
  27. //}}AFX_DATA_INIT
  28. }
  29. void CClientManDlg::DoDataExchange(CDataExchange* pDX)
  30. {
  31. CDialog::DoDataExchange(pDX);
  32. //{{AFX_DATA_MAP(CClientManDlg)
  33. DDX_Control(pDX, IDC_CTYPE_COMBO, m_Ctype);
  34. DDX_Control(pDX, IDC_ADODC1, m_adodc);
  35. DDX_Control(pDX, IDC_DATAGRID1, m_datagrid);
  36. //}}AFX_DATA_MAP
  37. }
  38. BEGIN_MESSAGE_MAP(CClientManDlg, CDialog)
  39. //{{AFX_MSG_MAP(CClientManDlg)
  40. ON_BN_CLICKED(IDC_ADD_BUTTON, OnAddButton)
  41. ON_CBN_SELCHANGE(IDC_CTYPE_COMBO, OnSelchangeCtypeCombo)
  42. ON_BN_CLICKED(IDC_MODI_BUTTON, OnModiButton)
  43. ON_BN_CLICKED(IDC_DEL_BUTTON, OnDelButton)
  44. //}}AFX_MSG_MAP
  45. END_MESSAGE_MAP()
  46. /////////////////////////////////////////////////////////////////////////////
  47. // CClientManDlg message handlers
  48. void CClientManDlg::Refresh_Data()
  49. {
  50. UpdateData(TRUE); //将控件的值读取到成员变量中
  51. CString cSource;
  52. CString cCtype;  //读取客户类型值
  53. cCtype.Format("%d", m_Ctype.GetCurSel() + 1);
  54. //设置SELECT语句,按客户单位排序
  55. cSource = "SELECT Cid, Cname AS 客户单位, Contact AS 联系人, Address AS 通信地址,";
  56. cSource += " Postcode AS 邮政编码, Phone AS 联系电话, Fax AS 传真电话, Memo AS 备注";
  57. cSource += " FROM Client WHERE Ctype=" + cCtype + " ORDER BY Cname";
  58. m_adodc.SetRecordSource(cSource);
  59. m_adodc.Refresh();
  60. //设置表格列宽度
  61. _variant_t vIndex;
  62. vIndex = long(0);
  63. m_datagrid.GetColumns().GetItem(vIndex).SetWidth(0);
  64. }
  65. BOOL CClientManDlg::OnInitDialog() 
  66. {
  67. CDialog::OnInitDialog();
  68. // TODO: Add extra initialization here
  69. m_Ctype.SetCurSel(0);  //设置客户类型
  70. Refresh_Data();  //刷新表格中的记录集
  71. return TRUE;  // return TRUE unless you set the focus to a control
  72.               // EXCEPTION: OCX Property Pages should return FALSE
  73. }
  74. void CClientManDlg::OnAddButton() 
  75. {
  76. // TODO: Add your control notification handler code here
  77. UpdateData(TRUE);
  78. //打开编辑对话框
  79. CClientEditDlg dlg;
  80. dlg.cCid = "";
  81. dlg.iCtype = m_Ctype.GetCurSel() + 1;
  82. if (dlg.DoModal() == IDOK)
  83. Refresh_Data();
  84. }
  85. void CClientManDlg::OnSelchangeCtypeCombo() 
  86. {
  87. // TODO: Add your control notification handler code here
  88. Refresh_Data();
  89. }
  90. void CClientManDlg::OnModiButton() 
  91. {
  92. // TODO: Add your control notification handler code here
  93. if (m_adodc.GetRecordset().GetEof()) 
  94. {
  95. MessageBox("请选择要修改的记录");
  96. return;
  97. }
  98. UpdateData(TRUE);
  99. CClientEditDlg dlg;
  100. dlg.cCid = m_datagrid.GetItem(0); //记录编号
  101. dlg.iCtype = m_Ctype.GetCurSel() + 1;  //客户类型
  102. dlg.m_Cname = m_datagrid.GetItem(1); //单位名称
  103. dlg.cCname = m_datagrid.GetItem(1);
  104. dlg.m_Contact = m_datagrid.GetItem(2); //联系人
  105. dlg.m_Address = m_datagrid.GetItem(3); //通信地址
  106. dlg.m_Postcode = m_datagrid.GetItem(4); //邮政编码
  107. dlg.m_Phone = m_datagrid.GetItem(5); //联系电话
  108. dlg.m_Fax = m_datagrid.GetItem(6); //传真
  109. dlg.m_Memo = m_datagrid.GetItem(7); //备注信息
  110. if (dlg.DoModal() == IDOK)
  111. Refresh_Data();
  112. }
  113. void CClientManDlg::OnDelButton() 
  114. {
  115. // TODO: Add your control notification handler code here
  116. if (m_adodc.GetRecordset().GetEof()) 
  117. {
  118. MessageBox("请选择要删除的记录");
  119. return;
  120. }
  121. CString Cid;
  122. Cid = m_datagrid.GetItem(0);
  123. CStoreIn obj;
  124. if (obj.HaveClient(Cid) == 1) 
  125. {
  126. MessageBox("客户出现在入库单中,不能删除");
  127. return;
  128. }
  129. CTakeOut obj1;
  130. if (obj1.HaveClient(Cid) == 1)
  131. {
  132. MessageBox("客户出现在出库单中,不能删除");
  133. return;
  134. }
  135. if (MessageBox("是否删除当前记录","请确定", MB_YESNO) == IDYES)
  136. {
  137. CClient clt;
  138. clt.sql_delete(m_datagrid.GetItem(0));
  139. Refresh_Data();
  140. }
  141. }
  142. BEGIN_EVENTSINK_MAP(CClientManDlg, CDialog)
  143.     //{{AFX_EVENTSINK_MAP(CClientManDlg)
  144. ON_EVENT(CClientManDlg, IDC_ADODC1, 200 /* WillMove */, OnWillMoveAdodc1, VTS_I4 VTS_PI4 VTS_DISPATCH)
  145. //}}AFX_EVENTSINK_MAP
  146. END_EVENTSINK_MAP()
  147. void CClientManDlg::OnWillMoveAdodc1(long adReason, long FAR* adStatus, LPDISPATCH pRecordset) 
  148. {
  149. // TODO: Add your control notification handler code here
  150. }