quanwei
18 hours ago c441dea81bd86bdfb12dff35821fed51f4cc91c2
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
<?php
 
namespace app\operations\model\plus\agent;
 
use app\common\model\plus\agent\Referee as RefereeModel;
 
/**
 * 分销商用户模型
 */
class Referee extends RefereeModel
{
    /**
     * 获取下级团队成员ID集
     */
    public function getTeamUserIds($agentId, $level = -1)
    {
        $level > -1 && $this->where('m.level', '=', $level);
        return $this->alias('m')
            ->join('user', 'user.user_id = m.user_id')
            ->where('m.agent_id', '=', $agentId)
            ->where('user.is_delete', '=', 0)
            ->column('m.user_id');
    }
 
 
    /**
     * 获取指定用户的推荐人列表
     */
    public static function getRefereeList($userId)
    {
        return (new static)->with(['agent1'])->where('user_id', '=', $userId)->select();
    }
 
    /**
     * 清空下级成员推荐关系
     */
    public function onClearTeam($agent_id, $level = -1)
    {
        $model = $this;
        if($level > -1){
            $model = $model->where('level', '=', $level);
        }
        return $model->where('agent_id', '=', $agent_id)->delete();
    }
 
    /**
     * 清空上级推荐关系
     */
    public function onClearReferee($userId, $level = -1)
    {
        $model = $this;
        if($level > -1) {
            $model = $model->where('level', '=', $level);
        }
        return $model->where('user_id', '=', $userId)->delete();
    }
 
    /**
     * 清空2-3级推荐人的关系记录
     */
    public function onClearTop($teamIds)
    {
        return $this->where('user_id', 'in', $teamIds)
            ->where('level', 'in', [2, 3])
            ->delete();
    }
}