AffiliateController.php 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Http\Controllers\Controller;
  4. use App\Models\ReferralApply;
  5. use App\Models\ReferralLog;
  6. use Illuminate\Http\JsonResponse;
  7. use Illuminate\Http\Request;
  8. use Response;
  9. /**
  10. * 推广控制器
  11. *
  12. * Class AffiliateController
  13. *
  14. * @package App\Http\Controllers\Controller
  15. */
  16. class AffiliateController extends Controller
  17. {
  18. // 提现申请列表
  19. public function affiliateList(Request $request)
  20. {
  21. $email = $request->input('email');
  22. $status = $request->input('status');
  23. $query = ReferralApply::with('user:id,email');
  24. if (isset($email)) {
  25. $query->whereHas(
  26. 'user',
  27. static function ($q) use ($email) {
  28. $q->where('email', 'like', '%' . $email . '%');
  29. }
  30. );
  31. }
  32. if ($status) {
  33. $query->whereStatus($status);
  34. }
  35. $view['applyList'] = $query->latest()->paginate(15)->appends(
  36. $request->except('page')
  37. );
  38. return view('admin.affiliate.affiliateList', $view);
  39. }
  40. // 提现申请详情
  41. public function affiliateDetail(Request $request)
  42. {
  43. $view['basic'] = ReferralApply::with('user:id,email')->find(
  44. $request->input('id')
  45. );
  46. $view['commissions'] = [];
  47. if ($view['basic'] && $view['basic']->link_logs) {
  48. $view['commissions'] = ReferralLog::with(
  49. ['invitee:id,email', 'order.goods:id,name']
  50. )
  51. ->whereIn(
  52. 'id',
  53. $view['basic']->link_logs
  54. )
  55. ->paginate(15)
  56. ->appends(
  57. $request->except('page')
  58. );
  59. }
  60. return view('admin.affiliate.affiliateDetail', $view);
  61. }
  62. // 设置提现申请状态
  63. public function setAffiliateStatus(Request $request): JsonResponse
  64. {
  65. $id = $request->input('id');
  66. $status = $request->input('status');
  67. $ret = ReferralApply::whereId($id)->update(['status' => $status]);
  68. if ($ret) {
  69. // 审核申请的时候将关联的
  70. $referralApply = ReferralApply::findOrFail($id);
  71. if ($referralApply && $status == 1) {
  72. ReferralLog::whereIn('id', $referralApply->link_logs)->update(
  73. ['status' => 1]
  74. );
  75. } elseif ($referralApply && $status == 2) {
  76. ReferralLog::whereIn('id', $referralApply->link_logs)->update(
  77. ['status' => 2]
  78. );
  79. }
  80. }
  81. return Response::json(['status' => 'success', 'message' => '操作成功']);
  82. }
  83. // 用户返利流水记录
  84. public function userRebateList(Request $request)
  85. {
  86. $invitee_email = $request->input('invitee_email');
  87. $inviter_email = $request->input('inviter_email');
  88. $status = $request->input('status');
  89. $query = ReferralLog::with(['invitee:id,email', 'inviter:id,email'])
  90. ->orderBy('status')
  91. ->latest();
  92. if (isset($invitee_email)) {
  93. $query->whereHas(
  94. 'invitee',
  95. static function ($q) use ($invitee_email) {
  96. $q->where('email', 'like', '%' . $invitee_email . '%');
  97. }
  98. );
  99. }
  100. if (isset($inviter_email)) {
  101. $query->whereHas(
  102. 'inviter',
  103. static function ($q) use ($inviter_email) {
  104. $q->where('email', 'like', '%' . $inviter_email . '%');
  105. }
  106. );
  107. }
  108. if (isset($status)) {
  109. $query->whereStatus($status);
  110. }
  111. $view['list'] = $query->paginate(15)->appends($request->except('page'));
  112. return view('admin.affiliate.userRebateList', $view);
  113. }
  114. }