From 04102f7237efefa744090ed7c25f7b5d0807b679 Mon Sep 17 00:00:00 2001
From: quanwei <419654421@qq.com>
Date: Thu, 05 Feb 2026 18:11:57 +0800
Subject: [PATCH] 完成运营中心提现和运营中心权限管理
---
admin/app/common/model/plus/vip/User.php | 102 ++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 101 insertions(+), 1 deletions(-)
diff --git a/admin/app/common/model/plus/vip/User.php b/admin/app/common/model/plus/vip/User.php
index b2b0bc2..84abd66 100644
--- a/admin/app/common/model/plus/vip/User.php
+++ b/admin/app/common/model/plus/vip/User.php
@@ -166,7 +166,9 @@
]);
}
-
+ /**
+ * 获取用户是否符合复购专区佣金条件
+ */
public function getViewpointMoneyQualification($user_id,$setting)
{
$userNum=$this->where('referee_id','=',$user_id)->count();
@@ -183,4 +185,102 @@
}
return false;
}
+ /**
+
+ * 获取用户所有级差上级
+
+ */
+
+ public static function getAllJcUser($user_id, $jcUser = [], $percent_total = 0, $is_add = true)
+
+ {
+
+ $user = User::detail($user_id);
+ $is_add && $percent_total += $user['grade']['differential_prize'] - $percent_total;
+ if($user['referee_id']) {
+ $is_add = false;
+ $parent = User::detail($user['referee_id']);
+ if (!$parent){
+ return $jcUser;
+ }
+ if ($parent['grade']['weight'] > $user['grade']['weight'] && $parent['grade']['differential_prize'] > $percent_total) {
+ $jcUser[] = [
+ 'user_id' => $parent['user_id'],
+ 'bonus_percent' => $parent['grade']['differential_prize'] - $percent_total //分红比例
+ ];
+ $is_add = true;
+
+ }
+ if($parent['user_id']) {
+ return self::getAllJcUser($parent['user_id'], $jcUser, $percent_total, $is_add);
+ }
+
+ }
+ return $jcUser;
+
+ }
+
+ /**
+
+ * 获取用户所有平级
+
+ * 每个级别都发放$pjaward_level层平级奖
+
+ */
+
+ public static function getAllPjUser($user_id, $pjaward_level, $pjUser = [])
+
+ {
+
+ $user = User::detail($user_id);
+ $pj_user[$user['grade_id']][] = [];
+ $pj_user = self::getPjUser($user_id, $pj_user);
+ if ($pj_user) {
+ foreach ($pj_user as $u) {
+ foreach ($u as $k => $item) {
+ if ($k > 0 && $k <= $pjaward_level) {
+ $pjUser[] = $item;
+ }
+ }
+ }
+
+ }
+ return $pjUser;
+
+ }
+ /**
+
+ * 获取所有平级
+
+ */
+
+ private static function getPjUser($user_id, $pj_user = [])
+
+ {
+
+ $user = User::detail($user_id);
+ if($user['referee_id']) {
+ $parent = User::detail($user['referee_id']);
+ if (!$parent){
+ return $pj_user;
+ }
+ // 记录平级用户
+ if($parent && $parent['grade']['weight'] >= $user['grade']['weight']) {
+ if ( $parent['grade']['equal_level_award']){
+ $pj_user[$parent['grade_id']][] = [
+ 'user_id' => $parent['user_id'],
+ 'bonus_percent' => $parent['grade']['equal_level_award'], // 平级分红比例
+ ];
+ }
+ }
+ if($parent['referee_id']) {
+ return self::getPjUser($parent['user_id'], $pj_user);
+
+ }
+
+ }
+
+ return $pj_user;
+
+ }
}
\ No newline at end of file
--
Gitblit v1.9.2