Shop.php 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284
  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. // 关联订单商品信息
  106. if (!empty($data)) {
  107. foreach ($data as &$order) {
  108. $cartInfo = Db::name('store_order_cart_info')
  109. ->where('oid', $order['id'])
  110. ->select()
  111. ->toArray();
  112. foreach ($cartInfo as &$item) {
  113. if (!empty($item['cart_info'])) {
  114. $innerCartInfo = json_decode($item['cart_info'], true);
  115. unset($item['cart_info']);
  116. $item = array_merge($item, $innerCartInfo);
  117. }
  118. }
  119. $order['cart_info'] = $cartInfo;
  120. }
  121. }
  122. $pageCount = $order->where($where)->count();
  123. $result = UtilService::getParam([
  124. 'id',
  125. 'order_id',
  126. 'uid',
  127. 'real_name',
  128. 'user_phone',
  129. 'address_id',
  130. 'user_address',
  131. // 'mobile',
  132. // 'nickname',
  133. // 'real_name',
  134. // 'tel',
  135. // 'province',
  136. // 'city',
  137. // 'district',
  138. // 'detail',
  139. 'total_price',
  140. 'pay_price',
  141. 'total_postage',
  142. 'pay_postage',
  143. 'paid',
  144. 'status',
  145. ['create_time', 'create_time', 'date("Y-m-d H:i:s",$1)'],
  146. ['pay_time', 'pay_time', function ($item) {
  147. return empty($item) ? "-" : date('Y-m-d H:i:s', $item);
  148. }],
  149. ['confirm_time', 'confirm_time', function ($item) {
  150. return empty($item) ? "-" : date('Y-m-d H:i:s', $item);
  151. }],
  152. ], $data);
  153. return app('json')->success([
  154. 'list' => $result,
  155. 'pageCount' => $pageCount,
  156. 'pageSize' => $pageSize,
  157. 'page' => $post['page'],
  158. ]);
  159. }
  160. /**
  161. * 商城订单详情
  162. * @param Request $request
  163. */
  164. public function info(Request $request)
  165. {
  166. $post = UtilService::getMore([
  167. ['id', '', 'empty', '参数错误'],
  168. ], $request);
  169. $order = Db::name('store_order')
  170. ->alias('o')
  171. ->field('o.*,u.mobile,u.nickname')
  172. ->leftJoin('user u', 'u.uid = o.uid')
  173. ->where('o.id', $post['id'])
  174. ->find();
  175. if (empty($order)) {
  176. return app('json')->fail('订单不存在');
  177. }
  178. $data = $order;
  179. //获取订单商品
  180. $cartInfo = Db::name('store_order_cart_info')
  181. ->where('oid', $data['id'])
  182. ->select()
  183. ->toArray();
  184. // 解析 cart_info JSON 字段并合并到外层
  185. foreach ($cartInfo as &$item) {
  186. if (!empty($item['cart_info'])) {
  187. $innerCartInfo = json_decode($item['cart_info'], true);
  188. unset($item['cart_info']);
  189. $item = array_merge($item, $innerCartInfo);
  190. } else {
  191. unset($item['cart_info']);
  192. }
  193. }
  194. $data['cart_info'] = $cartInfo;
  195. return app('json')->success($data);
  196. }
  197. /**
  198. * 发货
  199. * @param Request $request
  200. */
  201. public function fahuo(Request $request)
  202. {
  203. $post = UtilService::getMore([
  204. ['id', '', 'empty', '参数错误'],
  205. ['express_type', ''],
  206. ['express_code', ''],
  207. ['express_num', ''],
  208. ], $request);
  209. $order = Db::name('store_order')
  210. ->where('id', $post['id'])
  211. ->where('status', 1)
  212. ->find();
  213. if (empty($order)) {
  214. return app('json')->fail('当前订单不可发货');
  215. }
  216. if (empty($post['express_num'])) {
  217. return app('json')->fail('请输入物流单号');
  218. }
  219. $result = Db::name('store_order')->where('id', $post['id'])->update([
  220. 'status' => 2,
  221. 'express_type' => $post['express_type'],
  222. 'express_code' => $post['express_code'],
  223. 'express_num' => $post['express_num'],
  224. 'delivery_time' => time(),
  225. ]);
  226. if ($result) {
  227. return app('json')->success('操作成功');
  228. } else {
  229. return app('json')->fail('操作失败');
  230. }
  231. }
  232. /**
  233. * 订单备注
  234. * @param Request $request
  235. */
  236. public function mono(Request $request)
  237. {
  238. $post = UtilService::getMore([
  239. ['id', '', 'empty', '参数错误'],
  240. ['remark', '', 'empty', '请输入备注内容'],
  241. ], $request);
  242. $order = Db::name('store_order')->where('id', $post['id'])->find();
  243. if (empty($order)) {
  244. return app('json')->fail('订单不存在');
  245. }
  246. $result = Db::name('store_order')->where('id', $post['id'])->update([
  247. 'remark' => $post['remark'],
  248. ]);
  249. if ($result) {
  250. return app('json')->success('操作成功');
  251. } else {
  252. return app('json')->fail('操作失败');
  253. }
  254. }
  255. }