Order.php 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201
  1. <?php
  2. namespace App\Http\Controllers\admin;
  3. use App\Http\Controllers\Controller;
  4. use App\Models\FundsRecord;
  5. use App\Models\User;
  6. use App\Models\Order as OrderModel;
  7. use App\Models\Sport;
  8. use Exception;
  9. use Illuminate\Support\Facades\DB;
  10. use App\Constants\HttpStatus;
  11. use App\Models\Wallet;
  12. use App\Models\SportStatistics;
  13. /**
  14. * 足球订单
  15. */
  16. class Order extends Controller
  17. {
  18. /**
  19. * 订单手动退款
  20. */
  21. public function refund()
  22. {
  23. DB::beginTransaction();
  24. try {
  25. $params = request()->validate([
  26. 'id' => ['required', 'array', 'min:1'],
  27. ]);
  28. $orderList = OrderModel::whereIn('id', $params['id'])->get();
  29. foreach ($orderList as $order) {
  30. if ($order->return_status != 0 || $order->pay_status != 1 || $order->settlement_status != 0) {
  31. continue;
  32. }
  33. $order->status = 2;
  34. $order->return_status = 2;
  35. $order->return_operation_time = time();
  36. $order->save();
  37. // 获取用户余额
  38. $walletInfo = Wallet::where(['member_id' => $order->user_id])->first();
  39. if (!$walletInfo) continue;
  40. $before = $walletInfo->available_balance;
  41. $after = bcsub($walletInfo->available_balance, $order->amount, 2);
  42. $walletInfo->available_balance = $after;
  43. $walletInfo->save();
  44. FundsRecord::addData([
  45. 'change_type' => '体彩退款',
  46. 'amount' => $order->amount,
  47. 'before_balance' => $before,
  48. 'after_balance' => $after,
  49. 'member_id' => $order->user_id,
  50. 'related_id' => $order->id,
  51. 'remark' => '体彩订单退款',
  52. ]);
  53. }
  54. DB::commit();
  55. } catch (Exception $e) {
  56. DB::rollBack();
  57. return $this->error(HttpStatus::CUSTOM_ERROR, $e->getMessage());
  58. }
  59. return $this->success();
  60. }
  61. /**
  62. * 订单列表
  63. */
  64. public function list()
  65. {
  66. try {
  67. $params = request()->validate([
  68. 'page' => ['nullable', 'integer', 'min:1'],
  69. 'limit' => ['nullable', 'integer', 'min:1'],
  70. 'id' => ['nullable', 'string'],
  71. 'user_id' => ['nullable', 'string'],
  72. 'id' => ['nullable'],
  73. 'order_id' => ['nullable', 'string'],
  74. 'issue' => ['nullable', 'integer'],
  75. 'pay_status' => ['nullable', 'integer', 'in:0,1'],
  76. 'is_win' => ['nullable', 'integer', 'in:0,1'],
  77. 'is_roll' => ['nullable', 'integer', 'in:0,1'],
  78. 'settlement_status' => ['nullable', 'integer', 'in:0,1,2,3'],
  79. 'return_status' => ['nullable', 'integer', 'in:0,1,2,3'],
  80. 'status' => ['nullable', 'integer', 'in:0,1,2,-1'],
  81. 'start_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:end_time'],
  82. 'end_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:start_time'],
  83. 'league' => ['nullable'],
  84. 'home_team' => ['nullable'],
  85. 'guest_team' => ['nullable'],
  86. ]);
  87. $page = request()->input('page', 1);
  88. $limit = request()->input('limit', 15);
  89. $query = OrderModel::join('sport_odds', 'sport_odds.odd_name_en', '=', 'sport_order.odd_name')
  90. ->join('sport', 'sport.data_id', '=', 'sport_order.issue');
  91. if (!empty($params['id'])) {
  92. $query = $query->where('sport_order.id', $params['id']);
  93. }
  94. if (!empty($params['start_time'])) {
  95. $startTime = strtotime($params['start_time'] . " 00:00:00");
  96. $query = $query->where('sport_order.create_time', '>=', $startTime);
  97. }
  98. if (!empty($params['end_time'])) {
  99. $endTime = strtotime($params['end_time'] . " 23:59:59");
  100. $query = $query->where('sport_order.create_time', '<=', $endTime);
  101. }
  102. if (!empty($params['issue'])) {
  103. $query = $query->where('sport_order.issue', $params['issue']);
  104. }
  105. if (!empty($params['order_id'])) {
  106. $query = $query->where('order_id', $params['order_id']);
  107. }
  108. if (!empty($params['user_id'])) {
  109. $query = $query->where('sport_order.user_id', $params['user_id']);
  110. }
  111. if (isset($params['status'])) {
  112. $query = $query->where('sport_order.status', $params['status']);
  113. }
  114. if (isset($params['return_status'])) {
  115. $query = $query->where('sport_order.return_status', $params['return_status']);
  116. }
  117. if (isset($params['pay_status'])) {
  118. $query = $query->where('sport_order.pay_status', $params['pay_status']);
  119. }
  120. if (isset($params['is_win'])) {
  121. $query = $query->where('sport_order.is_win', $params['is_win']);
  122. }
  123. if (isset($params['settlement_status'])) {
  124. $query = $query->where('sport_order.settlement_status', $params['settlement_status']);
  125. }
  126. if (isset($params['is_roll'])) {
  127. $query = $query->where('sport_order.is_roll', $params['is_roll']);
  128. }
  129. if (!empty($params['league'])) {
  130. $query = $query->where('league|league_en', 'like', '%' . $params['league'] . '%');
  131. }
  132. if (!empty($params['home_team'])) {
  133. $query = $query->where('home_team|home_team_en', 'like', '%' . $params['home_team'] . '%');
  134. }
  135. if (!empty($params['guest_team'])) {
  136. $query = $query->where('guest_team|guest_team_en', 'like', '%' . $params['guest_team'] . '%');
  137. }
  138. $count = $query->distinct()->count('sport_order.id');
  139. $list = $query->distinct()
  140. ->select(['sport_order.*','sport_odds.odd_name as odd_name', 'sport.league', 'sport.league_en', 'sport.home_team', 'sport.home_team_en','sport.home_team_logo', 'sport.guest_team', 'sport.guest_team_en','sport.guest_team_logo'])
  141. ->forPage($page, $limit)
  142. ->orderByDesc('sport_order.create_time')
  143. ->get();
  144. foreach($list as &$item) {
  145. $item['odd_name'] = Sport::doOddName($item['odd_name']);
  146. $item['odd_value'] = Sport::doOddValue($item['odd_value']);
  147. $item['odd'] = formatDecimal($item['odd'], 2);
  148. }
  149. } catch (Exception $e) {
  150. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage());
  151. }
  152. return $this->success(['total' => $count, 'data' => $list]);
  153. }
  154. //订单详情
  155. function info()
  156. {
  157. try {
  158. request()->validate([
  159. 'order_id' => ['required', 'string'],
  160. ]);
  161. $order_id = request()->input('order_id');
  162. $order = OrderModel::join('sport_odds', 'sport_odds.odd_name_en', '=', 'sport_order.odd_name')
  163. ->join('sport', 'sport.data_id', '=', 'sport_order.issue')
  164. ->where('sport_order.order_id', $order_id)
  165. ->select(['sport_order.*','sport_odds.odd_name as odd_name', 'sport.league', 'sport.league_en', 'sport.home_team', 'sport.home_team_en','sport.home_team_logo', 'sport.guest_team', 'sport.guest_team_en','sport.guest_team_logo'])
  166. ->first();
  167. if (!$order) throw new Exception('订单不存在');
  168. $order = $order->toArray();
  169. $order['game_result'] = $order['game_result'] ? json_decode($order['game_result'],true) : null;
  170. $order['first_name'] = User::where('user_id', $order['user_id'])->value('first_name');
  171. $order['odd_name'] = Sport::doOddName($order['odd_name']);
  172. $order['odd_value'] = Sport::doOddValue($order['odd_value']);
  173. $order['odd'] = formatDecimal($order['odd'], 2);
  174. if (!empty($order['detail']['fixture_status'])) {
  175. $order['detail']['fixture_status'] = Sport::getFixtureStatus($order['detail']['fixture_status']);
  176. }
  177. //赛事统计数据
  178. $order['statistics'] = SportStatistics::where('data_id', $order['issue'])->get()->toArray();
  179. ksort($order);
  180. } catch (Exception $e) {
  181. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage());
  182. }
  183. return $this->success($order);
  184. }
  185. }