OrderService.php 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  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\OrderModel;
  13. use App\Services\BaseService;
  14. /**
  15. * 订单-服务类
  16. * @author laravel开发员
  17. * @since 2020/11/11
  18. * @package App\Services\Api
  19. */
  20. class OrderService extends BaseService
  21. {
  22. // 静态对象
  23. protected static $instance = null;
  24. /**
  25. * 构造函数
  26. * @author laravel开发员
  27. * @since 2020/11/11
  28. */
  29. public function __construct()
  30. {
  31. $this->model = new OrderModel();
  32. }
  33. /**
  34. * 静态入口
  35. */
  36. public static function make()
  37. {
  38. if (!self::$instance) {
  39. self::$instance = new static();
  40. }
  41. return self::$instance;
  42. }
  43. /**
  44. * 订单列表
  45. * @param $params
  46. * @param int $pageSize
  47. * @return array
  48. */
  49. public function getDataList($params, $pageSize = 15)
  50. {
  51. $model = $this->getQuery($params);
  52. // 数据
  53. $list = $model->where(function ($query) use ($params) {
  54. $status = isset($params['status']) ? $params['status'] : 0;
  55. // 进行中
  56. if ($status > 0 && is_array($status)) {
  57. $query->whereIn('a.status', $status);
  58. }else if($status>0){
  59. $query->where('a.status', $status);
  60. }
  61. })->select(['a.*'])
  62. ->orderBy('a.status', 'desc')
  63. ->orderBy('a.create_time', 'desc')
  64. ->orderBy('a.id', 'desc')
  65. ->paginate($pageSize > 0 ? $pageSize : 9999999);
  66. $list = $list ? $list->toArray() : [];
  67. if ($list) {
  68. $statusArr = [1 => '待审核', 2 => '进行中', 3 => '已完成'];
  69. foreach ($list['data'] as &$item) {
  70. $item['create_time'] = $item['create_time'] ? datetime($item['create_time'], 'Y-m-d H:i:s') : '';
  71. $status = isset($item['status']) ? $item['status'] : 0;
  72. $item['status_text'] = '待审核';
  73. if ($status) {
  74. $item['status_text'] = isset($statusArr[$status]) ? $statusArr[$status] : '';
  75. }
  76. }
  77. unset($item);
  78. }
  79. return [
  80. 'pageSize' => $pageSize,
  81. 'total' => isset($list['total']) ? $list['total'] : 0,
  82. 'list' => isset($list['data']) ? $list['data'] : []
  83. ];
  84. }
  85. /**
  86. * 查询条件
  87. * @param $params
  88. * @return mixed
  89. */
  90. public function getQuery($params)
  91. {
  92. $where = ['a.mark' => 1];
  93. return $this->model->from('orders as a')
  94. ->leftJoin('member as b', 'b.id', '=', 'a.user_id')
  95. ->where($where)
  96. ->where(function($query) use($params){
  97. $userId = isset($params['user_id']) ? intval($params['user_id']) : 0;
  98. if($userId>0){
  99. $query->where('a.user_id', $userId);
  100. }
  101. })
  102. ->where(function ($query) use ($params) {
  103. $keyword = isset($params['keyword']) ? $params['keyword'] : '';
  104. if ($keyword) {
  105. $query->where('a.order_no', 'like', "%{$keyword}%")
  106. ->orWhere('b.nickname', 'like', "%{$keyword}%")
  107. ->orWhere('b.mobile', 'like', "%{$keyword}%");
  108. }
  109. });
  110. }
  111. /**
  112. * 订单详情
  113. * @param $id
  114. */
  115. public function getOrderInfo($id)
  116. {
  117. $statusArr = [1 => '待审核', 2 => '进行中', 3 => '已完成'];
  118. $info = $this->model->from('orders as a')
  119. ->leftJoin('member as b', 'b.id', '=', 'a.user_id')
  120. ->where(['a.id' => $id, 'a.mark' => 1])
  121. ->select(['a.*'])
  122. ->first();
  123. if ($info) {
  124. $info = $info->toArray();
  125. $info['create_time'] = $info['create_time'] ? datetime($info['create_time'], 'Y-m-d H:i:s') : '';
  126. $status = isset($info['status']) ? $info['status'] : 0;
  127. $info['status_text'] = '待付款';
  128. if ($status) {
  129. $info['status_text'] = isset($statusArr[$status]) ? $statusArr[$status] : '';
  130. }
  131. }
  132. return $info;
  133. }
  134. }