AffiliateController.php 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  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\Request;
  7. class AffiliateController extends Controller
  8. {
  9. // 提现申请列表
  10. public function index(Request $request)
  11. {
  12. $email = $request->input('email');
  13. $status = $request->input('status');
  14. $query = ReferralApply::with('user:id,email');
  15. if (isset($email)) {
  16. $query->whereHas('user', static function ($q) use ($email) {
  17. $q->where('email', 'like', '%'.$email.'%');
  18. });
  19. }
  20. if ($status) {
  21. $query->whereStatus($status);
  22. }
  23. return view('admin.aff.index', ['applyList' => $query->latest()->paginate(15)->appends($request->except('page'))]);
  24. }
  25. // 提现申请详情
  26. public function detail(Request $request, ReferralApply $aff)
  27. {
  28. if ($aff->link_logs) {
  29. $commissions = ReferralLog::with(['invitee:id,email', 'order.goods:id,name'])
  30. ->whereIn('id', $aff->link_logs)
  31. ->paginate(15)
  32. ->appends($request->except('page'));
  33. }
  34. return view('admin.aff.detail', [
  35. 'referral' => $aff->load('user:id,email'),
  36. 'commissions' => $commissions ?? null,
  37. ]);
  38. }
  39. // 设置提现申请状态
  40. public function setStatus(Request $request, ReferralApply $aff)
  41. {
  42. $status = (int) $request->validate(['status' => 'required|numeric|between:-1,2']);
  43. if ($aff->update(['status' => $status])) {
  44. // 审核申请的时候将关联的
  45. if ($status === 1 || $status === 2) {
  46. $aff->referral_logs()->update(['status' => $status]);
  47. }
  48. }
  49. return response()->json(['status' => 'success', 'message' => '操作成功']);
  50. }
  51. // 用户返利流水记录
  52. public function rebate(Request $request)
  53. {
  54. $invitee_email = $request->input('invitee_email');
  55. $inviter_email = $request->input('inviter_email');
  56. $status = $request->input('status');
  57. $query = ReferralLog::with(['invitee:id,email', 'inviter:id,email'])->orderBy('status')->latest();
  58. if (isset($invitee_email)) {
  59. $query->whereHas('invitee', static function ($q) use ($invitee_email) {
  60. $q->where('email', 'like', '%'.$invitee_email.'%');
  61. });
  62. }
  63. if (isset($inviter_email)) {
  64. $query->whereHas('inviter', static function ($q) use ($inviter_email) {
  65. $q->where('email', 'like', '%'.$inviter_email.'%');
  66. });
  67. }
  68. if (isset($status)) {
  69. $query->whereStatus($status);
  70. }
  71. return view('admin.aff.rebate', ['referralLogs' => $query->paginate(15)->appends($request->except('page'))]);
  72. }
  73. }