JisuGameOrder.php 6.7 KB

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