AffiliateController.php 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  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. $query = ReferralApply::with('user:id,username');
  13. $request->whenFilled('username', function ($username) use ($query) {
  14. $query->whereHas('user', function ($query) use ($username) {
  15. $query->where('username', 'like', "%{$username}%");
  16. });
  17. });
  18. $request->whenFilled('status', function ($status) use ($query) {
  19. $query->whereStatus($status);
  20. });
  21. return view('admin.aff.index', ['applyList' => $query->latest()->paginate(15)->appends($request->except('page'))]);
  22. }
  23. // 提现申请详情
  24. public function detail(Request $request, ReferralApply $aff)
  25. {
  26. return view('admin.aff.detail', [
  27. 'referral' => $aff->load('user:id,username'),
  28. 'commissions' => $aff->referral_logs()->with(['invitee:id,username', 'order.goods:id,name'])->paginate()->appends($request->except('page')),
  29. ]);
  30. }
  31. // 设置提现申请状态
  32. public function setStatus(Request $request, ReferralApply $aff)
  33. {
  34. $status = (int) $request->input('status');
  35. if ($aff->update(['status' => $status])) {
  36. // 审核申请的时候将关联的
  37. if ($status === 1 || $status === 2) {
  38. if ($aff->referral_logs()->update(['status' => $status])) {
  39. return response()->json(['status' => 'success', 'message' => '操作成功']);
  40. }
  41. }
  42. return response()->json(['status' => 'success', 'message' => '操作成功']);
  43. }
  44. return response()->json(['status' => 'fail', 'message' => '操作失败']);
  45. }
  46. // 用户返利流水记录
  47. public function rebate(Request $request)
  48. {
  49. $query = ReferralLog::with(['invitee:id,username', 'inviter:id,username'])->orderBy('status')->latest();
  50. $request->whenFilled('invitee_username', function ($username) use ($query) {
  51. $query->whereHas('invitee', function ($query) use ($username) {
  52. $query->where('username', 'like', "%{$username}%");
  53. });
  54. });
  55. $request->whenFilled('inviter_username', function ($username) use ($query) {
  56. $query->whereHas('inviter', function ($query) use ($username) {
  57. $query->where('username', 'like', "%{$username}%");
  58. });
  59. });
  60. $request->whenFilled('status', function ($status) use ($query) {
  61. $query->whereStatus($status);
  62. });
  63. return view('admin.aff.rebate', ['referralLogs' => $query->paginate(15)->appends($request->except('page'))]);
  64. }
  65. }