SetPathDlg.cpp 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  1. // SetPathDlg.cpp : implementation file
  2. //
  3. #include "stdafx.h"
  4. #include "LYFZSendMsg.h"
  5. #include "SetPathDlg.h"
  6. #include "mysqldata.h"
  7. #ifdef _DEBUG
  8. #define new DEBUG_NEW
  9. #undef THIS_FILE
  10. static char THIS_FILE[] = __FILE__;
  11. #endif
  12. extern BOOL g_bLoadroad2clientarray;
  13. /////////////////////////////////////////////////////////////////////////////
  14. // SetPathDlg dialog IDC_psw
  15. SetPathDlg::SetPathDlg(CWnd* pParent /*=NULL*/)
  16. : CDialog(SetPathDlg::IDD, pParent)
  17. {
  18. //{{AFX_DATA_INIT(SetPathDlg)
  19. m_account = _T("");
  20. m_addr = _T("");
  21. m_name = _T("");
  22. m_phone = _T("");
  23. m_psw = _T("");
  24. m_qq = _T("");
  25. m_remark = _T("");
  26. m_signname = _T("【】");
  27. m_mode=0;
  28. m_check1 = 0;
  29. m_check2 = 0;
  30. //}}AFX_DATA_INIT
  31. }
  32. void SetPathDlg::DoDataExchange(CDataExchange* pDX)
  33. {
  34. CDialog::DoDataExchange(pDX);
  35. //{{AFX_DATA_MAP(SetPathDlg)
  36. DDX_Text(pDX, IDC_account, m_account);
  37. DDX_Text(pDX, IDC_addr, m_addr);
  38. DDX_Text(pDX, IDC_name, m_name);
  39. DDX_Text(pDX, IDC_phone, m_phone);
  40. DDX_Text(pDX, IDC_psw, m_psw);
  41. DDX_Text(pDX, IDC_qq, m_qq);
  42. DDX_Text(pDX, IDC_remark, m_remark);
  43. DDX_Text(pDX, IDC_signname, m_signname);
  44. DDX_Check(pDX, IDC_CHECK1, m_check1);
  45. DDX_Check(pDX, IDC_CHECK2, m_check2);
  46. //}}AFX_DATA_MAP
  47. }
  48. BEGIN_MESSAGE_MAP(SetPathDlg, CDialog)
  49. //{{AFX_MSG_MAP(SetPathDlg)
  50. //}}AFX_MSG_MAP
  51. ON_BN_CLICKED(IDC_CHECK1, OnBnClickedCheck1)
  52. ON_BN_CLICKED(IDC_CHECK2, OnBnClickedCheck2)
  53. ON_BN_CLICKED(IDOK, OnBnClickedOk)
  54. END_MESSAGE_MAP()
  55. /////////////////////////////////////////////////////////////////////////////
  56. // SetPathDlg message handlers
  57. BOOL SetPathDlg::OnInitDialog()
  58. {
  59. CDialog::OnInitDialog();
  60. // TODO: Add extra initialization here
  61. if(m_mode==1)
  62. {
  63. SetWindowText("客户资料修改");
  64. MyLock lock("xiaoaccessdbmsg");
  65. CRstClientInfo rsSt;
  66. rsSt.m_strFilter ="account='"+m_account+"'";
  67. rsSt.Open();
  68. if(!rsSt.IsEOF())
  69. {
  70. m_name=rsSt.m_name ;
  71. m_phone=rsSt.m_phone ;
  72. m_qq=rsSt.m_qq ;
  73. m_addr=rsSt.m_addr ;
  74. m_remark=rsSt.m_remark ;
  75. m_psw=rsSt.m_psw;
  76. m_signname=rsSt.m_signname;
  77. if(atoi(rsSt.m_road)==1)
  78. m_check1=1;
  79. if(atoi(rsSt.m_road)==2)
  80. m_check2=1;
  81. }
  82. rsSt.Close();
  83. if(m_signname=="")m_signname = _T("【】");
  84. }
  85. else
  86. {
  87. CString account;
  88. while( IsAccountExist(account) || account.IsEmpty () )
  89. {
  90. while(account.GetLength ()<6)
  91. {
  92. CString temp;
  93. temp.Format ("%d", ::GetTickCount ());
  94. account+=temp;
  95. }
  96. account=account.Right (6);
  97. }
  98. m_account=account;
  99. }
  100. UpdateData(false);
  101. CenterWindow(g_pMainWnd);
  102. return TRUE; // return TRUE unless you set the focus to a control
  103. // EXCEPTION: OCX Property Pages should return FALSE
  104. }
  105. extern int CheckPhoneType(CString phoneno);
  106. void SetPathDlg::OnOK()
  107. {
  108. // TODO: Add extra validation here
  109. UpdateData();
  110. m_account.TrimLeft ();
  111. m_account.TrimRight ();
  112. m_name.TrimLeft ();
  113. m_name.TrimRight ();
  114. m_signname.TrimLeft ();
  115. m_signname.TrimRight ();
  116. if(m_account.IsEmpty ()||m_name.IsEmpty ()||m_psw.IsEmpty ())
  117. {
  118. AfxMessageBox("*号项目为必填项目!");
  119. return;
  120. }
  121. if(m_signname.GetLength ()<4)
  122. {
  123. m_signname="【】";
  124. AfxMessageBox("签名不合规范!");
  125. UpdateData(0);
  126. return;
  127. }
  128. if(m_signname.Left (2)!="【" || m_signname.Right (2)!="】")
  129. {
  130. m_signname="【】";
  131. AfxMessageBox("签名不合规范!");
  132. UpdateData(0);
  133. return;
  134. }
  135. CString sql;
  136. CString road="0";
  137. if(m_check1)
  138. road="1";
  139. if(m_check2)
  140. road="2";
  141. if(m_mode==0)
  142. {
  143. if(IsAccountExist(m_account))
  144. {
  145. AfxMessageBox("此账号已存在!");
  146. return;
  147. }
  148. CString date=CTime::GetCurrentTime ().Format ("%Y-%m-%d");
  149. sql= "insert into clientinfo([account],[name],[psw],[phone],\
  150. [qq],[addr],[remark],[applydate],[balance],[signname],[road]) values(\
  151. '"+m_account+"',\
  152. '"+m_name+"',\
  153. '"+m_psw+"',\
  154. '"+m_phone+"',\
  155. '"+m_qq+"',\
  156. '"+m_addr+"',\
  157. '"+m_remark+"',\
  158. '"+date+"','0','"+m_signname+"','"+road+"')";
  159. }
  160. else
  161. {
  162. sql= "update clientinfo set [name]='"+m_name+"',[phone]='"+m_phone+"',\
  163. [qq]='"+m_qq+"',[addr]='"+m_addr+"',[psw]='"+m_psw+"',[remark]='"+m_remark+"',[signname]='"+m_signname+"',[road]='"+road+"' \
  164. where [account]='"+m_account+"'";
  165. }
  166. MyExecuteSQL(&g_db, sql);
  167. if(m_check1)g_bLoadroad2clientarray=1;
  168. if(m_check2)g_bLoadroad2clientarray=1;
  169. AfxMessageBox("保存成功!", MB_ICONINFORMATION);
  170. CDialog::OnOK();
  171. }
  172. BOOL SetPathDlg::IsAccountExist(CString account)
  173. {
  174. MyLock lock("xiaoaccessdbmsg");
  175. CRecordset myset(&g_db);
  176. CString sql="select count(*) as cot from clientinfo where [account]='"+account+"'";
  177. myset.Open (CRecordset::forwardOnly, sql);
  178. myset.GetFieldValue ("cot", sql);
  179. myset.Close();
  180. if(atoi(sql))return 1;
  181. return 0;
  182. }
  183. void SetPathDlg::OnBnClickedCheck1()
  184. {
  185. // TODO: 在此添加控件通知处理程序代码
  186. UpdateData();
  187. if(m_check1 && m_check2)
  188. {
  189. m_check2=0;
  190. UpdateData(0);
  191. }
  192. }
  193. void SetPathDlg::OnBnClickedCheck2()
  194. {
  195. // TODO: 在此添加控件通知处理程序代码
  196. UpdateData();
  197. if(m_check1 && m_check2)
  198. {
  199. m_check1=0;
  200. UpdateData(0);
  201. }
  202. }
  203. void SetPathDlg::OnBnClickedOk()
  204. {
  205. // TODO: 在此添加控件通知处理程序代码
  206. OnOK();
  207. }