Shop.php 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253
  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. 'mobile',
  111. 'nickname',
  112. 'real_name',
  113. 'phone',
  114. 'province',
  115. 'city',
  116. 'district',
  117. 'detail',
  118. 'total_price',
  119. 'pay_price',
  120. 'total_postage',
  121. 'pay_postage',
  122. 'paid',
  123. 'status',
  124. ['time', 'time', 'date("Y-m-d H:i:s",$1)'],
  125. ['pay_time', 'pay_time', function ($item) {
  126. return empty($item) ? "-" : date('Y-m-d H:i:s', $item);
  127. }],
  128. ['confirm_time', 'confirm_time', function ($item) {
  129. return empty($item) ? "-" : date('Y-m-d H:i:s', $item);
  130. }],
  131. ], $data);
  132. return app('json')->success([
  133. 'list' => $result,
  134. 'pageCount' => $pageCount,
  135. 'pageSize' => $pageSize,
  136. 'page' => $post['page'],
  137. ]);
  138. }
  139. /**
  140. * 商城订单详情
  141. * @param Request $request
  142. */
  143. public function info(Request $request)
  144. {
  145. $post = UtilService::getMore([
  146. ['id', '', 'empty', '参数错误'],
  147. ], $request);
  148. $order = Db::name('store_order')
  149. ->alias('o')
  150. ->field('o.*,u.mobile,u.nickname')
  151. ->leftJoin('user u', 'u.uid = o.uid')
  152. ->where('o.id', $post['id'])
  153. ->find();
  154. if (empty($order)) {
  155. return app('json')->fail('订单不存在');
  156. }
  157. $data = $order->toArray();
  158. //获取订单商品
  159. $cartInfo = Db::name('store_order_cart_info')
  160. ->where('oid', $data['id'])
  161. ->select()
  162. ->toArray();
  163. $data['cart_info'] = $cartInfo;
  164. return app('json')->success($data);
  165. }
  166. /**
  167. * 发货
  168. * @param Request $request
  169. */
  170. public function fahuo(Request $request)
  171. {
  172. $post = UtilService::getMore([
  173. ['id', '', 'empty', '参数错误'],
  174. ['express_type', ''],
  175. ['express_code', ''],
  176. ['express_num', ''],
  177. ], $request);
  178. $order = Db::name('store_order')
  179. ->where('id', $post['id'])
  180. ->where('status', 1)
  181. ->find();
  182. if (empty($order)) {
  183. return app('json')->fail('当前订单不可发货');
  184. }
  185. if (empty($post['express_num'])) {
  186. return app('json')->fail('请输入物流单号');
  187. }
  188. $result = Db::name('store_order')->where('id', $post['id'])->update([
  189. 'status' => 2,
  190. 'express_type' => $post['express_type'],
  191. 'express_code' => $post['express_code'],
  192. 'express_num' => $post['express_num'],
  193. 'delivery_time' => time(),
  194. ]);
  195. if ($result) {
  196. return app('json')->success('操作成功');
  197. } else {
  198. return app('json')->fail('操作失败');
  199. }
  200. }
  201. /**
  202. * 订单备注
  203. * @param Request $request
  204. */
  205. public function mono(Request $request)
  206. {
  207. $post = UtilService::getMore([
  208. ['id', '', 'empty', '参数错误'],
  209. ['remark', '', 'empty', '请输入备注内容'],
  210. ], $request);
  211. $order = Db::name('store_order')->where('id', $post['id'])->find();
  212. if (empty($order)) {
  213. return app('json')->fail('订单不存在');
  214. }
  215. $result = Db::name('store_order')->where('id', $post['id'])->update([
  216. 'remark' => $post['remark'],
  217. ]);
  218. if ($result) {
  219. return app('json')->success('操作成功');
  220. } else {
  221. return app('json')->fail('操作失败');
  222. }
  223. }
  224. }