You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

159 lines
5.9 KiB
PHTML

5 years ago
<?php
namespace Admin\Model;
use Think\Model;
/**
* 文档基础模型
*/
class BusinessAffairsModel extends Model{
/* 自动验证规则 */
protected $_validate = array(
array('account', '6,16', '商务专员账号长度为6-16个字符', self::EXISTS_VALIDATE, 'length'),
array('account','','账号被占用',0,'unique',1),
/* 验证密码 */
array('password','require', "请输入登录密码", self::EXISTS_VALIDATE, 'regex'), //密码长度不合法
array('password','6,30', "密码长度不合法", self::EXISTS_VALIDATE, 'length'), //密码长度不合法
array('sw_name', 'require', '请输入姓名', self::EXISTS_VALIDATE, 'regex'),
array('sw_name', '1,16', '姓名长度为1-16个字符', self::EXISTS_VALIDATE, 'length'),
array('phone','require','请输入联系电话','0','regex',1),
array('phone','/^1[3|4|5|7|8][0-9]\d{4,8}$/','联系电话错误!','0','regex',1),
);
/* 自动完成规则 */
protected $_auto = array(
array('password', 'think_ucenter_md5', self::MODEL_BOTH, 'function', UC_AUTH_KEY),
array('create_time', 'getCreateTime', self::MODEL_INSERT,'callback'),
array('inferiors', 0, self::MODEL_INSERT),
array('promote_id', 0, self::MODEL_INSERT),
);
/**
* 构造函数
* @param string $name 模型名称
* @param string $tablePrefix 表前缀
* @param mixed $connection 数据库连接信息
*/
public function __construct($name = '', $tablePrefix = '', $connection = '') {
/* 设置默认的表前缀 */
$this->tablePrefix ='tab_';
/* 执行构造方法 */
parent::__construct($name, $tablePrefix, $connection);
}
public function sw_add($add_data=array()){
$data = array(
'account' => $add_data['account'],
'password' => $add_data['password'],
'sw_name' => $add_data['sw_name'],
'phone' => $add_data['phone'],
'qq' => $add_data['qq'],
'inferiors' => $add_data['inferiors'],
'status' => $add_data['status'],
'create_time' => NOW_TIME,
);
/* 添加用户 */
$result = $this->create($data);
if($result){
$uid = $this->add();
return $uid ? $uid : 0; //0-未知错误大于0-注册成功
} else {
return $this->getError(); //错误详情见自动验证注释
}
}
public function add_child($id,$promote_id){
$data = $this->field("promote_id")->find($id);
if($data['promote_id'] == 0 || $data['promote_id']=="" || $data["promote_id"] == null){
$field = $promote_id;
}else{
$field = $data['promote_id'].",".$promote_id;
$this->where("id=".$id)->setInc("inferiors",1);
}
$this->where("id=".$id)->setField('promote_id',$field);
}
/**
*修改商务专员旗下推广员数量
*/
public function update_child($id=0,$new_id=null,$promote_id=null){
$p_ids = array();
5 years ago
$data_child = D('Promote')->where("chain like '%/{$promote_id}/%'")->getField('id',true);
5 years ago
if(empty($data_child)){
$p_ids[0] = $promote_id;
}else{
array_unshift($data_child,$promote_id);
$p_ids = $data_child;
}
if($id != 0){
$ba_old_ids = $this->where('id='.$id)->getField('promote_id');
$ba_old_ids = explode(",",$ba_old_ids);
$ba_old_ids = array_diff($ba_old_ids,$p_ids);
if(empty($ba_old_ids)){
$ba_old_ids[0] = 0;
}
$this->where("id=".$id)->setField('promote_id', implode(",", $ba_old_ids));
$this->where("id=".$id)->setDec("inferiors",count($p_ids));
}
$ba_new_ids = $this->where("id=".$new_id)->getField('promote_id');
if(empty($ba_new_ids)){
$ba_new_ids = $p_ids;
}else{
$ba_new_ids = explode(",", $ba_new_ids);
array_push($ba_new_ids,$p_ids);
}
5 years ago
D('Promote')->where("chain like '%/{$promote_id}/%'")->setField('ba_id',$new_id);
5 years ago
$this->where("id=".$new_id)->setField('promote_id', implode(",", $ba_new_ids));
$this->where("id=".$new_id)->setInc("inferiors",count($p_ids));
}
/**
*删除商务专员旗下推广员
*/
public function del_child($ba_id = 0,$promote_ids = 0){
//查找所有父级和子级id array_unique
$pMap['parent_id'] = array("IN",$promote_ids);
$data_child = D('Promote')->where($pMap)->getField('id',true);
if(empty($data_child)){
$p_ids = $promote_ids;
}else{
$p_ids = array_merge($data_child,$promote_ids);
$p_ids = array_unique($p_ids);
}
$num = count($p_ids);
$ba_promote_id_new = $this->where('id = '.$ba_id)->getField('promote_id');
$ba_promote_id_new = explode(",", $ba_promote_id_new);
$ba_promote_id_new = array_diff($ba_promote_id_new,$p_ids);
if(empty($ba_promote_id_new)){
$ba_promote_id_new[0] = 0;
}
$setPromoteMap['id'] = array('IN',$p_ids);
$promote = D('Promote')->where($setPromoteMap)->setField(array('ba_id'=>0));
$baMap['id'] = $ba_id;
if($ba_promote_id_new[0] == 0){
$ba = $this->where($baMap)->setField('inferiors',0);
}else{
$ba = $this->where($baMap)->setDec('inferiors',$num);
}
$ba_p = $this->where($baMap)->setField(array('promote_id'=>implode(",", $ba_promote_id_new)));
}
/**
* 创建时间不写则取当前时间
* @return int 时间戳
* @author huajie <banhuajie@163.com>
*/
protected function getCreateTime(){
$create_time = I('post.create_time');
return $create_time?strtotime($create_time):NOW_TIME;
}
}