AffiliateController.php 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  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. class AffiliateController extends Controller
  15. {
  16. // 提现申请列表
  17. public function index(Request $request)
  18. {
  19. $email = $request->input('email');
  20. $status = $request->input('status');
  21. $query = ReferralApply::with('user:id,email');
  22. if (isset($email)) {
  23. $query->whereHas('user', static function ($q) use ($email) {
  24. $q->where('email', 'like', '%'.$email.'%');
  25. });
  26. }
  27. if ($status) {
  28. $query->whereStatus($status);
  29. }
  30. $view['applyList'] = $query->latest()->paginate(15)->appends($request->except('page'));
  31. return view('admin.aff.index', $view);
  32. }
  33. // 提现申请详情
  34. public function detail(Request $request, $id)
  35. {
  36. $view['basic'] = ReferralApply::with('user:id,email')->find($id);
  37. $view['commissions'] = [];
  38. if ($view['basic'] && $view['basic']->link_logs) {
  39. $view['commissions'] = ReferralLog::with(['invitee:id,email', 'order.goods:id,name'])
  40. ->whereIn('id', $view['basic']->link_logs)
  41. ->paginate(15)
  42. ->appends($request->except('page'));
  43. }
  44. return view('admin.aff.detail', $view);
  45. }
  46. // 设置提现申请状态
  47. public function setStatus(Request $request): JsonResponse
  48. {
  49. $id = $request->input('id');
  50. $status = (int) $request->input('status');
  51. $ret = ReferralApply::whereId($id)->update(['status' => $status]);
  52. if ($ret) {
  53. // 审核申请的时候将关联的
  54. $referralApply = ReferralApply::findOrFail($id);
  55. if ($referralApply && $status === 1) {
  56. ReferralLog::whereIn('id', $referralApply->link_logs)->update(['status' => 1]);
  57. } elseif ($referralApply && $status === 2) {
  58. ReferralLog::whereIn('id', $referralApply->link_logs)->update(['status' => 2]);
  59. }
  60. }
  61. return Response::json(['status' => 'success', 'message' => '操作成功']);
  62. }
  63. // 用户返利流水记录
  64. public function rebate(Request $request)
  65. {
  66. $invitee_email = $request->input('invitee_email');
  67. $inviter_email = $request->input('inviter_email');
  68. $status = $request->input('status');
  69. $query = ReferralLog::with(['invitee:id,email', 'inviter:id,email'])->orderBy('status')->latest();
  70. if (isset($invitee_email)) {
  71. $query->whereHas('invitee', static function ($q) use ($invitee_email) {
  72. $q->where('email', 'like', '%'.$invitee_email.'%');
  73. });
  74. }
  75. if (isset($inviter_email)) {
  76. $query->whereHas('inviter', static function ($q) use ($inviter_email) {
  77. $q->where('email', 'like', '%'.$inviter_email.'%');
  78. });
  79. }
  80. if (isset($status)) {
  81. $query->whereStatus($status);
  82. }
  83. $view['list'] = $query->paginate(15)->appends($request->except('page'));
  84. return view('admin.aff.rebate', $view);
  85. }
  86. }