AffiliateController.php 2.9 KB

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