SportGameOrder.php 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. <?php
  2. namespace App\Http\Controllers\admin;
  3. use App\Http\Controllers\Controller;
  4. use App\Models\SportGameOrder as SportGameOrderModel;
  5. use App\Models\FundsRecord;
  6. use App\Models\Wallet;
  7. use Exception;
  8. use App\Constants\HttpStatus;
  9. use Illuminate\Support\Facades\DB;
  10. class SportGameOrder extends Controller
  11. {
  12. /**
  13. * 订单列表
  14. */
  15. public function list()
  16. {
  17. try {
  18. $params = request()->validate([
  19. 'page' => ['nullable', 'integer', 'min:1'],
  20. 'limit' => ['nullable', 'integer', 'min:1'],
  21. 'ordernum' => ['nullable', 'string'],
  22. 'member_id' => ['nullable', 'integer'],
  23. 'first_name' => ['nullable'],
  24. 'game_name' => ['nullable', 'string'],
  25. 'gameplay_name' => ['nullable', 'string'],
  26. 'status' => ['nullable', 'integer'],
  27. 'id' => ['nullable', 'integer'],
  28. 'start_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:end_time'],
  29. 'end_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:start_time'],
  30. ]);
  31. $page = request()->input('page', 1);
  32. $limit = request()->input('limit', 15);
  33. $query = new SportGameOrderModel();
  34. $query = SportGameOrderModel::join('users', 'users.member_id', '=', 'sport_game_order.member_id')
  35. ->join('sport_game', 'sport_game.id', '=', 'sport_game_order.game_id')
  36. ->join('sport_gameplay', 'sport_gameplay.id', '=', 'sport_game_order.gameplay_id');
  37. if (!empty($params['id'])) {
  38. $query = $query->where('sport_game_order.id', $params['id']);
  39. }
  40. if (!empty($params['ordernum'])) {
  41. $query = $query->where('sport_game_order.ordernum', $params['ordernum']);
  42. }
  43. if (!empty($params['member_id'])) {
  44. $query = $query->where('sport_game_order.member_id', $params['member_id']);
  45. }
  46. if (isset($params['status']) && $params['status'] !== null) {
  47. $query = $query->where('sport_game_order.status', $params['status']);
  48. }
  49. if (!empty($params['game_name'])) {
  50. $query = $query->where('sport_game.name|sport_game.name_en', 'like', '%'.$params['game_name'].'%');
  51. }
  52. if (!empty($params['gameplay_name'])) {
  53. $query = $query->where('sport_gameplay.name|sport_gameplay.name_en', 'like', '%'.$params['gameplay_name'].'%');
  54. }
  55. if (!empty($params['first_name'])) {
  56. $query = $query->where('users.first_name', 'like', "%{$params['first_name']}%");
  57. }
  58. if (!empty($params['start_time'])) {
  59. $startTime = $params['start_time'] . " 00:00:00";
  60. $query = $query->where('sport_game_order.created_at', '>=', $startTime);
  61. }
  62. if (!empty($params['end_time'])) {
  63. $endTime = $params['end_time'] . " 23:59:59";
  64. $query = $query->where('sport_game_order.created_at', '<=', $endTime);
  65. }
  66. $count = $query->count();
  67. $list = $query->select('sport_game_order.*','users.first_name','users.member_id', 'sport_game.name as game_name', 'sport_gameplay.name as gameplay_name')
  68. ->forPage($page, $limit)
  69. ->orderByDesc('sport_game_order.created_at')
  70. ->get();
  71. } catch (Exception $e) {
  72. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage());
  73. }
  74. return $this->success(['total' => $count, 'data' => $list]);
  75. }
  76. //订单详情
  77. function info()
  78. {
  79. try {
  80. request()->validate([
  81. 'id' => ['required', 'integer'],
  82. ]);
  83. $id = request()->input('id');
  84. $order = SportGameOrderModel::join('users', 'users.member_id', '=', 'sport_game_order.member_id')
  85. ->join('sport_game', 'sport_game.id', '=', 'sport_game_order.game_id')
  86. ->join('sport_gameplay', 'sport_gameplay.id', '=', 'sport_game_order.gameplay_id')
  87. ->where('sport_game_order.id', $id)
  88. ->select('sport_game_order.*','users.first_name','users.member_id', 'sport_game.name as game_name', 'sport_gameplay.name as gameplay_name')
  89. ->first();
  90. if (!$order) throw new Exception('订单不存在');
  91. $order = $order->toArray();
  92. } catch (Exception $e) {
  93. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage());
  94. }
  95. return $this->success($order);
  96. }
  97. /**
  98. * @api {post} /sportGameOrder/refund 同意退款
  99. * @apiGroup 订单管理
  100. */
  101. public function refund()
  102. {
  103. $errors = [];
  104. try {
  105. DB::beginTransaction();
  106. $params = request()->validate([
  107. 'id' => ['required', 'array', 'min:1'],
  108. ]);
  109. $orderList = SportGameOrderModel::whereIn('id', $params['id'])->get();
  110. foreach ($orderList as $order) {
  111. if ($order->status != 0) {
  112. continue;
  113. }
  114. $order->status = 4;
  115. $order->updated_at = time();
  116. $order->save();
  117. // 获取用户余额
  118. $walletInfo = Wallet::where(['member_id' => $order->member_id])->first();
  119. if (!$walletInfo) continue;
  120. $before = $walletInfo->available_balance;
  121. $after = bcsub($walletInfo->available_balance, $order->amount, 2);
  122. $walletInfo->available_balance = $after;
  123. $walletInfo->save();
  124. FundsRecord::addData([
  125. 'change_type' => '足球游戏退款',
  126. 'amount' => $order->amount,
  127. 'before_balance' => $before,
  128. 'after_balance' => $after,
  129. 'member_id' => $order->user_id,
  130. 'related_id' => $order->id,
  131. 'remark' => '足球游戏订单退款',
  132. ]);
  133. }
  134. DB::commit();
  135. } catch (Exception $e) {
  136. DB::rollBack();
  137. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage(), $errors);
  138. }
  139. return $this->success();
  140. }
  141. }