|
|
|
|
<?php
|
|
|
|
|
namespace Admin\Event;
|
|
|
|
|
|
|
|
|
|
use Think\Controller;
|
|
|
|
|
|
|
|
|
|
class MarketEvent extends Controller
|
|
|
|
|
{
|
|
|
|
|
private $MarketDepartmentId = "1,2";
|
|
|
|
|
private $ManagerLevel = "4";
|
|
|
|
|
private $DirectorLevel = "5";
|
|
|
|
|
private $LevelConfig = [
|
|
|
|
|
'1'=>'初级',
|
|
|
|
|
'2'=>'中级',
|
|
|
|
|
'3'=>'高级',
|
|
|
|
|
'4'=>'经理'
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 获取所有市场部组id
|
|
|
|
|
*/
|
|
|
|
|
public function getMarketGroupId()
|
|
|
|
|
{
|
|
|
|
|
$res = M('department','sys_')->where("id in ({$this->MarketDepartmentId})")->getField("group_ids",true);
|
|
|
|
|
$sendData = '';
|
|
|
|
|
foreach ($res as $value) {
|
|
|
|
|
$sendData .= $value.",";
|
|
|
|
|
}
|
|
|
|
|
return rtrim($sendData,",");
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* 获取市场专员gid(除了总监)
|
|
|
|
|
*/
|
|
|
|
|
public function getNoLeaderMarketGroupId()
|
|
|
|
|
{
|
|
|
|
|
$where = [
|
|
|
|
|
"department_id"=>['in',$this->MarketDepartmentId],
|
|
|
|
|
"department_level"=>['neq',$this->DirectorLevel]
|
|
|
|
|
];
|
|
|
|
|
$dbres = M('auth_group','sys_')->where($where)->getField("id",true);
|
|
|
|
|
return implode(",",$dbres);
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* 获取普通的市场专员(初中高)的gid
|
|
|
|
|
*/
|
|
|
|
|
public function getGeneralMarketGroup()
|
|
|
|
|
{
|
|
|
|
|
$where = [
|
|
|
|
|
"department_id"=>['in',$this->MarketDepartmentId],
|
|
|
|
|
"department_level"=>['LT',4]
|
|
|
|
|
];
|
|
|
|
|
$dbres = M('auth_group','sys_')->where($where)->getField("id",true);
|
|
|
|
|
return implode(",",$dbres);
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* 获取经理信息
|
|
|
|
|
*/
|
|
|
|
|
public function getManagerPerformanInfo()
|
|
|
|
|
{
|
|
|
|
|
$where = [
|
|
|
|
|
"department_id"=>['in',$this->MarketDepartmentId],
|
|
|
|
|
"department_level"=>['eq',$this->ManagerLevel]
|
|
|
|
|
];
|
|
|
|
|
$dbres = M('auth_group','sys_')->where($where)->getField("id",true);
|
|
|
|
|
$market = M("auth_group_access")
|
|
|
|
|
->alias("acc")
|
|
|
|
|
->where(["acc.group_id"=>['in',$dbres]])
|
|
|
|
|
->join("sys_member as mem on acc.uid = mem.uid")
|
|
|
|
|
->join("sys_auth_group as gro on acc.group_id = gro.id")
|
|
|
|
|
->getField("acc.uid,mem.nickname,mem.real_name,gro.department_id,gro.market_percentage",true);
|
|
|
|
|
return $market;
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* 获取配置信息
|
|
|
|
|
* @param [string] $key
|
|
|
|
|
* @return void
|
|
|
|
|
*/
|
|
|
|
|
public function getConfig($key)
|
|
|
|
|
{
|
|
|
|
|
return $this->$key;
|
|
|
|
|
}
|
|
|
|
|
public function getLevelName($level)
|
|
|
|
|
{
|
|
|
|
|
return $this->LevelConfig[$level];
|
|
|
|
|
}
|
|
|
|
|
public function isMarketAdminGroup($gid)
|
|
|
|
|
{
|
|
|
|
|
$where = [
|
|
|
|
|
"department_id"=>['in',$this->MarketDepartmentId],
|
|
|
|
|
"id"=>$gid
|
|
|
|
|
];
|
|
|
|
|
return M('auth_group','sys_')->field("id,department_id,department_level")->where($where)->find();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function isDepartmentLeder($department_id,$uid)
|
|
|
|
|
{
|
|
|
|
|
$gid = M("auth_group_access")->where("uid = '{$uid}'")->getField('group_id');
|
|
|
|
|
return M('department','sys_')->where("id = '{$department_id}' and leader_group = '$gid'")->field("id")->find();
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* 添加部门总监的会长权限
|
|
|
|
|
* $uid,$promote_id
|
|
|
|
|
*/
|
|
|
|
|
public function addPresident($uid,$promote_id)
|
|
|
|
|
{
|
|
|
|
|
$leader_group = M("auth_group_access")
|
|
|
|
|
->alias("acc")
|
|
|
|
|
->where(['acc.uid'=>$uid])
|
|
|
|
|
->join("sys_auth_group as gro on acc.group_id = gro.id")
|
|
|
|
|
->join("sys_department as dep on gro.department_id = dep.id")
|
|
|
|
|
->getField("dep.leader_group",1);
|
|
|
|
|
if(!$leader_group){
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
$info = M('auth_group','sys_')->where(['id'=>$leader_group])->find();
|
|
|
|
|
return M('auth_group','sys_')->where(['id'=>$leader_group])->save(['data_president'=>$info['data_president'].",".$promote_id]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function getDepartmentUserId($department_id)
|
|
|
|
|
{
|
|
|
|
|
$res = M("auth_group_access")
|
|
|
|
|
->alias("acc")
|
|
|
|
|
->field("acc.uid")
|
|
|
|
|
->where(['gro.department_id'=>$department_id])
|
|
|
|
|
->join("sys_member as mem on acc.uid = mem.uid")
|
|
|
|
|
->join("sys_auth_group as gro on acc.group_id = gro.id")
|
|
|
|
|
->select();
|
|
|
|
|
return array_column($res,'uid');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function getAdminCompanyId()
|
|
|
|
|
{
|
|
|
|
|
if (!empty(session('user_auth_company_ids'))) {
|
|
|
|
|
return session('user_auth_company_ids');
|
|
|
|
|
}
|
|
|
|
|
$userAuth = session('user_auth');
|
|
|
|
|
$companyIds = 'all';
|
|
|
|
|
$userAuth['data_president']= trim($userAuth['data_president'], ",");
|
|
|
|
|
if (!empty($userAuth['data_empower_type'])) {//数据权限 1 全部 2 部分数据 3 自己底下的会长
|
|
|
|
|
//等于1默认全部数据,不进行筛选
|
|
|
|
|
if (in_array($userAuth['data_empower_type'], [2, 3])) {
|
|
|
|
|
$companyIds = '';
|
|
|
|
|
//自己创建的会长
|
|
|
|
|
$myPromote_ids = M('promote', 'tab_')
|
|
|
|
|
->field('GROUP_CONCAT(id) as promote_ids')
|
|
|
|
|
->where(['admin_id' => $userAuth['uid']])
|
|
|
|
|
->find();
|
|
|
|
|
$myPromote_ids = $myPromote_ids['promote_ids'];
|
|
|
|
|
if ($myPromote_ids) {
|
|
|
|
|
if ($userAuth['data_empower_type'] == 2) {//部分会长加上自己创建的会长
|
|
|
|
|
|
|
|
|
|
// $userAuth['data_president'] .= "," . $myPromote_ids;
|
|
|
|
|
} elseif ($userAuth['data_empower_type'] == 3) {//自己创建的会长和底下推广员
|
|
|
|
|
$userAuth['data_president'] = $myPromote_ids;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
$dbres = M('promote', 'tab_')
|
|
|
|
|
->field('company_id')
|
|
|
|
|
->where(['id' =>['in',$userAuth['data_president']],'level'=>1])
|
|
|
|
|
->group('company_id')
|
|
|
|
|
->getField('company_id',true);
|
|
|
|
|
$companyIds = implode(",",$dbres);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
session('user_auth_company_ids', $companyIds);
|
|
|
|
|
return $companyIds;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|