'未审核',
'1'=>'已审核',
'2'=>'被举报',
'3'=>'未通过'
);
public $resume_status_arr = array(
'1'=>'公开',
'2'=>'隐藏',
'3'=>'仅投递企业可见'
);
public $resume_rstatus_arr = array(
'0'=>'未审核',
'1'=>'已审核',
'2'=>'账户被锁定',
'3'=>'未通过'
);
/* 查询数量 */
function getResumeNum($Where=array()){
return $this->select_num('resume',$Where);
}
/* 查询简历数 */
function getExpectNum($Where=array()){
return $this->select_num('resume_expect',$Where);
}
/**
* 通过uid查询单条简历。有默认简历返回默认简历;没有默认简历,返回最近更新的简历
*/
function getExpectByUid($uid = '', $data = array()){
$expect = $this->getExpect(array('uid'=>$uid,'defaults'=>1), $data);
if (empty($expect)){
$expect = $this->getExpect(array('uid'=>$uid,'orderby'=>'`id`'), $data);
}
return $expect;
}
private function addErrorLog($uid,$type='',$content) {
require_once ('errlog.model.php');
$ErrlogM = new errlog_model($this->db, $this->def);
return $ErrlogM -> addErrorLog($uid, $type, $content);
}
/**
* @desc 引用log类,添加用户日志
*/
private function addMemberLog($uid,$usertype,$content,$opera='',$type='') {
require_once ('log.model.php');
$LogM = new log_model($this->db, $this->def);
return $LogM -> addMemberLog($uid,$usertype,$content,$opera,$type);
}
/**
* 批量查个人基本信息
* @param array $whereData
* @param string $field
*/
function getResumeList($whereData, $data = array('field' => null, 'utype'=>null)){
$field = $data['field'] ? $data['field'] : '*';
$List = $this->select_all('resume', $whereData, $field);
$cache = $this->getClass(array('user'));
//所获列表数据是否要对下载后的简历信息处理
$downuids = array();
if(!empty($data['downresume_where'])){
$dresume = $this -> select_all('down_resume',$data['downresume_where'],'`uid`');
foreach($dresume as $dv){
$downuids[] = $dv['uid'];
}
}
foreach ($List as $k => $v) {
$photoArr = array('photo' => $v['photo'],'defphoto' => $v['defphoto'], 'phototype'=> $v['phototype'], 'photo_status' => $v['photo_status'], 'sex' => $v['sex']);
if($v['photo']){
$List[$k]['photo_o'] = $v['photo'];
}
if ($data['utype'] == 'admin'){
$List[$k]['photo'] = checkpic($v['photo']);
}else{
$List[$k]['photo'] = $this -> setResumePhotoShow($photoArr);
}
//已下载过的简历呈现给商家时为原名
if(!empty($data['downresume_where']) && !empty($downuids) && in_array($v['uid'], $downuids)){
$List[$k]['name_n'] = $v['name'];
}else{
$nameArr = array('nametype' => $v['nametype'], 'name' => $v['name'], 'eid' => $v['def_job'], 'sex' => $v['sex']);
$List[$k]['name_n'] = $this -> setUsernameShow($nameArr);
}
$List[$k]['username_n'] = $v['name'];
unset($List[$k]['name']);
if ($v['marriage']) {
$List[$k]['marriage_n'] = $cache['userclass_name'][$v['marriage']];
}
if ($v['sex']) {
$List[$k]['sex_n'] = $cache['user_sex'][$v['sex']];
}
if ($v['edu']) {
$List[$k]['edu_n'] = $cache['userclass_name'][$v['edu']];
}
if ($v['exp']) {
$List[$k]['exp_n'] = $cache['userclass_name'][$v['exp']];
}
if ($v['birthday']) {
$List[$k]['age_n'] = date('Y') - date('Y',strtotime($v['birthday']));
}
if ($v['idcard_pic']) {
$List[$k]['idcard_pic'] = checkpic($v['idcard_pic']);
}
if ($v['tag']) {
$List[$k]['tag_arr'] = @explode(',',$v['tag']);
}
$List[$k]['email_status_n'] = $v['email_status'];
$List[$k]['moblie_status'] = $v['moblie_status'];
$List[$k]['idcard_status'] = $v['idcard_status'];
$List[$k]['idcard'] = $v['idcard'];
}
if ($data['utype']=='admin') {
$List = $this->getDataUserList($List);
}
return $List;
}
/**
* @desc 获取resume_expect 列表,简单的查询返回,复杂的,访问getList方法
*
* @param $whereData 查询条件
* @param array $data 自定义处理数组
* @return array|bool|false|string|void
*/
public function getSimpleList($whereData, $data = array())
{
$data['field'] = empty($data['field']) ? '*' : $data['field'];
$List = $this->select_all('resume_expect', $whereData, $data['field']);
foreach ($List as $k => $v) {
$List[$k]['lastupdate'] = date('Y-m-d H:i:s', $v['lastupdate']);
}
return $List;
}
//搜索筛选-简历列表
public function searchList($data){
$uid = $data['uid'];
$usertype = $data['usertype'];
unset($data['uid']);
unset($data['usertype']);
$_POST = $data;
$where = "a.`state`=1 AND a.`r_status`=1 AND a.`defaults`=1 AND a.`status`=1";
$page = $_POST['page'];
$limit = $_POST['limit'];
$time = time();
$CacheArr = $this -> getClass(array('user','city'));
if($_POST['exp']){
$expArr = $CacheArr['userdata']['user_word'];
$expIds = [];
foreach ($expArr as $key => $value) {
if ($value == $_POST['exp']) {
$expIds = array_slice($expArr, $key);
break;
}
}
sort($expIds);
if ($expIds) {
$where .= " AND a.`exp` in (".implode(",",$expIds).")";
}
}
//性别
if($_POST['sex']){
$where .= " AND a.`sex`='".$_POST['sex']."'";
}
if($_POST['edu']){
$eduArr = $CacheArr['userdata']['user_edu'];
$eduIds = [];
foreach ($eduArr as $key => $value) {
if ($value == $_POST['edu']) {
$eduIds = array_slice($eduArr, $key);
break;
}
}
sort($eduIds);
if ($eduIds) {
$where .= " AND a.`edu` in (".implode(",", $eduIds).")";
}
}
if($_POST['type']){
$where .= " AND a.`type`='".$_POST['type']."'";
}
if($_POST['report']){
$where .= " AND a.`report`='".$_POST['report']."'";
}
if($_POST['rec_resume']){
$where .= " AND a.`rec_resume`=1";
}
if($_POST['integrity']){
include(CONFIG_PATH.'db.data.php');
$integrity_val = $arr_data['integrity_val'];
$integrity = $integrity_val[$_POST['integrity']];
$where .= " AND a.`integrity`>='".$integrity."'";
}
if($_POST['tag']){
$tagname=$CacheArr['userclass_name'][$_POST['tag']];
$rwhere['def_job'] = array('>',0);
$rwhere['r_status'] = 1;
$rwhere['status'] = 1;
$rwhere['tag'] = array('findin',$tagname);
$tag = $this->select_all("resume",$rwhere,"`def_job`");
if(is_array($tag)){
foreach($tag as $v){
$tagid[]=$v['def_job'];
}
}
$where .= " AND a.`id` in (".pylode(",",$tagid).")";
}
if($_POST['uptime']){
if($_POST['uptime']==1){
$beginToday = strtotime(date('Y-m-d 00:00:00'));
$where .= " AND a.`lastupdate`>$beginToday";
}else{
$uptime = time()-($_POST['uptime']*86400);
$where .= " AND a.`lastupdate`>$uptime";
}
}else{
if($this->config['sy_datacycle']>0){
// 后台-页面设置-数据周期
$uptime = strtotime('-'.$this->config['sy_datacycle'].' day');
$where.=" AND a.`lastupdate`>$uptime";
}
}
$cjwhere = '1';
$job_col = $city_col = '';
if($_POST['three_cityid']){
$city_col = "three_cityid";
$cjwhere .= " AND `$city_col`= $_POST[three_cityid]";
}elseif($_POST['cityid']){
$city_col = "cityid";
$cjwhere .= " AND `$city_col`= $_POST[cityid]";
}elseif($_POST['provinceid']){
$city_col = "provinceid";
$cjwhere .= " AND `$city_col`= $_POST[provinceid]";
}
if($_POST['job_post']){
$job_col = "job_post";
$cjwhere .= " AND `$job_col`= $_POST[job_post]";
}elseif($_POST['job1_son']){
$job_col = "job1_son";
$cjwhere .= " AND `$job_col`= $_POST[job1_son]";
}elseif($_POST['job1']){
$job_col = "job1";
$cjwhere .= " AND `$job_col`= $_POST[job1]";
}
if ($_POST['keyword']){
$keyword = $_POST['keyword'];
$where1[] = "a.`name` LIKE '%$keyword%'";
$where1[] = "a.`uname` LIKE '%$keyword%'";
$cityid = array();
foreach($CacheArr['city_name'] as $k=>$v){
if(strpos($v,$keyword)!==false){
$cityid[] = $k;
}
}
//只取匹配到的第一个城市,已选省则匹配省下面的城市、未选择城市则按关键字匹配城市
if(!empty($cityid)){
$ckwhere['PHPYUNBTWSTART_A'] = '';
$ckwhere['cityid'] = array('in',pylode(',',$cityid),'OR');
$ckwhere['three_cityid'] = array('in',pylode(',',$cityid),'OR');
$ckwhere['PHPYUNBTWEND_A'] = '';
$cityresume = $this->select_all("resume_cityclass",$ckwhere);
if($cityresume){
$rc = array();
foreach ($cityresume as $v){
$rc[] = $v['eid'];
}
$where1[] = 'a.`id` IN ('.pylode(',', $rc).')';
}
}
//搜索工作经历
$workList = $this->select_all('resume_work', array('title'=>array('like',$keyword), 'content'=>array('like',$keyword, 'OR'),'orderby'=>'id', 'limit'=>500), 'eid');
if(!empty($workList)){
$workId = array();
foreach($workList as $v){
$workId[] = $v['eid'];
}
$where1[] = 'a.`id` IN ('.pylode(',', $workId).')';
}
$where .= " AND (".@implode(" or ",$where1).")";
}
if(!empty($_POST['zdids'])){
$where .= " AND a.`id` not in (".pylode(',',$_POST['zdids']).")";
}
$order = " order by a.`lastupdate` desc";
if($page){//分页
$pagenav = ($page-1)*$limit;
$resumelimit=" limit $pagenav,$limit";
}else{
$resumelimit=" limit $limit";
}
// 拼接唯一标识字段
if($city_col || $job_col){
if($city_col && $job_col){
$cjwhere .= " AND `{$city_col}_{$job_col}_num`= 1";
}elseif($city_col){
$cjwhere .= " AND `{$city_col}_num`= 1";
}elseif($job_col){
$cjwhere .= " AND `{$job_col}_num`= 1";
}
}
$pagewhere = "";
$joinwhere = "";
if($cjwhere != '1'){
$pagewhere .= " ,(select `eid` from `".$this->def."resume_city_job_class` where ".$cjwhere." group by `eid`) cj";
$joinwhere .= " a.`id`=cj.`eid` and ";
}
$select = "a.`id`,a.`uid`,a.`name`,a.`hy`,a.`job_classid`,a.`city_classid`,a.`jobstatus`,a.`type`,a.`photo`,a.`report`,a.`lastupdate`,a.`rec`,a.`top`,a.`topdate`,a.`rec_resume`,a.`ctime`,a.`uname`,a.`idcard_status`,a.`minsalary`,a.`maxsalary`,a.`topdate`";
if($pagewhere!=""){
$sql = "select ".$select." from `".$this->def."resume_expect` a ".$pagewhere." where ".$joinwhere.$where.$order.$resumelimit;
}else{
$sql = "select ".$select." from `".$this->def."resume_expect` a where ".$where.$order.$resumelimit;
}
$rows = $this->DB_query_all($sql,'all');
if($rows&&is_array($rows)){
if ($page==1){
$zdids = array();
$where .= ' AND a.`top`=1 AND a.`topdate`>"'.$time.'"';
if($pagewhere!=""){
$sql = "select ".$select." from `".$this->def."resume_expect` a ".$pagewhere." where ".$joinwhere.$where.' ORDER BY rand() limit 5';
}else{
$sql = "select ".$select." from `".$this->def."resume_expect` a where ".$where.' ORDER BY rand() limit 5';
}
$topresume = $this->DB_query_all($sql,'all');
if ($topresume){
foreach($rows as $k=>$v){
foreach ($topresume as $val){
if($v['id']==$val['id']){
unset($rows[$k]);
}
}
}
foreach ($topresume as $v){
$zdids[] = $v['id'];
array_unshift($rows,$v);
}
}
}
}
$data['row']=$rows;
$data['zdids']=$zdids;
return $data;
}
/**
* 简历列表
* @param array $whereData
* @param array $data field:查询字段;
'utype':列表显示位置,不同的位置可能有不同的需求 ;
'cache':页面需要传回缓存 多条数据查询合并,
withResumeFiled:联合resume表 多条数据查询合并时查询resume表的字段
downresume_where:在联合resume表查询时,查询down_resume表的条件
search:列表搜索的post值,主要用于列表搜索筛选
*/
public function getList($whereData,$data=array('utype'=>'')){
$ListNew = array();
$field = $data['field'] ? $data['field'] : '*';
if(!empty($data['search'])){
$rdata = $this -> searchList($data['search']);
$List = $rdata['row'];
$zdids = $rdata['zdids'];
}elseif(!empty($data['sql'])){
$List = $this->DB_query_all($data['sql'], 'all');
}else{
$List = $this -> select_all('resume_expect',$whereData,$field);
}
if(!empty($List)){
//真正的列表查询,需要处理列表数据,一般的简单查询,不需要处理
$time = time();
$cache = $this -> getClass(array('user','city','hy','job'));
foreach($List as $k=>$v){
$euids[] = $v['uid'];
$List[$k]['age_n'] = date('Y') - date('Y',strtotime($v['birthday']));
$List[$k]['hy_n'] = $cache['industry_name'][$v['hy']] ? $cache['industry_name'][$v['hy']] : '不限';
$List[$k]['sex_n'] = $cache['user_sex'][$v['sex']];
$List[$k]['edu_n'] = $cache['userclass_name'][$v['edu']];
$List[$k]['exp_n'] = $cache['userclass_name'][$v['exp']];
$List[$k]['report_n'] = $cache['userclass_name'][$v['report']];
$List[$k]['type_n'] = $cache['userclass_name'][$v['type']];
if($v['lastupdate']){
$ltime = $v['lastupdate'];
//今天开始时间戳
$beginToday = strtotime('today');
//昨天开始时间戳
$beginYesterday = strtotime('yesterday');
//一周内时间戳
if($ltime>$beginYesterday && $ltime<$beginToday){
$List[$k]['lastupdate_n'] = "昨天";
}elseif($ltime>$beginToday){
$List[$k]['lastupdate_n'] = lastupdateStyle($ltime);
}else{
$List[$k]['lastupdate_n'] = date("Y-m-d",$ltime);
}
}
if(isset($v['ctime'])){
$todaystart = strtotime('today');
$beforeYesterday = $todaystart - 86400 * 2;
if($v['ctime']>$beforeYesterday){
$List[$k]['newtime'] = 1;
}
}
//处理薪资
if($v['minsalary'] && $v['maxsalary']){
if($this ->config['resume_salarytype']==1){
$List[$k]['salary'] = $v['minsalary'].'-'.$v['maxsalary'].'元';
}else{
if($v['maxsalary']<1000){
if($this->config['resume_salarytype']==2){
$List[$k]['salary'] = '1千以下';
}elseif($this->config['resume_salarytype']==3){
$List[$k]['salary'] = '1K以下';
}elseif($this->config['resume_salarytype']==4){
$List[$k]['salary'] = '1k以下';
}
}else{
$List[$k]['salary'] = changeSalary($v['minsalary']).'-'.changeSalary($v['maxsalary']);
}
}
}elseif ($v['minsalary']){
if($this ->config['resume_salarytype']==1){
$List[$k]['salary'] = $v['minsalary'];
}else{
$List[$k]['salary'] = changeSalary($v['minsalary']);
}
}elseif ($v['maxsalary']){
if($this ->config['resume_salarytype']==1){
$List[$k]['salary'] = $v['maxsalary'].'元';
}else{
$List[$k]['salary'] = changeSalary($v['maxsalary']);
}
}else{
$List[$k]['salary'] = '面议';
}
//处理职位类别id
if ($v['job_classid'] && $cache){
$job_classid = @explode(',',$v['job_classid']);
if(is_array($job_classid)){
$jobclassid = array();
$job_classname = array();
foreach($job_classid as $jv){
if($cache['job_name'][$jv]){
$jobclassid[] = $jv;
$job_classname[] = $cache['job_name'][$jv];
}
}
$List[$k]['job_classid'] = pylode(',',$jobclassid);
$List[$k]['job_classname'] = @implode(',',$job_classname);
}
}
//处理城市类别id
if ($v['city_classid'] && $cache){
$city_classid = @explode(',',$v['city_classid']);
if(is_array($city_classid)){
$cityclassid = array();
$city_classname = array();
foreach($city_classid as $cv){
if($cache['city_name'][$cv]){
$cityclassid[] = $cv;
$city_classname[] = $cache['city_name'][$cv];
}
}
$List[$k]['city_classid'] = pylode(',',$cityclassid);
$List[$k]['city_classname'] = @implode(' ',$city_classname);
}
}
//处理置顶天数
if($v['topdate'] > $time){
$List[$k]['top_day'] = ceil(($v['topdate']-$time)/86400);
}else{
$List[$k]['top_day'] = '0';
}
if (isset($v['photo'])){
$icon = $v['sex'] == 1 ? $this->config['sy_member_icon'] : $this->config['sy_member_iconv'];
$List[$k]['photo_n'] = checkpic($v['photo'], $icon);
}
if (isset($data['url'])){
$List[$k]['wapurl'] = Url('wap', array('c'=>'resume','a'=>'show','id'=>$v['id']));
}
}
//后台处理简历多城市/用户名、审核状态
if ($data['utype'] == 'admin'){
$List = $this -> getDataList($List,$cache);
}
//联合resume表 多条数据 查询合并
if ($data['withResumeField']){
$resumelist = $this -> getResumeList(
array('uid'=>array('in',pylode(',',$euids))),
array(
'field' => $data['withResumeField'],
'downresume_where' => $data['downresume_where']
)
);
foreach($List as $lk=>$lv){
foreach($resumelist as $rk=>$rv){
if($rv['uid']==$lv['uid']){
$List[$lk] = array_merge($lv,$rv);
}
}
}
}
//网络招聘会大厅简历列表、浏览简历列表类查询个人姓名使用
if ($data['utype'] == 'zphnet' || $data['utype'] == 'user'){
$List = $this -> getJlData($List);
}
if($data['workexp']){//学历与经验简化显示
$List = $this -> getWorkexpData($List);
}
$ListNew['list'] = $List;
//app简历列表返回第一页的置顶简历id数组集
if(isset($zdids) && !empty($zdids)){
$ListNew['zdids'] = $zdids;
}
//需要缓存的
if ($data['cache']){
$ListNew['cache'] = $cache;
}
}
return $ListNew;
}
function getWorkexpData($List){
$cache = $this -> getClass(array('user'));
$userclass_name = $cache['userclass_name'];
$eids = array();
foreach ($List as $lv){
$eids[] = $lv['id'];
}
if(!empty($eids)){
$eduList = $this-> select_all("resume_edu",array('eid'=>array('in',pylode(',',$eids))));
$workList = $this-> select_all("resume_work",array('eid'=>array('in',pylode(',',$eids))));
}
if(!empty($eduList)){
foreach($eduList as $key=>$value){
$eduListNew[$value['eid']][] = $value;
}
foreach($eduListNew as $k=>$eduv){
$edumin = 0;
$edumax = 0;
$edutitle = array();
$education = array();
foreach($eduv as $v){
$edumin = $v['sdate'];
if($v['edate']==0 ){
$edumax = 0;
}elseif($edumax<$v['edate']){
$edumax = $v['edate'];
}
$education[] = $userclass_name[$v['education']];
$edutitle[] = $v['specialty'];
}
$return = array();
$return['edumin'] = date('Y.m',$edumin);
$return['edumax'] = $edumax == 0 ? '至今': date('Y',$edumax);
$return['education']= @implode(',',$education);
$return['edu_time'] = $return['edumin']."-".$return['edumax'];
$return['eduspecialty'] = @implode('、',$edutitle);
if($return['eduspecialty']){
$workexpList[$k]['edu_content'] = $return['education'].'学历 ▪ '.$return['eduspecialty'].' ▪ 毕业于'.$return['edumax'].'年';
}else{
$workexpList[$k]['edu_content'] = $return['education'].'学历 ▪ 毕业于'.$return['edumax'].'年';
}
}
}
if(!empty($workList)){
foreach($workList as $key=>$value){
$workListNew[$value['eid']][] = $value;
}
foreach($workListNew as $k=>$workv){
$whour = 0;
$hour = array();
$time = time();
$workmin = 0;
$workmax = 0;
$worknum = count($workv);
$wtitle = array();
foreach($workv as $v){
if ($v['edate']){
$workTime = ceil(($v['edate']-$v['sdate'])/(30*86400));
}else{
$workTime = ceil(($time - $v['sdate'])/(30*86400));
}
/* 计算每份工作时长(按月) */
$workmin = $v['sdate'];
if($v['edate']==0 ){
$workmax = 0;
}elseif($workmax<$v['edate']){
$workmax = $v['edate'];
}
$wtitle[] = $v['title'];
$hour[] = $workTime;
$whour += $workTime;
}
$workavg = ceil($whour/count($hour));
$return = array();
$return['worknum'] = $worknum > 0 ? $worknum:0;
$return['workavg'] = $workavg > 11 ? avgToYm($workavg) : $workavg;
$return['workmin'] = date('Y.m',$workmin);
$return['workmax'] = $workmax == 0 ? '至今': date('Y.m',$workmax);
$return['worktit'] = @implode(',',$wtitle);
$return['work_time'] = $return['workmin'].'-'.$return['workmax'];
if($return['workavg']>0){
if($return['worktit']!=''){
$workexpList[$k]['work_content'] = ' 参加过'.$return['worknum'].'份工作 ▪ 涉及'.$return['worktit'].'等岗位';
}else{
$workexpList[$k]['work_content'] = '参加过'.$return['worknum'].'份工作';
}
}
}
}
if(!empty($workexpList)){
foreach ($List as $k=>$v){
$List[$k]['work_content'] = '';
$List[$k]['edu_content'] = '';
foreach($workexpList as $wk=>$wv){
if($wk==$v['id']){
$List[$k]['work_content'] = $wv['work_content'] ? $wv['work_content'] : '';
$List[$k]['edu_content'] = $wv['edu_content'] ? $wv['edu_content'] : '';
}
}
}
}
return $List;
}
/**
* @desc 获取resume 详情 ; 简单的查询返回,复杂的,访问getInfo方法
* @param $whereData 查询条件
* @param null[] $data 自定义处理数组
* @return array|bool|false|string|void
*/
public function getResumeInfo($whereData, $data = array('logo'=>null))
{
$data['field'] = empty($data['field']) ? '*' : $data['field'];
$resumeInfo = $this -> select_once('resume', $whereData, $data['field']);
if(!empty($resumeInfo)){
$cache = $this -> getClass('user');
$userclass_name = $cache['userclass_name'];
if($resumeInfo['birthday']){
$a = date('Y',strtotime($resumeInfo['birthday']));
$resumeInfo['birthYear'] = date('Y',strtotime($resumeInfo['birthday']));
$resumeInfo['age'] = date("Y")-$a;
}
$resumeInfo['sex_n'] = $resumeInfo['sex'] == 1?'男':'女';
if ($resumeInfo['nametype'] == 1) {
$resumeInfo['nametype_n'] = '完全公开';
} elseif ($resumeInfo['nametype'] == 2) {
$resumeInfo['nametype_n'] = '显示编号(例:NO.11)';
} elseif ($resumeInfo['nametype'] == 3) {
$resumeInfo['nametype_n'] = '性别称呼(例:X先生)';
} else {
$resumeInfo['nametype_n'] = '完全公开';
}
if ($resumeInfo['marriage']) {
$resumeInfo['marriage_n'] = $userclass_name[$resumeInfo['marriage']];
}
if ($resumeInfo['edu']) {
$resumeInfo['edu_n'] = $userclass_name[$resumeInfo['edu']];
}
if ($resumeInfo['exp']) {
$resumeInfo['exp_n'] = $userclass_name[$resumeInfo['exp']];
}
if (!empty($resumeInfo['tag'])){
$resumeInfo['arrayTag'] = explode(',', $resumeInfo['tag']);
}
if (!empty($whereData['uid'])){
if(isset($data['setname']) && $data['setname'] == 1){
require_once ('userinfo.model.php');
$UserinfoM = new userinfo_model($this->db, $this->def);
$info = $UserinfoM -> getInfo(array('uid'=> $whereData['uid']),array('setname'=>'1'));
$resumeInfo['setname'] = $info['setname']=='1'?1:0;
}
if($data['logo'] == 1){
// 个人查看
$icon = $resumeInfo['sex'] == 1 ? $this->config['sy_member_icon'] : $this->config['sy_member_iconv'];
$resumeInfo['photo_n'] = $resumeInfo['photo'];
$resumeInfo['photo'] = checkpic($resumeInfo['photo'],$icon);
$resumeInfo['wxewm'] = checkpic($resumeInfo['wxewm']);
$resumeInfo['idcard_pic'] = checkpic($resumeInfo['idcard_pic']);
}elseif($data['logo'] == 2){
// 非个人查看
if (empty($resumeInfo['photo_status']) || empty($resumeInfo['phototype']) || empty($resumeInfo['sex'])){
$resume = $this -> select_once('resume', $whereData, '`photo_status`,`phototype`,`sex`');
$resumeInfo['photo_status'] = $resume['photo_status'];
$resumeInfo['phototype'] = $resume['phototype'];
$resumeInfo['sex'] = $resume['sex'];
}
$resumeInfo['photo'] = $this -> setResumePhotoShow(array('photo' => $resumeInfo['photo'],'defphoto' => $resumeInfo['defphoto'], 'photo_status'=>$resumeInfo['photo_status'],'phototype' => $resumeInfo['phototype'], 'sex' => $resumeInfo['sex']));
}
}
}
return $resumeInfo;
}
/**
* @desc 更新个人基本信息操作
* @param array $whereData
* @param null[] $data | mData member表要修改数据; rData resume表要修改数据; utype 修改操作类型:admin-后台,user-会员中心; port 刷新简历操作端
* @return array|string[]
*/
public function upResumeInfo($whereData = array(), $data = array('mData' => null, 'rData' => null, 'utype' => null, 'port' => 1))
{
$return = array();
if (is_array($whereData) && !empty($whereData)) {
$mData = $data['mData'];
$rData = $data['rData'];
$rField = '`living`,`lastupdate`,`moblie_status`,`email_status`,`idcard_status`';
$resume = $this->select_once('resume', array('uid' => $whereData['uid']), $rField);
//会员操作的修改,需要判断手机号、邮件是否已绑定,身份证是否已验证,绑定的不能修改
if ($data['utype'] == 'user') {
if (!empty($resume)) {
if ($resume['moblie_status'] == '1') {
if (!empty($mData) && $mData['moblie']) {
unset($mData['moblie']);
}
if (!empty($rData) && $rData['moblie']) {
unset($rData['moblie']);
}
}
if ($resume['email_status'] == '1') {
if (!empty($mData) && $mData['email']) {
unset($mData['email']);
}
if (!empty($rData) && $rData['email']) {
unset($rData['email']);
}
}
if ($resume['idcard_status'] == '1') {
if (!empty($rData) && $rData['name']) {
unset($rData['name']);
}
}
}
}
// 处理会员基本信息
if (!empty($mData)) {
require_once('userinfo.model.php');
$UserinfoM = new userinfo_model($this->db, $this->def);
$ckresult = $UserinfoM->addMemberCheck($mData, $whereData['uid'], $data['utype']);
if (isset($ckresult) && $ckresult['msg']) {
$ckresult['errcode'] = 8;
return $ckresult;
}
}
// 处理个人基本信息
if (!empty($rData)) {
//处理手机站个人二维码
if (!empty($rData['preview']) || !empty($rData['ewmFromWx'])) {
$upArr = array(
'base' => $rData['preview'],
'dir' => 'user',
'file' => $rData['ewmFromWx']
);
$result = $this->upload($upArr);
if (!empty($result['msg'])) {
$return['msg'] = $result['msg'];
$return['errcode'] = 8;
return $return;
} else {
$rData['wxewm'] = $result['picurl'];
}
unset($rData['preview']);
unset($rData['ewmFromWx']);
}
if ($data['utype'] == 'user') {
$pass = $this->infoConCheck($rData, array('uid' => $whereData['uid'], 'usertype' => 1, 'source' => $data['source']));
if (!$pass) {
$rData['r_status'] = 0;
$rData['state'] = 0;
// 将个人设为未审核,简历也要设为未审核
$return['r_status'] = $rData['r_status'];
}
}
$return['id'] = $this->update_once('resume', $rData, $whereData);
if ($return['id']) {
//处理求职意向相关数据
$expect = $this->setExpectInfo($whereData['uid'], $rData, $port = $data['port']);
//处理用户提交内容
if ($data['utype'] == 'user') {
require_once('cookie.model.php');
$cookieM = new cookie_model($this->db, $this->def);
$cookieM->SetCookie('delay', '', time() - 60);
// 会员日志
$this->addMemberLog($whereData['uid'], 1, '修改基本信息', 7, 2);
// 首次完善获取积分
if ($resume['name'] == '' || $resume['living'] == '') {
require_once('integral.model.php');
$IntegralM = new integral_model($this->db, $this->def);
$IntegralM->invtalCheck($whereData['uid'], 1, 'integral_userinfo', '首次填写基本资料', 25);
}
$status = '1';
}
$return['msg'] = '基本资料修改成功';
$return['errcode'] = 9;
if ($expect == false) {
$return['url'] = 'index.php?c=expect&act=add';
} else {
$return['url'] = $_SERVER['HTTP_REFERER'];
}
} else {
$status = '2';
$return['msg'] = '基本资料修改失败';
$return['errcode'] = 8;
}
} else {
$return['msg'] = '没有要修改的信息';
$return['errcode'] = 8;
}
} else {
$return['msg'] = '请选择要修改的个人';
$return['errcode'] = 8;
}
if (isset($status)){
$return['status'] = $status;
}
return $return;
}
/**
* 修改个人基本信息同步修改简历相关信息
* @param $uid
* @param $rData
* @param $port
* @return bool
*/
private function setExpectInfo($uid, $rData, $port)
{
$eField = '`sex`,`birthday`,`exp`,`edu`,`uname`,`r_status`,`photo`';
$expect = $this->select_once('resume_expect', array('uid' => $uid), $eField);
// 有简的比较各修改项,有改动的才修改
if (!empty($expect)) {
if (!empty($rData['lastupdate'])) {
$eData['lastupdate'] = $rData['lastupdate'];
}
if (!empty($rData['photo']) && $expect['photo'] != $rData['photo']) {
$eData['photo'] = $rData['photo'];
}
if (!empty($rData['sex']) && $expect['sex'] != $rData['sex']) {
$eData['sex'] = $rData['sex'];
}
if (!empty($rData['birthday']) && $expect['birthday'] != $rData['birthday']) {
$eData['birthday'] = $rData['birthday'];
}
if (!empty($rData['exp']) && $expect['exp'] != $rData['exp']) {
$eData['exp'] = $rData['exp'];
}
if (!empty($rData['edu']) && $expect['edu'] != $rData['edu']) {
$eData['edu'] = $rData['edu'];
}
if (!empty($rData['name']) && $expect['uname'] != $rData['name']) {
$eData['uname'] = $rData['name'];
}
if (isset($rData['r_status']) && $expect['r_status'] != $rData['r_status']) {
$eData['r_status'] = $rData['r_status'];
}
if (!empty($eData)) {
$this->update_once('resume_expect', $eData, array('uid' => $uid));
}
if (isset($rData['state'])) {
$expectS = $this->select_all('resume_expect', array('uid' => $uid), 'id, state, uname, name');
require_once 'admin.model.php';
$adminM = new admin_model($this->db, $this->def);
if ($rData['state'] == 0){
$eidArr = array();
foreach ($expectS as $ek => $ev) {
$eidArr[] = $ev['id'];
if ($ev['state'] != 0){
if ($ev['uname']){
$wxTempMsg = '有新的简历需要审核,用户《'.$ev['uname'].'》修改简历《'.$ev['name'].'》';
}else{
$wxTempMsg = '有新的简历需要审核,用户修改简历《'.$ev['name'].'》';
}
$adminM->sendAdminMsg(array('first'=>$wxTempMsg,'type'=>6));
}
}
$this->update_once('resume_expect', array('state' => 0), array('id' => array('in', pylode(',', $eidArr))));
$this->update_once('userid_job', array('resume_state' => 0), array('eid' => array('in', pylode(',', $eidArr))));
}
}else{
$expectS = $this->select_all('resume_expect', array('uid' => $uid, 'state' => 3), 'id, uname, name');
if (!empty($expectS)){
require_once 'admin.model.php';
$adminM = new admin_model($this->db, $this->def);
$eidArr = array();
foreach ($expectS as $ek => $ev) {
$eidArr[] = $ev['id'];
if ($ev['uname']){
$wxTempMsg = '有新的简历需要审核,用户《'.$ev['uname'].'》修改简历《'.$ev['name'].'》';
}else{
$wxTempMsg = '有新的简历需要审核,用户修改简历《'.$ev['name'].'》';
}
$adminM->sendAdminMsg(array('first'=>$wxTempMsg,'type'=>6));
}
$this->update_once('resume_expect', array('state' => 0), array('id' => array('in', pylode(',', $eidArr))));
$this->update_once('userid_job', array('resume_state' => 0), array('eid' => array('in', pylode(',', $eidArr))));
}
}
if (isset($eData['lastupdate'])){
$resumeExpect = $this->select_all('resume_expect', array('uid' => $uid), 'id,lastupdate');
$logSxData = array();
foreach ($resumeExpect as $rk => $rv) {
$logSxData[$rk]['uid'] = $uid;
$logSxData[$rk]['resume_id'] = $rv['id'];
$logSxData[$rk]['r_time'] = $rv['lastupdate'];
$logSxData[$rk]['port'] = $port;
$logSxData[$rk]['ip'] = fun_ip_get();
}
require_once 'log.model.php';
$logM = new log_model($this->db, $this->def);
$logM->addResumeSxLogS($logSxData);
}
return true;
} else {
return false;
}
}
/**
* 修改询简历信息时的查询
* @param array $data uid=>用户id; eid=>简历id; rfield=>基本信息查询字段; needCache=>需要调用缓存; tb=>查询表范围
* @return mixed
*/
public function getInfo($data = array('uid'=>null,'eid'=>null,'needCache'=>null,'tb'=>null))
{
if ($data['needCache'] == 1){
$cache = $this -> getClass(array('user','city','job','hy','introduce'));
$return['cache'] = $cache;
}
$resume = $expect = $edu = $other = $project = $skill = $training = $work = array();
$resume = $this -> getResumeInfo(array('uid'=>$data['uid']),array('logo'=>1));
//查询简历信息
if ($resume['uid'] && !empty($data['eid'])){
$eid = intval($data['eid']);
$expect = $this -> getExpect(array('id'=>$eid,'uid'=>$resume['uid']),array('cache'=>$cache,'needCache'=>$data['needCache']));
//查询所有附表信息
if ($expect['id'] && $data['tb'] == 'all'){
$edu = $this -> getResumeEdus(array('eid'=>$eid,'uid'=>$resume['uid'],'orderby'=>'sdate,desc'),'*',$cache['userclass_name']);
$other = $this -> getResumeOthers((array('eid'=>$eid,'uid'=>$resume['uid'])));
$project = $this -> getResumeProjects(array('eid'=>$eid,'uid'=>$resume['uid'],'orderby'=>'sdate,desc'));
$skill = $this -> getResumeSkills(array('eid'=>$eid,'uid'=>$resume['uid']),'*',$cache['userclass_name']);
$training = $this -> getResumeTrains(array('eid'=>$eid,'uid'=>$resume['uid'],'orderby'=>'sdate,desc'));
$work = $this -> getResumeWorks(array('eid'=>$eid,'uid'=>$resume['uid'],'orderby'=>'sdate,desc'));
$show = $this -> getResumeShowList(array('eid'=>$eid,'uid'=>$resume['uid'],'orderby'=>'sort,desc'));
}
}
$return['resume'] = $resume;
$return['expect'] = $expect;
$return['edu'] = $edu;
$return['other'] = $other;
$return['project'] = $project;
$return['skill'] = $skill;
$return['training'] = $training;
$return['work'] = $work;
$return['show'] = $show;
return $return;
}
/**
* 通过eid查询简历信息,用作简历详情页展示
* @param array $data : uid => 查看用户id; eid=>简历id; field=>基本信息查询字段; cache=>返回包含的缓存数据
* @return array|bool|false|string|void
*/
public function getInfoByEid($data = array())
{
$res = array();
$eid = intval($data['eid']);
$uid = intval($data['uid']); //查看简历的用户uid
$usertype = intval($data['usertype']); //查看简历的用户usertype
$spid = !empty($data['spid']) ? intval($data['spid']) : '';
if(empty($eid)){
return $res;
}
$cache = $this -> getClass(array('user', 'city', 'job', 'hy', 'industry'));
//查询简历信息
$expect = $this -> getExpect(array('id' => $eid), array('cache' => $cache,'needCache'=>1));
if(empty($expect)){
return $res;
}
$euid = $expect['uid'];
$resume = $this -> getResumeInfo(array('uid' => $euid));
if(empty($resume)){
return $res;
}
//拼凑相关的字段
if(empty($resume['sex'])){
$resume['sex'] = $expect['sex'];
}
if($resume['sex'] == 152){
$resume['sex'] = 2;
}elseif ($resume['sex'] == 153){
$resume['sex'] = 1;
}
//简历名称
$resume['customjob'] = $expect['name'];
//名称显示处理
$resume['username_n'] = $this -> setUsernameShow(array('nametype' => $resume['nametype'], 'name' => $resume['name'], 'eid' => $eid, 'sex' => $resume['sex']));
//图片显示处理
$resume['photo'] = $this -> setResumePhotoShow(array('photo' => $resume['photo'],'defphoto' => $resume['defphoto'], 'photo_status'=>$resume['photo_status'],'phototype' => $resume['phototype'], 'sex' => $resume['sex']));
//年龄
if(!empty($resume['birthday'])){
$resume['age'] = date('Y') - date('Y', strtotime($resume['birthday']));
}
$resume['user_exp'] = $cache['userclass_name'][$resume['exp']];
$resume['user_marriage'] = $cache['userclass_name'][$resume['marriage']];
$resume['useredu'] = $cache['userclass_name'][$resume['edu']];
$resume['job_sex'] = $cache['user_sex'][$resume['sex']];
$resume['minsalary'] = $expect['minsalary'];
$resume['job_classid'] = $expect['job_classid'];
$resume['city_classid'] = $expect['city_classid'];
$resume['maxsalary'] = $expect['maxsalary'];
$resume['salary'] = $expect['salary'];
$resume['jobstatus'] = $expect['jobstatus_n'];
$resume['report'] = $expect['report_n'];
$resume['type'] = $expect['type_n'];
$resume['hy'] = $expect['hy_n'];
$resume['lastupdate'] = lastupdateStyle($expect['lastupdate']);
$resume['r_name'] = $expect['name'];
$resume['doc'] = $expect['doc'];
$resume['hits'] = $expect['hits'];
$resume['dnum'] = $expect['dnum'];
$resume['r_status'] = $expect['r_status'];
$resume['state'] = $expect['state'];
$resume['expect_audit'] = $expect['statusbody'];
$resume['content'] = $expect['content'];
$resume['uname'] = $expect['uname'];
$resume['label_n'] = !empty($expect['label']) ? $cache['userclass_name'][$expect['label']] : '';
$resume['height_status'] = $expect['height_status'];
$resume['id'] = $eid;
$resume['login_date_n'] = $resume['login_date'] > 0 ? date('Y-m-d', $resume['login_date']) : '从未登录';
$resume['wxewm'] = checkpic($resume['wxewm']);
if (!empty($resume['tag'])){
$resume['arrayTag'] = explode(',', $resume['tag']);
}
if (!empty($expect['whour'])){
$resume['whour'] = $expect['whour'];
if(($expect['whour']/12) >= 1){
$whour = floor($expect['whour']/12).'年';
}
if(($expect['whour']%12) >= 1){
$whour = floor($expect['whour']%12).'个月';
}
$resume['whourInfo'] = $whour;
}
if (!empty($expect['avghour'])){
$resume['avghour'] = $expect['avghour'];
$avghour = '';
if(($expect['avghour']/12) >= 1){
$avghour .= floor($expect['avghour']/12).'年';
}
if(($expect['avghour']%12) >= 1){
$avghour .= floor($expect['avghour']%12).'个月';
}
$resume['avghourInfo'] = $avghour;
}else{
$resume['avghourInfo'] = '1个月内';
}
$resume['jobname'] = $expect['job_classname'];
$resume['expectjob'] = @explode(',', $expect['job_classname']);
$resume['cityname'] = $expect['city_classname'];
$resume['expectcity'] = @explode(',', $expect['city_classname']);
if($expect['doc'] == 1){
$user_doc = $this -> select_once('resume_doc', array('eid' => $eid));
}else{
$user_edu = $this -> getResumeEdus(array('eid' => $eid, 'orderby' => 'sdate, desc'), '*', $cache['userclass_name']);
$user_training = $this -> getResumeTrains(array('eid' => $eid, 'orderby' => 'sdate,desc'));
$user_work = $this -> getResumeWorks(array('eid' => $eid, 'orderby' => 'sdate,desc'));
$user_other = $this -> getResumeOthers(array('eid' => $eid));
$user_skill = $this -> getResumeSkills(array('eid' => $eid), '*', $cache['userclass_name']);
$user_xm = $this -> getResumeProjects(array('eid' => $eid, 'orderby' => 'sdate,desc'));
if ($usertype == 2 || $usertype == 3) {
$user_show = $this -> getResumeShowList(array('eid' => $eid, 'status' => 0));
}else {
$user_show = $this -> getResumeShowList(array('eid' => $eid));
}
}
//获取是否可以查看
if($usertype == 2){
$userid_job = $this->select_once('userid_job',array('com_id' => $uid,'isdel'=>9,'eid' => $eid,'orderby'=>'id,desc'),'`id`,`job_name`,`datetime`');
if (!empty($userid_job)){
$resume['sqInfo'] = array(
'sq_job_name' => $userid_job['job_name'],
'sq_job_time' => date('Y-m-d', $userid_job['datetime'])
);
}
$comstatis = $this->select_once('company_statis',array('uid'=>$uid),'`rating`');
//已投递简历并且免费查看联系方式
$com_look = @explode(',', $this->config['com_look']);
if(!empty($userid_job)){
// 已向简历投递企业
$resume['userid_job'] = 1;
if(!empty($com_look)){
if(in_array($comstatis['rating'], $com_look)){
// 后台设置企业当前套餐可以免费查看联系方式
$resume['m_status'] = 1;
}
}
if($this->config['sy_privacy_open'] =='1' && $this -> config['sy_privacy_type'] == '1'){
// 隐私号开启,并且是全部简历的(因此处是已投递,未投递简历状态无需考虑),更换为隐私号模式 禁止直接展示联系方式
$resume['privacy_status'] = 1;
}
}
$resume['rdayprice'] = $this -> setDayprice($eid);
}
if($uid == $euid){
$resume['m_status'] = 1;
$resume['username_n'] = $resume['name'];
$resume['diy_status'] = 1;
}else{
$resume['diy_status'] = 2;
}
//获取是否下载过此简历
if(in_array($usertype, array(2, 3))){
$row = $this -> select_once('down_resume',array('eid' => $eid, 'comid' => $uid,'usertype'=>$usertype));
if(!empty($row)){
//已下载
$resume['downresume'] = 1;
if ($usertype == 2 && $this->config['sy_privacy_open'] =='1' && ($this->config['sy_privacy_type'] == '1' || ($this->config['sy_privacy_type'] == '2' && empty($userid_job)))){
// 条件解释:1、隐私号只针对企业。2、隐私号开启。(3、设置全部简历;或者4、设置未投递简历,且没有投递记录)
$resume['privacy_status'] = 1;
}else{
$resume['m_status'] = 1;
}
$resume['username_n'] = $resume['name'];
}else{
//此处获取每日最大限制
if($usertype == 3){
$tmpField = '`lt_down_resume` AS down_resume, `rating_type`';
}else{
$tmpField = '`down_resume`, `rating_type`';
$suid = !empty($spid) ? $spid : $uid;
}
require_once ('statis.model.php');
$statisM = new statis_model($this->db, $this->def);
$row = $statisM -> getInfo($suid, array('usertype' => $usertype, 'field' => $tmpField));
if($row['rating_type'] == 2){
require_once ('company.model.php');
$comM = new company_model($this->db, $this->def);
$today = strtotime('today');
$nid = $comM -> comVipDayActionCheck('resume', $uid);
$dnum = $this -> select_num('down_resume', array('comid' => $uid, 'downtime' => array('>',$today)));
if($nid != 1){
$row['down_resume'] = 0;
}else{
$row['down_resume'] = $row['down_resume'] - $dnum; // 时间会员今日已下载
}
}
if(isVip($row['vip_etime']) && $row['down_resume'] > 0){
if($this->config['com_lietou_job'] == 1){
if($usertype == 2){
$jobNum = $this->select_num('company_job',array('uid' => $uid, 'state' => 1,'r_status' =>1, 'status' => 0));
$ltJobNum = $this->select_num('lt_job',array('uid' => $uid, 'zp_status' => 0, 'status' => 1, 'r_status' => 1));
$listNum = $jobNum + $ltJobNum;
}
if($usertype == 3){
$listNum = $this->select_num('lt_job',array('uid' => $uid, 'zp_status' => 0, 'status' => 1, 'r_status' => 1));
}
if(intval($listNum) > 0){
$resume['showcontactflag'] = true;
$resume['downresumes'] = $row['down_resume']; // 剩余下载量(时间会员每人剩余/套餐会员总剩余量)
}
}else {
$resume['showcontactflag'] = true;
$resume['downresumes'] = $row['down_resume']; // 剩余下载量(时间会员每人剩余/套餐会员总剩余量)
}
}
}
}
if(isset($data['reward'])){
if($data['reward']>1 && $data['reward']!=20){
$resume['m_status'] = 1;
}elseif($data['reward']==1){
$resume['m_status'] = 2;
}
}
$tj = $this->getTj(array('edu'=>$user_edu,'train'=>$user_training,'work'=>$user_work,'xm'=>$user_xm,'skill'=>$user_skill , 'show'=>$user_show));
$resume['per'] = sprintf('%.2f%%',($expect['dnum']/$expect['hits'])*100);
$resume['description'] = str_replace(array('\r','\n'), array('
','
'), strip_tags($resume['description'],'\r,\n'));
$resume['user_doc'] = isset($user_doc) ? $user_doc : array();
$resume['user_edu'] = $user_edu;
$resume['user_tra'] = $user_training;
$resume['user_work'] = $user_work;
$resume['user_other'] = $user_other;
$resume['user_xm'] = $user_xm;
$resume['user_skill'] = $user_skill;
$resume['user_show'] = $user_show;
$resume['tj'] = $tj;
return $resume;
}
/**
* 企业、猎头通过uid查看用户姓名
*/
function getUnameByUid($uid, $data = array())
{
$name = '';
if (empty($data['comid']) || empty($data['usertype'])){
return $name;
}
// 首先按照后台、个人设置的姓名显示方式处理
$resume = $this->select_once('resume',array('uid'=>$uid),'name,sex,nametype,def_job');
$setarr = array('name'=>$resume['name'],'sex'=>$resume['sex'],'eid'=>$resume['def_job'],'nametype'=>$resume['nametype']);
$name = $this->setUsernameShow($setarr);
if ($data['usertype'] == 2){
// 企业会员
$statis = $this->select_once('company_statis',array('uid'=>$data['comid']),'rating');
$comlook = explode(',', $this->config['com_look']);
if (in_array($statis['rating'], $comlook)){
// 后台设置企业的会员套餐可以免费查看和下载投递简历,返回真实姓名
$name = $resume['name'];
return $name;
}
}
// 有下载记录,返回真实姓名
$down = $this->select_num('down_resume', array('uid'=>$uid, 'comid'=>$data['comid'], 'usertype'=>$data['usertype']));
if ($down){
$name = $resume['name'];
}
return $name;
}
//个人随机默认头像
public function deflogo($data = array()){
$logo = '';
$sex = $data['sex'];
if($sex=='2'){
$icon_arr = $this->config['sy_member_iconv_arr'];
}else{
$icon_arr = $this->config['sy_member_icon_arr'];
}
if(!empty($icon_arr)){
$key = array_rand($icon_arr,1);
$logo = $icon_arr[$key];
}
return $logo;
}
/**
* 创建简历
* @param null[] $data
* @return array|string[]
*/
public function addInfo($data=array('uid'=>null,'eData'=>null,'rData'=>null,'workData'=>null,'eduData'=>null,'proData'=>null,'utype'=>null)){
// 字段检测
$check = $this->setFieldCheck($data);
$uid = $data['uid'];
if ($check['msg']){
return $check;
}
// 保存基本信息
if (!empty($data['rData']) && !empty($uid)){
$mData = array(
'email' => $data['rData']['email'],
'moblie' => $data['rData']['telphone']
);
$num = $this->select_num('resume',array('uid'=>$uid));
if ($num > 0) {
$result = $this->upResumeInfo(array('uid' => $uid), array('mData' => $mData, 'rData' => $data['rData'], 'utype' => 'user', 'source' => $data['source']));
} else {
$this->insert_into('resume', array('uid' => $uid));
$result = $this->upResumeInfo(array('uid' => $uid), array('mData' => $mData, 'rData' => $data['rData'], 'utype' => 'user', 'source' => $data['source']));
}
if ($result['errcode'] == 8){
return $result;
}
}
// 添加求职意向
if (!empty($data['eData'])){
$eData = $data['eData'];
//先检查后台设置的最大简历数量
$enum = $this -> getExpectNum(array('uid'=>$uid));
//用户操作的,判断简历是否超限
if ($data['utype'] == 'user'){
if($this->config['user_number'] && $enum >= $this->config['user_number']){
return array('errcode'=>8,'msg'=>'您最多可以拥有'.$this->config['user_number'].'份简历');
}
}
if (isset($result['r_status'])){
// 根据上面 upResumeInfo 返回的参数进行修改账号审核状态
$eData['r_status'] = $result['r_status'];
}
// 拥有简历数量为0,新添加的简历设为默认简历
$eData['defaults'] = $enum == 0 ? 1 : 0;
$return['id'] = $this -> insert_into('resume_expect',$eData);
if ($return['id']){
// 处理简历多职位和多城市
$this->city_job($return['id'], $uid, $eData['lastupdate'], $eData['city_classid'], $eData['job_classid']);
$this -> update_once('member_statis',array('resume_num'=>$enum + 1),array('uid'=>$uid));
// 创建简历基础完成度
$integrity = 55;
// 基础平均工作时长
$whour = 0;
// 处理user_resume表数据
$uResume = array(
'uid' => $uid,
'eid' => $return['id'],
'expect' => 1,
'work' => 0,
'edu' => 0,
'project' => 0
);
if ($data['utype'] == 'user'){
// 处理工作经历
if (!empty($data['workData'])){
// 处理平均工作时长
$whour = 0;
$hour = array();
foreach ($data['workData'] as $key => $value) {
$data['workData'][$key]['eid'] = $return['id'];
$this -> insert_into('resume_work',$data['workData'][$key]);
$uResume['work']++;
// 计算每份工作时长(按月)
if ($value['edate']) {
$workTime = ceil(($value['edate'] - $value['sdate']) / (30 * 86400));
} else {
$workTime = ceil((time() - $value['sdate']) / (30 * 86400));
}
$hour[] = $workTime;
$whour += $workTime;
}
// 更新当前简历时长字段
$avghour = ceil($whour / count($hour));
$integrity += 10;
}
// 处理教育经历
if (!empty($data['eduData'])){
foreach ($data['eduData'] as $key => $value) {
$data['eduData'][$key]['eid'] = $return['id'];
$this -> insert_into('resume_edu',$data['eduData'][$key]);
$uResume['edu']++;
}
$integrity += 10;
}
// 处理项目经历
if (!empty($data['proData'])){
foreach ($data['proData'] as $key => $value) {
$data['proData'][$key]['eid'] = $return['id'];
$this -> insert_into('resume_project',$data['proData'][$key]);
$uResume['project']++;
}
$integrity += 8;
}
// 记录会员日志
$this -> addMemberLog($uid, 1, '创建一份简历(ID:'.$return['id'].')', 2, 1);
//预警处理
require_once('warning.model.php');
$warningM = new warning_model($this->db, $this->def);
$warningM -> warning(3, $uid);
require_once ('cookie.model.php');
$cookieM = new cookie_model($this->db, $this->def);
$cookieM -> SetCookie('delay', '', time() - 60);
}
// 创建简历,修改默认简历
if ($enum == 0){
$this -> update_once('resume',array('def_job'=>$return['id'],'lastupdate'=>$eData['lastupdate'],'resumetime'=>$eData['ctime']),array('uid'=>$uid));
if ($data['utype'] == 'user'){
// 创建首份简历发微信红包
require_once('wxredpack.model.php');
$wxRedPackM = new wxredpack_model($this->db, $this->def);
$wxRedPackM ->sendRedPack(array('type'=>3,'uid'=>$uid));
// 创建首份简历加积分,先要检测是否已获得过此积分
$ipay = $this -> select_once('company_pay',array('com_id'=>$uid,'pay_remark'=>'发布简历'));
if (empty($ipay)) {
require_once('integral.model.php');
$integralM = new integral_model($this->db, $this->def);
$integralM->invtalCheck($uid, 1, 'integral_add_resume', '发布简历');
}
}
}else {
$this -> update_once('resume',array('resumetime'=>$eData['ctime']),array('uid'=>$uid));
}
// 增加简历附表数据
$this -> insert_into('user_resume', $uResume);
// 向简历表中更新基本信息中已有数据
$resume = $this->select_once('resume',array('uid'=>$uid),'`name`,`idcard_status`,`status`,`photo`,`defphoto`, `phototype`,`did`');
$upExpect = array(
'did' => $resume['did'],
'integrity' => $integrity,
'whour' => $whour,
'avghour' => $avghour,
'uname' => $resume['name'],
'status' => $resume['status'],
'photo' => $resume['photo'],
'defphoto' => $resume['defphoto'],
'phototype' => $resume['phototype'],
'idcard_status' => $resume['idcard_status']
);
//内容检测
if ($data['utype'] == 'user'){
$reusmeData['expect'] = $eData;
$reusmeData['workData'] = $data['workData'];
$reusmeData['eduData'] = $data['eduData'];
$reusmeData['projectData'] = $data['proData'];
$pass = $this->resumeConCheck($reusmeData,array('uid'=>$uid,'usertype'=>1,'eid'=>$return['id'],'source'=>$data['source']));
if(!$pass){
$upExpect['state'] = 0;
}
}
if(isset($upExpect['state'])){
$this->setExpectState($upExpect,array('id'=>$return['id'], 'uid'=> $uid));
}else{
$this->update_once('resume_expect', $upExpect, array('id'=>$return['id'], 'uid'=> $uid));
}
// 管理员操作记录管理员日志
if ($data['utype'] == 'admin'){
require_once 'log.model.php';
$logM = new log_model($this->db, $this->def);
$logM -> addAdminLog('添加简历(ID:'.$return['id'].')');
}
$return['errcode'] = 9;
$return['msg'] = '保存成功';
if(isset($eData['state']) && $eData['state']==0){
require_once 'admin.model.php';
$adminM = new admin_model($this->db, $this->def);
$wxtempMsg='有新的简历需要审核,用户《'.$resume['name'].'》新增简历《'.$eData['name'].'》';
$adminM -> sendAdminMsg(array('first'=>$wxtempMsg,'type'=>6));
}
}else {
$return['errcode'] = 8;
$return['msg'] = '保存失败';
$this->addErrorLog($uid,2,'简历保存失败');
}
}
return $return;
}
/**
* 创建简历字段检测
*/
private function setFieldCheck($data = array()){
$return = array();
$rData = $data['rData'];
$eData = $data['eData'];
$workData = $data['workData'];
$eduData = $data['eduData'];
$proData = $data['proData'];
$return['errcode'] = 8;
if (!empty($rData)){
if($rData['name']=='') {$return['msg'] == '请填写真实姓名';}
if($rData['sex']=='') {$return['msg'] == '请选择性别';}
if($rData['birthday']=='') {$return['msg'] == '请选择出生年月';}
if($rData['living']=='') {$return['msg'] == '请填写现居住地';}
if($rData['edu']=='') {$return['msg'] == '请选择最高学历';}
if($rData['exp']=='') {$return['msg'] == '请选择工作经验';}
if($rData['telphone']=='') {$return['msg'] == '请填写手机号码';}
}
if (!empty($eData)){
if($eData['name']=='') {$return['msg'] == '请填写期望职位';}
if($eData['hy']=='') {$return['msg'] == '请选择从事行业';}
if($eData['job_class']=='') {$return['msg'] == '请选择期望职位';}
if($eData['minsalary']=='') {$return['msg'] == '请填写期望薪资';}
elseif($eData['maxsalary']>0 && (int)$eData['minsalary'] > (int)$eData['maxsalary']){$return['msg'] == '最高薪资必须大于最低薪资';}
if($eData['city_class']==''){$return['msg'] == '请选择工作地区';}
if($eData['type']=='') {$return['msg'] == '请选择工作性质';}
if($eData['report']=='') {$return['msg'] == '请选择到岗时间';}
if($eData['jobstatus']=='') {$return['msg'] == '请选择求职状态';}
}
if (!empty($workData)){
if($workData['workname']=='') {$return['msg'] == '请填写公司名称';}
if($workData['worksdate']==''){$return['msg'] == '请填写工作时间';}
if($workData['worktitle']==''){$return['msg'] == '请填写公司职务';}
if($workData['workedate'] < $workData['worksdate']){$return['msg'] == '工作时间不合理';}
}
if (!empty($eduData)){
if($eduData['eduname']=='') {$return['msg'] == '请填写学校名称';}
if($eduData['edusdate']=='') {$return['msg'] == '请填写在校时间';}
if($eduData['eduedate']=='') {$return['msg'] == '请填写离校或预计离校时间';}
if($eduData['education']==''){$return['msg'] == '请选择相关学历';}
if($eduData['eduspec']=='') {$return['msg'] == '请填写相关专业';}
if($eduData['eduedate'] < $eduData['edusdate']){$return['msg'] == '在校时间不合理';}
}
if (!empty($proData)){
if($proData['proname']=='') {$return['msg'] == '请填写项目名称';}
if($proData['prosdate']==''){$return['msg'] == '请填写项目开始时间';}
if($proData['proedate']==''){$return['msg'] == '请填写项目结束时间';}
if($proData['protitle']==''){$return['msg'] == '请填写项目担任职务';}
if($eduData['proedate'] < $eduData['prosdate']){$return['msg'] == '项目时间不合理';}
}
return $return;
}
/**
* 添加修改粘贴简历
* @param $post
* @return array
*/
public function addDocInfo($post)
{
$eid = intval($post['eid']);
$uid = intval($post['uid']);
$usertype = intval($post['usertype']);
$expect = $post['expect'];//插入到resume_expect数据
$doc = $post['doc'];
$doctype = $post['doctype'];//判断是否是粘贴简历
$expect['lastupdate'] = time();
if($doctype){
$expect['doc'] = 1;
}
if(!$eid){
//判断简历数是否超过后台设置
$num = $this -> getExpectNum(array('uid'=>$uid));
if($this->config['user_number'] && $num >= $this->config['user_number']){
return array('errcode'=>1,'msg'=>'您最多可以拥有'.$this->config['user_number'].'份简历');
}
//拥有简历数量为0,新添加的简历设为默认简历
$expect['defaults'] = $num == 0 ? 1 : 0;
$expect['ctime'] = time();
$nid = $this -> insert_into('resume_expect',$expect);
$eid = $nid;
if($doctype){
$this->insert_into('resume_doc',array('uid'=>$uid,'eid'=>$eid,'doc'=>$doc));
}
if($nid){
$qdata = array(
'uid'=>$uid,
'eid'=>$eid,
'expect'=>1
);
$this->insert_into('user_resume',$qdata);
$this->update_once('member_statis',array('resume_num'=>array('+',1)),array('uid'=>$uid));
if($num==0){
$this->update_once('resume',array('def_job'=>$eid),array('uid'=>$uid));
}
}
$etype = 1;
$msg = '添加';
}else{
$oldresume = $this->getExpect(array('uid'=>$uid),array('field'=>'`city_classid`,`job_classid`,`state`'));
$nid = $this->update_once('resume_expect', $expect,array('id'=>$eid,'uid'=>$uid));
if($doctype){
$this->update_once('resume_doc',array('doc'=>$doc),array('uid'=>$uid,'eid'=>$eid));
}
$etype = 2;
$msg = '修改';
}
if($nid){
//判断是否已获取发布简历送积分
$paynum = $this->select_num('company_pay',array('com_id'=>$uid,'pay_remark'=>'发布简历'));
if($paynum < 1){
include_once('integral.model.php');
$integralM = new integral_model($this->db, $this->def);
$integralM->invtalCheck($uid,$usertype,'integral_add_resume','发布简历');
}
//更新与resume里相同的字段
$resume = $this->getResumeInfo(array('uid'=>$uid),array('field'=>'`name`,`edu`,`exp`,`sex`,`birthday`,`idcard_status`,`status`,`r_status`,`photo`,`phototype`'));
$rdata = array(
'edu' => $resume['edu'],
'exp' => $resume['exp'],
'uname' => $resume['name'],
'sex' => $resume['sex'],
'birthday' => $resume['birthday'],
'idcard_status' => $resume['idcard_status'],
'status' => $resume['status'],
'state' => $resume['r_status']==2 ? 0 : $this->config['resume_status'],
'photo' => $resume['photo'],
'phototype' => $resume['phototype']
);
$expectS = $this->getExpect(array('id'=>$eid));
if(!empty($expectS['edu'])){
if( $this->config['user_revise_state']=='0'){
$rdata['state'] = 0;
$wxTempMsg = '有新的简历需要审核,用户《'.$resume['name'].'》修改简历《'.$post['name'].'》';
}
}
$resume_v = array('lastupdate'=>time());
if ($post['utype'] == 'user'){
$resumeData['docData'][] = array('doc'=>$doc);
$pass2 = $this->resumeConCheck($resumeData,array('uid'=>$uid,'usertype'=>1,'eid'=>$eid));
if(!$pass2){
$rdata['state'] = 0;
}
$pass1 = $this->infoConCheck($expect,array('uid'=>$uid,'usertype'=>1,'source'=>$post['source']));
if(!$pass1){
$resume_v['r_status'] = 0;
$rdata['r_status'] = 0;
$rdata['state'] = 0;
}
}
if (isset($oldresume)){
if ($oldresume['state'] == 3){
$rdata['state'] = 0;
$wxTempMsg = '有新的简历需要审核,用户《'.$resume['name'].'》修改简历《'.$post['name'].'》';
}
if ($oldresume['state'] != 0 && $rdata['state'] == 0){
$wxTempMsg = '有新的简历需要审核,用户《'.$resume['name'].'》修改简历《'.$post['name'].'》';
}
}
if (isset($wxTempMsg) && !empty($wxTempMsg)) {
require_once 'admin.model.php';
$adminM = new admin_model($this->db, $this->def);
$adminM->sendAdminMsg(array('first' => $wxTempMsg, 'type' => 6));
}
$this->setExpectState($rdata,array('id'=>$eid));
$this->update_once('resume',$resume_v,array('uid'=>$uid));
// 处理简历职位和城市多选
$oldCity = isset($oldresume['city_classid']) ? $oldresume['city_classid'] : '';
$oldJob = isset($oldresume['job_classid']) ? $oldresume['job_classid'] : '';
$this->city_job($eid,$uid,$expect['lastupdate'],$expect['city_classid'],$expect['job_classid'],$oldCity,$oldJob);
if($doctype){
$docmsg = '粘贴';
}
if($etype==1 && $usertype && $uid){
$this->addMemberLog($uid,$usertype,$msg.$docmsg.'简历',2,2);
}elseif($etype==2 && $usertype && $uid){
$this->addMemberLog($uid,$usertype,$msg.$docmsg.'简历',2,1);
}
return array('errcode'=>9,'msg'=>$msg.'成功');
}else{
$this->addErrorLog($uid,2,'粘贴简历'.$msg.'失败');
return array('errcode'=>9,'msg'=>$msg.'失败');
}
}
/**
* 修改求职意向信息
* @param $whereData | $id int:1 or array('in','1,2,3')
* @param array $data | port 刷新端口 sxlog: 1-需要添加刷新日志;
* @return boolean | $return
*/
public function upInfo($whereData, $data = array('eData' => null, 'utype' => null, 'port' => 1, 'sxlog' => null))
{
if (!empty($whereData)) {
//修改求职意向
if (!empty($data['eData'])) {
$return['msg'] = '简历信息';
$eData = $data['eData'];
//处理简历多职位、多城市
if ($eData['job_classid'] || $eData['city_classid'] && !empty($whereData['id'])) {
$oldJob = $oldCity = '';
$oldExpect = $this->select_once('resume_expect', array('id' => $whereData['id']), 'uid,job_classid,city_classid,state');
if ($data['utype'] != 'admin' && $whereData['uid'] != $oldExpect['uid']) {
$return['msg'] = '简历信息修改失败!';
$return['errcode'] = 8;
return $return;
}
// 处理简历职位和城市多选
$oldJob = isset($oldExpect['job_classid']) ? $oldExpect['job_classid'] : '';
$oldCity = isset($oldExpect['city_classid']) ? $oldExpect['city_classid'] : '';
$this->city_job($whereData['id'], $oldExpect['uid'], $eData['lastupdate'], $eData['city_classid'], $eData['job_classid'], $oldCity, $oldJob);
}
//内容检测
if ($data['utype'] == 'user') {
$reusmeData['expect'] = $eData;
$pass = $this->resumeConCheck($reusmeData, array('uid' => $whereData['uid'], 'usertype' => 1, 'eid' => $whereData['id'], 'source' => $data['source']));
if (!$pass) {
$eData['state'] = 0;
}else if (!isset($oldExpect)){
$oldExpect = $this->select_once('resume_expect', array('id' => $whereData['id']), 'state');
if ($oldExpect['state'] == 3){
$eData['state'] = 0;
}
}else if ($oldExpect['state'] == 3){
$eData['state'] = 0;
}
}
if (isset($eData['state'])) {
$return['id'] = $this->setExpectState($eData, $whereData);
} else {
$return['id'] = $this->update_once('resume_expect', $eData, $whereData);
if (isset($eData['lastupdate']) && $data['sxlog'] == 1){
require_once 'log.model.php';
$logM = new log_model($this->db, $this->def);
$logSxData = array(
'uid' => $whereData['uid'],
'resume_id' => $whereData['id'],
'r_time' => $eData['lastupdate'],
'port' => $data['port'],
'ip' => fun_ip_get()
);
$logM->addResumeSxLog($logSxData);
}
}
$resume = $this->select_once('resume', array('uid' => $whereData['uid']), '`name`');
$resumeinfo = $this->select_once('resume_expect', array('id' => $whereData['id']), '`name`');
if ($return['id']) {
if ($data['utype'] == 'admin') {
require_once 'log.model.php';
$logM = new log_model($this->db, $this->def);
$logM->addAdminLog('修改简历信息(ID:' . $whereData['id'] . ')');
}
if (isset($eData['state']) && $eData['state'] == 0) {
require_once 'admin.model.php';
$adminM = new admin_model($this->db, $this->def);
$wxTempMsg = '有新的简历需要审核,用户《' . $resume['name'] . '》修改简历《' . $resumeinfo['name'] . '》';
$adminM->sendAdminMsg(array('first' => $wxTempMsg, 'type' => 6));
}
$return['msg'] = '简历信息修改成功!';
$return['errcode'] = 9;
} else {
$return['msg'] = '简历信息修改失败!';
$return['errcode'] = 8;
}
}
return $return;
}
}
/**
* 查询求职意向
* @param $whereData
* @param array $data
* @return array
*/
public function getExpect($whereData,$data = array())
{
$field = isset($data['field']) ? $data['field'] : '*';
$expect = $this -> select_once('resume_expect',$whereData, $field);
if ($expect && !empty($data['needCache'])){
//处理薪资
if($expect['minsalary'] && $expect['maxsalary']){
if($this ->config['resume_salarytype']==1){
$expect['salary'] = $expect['minsalary'].'-'.$expect['maxsalary'];
}else{
if($expect['maxsalary']<1000){
if($this->config['resume_salarytype']==2){
$expect['salary'] = '1千以下';
}elseif($this->config['resume_salarytype']==3){
$expect['salary'] = '1K以下';
}elseif($this->config['resume_salarytype']==4){
$expect['salary'] = '1k以下';
}
}else{
$expect['salary'] = changeSalary($expect['minsalary']).'-'.changeSalary($expect['maxsalary']);
}
}
}elseif ($expect['minsalary']){
if($this ->config['resume_salarytype']==1){
$expect['salary'] = $expect['minsalary'];
}else{
$expect['salary'] = changeSalary($expect['minsalary']);
}
}else{
$expect['salary'] = '面议';
}
if ($data['cache']){
$cache = $data['cache'];
}else{
$cache = $this -> getClass(array('user','city','job','hy'));
}
//处理职位类别id
if ($expect['job_classid'] ){
$job_classid = @explode(',',$expect['job_classid']);
if(is_array($job_classid)){
foreach($job_classid as $v){
if($cache['job_name'][$v]){
$job_classname[$v] = $cache['job_name'][$v];
$jobclassid[] = $v;
}
}
$expect['jobArr'] = $jobclassid;
$expect['jobnameArr'] = $job_classname;
$expect['job_classid'] = pylode(',',$jobclassid);
$expect['job_classname'] = @implode(',',$job_classname);
}
}
//处理城市类别id
if ($expect['city_classid']){
$city_classid = @explode(',',$expect['city_classid']);
if(is_array($city_classid)){
foreach($city_classid as $v){
if($cache['city_name'][$v]){
$city_classname[$v] = $cache['city_name'][$v];
$cityclassid[] = $v;
}
}
$expect['cityArr'] = $cityclassid;
$expect['citynameArr'] = $city_classname;
$expect['city_classid'] = pylode(',',$cityclassid);
$expect['city_classname'] = @implode(' ',$city_classname);
}
}
$expect['lastupdate_n'] = date('Y-m-d',$expect['lastupdate']);
if($expect['state']=='1'){
$expect['r_status_n'] = '已审核';
}elseif($expect['state']=='0'){
$expect['r_status_n'] = '正在审核中';
}elseif($expect['state']=='3'){
$expect['r_status_n'] = '未通过审核';
}
$expect['exp_n'] = $cache['userclass_name'][$expect['exp']];
$expect['edu_n'] = $cache['userclass_name'][$expect['edu']];
$expect['hy_n'] = isset($cache['industry_name'][$expect['hy']]) ? $cache['industry_name'][$expect['hy']] : '不限';
$expect['report_n'] = $cache['userclass_name'][$expect['report']];
$expect['type_n'] = $cache['userclass_name'][$expect['type']];
$expect['jobstatus_n'] = $cache['userclass_name'][$expect['jobstatus']];
if ($expect['topdate'] > time()){
$day = ($expect['topdate'] - strtotime(date('Y-m-d')))/86400;
$expect['top_day'] = (int)$day;
}
if($data['member']){
$ur = $this->getUserResumeInfo(array('eid'=>$expect['id'],'uid'=>$whereData['uid']));
if ($ur['expect'] == 0){
$expect['wstitle'] = '求职意向';
}elseif ($ur['work'] == 0){
$expect['wstitle'] ='工作经历';
$expect['wspcurl']= 'index.php?c=expect&e=' .$expect['id'] ."#work_upbox";
}elseif ($ur['edu'] == 0){
$expect['wstitle'] ='教育经历';
$expect['wspcurl']= 'index.php?c=expect&e=' .$expect['id'] ."#edu_upbox";
}elseif ($ur['project'] == 0){
$expect['wstitle'] ='项目经历';
$expect['wspcurl']= 'index.php?c=expect&e=' .$expect['id'] ."#project_upbox";
}elseif ($ur['training'] == 0){
$expect['wstitle'] ='培训经历';
$expect['wspcurl']= 'index.php?c=expect&e=' .$expect['id'] ."#training_upbox";
}elseif ($ur['skill'] == 0){
$expect['wstitle'] ='职业技能';
$expect['wspcurl']= 'index.php?c=expect&e=' .$expect['id'] ."#skill_upbox";
}elseif($ur['other'] == 0){
$expect['wstitle'] ='其他信息';
$expect['wspcurl']= 'index.php?c=expect&e=' .$expect['id'] ."#other_upbox";
}
}
}
return $expect;
}
//查询单个教育经历
public function getResumeEdu($where = array(), $field = '*', $userclass_name = null){
$edu = $this -> select_once('resume_edu', $where, $field);
if($edu){
$edu['sdate_n'] = date('Y-m',$edu['sdate']);
$edu['edate_n'] = $edu['edate'] == 0 ? '至今' : date('Y-m',$edu['edate']);
//如没有传入缓存,重新调取
if ($userclass_name == null){
$cache = $this -> getClass('user');
$userclass_name = $cache['userclass_name'];
}
$edu['education_n'] = $userclass_name[$edu['education']];
}
return $edu;
}
/**
* 查询多个教育经历 $userclass_name 个人缓存,调用方法里已经有缓存的,可以先对学历进行处理
*/
public function getResumeEdus($where = array(), $field = '*', $userclass_name = null){
$edus = $this->select_all('resume_edu', $where, $field);
foreach ($edus as $k=>$v){
$edus[$k]['content'] = str_replace('\r\n', '
', strip_tags($v['content'],'\r\n'));
$edus[$k]['sdate_n'] = date('Y-m',$v['sdate']);
$edus[$k]['edate_n'] = $v['edate'] == 0 ? '至今' : date('Y-m',$v['edate']);
$edus[$k]['date_n'] = $edus[$k]['sdate_n'].'-'.$edus[$k]['edate_n'];
if ($userclass_name){
$edus[$k]['education_n'] = $userclass_name[$v['education']];
}
}
return $edus;
}
//添加/修改 教育经历
public function addResumeEdu($addData,$data = array()){
if ($data['where'] && !empty($data['where'])){
$type = 'up';
$success = $this->update_once('resume_edu',$addData,$data['where']);
} else {
$type = 'add';
$success = $this->insert_into('resume_edu',$addData);
}
$fbData = array(
'id' => $data['where']['id'],
'eid' => $addData['eid'],
'uid' => $addData['uid']
);
// 简历附表处理完成的返回值处理
$return = $this->getFbReturn('edu',$fbData,array('type'=>$type,'success'=>$success,'utype'=>$data['utype']));
return $return;
}
//查询单条其他描述
public function getResumeOther($where = array(), $field = '*'){
return $this -> select_once('resume_other', $where, $field);
}
//查询多条其他描述
public function getResumeOthers($where = array(), $field = '*'){
$others = $this -> select_all('resume_other', $where, $field);
foreach ($others as $k=>$v){
$others[$k]['content'] = str_replace('\r\n', '
', strip_tags($v['content'],'\r\n'));
}
return $others;
}
//添加/修改 其他描述
public function addResumeOther($addData,$data = array()){
if ($data['where'] && !empty($data['where'])){
$type = 'up';
$success = $this->update_once('resume_other',$addData,$data['where']);
} else {
$type = 'add';
$success = $this->insert_into('resume_other',$addData);
}
$fbData = array(
'id' => $data['where']['id'],
'eid' => $addData['eid'],
'uid' => $addData['uid']
);
// 简历附表处理完成的返回值处理
$return = $this->getFbReturn('other',$fbData,array('type'=>$type,'success'=>$success,'utype'=>$data['utype']));
return $return;
}
//查询单条项目经历
public function getResumeProject($where = array(), $field = '*'){
$project = $this->select_once('resume_project', $where, $field);
if($project){
$project['sdate_n'] = date('Y-m',$project['sdate']);
$project['edate_n'] = $project['edate'] == 0 ? '至今' : date('Y-m',$project['edate']);
}
return $project;
}
//查询多条项目经历
public function getResumeProjects($where = array(), $field = '*'){
$projects = $this->select_all('resume_project', $where, $field);
foreach ($projects as $k=>$v){
$projects[$k]['content'] = str_replace('\r\n', '
', strip_tags($v['content'],'\r\n'));
$projects[$k]['sdate_n'] = date('Y-m',$v['sdate']);
$projects[$k]['edate_n'] = $v['edate'] == 0 ? '至今' : date('Y-m',$v['edate']);
$projects[$k]['date_n'] = $projects[$k]['sdate_n'].'-'.$projects[$k]['edate_n'];
}
return $projects;
}
//添加/修改 项目经历
public function addResumeProject($addData,$data = array()){
if ($data['where'] && !empty($data['where'])){
$type = 'up';
$success = $this->update_once('resume_project',$addData,$data['where']);
} else {
$type = 'add';
$success = $this->insert_into('resume_project',$addData);
}
$fbData = array(
'id' => $data['where']['id'],
'eid' => $addData['eid'],
'uid' => $addData['uid']
);
// 简历附表处理完成的返回值处理
$return = $this->getFbReturn('project',$fbData,array('type'=>$type,'success'=>$success,'utype'=>$data['utype']));
return $return;
}
//查询单条职业技能
public function getResumeSkill($where = array(), $field = '*', $userclass_name = null){
$skill = $this->select_once('resume_skill', $where, $field);
if(!empty($skill)){
$cache = $this -> getClass(array('user'));
$userclass_name = $cache['userclass_name'];
$skill['pic'] = checkpic($skill['pic']);
$skill['ing_n'] = $userclass_name[$skill['ing']];
}
return $skill;
}
//查询多条职业技能
public function getResumeSkills($where = array(), $field = '*', $userclass_name = null){
$cache = $this -> getClass(array('user'));
$userclass_name = $cache['userclass_name'];
$skills = $this->select_all('resume_skill', $where, $field);
foreach ($skills as $k=>$v){
$skills[$k]['ing_n'] = $userclass_name[$v['ing']];
$skills[$k]['pic'] = checkpic($v['pic']);
$skills[$k]['picurl'] = $skills[$k]['pic'];
}
return $skills;
}
//添加/修改 职业技能
public function addResumeSkill($addData,$data = array()){
if($addData['file']['tmp_name']){
$upArr = array(
'file' => $addData['file'],
'dir' => 'user'
);
include_once('upload.model.php');
$uploadM = new upload_model($this->db, $this->def);
$picr = $uploadM->newUpload($upArr);
if (!empty($picr['msg'])){
$return['msg'] = $picr['msg'];
$return['errcode'] = '8';
return $return;
}elseif (!empty($picr['picurl'])){
$pictures = $picr['picurl'];
}
}
unset($addData['file']);
if(isset($pictures)){
$addData['pic']=$pictures;
}
if ($data['where'] && !empty($data['where'])){
$type = 'up';
$success = $this->update_once('resume_skill',$addData,$data['where']);
} else {
$type = 'add';
$success = $this->insert_into('resume_skill',$addData);
}
$fbData = array(
'id' => $data['where']['id'],
'eid' => $addData['eid'],
'uid' => $addData['uid']
);
// 简历附表处理完成的返回值处理
$return = $this->getFbReturn('skill',$fbData,array('type'=>$type,'success'=>$success,'utype'=>$data['utype']));
return $return;
}
//查询单条培训经历
public function getResumeTrain($where = array(), $field = '*'){
$training = $this->select_once('resume_training', $where, $field);
$training['sdate_n'] = date('Y-m',$training['sdate']);
$training['edate_n'] = $training['edate'] == 0 ? '至今' : date('Y-m',$training['edate']);
return $training;
}
//查询多条培训经历
public function getResumeTrains($where = array(), $field = '*'){
$trainings = $this->select_all('resume_training', $where, $field);
foreach ($trainings as $k=>$v){
$trainings[$k]['content'] = str_replace('\r\n', '
', strip_tags($v['content'],'\r\n'));
$trainings[$k]['sdate_n'] = date('Y-m', $v['sdate']);
$trainings[$k]['edate_n'] = $v['edate'] == 0 ? '至今' : date('Y-m',$v['edate']);
$trainings[$k]['date_n'] = $trainings[$k]['sdate_n'].'-'.$trainings[$k]['edate_n'];
}
return $trainings;
}
//添加/修改 培训经历
public function addResumeTrain($addData,$data = array()){
if ($data['where'] && !empty($data['where'])){
$type = 'up';
$success = $this->update_once('resume_training',$addData,$data['where']);
} else {
$type = 'add';
$success = $this->insert_into('resume_training',$addData);
}
$fbData = array(
'id' => $data['where']['id'],
'eid' => $addData['eid'],
'uid' => $addData['uid']
);
// 简历附表处理完成的返回值处理
$return = $this->getFbReturn('training',$fbData,array('type'=>$type,'success'=>$success,'utype'=>$data['utype']));
return $return;
}
//查询单个工作经历
public function getResumeWork($where = array(), $field = '*'){
$work = $this->select_once('resume_work', $where, $field);
if($work){
$work['sdate_n'] = date('Y-m',$work['sdate']);
$work['edate_n'] = $work['edate'] == 0 ? '至今' : date('Y-m',$work['edate']);
}
return $work;
}
/**
* 查询多个工作经历
*
* @param array $where
* @param string $field
* @return array|bool|false|string|void
*/
public function getResumeWorks($where = array(), $field = '*')
{
$works = $this->select_all('resume_work', $where, $field);
foreach ($works as $k => $v) {
$works[$k]['content'] = str_replace('\r\n', '
', strip_tags($v['content'], '\r\n'));
$works[$k]['sdate_n'] = date('Y-m', $v['sdate']);
$works[$k]['edate_n'] = $v['edate'] == 0 ? '至今' : date('Y-m', $v['edate']);
$works[$k]['date_n'] = $works[$k]['sdate_n'] . '-' . $works[$k]['edate_n'];
if ($v['edate'] == 0) {
$works[$k]['time_n']= $this->computeTime(time() - $v['sdate']);
} else {
$works[$k]['time_n']= $this->computeTime($v['edate'] - $v['sdate']);
}
}
return $works;
}
/**
* @desc 时间戳差值转换成多少年多少月;
* @param $timesDiff
* @return string
*/
private function computeTime($timesDiff)
{
$avgHour = ceil($timesDiff / (86400 * 30));
if ($avgHour > 11) {
$time = $avgHour > 11 ? avgToYm($avgHour) : $avgHour;
if (bcmod($avgHour, 12) > 0) {
return $time . '个月';
} else {
return $time;
}
} else if($avgHour > 0){
return $avgHour . '个月';
} else {
return '1个月';
}
}
//查询单条粘贴简历
public function getResumeDoc($where = array(), $field = '*'){
return $this -> select_once('resume_doc', $where, $field);
}
//添加/修改 工作经历
public function addResumeWork($addData,$data = array()){
if ($data['where'] && !empty($data['where'])){
$type = 'up';
$success = $this->update_once('resume_work',$addData,$data['where']);
} else {
$type = 'add';
$success = $this->insert_into('resume_work',$addData);
}
$fbData = array(
'id' => $data['where']['id'],
'eid' => $addData['eid'],
'uid' => $addData['uid']
);
// 简历附表处理完成的返回值处理
$return = $this->getFbReturn('work',$fbData,array('type'=>$type,'success'=>$success,'utype'=>$data['utype']));
return $return;
}
//查询多个简历证书,未见使用
// public function getResumeCerts($where = array(), $field = '*'){
// return $this->select_all('resume_cert', $where, $field);
// }
//查询单个简历附表
public function getFb($table, $id ,$uid=''){
if ($table == 'resume_work'){
$info = $this -> getResumeWork(array('id'=>$id));
}elseif ($table == 'resume_edu'){
$cache = $this -> getClass('user');
$info = $this -> getResumeEdu(array('id'=>$id),'*',$cache['userclass_name']);
}elseif ($table == 'resume_training'){
$info = $this -> getResumeTrain(array('id'=>$id));
}elseif ($table == 'resume_skill'){
$cache = $this -> getClass('user');
$info = $this -> getResumeSkill(array('id'=>$id),'*',$cache['userclass_name']);
}elseif ($table == 'resume_project'){
$info = $this -> getResumeProject(array('id'=>$id));
}elseif ($table == 'resume_other'){
$info = $this -> getResumeOther(array('id'=>$id));
}elseif ($table == 'resume_doc'){
$info = $this -> getResumeDoc(array('eid'=>$id));
}elseif ($table == 'resume_show'){
$info = $this -> getResumeShowInfo(array('id'=>$id));
}
if($uid && $info['uid']!=$uid){
$info = array();
}
return $info;
}
public function getFbList($type, $where)
{
$table = 'resume_'.$type;
if ($table == 'resume_work'){
$list = $this -> getResumeWorks($where);
}elseif ($table == 'resume_edu'){
$cache = $this -> getClass('user');
$list = $this -> getResumeEdus($where,'*',$cache['userclass_name']);
}elseif ($table == 'resume_training'){
$list = $this -> getResumeTrains($where);
}elseif ($table == 'resume_skill'){
$cache = $this -> getClass('user');
$list = $this -> getResumeSkills($where,'*',$cache['userclass_name']);
}elseif ($table == 'resume_project'){
$list = $this -> getResumeProjects($where);
}elseif ($table == 'resume_other'){
$list = $this -> getResumeOthers($where);
}elseif ($table == 'resume_show'){
$list = $this-> getResumeShowList($where);
}
return $list;
}
/**
* 删除简历附表
* @param string $table 'work'
* @param array $whereData array('id'=>1,'eid'=>1)
* @return string
*/
public function delFb($table,$whereData = array(),$data = array()){
if(!in_array($table,array('expect','edu','other','project','show','skill','training','work'))){
$return['msg'] = '请选择要删除的内容';
$return['errcode'] = '8';
return $return;
}
$tableName = 'resume_'.$table;
//处理查询条件,如某项传值有问题,即返回错误
foreach ($whereData as $v){
if (!$v){
return false;
}
}
if($whereData['id']){
$whereData['id'] = array('in', is_array($whereData['id']) ? pylode(',', $whereData['id']) : $whereData['id']);
}
$success = $this -> delete_all($tableName, $whereData,'');
if(!empty($data['utype'])){
$fbData = array(
'id' => $whereData['id'],
'eid' => $whereData['eid'],
'uid' => $whereData['uid']
);
//简历附表处理完成的返回值处理
$return = $this -> getFbReturn($table,$fbData,array('type'=>'del','success'=>$success,'utype'=>$data['utype']));
return $return;
}else{
return $success;
}
}
/**
* 简历附表处理完成的返回值处理
* @param string $fbName 'work'
* @param array $fbData array('id'=>1,'eid'=>'1')
* @param array $data array('id'=>1,'type'=>'add','success'=>$nid)
* @return string
*/
private function getFbReturn($fbName,$fbData,$data = array('utype'=>null)){
//获取统一附表名称
// $msg = $this -> getFbName($fbName).'(ID:'.$fbData['id'].')';
$msg = $this -> getFbName($fbName);
//根据操作类型,分别返回
if ($data['type'] == 'add'){
$msg .= '添加';
}elseif ($data['type'] == 'up'){
$msg .= '修改';
}elseif ($data['type'] == 'del'){
$msg .= '删除';
}
//操作是否成功判断
if ($data['success']){
$msg .= '成功';
$return['errcode'] = '9';
if ($fbName == 'work'){
//处理求职意向表中的平均工作时长
$this -> workTime($fbData['eid']);
}
//操作成功的处理简历完整度
if ($data['type'] == 'add'){
$this -> upUserResume(array($fbName=>array('+',1)), array('eid'=>$fbData['eid'],'uid'=>$fbData['uid']));
}elseif ($data['type'] == 'del'){
$this -> upUserResume(array($fbName=>array('-',1)), array('eid'=>$fbData['eid'],'uid'=>$fbData['uid']));
}
}else {
$msg .= '失败';
$return['errcode'] = '8';
}
$return['id'] = $data['success'];
$return['msg'] = $msg;
//后台操作的,添加管理员日志
if ($data['utype'] == 'admin'){
include_once('log.model.php');
$logM = new log_model($this->db, $this->def);
$logM -> addAdminLog($msg);
}
if ($data['utype'] == 'user'){
$this->addMemberLog($fbData['uid'], 1, $msg);
}
return $return;
}
//简历附表名称处理
private function getFbName($fb){
$tname = array(
'work' => '工作经历',
'edu' => '教育经历',
'skill' => '职业技能',
'project' => '项目经历',
'training' => '培训经历',
'other' => '其他描述'
);
return $tname[$fb];
}
/**
* 获取user_resume 详情
* $whereData 查询条件
* $data 自定义处理数组
* 完整度的查询返回
*/
public function getUserResumeInfo($whereData, $data = array()) {
$data['field'] = empty($data['field']) ? '*' : $data['field'];
$resumeInfo = $this -> select_once('user_resume', $whereData, $data['field']);
return $resumeInfo;
}
/**
* 修改简历完整度
* 参数格式
* $data = array('work'=>array('+',1));
* $whereData = array('eid'=>'1')
*/
function upUserResume($data,$whereData){
if (isset($whereData['uid']) && isset($whereData['eid'])){
$skill = $this-> select_num('resume_skill',array('eid'=>$whereData['eid']));
$work = $this-> select_num('resume_work',array('eid'=>$whereData['eid']));
$pro = $this-> select_num('resume_project',array('eid'=>$whereData['eid']));
$edu = $this-> select_num('resume_edu',array('eid'=>$whereData['eid']));
$train = $this-> select_num('resume_training',array('eid'=>$whereData['eid']));
$cert = $this-> select_num('resume_cert',array('eid'=>$whereData['eid']));
$other = $this-> select_num('resume_other',array('eid'=>$whereData['eid']));
$integrity = 55;
$user_resume_sql['uid'] = $whereData['uid'];
$user_resume_sql['eid'] = $whereData['eid'];
$user_resume_sql['expect'] = 1;
if($work > 0){
$integrity = $integrity + 10;
}
$user_resume_sql['work'] = $work;
if($edu > 0){
$integrity = $integrity + 10;
}
$user_resume_sql['edu'] = $edu;
if($skill > 0){
$integrity = $integrity + 10;
}
$user_resume_sql['skill'] = $skill;
if($pro > 0){
$integrity = $integrity + 8;
}
$user_resume_sql['project'] = $pro;
if($train > 0){
$integrity = $integrity + 7;
}
$user_resume_sql['training'] = $train;
$userResume = $this->select_once('user_resume',$whereData);
if (!empty($userResume)){
$this->update_once('user_resume',$user_resume_sql,$whereData);
}else{
$this->insert_into('user_resume',$user_resume_sql);
}
$this->update_once('resume_expect',array('integrity'=>$integrity),array('id'=>$whereData['eid']));
}
}
/**
* @desc 简历审核,个人不是已审核状态,弹出同步操作状态审核
* @param int $id
* @param array $data|state statusbody
*/
public function status($id, $data = array()){
if (!$id){
$return = array(
'errcode' => 8,
'msg' => '参数错误!'
);
return $return;
}else{
$resume = $this->select_once('resume_expect', array('id' => $id), '`id`,`uid`,`name`,`state`');
$resumeinfo = $this->select_once('resume', array('uid' =>$resume['uid']), '`telphone`');
$upData = array(
'state' => intval($data['state']),
'statusbody'=> trim($data['statusbody'])
);
$uid = $data['uid'];
$result = $this->setExpectState($upData,array('id' => $id, 'uid' => $uid));
if ($result) {
if ($data['state'] == '1') {
$state_n = '已通过';
$body = '';
$msg = '您的简历《'.$resume['name'].'》审核通过';
require_once 'userinfo.model.php';
$userinfoM = new userinfo_model($this->db, $this->def);
$post = array(
'id' => $id,
'status' => 1
);
$userinfoM -> status(array('uid' => $uid, 'usertype' => 1), array('post' => $post));
// 因简历未审核不能投递,记录的申请职位id,审核通过后,将简历按职位id,进行投递
$reusmesqjob = $this -> select_once('resume_expect',array('id'=>$id),'`id`,`uid`,`sq_jobid`');
if (!empty($reusmesqjob) && $reusmesqjob['sq_jobid'] > 0){
$reusmesqjobinfos = $this -> select_once('company_job',array('id'=>$reusmesqjob['sq_jobid']),'`id`,`uid`,`name`,`com_name`');
if($reusmesqjob['sq_jobid']){
include_once('job.model.php');
$jobM = new job_model($this->db, $this->def);
$sqdata = array(
'job_id' => $reusmesqjob['sq_jobid'],
'com_name' => $reusmesqjobinfos['com_name'],
'job_name' => $reusmesqjobinfos['name'],
'com_id' => $reusmesqjobinfos['uid'],
'uid' => $reusmesqjob['uid'],
'eid' => $reusmesqjob['id'],
'datetime' => time(),
'resume_state' => $data['state'],
);
$jobM -> addSqJob($sqdata);
$this -> update_once('resume_expect',array('sq_jobid'=>''), array('id' => $id, 'uid' => $uid));
}
}
}else{
$state_n = '未通过';
$body = '。原因:'.$data['statusbody'];
$msg = '您的简历《'.$resume['name'].'》审核未通过;原因:'.$data['statusbody'];
}
if($resumeinfo['telphone'] && $resume['state']!=$upData['state']){
require_once 'notice.model.php';
$noticeM = new notice_model($this->db, $this->def);
$smsdata = array(
'uid' => $resume['uid'],
'usertype' => 1,
'moblie' => $resumeinfo['telphone'],
'type' => 'resumestate',
'resumename'=> $resume['name'],
'state_n' => $state_n,
'port' => '1'
);
$noticeM->sendSMSType($smsdata);
}
//发送系统通知
require_once 'sysmsg.model.php';
$sysmsgM = new sysmsg_model($this->db, $this->def);
$sysmsgM -> addInfo(array('uid' => $uid,'usertype'=>1,'content'=>$msg));
$return = array(
'errcode' => 9,
'msg' => '简历审核'.$state_n.'设置成功!(ID:'.$id.$body.')'
);
}else{
$return = array(
'errcode' => 8,
'msg' => '简历审核设置失败!(ID:'.$id.')'
);
}
return $return;
}
}
/**
* 后台简历审核
* @param string $id 格式:单个,如1 ; 批量,如1,2,3
* @param array $data
*/
public function statusResume($id,$data = array()){
$id = @explode(',',$id);
foreach($id as $v){
if($v){
$ids[] = $v;
}
}
if (!empty($ids)){
$idstr = pylode(',', $ids);
$post = $data['post'];
//查询出需审核的简历的名称,为发送系统通知做准备
$expects = $this -> getList(array('id'=>array('in',$idstr),'r_status'=>1),array('field'=>'id,uid,name,state','withResumeField'=>'`uid`,`telphone`'));
$result = $this -> upInfo(array('id'=>array('in',$idstr),'r_status'=>1),array('eData'=>$post));
if ($result){
if($post['state']==1){
$reusmesqjob = $this -> select_all('resume_expect',array('id'=>array('in',$idstr)),'`id`,`uid`,`sq_jobid`');
foreach($reusmesqjob as $val){
$job_ids[]=$val['sq_jobid'];
}
$reusmesqjobinfos = $this -> select_all('company_job',array('id'=>array('in',pylode(',', $job_ids))),'`id`,`uid`,`name`,`com_name`');
include_once('job.model.php');
$jobM = new job_model($this->db, $this->def);
foreach($reusmesqjob as $k=>$v){
foreach($reusmesqjobinfos as $val){
if($v['sq_jobid']==$val['id']){
$ysqnum= $jobM->getSqJobNum(array('job_id'=>$val['id'],'com_id'=>$val['uid'],'uid'=>$v['uid'],'eid'=>$v['id'],'isdel'=>9));
if($ysqnum<1){
$jobM -> addSqJob(array('job_id'=>$val['id'],'com_name'=>$val['com_name'], 'job_name'=>$val['name'],'com_id'=>$val['uid'],'uid'=>$v['uid'],'eid'=>$v['id'],'datetime'=>time(),'resume_state'=>$post['state']));
}
}
}
}
$this -> update_once('resume_expect',array('sq_jobid'=>''),array('id'=>array('in',$idstr)));
}
if ($post['state'] == 1 || $post['state'] == 3){
$msg = array();
$uids = array();
/* 处理审核信息 */
if ($post['state'] == 3){
$state_n = '未通过';
$body = !empty($post['statusbody']) ? '。 原因:'.$post['statusbody'] : '';
}elseif($post['state'] == 1){
$state_n = '已通过';
$boty = '';
}
require_once 'notice.model.php';
$noticeM = new notice_model($this->db, $this->def);
if($expects && is_array($expects)){
foreach ($expects['list'] as $k=>$v){
$uids[] = $v['uid'];
/* 处理审核信息 */
if ($post['state'] == 3){
$msg[$v['uid']][] = '您的简历《'.$v['name'].'》审核未通过'.$body;
}elseif($post['state'] == 1){
$msg[$v['uid']][] = '您的简历《'.$v['name'].'》已审核通过';
}
if($v['telphone'] && $v['state']!=$post['state']){
$smsdata = array(
'uid' => $v['uid'],
'usertype' => 1,
'moblie' => $v['telphone'],
'type' => 'resumestate',
'resumename'=> $v['name'],
'state_n' => $state_n,
'port' => '1'
);
$res=$noticeM->sendSMSType($smsdata);
}
}
//发送系统通知
include_once('sysmsg.model.php');
$sysmsgM = new sysmsg_model($this->db, $this->def);
$sysmsgM -> addInfo(array('uid'=>$uids,'usertype'=>1, 'content'=>$msg));
}
}
$resumewhere['id'] = array('in',$idstr);
$resumenum = $this->getExpectNum($resumewhere);
if($resumenum>1){
$resumetwhere['id'] = array('in',$idstr);
$resumetwhere['r_status'] = 1;
$resumetnum = $this->getExpectNum($resumetwhere);
$resumewwhere['id'] = array('in',$idstr);
$resumewwhere['r_status'] = array('<>',1);
$resumewnum = $this->getExpectNum($resumewwhere);
if($resumewnum>0){
$return['msg'] = '简历批量审核'.$state_n.'成功'.$resumetnum.'条,失败'.$resumewnum.'条。原因:个人账户未审核';
}else{
$return['msg'] = '简历批量审核'.$state_n.'成功(ID:'.$idstr.$body.')';
}
$return['errcode'] = 9;
}else{
$resumewwhere['id'] = array('in',$idstr);
$resumewwhere['r_status'] = array('<>',1);
$resumetnum = $this->getExpectNum($resumewwhere);
if($resumetnum>0){
$return['msg'] = '审核简历'.$state_n.'失败,原因:个人账户未审核(ID:'.$idstr.')';
$return['errcode'] = 8;
}else{
$return['msg'] = '审核简历'.$state_n.'设置成功(ID:'.$idstr.$body.')';
$return['errcode'] = 9;
}
}
}else{
$return['msg'] = '审核简历设置失败(ID:'.$idstr.')';
$return['errcode'] = '8';
}
}else{
$return['msg'] = '请选择要审核的简历';
$return['errcode'] = '8';
}
return $return;
}
/**
* 刷新简历
* @param string $id 格式:单个,如1 ; 批量,如1,2,3
* @param array $data
* @return mixed
*/
public function refreshResume($id)
{
$id = @explode(',', $id);
foreach ($id as $v) {
if ($v) {
$ids[] = $v;
}
}
if (!empty($ids)) {
$idstr = pylode(',', $ids);
$post = array('lastupdate' => time());
$result['id'] = $this->update_once('resume_expect', $post, array('id' => array('in', $idstr)));
if ($result['id']) {
$msg = array();
$uids = array();
//查询出需刷新的简历的名称,为发送系统通知做准备
$expects= $this->getList(array('id' => array('in', $idstr)), array('field' => 'id,uid,name'));
$logSxData = array();
foreach ($expects['list'] as $k => $v) {
$uids[] = $v['uid'];
$msg[$v['uid']] = '您的简历《'.$v['name'].'》已刷新';
$logSxData[$k]['uid'] = $v['uid'];
$logSxData[$k]['resume_id'] = $v['id'];
$logSxData[$k]['r_time'] = time();
$logSxData[$k]['port'] = 5;
$logSxData[$k]['ip'] = fun_ip_get();
}
//简历刷新成功,修改个人基本信息表中的更新时间
$this->update_once('resume', $post, array('uid' => array('in', pylode(',', $uids))));
//发送系统通知
include_once('sysmsg.model.php');
$sysmsgM = new sysmsg_model($this->db, $this->def);
$sysmsgM->addInfo(array('uid' => $uids, 'usertype' => 1, 'content' => $msg));
include_once('log.model.php');
$logM = new log_model($this->db, $this->def);
$logM->addResumeSxLogS($logSxData);
$return['msg'] = '刷新简历(ID:' . $idstr . ')设置成功';
$return['errcode'] = '9';
} else {
$return['msg'] = '刷新简历(ID:' . $idstr . ')设置失败';
$return['errcode'] = '8';
}
} else {
$return['msg'] = '请选择要刷新的简历';
$return['errcode'] = '8';
}
return $return;
}
/**
* 推荐简历
* @param string $id 格式:单个,如1 ; 批量,如1,2,3
* @param array $data
*/
public function recResume($id,$rec){
$id = @explode(',',$id);
foreach($id as $v){
if($v){
$ids[] = $v;
}
}
if (!empty($ids)){
$idstr = pylode(',', $ids);
$post = array('rec_resume'=>$rec);
$result['id'] = $this -> update_once('resume_expect', $post, array('id'=>array('in',$idstr)));
if ($result['id']){
$msg = array();
$uids = array();
//查询出需推荐的简历的名称,为发送系统通知做准备
$expects = $this -> getList(array('id'=>array('in',$idstr)),array('field'=>'id,uid,name'));
foreach ($expects['list'] as $k=>$v){
$uids[] = $v['uid'];
if ($rec == 1){
$msg[$v['uid']] = '您的简历《'.$v['name'].'》被管理员设为推荐简历';
}elseif ($rec == 0){
$msg[$v['uid']] = '您的简历《'.$v['name'].'》被管理员设为非推荐简历';
}
}
//发送系统通知
include_once('sysmsg.model.php');
$sysmsgM = new sysmsg_model($this->db, $this->def);
$sysmsgM -> addInfo(array('uid'=>$uids,'usertype'=>1, 'content'=>$msg));
$return['msg'] = '推荐简历(ID:'.$idstr.')设置成功';
$return['errcode'] = '9';
}else{
$return['msg'] = '推荐简历(ID:'.$idstr.')设置失败';
$return['errcode'] = '8';
}
}else{
$return['msg'] = '请选择要推荐的简历';
$return['errcode'] = '8';
}
return $return;
}
/**
* 置顶简历
* @param string $id 格式:单个,如1 ; 批量,如1,2,3
* @param array $data
*/
public function topResume($id,$post){
$id = @explode(',',$id);
foreach($id as $v){
if($v){
$ids[] = $v;
}
}
if (!empty($ids)){
$idstr = pylode(',', $ids);
$result['id'] = $this -> update_once('resume_expect', $post, array('id'=>array('in',$idstr)));
if ($result['id']){
$msg = array();
$uids = array();
//查询出需置顶的简历的名称,为发送系统通知做准备
$expects = $this -> getList(array('id'=>array('in',$idstr)),array('field'=>'id,uid,name'));
foreach ($expects['list'] as $k=>$v){
$uids[] = $v['uid'];
if ($post['top'] == 1){
$msg[$v['uid']] = '您的简历《'.$v['name'].'》已置顶';
}elseif ($post['top'] == 0){
$msg[$v['uid']] = '您的简历《'.$v['name'].'》被管理员取消置顶';
}
}
//发送系统通知
include_once('sysmsg.model.php');
$sysmsgM = new sysmsg_model($this->db, $this->def);
$sysmsgM -> addInfo(array('uid'=>$uids,'usertype'=>1, 'content'=>$msg));
$return['msg'] = '置顶简历(ID:'.$idstr.')设置成功';
$return['errcode'] = '9';
}else{
$return['msg'] = '置顶简历(ID:'.$idstr.')设置失败';
$return['errcode'] = '8';
}
}else{
$return['msg'] = '请选择要置顶的简历';
$return['errcode'] = '8';
}
return $return;
}
/**
* 后台简历备注
* @param string $id 格式:如1 ;
* @param array $data
*/
public function label($id,$post){
if (!empty($id)){
$return['id'] = $this -> update_once('resume_expect', $post, array('id'=>$id));
$return['msg'] = '简历备注(ID:'.$id.')';
$return['msg'] = $return['id'] ? $return['msg'].'设置成功!' : $return['msg'].'设置失败!';
//操作状态 9:成功 8:失败 配合原有提示函数
$return['errcode'] = $return['id'] ? '9' :'8';
return $return;
}
}
/**
* 删除简历
* @param string $id 格式:单个,如1 ; 批量,如1,2,3
* @param array $data utype=admin; delAccount=1, 同步删除账号
*/
public function delResume($id,$data=array()){
$limit = 'limit 1';
$return['layertype'] = 0;
if (!empty($id)){
if(is_array($id)){
$id = pylode(',', $id);
$return['layertype'] = 1;
$limit = '';
}
if($data['utype']!='admin'){
//如果不是后台操作 必须传入UID
$elist = $this -> getList(array('id'=>array('in',$id)),array('field'=>'`id`,`uid`'));
foreach($elist['list'] as $v){
if($data['uid'] != $v['uid']){
$return['msg'] = '非法操作!';
$return['errcode'] = '8';
return $return;
}
$resumenum= $this -> getExpectNum(array('uid'=>array('in',$v['uid'])));
if($resumenum==1){
$return['msg'] = '请至少保留一份简历!';
$return['errcode'] = '8';
return $return;
}
}
}else if($data['utype'] == 'admin' && $data['delAccount'] == '1'){ // 同步删除账号,提取账号UID
$elist = $this -> getList(array('id'=>array('in',$id)),array('field'=>'`id`,`uid`'));
$euids = array();
foreach($elist['list'] as $ek => $ev){
$euids[$ev['uid']] = $ev['uid'];
}
require_once ('userinfo.model.php');
$userinfoM = new userinfo_model($this->db, $this->def);
return $userinfoM -> delMember($euids);
}
//查询删掉的是默认简历的数据
$expects = $this -> getList(array('id'=>array('in',$id),'defaults'=>1),array('field'=>'`id`,`uid`'));
$expectA = $this -> select_all('resume_expect',array('id'=>array('in',$id)),'`uid`');
if (!empty($expectA)) {
foreach ($expectA as $ev) {
$expectAuids[$ev['uid']] = $ev['uid'];
}
}
$nid = $this -> delete_all('resume_expect',array('id'=>array('in',$id)),$limit);
if ($nid){
//删除简历时修改默认简历
$this -> upDefaults($expects['list']);
//删除简历相关其他的表中数据
$this -> delete_all('company_job_rewardlist',array('eid'=>array('in',$id)),'');
$this -> delete_all('company_job_rewardlog',array('eid'=>array('in',$id)),'');
$this -> delete_all('down_resume',array('eid'=>array('in',$id)),'');
$this -> delete_all('look_resume',array('resume_id'=>array('in',$id)),'');
$this -> delete_all('resume_city_job_class',array('eid'=>array('in',$id)),'');
$this -> delete_all('resume_cityclass',array('eid'=>array('in',$id)),'');
$this -> delete_all('resume_doc',array('eid'=>array('in',$id)),'');
$this -> delete_all('resume_edu',array('eid'=>array('in',$id)),'');
$this -> delete_all('resume_jobclass',array('eid'=>array('in',$id)),'');
$this -> delete_all('resume_other',array('eid'=>array('in',$id)),'');
$this -> delete_all('resume_project',array('eid'=>array('in',$id)),'');
$this -> delete_all('resume_show',array('eid'=>array('in',$id)),'');
$this -> delete_all('resume_skill',array('eid'=>array('in',$id)),'');
$this -> delete_all('resume_training',array('eid'=>array('in',$id)),'');
$this -> delete_all('resume_work',array('eid'=>array('in',$id)),'');
$this -> delete_all('report',array('eid'=>array('in',$id), 'usertype' => 2, 'type' => 0),'');
$this -> delete_all('talent_pool',array('eid'=>array('in',$id)),'');
$this -> delete_all('user_entrust',array('eid'=>array('in',$id)),'');
$this -> delete_all('user_entrust_record',array('eid'=>array('in',$id)),'');
$this -> delete_all('user_resume',array('eid'=>array('in',$id)),'');
$this -> delete_all('userid_job',array('eid'=>array('in',$id)),'');
$this -> delete_all('spview_subscribe', array('eid' => array('in',$id)), '');
$this -> delete_all('spview_subscribe_msg', array('eid' => array('in',$id)), '');
if (!empty($expectAuids)){
$this -> delete_all('look_job',array('uid' => array('in', pylode(',',$expectAuids))),'');
}
$return['id'] = $nid;
$return['msg'] = '简历(ID:'.$id.')删除成功';
$return['errcode'] = '9';
}else{
$return['msg'] = '简历(ID:'.$id.')删除失败';
$return['errcode'] = '8';
}
}else{
$return['msg'] = '请选择要删除的简历';
$return['errcode'] = '8';
}
return $return;
}
//删除简历时修改默认简历,并处理与uid相关数据
private function upDefaults($list = array()){
$uids = array();
foreach ($list as $k=>$v){
$uids[] = $v['uid'];
}
if (!empty($uids)){
//先去除重复的uid
$uids = array_unique($uids);
$newdef = array();//要修改的默认简历数据
$newids = array();//要修改的默认简历id
$newuids = array();//还有简历的用户uid
$newrnum = array();//要修改的简历数量数据
//根据删除简历的uid来查询删除后剩下的相关简历
$newExpects = $this -> getList(array('uid'=>array('in',pylode(',', $uids)),'groupby'=>'uid'),array('field'=>'id,uid,count(id) as rnum'));
//被删除简历的用户,def_job默认为0
foreach ($uids as $uk=>$uv){
$newdef[$uv] = 0;
$newrnum[$uv] = 0;
}
//删除后还有简历的,def_job设置查到的简历id
foreach ($newExpects['list'] as $ek=>$ev){
$newids[] = $ev['id'];
$newuids[] = $ev['uid'];
$newdef[$ev['uid']] = $ev['id'];
$newrnum[$ev['uid']] = $ev['rnum'];
}
//修改基本信息中的默认简历数据
$this -> update_once('resume', array('def_job'=>array('CASE','uid',$newdef)), array('uid'=>array('in',pylode(',', $uids))));
//修改简历中的默认简历数据
$this -> update_once('resume_expect', array('defaults'=>1), array('id'=>array('in',pylode(',', $newids))));
//修改现有简历数量
$this -> update_once('member_statis',array('resume_num'=>array('CASE','uid',$newrnum)),array('uid'=>array('in',pylode(',', $newuids))));
//数组去重,取得已经没有简历的用户uid
$noResume = array_diff($uids, $newuids);
if (!empty($noResume)){
//删除已没有简历用户的关注记录
$this -> delete_all('atn',array('uid'=>array('in',pylode(',', $noResume))),'');
//删除已没有简历用户的职位浏览记录
$this -> delete_all('look_job',array('uid'=>array('in',pylode(',', $noResume))),'');
//删除已没有简历用户的邀请面试记录
$this -> delete_all('userid_msg',array('uid'=>array('in',pylode(',', $noResume))),'');
}
}
}
/**
* 后台个人认证审核
* @param string $id 格式:单个,如1 ; 批量,如1,2,3
* @param array $data
*/
public function statusCert($uid,$data = array()){
$uid = @explode(',',$uid);
if (count($uid) > 1){
$return['layertype'] = 1;
}else {
$return['layertype'] = 0;
}
foreach($uid as $v){
if(!empty($v)){
$uids[] = $v;
}
}
if (!empty($uids)){
$uidstr = pylode(',', $uids);
$post = $data['post'];
$result = $this -> update_once('resume', $post, array('uid'=>array('in',$uidstr)));
if ($result){
$status = $post['idcard_status'];
$this -> update_once('resume_expect', array('idcard_status'=>$status), array('uid'=>array('in',$uidstr)));
if ($status == 1 || $status == 2){
//通过审核,并后台设置的上传身份验证所加积分大于0,才需要处理加积分
if ($status == 1 && $this->config['integral_identity'] > 0){
$compays = $this -> select_all('company_pay',array('com_id'=>array('in',$uidstr),'pay_remark'=>'上传身份验证'),'com_id');
if (!empty($compays)){
//获取已经获得过验证积分的uid
foreach ($compays as $v){
$payed[] = $v['com_id'];
}
//取差集,得到还未获得认证积分的uid
$needs = array_diff($uids, $payed);
}else{
$needs = $uids;
}
//发放身份认证积分
if(!empty($needs)){
include_once('integral.model.php');
$integralM = new integral_model($this->db, $this->def);
foreach ($needs as $v){
$integralM -> invtalCheck($v,1,'integral_identity','上传身份验证');
}
}
}
foreach ($uids as $k=>$v){
/* 处理审核信息 */
if ($post['idcard_status'] == 2){
$statusInfo = '您的身份证审核未通过 ';
if($post['statusbody']){
$statusInfo .= ', 原因:'.$post['statusbody'];
}
$msg = $statusInfo;
}elseif($post['idcard_status'] == 1){
$msg = '您的身份证已审核通过';
}
}
//发送系统通知
include_once('sysmsg.model.php');
$sysmsgM = new sysmsg_model($this->db, $this->def);
$sysmsgM -> addInfo(array('uid'=>$uids,'usertype'=>1, 'content'=>$msg));
//发邮件通知
if ($this->config['sy_email_usercert'] == '1'){
$tplData = array(
'certinfo' => $msg,
'type' => 'usercert'
);
include_once('notice.model.php');
$noticeM = new notice_model($this->db, $this->def);
$emailTpl = $noticeM -> getTpl($tplData,'email');
$resumes = $this -> select_all('member',array('uid'=>array('in',$uidstr)),'uid,email');
foreach($resumes as $v){
$edata = array(
'uid' => $v['uid'],
'cuid' => 0,
'certinfo' => $msg,
'email' => $v['email'],
'type' => 'usercert'
);
$noticeM -> sendEmailType($edata,$emailTpl);
}
}
}
$return['msg'] = '个人认证审核(ID:'.$uidstr.')设置成功';
$return['errcode'] = '9';
}else{
$return['msg'] = '个人认证审核(ID:'.$uidstr.')设置失败';
$return['errcode'] = '8';
}
}else{
$return['msg'] = '请选择要审核的认证';
$return['errcode'] = '8';
}
return $return;
}
/**
* 删除个人身份验证
* @param string $id 格式:单个,如1 ; 批量,如1,2,3
* @param array $data
*/
public function delResumeCert($uid){
$return['layertype'] = 0;
if (!empty($uid)){
if(is_array($uid)){
$uid = pylode(',', $uid);
$return['layertype'] = 1;
}
$cdata = array(
'idcard_pic' => '',
'idcard_status' => 0,
'cert_time' => '',
'statusbody' => ''
);
$nid = $this -> update_once('resume',$cdata,array('uid'=>array('in',$uid)));
if ($nid){
$return['msg'] = '个人身份认证(ID:'.$uid.')删除成功';
$return['errcode'] = '9';
}else{
$return['msg'] = '个人身份认证(ID:'.$uid.')删除失败';
$return['errcode'] = '8';
}
}else{
$return['msg'] = '请选择要删除的个人身份认证';
$return['errcode'] = '8';
}
return $return;
}
/**
* 后台个人头像审核
* @param string $id 格式:单个,如1 ; 批量,如1,2,3
* @param array $data
*/
public function statusPhoto($uid,$data = array()){
$uid = @explode(',',$uid);
foreach($uid as $v){
if($v){
$uids[] = $v;
}
}
if (!empty($uids)){
$uidstr = pylode(',', $uids);
$post = $data['post'];
if ($post['photo_status'] == 2){
//审核不通过删除图片
$post['photo'] ='';
}
$result = $this -> update_once('resume', $post, array('uid'=>array('in',$uidstr)));
if ($result){
if ($post['photo_status'] == 2){
// 审核不通过,相关表头像删除
$this -> update_once('resume_expect',array('photo'=>''),array('uid'=>array('in',$uidstr)));
$this -> update_once('answer',array('pic'=>''),array('uid'=>array('in',$uidstr)));
$this -> update_once('question',array('pic'=>''),array('uid'=>array('in',$uidstr)));
$statusInfo = '您的头像';
foreach ($uids as $k=>$v){
/* 处理审核信息 */
if($post['photo_statusbody']){
$statusInfo .= ' , 因为'.$post['photo_statusbody'].' , ';
}
$statusInfo .= '已被管理员删除';
$msg[$v] = $statusInfo;
}
//发送系统通知
include_once('sysmsg.model.php');
$sysmsgM = new sysmsg_model($this->db, $this->def);
$sysmsgM -> addInfo(array('uid'=>$uids,'usertype'=>1, 'content'=>$msg));
}elseif ($post['photo_status'] == 0){
// 审核通过,修改相关表头像
$resume = $this -> select_all('resume',array('uid'=>array('in',$uidstr)),'`uid`,`photo`');
foreach ($resume as $k=>$v){
$newphoto[$v['uid']] = $v['photo'];
}
//修改基本信息中的默认简历数据
$this -> update_once('resume_expect', array('photo'=>array('CASE','uid',$newphoto)), array('uid'=>array('in',$uidstr)));
$this -> update_once('answer',array('pic'=>array('CASE','uid',$newphoto)),array('uid'=>array('in',$uidstr)));
$this -> update_once('question',array('pic'=>array('CASE','uid',$newphoto)),array('uid'=>array('in',$uidstr)));
}
$return['msg'] = '头像审核(ID:'.$uidstr.')设置成功';
$return['errcode'] = '9';
}else{
$return['msg'] = '头像审核(ID:'.$uidstr.')设置失败';
$return['errcode'] = '8';
}
}else{
$return['msg'] = '请选择要审核的头像';
$return['errcode'] = '8';
}
return $return;
}
/**
* 后台个人作品审核
* @param string $id 格式:单个,如1 ; 批量,如1,2,3
* @param array $data
*/
public function statusShow($id,$data = array()){
$id = @explode(',',$id);
foreach($id as $v){
if($v){
$ids[] = $v;
}
}
if (!empty($ids)){
$idstr = pylode(',', $ids);
$shows = $this -> getResumeShowList(array('id'=>array('in',$idstr)),array('field'=>'`uid`,`title`'));
$post = $data['post'];
if ($post['status'] == 2){
//审核不通过删除
$result = $this -> delete_all('resume_show', array('id'=>array('in',$idstr)),'');
}elseif($post['status'] == 0){
$result = $this -> update_once('resume_show', $post, array('id'=>array('in',$idstr)));
}
if ($result){
if ($post['status'] == 0 || $post['status'] == 2){
foreach ($shows as $k=>$v){
$uids[] = $v['uid'];
/* 处理审核信息 */
if ($post['status'] == 2){
if ($v['title'] != ''){
$statusInfo = '您的作品案例('.$v['title'].')审核未通过';
}else{
$statusInfo = '您的作品案例审核未通过';
}
if($post['statusbody']){
$statusInfo .= ', 原因:'.$post['statusbody'];
}
$msg[$v['uid']][] = $statusInfo;
}elseif($post['status'] == 0){
if ($v['title'] != ''){
$msg[$v['uid']][] = '您的作品案例('.$v['title'].')已审核通过';
}else{
$msg[$v['uid']][] = '您的作品案例已审核通过';
}
}
}
//发送系统通知
include_once('sysmsg.model.php');
$sysmsgM = new sysmsg_model($this->db, $this->def);
$sysmsgM -> addInfo(array('uid'=>$uids,'usertype'=>1, 'content'=>$msg));
}
$return['msg'] = '作品案例审核(ID:'.$idstr.')设置成功';
$return['errcode'] = '9';
}else{
$return['msg'] = '作品案例审核(ID:'.$idstr.')设置失败';
$return['errcode'] = '8';
}
}else{
$return['msg'] = '请选择要审核的作品案';
$return['errcode'] = '8';
}
return $return;
}
/**
* 修改个人头像
* @param array $whereData
* @param array $data photo/需上传的图片文件; thumb/已处理好的缩略图; utype/操作的用户类型; base/需上传的base4图片; preview/pc预览即上传
*/
public function upPhoto($whereData = array(),$data=array('photo'=>null,'thumb'=>null,'utype'=>null,'base'=>null,'preview'=>null))
{
if (!empty($whereData['uid'])){
$uid = $whereData['uid'];
// 头像还需上传的
if ($data['photo']['tmp_name'] || $data['base']){
$upArr = array(
'file' => $data['photo'],
'dir' => 'user',
'type' => 'logo',
'base' => $data['base'],
'preview' => $data['preview'],
'watermark'=> 0
);
$result = $this -> upload($upArr);
if (!empty($result['msg'])){
$return['msg'] = $result['msg'];
$return['errcode'] = '8';
return $return;
}elseif (!empty($result['picurl'])){
$photo = $result['picurl'];
}
}
// 已处理好的头像缩略图
if ($data['thumb']){
$photo = str_replace('../data','./data',$data['thumb'][1]);
}
if (!empty($photo)){
// 用户操作,且后台设置用户头像需要审核的
$rinfo=$this->getResumeInfo(array('uid'=>$uid),array('field'=>'r_status'));
if ($data['utype'] == 'user' && $this -> config['user_photo_status'] == 1){
$photo_status = 1;
}else{
$photo_status = $rinfo['r_status']!=1?1:0;
}
$resumeData = array('photo'=>$photo,'defphoto'=>1);
if ($data['utype'] == 'user'){
$pass = $this->infoConCheck($resumeData,array('uid'=>$uid,'usertype'=>1,'source'=>$data['source']));
if(!$pass){
$photo_status = 1;
}
}
$resumeData['photo_status'] = $photo_status;
$return['id'] = $this -> update_once('resume',$resumeData,array('uid'=>$uid));
}
if (isset($return['id'])) {
// 用户操作的,判断处理头像上传积分
if ($data['utype'] == 'user'){
require_once ('integral.model.php');
$IntegralM = new integral_model($this -> db, $this -> def);
$IntegralM -> invtalCheck($uid,1,'integral_avatar','上传头像');
$this -> addMemberLog($uid, 1, '上传头像', 16, 1);
if ($this -> config['user_photo_status'] == 1){
// 需审核时,简历表,以前的头像要清除
$this -> update_once('resume_expect',array('photo'=>'', 'defphoto' => 1),array('uid'=>$uid));
$return['errcode'] = '9';
$return['msg'] = '上传成功,管理员审核后对其他用户开放显示';
}else{
$this->update_once('resume_expect', array('photo' => $photo, 'defphoto' => 1), array('uid' => $uid));
$return['errcode'] = '9';
$return['msg'] = '上传成功';
}
// pc会员中心预览即上传,处理预览图
if ($data['preview']){
$return['picurl'] = checkpic($photo);
}
}else{
$return['msg'] = '个人头像(ID:'.$uid.')修改成功';
$return['errcode'] = '9';
}
}else{
$return['msg'] = '个人头像(ID:'.$uid.')修改失败';
$return['errcode'] = '8';
}
}else{
$return['msg'] = '请选择需要修改的用户';
$return['errcode'] = '8';
}
return $return;
}
/**
* 修改个人二维码
* @param array $whereData
* @param array $data photo/需上传的图片文件; base/需上传的base4图片; preview/pc预览即上传
*/
public function upEwm($whereData = array(),$data=array('photo'=>null,'base'=>null,'preview'=>null))
{
if (!empty($whereData['uid'])){
$uid = $whereData['uid'];
if ($data['photo'] || $data['base']){
$upArr = array(
'file' => $data['photo'],
'dir' => 'user',
'type' => 'ewm',
'base' => $data['base'],
'preview' => $data['preview']
);
$result = $this -> upload($upArr);
if (!empty($result['msg'])){
$return['msg'] = $result['msg'];
$return['errcode'] = '8';
return $return;
}elseif (!empty($result['picurl'])){
$photo = $result['picurl'];
}
}
if (!empty($photo)){
$resumeData = array('wxewm'=>$photo);
//内容检测
if ($data['utype'] == 'user'){
$pass = $this->infoConCheck($resumeData,array('uid'=>$uid,'usertype'=>1,'source'=>$data['source']));
if(!$pass){
$resumeData['r_status'] = 0;
}
}
$return['id'] = $this -> update_once('resume',$resumeData,array('uid'=>$uid));
if(isset($resumeData['r_status']) && $resumeData['r_status'] === 0){
$this->setExpectState(array('r_status'=>0,'state'=>0),array('uid'=>$uid));
}
}
if (isset($return['id'])) {
$this -> addMemberLog($uid, 1, '上传二维码', 16, 1);
// 处理预览图
if ($data['preview']){
$return['picurl'] = checkpic($photo);
}
$return['msg'] = '个人二维码修改成功';
$return['errcode'] = '9';
}else{
$return['msg'] = '个人二维码修改失败';
$return['errcode'] = '8';
}
}else{
$return['msg'] = '请选择需要修改的用户';
$return['errcode'] = '8';
}
return $return;
}
/**
* 内容检测
*/
function resumeConCheck($reusmeData,$data){
$expect = isset($reusmeData['expect'])?$reusmeData['expect']:array();
$workData = isset($reusmeData['workData'])?$reusmeData['workData']:array();
$eduData = isset($reusmeData['eduData'])?$reusmeData['eduData']:array();
$proData = isset($reusmeData['projectData'])?$reusmeData['projectData']:array();
$trainData = isset($reusmeData['trainingData'])?$reusmeData['trainingData']:array();
$skillData = isset($reusmeData['skillData'])?$reusmeData['skillData']:array();
$otherData = isset($reusmeData['otherData'])?$reusmeData['otherData']:array();
$showData = isset($reusmeData['showData'])?$reusmeData['showData']:array();
$docData = isset($reusmeData['docData'])?$reusmeData['docData']:array();
require_once('concheck.model.php');
$concheckM = new concheck_model($this->db,$this->def);
$check_con = array();
$check_pic = array();
$pass = true;
if(!empty($expect)){
if(isset($expect['name']) && $expect['name']!=''){
$check_con['expect_name'] = strip_tags($expect['name']);
}
}
if(!empty($workData)){
foreach ($workData as $wk => $wv) {
$wkey = $wk>0 ? '_'.$wk:'';
if(isset($wv['name']) && $wv['name']!=''){
$check_con['work_name'.$wkey] = strip_tags($wv['name']);
}
if(isset($wv['title']) && $wv['title']!=''){
$check_con['work_title_'.$wkey] = strip_tags($wv['title']);
}
if(isset($wv['content']) && $wv['content']!=''){
$check_con['work_content_'.$wkey] = strip_tags($wv['content']);
}
}
}
if(!empty($eduData)){
foreach ($eduData as $ek => $ev) {
$ekey = $ek>0 ? '_'.$ek:'';
if(isset($ev['name']) && $ev['name']!=''){
$check_con['edu_name'.$ekey] = strip_tags($ev['name']);
}
if(isset($ev['specialty']) && $ev['specialty']!=''){
$check_con['edu_specialty'.$ekey] = strip_tags($ev['specialty']);
}
}
}
if(!empty($proData)){
foreach ($proData as $pk => $pv) {
$pkey = $pk>0 ? '_'.$pk:'';
if(isset($pv['name']) && $pv['name']!=''){
$check_con['project_name'.$pkey] = strip_tags($pv['name']);
}
if(isset($pv['title']) && $pv['title']!=''){
$check_con['project_title'.$pkey] = strip_tags($pv['title']);
}
if(isset($pv['content']) && $pv['content']!=''){
$check_con['project_content'.$pkey] = strip_tags($pv['content']);
}
}
}
if(!empty($trainData)){
foreach ($trainData as $tk => $tv) {
$tkey = $tk>0 ? '_'.$tk:'';
if(isset($tv['name']) && $tv['name']!=''){
$check_con['train_name'.$tkey] = strip_tags($tv['name']);
}
if(isset($tv['title']) && $tv['title']!=''){
$check_con['train_title'.$tkey] = strip_tags($tv['title']);
}
if(isset($tv['content']) && $tv['content']!=''){
$check_con['train_content'.$tkey] = strip_tags($tv['content']);
}
}
}
if(!empty($skillData)){
foreach ($skillData as $sk => $sv) {
$skey = $sk>0 ? '_'.$sk:'';
if(isset($sv['name']) && $sv['name']!=''){
$check_con['skill_name'.$skey] = strip_tags($sv['name']);
}
}
}
if(!empty($otherData)){
foreach ($otherData as $ok => $ov) {
$okey = $ok>0 ? '_'.$ok:'';
if(isset($ov['name']) && $ov['name']!=''){
$check_con['other_name'.$okey] = strip_tags($ov['name']);
}
if(isset($ov['content']) && $ov['content']!=''){
$check_con['other_content'.$okey] = strip_tags($ov['content']);
}
}
}
if(!empty($docData)){
foreach ($docData as $dock => $docv) {
$dockey = $dock>0 ? '_'.$dock:'';
if(isset($docv['doc']) && $docv['doc']!=''){
$check_con['doc'.$dockey] = strip_tags($docv['doc']);
}
}
}
$check_con_data = array(
'type' => 'text',
'uid' => $data['uid'],
'usertype' => $data['usertype'],
'ctype' => 1,
'cid' => $data['eid']
);
if(isset($data['source'])){
$check_con_data['source'] = $data['source'];
}
if(!empty($check_con)){
$cresult = $concheckM->checkContent($check_con,$check_con_data);
$code = isset($cresult['code']) ? $cresult['code'] : 0;
if ($code != 1) {
$pass = false;
}
}
return $pass;
}
function infoConCheck($userdata,$data){
require_once('concheck.model.php');
$concheckM = new concheck_model($this->db,$this->def);
$check_con =array();
$check_pic =array();
$pass = true;
if(isset($userdata['name']) && $userdata['name']!=''){
$check_con['name'] = strip_tags($userdata['name']);
}
if(isset($userdata['living']) && $userdata['living']!=''){
$check_con['living'] = strip_tags($userdata['living']);
}
if(isset($userdata['address']) && $userdata['address']!=''){
$check_con['address'] = strip_tags($userdata['address']);
}
if(isset($userdata['nationality']) && $userdata['nationality']!=''){
$check_con['nationality'] = strip_tags($userdata['nationality']);
}
if(isset($userdata['domicile']) && $userdata['domicile']!=''){
$check_con['domicile'] = strip_tags($userdata['domicile']);
}
if(isset($userdata['description']) && $userdata['description']!=''){
$check_con['description'] = strip_tags($userdata['description']);
}
if(isset($userdata['tag']) && $userdata['tag']!=''){
$check_con['tag'] = strip_tags($userdata['tag']);
}
$check_con_data = array(
'type' => 'text',
'uid' => $data['uid'],
'usertype' => $data['usertype'],
'ctype' => 3,
'cid' => $data['uid']
);
if(isset($data['source'])){
$check_con_data['source'] = $data['source'];
}
if(!empty($check_con)){
$cresult = $concheckM->checkContent($check_con,$check_con_data);
$code = isset($cresult['code']) ? $cresult['code'] : 0;
if ($code != 1) {
$pass = false;
}
}
return $pass;
}
/**
* 删除个人头像
* @param string $id 格式:单个,如1 ; 批量,如1,2,3
*/
public function delPhoto($uid){
$return['layertype'] = 0;
if (!empty($uid)){
if(is_array($uid)){
$uid = pylode(',', $uid);
$return['layertype'] = 1;
}
$rdata = array(
'photo' => '',
'photo_status' => '',
'photo_statusbody' => ''
);
$return['id'] = $this -> update_once('resume', $rdata, array('uid'=>array('in',$uid)));
if ($return['id']){
//删除相关头像
$this -> update_once('resume_expect',array('photo'=>'','phototype'=>''),array('uid'=>array('in',$uid)));
$this -> update_once('answer',array('pic'=>''),array('uid'=>array('in',$uid)));
$this -> update_once('question',array('pic'=>''),array('uid'=>array('in',$uid)));
$return['msg'] = '个人头像(ID:'.$uid.')删除成功';
$return['errcode'] = '9';
}else{
$return['msg'] = '个人头像(ID:'.$uid.')删除失败';
$return['errcode'] = '8';
}
}else{
$return['msg'] = '请选择要删除的个人头像';
$return['errcode'] = '8';
}
return $return;
}
/**
* 个人作品列表(d单条)
* @param string $whereData
* @param array $data
*/
public function getResumeShowInfo($whereData = array(), $data =array()){
$data['field'] = empty($data['field']) ? '*' : $data['field'];
$resumeshow = $this -> select_once('resume_show', $whereData, $data['field']);
if (!empty($resumeshow)){
if ($resumeshow['picurl']){
$resumeshow['picurl_n'] = checkpic($resumeshow['picurl']);
}
}
return $resumeshow;
}
/**
* 后台个人作品列表
* @param array $whereData
* @param array $data
* @return array|bool|false|string|void
*/
public function getResumeShowList($whereData = array(), $data = array('field' => null, 'utype' => null))
{
$field = $data['field'] ? $data['field'] : '*';
$List = $this->select_all('resume_show', $whereData, $field);
if ($data['utype'] == 'admin') {
$resumeIds = array();
foreach ($List as $v) {
$resumeIds[] = $v['eid'];
}
$resume = $this->getSimpleList(array('id' => array('in', pylode(',', $resumeIds))), array('field' => '`id`,`name`,`uname`'));
}
foreach ($List as $k => $v) {
if (!empty($resume)) {
foreach ($resume as $val) {
if ($v['eid'] == $val['id']) {
$List[$k]['name'] = $val['uname'];
$List[$k]['expect'] = $val['name'];
}
}
}
$List[$k]['title'] = mb_substr($v['title'], 0, 15);
if (strpos($v['picurl'], 'http') === false) {
$List[$k]['picurl'] = checkpic($v['picurl']);
} else {
$List[$k]['picurl'] = '';
}
}
return $List;
}
/**
* 添加简历作品 resume_show
* @param array $data
* @return bool
*/
public function addResumeShow($data = array())
{
$post = $data['post'];
if(isset($data['file']) && $data['file']['tmp_name']!=''){
// pc端上传
$upArr = array(
'file' => $data['file'],
'dir' => 'show'
);
require_once ('upload.model.php');
$uploadM = new upload_model($this->db, $this->def);
$pic = $uploadM->newUpload($upArr);
if (!empty($pic['msg'])){
$return['msg'] = $pic['msg'];
$return['errcode'] = 8;
return $return;
}elseif (!empty($pic['picurl'])){
$post['picurl'] = $pic['picurl'];
}
}
if($data['utype']=='user'){
$resumeData['showData'] = $post;
if($data['id']){
$resumeshow = $this -> select_once('resume_show',array('id'=>$data['id'],'uid'=>$data['uid']),'`eid`');
$eid = $resumeshow['eid'];
}else{
$eid = $post['eid'];
}
$pass = $this->resumeConCheck($resumeData,array('uid'=>$data['uid'],'usertype'=>1,'eid'=>$eid));
if(!$pass){
$post['status'] = 1;
}
}
if($data['id']){
$updateWhere = array('id'=>$data['id']);
if (isset($data['uid']) && $data['uid']) {
$updateWhere['uid'] = $data['uid'];
}
$nid = $this -> update_once('resume_show',$post,$updateWhere);
if ($nid) {
$return['msg'] = '个人作品(ID:'.$data['id'].')修改成功';
$return['errcode'] = '9';
}else{
$return['msg'] = '个人作品(ID:'.$data['id'].')修改失败';
$return['errcode'] = '8';
}
return $return;
}else{
$member = $this->select_once('member',array('uid'=>$data['uid']),'`did`');
$post['did'] = $member['did'];
$post['uid'] = $data['uid'];
$post['ctime'] = time();
$nid = $this->insert_into('resume_show',$post);
if ($nid){
$this -> addMemberLog($data['uid'], $data['usertype'], '添加作品展示',16,3);
}
return $nid;
}
}
/**
* 删除个人作品
* @param string $id 格式:单个,如1 ; 批量,如1,2,3
*/
public function delShow($id,$data=array()){
$return['layertype'] = 0;
$limit = 'limit 1';
if (!empty($id)){
if(is_array($id)){
$ids = $id;
$return['layertype'] = 1;
$limit = '';
}else{
$ids = @explode(',', $id);
$return['layertype'] = 0;
}
$id = pylode(',', $ids);
if($data['utype'] == 'admin'){
$delWhere = array('id'=>array('in',$id));
}else{
$delWhere = array('uid'=>$data['uid'],'id'=>array('in',$id));
}
$return['id'] = $this -> delete_all('resume_show',$delWhere,$limit);
if ($return['id']){
$this -> addMemberLog($data['uid'],$data['usertype'],'删除作品案例',16,3);
$return['msg'] = '个人作品(ID:'.$id.')删除成功';
$return['errcode'] = '9';
}else{
$return['msg'] = '个人作品(ID:'.$id.')删除失败';
$return['errcode'] = '8';
}
}else{
$return['msg'] = '请选择要删除的个人作品';
$return['errcode'] = '8';
}
return $return;
}
/**
* 处理单个图片上传
* @param file/需上传文件; dir/上传目录; type/上传图片类型; base/需上传base64; preview/pc预览即上传
*/
private function upload($data = array('file'=>null,'dir'=>null,'type'=>null,'base'=>null,'preview'=>null)){
include_once('upload.model.php');
$UploadM = new upload_model($this->db, $this->def);
$upArr = array(
'file' => $data['file'],
'dir' => $data['dir'],
'type' => $data['type'],
'base' => $data['base'],
'preview' => $data['preview']
);
if (isset($data['watermark'])){
$upArr['watermark'] = $data['watermark'];
}
$return = $UploadM -> newUpload($upArr);
return $return;
}
/**
* 处理搜索用简历多城市、多职位记录
*/
private function city_job($eid, $uid, $lastupdate, $nowCity, $nowJob, $oldCity = '', $oldJob = '')
{
$resume_city = $this->addCityclass($eid, $uid, $nowCity);
$resume_job = $this->addJobclass($eid, $uid, $nowJob);
if (!empty($resume_city) && !empty($resume_job)){
if (!empty($oldCity) || !empty($oldJob)){
// 经处理的城市、职位不为空,并且已存在的城市或职位也不为空,说明是修改简历,需要将已存在的记录删除
$this -> delete_all('resume_city_job_class',array('eid'=>$eid,'uid'=>$uid),'');
}
$ac1 = $ac2 = $ac3 = $aj1 = $aj2 = $aj3 = $rcj = array();
foreach ($resume_city as $k=>$v){
foreach ($resume_job as $key=>$val){
// 分别统计每个字段出现次数,防止重复
$c1key = $v['provinceid'];
$c2key = $v['cityid'];
$c3key = $v['three_cityid'];
$j1key = $val['job1'];
$j2key = $val['job1_son'];
$j3key = $val['job_post'];
$ac1[$c1key] = isset($ac1[$c1key]) ? $ac1[$c1key] + 1 : 1;
$ac2[$c2key] = isset($ac2[$c2key]) ? $ac2[$c2key] + 1 : 1;
$ac3[$c3key] = isset($ac3[$c3key]) ? $ac3[$c3key] + 1 : 1;
$aj1[$j1key] = isset($aj1[$j1key]) ? $aj1[$j1key] + 1 : 1;
$aj2[$j2key] = isset($aj2[$j2key]) ? $aj2[$j2key] + 1 : 1;
$aj3[$j3key] = isset($aj3[$j3key]) ? $aj3[$j3key] + 1 : 1;
$rcj[] = array(
'provinceid' => $c1key,
'provinceid_num' => $ac1[$c1key],
'cityid' => $c2key,
'cityid_num' => $ac2[$c2key],
'three_cityid' => $c3key,
'three_cityid_num' => $ac3[$c3key],
'job1' => $j1key,
'job1_num' => $aj1[$j1key],
'job1_son' => $j2key,
'job1_son_num' => $aj2[$j2key],
'job_post' => !empty($j3key) ? $j3key : 0,
'job_post_num' => $aj3[$j3key],
);
}
}
// 处理合并后数量
if (!empty($rcj)){
// 统计字段组合出现次数
$c1j1 = $c1j2 = $c1j3 = $c2j1 = $c2j2 = $c2j3 = $c3j1 = $c3j2 = $c3j3 = array();
foreach ($rcj as $k=>$v){
$c1j1[$v['provinceid'].'_'.$v['job1']][] = $v['provinceid'].'_'.$v['job1'];
$c1j2[$v['provinceid'].'_'.$v['job1_son']][] = $v['provinceid'].'_'.$v['job1_son'];
$c1j3[$v['provinceid'].'_'.$v['job_post']][] = $v['provinceid'].'_'.$v['job_post'];
$c2j1[$v['cityid'].'_'.$v['job1']][] = $v['cityid'].'_'.$v['job1'];
$c2j2[$v['cityid'].'_'.$v['job1_son']][] = $v['cityid'].'_'.$v['job1_son'];
$c2j3[$v['cityid'].'_'.$v['job_post']][] = $v['cityid'].'_'.$v['job_post'];
$c3j1[$v['three_cityid'].'_'.$v['job1']][] = $v['three_cityid'].'_'.$v['job1'];
$c3j2[$v['three_cityid'].'_'.$v['job1_son']][] = $v['three_cityid'].'_'.$v['job1_son'];
$c3j3[$v['three_cityid'].'_'.$v['job_post']][] = $v['three_cityid'].'_'.$v['job_post'];
$rcj[$k]['provinceid_job1_num'] = count($c1j1[$v['provinceid'].'_'.$v['job1']]);
$rcj[$k]['provinceid_job1_son_num'] = count($c1j2[$v['provinceid'].'_'.$v['job1_son']]);
$rcj[$k]['provinceid_job_post_num'] = count($c1j3[$v['provinceid'].'_'.$v['job_post']]);
$rcj[$k]['cityid_job1_num'] = count($c2j1[$v['cityid'].'_'.$v['job1']]);
$rcj[$k]['cityid_job1_son_num'] = count($c2j2[$v['cityid'].'_'.$v['job1_son']]);
$rcj[$k]['cityid_job_post_num'] = count($c2j3[$v['cityid'].'_'.$v['job_post']]);
$rcj[$k]['three_cityid_job1_num'] = count($c3j1[$v['three_cityid'].'_'.$v['job1']]);
$rcj[$k]['three_cityid_job1_son_num'] = count($c3j2[$v['three_cityid'].'_'.$v['job1_son']]);
$rcj[$k]['three_cityid_job_post_num'] = count($c3j3[$v['three_cityid'].'_'.$v['job_post']]);
$rcj[$k]['eid'] = $eid;
$rcj[$k]['uid'] = $uid;
$rcj[$k]['lastupdate'] = $lastupdate;
}
$this -> DB_insert_multi('resume_city_job_class',$rcj);
}
}
}
/**
* 获取职位、城市字段出现字数
*/
private function getNum($id = '', $idarr = array(), $numarr = array())
{
$num = in_array($id, $idarr) && isset($numarr[$id]) ? $numarr[$id] + 1 : 1;
return $num;
}
/**
* 处理简历多城市的添加、修改
*/
private function addCityclass($eid, $uid, $nowCity, $oldCity = '')
{
$resume_city = $city_sort = array();
if (!empty($eid) && !empty($uid) && !empty($nowCity)){
$cityArr = @explode(',', $nowCity);
$citynochange = 0;
//修改之前先判断是否需要修改,需要修改,先删除之前保存的
if ($oldCity != ''){
$oldArr = @explode(',', $oldCity);
if(array_diff($oldArr,$cityArr) || array_diff($cityArr,$oldArr)){
$citynochange = 1;
$this -> delete_all('resume_cityclass',array('eid'=>$eid),'');
}
}else{
$citynochange = 1;
}
if($citynochange == 1){
include(PLUS_PATH.'cityparent.cache.php');
foreach ($cityArr as $v){
//获取当前城市级别,根据级别来处理,获得其他级别的数据
$lev = getLev($v,$city_parent);
if ($lev == 1){
$provinceid = $v;
$cityid = 0;
$threecityid = 0;
}elseif ($lev == 2){
$cityid = $v;
$provinceid = $city_parent[$v];
$threecityid = 0;
}elseif ($lev == 3){
$threecityid = $v;
$cityid = $city_parent[$threecityid];
$provinceid = $city_parent[$cityid];
}
$resume_city[]=array(
'provinceid' => $provinceid,
'cityid' => $cityid,
'three_cityid' => $threecityid
);
$city_sort[] = $provinceid;
}
if (!empty($resume_city)){
$list = array();
foreach ($resume_city as $k=>$v){
$list[$k]['eid'] = $eid;
$list[$k]['uid'] = $uid;
$list[$k]['provinceid'] = $v['provinceid'];
$list[$k]['cityid'] = $v['cityid'];
$list[$k]['three_cityid'] = $v['three_cityid'];
}
$this -> DB_insert_multi('resume_cityclass',$list);
array_multisort($city_sort, SORT_ASC, SORT_NUMERIC, $resume_city);
}
}
}
return $resume_city;
}
/**
* 处理简历多职位的添加、修改
*/
private function addJobclass($eid, $uid, $nowJob, $oldJob = ''){
$resume_job = $job_sort = array();
if (!empty($eid) && !empty($uid) && !empty($nowJob)){
$jobArr = @explode(',', $nowJob);
$jobnochange = 0;
//修改之前先判断是否需要修改,需要修改,先删除之前保存的
if ($oldJob != ''){
$oldArr = @explode(',', $oldJob);
if(array_diff($oldArr,$jobArr) || array_diff($jobArr,$oldArr)){
$jobnochange = 1;
$this -> delete_all('resume_jobclass',array('eid'=>$eid),'');
}
}else{
$jobnochange=1;
}
if($jobnochange==1){
include(PLUS_PATH.'jobparent.cache.php');
foreach ($jobArr as $v){
//获取当前职位级别,根据级别来处理,获得其他级别的数据
$lev = getLev($v,$job_parent);
if ($lev == 1){
$job = $v;
$jobson = 0;
$jobpost = 0;
}elseif ($lev == 2){
$jobson = $v;
$job = $job_parent[$v];
$jobpost = 0;
}elseif ($lev == 3){
$jobpost = $v;
$jobson = $job_parent[$jobpost];
$job = $job_parent[$jobson];
}
$resume_job[]=array(
'job1' => $job,
'job1_son' => $jobson,
'job_post' => $jobpost
);
$job_sort[] = $job;
}
if (!empty($resume_job)){
$list = array();
foreach ($resume_job as $k=>$v){
$list[$k]['eid'] = $eid;
$list[$k]['uid'] = $uid;
$list[$k]['job1'] = $v['job1'];
$list[$k]['job1_son'] = $v['job1_son'];
$list[$k]['job_post'] = $v['job_post'];
}
$this -> DB_insert_multi('resume_jobclass',$list);
array_multisort($job_sort, SORT_ASC, SORT_NUMERIC, $resume_job);
}
}
}
return $resume_job;
}
public function getCityclassList($whereData = array(),$data=array())
{
$field = !empty($data['field']) ? $data['field'] : '*';
$rows = $this -> select_all('resume_cityclass',$whereData,$field);
return $rows;
}
public function getCityJobClass($whereData = array(), $field = '*'){
$rows = $this -> select_all('resume_city_job_class', $whereData, $field);
return $rows;
}
public function getJobclassList($whereData = array())
{
$rows = $this -> select_all('resume_jobclass',$whereData);
return $rows;
}
private function getClass($options)
{
if (!empty($options)){
include_once('cache.model.php');
$cacheM = new cache_model($this->db,$this->def);
$cache = $cacheM -> GetCache($options);
return $cache;
}
}
private function getDataUserList($List){
if(!empty($List)){
$uids = $cids = array();
foreach ($List as $val) {
$uids[] = $val['uid'];
if ($val['crm_uid']) {
$cids[] = $val['crm_uid'];
}
}
// 查询admin_user 业务员信息
$crmList = $this->select_all('admin_user', array('uid' => array('in', pylode(',', $cids))), '`uid`,`name`');
$member = $this->select_all('member', array('uid' => array('in', pylode(',', $uids))), '`uid`,`username`,`usertype`,`reg_date`,`login_date`,`source`,`status`,`wxopenid`,`unionid`,`wxid`,`app_wxid`');
$sqList = $this->select_all('userid_job', array('uid' => array('in', pylode(',', $uids)),'isdel'=>9), '`uid`');
foreach($List as $k=>$v){
foreach($member as $val){
if($v['uid'] == $val['uid']){
$List[$k] = array_merge($List[$k], $val);
$List[$k]['app_wxid'] = $val['app_wxid'];
$List[$k]['unionid'] = $val['unionid'];
$List[$k]['wxopenid'] = $val['wxopenid'];
$List[$k]['wxid'] = $val['wxid'];
}
}
// 提取顾问表查询数据
if (!empty($crmList)) {
foreach ($crmList as $crm){
if($v['crm_uid'] == $crm['uid']){
$List[$k]['crm_name'] = $crm['name'];
}
}
}
foreach ($sqList as $sk => $sv){
if ($v['uid'] == $sv['uid']){
$List[$k]['sq_num']++;
}
}
}
}
return $List;
}
//后台列表处理简历多城市/用户名、审核状态
private function getDataList($List,$cache)
{
foreach ($List as $v) {
$uids[] = $v['uid'];
$eids[] = $v['id'];
}
$member = $this->select_all('member',array('uid'=>array('in',pylode(',', $uids))),'uid,username,moblie');
$resume_city = $this->select_all('resume_cityclass',array('eid'=>array('in',pylode(',', $eids))),'eid,provinceid,cityid,three_cityid');
$sqList = $this->select_all('userid_job', array('eid' => array('in', pylode(',', $eids))), '`uid`,`eid`');
foreach($List as $k=>$v){
foreach($member as $val){
if($val['uid']==$v['uid']){
$List[$k]['username'] = $val['username'];
$List[$k]['moblie'] = $val['moblie'];
}
}
if ($resume_city){
$city_classid = explode(',',$v['city_classid']);
foreach($resume_city as $val){
if($v['id'] == $val['eid']){
if($val['provinceid'] == $city_classid[0]){
$List[$k]['city_n'] = $cache['city_name'][$city_classid[0]];
}else if($val['cityid']==$city_classid[0]){
$List[$k]['city_n'] = $cache['city_name'][$val['provinceid']].'-'.$cache['city_name'][$city_classid[0]];
}else if($val['three_cityid']==$city_classid[0]){
$List[$k]['city_n'] = $cache['city_name'][$val['provinceid']].'-'.$cache['city_name'][$val['cityid']].'-'.$cache['city_name'][$city_classid[0]];
}
}
}
$cityall = array();
if(is_array($city_classid)){
$i = 0;
foreach($city_classid as $cv){
if($cache['city_name'][$cv]){
$i++;
$cityall[] = $cache['city_name'][$cv];
}
}
$List[$k]['citynum'] = $i;
}
$List[$k]['cityall'] = implode('、',$cityall);
}
foreach ($sqList as $sk => $sv){
if ($v['id'] == $sv['eid'] && $v['uid'] == $sv['uid']){
$List[$k]['sq_num']++;
}
}
}
return $List;
}
//计算工作经历工作时长
private function workTime($eid)
{
$workList = $this -> getResumeWorks(array('eid'=>$eid),'sdate,edate');
$whour = 0;
$hour = array();
$time = time();
foreach($workList as $v){
//计算每份工作时长(按月)
if ($v['edate']){
$workTime = ceil(($v['edate']-$v['sdate'])/(30*86400));
}else{
$workTime = ceil(($time - $v['sdate'])/(30*86400));
}
$hour[] = $workTime;
$whour += $workTime;
}
//更新当前简历时长字段
$avghour = ceil($whour/count($hour));
$post = array(
'whour' => $whour,
'avghour' => $avghour
);
$this -> update_once('resume_expect', $post, array('id'=>$eid));
}
/**
* @desc 简历推送列表
*
* @param array $whereData
* @param array $data
*/
public function getResTsList($whereData,$data=array()) {
$select = $data['field'] ? $data['field'] : '*';
$List = $this -> select_all('user_entrust_record',$whereData,$select);
return $List;
}
/**
* @desc 收藏人才列表查询
*/
function getTalentList($whereData = array(), $data = array()) {
$field = $data['field'] ? $data['field'] : '*';
$List = $this -> select_all('talent_pool',$whereData,$field);
if (!empty($List)) {
$List = $this -> subTalentInfo($List,$data);
}
return $List;
}
/**
* @desc 收藏人才列表信息补充完善
*/
private function subTalentInfo($List,$data) {
$utype = isset($data['utype']) ? $data['utype'] : '';
foreach ($List as $v) {
$uids[] = $v['uid'];
$eids[] = $v['eid'];
$cuids[] = $v['cuid'];
}
// 查询个人简历名称
$reWhere['id'] = array('in', pylode(',', $eids));
$reData['field'] = '`id`,`name`,`job_classid`,`minsalary`,`maxsalary`,`height_status`,`exp`,`edu`,`birthday`,`sex`,`uname`,`photo`';
$expect = $this -> getList($reWhere, $reData);
if ($utype == 'admin'){
/* 提取企业信息 */
$cWhere['uid'] = array('in', pylode(',', $cuids));
$comList = $this -> select_all('company', $cWhere,'`uid`,`name`');
}
if ($utype == 'pc'){
$userid_msg = $this -> select_all('userid_msg',array('fid'=>$data['uid'],'uid'=>array('in',pylode(',',$uids)),'isdel'=>9),'`uid`');
$userid_job = $this -> select_all('userid_job',array('com_id'=>$data['uid'],'uid'=>array('in',pylode(',',$uids)),'isdel'=>9),'`uid`,`is_browse`');
}
$downArr = array();
if(isset($data['isdown']) && $data['isdown'] == 1){
$downList = $this -> select_all('down_resume', array('comid' => $data['uid'], 'uid'=>array('in',pylode(',', $uids))), '`uid`,`eid`');
foreach ($downList as $val){
$downArr[] = $v['uid'];
}
}
foreach ($List as $k => $v){
$List[$k]['wapurl'] = Url('wap', array('c'=>'resume','a'=>'show','id'=>$v['eid']));
$List[$k]['remark'] = stripslashes($v['remark']);
$List[$k]['ctime_n'] = timeForYear($v['ctime']);
$List[$k]['datetime_n'] = $List[$k]['ctime_n'];
foreach ($expect['list'] as $rv){
if ($v['eid'] == $rv['id']) {
$List[$k]['rname'] = $rv['name'];
$List[$k]['exp'] = $rv['exp_n'];
$List[$k]['edu'] = $rv['edu_n'];
$List[$k]['age'] = $rv['age_n'];
$List[$k]['salary'] = $rv['salary'];
$List[$k]['photo'] = $rv['photo_n'];
if ($rv['job_classid'] != '') {
$List[$k]['jobname'] = $rv['job_classname'];
}
if ($utype == 'admin'){
// 后台直接展示姓名
$List[$k]['username'] = $rv['uname'];
}else{
if (in_array($v['uid'], $downArr)){
$List[$k]['username'] = $rv['uname'];
}else{
$nameArr = array('nametype'=>$this->config['user_name'], 'name' => $rv['uname'], 'eid' => $rv['id'], 'sex' => $rv['sex']);
$List[$k]['username'] = $this -> setUsernameShow($nameArr);
}
}
}
}
if (!empty($comList)){
foreach ($comList as $cv){
if ($v['cuid'] == $cv['uid']) {
$List[$k]['com_name'] = $cv['name'];
}
}
}
if (!empty($userid_msg)){
foreach($userid_msg as $val){
if($v['uid']==$val['uid']){
$List[$k]['userid_msg'] = 1;
}
}
}
if (!empty($userid_msg)){
foreach($userid_job as $val){
if($v['uid']==$val['uid']){
$List[$k]['is_browse'] = $val['is_browse'];
}
}
}
if (!empty($downList)){
foreach($downList as $dv){
if($v['uid']==$dv['uid'] && $v['eid'] == $dv['eid']){
$List[$k]['down'] = 1;
}
}
}
}
return $List;
}
/**
* @desc 删除收藏人才
*/
function delTalentPool($id = null , $data = array()){
if(!empty($id)){
if(is_array($id)){
$ids = $id;
$return['layertype'] = 1;
}else{
$ids = @explode(',', $id);
$return['layertype'] = 0;
}
$id = pylode(',', $ids);
if($data['utype'] !='admin'){
$delWhere = array('cuid'=>$data['uid'],'id' => array('in',$id));
}else{
$delWhere = array('id' => array('in',$id));
}
$return['id'] = $this -> delete_all('talent_pool',$delWhere,'');
$this -> addMemberLog($data['uid'],$data['usertype'],'删除收藏简历人才',5,3);
$return['msg'] = '收藏人才记录(ID:'.$id.')';
$return['errcode'] = $return['id'] ? '9' :'8';
$return['msg'] = $return['id'] ? $return['msg'].'删除成功!' : $return['msg'].'删除失败!';
}elseif($data['where']){
$where = $data['where'];
if($data['norecycle'] == '1'){ // 数据库清理,不插入回收站
$nid = $this -> delete_all('talent_pool', $where, '', '', '1');
}else{
$nid = $this -> delete_all('talent_pool', $where, '');
}
return $nid;
}else{
$return['msg'] = '请选择您要删除的数据!';
$return['errcode'] = 8;
}
return $return;
}
/**
* @desc 收藏人才列表数量
*/
function getTalentNum($whereData = array()) {
return $this -> select_num('talent_pool',$whereData);
}
/**
* 收藏简历
*/
public function addTalent($data = array()){
$return = array();
if($data['cuid']==''){
$return['msg'] = '您还未登录企业账号,是否登录?';
$return['errcode'] = 8;
$return['state'] = 3;
return $return;
}
if($data['usertype'] != "2"){
$return['msg'] = '只有企业用户,才可以操作!';
$return['errcode'] = 8;
$return['state'] = 0;
return $return;
}
$row = $this -> select_once('talent_pool',array('eid' => $data['eid'], 'cuid' => $data['cuid']));
if(empty($row)){
$tdata=array(
'eid' => $data['eid'],
'cuid' => $data['cuid'],
'uid' => (int)$data['uid'],
'remark' => $data['remark'],
'ctime' => time(),
);
$this -> insert_into('talent_pool',$tdata);
//加入收藏信息
$company = $this -> select_once('company', array('uid' => $data['cuid']), '`name`');
require_once ('sysmsg.model.php');
$sysmsgM = new sysmsg_model($this->db, $this->def);
$sysmsgM -> addInfo(array('uid' => $data['uid'],'usertype'=>1, 'content' => '企业 '.$company['name'].' 收藏您的简历'));
require_once ('history.model.php');
$historyM = new history_model($this->db, $this->def);
$historyM->addHistory('talentpool',$data['eid']);
$return['msg'] = '收藏成功!';
$return['errcode'] = 9;
$return['state'] = 1;
}else{
// $return['msg'] = '该简历已加入到人才库!';
// $return['errcode'] = 8;
// $return['state'] = 2;
$this -> delete_all('talent_pool', array('id' => $row['id']));
$this -> addMemberLog($data['cuid'],$data['usertype'],'取消收藏简历',5,3);
$return['msg'] = '取消收藏!';
$return['errcode'] = 9;
$return['state'] = 1;
}
return $return;
}
/**
* 添加收藏简历备注
*/
public function RemarkTalent($data = array()){
if($data['remark']==''){
$return['msg'] = '备注内容不能为空!';
$return['errcode'] = 8;
}
$id = $this -> update_once('talent_pool',array('remark'=>$data['remark']),array('id'=>intval($data['id']),'cuid'=>$data['uid']));
if ($id){
$this -> addMemberLog($data['uid'],$data['usertype'],'收藏备注'.$data['rname'],5,1);
$return['msg'] = '备注成功!';
$return['errcode'] = '9';
}else{
$return['msg'] = '备注失败!';
$return['errcode'] = '8';
}
return $return;
}
/**
* 添加收到简历备注
*/
public function RemarkHr($data = array()){
if($data['remark']==''){
$return['msg'] = '备注内容不能为空!';
$return['errcode'] = 8;
}
$id = $this -> update_once('userid_job',array('remark'=>$data['remark']),array('id'=>intval($data['id']),'com_id'=>$data['uid']));
if ($id){
$this -> addMemberLog($data['uid'],$data['usertype'],'收到简历备注'.$data['rname'],5,1);
$return['msg'] = '备注成功!';
$return['errcode'] = '9';
}else{
$return['msg'] = '备注失败!';
$return['errcode'] = '8';
}
return $return;
}
/**
* 设置姓名展示
*/
public function setUsernameShow($data = array())
{
$resUserName = '';
if(empty($this -> config['user_name']) || $this -> config['user_name'] == 1){
if($data['nametype'] == 1 && !empty($data['name'])){
if(CheckMobile($data['name'])){
$resUserName = mb_substr($data['name'], 0, 3)."****". mb_substr($data['name'], 7);
}else{
$resUserName = $data['name'];
}
}else if($data['nametype'] == 2 && !empty($data['eid'])){
$resUserName = 'NO.'. $data['eid'];
}elseif($data['nametype'] == 3 && !empty($data['name'])){
if($data['sex'] == 1){
$resUserName = mb_substr($data['name'], 0, 1, 'utf-8').'先生';
}else{
$resUserName = mb_substr($data['name'], 0, 1, 'utf-8').'女士';
}
}
}elseif($this -> config['user_name'] == 2 && !empty($data['eid'])){
$resUserName = 'NO.'. $data['eid'];
}elseif($this -> config['user_name'] == 3 && !empty($data['name'])){
if($data['sex'] == 1){
$resUserName = mb_substr($data['name'], 0, 1, 'utf-8').'先生';
}else{
$resUserName = mb_substr($data['name'], 0, 1, 'utf-8').'女士';
}
}elseif($this -> config['user_name'] == 4 && !empty($data['name'])){
$resUserName = $data['name'];
}
if(empty($resUserName)){
$resUserName = $data['name'];
}
return $resUserName;
}
/**
* 设置简历头像展示
*/
public function setResumePhotoShow($data = array())
{
$resumePhoto = '';
$maleUrl = checkpic('',$this -> config['sy_member_icon']);
$femaleUrl = checkpic('',$this -> config['sy_member_iconv']);
$sexArr = array(1, 152);
if($data['defphoto']==2){
$resumePhoto = checkpic($data['photo']);
}else{
if(empty($this -> config['user_pic']) || $this -> config['user_pic'] == 1){
if($data['photo'] && $data['photo_status'] == 0 && $data['phototype'] != 1){
$resumePhoto = checkpic($data['photo']);
}else{
if(in_array($data['sex'], $sexArr)){
$resumePhoto = $maleUrl;
}else{
$resumePhoto = $femaleUrl;
}
}
}elseif($this -> config['user_pic'] == 2){
if($data['photo'] && $data['photo_status'] == 0){
$resumePhoto = checkpic($data['photo']);
}else{
if(in_array($data['sex'], $sexArr)){
$resumePhoto = $maleUrl;
}else{
$resumePhoto = $femaleUrl;
}
}
}elseif($this -> config['user_pic'] == 3){
if(in_array($data['sex'], $sexArr)){
$resumePhoto = $maleUrl;
}else{
$resumePhoto = $femaleUrl;
}
}
}
return $resumePhoto;
}
//更新职位点击率
function addExpectHits($id){
if($this -> config['sy_job_hits'] > 100 || !$this -> config['sy_job_hits']){
$hits = 1;
}else{
$hits = mt_rand(1, $this->config['sy_job_hits']);
}
$this -> update_once('resume_expect', array('hits' => array('+', $hits)), array('id' => $id));
}
/**
* @desc 更新简历相关字段$table 比如:resume_edu,exp,other等
* @param $table
* @param $whereData
* @param $data
* @param array $odata
* @return bool
*/
function upResumeTable($table, $whereData, $data, $odata = array())
{
if (!empty($whereData)) {
$nid = $this->update_once($table, $data, $whereData);
} else {
if ($data['eid'] && $data['uid']) {
$eptNum = $this->select_num('resume_expect', array('id' => intval($data['eid']), 'uid' => intval($data['uid'])));
if ($eptNum > 0) {
$nid= $this->insert_into($table, $data);
}
}
}
$state = $this->config['user_revise_state'];
$expect = $this->select_once('resume_expect', array('id' => $data['eid']), 'state');
if ($expect['state'] == 3){
$state = 0;
}
if ($table != 'resume_show') {
if ($state == '0') {
$this->setExpectState(array('state' => 0), array('id' => intval($data['eid'])));
}
}
return $nid;
}
/**
* @desc 简历外发列表查询
*/
function getResumeOutList($whereData = array(), $data = array()) {
$field = $data['field'] ? $data['field'] : '*';
$List = $this -> select_all('resumeout',$whereData,$field);
return $List;
}
/**
* 添加简历外发
*/
public function addResumeOut($data,$param){
include_once('recommend.model.php');
$recomM = new recommend_model($this->db, $this->def);
if(isset($this->config['sy_resumeout_day_num']) && $this->config['sy_resumeout_day_num'] > 0){
$rnwhere=array('uid'=>$param['uid'],'rec_type'=>3,'addtime'=>array('>',strtotime('today')));
$num = $recomM -> getRecommendNum($rnwhere);
if($num >= $this->config['sy_resumeout_day_num']){
return array('msg'=>'每天最多外发'.$this->config['sy_resumeout_day_num'].'次简历!','errcode'=>8);
}
}else{
return array('msg'=>'外发简历功能已关闭!','errcode'=>8);
}
//判断上一次外发的时间间隔
if(isset($this->config['sy_resumeout_interval']) && $this->config['sy_resumeout_interval'] > 0){
$row = $recomM -> getInfo(array('uid' =>$param['uid'],'rec_type'=>3, 'orderby' => 'addtime'));
if(!empty($row['addtime']) && (time() - $row['addtime']) < $this->config['sy_resumeout_interval']){
$needTime = $this->config['sy_resumeout_interval'] - (time() - $row['addtime']);
if($needTime > 60){
$h = floor(($needTime % (3600*24)) / 3600);
$m = floor((($needTime % (3600*24)) % 3600) / 60);
$s = floor((($needTime % (3600*24)) % 3600 % 60));
if($h != 0){
$needTime = $h.'时';
}else if($m != 0){
$needTime = $m.'分';
}
}else{
$needTime = $needTime.'秒';
}
$recs = $this->config['sy_resumeout_interval'];
if($recs>60){
$h = floor(($recs % (3600*24)) / 3600);
$m = floor((($recs % (3600*24)) % 3600) / 60);
$s = floor((($recs % (3600*24)) % 3600 % 60));
if($h != 0){
$recs = $h.'时';
}else if($m != 0){
$recs = $m.'分';
}
}else{
$recs = $recs.'秒';
}
return array('msg'=>'外发简历间隔不得少于'.$recs.',请'.$needTime.'后再外发!','errcode'=>8);
}
}
if (!empty($data)){
if($data['resume']==''){
return array('msg'=>'请选择简历','errcode'=>8);
}
$email=$data['email'];
if($email==''){
return array('msg'=>'请输入邮箱','errcode'=>8);
}elseif (CheckRegEmail($email)==false){
return array('msg'=>'邮箱格式错误','errcode'=>8);
}
if($data['comname']==''){
return array('msg'=>'请输入企业名称','errcode'=>8);
}
if ($data['jobname']==''){
return array('msg'=>'请输入职位名称','errcode'=>8);
}
if($this->config['sy_email_set']!='1'){
return array('msg'=>'网站邮件服务器不可用','errcode'=>8);
}
$today = strtotime('today');
$outnum = $this->select_num('resumeout', array('uid'=>$data['uid'],'datetime'=>array('>', $today)));
if(!empty($this->config['sy_recommend_day_num']) && $outnum > $this->config['sy_recommend_day_num']){
return array('msg'=>'简历每天只能推荐'.$this->config['sy_recommend_day_num'].'次','errcode'=>8);
}elseif(!$this->config['sy_recommend_day_num'] || $this->config['sy_recommend_day_num']<=0){
return array('msg'=>'推荐功能已关闭','errcode'=>8);
}elseif(isset($_COOKIE['resumeout']) && $_COOKIE['resumeout'] == $data['resume']){
return array('msg'=>'请不要频繁发送邮件!同一简历发送间隔为两分钟!','errcode'=>8);
}
$Info = $this->getInfoByEid(array('eid' => $data['resume']));
// 简历模糊化
$resumeCheck = $this->config['resume_open_check'] == 1 ? 1 : 2;
global $phpyun;
$phpyun -> assign('Info',$Info);
$phpyun -> assign('resumeCheck',$resumeCheck);
$contents = $phpyun -> fetch(TPL_PATH.'resume/sendresume.htm',time());
//发送邮件并记录入库
$emailData=array(
'email' => $email,
'subject' => '我看到贵公司在招收'.$data['jobname'].',向您自荐一份简历!',
'content' => $contents,
'uid' => '',
'name' => $data['recipient'],
'cuid' => $Info['uid'],
'cname' => $Info['name']
);
include_once('notice.model.php');
$noticeM = new notice_model($this->db, $this->def);
$sendid = $noticeM -> sendEmail($emailData);
if($sendid['status'] != -1){
$arr = array(
'uid' => $Info['uid'],
'comname' => $data['comname'],
'jobname' => $data['jobname'],
'recipient' => $data['comname'],
'email' => $email,
'datetime' => time(),
'resume' => $data['resumename']
);
$this -> insert_into('resumeout',$arr);
require_once ('cookie.model.php');
$cookieM = new cookie_model($this->db, $this->def);
$cookieM -> SetCookie('resumeout', $data['resume'], time() + 120);
$recommend = array(
'uid' => $Info['uid'],
'rec_type' => 3,
'rec_id' => $data['resume'],
'email' => $email,
'addtime' => time()
);
$result = $recomM -> addRecommendInfo($recommend);
return array('msg'=>'发送成功','errcode'=>9);
}else{
return array('msg'=>'邮件发送错误 原因:' . $sendid['msg'],'errcode'=>8);
}
}
}
/**
* 删除简历外发记录
* @param string $id 格式:单个,如1 ; 批量,如1,2,3
*/
public function delResumeOut($id,$data=array()){
$return['layertype'] = 0;
$limit = 'limit 1';
if (!empty($id)){
if(is_array($id)){
$id = pylode(',', $id);
$return['layertype'] = 1;
$limit = '';
}
$return['id'] = $this -> delete_all('resumeout',array('uid'=>$data['uid'],'id'=>array('in',$id)),$limit);
if ($return['id']){
$this->addMemberLog($data['uid'],$data['usertype'],'删除简历外发记录',2,3);
$return['msg'] = '删除成功';
$return['errcode'] = '9';
}else{
$return['msg'] = '删除失败';
$return['errcode'] = '8';
}
}else{
$return['msg'] = '请选择要删除的记录';
$return['errcode'] = '8';
}
return $return;
}
//简历分布定价,按照时间分别定价
function setDayprice($eid,$data=array()){
$rinfo = $this -> select_once('resume_expect',array('id'=>$eid),'lastupdate');
$conlist = $this -> select_once('admin_config',array('name'=>'integral_down_resume_dayprice'));
$marr = explode(':',$conlist['config']);
foreach($marr as $v){
$narr = explode('_',$v);
$days[] = $narr[0];
$data[$narr[0]] = $narr[1];
}
$ryear = intval(date('Y',time()-$rinfo['lastupdate']));
$rday = intval(date('d', time() - $rinfo['lastupdate']));
if ($ryear != 0) {
$rday = $ryear * 365 + $rday;
}
if(in_array($rday,$days)){
$rdayprice=$data[$rday];
}else{
foreach($days as $val){
if($rday<$val){
$rdayprice=$data[$val];
break;
}
}
}
if(!$rdayprice){
if($data['integral']&&$data['integral']=='yes'){
$newdayprice = $this->config['integral_down_resume'] * $this->config['integral_proportion'];// 购买简历下载所需积分
}else{
$newdayprice = $this->config['integral_down_resume']; // 购买简历下载所需金额
}
}else{
if($data['integral']&&$data['integral']=='yes'){
$newdayprice = $rdayprice*$this->config['integral_proportion'];
}else{
$newdayprice = $rdayprice;
}
}
return $newdayprice;
}
/**
* 简历开放状态检查
* @param array $data
*/
function openResumeCheck($data){
$type = 2;
if(isset($data['from']) && $data['from']=='reward'){
$type = 1;
}else{
/* 个人查看自己 */
if(isset($data['ruid']) && $data['uid']==$data['ruid']){
$type = 1;
}else{
/* 开放状态 */
if($this->config['resume_open_check'] == 1){
$type = 1;
}
/* 企业登录状态 */
if($this->config['resume_open_check'] == 2){
if($data['uid'] && $data['usertype']==2 || $data['usertype'] == 3){
$type = 1;
}
}
/* 发布职位状态 */
if($this->config['resume_open_check'] == 3){
if($data['uid'] && $data['usertype']==2){
$where['r_status'] = 1;
$where['status'] = '0';
$where['state'] = '1';
$where['uid'] = $data['uid'];
$jobNum = $this->select_num('company_job',$where);
if($jobNum>0){
$type = 1;
}
}
}
/* 下载简历状态(包括企业可以免费查看投递简历) */
if($this->config['resume_open_check'] == 4){
if($data['uid']){
$where['comid'] = $data['uid'];
$where['eid'] = $data['eid'];
$where['usertype'] = $data['usertype'];
$downNum = $this->select_num('down_resume', $where);
if($downNum>0){
$type = 1;
}
if($data['usertype'] == 2){
$userid_job = $this->select_once('userid_job',array('com_id' => $data['uid'], 'eid' => $data['eid'],'isdel'=>9),'`id`');
$comstatis = $this->select_once('company_statis',array('uid'=>$data['uid']),'`rating`');
//已投递简历并且免费查看联系方式
if(!empty($userid_job) && in_array($comstatis['rating'], @explode(',', $this->config['com_look']))){
$type = 1;
}
}
}
}
}
}
return $type;
}
/**
* 用户设置默认简历
*/
public function defaults($data = array()){
$return = array('errcode'=>'2','msg'=>'设置失败!');
if (!empty($data)){
$row = $this -> select_once('resume_expect',array('id'=>$data['id']), '`id`,`uid`,`topdate`,`top`');
if (!empty($row['id'])){
$id = $this->update_once('resume', array('def_job'=>$row['id']), array('uid'=>$data['uid']));
// 如原默认简历有置顶记录,且已过期,将置顶记录清空
if($row['topdate'] < time()){
$redata = array(
'defaults' => 0,
'topdate' => '',
'top' => ''
);
}else{
$redata = array(
'defaults' => 0
);
}
$this->update_once('resume_expect', $redata, array('uid'=>$row['uid']));
$this->update_once('resume_expect', array('defaults'=>1), array('id'=>$row['id']));
$this->addMemberLog($row['uid'], 1, '设置默认简历', 2, 2);
$return = $id ? array('errcode'=>'1','msg'=>'设置成功!') : array('errcode'=>'2','msg'=>'设置失败!');
}
}
return $return;
}
/**
* 简历模糊字段
*/
public function getTj($data){
if (!empty($data)){
/*教育经历*/
$eduList = $data['edu'];
if($eduList){
$edumin = 0;
$edumax = 0;
foreach($eduList as $v){
if($v['sdate']>0 && $edumin==0){
$edumin = $v['sdate'];
}elseif($edumin>$v['sdate']){
$edumin = $v['sdate'];
}
if($v['edate']==0 ){
$edumax = 0;
}elseif($edumax<$v['edate']){
$edumax = $v['edate'];
}
$education[] = $v['education_n'];
$edutitle[] = $v['title'];
}
$return['edumin'] = date('Y.m',$edumin);
$return['edumax'] = $edumax == 0 ? '至今': date('Y.m',$edumax);
$return['education'] = @implode(',',$education);
$return['edutit'] = @implode(',',$edutitle);
$return['edu_time'] = $return['edumin'].'-'.$return['edumax'];
$return['edu_content'] = '已完成'.$return['education'].'段学业';
}
/*工作经历*/
$workList = $data['work'];
if($workList){
$whour = 0;
$hour = array();
$time = time();
$workmin = 0;
$workmax = 0;
$worknum = count($workList);
foreach($workList as $v){
/* 计算每份工作时长(按月) */
if ($v['edate']){
$workTime = ceil(($v['edate']-$v['sdate'])/(30*86400));
}else{
$workTime = ceil(($time - $v['sdate'])/(30*86400));
}
if($v['sdate']>0 && $workmin==0){
$workmin = $v['sdate'];
}elseif($workmin>$v['sdate']){
$workmin = $v['sdate'];
}
if($v['edate']==0 ){
$workmax = 0;
}elseif($workmax<$v['edate']){
$workmax = $v['edate'];
}
$wtitle[] = $v['title'];
$hour[] = $workTime;
$whour += $workTime;
}
$workavg = ceil($whour/count($hour));
$return['worknum'] = $worknum > 0 ? $worknum:0;
$return['workavg'] = $workavg > 11 ? avgToYm($workavg) : $workavg;
$return['workmin'] = date('Y.m',$workmin);
$return['workmax'] = $workmax == 0 ? '至今': date('Y.m',$workmax);
$return['worktit'] = @implode(',',$wtitle);
$return['work_time'] = $return['workmin'].'-'.$return['workmax'];
if($return['workavg']>0){
if($return['worktit']!=''){
$return['work_content'] = '参加过'.$return['worknum'].'份工作 , 平均工作时长'.$return['workavg'].'个月,涉及'.$return['worktit'].'等岗位';
}else{
$return['work_content'] = '参加过'.$return['worknum'].'份工作 , 平均工作时长'.$return['workavg'].'个月';
}
}
}
/*项目经历*/
$xmList = $data['xm'];
if($xmList){
$xmmin = 0;
$xmmax = 0;
$xmnum = count($xmList);
foreach($xmList as $v){
if($v['sdate']>0 && $xmmin==0){
$xmmin = $v['sdate'];
}elseif($xmmin>$v['sdate']){
$xmmin = $v['sdate'];
}
if($v['edate']==0 ){
$xmmax = 0;
}elseif($xmmax<$v['edate']){
$xmmax = $v['edate'];
}
$xmtitle[] = $v['title'];
}
$return['xmnum'] = $xmnum > 0 ? $xmnum:0;
$return['xmmin'] = date('Y.m',$xmmin);
$return['xmmax'] = $xmmax == 0 ? '至今':date('Y.m',$xmmax);
$return['xmtit'] = @implode(',',$xmtitle);
$return['xm_time'] = $return['xmmin'].'-'.$return['xmmax'];
if($return['xmtit']!=''){
$return['xm_content'] = '独自完成或参与过'.$return['xmnum'].'个项目,并在其中担任过'.$return['xmtit'].'等职务';
}else{
$return['xm_content'] = '独自完成或参与过'.$return['xmnum'].'个项目';
}
}
/*培训经历*/
$trainList = $data['train'];
if($trainList){
$trainmin = 0;
$trainmax = 0;
$trainnum = count($trainList);
foreach($trainList as $v){
if($v['sdate']>0 && $trainmin==0){
$trainmin = $v['sdate'];
}elseif($xmmin>$v['sdate']){
$trainmin = $v['sdate'];
}
if($v['edate']==0 ){
$trainmax = 0;
}elseif($xmmax<$v['edate']){
$trainmax = $v['edate'];
}
}
$return['trainnum'] = $trainnum > 0 ? $trainnum:0;
$return['trainmin'] = date('Y.m',$trainmin);
$return['trainmax'] = $trainmax == 0 ? '至今':date('Y.m',$trainmax);
$return['train_time'] = $return['trainmin'].'-'.$return['trainmax'];
$return['train_content']= '参加过'.$return['trainnum'].'次培训,进行自我充电,能力提升';
}
/*专业技能*/
$skillList = $data['skill'];
if($skillList){
$skillpic = 0;
$skillnum = count($skillList);
foreach($skillList as $v){
if($v['pic']){
$skillpic += 1;
}
}
$return['skillnum'] = $skillnum > 0 ? $skillnum:0;
$return['skillpic'] = $skillpic > 0 ? $skillpic:0;
$return['skill_content']= '目前已掌握'.$return['skillnum'].'项技能,其中'.$return['skillpic'].'项拥有技能证书';
}
/*作品案例*/
$showList = $data['show'];
if($showList){
$shownum = 0;
$shownum = count($showList);
$return['shownum'] = $shownum > 0 ? $shownum:0;
$return['show_content']= '已上传'.$return['shownum'].'份作品案例给招聘企业提前预览';
}
}
return $return;
}
/**
* 获取temporary_resume 详情
* $whereData 查询条件
* $data 自定义处理数组 scene 场景值,定制不同场景返回的数据
*/
public function getTempResumeInfo($whereData, $data = array()) {
$Info = array();
$data['field'] = empty($data['field']) ? '*' : $data['field'];
$Info = $this -> select_once('temporary_resume', $whereData, $data['field']);
if(!empty($Info)){
//定制不同场景展示的内容
if(isset($data['scene']) && $data['scene'] == 'detail'){
//获取缓存数据
include_once('cache.model.php');
$cacheM = new cache_model($this->db, $this->def);
$CacheList = $cacheM -> GetCache(array('user','hy','job','city'));
//处理性别
if(isset($CacheList['user_sex'][$Info['sex']])){
$Info['sex'] = $CacheList['user_sex'][$Info['sex']];
}else{
$Info['sex'] = '';
}
//处理职位类别
if(!empty($Info['job_classid'])){
$jobids = @explode(',', $Info['job_classid']);
foreach($jobids as $val){
$jobname[] = $CacheList['job_name'][$val];
}
$Info['jobname'] = @implode('、',$jobname);
}
//处理省份城市
if(!empty($Info['provinceid'])){
$Info['city'] = $CacheList['city_name'][$Info['provinceid']];
}
if(isset($CacheList['city_name'][$Info['cityid']])){
$Info['city'] .= '-'.$CacheList['city_name'][$Info['cityid']];
}
if(isset($CacheList['city_name'][$Info['three_cityid']])){
$Info['city'] .= '-'.$CacheList['city_name'][$Info['three_cityid']];
}
//处理薪资
if(!empty($Info['minsalary'])){
if($Info['maxsalary']){
$Info['rsalary'] = $Info['minsalary'].'-'.$Info['maxsalary'];
}else{
$Info['rsalary'] = $Info['minsalary'];
}
}else{
$Info['rsalary'] = '面议';
}
//处理学历
if(isset($CacheList['userclass_name'][$Info['edu']])){
$Info['job_edu'] = $CacheList['userclass_name'][$Info['edu']];
}else{
$Info['job_edu'] = '';
}
//处理工作经验
if(isset($CacheList['userclass_name'][$Info['exp']])){
$Info['job_exp'] = $CacheList['userclass_name'][$Info['exp']];
}else{
$Info['job_exp'] = '';
}
//处理工作性质
if(isset($CacheList['userclass_name'][$Info['type']])){
$Info['job_type'] = $CacheList['userclass_name'][$Info['type']];
}else{
$Info['job_type'] = '';
}
//处理到岗时间
if(isset($CacheList['userclass_name'][$Info['report']])){
$Info['job_report'] = $CacheList['userclass_name'][$Info['report']];
}else{
$Info['job_report'] = '';
}
//处理从事行业
if(isset($CacheList['industry_name'][$Info['hy']])){
$Info['job_hy'] = $CacheList['industry_name'][$Info['hy']];
}else{
$Info['job_hy'] = '';
}
}
}
return $Info;
}
/**
* 删除temporary_resume 详情
* $whereData 查询条件
*/
public function delTempResumeInfo($whereData) {
$nid = $this -> delete_all('temporary_resume', $whereData, '');
return $nid;
}
/**
* 添加temporary_resume
* $data 插入数据
*/
public function addTempResumeInfo($data=array()) {
$nid = $this -> insert_into('temporary_resume',$data);
return $nid;
}
// 简历置顶检测
public function topResumeCheck($data = array('eid'=>null,'uid'=>null)){
$return = array();
$expect = $this->select_once('resume_expect',array('id'=>$data['eid'],'uid'=>$data['uid']),'`doc`,`state`');
$work = $this->select_num('resume_work',array('eid'=>$data['eid'],'uid'=>$data['uid']));
$edu = $this->select_num('resume_edu',array('eid'=>$data['eid'],'uid'=>$data['uid']));
$project = $this->select_num('resume_project',array('eid'=>$data['eid'],'uid'=>$data['uid']));
if(empty($expect)){
$return['msg'] = '请先创建简历!';
}else if($expect['state']!=1){
$return['msg'] = '您的简历尚未审核,无法置顶操作!';
}else{
if($expect['doc'] == 0){
if($this->config['user_work_regiser']==1){
if($work < 1){
$return['msg'] = '你的简历没有工作经历,请填写工作经历';
}
}
if($this->config['user_edu_regiser']==1){
if($edu < 1){
$return['msg'] = '你的简历没有教育经历,请填写教育经历';
}
}
if($this->config['user_project_regiser']==1){
if($project < 1){
$return['msg'] = '你的简历没有项目经历,请填写项目经历';
}
}
}
}
return $return;
}
/**
* @desc 简历匹配职位
* @param array $data
*/
public function likeJob($data=array('id'=>null,'uid'=>null,'limit'=>16)){
$job = array();
if($data['id']){
$id = $data['id'];
$uid = $data['uid'];
$resume = $this->getInfoByEid(array('eid'=>$id,'uid'=>$uid));
$where['r_status'] = 1;
$where['status'] = 0;
$where['state'] = 1;
if($resume['job_classid']!=""){
$where['PHPYUNBTWSTART_A']='';
$where['job_post'] = array('in',$resume['job_classid']);
$where['job1_son'] = array('in',$resume['job_classid'],'OR');
$where['PHPYUNBTWEND_A']='';
}
if($resume['city_classid']!=""){
$where['PHPYUNBTWSTART_B'] = '';
$where['provinceid'] = array('in',$resume['city_classid']);
$where['cityid'] = array('in',$resume['city_classid'],'OR');
$where['three_cityid'] = array('in',$resume['city_classid'],'OR');
$where['PHPYUNBTWEND_B'] = '';
}
$where['orderby'] = 'id,desc';
$where['limit'] = is_numeric($data['limit']) && $data['limit']>0 ? $data['limit'] : 16;
$cdata['field'] = 'id,uid,name,cityid,three_cityid,edu,sex,marriage,report,exp,minsalary,maxsalary,lastupdate,com_name,com_logo';
require_once ('job.model.php');
$jobM = new job_model($this->db, $this->def);
$List = $jobM -> getList($where,$cdata);
$job = $List['list'];
if(is_array($resume)){
foreach($job as $k=>$v){
$pre = 60;
$city_classname = @explode(',',$resume['city_classid']);
if(in_array($v['cityid'],$city_classname) || in_array($v['three_cityid'],$city_classname)){//地区
$pre = $pre+10;
}
if($resume['useredu']==$v['job_edu'] || $v['job_edu']=="不限"){//学历
$pre = $pre+5;
}
if($resume['user_marriage']==$v['job_marriage'] || $v['job_marriage']=="不限"){//婚姻
$pre = $pre+5;
}
if($resume['sex']==$v['job_sex'] || $v['job_sex']=='不限'){
$pre = $pre+5;
}
if($resume['report']==$v['job_report'] || $v['job_report']=="不限"){//到岗时间
$pre = $pre+5;
}
if($resume['user_exp']==$v['job_exp'] || $v['job_exp']=="不限"){//工作经验
$pre = $pre+5;
}
$job[$k]['pre'] = $pre;
if(empty($v['job_sex'])){
$job[$k]['job_sex'] = '保密';
}
$job[$k]['wapjob_url'] = Url('wap',array('c'=>'job','a'=>'comapply','id'=>$v['id']));
$job[$k]['wapcom_url'] = Url('wap',array('c'=>'company','a'=>'show','id'=>$v['uid']));
}
$sort = array(
'direction' => 'SORT_DESC', //排序顺序标志 SORT_DESC 降序;SORT_ASC 升序
'field' => 'pre', //排序字段
);
$arrSort = array();
foreach($job AS $uniqid => $row){
foreach($row AS $key=>$value){
$arrSort[$key][$uniqid] = $value;
}
}
if($sort['direction']){
array_multisort($arrSort[$sort['field']], constant($sort['direction']), $job);
}
}
}
return $job;
}
/*会员添加简历页面,添加前检查是否满足各项条件,例如简历数,并返回部分基本信息
needcache:是否需要缓存,$from:默认pc:为pc端,wap:wap端,wxapp:小程序端
**/
public function addResumeRequireCheck($data=array('uid'=>null,'needcache'=>null), $from='pc'){
$error['err'] = 0;
if($data['uid']){
$uid = $data['uid'];
$num = $this -> getExpectNum(array('uid'=>$uid));
if($this->config['user_number']!='' && $num >= $this->config['user_number']){
$error['err'] = 1;
$error['msg'] = '您最多可以拥有'.$this->config['user_number'].'份简历';
$error['url'] = 'index.php?c=resume';
}
return $error;
}
}
/*会员添加简历页面,添加前检查是否满足各项条件,例如身份认证和简历数,并返回部分基本信息
needcache:是否需要缓存,$from:默认pc:pc端,wap:wap端,wxapp:小程序端
**/
public function addResumePage($data=array('uid'=>null,'needcache'=>null), $from='pc'){
$return = array();
if($data['uid']){
$uid = $data['uid'];
$resume = $this -> getResumeInfo(array('uid'=>$uid));
if(empty($resume)){
$member=$this->select_once('member',array('uid'=>$uid),'`moblie`,`email`');
$resume['telphone'] = $member['moblie'];
$resume['email'] = $member['email'];
}
//验证是否满足条件
$error = $this->addResumeRequireCheck($data, $from);
$return['error'] = $error;
//验证结束
if($return['error']['err']==0){
$return['setarr'] = array();
switch ($from) {
case 'pc':
$setarr = array(
'resume' => $resume,
'layerv' => 5,
'js_def' => 2
);
break;
case 'wap':
$setarr = array(
'resume' => $resume,
'headertitle' => '创建简历'
);
break;
case 'wxapp':
$resume['resume_create_exp'] = $this->config['resume_create_exp'];
$resume['resume_create_edu'] = $this->config['resume_create_edu'];
$resume['resume_create_project']= $this->config['resume_create_project'];
$resume['expcreate'] = $this->config['expcreate'];
$resume['educreate'] = $this->config['educreate'];
$setarr = array('resume' => $resume);
break;
}
if(!empty($data['needcache'])){
//是否需要缓存
require_once ('cache.model.php');
$cacheM = new cache_model($this->db, $this->def);
$cache = $cacheM->GetCache(array('city','user','hy','job'));
$return['cache'] = $cache;
$setarr['user_sex'] = $cache['user_sex'];
$setarr['userdata'] = $cache['userdata'];
$setarr['userclass_name'] = $cache['userclass_name'];
$setarr['industry_index'] = $cache['industry_index'];
$setarr['industry_name'] = $cache['industry_name'];
if(empty($cache['city_type'])){
$setarr['cionly'] = 1;
}
if(empty($cache['job_type'])){
$setarr['jionly'] = 1;
}
}
$return['setarr'] = $setarr;
}
}
return $return;
}
function upExpectHeight($data=array()){
$nid = 0;
if(!empty($data)){
$eid = $data['eid'];
$expect = $this->select_once('resume_expect',array('id'=>$eid));
if($expect['height_status']!=0){
$nid = $this->update_once('resume_expect',array('height_status'=>1),array('id'=>$eid));
}
}
return $nid;
}
/**
* 网络招聘会大厅简历列表、浏览简历列表类查询个人姓名使用
*/
private function getJlData($List){
foreach ($List as $v){
$uids[] = $v['uid'];
}
$resume = $this->select_all('resume',array('uid'=>array('in',pylode(',', $uids))),'`uid`,`name`,`nametype`,`photo`,`phototype`,`defphoto`,`photo_status`');
foreach ($List as $k=>$v){
$List[$k]['wapurl'] = Url('wap',array('c'=>'resume','a'=>'show','id'=>$v['id']));
foreach ($resume as $val){
if ($v['uid'] == $val['uid']){
$List[$k]['photo_n'] = $this->setResumePhotoShow(array('photo'=>$val['photo'],'defphoto'=>$val['defphoto'],'phototype'=>$val['phototype'],'photo_status'=>$val['photo_status'],'sex'=>$v['sex']));
$List[$k]['uname_n'] = $this->setUsernameShow(array('nametype'=>$val['nametype'],'name'=>$val['name'],'eid'=>$v['id'],'sex'=>$v['sex']));
}
}
}
return $List;
}
/*
* 获取简历的原始数据,类别汉字化处理,$data中定义获取哪些表,all=1为全部
*/
function getResumeRaw($Where=array(),$data=array('all'=>0)){
$return = array();
$resume = $this->select_once('resume',$Where);
if(!empty($resume)){
$cache = $this -> getClass(array('user','city','job','hy','introduce'));
$userclass_name = $cache['userclass_name'];
$resume['sex'] = $resume['sex'] == 1?'男':'女';
if($resume['edu']){
$resume['edu'] = $userclass_name[$resume['edu']];
}
if($resume['exp']){
$resume['exp'] = $userclass_name[$resume['exp']];
}
if($resume['marriage']){
$resume['marriage'] = $userclass_name[$resume['marriage']];
}
//联系方式不同步,删除操作
unset($resume['telphone']);
unset($resume['telhome']);
unset($resume['qq']);
unset($resume['email']);
unset($resume['address']);
$return['resume'] = $resume;
$fbwhere = array('uid'=>$resume['uid'],'eid'=>$resume['def_job']);
if($data['all']=='1' || $data['expect']=='1'){
$resume_expect = $this->select_once('resume_expect',array('uid'=>$resume['uid'],'defaults'=>1));
if(!empty($resume_expect)){
$resume_expect['sex'] = $resume_expect['sex'] == 1?'男':'女';
$resume_expect['exp'] = $cache['userclass_name'][$resume_expect['exp']];
$resume_expect['edu'] = $cache['userclass_name'][$resume_expect['edu']];
$resume_expect['hy'] = $cache['industry_name'][$resume_expect['hy']] ? $cache['industry_name'][$resume_expect['hy']] : '不限';
$resume_expect['report'] = $cache['userclass_name'][$resume_expect['report']];
$resume_expect['type'] = $cache['userclass_name'][$resume_expect['type']];
$resume_expect['jobstatus'] = $cache['userclass_name'][$resume_expect['jobstatus']];
//处理职位类别id
if ($resume_expect['job_classid'] ){
$job_classid = @explode(',',$resume_expect['job_classid']);
if(is_array($job_classid)){
foreach($job_classid as $v){
if($cache['job_name'][$v]){
$job_classname[] = $cache['job_name'][$v];
}
}
$resume_expect['job_classid'] = @implode(',',$job_classname);
}
}
//处理城市类别id
if ($resume_expect['city_classid']){
$city_classid = @explode(',',$resume_expect['city_classid']);
if(is_array($city_classid)){
foreach($city_classid as $v){
if($cache['city_name'][$v]){
$city_classname[] = $cache['city_name'][$v];
}
}
$resume_expect['city_classid'] = @implode(',',$city_classname);
}
}
}
$return['resume_expect']= !empty($resume_expect) ? $resume_expect : array();
}
if($data['all']=='1' || $data['work']=='1'){
$resume_work = $this->select_all('resume_work', $fbwhere);
$return['resume_work'] = !empty($resume_work) ? $resume_work : array();
}
if($data['all']=='1' || $data['edu']=='1'){
$resume_edu = $this->select_all('resume_edu', $fbwhere);
if(!empty($resume_edu)){
foreach($resume_edu as $ek=>$ev){
$resume_edu[$ek]['education'] = $userclass_name[$ev['education']];
}
}
$return['resume_edu'] = !empty($resume_edu) ? $resume_edu : array();
}
}
return $return;
}
public function getResumeCityClassList($whereData,$data=array()){
$field = $data['field'] ? $data['field'] : '*';
$List = $this -> select_all('resume_cityclass',$whereData,$field);
return $List;
}
//发布工具搜索
public function Getresume($where = array(),$data = array())
{
$lists = $this->select_all('resume_expect',$where,'`id`');
foreach ($lists as $k => $v) {
$list = $this->getInfoByEid(array('eid' => $v['id']));
if($list['age']==0){
$list['age']='保密';
}else{
$list['age']=$list['age'].'岁';
}
if($list['user_exp']){
$list['user_exp']=$list['user_exp'].'经验';
}
if($list['useredu']){
$list['useredu']=$list['useredu'].'学历';
}
if($list['tj']['worknum']>0){
$list['resume_workjj'] = $list['tj']['workmin'].'-'.$list['tj']['workmax'].'参加过'.$list['tj']['worknum'].'份工作,平均工作时长'.$list['tj']['workavg'].'个月,涉及'.$list['tj']['worktit'].'等岗位。';
}
if($list['tj']['education']){
$list['resume_edujj'] = $list['tj']['edumin'].'-'.$list['tj']['edumax'].'已完成'.$list['tj']['education'].'段学业。';
}
$lists[$k]['list'] = $list;
}
return $lists;
}
public function updateExpect($data = array(), $where = array())
{
if (!empty($where)) {
$this->update_once('resume_expect', $data, $where);
}
}
public function setExpectState($data = array(), $where = array())
{
if (!empty($where)) {
$expect_all = $this->select_all('resume_expect', $where, '`id`,`uid`');
$eid_arr = array();
foreach ($expect_all as $k => $v) {
if (!in_array($v['id'], $eid_arr)) {
$eid_arr[] = $v['id'];
}
}
$nid = $this->update_once('resume_expect', $data, $where);
if (isset($data['state']) && !empty($eid_arr)) {
$this->update_once('userid_job', array('resume_state' => $data['state']), array('eid' => array('in', pylode(',', $eid_arr))));
}
return $nid;
}
}
}
?>