OrderListUI.cpp 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. #include "../pch/pch.h"
  2. #include "OrderListUI.h"
  3. #include "CWaimaiOrderItemUI.h"
  4. #include "ControlEx.h"
  5. void OrderListUI::Refresh()
  6. {
  7. std::string url;
  8. if (m_status == 1)
  9. {
  10. url = "/waimaiorder/getopenlist";
  11. }
  12. else if (m_status == 2)
  13. {
  14. url = "/waimaiorder/getconfirmedlist";
  15. }
  16. else if (m_status == 3)
  17. {
  18. url = "/waimaiorder/getdeliverylist";
  19. }
  20. else if (m_status == 4)
  21. {
  22. url = "/waimaiorder/getsucceededlist";
  23. }
  24. else if (m_status == 5)
  25. {
  26. url = "/waimaiorder/getfailedlist";
  27. }
  28. else if (m_status == 6)
  29. {
  30. url = "/waimaiorder/getrefundlist";
  31. }
  32. //请求外卖的未处理订单,直接用当前的page值去请求
  33. std::map<string, string> params;
  34. params["page"] = to_string(m_page);
  35. std::string response;
  36. CZhipuziHttpClient::RequestOld(url.c_str(), params, response);
  37. //请求成功之后,清空之前的数据
  38. this->RemoveAll();
  39. rapidjson::Document document;
  40. document.Parse(response.c_str());
  41. if (document.HasParseError())
  42. {
  43. LOG_INFO("parse response error!");
  44. return;
  45. }
  46. if (!document.HasMember("errcode") || !document.HasMember("errmsg") || !document.HasMember("data"))
  47. {
  48. LOG_INFO("json error!");
  49. return;
  50. }
  51. rapidjson::Value& v_errcode = document["errcode"];
  52. int errcode = v_errcode.GetInt();
  53. if (errcode != 0)
  54. {
  55. LOG_INFO("response failed! message:" << document["errmsg"].GetString());
  56. return;
  57. }
  58. //获得数据成功
  59. rapidjson::Value& data = document["data"];
  60. rapidjson::Value& v_count = data["count"];
  61. string count = v_count.GetString();
  62. //处理页数
  63. int nCount = atoi(count.c_str());
  64. m_total_page = (int)ceil(nCount / 20.0);
  65. if (m_total_page < 1)
  66. {
  67. m_total_page = 1;
  68. }
  69. if (m_page <= 1)
  70. {
  71. m_page = 1;
  72. CButtonUI* pControl = static_cast<CButtonUI*>(m_pManager->FindControl(_T("waimai_order_list_last")));
  73. pControl->SetEnabled(false);
  74. }
  75. if (m_page >= m_total_page)
  76. {
  77. m_page = m_total_page;
  78. CButtonUI* pControl = static_cast<CButtonUI*>(m_pManager->FindControl(_T("waimai_order_list_next")));
  79. pControl->SetEnabled(false);
  80. }
  81. CLabelUI* pControl = static_cast<CLabelUI*>(m_pManager->FindControl(_T("waimai_order_list_page")));
  82. wstring pageinfo = _T("第 ") + CLewaimaiString::ANSIToUnicode(to_string(m_page)) + _T("页/共 ") + CLewaimaiString::ANSIToUnicode(to_string(m_total_page)) + _T("页");
  83. pControl->SetText(pageinfo.c_str());
  84. rapidjson::Value& v_rows = data["rows"];
  85. for (rapidjson::SizeType i = 0; i < v_rows.Size(); ++i)
  86. {
  87. rapidjson::Value& v_row_i = v_rows[i];
  88. //创建一个对象
  89. CDialogBuilder builder;
  90. CDialogBuilderCallbackEx cb;
  91. CWaimaiOrderItemUI* pDesk = static_cast<CWaimaiOrderItemUI*>(builder.Create(_T("desk.xml"), (UINT)0, &cb, m_pManager));
  92. if (pDesk != NULL)
  93. {
  94. //初始化该对应的数据
  95. pDesk->SetData(v_row_i);
  96. this->Add(pDesk);
  97. pDesk = NULL;
  98. }
  99. }
  100. //重置滚动条的位置
  101. tagSIZE size;
  102. size.cx = 0;
  103. size.cy = 0;
  104. this->SetScrollPos(size);
  105. }
  106. void OrderListUI::LastPage()
  107. {
  108. m_page--;
  109. if (m_page < 1)
  110. {
  111. m_page = 1;
  112. }
  113. if (m_page == 1)
  114. {
  115. CButtonUI* pControl = static_cast<CButtonUI*>(m_pManager->FindControl(_T("waimai_order_list_last")));
  116. pControl->SetEnabled(false);
  117. }
  118. Refresh();
  119. }
  120. void OrderListUI::NextPage()
  121. {
  122. m_page++;
  123. if (m_page > m_total_page)
  124. {
  125. m_page = m_total_page;
  126. }
  127. if (m_page == m_total_page)
  128. {
  129. CButtonUI* pControl = static_cast<CButtonUI*>(m_pManager->FindControl(_T("waimai_order_list_next")));
  130. pControl->SetEnabled(false);
  131. }
  132. Refresh();
  133. }
  134. void OrderListUI::DoEvent(TEventUI& event)
  135. {
  136. if (!IsMouseEnabled() && event.Type > UIEVENT__MOUSEBEGIN && event.Type < UIEVENT__MOUSEEND)
  137. {
  138. if (m_pParent != NULL)
  139. {
  140. m_pParent->DoEvent(event);
  141. }
  142. else
  143. {
  144. CTileLayoutUI::DoEvent(event);
  145. }
  146. return;
  147. }
  148. if (event.Type == UIEVENT_TIMER && event.wParam == SCROLL_TIMERID)
  149. {
  150. if ((m_uButtonState & UISTATE_CAPTURED) != 0)
  151. {
  152. POINT pt = m_pManager->GetMousePos();
  153. LONG cy = (pt.y - m_ptLastMouse.y);
  154. m_ptLastMouse = pt;
  155. SIZE sz = GetScrollPos();
  156. sz.cy -= cy;
  157. SetScrollPos(sz);
  158. return;
  159. }
  160. else if (m_dwDelayLeft > 0)
  161. {
  162. --m_dwDelayLeft;
  163. SIZE sz = GetScrollPos();
  164. LONG lDeltaY = (LONG)(CalculateDelay((double)m_dwDelayLeft / m_dwDelayNum) * m_dwDelayDeltaY);
  165. if ((lDeltaY > 0 && sz.cy != 0) || (lDeltaY < 0 && sz.cy != GetScrollRange().cy))
  166. {
  167. sz.cy -= lDeltaY;
  168. SetScrollPos(sz);
  169. return;
  170. }
  171. }
  172. m_dwDelayDeltaY = 0;
  173. m_dwDelayNum = 0;
  174. m_dwDelayLeft = 0;
  175. m_pManager->KillTimer(this, SCROLL_TIMERID);
  176. return;
  177. }
  178. if (event.Type == UIEVENT_BUTTONDOWN && IsEnabled())
  179. {
  180. m_uButtonState |= UISTATE_CAPTURED;
  181. m_ptLastMouse = event.ptMouse;
  182. m_dwDelayDeltaY = 0;
  183. m_dwDelayNum = 0;
  184. m_dwDelayLeft = 0;
  185. ::SetCursor(::LoadCursor(NULL, MAKEINTRESOURCE(IDC_HAND)));
  186. m_pManager->SetTimer(this, SCROLL_TIMERID, 50U);
  187. return;
  188. }
  189. if (event.Type == UIEVENT_BUTTONUP)
  190. {
  191. if ((m_uButtonState & UISTATE_CAPTURED) != 0)
  192. {
  193. m_uButtonState &= ~UISTATE_CAPTURED;
  194. ::SetCursor(::LoadCursor(NULL, MAKEINTRESOURCE(IDC_ARROW)));
  195. if (m_ptLastMouse.y != event.ptMouse.y)
  196. {
  197. m_dwDelayDeltaY = (event.ptMouse.y - m_ptLastMouse.y);
  198. if (m_dwDelayDeltaY > 120)
  199. {
  200. m_dwDelayDeltaY = 120;
  201. }
  202. else if (m_dwDelayDeltaY < -120)
  203. {
  204. m_dwDelayDeltaY = -120;
  205. }
  206. m_dwDelayNum = (DWORD)sqrt((double)abs(m_dwDelayDeltaY)) * 5;
  207. m_dwDelayLeft = m_dwDelayNum;
  208. }
  209. else
  210. {
  211. m_pManager->KillTimer(this, SCROLL_TIMERID);
  212. }
  213. }
  214. return;
  215. }
  216. if (event.Type == UIEVENT_SCROLLWHEEL)
  217. {
  218. LONG lDeltaY = 0;
  219. if (m_dwDelayNum > 0)
  220. {
  221. lDeltaY = (LONG)(CalculateDelay((double)m_dwDelayLeft / m_dwDelayNum) * m_dwDelayDeltaY);
  222. }
  223. switch (LOWORD(event.wParam))
  224. {
  225. case SB_LINEUP:
  226. if (m_dwDelayDeltaY >= 0)
  227. {
  228. m_dwDelayDeltaY = lDeltaY + 8;
  229. }
  230. else
  231. {
  232. m_dwDelayDeltaY = lDeltaY + 12;
  233. }
  234. break;
  235. case SB_LINEDOWN:
  236. if (m_dwDelayDeltaY <= 0)
  237. {
  238. m_dwDelayDeltaY = lDeltaY - 8;
  239. }
  240. else
  241. {
  242. m_dwDelayDeltaY = lDeltaY - 12;
  243. }
  244. break;
  245. }
  246. if (m_dwDelayDeltaY > 100)
  247. {
  248. m_dwDelayDeltaY = 100;
  249. }
  250. else if (m_dwDelayDeltaY < -100)
  251. {
  252. m_dwDelayDeltaY = -100;
  253. }
  254. m_dwDelayNum = (DWORD)sqrt((double)abs(m_dwDelayDeltaY)) * 5;
  255. m_dwDelayLeft = m_dwDelayNum;
  256. m_pManager->SetTimer(this, SCROLL_TIMERID, 50U);
  257. return;
  258. }
  259. CTileLayoutUI::DoEvent(event);
  260. }