OrderService.php 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | LARAVEL8.0 框架 [ LARAVEL ][ RXThinkCMF ]
  4. // +----------------------------------------------------------------------
  5. // | 版权所有 2017~2021 LARAVEL研发中心
  6. // +----------------------------------------------------------------------
  7. // | 官方网站: http://www.laravel.cn
  8. // +----------------------------------------------------------------------
  9. // | Author: laravel开发员 <laravel.qq.com>
  10. // +----------------------------------------------------------------------
  11. namespace App\Services\Api;
  12. use App\Models\GoodsModel;
  13. use App\Models\MemberModel;
  14. use App\Models\OrderGoodsModel;
  15. use App\Models\OrderModel;
  16. use App\Services\BaseService;
  17. use App\Services\ConfigService;
  18. use App\Services\RedisService;
  19. use Illuminate\Support\Facades\DB;
  20. use wxkxklmyt\Scws;
  21. /**
  22. * 订单-服务类
  23. * @author laravel开发员
  24. * @since 2020/11/11
  25. * @package App\Services\Api
  26. */
  27. class OrderService extends BaseService
  28. {
  29. // 静态对象
  30. protected static $instance = null;
  31. /**
  32. * 构造函数
  33. * @author laravel开发员
  34. * @since 2020/11/11
  35. */
  36. public function __construct()
  37. {
  38. $this->model = new OrderModel();
  39. }
  40. /**
  41. * 静态入口
  42. */
  43. public static function make()
  44. {
  45. if (!self::$instance) {
  46. self::$instance = new static();
  47. }
  48. return self::$instance;
  49. }
  50. /**
  51. * 订单列表
  52. * @param $params
  53. * @param int $pageSize
  54. * @return array
  55. */
  56. public function getDataList($params, $pageSize = 15)
  57. {
  58. $where = ['a.mark' => 1];
  59. $list = $this->model->from('orders as a')->with(['goods','user'])
  60. ->leftJoin('member as b', 'b.id', '=', 'a.buy_user_id')
  61. ->where($where)
  62. ->where(function ($query) use ($params) {
  63. $keyword = isset($params['keyword']) ? $params['keyword'] : '';
  64. if ($keyword) {
  65. $query->where('a.order_no', 'like', "%{$keyword}%")
  66. ->orWhere('b.username', 'like', "%{$keyword}%")
  67. ->orWhere('b.nickname', 'like', "%{$keyword}%")
  68. ->orWhere('b.mobile', 'like', "%{$keyword}%");
  69. }
  70. })
  71. ->where(function ($query) use ($params) {
  72. $userId = isset($params['user_id']) ? $params['user_id'] : 0;
  73. if ($userId) {
  74. $query->where(function($query) use($userId){
  75. $query->where('a.user_id', $userId)
  76. ->orWhere('a.buy_user_id', $userId);
  77. });
  78. }
  79. $driverId = isset($params['driver_id']) ? $params['driver_id'] : 0;
  80. if ($driverId) {
  81. $query->where('a.driver_id', '=', $driverId);
  82. }
  83. $orderType = isset($params['order_type']) ? $params['order_type'] : 0;
  84. if ($orderType > 0) {
  85. $query->where('a.order_type', '=', $orderType);
  86. }
  87. })
  88. ->where(function ($query) use ($params) {
  89. $status = isset($params['status']) ? $params['status'] : 0;
  90. // 进行中
  91. if ($status>0) {
  92. $query->where('a.status', $status);
  93. }
  94. })
  95. ->select(['a.*'])
  96. ->orderBy('a.status', 'asc')
  97. ->orderBy('a.create_time', 'desc')
  98. ->orderBy('a.pay_at', 'desc')
  99. ->orderBy('a.id', 'desc')
  100. ->paginate($pageSize > 0 ? $pageSize : 9999999);
  101. $list = $list ? $list->toArray() : [];
  102. if ($list) {
  103. $statusArr = [1 => '待审核', 2 => '待捡货', 3 => '捡货中', 4 => '已发货', 5 => '已送达', 6 => '已结账'];
  104. foreach ($list['data'] as &$item) {
  105. $item['create_time'] = $item['create_time'] ? datetime($item['create_time'], 'Y-m-d H:i:s') : '';
  106. $status = isset($item['status']) ? $item['status'] : 0;
  107. $item['status_text'] = '待审核';
  108. if ($status) {
  109. $item['status_text'] = isset($statusArr[$status]) ? $statusArr[$status] : '';
  110. }
  111. $item['goods'] = isset($item['goods']) && $item['goods']? $item['goods'] : [];
  112. }
  113. unset($item);
  114. }
  115. return [
  116. 'pageSize' => $pageSize,
  117. 'total' => isset($list['total']) ? $list['total'] : 0,
  118. 'list' => isset($list['data']) ? $list['data'] : []
  119. ];
  120. }
  121. /**
  122. * 订单详情
  123. * @param $id
  124. */
  125. public function getOrderInfo($id)
  126. {
  127. $statusArr = [1 => '待审核', 2 => '待捡货', 3 => '捡货中', 4 => '已发货', 5 => '已送达', 6 => '已结账'];
  128. $info = $this->model->from('orders as a')->with(['goods', 'user'])
  129. ->leftJoin('member as b', 'b.id', '=', 'a.buy_user_id')
  130. ->where(['a.id' => $id, 'a.mark' => 1])
  131. ->select(['a.*'])
  132. ->first();
  133. if ($info) {
  134. $info = $info->toArray();
  135. $info['create_time'] = $info['create_time'] ? datetime($info['create_time'], 'Y-m-d H:i:s') : '';
  136. $status = isset($info['status']) ? $info['status'] : 0;
  137. $info['status_text'] = '待付款';
  138. if ($status) {
  139. $info['status_text'] = isset($statusArr[$status]) ? $statusArr[$status] : '';
  140. }
  141. $info['goods'] = isset($info['goods'])&&$info['goods']? $info['goods'] : [];
  142. }
  143. return $info;
  144. }
  145. /**
  146. * 创建订单
  147. * @param $userId 用户
  148. * @param $params 参数
  149. * @return array|false
  150. */
  151. public function createOrder($userId, $params)
  152. {
  153. $orderType = isset($params['order_type']) && $params['order_type'] ? intval($params['order_type']) : 1;
  154. $prePayStatus = isset($params['pre_pay_status']) && $params['pre_pay_status']? intval($params['pre_pay_status']) : 1;
  155. $prePayMoney = isset($params['pre_pay_money']) && $params['pre_pay_money']? floatval($params['pre_pay_money']) : 0;
  156. $isAfter = isset($params['is_after']) && $params['is_after']? intval($params['is_after']) : 1;
  157. $afterType = isset($params['after_type']) && $params['after_type']? intval($params['after_type']) : 0;
  158. $num = isset($params['num']) ? intval($params['num']) : 0;
  159. $total = isset($params['total']) ? floatval($params['total']) : 0;
  160. $buyUserId = isset($params['buy_user_id']) ? floatval($params['buy_user_id']) : 0;
  161. $stockId = isset($params['stock_id']) ? intval($params['stock_id']) : 0;
  162. $goods = isset($params['goods']) && $params['goods'] ? $params['goods'] : [];
  163. $goodsIds = $goods? array_keys($goods) : [];
  164. $goodsIds = array_filter($goodsIds); // 过滤空
  165. // 参数验证
  166. if (!in_array($orderType, [1, 2])) {
  167. $this->error = 2102;
  168. return false;
  169. } else if (empty($goods) || empty($goodsIds) || !is_array($goods) || $num<=0) {
  170. $this->error = 2103;
  171. return false;
  172. } else if ($orderType == 2 && $buyUserId <=0) {
  173. $this->error = 2104;
  174. return false;
  175. }
  176. if ($prePayStatus > 1 && $prePayMoney<=0) {
  177. $this->error = 2105;
  178. return false;
  179. }
  180. if ($isAfter > 1 && $afterType<=0) {
  181. $this->error = 2106;
  182. return false;
  183. }
  184. // 缓存锁
  185. $cacheLockKey = "caches:orders:submit_lock:{$userId}_{$orderType}";
  186. if (RedisService::get($cacheLockKey)) {
  187. $this->error = 2107;
  188. return false;
  189. }
  190. if($stockId<=0){
  191. $this->error = 2033;
  192. return false;
  193. }
  194. // 验证用户信息
  195. RedisService::set($cacheLockKey, ['params' => $params, 'user_id' => $userId], rand(2, 3));
  196. $userInfo = MemberModel::where(['id' => $userId, 'mark' => 1])
  197. ->select(['id','username', 'mobile', 'nickname', 'address', 'status'])
  198. ->first();
  199. $status = isset($userInfo['status']) ? $userInfo['status'] : 0;
  200. $nickname = isset($userInfo['nickname']) ? trim($userInfo['nickname']) : '';
  201. $contact = isset($userInfo['mobile']) ? trim($userInfo['mobile']) : '';
  202. $address = isset($userInfo['address']) ? trim($userInfo['address']) : '';
  203. if (empty($userInfo) || $status != 1) {
  204. $this->error = 2015;
  205. RedisService::clear($cacheLockKey);
  206. return false;
  207. }
  208. if(empty($nickname) || empty($address) || empty($contact)){
  209. $this->error = "203{$orderType}";
  210. RedisService::clear($cacheLockKey);
  211. return false;
  212. }
  213. // 验证商品
  214. $buyGoods = GoodsService::make()->getListByIds($goods, true);
  215. if(empty($buyGoods)){
  216. $this->error = 2108;
  217. RedisService::clear($cacheLockKey);
  218. return false;
  219. }
  220. // 统计购买商品数据
  221. $buyNum = 0;
  222. $buyTotal = 0;
  223. $originalTotal = 0;
  224. $orderNo = get_order_num('YD');
  225. $orderGoods = [];
  226. foreach ($buyGoods as $item){
  227. $goodsId = isset($item['goods_id'])? $item['goods_id'] : 0;
  228. $price = isset($item['price'])? $item['price'] : 0;
  229. $goodsNum = isset($item['num'])? $item['num'] : 0;
  230. $category = isset($item['category'])? $item['category'] : [];
  231. $realPrice = isset($item['real_price']) && $item['real_price']>0? floatval($item['real_price']) : $price;
  232. $goodsTotal = round($realPrice * $goodsNum, 2);
  233. $goodsOriginalTotal = round($price * $goodsNum, 2);
  234. if($goodsId && $goodsTotal>0){
  235. $buyNum++;
  236. $originalTotal += $goodsOriginalTotal;
  237. $buyTotal += $goodsTotal;
  238. $orderGoods[] = [
  239. 'goods_id'=> $goodsId,
  240. 'user_id'=> $orderType==2? $buyUserId : $userId,
  241. 'order_no'=> $orderNo,
  242. 'price'=> $realPrice,
  243. 'original_price'=> $price,
  244. 'goods_name'=> isset($item['goods_name'])? $item['goods_name'] : '',
  245. 'stock_id'=> $stockId,
  246. 'brand_id'=> isset($item['brand_id'])? $item['brand_id'] : 0,
  247. 'cate_id'=> isset($item['cate_id'])? $item['cate_id'] : 0,
  248. 'cate_name'=> isset($category['cate_name'])? $category['cate_name'] : '',
  249. 'settle_type'=> isset($item['settle_type'])? $item['settle_type'] : 0,
  250. 'settle_rate'=> isset($item['settle_rate'])? $item['settle_rate'] : 0,
  251. 'settle_num'=> isset($item['settle_num'])? $item['settle_num'] : 0,
  252. 'supplier_name'=> isset($item['supplier_name'])? $item['supplier_name'] : '',
  253. 'spec'=> isset($item['spec'])? $item['spec'] : '',
  254. 'thumb'=> isset($item['thumb']) && $item['thumb']? get_image_path($item['thumb']) : '',
  255. 'unit'=> isset($item['unit'])? $item['unit'] : '',
  256. 'unit1'=> isset($item['unit1'])? $item['unit1'] : '',
  257. 'unit1_num'=> isset($item['unit1_num'])? $item['unit1_num'] :0,
  258. 'num'=> $goodsNum,
  259. 'create_time'=> time(),
  260. 'update_time'=> time(),
  261. 'status'=> 1,
  262. 'mark'=> 1,
  263. ];
  264. }
  265. }
  266. if(intval($buyTotal) != intval($total)){
  267. $this->error = 2115;
  268. RedisService::clear($cacheLockKey);
  269. return false;
  270. }
  271. // 订单数据
  272. $order = [
  273. 'order_no'=> $orderNo,
  274. 'user_id'=> $userId,
  275. 'buy_user_id'=> $orderType==2? $buyUserId : $userId,
  276. 'delivery_user_id'=>$orderType==2? $userId : 0,
  277. 'order_type'=> $orderType,
  278. 'stock_id'=> $stockId,
  279. 'num'=> $buyNum,
  280. 'total'=> $buyTotal,
  281. 'original_total'=> $originalTotal,
  282. 'pay_status'=> 3,
  283. 'pre_pay_status'=> $prePayStatus,
  284. 'pre_pay_money'=> $prePayStatus>1?$prePayMoney:0,
  285. 'pre_pay_remark'=> isset($params['pre_pay_remark']) && $prePayStatus>1? trim($params['pre_pay_remark']) : '',
  286. 'customer_name'=> $nickname,
  287. 'customer_contact'=> $contact,
  288. 'customer_address'=> $address,
  289. 'is_after'=> $isAfter,
  290. 'after_type'=> $isAfter>1?$afterType:0,
  291. 'after_money'=> isset($params['after_money']) && $isAfter>1? floatval($params['after_money']) : 0,
  292. 'after_remark'=> isset($params['after_remark']) && $isAfter>1? trim($params['after_remark']) : '',
  293. 'create_time'=> time(),
  294. 'update_time'=> time(),
  295. 'updated_at'=> date('Y-m-d H:i:s'),
  296. 'is_cancel'=> 2,
  297. 'status'=> 1,
  298. 'mark'=> 1,
  299. ];
  300. // 订单处理
  301. DB::beginTransaction();
  302. if(!$orderId = $this->model->insertGetId($order)){
  303. DB::rollBack();
  304. $this->error = 2109;
  305. RedisService::clear($cacheLockKey);
  306. return false;
  307. }
  308. // 订单商品
  309. if(!OrderGoodsModel::insert($orderGoods)){
  310. DB::rollBack();
  311. $this->error = 2110;
  312. RedisService::clear($cacheLockKey);
  313. return false;
  314. }
  315. DB::commit();
  316. // 订单下单统计数据处理
  317. $this->error = "211{$orderType}";
  318. RedisService::clear($cacheLockKey);
  319. return ['order_id'=> $orderId,'total'=> $buyTotal,'num'=> $buyNum,'goods'=> $goods];
  320. }
  321. /**
  322. * 收货处理
  323. * @param $driverId
  324. * @param $params
  325. * @return bool
  326. */
  327. public function receive($driverId, $params)
  328. {
  329. $id = isset($params['id']) ? intval($params['id']) : 0; // 订单ID
  330. $cacheKey = "caches:orders:receive_lock:{$id}_{$driverId}";
  331. if (RedisService::get($cacheKey)) {
  332. $this->error = 1034;
  333. return false;
  334. }
  335. // 缓存锁
  336. RedisService::set($cacheKey, ['id' => $id, 'driver_id' => $driverId], rand(2, 3));
  337. $orderInfo = $this->model->with(['member', 'driver', 'payment'])->where(['id' => $id, 'mark' => 1])
  338. ->select(['id', 'order_no', 'pay_money', 'user_id', 'driver_id', 'deposit', 'deposit_status', 'pay_status', 'deposit_order_no', 'transaction_id', 'coupon_id', 'service_type', 'pay_style', 'pay_type', 'status'])
  339. ->first();
  340. $orderStatus = isset($orderInfo['status']) ? $orderInfo['status'] : 0;
  341. $payStatus = isset($orderInfo['pay_status']) ? $orderInfo['pay_status'] : 0;
  342. $depositStatus = isset($orderInfo['deposit_status']) ? $orderInfo['deposit_status'] : 0;
  343. $payStyle = isset($orderInfo['pay_style']) ? $orderInfo['pay_style'] : 0;
  344. $serviceType = isset($orderInfo['service_type']) ? $orderInfo['service_type'] : 0;
  345. $orderUserId = isset($orderInfo['user_id']) ? $orderInfo['user_id'] : 0;
  346. $orderNo = isset($orderInfo['order_no']) ? $orderInfo['order_no'] : '';
  347. if (empty($id) || empty($orderInfo)) {
  348. $this->error = 2128;
  349. return false;
  350. }
  351. // 验证订单状态,到付订单(可未支付,只支付诚意金)或已支付订单
  352. if (($payStyle == 1 && $payStatus != 1) || ($payStyle == 2 && $depositStatus != 1)) {
  353. $this->error = 2129;
  354. return false;
  355. }
  356. // 验证状态
  357. if ($orderStatus != 7) {
  358. $this->error = 2146;
  359. return false;
  360. }
  361. // 司机信息
  362. $driverInfo = DriverModel::where(['id' => $driverId, 'mark' => 1])
  363. ->select(['id', 'mobile', 'realname', 'car_number', 'is_online', 'status'])
  364. ->first();
  365. $status = isset($driverInfo['status']) ? $driverInfo['status'] : 0;
  366. $isOnline = isset($driverInfo['is_online']) ? $driverInfo['is_online'] : 0;
  367. $realname = isset($driverInfo['realname']) ? $driverInfo['realname'] : '';
  368. $carNumber = isset($driverInfo['car_number']) ? $driverInfo['car_number'] : '';
  369. if (empty($driverInfo) || $status != 2) {
  370. $this->error = 2024;
  371. return false;
  372. }
  373. // 司机未在线
  374. if ($isOnline != 1) {
  375. $this->error = 2145;
  376. return false;
  377. }
  378. // 接单处理
  379. DB::beginTransaction();
  380. if (!$this->model->where(['id' => $id, 'mark' => 1])->update(['status' => 3, 'update_time' => time()])) {
  381. DB::rollBack();
  382. $this->error = $serviceType == 1 ? 2148 : 2147;
  383. return false;
  384. }
  385. DB::commit();
  386. // 消息推送
  387. $params = [
  388. 'title' => $serviceType == 1 ? "订单开始服务通知" : '订单开始配送通知',
  389. 'description' => "您的订单【{$orderNo}】" . ($serviceType == 1 ? '已开始服务' : '司机已取到货并开始配送') . ",请及时查看订单进度",
  390. 'type' => 2, // 1-公告通知,2-订单通知,3-交易通知,4-其他
  391. 'content' => json_encode([
  392. 'order_no' => ['name' => '订单号', 'text' => $orderNo],
  393. 'picker_time' => ['name' => '取货时间', 'text' => date('Y-m-d H:i:s')],
  394. 'realname' => ['name' => '司机', 'text' => $realname],
  395. 'car_number' => ['name' => '车牌号', 'text' => $carNumber],
  396. 'status' => ['name' => '状态', 'text' => $serviceType == 1 ? '服务中' : '配送中'],
  397. ], 256),
  398. 'bind_id' => $id,
  399. ];
  400. // 推送消息处理
  401. MessageService::make()->pushMessage($orderUserId, $params);
  402. $this->error = $serviceType == 1 ? 2149 : 2150;
  403. return true;
  404. }
  405. /**
  406. * 获取用户历史购买商品数据/列表
  407. * @param $userId
  408. * @param array $params
  409. * @param int $pageSize
  410. * @return array
  411. */
  412. public function getHistoryGoods($userId, $params = [], $pageSize = 0)
  413. {
  414. $cacheKey = "caches:goods:history:{$userId}_" . ($params ? md5(json_encode($params, 256)) : 0);
  415. $datas = RedisService::get($cacheKey);
  416. if (empty($datas)) {
  417. $showNum = ConfigService::make()->getConfigByCode('show_history_goods_num', 4);
  418. $pageSize = $pageSize ? $pageSize : $showNum;
  419. $model = GoodsModel::with(['category'])->from('goods as a')
  420. ->leftJoin('orders_goods as b', 'a.goods_id', '=', 'b.goods_id')
  421. ->leftJoin('orders as c', 'b.order_no', '=', 'c.order_no')
  422. ->leftJoin('goods_categorys as d', 'd.cate_id', '=', 'a.cate_id')
  423. ->whereIn('c.status', [1, 2, 3, 4, 5, 6])
  424. ->where(function($query) use($userId){
  425. $query->where('c.user_id', $userId)
  426. ->orWhere('c.buy_user_id', $userId);
  427. })
  428. ->where([ 'b.mark' => 1,'c.mark'=>1])
  429. ->where(function ($query) use ($params) {
  430. // 分类
  431. $cateId = isset($params['cate_id'])? $params['cate_id'] : 0;
  432. if($cateId){
  433. $query->where(function($query) use($cateId){
  434. $query->where('a.cate_id', $cateId)
  435. ->orWhere('d.pids','like',"%{$cateId},%");
  436. });
  437. }
  438. $keyword = isset($params['keyword']) ? $params['keyword'] : '';
  439. if ($keyword) {
  440. $scws = new Scws();
  441. $kws = $scws->scws($keyword,3,false);
  442. if(count($kws) >1){
  443. $query->where(function ($query) use ($kws) {
  444. foreach ($kws as $kw) {
  445. $kw = trim($kw);
  446. $query->where('a.goods_name', 'like', "%{$kw}%")
  447. ->where('a.keywords', 'like', "%{$kw}%");
  448. }
  449. });
  450. }else{
  451. $query->where(function ($query) use ($keyword){
  452. $query->where('a.goods_name','like',"%{$keyword}%")
  453. ->orWhere('a.goods_pinyin','like',"%{$keyword}%")
  454. ->orWhere('a.keywords', 'like', "%{$keyword}%");
  455. });
  456. }
  457. }
  458. })
  459. ->select(['a.*', 'a.price as real_price']);
  460. $sortType = isset($params['sort_type']) ? $params['sort_type'] : 0;
  461. if ($sortType == 1) {
  462. $model = $model->orderBy('a.sales', 'desc');
  463. } else if ($sortType == 2) {
  464. $model = $model->orderBy('a.sales', 'asc');
  465. } else if ($sortType == 3) {
  466. $model = $model->orderBy('a.price', 'desc');
  467. } else if ($sortType == 4) {
  468. $model = $model->orderBy('a.price', 'asc');
  469. } else {
  470. $model = $model->orderBy('a.create_time', 'desc');
  471. $model = $model->orderBy('a.goods_id', 'desc');
  472. }
  473. $list = $model->orderBy('c.create_time', 'desc')
  474. ->groupBy('a.goods_id')
  475. ->orderBy('a.goods_id', 'desc')
  476. ->paginate($pageSize > 0 ? $pageSize : 9999999);
  477. $list = $list ? $list->toArray() : [];
  478. if ($list) {
  479. foreach ($list['data'] as &$item) {
  480. $item['real_price'] = GoodsService::make()->getRealPrice($item);
  481. $item['discount_start_at'] = $item['discount_start_time'] ? date('Y-m-d H:i:s', $item['discount_start_time']) : '';
  482. $item['discount_end_at'] = $item['discount_end_time'] ? date('Y-m-d H:i:s', $item['discount_end_time']) : '';
  483. }
  484. }
  485. }
  486. $total = isset($list['total']) ? $list['total'] : 0;
  487. $result = [
  488. 'pageSize' => $pageSize,
  489. 'total' => $total,
  490. 'list' => isset($list['data']) ? $list['data'] : []
  491. ];
  492. if ($total) {
  493. RedisService::set($cacheKey, $result, rand(3, 5));
  494. }
  495. return $result;
  496. }
  497. /**
  498. * 订单统计数据
  499. * @param $userId
  500. * @return array|int[]|mixed
  501. */
  502. public function getCounts($userId)
  503. {
  504. $cacheKey = "caches:orders:counts:u_{$userId}";
  505. $counts = RedisService::get($cacheKey);
  506. if(empty($counts)){
  507. $counts = ['status1'=>0,'status2'=>0,'status3'=>0,'status4'=>0,'status5'=>0];
  508. $datas = $this->model->where(['user_id'=>$userId,'order_type'=>2,'mark'=>1])
  509. ->where('create_time','>=', time() - 600)
  510. ->whereBetween('status',[1,5])
  511. ->select("status",DB::raw("count(order_id) as count"))
  512. ->groupBy('status')
  513. ->get();
  514. $datas = $datas? $datas->toArray() : [];
  515. if($datas){
  516. foreach ($datas as $item){
  517. $status = isset($item['status'])? $item['status'] : 0;
  518. $count = isset($item['count'])? $item['count'] : 0;
  519. if($status>0 && $count>0 && isset($counts["status".$status])){
  520. $counts["status".$status] = $count;
  521. }
  522. }
  523. RedisService::set($cacheKey, $counts, rand(5, 10));
  524. }
  525. }
  526. return $counts;
  527. }
  528. }