AffiliateController.php 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  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. return view('admin.aff.detail', [
  29. 'referral' => $aff->load('user:id,email'),
  30. 'commissions' => $aff->referral_logs()->with(['invitee:id,email', 'order.goods:id,name'])->paginate()->appends($request->except('page')),
  31. ]);
  32. }
  33. // 设置提现申请状态
  34. public function setStatus(Request $request, ReferralApply $aff)
  35. {
  36. $status = (int) $request->validate(['status' => 'required|numeric|between:-1,2']);
  37. if ($aff->update(['status' => $status])) {
  38. // 审核申请的时候将关联的
  39. if ($status === 1 || $status === 2) {
  40. $aff->referral_logs()->update(['status' => $status]);
  41. }
  42. }
  43. return response()->json(['status' => 'success', 'message' => '操作成功']);
  44. }
  45. // 用户返利流水记录
  46. public function rebate(Request $request)
  47. {
  48. $invitee_email = $request->input('invitee_email');
  49. $inviter_email = $request->input('inviter_email');
  50. $status = $request->input('status');
  51. $query = ReferralLog::with(['invitee:id,email', 'inviter:id,email'])->orderBy('status')->latest();
  52. if (isset($invitee_email)) {
  53. $query->whereHas('invitee', static function ($q) use ($invitee_email) {
  54. $q->where('email', 'like', '%'.$invitee_email.'%');
  55. });
  56. }
  57. if (isset($inviter_email)) {
  58. $query->whereHas('inviter', static function ($q) use ($inviter_email) {
  59. $q->where('email', 'like', '%'.$inviter_email.'%');
  60. });
  61. }
  62. if (isset($status)) {
  63. $query->whereStatus($status);
  64. }
  65. return view('admin.aff.rebate', ['referralLogs' => $query->paginate(15)->appends($request->except('page'))]);
  66. }
  67. }