Shop.php 9.1 KB

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