ShangPin.cpp 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351
  1. // ShangPin.cpp : implementation file
  2. //
  3. #include "stdafx.h"
  4. #include "LYFZIPManage.h"
  5. #include "ShangPin.h"
  6. #include "MyMdi.H"
  7. #ifdef _DEBUG
  8. #define new DEBUG_NEW
  9. #undef THIS_FILE
  10. static char THIS_FILE[] = __FILE__;
  11. #endif
  12. /////////////////////////////////////////////////////////////////////////////
  13. // ShangPin
  14. IMPLEMENT_DYNCREATE(ShangPin, CFormView)
  15. ShangPin::ShangPin()
  16. : CFormView(ShangPin::IDD)
  17. {
  18. //{{AFX_DATA_INIT(ShangPin)
  19. m_spbz = _T("");
  20. m_spdanwei = _T("");
  21. m_spid = _T("");
  22. m_spjiaga1 = _T("");
  23. m_spjiage2 = _T("");
  24. m_spname = _T("");
  25. m_autoid=0;
  26. //}}AFX_DATA_INIT
  27. }
  28. ShangPin::~ShangPin()
  29. {
  30. }
  31. void ShangPin::DoDataExchange(CDataExchange* pDX)
  32. {
  33. CFormView::DoDataExchange(pDX);
  34. //{{AFX_DATA_MAP(ShangPin)
  35. DDX_Control(pDX, IDC_EDITspjiage2, m_editctrl2);
  36. DDX_Control(pDX, IDC_EDITspjiaga1, m_editctrl1);
  37. DDX_Control(pDX, IDC_COMBOsplb, m_combosplb);
  38. DDX_Control(pDX, IDC_LIST2, m_List1);
  39. DDX_Control(pDX, IDC_STATIC1, m_static1);
  40. DDX_Text(pDX, IDC_EDITspbz, m_spbz);
  41. DDX_Text(pDX, IDC_EDITspdanwei, m_spdanwei);
  42. DDX_Text(pDX, IDC_EDITspid, m_spid);
  43. DDX_Text(pDX, IDC_EDITspjiaga1, m_spjiaga1);
  44. DDX_Text(pDX, IDC_EDITspjiage2, m_spjiage2);
  45. DDX_Text(pDX, IDC_EDITspname, m_spname);
  46. //}}AFX_DATA_MAP
  47. }
  48. BEGIN_MESSAGE_MAP(ShangPin, CFormView)
  49. //{{AFX_MSG_MAP(ShangPin)
  50. ON_BN_CLICKED(IDC_BUTsave, OnBUTsave)
  51. ON_BN_CLICKED(IDC_BUTdel, OnBUTdel)
  52. ON_BN_CLICKED(IDC_BUTclose, OnBUTclose)
  53. ON_NOTIFY(NM_CLICK, IDC_LIST2, OnClickList2)
  54. ON_BN_CLICKED(IDC_BUTadd, OnBUTadd)
  55. ON_CBN_SELCHANGE(IDC_COMBOsplb, OnSelchangeCOMBOsplb)
  56. //}}AFX_MSG_MAP
  57. END_MESSAGE_MAP()
  58. /////////////////////////////////////////////////////////////////////////////
  59. // ShangPin diagnostics
  60. #ifdef _DEBUG
  61. void ShangPin::AssertValid() const
  62. {
  63. CFormView::AssertValid();
  64. }
  65. void ShangPin::Dump(CDumpContext& dc) const
  66. {
  67. CFormView::Dump(dc);
  68. }
  69. #endif //_DEBUG
  70. /////////////////////////////////////////////////////////////////////////////
  71. // ShangPin message handlers
  72. void ShangPin::OnInitialUpdate()
  73. {
  74. CFormView::OnInitialUpdate();
  75. // TODO: Add your specialized code here and/or call the base class
  76. CMyMdi Mdi;
  77. Mdi.SetSubView((CWnd*)GetParent(), (CWnd*)this);
  78. // Here we create the outbar control using the splitter as its parent
  79. // and setting its id to the first pane.
  80. CRect rc2;
  81. GetWindowRect(rc2);
  82. ::MoveWindow(m_hWnd,g_rc.left,g_rc.top,g_rc.Width(),g_rc.Height(),TRUE);
  83. EnumChildWindows(m_hWnd,(WNDENUMPROC)EnumChildProc,0);
  84. m_combosplb.GetWindowRect (rc2);
  85. ScreenToClient(rc2);
  86. rc2.bottom +=200;
  87. m_combosplb.MoveWindow (rc2);
  88. m_static1.SetFont (&g_titlefont);
  89. m_List1.SetHeadings( "编号, 50;商品名称, 100;单位, 50;进价, 50;卖价, 50;商品分类, 100" );
  90. m_List1.LoadColumnInfo (100);
  91. g_sendhead.bsql=0;
  92. g_sendhead.code[0]=2;
  93. g_sendhead.code[1]=4;
  94. g_sendhead.tabcount=2;
  95. g_pMainWnd->ProcessChatMessageRequest2(2);if(g_bSendOK==0)return;
  96. DataToArray(&g_List1array, &m_List1array);
  97. for(int i=0; i<g_List1array.GetSize (); i++)
  98. m_combosplb.AddString (g_List1array.ElementAt (i).ElementAt (0));
  99. CString sql;
  100. sql="select max(spid) as cot from shangpin";
  101. g_sendhead.bsql=1;
  102. g_pMainWnd->ProcessChatMessageRequest2(sql);if(g_bSendOK==0)return;
  103. m_autoid=g_ncount+1;
  104. }
  105. void ShangPin::OnSelchangeCOMBOsplb()
  106. {
  107. // TODO: Add your control notification handler code here
  108. int pos=m_combosplb.GetCurSel ();
  109. if(pos==-1)return;
  110. CString str;
  111. m_combosplb.GetLBText (pos, str);
  112. FillGrid(str);
  113. }
  114. void ShangPin::FillGrid(CString str)
  115. {
  116. m_List1.DeleteAllItems2 ();
  117. int ii=0;
  118. m_List1.m_arLabels.SetSize( m_List1array.GetSize (), 1 );
  119. int count=0;
  120. for(ii=0; ii<m_List1.m_arLabels.GetSize (); ii++)
  121. {
  122. if(m_List1array.ElementAt (ii).ElementAt (5)==str)
  123. {
  124. m_List1.m_arLabels.ElementAt (count++).Copy (m_List1array.ElementAt (ii));
  125. }
  126. }
  127. m_List1.m_arLabels.SetSize(count, 1);
  128. ii=count;
  129. m_List1.m_LabelCount=ii;
  130. m_List1.SetItemCountEx (ii);
  131. OnBUTadd() ;
  132. }
  133. void ShangPin::OnBUTclose()
  134. {
  135. // TODO: Add your control notification handler code here
  136. GetParent()->SendMessage(WM_CLOSE);
  137. }
  138. void ShangPin::ClearCtrl()
  139. {
  140. m_spbz = _T("");
  141. m_spdanwei = _T("");
  142. m_spjiaga1 = _T("");
  143. m_spjiage2 = _T("");
  144. m_spname = _T("");
  145. m_spid.Format ("%d", m_autoid);
  146. UpdateData(false);
  147. }
  148. void ShangPin::OnClickList2(NMHDR* pNMHDR, LRESULT* pResult)
  149. {
  150. // TODO: Add your control notification handler code here
  151. ListSelChange();
  152. *pResult = 0;
  153. }
  154. void ShangPin::ListSelChange()
  155. {
  156. POSITION pos;
  157. pos=m_List1.GetFirstSelectedItemPosition();
  158. if(pos==NULL)
  159. {OnBUTadd();
  160. return;
  161. }
  162. int iItem=m_List1.GetNextSelectedItem(pos);
  163. m_oldspid=m_List1.GetItemText (iItem, 0);
  164. for(int ii=0; ii<m_List1array.GetSize (); ii++)
  165. {
  166. if(m_List1array.ElementAt (ii).ElementAt (0)==m_oldspid)
  167. {
  168. m_spid = m_List1array.ElementAt (ii).ElementAt (0);
  169. m_spname = m_List1array.ElementAt (ii).ElementAt (1);
  170. m_spdanwei = m_List1array.ElementAt (ii).ElementAt (2);
  171. m_spjiaga1 = m_List1array.ElementAt (ii).ElementAt (3);
  172. m_spjiage2 = m_List1array.ElementAt (ii).ElementAt (4);
  173. m_spbz = m_List1array.ElementAt (ii).ElementAt (6);
  174. UpdateData(false);
  175. return;
  176. }
  177. }
  178. }
  179. void ShangPin::OnBUTadd()
  180. {
  181. // TODO: Add your control notification handler code here
  182. m_oldspid.Empty ();
  183. ClearCtrl();
  184. }
  185. void ShangPin::OnBUTsave()
  186. {
  187. // TODO: Add your control notification handler code here
  188. UpdateData();
  189. if(m_spid.IsEmpty () || m_spname.IsEmpty () || m_spjiage2.IsEmpty ())
  190. {
  191. AfxMessageBox("资料不全!", MB_ICONINFORMATION);return;
  192. }
  193. CString sql;
  194. CString splb;
  195. int pos=m_combosplb.GetCurSel ();
  196. if(pos==-1)return;
  197. m_combosplb.GetLBText (pos, splb);
  198. if(m_oldspid.IsEmpty ())//新增
  199. {
  200. if(IsExist())
  201. {
  202. AfxMessageBox("已有此编号的商品,请重新编号", MB_ICONINFORMATION);
  203. return;
  204. }
  205. sql.Format ("insert into shangpin(spid,spname,spdanwei,spjiaga1,spjiage2,splb,spbz)\
  206. values('%s','%s','%s','%s','%s','%s','%s')", m_spid,m_spname,m_spdanwei,m_spjiaga1,m_spjiage2,splb,m_spbz);
  207. sql+=SP_REF;
  208. g_sendhead.bsql=1;
  209. g_pMainWnd->ProcessChatMessageRequest2(sql);if(g_bSendOK==0)return;
  210. GetData();
  211. OnSelchangeCOMBOsplb();
  212. m_autoid++;
  213. }
  214. else//修改
  215. {
  216. if(m_oldspid!=m_spid)
  217. {
  218. if(IsExist())
  219. {
  220. AfxMessageBox("已有此编号的商品,请重新编号", MB_ICONINFORMATION);
  221. return;
  222. }
  223. }
  224. sql.Format ("update shangpin set spid='%s',spname='%s',spdanwei='%s',spjiaga1='%s',spjiage2='%s',splb='%s',spbz='%s' where spid=%d ", m_spid,m_spname,m_spdanwei,m_spjiaga1,m_spjiage2,splb,m_spbz, atol(m_oldspid));
  225. sql+=SP_REF;
  226. g_sendhead.bsql=1;
  227. g_pMainWnd->ProcessChatMessageRequest2(sql);if(g_bSendOK==0)return;
  228. GetData();
  229. OnSelchangeCOMBOsplb();
  230. }
  231. OnBUTadd();
  232. }
  233. void ShangPin::OnBUTdel()
  234. {
  235. // TODO: Add your control notification handler code here
  236. POSITION pos;
  237. pos=m_List1.GetFirstSelectedItemPosition();
  238. if(pos==NULL)
  239. {
  240. return;
  241. }
  242. if(AfxMessageBox("确认删除吗?", MB_YESNO|MB_ICONINFORMATION)!=IDYES)return;
  243. int iItem=m_List1.GetNextSelectedItem(pos);
  244. CString id=m_List1.GetItemText (iItem, 0);
  245. CString sql;
  246. sql.Format ("delete from shangpin where spid=%d ", atol(id));
  247. sql+=SP_REF;
  248. g_sendhead.bsql=1;
  249. g_pMainWnd->ProcessChatMessageRequest2(sql);if(g_bSendOK==0)return;
  250. GetData();
  251. OnSelchangeCOMBOsplb();
  252. }
  253. void ShangPin::GetData()
  254. {
  255. g_sendhead.bsql=0;
  256. g_sendhead.code[0]=4;
  257. g_sendhead.tabcount=1;
  258. g_pMainWnd->ProcessChatMessageRequest2(4);if(g_bSendOK==0)return;
  259. DataToArray(&m_List1array);
  260. }
  261. BOOL ShangPin::IsExist()
  262. {
  263. for(int i=0; i<m_List1array.GetSize (); i++)
  264. {
  265. if(m_spid==m_List1array.ElementAt (i).ElementAt (0))return 1;
  266. }
  267. return 0;
  268. }
  269. BOOL ShangPin::PreTranslateMessage(MSG* pMsg)
  270. {
  271. // TODO: Add your specialized code here and/or call the base class
  272. try
  273. {
  274. if(pMsg->message==WM_KEYDOWN)
  275. {
  276. switch (pMsg->wParam)
  277. {
  278. case 0x43: // copy
  279. if ( ( GetKeyState( VK_CONTROL ) & 0x80 ) )
  280. {
  281. GetFocus()->SendMessage(WM_COPY);
  282. return TRUE;
  283. }
  284. break;
  285. case 0x56: //Ctrl + V:
  286. if ( ( GetKeyState( VK_CONTROL ) & 0x80 ) )
  287. {
  288. GetFocus()->SendMessage(WM_PASTE);
  289. return TRUE;
  290. }
  291. break;
  292. case 0x58: // cut
  293. if ( ( GetKeyState( VK_CONTROL ) & 0x80 ) )
  294. {
  295. GetFocus()->SendMessage(WM_CUT);
  296. return TRUE;
  297. }
  298. break;
  299. case 0x5A: //undo
  300. case 0x59: //redo
  301. if ( ( GetKeyState( VK_CONTROL ) & 0x80 ) )
  302. {
  303. GetFocus()->SendMessage(WM_UNDO);
  304. return TRUE;
  305. }
  306. break;
  307. }
  308. }
  309. return CFormView::PreTranslateMessage(pMsg);
  310. }
  311. catch(...)
  312. {
  313. }
  314. }