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
PHP

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

<?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();
$data_child = D('Promote')->where("chain like '%/{$promote_id}/%'")->getField('id',true);
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);
}
D('Promote')->where("chain like '%/{$promote_id}/%'")->setField('ba_id',$new_id);
$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;
}
}