AffiliateController.php 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  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 status(Request $request)
  35. {
  36. header('Access-Control-Allow-Origin: *');
  37. header('Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept');
  38. //$status = (int) $request->validate(['status' => 'required|numeric']);
  39. $status = $request->input('status');
  40. $id = $request->input('id');
  41. $query = ReferralApply::query();
  42. //return response()->json(['status' => 'success', 'message' => $status]);
  43. //return response()->json(['status' => 'update', 'message' => ]);
  44. if ($query->where('id',$id )->update(['status' => $status])) {
  45. // 审核申请的时候将关联的
  46. if ($status == 1 || $status == 2) {
  47. $nod = $query->where('id',$id )->get();
  48. foreach ($nod as $nn) {
  49. $nn->referral_logs()->update(['status' => $status]);
  50. }
  51. }
  52. }
  53. return response()->json(['status' => 'success', 'message' => 'success']);
  54. }
  55. // 用户返利流水记录
  56. public function rebate(Request $request)
  57. {
  58. $invitee_email = $request->input('invitee_email');
  59. $inviter_email = $request->input('inviter_email');
  60. $status = $request->input('status');
  61. $query = ReferralLog::with(['invitee:id,email', 'inviter:id,email'])->orderBy('status')->latest();
  62. if (isset($invitee_email)) {
  63. $query->whereHas('invitee', static function ($q) use ($invitee_email) {
  64. $q->where('email', 'like', '%'.$invitee_email.'%');
  65. });
  66. }
  67. if (isset($inviter_email)) {
  68. $query->whereHas('inviter', static function ($q) use ($inviter_email) {
  69. $q->where('email', 'like', '%'.$inviter_email.'%');
  70. });
  71. }
  72. if (isset($status)) {
  73. $query->whereStatus($status);
  74. }
  75. return view('admin.aff.rebate', ['referralLogs' => $query->paginate(15)->appends($request->except('page'))]);
  76. }
  77. }