mirror of
https://github.com/ProxyPanel/ProxyPanel.git
synced 2026-04-11 23:19:05 +00:00
1. models 关系规范化; 2. 本地-在线 订单处理改写; 3. 优化用户界面节点的查表操作; 4. 半修复 VNet SSR版需要面板主动提交用户信息变动的问题;(节点等级,用户分组,Node信息修改 主动通知节点尚未添加); 5. 简化并提取出了 返利佣金相关处理逻辑;
104 lines
3.1 KiB
PHP
104 lines
3.1 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Admin;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Models\ReferralApply;
|
|
use App\Models\ReferralLog;
|
|
use Illuminate\Http\JsonResponse;
|
|
use Illuminate\Http\Request;
|
|
use Response;
|
|
|
|
/**
|
|
* 推广控制器
|
|
*
|
|
* Class AffiliateController
|
|
*
|
|
* @package App\Http\Controllers\Controller
|
|
*/
|
|
class AffiliateController extends Controller {
|
|
|
|
// 提现申请列表
|
|
public function affiliateList(Request $request): \Illuminate\Http\Response {
|
|
$email = $request->input('email');
|
|
$status = $request->input('status');
|
|
|
|
$query = ReferralApply::with('user:id,email');
|
|
if(isset($email)){
|
|
$query->whereHas('user', static function($q) use ($email) {
|
|
$q->where('email', 'like', '%'.$email.'%');
|
|
});
|
|
}
|
|
|
|
if($status){
|
|
$query->whereStatus($status);
|
|
}
|
|
|
|
$view['applyList'] = $query->latest()->paginate(15)->appends($request->except('page'));
|
|
|
|
return Response::view('admin.affiliate.affiliateList', $view);
|
|
}
|
|
|
|
// 提现申请详情
|
|
public function affiliateDetail(Request $request): \Illuminate\Http\Response {
|
|
$view['basic'] = ReferralApply::with('user:id,email')->find($request->input('id'));
|
|
$view['commissions'] = [];
|
|
if($view['basic'] && $view['basic']->link_logs){
|
|
$view['commissions'] = ReferralLog::with(['invitee:id,email', 'order.goods:id,name'])
|
|
->whereIn('id', $view['basic']->link_logs)
|
|
->paginate(15)
|
|
->appends($request->except('page'));
|
|
}
|
|
|
|
return Response::view('admin.affiliate.affiliateDetail', $view);
|
|
}
|
|
|
|
// 设置提现申请状态
|
|
public function setAffiliateStatus(Request $request): JsonResponse {
|
|
$id = $request->input('id');
|
|
$status = $request->input('status');
|
|
|
|
$ret = ReferralApply::whereId($id)->update(['status' => $status]);
|
|
if($ret){
|
|
// 审核申请的时候将关联的
|
|
$referralApply = ReferralApply::findOrFail($id);
|
|
if($referralApply && $status == 1){
|
|
ReferralLog::whereIn('id', $referralApply->link_logs)->update(['status' => 1]);
|
|
}elseif($referralApply && $status == 2){
|
|
ReferralLog::whereIn('id', $referralApply->link_logs)->update(['status' => 2]);
|
|
}
|
|
}
|
|
|
|
return Response::json(['status' => 'success', 'message' => '操作成功']);
|
|
}
|
|
|
|
// 用户返利流水记录
|
|
public function userRebateList(Request $request): \Illuminate\Http\Response {
|
|
$invitee_email = $request->input('invitee_email');
|
|
$inviter_email = $request->input('inviter_email');
|
|
$status = $request->input('status');
|
|
|
|
$query = ReferralLog::with(['invitee:id,email', 'inviter:id,email'])->orderBy('status')->latest();
|
|
|
|
if(isset($invitee_email)){
|
|
$query->whereHas('invitee', static function($q) use ($invitee_email) {
|
|
$q->where('email', 'like', '%'.$invitee_email.'%');
|
|
});
|
|
}
|
|
|
|
if(isset($inviter_email)){
|
|
$query->whereHas('inviter', static function($q) use ($inviter_email) {
|
|
$q->where('email', 'like', '%'.$inviter_email.'%');
|
|
});
|
|
}
|
|
|
|
if(isset($status)){
|
|
$query->whereStatus($status);
|
|
}
|
|
|
|
$view['list'] = $query->paginate(15)->appends($request->except('page'));
|
|
|
|
return Response::view('admin.affiliate.userRebateList', $view);
|
|
}
|
|
}
|