user['id'])->where('status', 0)->count() >= admin_setting('invite_gen_limit', 5)) { return $this->fail([400,__('The maximum number of creations has been reached')]); } $inviteCode = new InviteCode(); $inviteCode->user_id = $request->user['id']; $inviteCode->code = Helper::randomChar(8); return $this->success($inviteCode->save()); } public function details(Request $request) { $current = $request->input('current') ? $request->input('current') : 1; $pageSize = $request->input('page_size') >= 10 ? $request->input('page_size') : 10; $builder = CommissionLog::where('invite_user_id', $request->user['id']) ->where('get_amount', '>', 0) ->select([ 'id', 'trade_no', 'order_amount', 'get_amount', 'created_at' ]) ->orderBy('created_at', 'DESC'); $total = $builder->count(); $details = $builder->forPage($current, $pageSize) ->get(); return response([ 'data' => $details, 'total' => $total ]); } public function fetch(Request $request) { $codes = InviteCode::where('user_id', $request->user['id']) ->where('status', 0) ->get(); $commission_rate = admin_setting('invite_commission', 10); $user = User::find($request->user['id']); if ($user->commission_rate) { $commission_rate = $user->commission_rate; } $uncheck_commission_balance = (int)Order::where('status', 3) ->where('commission_status', 0) ->where('invite_user_id', $request->user['id']) ->sum('commission_balance'); if (admin_setting('commission_distribution_enable', 0)) { $uncheck_commission_balance = $uncheck_commission_balance * (admin_setting('commission_distribution_l1') / 100); } $stat = [ //已注册用户数 (int)User::where('invite_user_id', $request->user['id'])->count(), //有效的佣金 (int)CommissionLog::where('invite_user_id', $request->user['id']) ->sum('get_amount'), //确认中的佣金 $uncheck_commission_balance, //佣金比例 (int)$commission_rate, //可用佣金 (int)$user->commission_balance ]; $data = [ 'codes' => $codes, 'stat' => $stat ]; return $this->success($data); } }