Shop.php 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  1. <?php
  2. declare (strict_types = 1);
  3. namespace app\system\controller;
  4. use app\BaseController;
  5. use app\model\api\StoreOrder;
  6. use app\model\api\StoreOrderCartInfo;
  7. use app\Request;
  8. use library\services\UtilService;
  9. use think\facade\Db;
  10. class Shop extends BaseController
  11. {
  12. /**
  13. * 商城订单统计
  14. * @param Request $request
  15. */
  16. public function total(Request $request)
  17. {
  18. $post = UtilService::getMore([
  19. ['status', ''],
  20. ], $request);
  21. $order = Db::name('store_order');
  22. $totalWhere = [];
  23. if ($post['status'] !== '' && in_array((string)$post['status'], ["0", "1", "2", "3", "-1"])) {
  24. $totalWhere[] = ['status', '=', (int)$post['status']];
  25. }
  26. //全部
  27. $orderCount = $order->where($totalWhere)->count();
  28. //待支付
  29. $waitPayWhere = $totalWhere;
  30. $waitPayWhere[] = ['status', '=', 0];
  31. $waitPayCount = $order->where($waitPayWhere)->count();
  32. //待发货
  33. $waitSendWhere = $totalWhere;
  34. $waitSendWhere[] = ['status', '=', 1];
  35. $waitSendCount = $order->where($waitSendWhere)->count();
  36. //待收货
  37. $waitAcceptWhere = $totalWhere;
  38. $waitAcceptWhere[] = ['status', '=', 2];
  39. $waitAcceptCount = $order->where($waitAcceptWhere)->count();
  40. //已完成
  41. $okWhere = $totalWhere;
  42. $okWhere[] = ['status', '=', 3];
  43. $okCount = $order->where($okWhere)->count();
  44. //已取消
  45. $closeWhere = $totalWhere;
  46. $closeWhere[] = ['status', '=', -1];
  47. $closeCount = $order->where($closeWhere)->count();
  48. return app('json')->success([
  49. 'orderCount' => $orderCount,
  50. 'waitPayCount' => $waitPayCount,
  51. 'waitSendCount' => $waitSendCount,
  52. 'waitAcceptCount' => $waitAcceptCount,
  53. 'okCount' => $okCount,
  54. 'closeCount' => $closeCount,
  55. ]);
  56. }
  57. /**
  58. * 商城订单列表
  59. * @param Request $request
  60. */
  61. public function list(Request $request)
  62. {
  63. $pageSize = 50;
  64. $post = UtilService::getMore([
  65. ['page', 1],
  66. ['uid', 0],
  67. ['mobile', ''],
  68. ['order_id', ''],
  69. ['status', ''],
  70. ['time', []],
  71. ], $request);
  72. $where = [];
  73. if (!empty($post['uid'])) {
  74. $where[] = ['o.uid', '=', $post['uid']];
  75. } else if (!empty($post['mobile'])) {
  76. $m = Db::name('user')->where('mobile', $post['mobile'])->find();
  77. if (!empty($m)) {
  78. $where[] = ['o.uid', '=', $m['uid']];
  79. }
  80. }
  81. if (!empty($post['order_id'])) {
  82. $where[] = ['o.order_id', '=', $post['order_id']];
  83. }
  84. if ($post['status'] !== '' && in_array((string)$post['status'], ["0", "1", "2", "3", "-1"])) {
  85. $where[] = ['o.status', '=', (int)$post['status']];
  86. }
  87. //创建时间
  88. $startTime = '';
  89. $endTime = '';
  90. if (!empty($post['time'][0]) && !empty($post['time'][1])) {
  91. $startTime = strtotime($post['time'][0]);
  92. $endTime = strtotime($post['time'][1]);
  93. $where[] = ['o.time', 'between', "{$startTime},{$endTime}"];
  94. }
  95. $order = Db::name('store_order');
  96. $data = $order
  97. ->alias('o')
  98. ->field('o.*,u.mobile,u.nickname')
  99. ->leftJoin('user u', 'u.uid = o.uid')
  100. ->where($where)
  101. ->page((int)$post['page'], $pageSize)
  102. ->order('o.id', 'desc')
  103. ->select()
  104. ->toArray();
  105. $pageCount = $order->where($where)->count();
  106. $result = UtilService::getParam([
  107. 'id',
  108. 'order_id',
  109. 'uid',
  110. 'real_name',
  111. 'user_phone',
  112. 'address_id',
  113. 'user_address',
  114. // 'mobile',
  115. // 'nickname',
  116. // 'real_name',
  117. // 'tel',
  118. // 'province',
  119. // 'city',
  120. // 'district',
  121. // 'detail',
  122. 'total_price',
  123. 'pay_price',
  124. 'total_postage',
  125. 'pay_postage',
  126. 'paid',
  127. 'status',
  128. ['create_time', 'create_time', 'date("Y-m-d H:i:s",$1)'],
  129. ['pay_time', 'pay_time', function ($item) {
  130. return empty($item) ? "-" : date('Y-m-d H:i:s', $item);
  131. }],
  132. ['confirm_time', 'confirm_time', function ($item) {
  133. return empty($item) ? "-" : date('Y-m-d H:i:s', $item);
  134. }],
  135. ], $data);
  136. return app('json')->success([
  137. 'list' => $result,
  138. 'pageCount' => $pageCount,
  139. 'pageSize' => $pageSize,
  140. 'page' => $post['page'],
  141. ]);
  142. }
  143. /**
  144. * 商城订单详情
  145. * @param Request $request
  146. */
  147. public function info(Request $request)
  148. {
  149. $post = UtilService::getMore([
  150. ['id', '', 'empty', '参数错误'],
  151. ], $request);
  152. $order = Db::name('store_order')
  153. ->alias('o')
  154. ->field('o.*,u.mobile,u.nickname')
  155. ->leftJoin('user u', 'u.uid = o.uid')
  156. ->where('o.id', $post['id'])
  157. ->find();
  158. if (empty($order)) {
  159. return app('json')->fail('订单不存在');
  160. }
  161. $data = $order;
  162. //获取订单商品
  163. $cartInfo = Db::name('store_order_cart_info')
  164. ->where('oid', $data['id'])
  165. ->select()
  166. ->toArray();
  167. $data['cart_info'] = $cartInfo;
  168. return app('json')->success($data);
  169. }
  170. /**
  171. * 发货
  172. * @param Request $request
  173. */
  174. public function fahuo(Request $request)
  175. {
  176. $post = UtilService::getMore([
  177. ['id', '', 'empty', '参数错误'],
  178. ['express_type', ''],
  179. ['express_code', ''],
  180. ['express_num', ''],
  181. ], $request);
  182. $order = Db::name('store_order')
  183. ->where('id', $post['id'])
  184. ->where('status', 1)
  185. ->find();
  186. if (empty($order)) {
  187. return app('json')->fail('当前订单不可发货');
  188. }
  189. if (empty($post['express_num'])) {
  190. return app('json')->fail('请输入物流单号');
  191. }
  192. $result = Db::name('store_order')->where('id', $post['id'])->update([
  193. 'status' => 2,
  194. 'express_type' => $post['express_type'],
  195. 'express_code' => $post['express_code'],
  196. 'express_num' => $post['express_num'],
  197. 'delivery_time' => time(),
  198. ]);
  199. if ($result) {
  200. return app('json')->success('操作成功');
  201. } else {
  202. return app('json')->fail('操作失败');
  203. }
  204. }
  205. /**
  206. * 订单备注
  207. * @param Request $request
  208. */
  209. public function mono(Request $request)
  210. {
  211. $post = UtilService::getMore([
  212. ['id', '', 'empty', '参数错误'],
  213. ['remark', '', 'empty', '请输入备注内容'],
  214. ], $request);
  215. $order = Db::name('store_order')->where('id', $post['id'])->find();
  216. if (empty($order)) {
  217. return app('json')->fail('订单不存在');
  218. }
  219. $result = Db::name('store_order')->where('id', $post['id'])->update([
  220. 'remark' => $post['remark'],
  221. ]);
  222. if ($result) {
  223. return app('json')->success('操作成功');
  224. } else {
  225. return app('json')->fail('操作失败');
  226. }
  227. }
  228. }