getAttributes($compiler, $args); $from = $_attr['from']; $item = $_attr['item']; $name = $_attr['item']; $name=str_replace('\'','',$name); $name=$name?$name:'List';$name='$'.$name; if (!strncmp("\$_smarty_tpl->tpl_vars[$item]", $from, strlen($item) + 24)) { $compiler->trigger_template_error("item variable {$item} may not be the same variable as at 'from'", $compiler->lex->taglineno); } //自定义标签 START $OutputStr='global $db,$db_config,$config; $time = time(); //可以做缓存 $paramer='.ArrayToString($_attr,true).'; $ParamerArr = GetSmarty($paramer,$_GET,$_smarty_tpl); $paramer = $ParamerArr[arr]; $Purl = $ParamerArr[purl]; global $ModuleName; if(!$Purl["m"]){ $Purl["m"]=$ModuleName; } include_once PLUS_PATH."/comrating.cache.php"; include(CONFIG_PATH."db.data.php"); if($config[sy_web_site]=="1"){ if($config[province]>0 && $config[province]!=""){ $paramer[provinceid] = $config[province]; } if($config[cityid]>0 && $config[cityid]!=""){ $paramer[cityid] = $config[cityid]; } if($config[three_cityid]>0 && $config[three_cityid]!=""){ $paramer[three_cityid] = $config[three_cityid]; } if($config[hyclass]>0 && $config[hyclass]!=""){ $paramer[hy]=$config[hyclass]; } } if($paramer[sdate]){ $where = "`sdate`>".strtotime("-".intval($paramer[sdate])." day",time())." and `state`=1"; }else{ $where = "`state`=1"; } //按照UID来查询(按公司地址查询可用GET[id]获取当前公司ID) if($paramer[uid]){ $where .= " AND `uid` = \'$paramer[uid]\'"; } if($paramer[com_id]){ $where .= " AND `uid` = \'$paramer[com_id]\'"; } //是否推荐职位 if($paramer[rec]){ $where.=" AND `rec_time`>=".time(); } //企业认证条件 if($paramer[\'cert\']){ $job_uid=array(); $company=$db->select_all("company","`yyzz_status`=1","`uid`"); if(is_array($company)){ foreach($company as $v){ $job_uid[]=$v[\'uid\']; } } $where.=" and `uid` in (".@implode(",",$job_uid).")"; } //取不包含当前企业的职位 if($paramer[nouid]){ $where.= " and `uid`<>$paramer[nouid]"; } //取不包含当前id的职位 if($paramer[noid]){ $where.= " and `id`<>$paramer[noid]"; } //是否被锁定 if($paramer[r_status]){ $where.= " and `r_status`=2"; }else{ $where.= " and `r_status`=1"; } //是否下架职位 if($paramer[status]){ $where.= " and `status`=\'1\'"; }else{ $where.= " and `status`=\'0\'"; } //公司体制 if($paramer[pr]){ $where .= " AND `pr` =$paramer[pr]"; } //公司行业分类 if($paramer[\'hy\']){ $where .= " AND `hy` = $paramer[hy]"; } //职位大类 if($paramer[job1]){ $where .= " AND `job1` = $paramer[job1]"; } //职位子类 if($paramer[job1_son]){ $where .= " AND `job1_son` = $paramer[job1_son]"; } //职位三级分类 if($paramer[job_post]){ $where .= " AND (`job_post` IN ($paramer[job_post]))"; } //您可能感兴趣的职位--个人会员中心 if($paramer[\'jobwhere\']){ $where .=" and ".$paramer[\'jobwhere\']; } //职位分类综合查询 if($paramer[\'jobids\']){ $where.= " AND (`job1` = \'$paramer[jobids]\' OR `job1_son`= \'$paramer[jobids]\' OR `job_post`=\'$paramer[jobids]\')"; } //职位分类区间,不建议执行该查询 if($paramer[\'jobin\']){ $where .= " AND (`job1` IN ($paramer[jobin]) OR `job1_son` IN ($paramer[jobin]) OR `job_post` IN ($paramer[jobin]))"; } //城市大类 if($paramer[provinceid]){ $where .= " AND `provinceid` = $paramer[provinceid]"; } //城市子类 if($paramer[\'cityid\']){ $where .= " AND (`cityid` IN ($paramer[cityid]))"; } //城市三级子类 if($paramer[\'three_cityid\']){ $where .= " AND (`three_cityid` IN ($paramer[three_cityid]))"; } if($paramer[\'cityin\']){ $where .= " AND `three_cityid` IN ($paramer[cityin])"; } //学历 if($paramer[edu]){ $eduKey = $db->DB_select_once("comclass", "`variable` = \'job_edu\'", "`id`"); $eduReq = $db->DB_select_once("comclass", "`id` = $paramer[edu]", "`sort`,`name`"); if($eduReq[name] != "不限"){ $eduArr = $db->select_all("comclass", "`keyid` = $eduKey[id] AND `sort` <= $eduReq[sort]", "`id`"); $eduIds = array(); foreach($eduArr as $v){ $eduIds[] = $v[id]; } $where .= " AND `edu` in (".@implode(",",$eduIds).")"; } } //工作经验 if($paramer[exp]){ $expKey = $db->DB_select_once("comclass", "`variable` = \'job_exp\'", "`id`"); $expReq = $db->DB_select_once("comclass", "`id` = $paramer[exp]", "`sort`,`name`"); if($expReq[name] != "不限"){ $expArr = $db->select_all("comclass", "`keyid` = $expKey[id] AND `sort` <= $expReq[sort]", "`id`"); $expIds = array(); foreach($expArr as $v){ $expIds[] = $v[id]; } $where .= " AND `exp` in (".@implode(",",$expIds).")"; } } //到岗时间 if($paramer[report]){ $where .= " AND `report` = $paramer[report]"; } //职位性质 if($paramer[type]){ $where .= " AND `type` = $paramer[type]"; } //性别 if($paramer[sex]){ $where .= " AND `sex` = $paramer[sex]"; } //应届生 if($paramer[is_graduate]){ $where .= " AND `is_graduate` = $paramer[is_graduate]"; } //公司规模 if($paramer[mun]){ $where .= " AND `mun` = $paramer[mun]"; } if($paramer[minsalary] && $paramer[maxsalary]){ $where.= " AND (`minsalary`>=".intval($paramer[minsalary])." and `minsalary`<=".intval($paramer[maxsalary])." and `maxsalary`<=".intval($paramer[maxsalary]).") "; }elseif($paramer[minsalary]&&!$paramer[maxsalary]){ $where.= " AND (`minsalary`>=".intval($paramer[minsalary]).") "; }elseif(!$paramer[minsalary]&&$paramer[maxsalary]){ $where.= " AND (`minsalary`<=".intval($paramer[maxsalary])." and `maxsalary`<=".intval($paramer[maxsalary]).") "; } //福利待遇 $cache_array = $db->cacheget(); $comclass_name = $cache_array["comclass_name"]; if($paramer[welfare]){ $welfarename=$comclass_name[$paramer[welfare]]; $where .=" AND `welfare` LIKE \'%".$welfarename."%\' "; } //城市区间,不建议执行该查询 if($paramer[cityin]){ $where .= " AND (`provinceid` IN ($paramer[cityin]) OR `cityid` IN ($paramer[cityin]) OR `three_cityid` IN ($paramer[cityin]))"; } //紧急招聘urgent if($paramer[urgent]){ $where.=" AND `urgent_time`>".time(); } //更新时间区间 if($paramer[uptime]){ if($paramer[uptime]==1){ $beginToday=mktime(0,0,0,date(\'m\'),date(\'d\'),date(\'Y\')); $where.=" AND lastupdate>$beginToday"; }else{ $time=time(); $uptime = $time-($paramer[uptime]*86400); $where.=" AND lastupdate>$uptime"; } }else{ if($config[sy_datacycle]>0){ // 后台-页面设置-数据周期 $uptime = strtotime(\'-\'.$config[sy_datacycle].\' day\'); $where.=" AND lastupdate>$uptime"; } } //按类似公司名称,不建议进行大数据量操作 if($paramer[comname]){ $where.=" AND `com_name` LIKE \'%".$paramer[comname]."%\'"; } //按公司归属地,只适合查询一级城市分类 if($paramer[com_pro]){ $where.=" AND `com_provinceid` =\'".$paramer[com_pro]."\'"; } //按照职位名称匹配 if($paramer[keyword]){ $where1[]="`name` LIKE \'%".$paramer[keyword]."%\'"; $where1[]="`com_name` LIKE \'%".$paramer[keyword]."%\'"; include PLUS_PATH."/city.cache.php"; foreach($city_name as $k=>$v){ if(strpos($v,$paramer[keyword])!==false){ $cityid[]=$k; } } if(is_array($cityid)){ foreach($cityid as $value){ $class[]= "(provinceid = \'".$value."\' or cityid = \'".$value."\')"; } $where1[]=@implode(" or ",$class); } $where.=" AND (".@implode(" or ",$where1).")"; } //多选职位 if($paramer["job"]){ $where.=" AND `job_post` in ($paramer[job])"; } //置顶招聘 if($paramer[bid]){ if($config[joblist_top]!=1){ $paramer[limit] = 5; } $where.=" and `xsdate`>\'".time()."\'"; } //自定义查询条件,默认取代上面任何参数直接使用该语句 if($paramer[where]){ $where = $paramer[where]; } //查询条数 $limit = \'\'; if($paramer[limit]){ $limit = " limit ".$paramer[limit]; } if($paramer[ispage]){ $limit = PageNav($paramer,$_GET,"company_job",$where,$Purl,"",$paramer[islt]?$paramer[islt]:"6",$_smarty_tpl); } //排序字段默认为更新时间 //置顶设置为随机5条时,随机查询 if($paramer[bid] && $paramer[limit]){ $order = " ORDER BY rand() "; }else{ if($paramer[order] && $paramer[order]!="lastdate"){ $order = " ORDER BY ".str_replace("\'","",$paramer[order])." "; }else{ $order = " ORDER BY `lastupdate` "; } } //排序规则 默认为倒序 if($paramer[sort]){ $sort = $paramer[sort]; }else{ $sort = " DESC"; } $where.=$order.$sort; '.$name.' = $db->select_all("company_job",$where.$limit); if(is_array('.$name.') && !empty('.$name.')){ //处理类别字段 $cache_array = $db->cacheget(); $comuid=$jobid=array(); foreach('.$name.' as $key=>$value){ if(in_array($value[\'uid\'],$comuid)==false){$comuid[] = $value[\'uid\'];} if(in_array($value[\'id\'],$jobid)==false){$jobid[] = $value[\'id\'];} } $comuids = @implode(\',\',$comuid); $jobids = @implode(\',\',$jobid); //减少曝光量统计维度 只有列表才统计 if($paramer[ispage]){ $db->update_all("company_job", "`jobexpoure` = `jobexpoure` + 1", "`id` in ($jobids)"); } if($comuids){ $r_uids=$db->select_all("company","`uid` IN (".$comuids.")","`uid`,`yyzz_status`,`logo`,`logo_status`,`pr`,`hy`,`mun`,`shortname`,`welfare`,`hotstart`,`hottime`"); if(is_array($r_uids)){ foreach($r_uids as $key=>$value){ if($value[shortname]){ $value[\'shortname_n\'] = $value[shortname]; } if(!$value[\'logo\'] || $value[\'logo_status\']!=0){ $value[\'logo\'] = checkpic("",$config[\'sy_unit_icon\']); }else{ $value[\'logo\']= checkpic($value[\'logo\']); } $value[\'pr_n\'] = $cache_array[\'comclass_name\'][$value[pr]]; $value[\'hy_n\'] = $cache_array[\'industry_name\'][$value[hy]]; $value[\'mun_n\'] = $cache_array[\'comclass_name\'][$value[mun]]; if($value[\'hotstart\']<=time() && $value[\'hottime\']>=time()){ $value[\'hotlogo\'] = 1; } $r_uid[$value[\'uid\']] = $value; } } } if($paramer[bid]){ $noids=array(); } foreach('.$name.' as $key=>$value){ if($paramer[bid]){ $noids[] = $value[id]; } //筛除重复 if($paramer[noids]==1 && !empty($noids) && in_array($value[\'id\'],$noids)){ unset('.$name.'[$key]); continue; }else{ '.$name.'[$key] = $db->array_action($value,$cache_array); '.$name.'[$key][stime] = date("Y-m-d",$value[sdate]); '.$name.'[$key][etime] = date("Y-m-d",$value[edate]); if($arr_data[\'sex\'][$value[\'sex\']]){ '.$name.'[$key][sex_n]=$arr_data[\'sex\'][$value[\'sex\']]; } '.$name.'[$key][lastupdate] =lastupdateStyle($value[lastupdate]); if($value[minsalary]&&$value[maxsalary]){ if($config[\'resume_salarytype\']==1){ '.$name.'[$key][job_salary] =$value[minsalary]."-".$value[maxsalary]; }else{ if($value[maxsalary]<1000){ if($config[\'resume_salarytype\']==2){ '.$name.'[$key][job_salary] = "1千以下"; }elseif($config[\'resume_salarytype\']==3){ '.$name.'[$key][job_salary] = "1K以下"; }elseif($config[\'resume_salarytype\']==4){ '.$name.'[$key][job_salary] = "1k以下"; } }else if($value[minsalary]<1000){ '.$name.'[$key][job_salary] =changeSalary($value[maxsalary]); }else{ '.$name.'[$key][job_salary] =changeSalary($value[minsalary])."-".changeSalary($value[maxsalary]); } } }elseif($value[minsalary]){ if($config[\'resume_salarytype\']==1){ '.$name.'[$key][job_salary] =$value[minsalary]."以上"; }else{ '.$name.'[$key][job_salary] =changeSalary($value[minsalary])."以上"; } }else{ '.$name.'[$key][job_salary] ="面议"; } if($r_uid[$value[\'uid\']][shortname]){ '.$name.'[$key][com_name] =$r_uid[$value[\'uid\']][shortname]; } if(!empty($value[zp_minage]) && !empty($value[zp_maxage])){ if($value[zp_minage]==$value[zp_maxage]){ '.$name.'[$key][job_age] = $value[zp_minage]."周岁以上"; }else{ '.$name.'[$key][job_age] = $value[zp_minage]."-".$value[zp_maxage]."周岁"; } }else if(!empty($value[zp_minage]) && empty($value[zp_maxage])){ '.$name.'[$key][job_age] = $value[zp_minage]."周岁以上"; }else{ '.$name.'[$key][job_age] = 0; } if($value[zp_num]==0){ '.$name.'[$key][job_number] = ""; }else{ '.$name.'[$key][job_number] = $value[zp_num]." 人"; } '.$name.'[$key][yyzz_status] =$r_uid[$value[\'uid\']][yyzz_status]; '.$name.'[$key][logo] =$r_uid[$value[\'uid\']][logo]; '.$name.'[$key][pr_n] =$r_uid[$value[\'uid\']][pr_n]; '.$name.'[$key][hy_n] =$r_uid[$value[\'uid\']][hy_n]; '.$name.'[$key][mun_n] =$r_uid[$value[\'uid\']][mun_n]; '.$name.'[$key][hotlogo] =$r_uid[$value[\'uid\']][hotlogo]; $time=$value[\'lastupdate\']; //今天开始时间戳 $beginToday=mktime(0,0,0,date(\'m\'),date(\'d\'),date(\'Y\')); //昨天开始时间戳 $beginYesterday=mktime(0,0,0,date(\'m\'),date(\'d\')-1,date(\'Y\')); if($time>$beginYesterday && $time<$beginToday){ '.$name.'[$key][\'time\'] ="昨天"; }elseif($time>$beginToday){ '.$name.'[$key][\'time\'] = '.$name.'[$key][\'lastupdate\']; '.$name.'[$key][\'redtime\'] =1; }else{ '.$name.'[$key][\'time\'] = date("Y-m-d",$value[\'lastupdate\']); } // 前天 $beforeYesterday=mktime(0,0,0,date(\'m\'),date(\'d\')-2,date(\'Y\')); if($value[\'sdate\']>$beforeYesterday){ '.$name.'[$key][\'newtime\'] =1; } //获得福利待遇名称 if($value[welfare]){ $value[welfare] = str_replace(\' \', \'\',$value[welfare]); $welfareList = @explode(\',\',trim($value[welfare])); if(!empty($welfareList)){ '.$name.'[$key][welfarename] =array_filter($welfareList); } } //截取公司名称 if($paramer[comlen]){ if($r_uid[$value[\'uid\']][shortname]){ '.$name.'[$key][com_n] = mb_substr($r_uid[$value[\'uid\']][shortname],0,$paramer[comlen],"utf-8"); }else{ '.$name.'[$key][com_n] = mb_substr($value[\'com_name\'],0,$paramer[comlen],"utf-8"); } } //截取职位名称 if($paramer[namelen]){ if($value[\'rec_time\']>time()){ '.$name.'[$key][name_n] = "".mb_substr($value[\'name\'],0,$paramer[namelen],"utf-8").""; }else{ '.$name.'[$key][name_n] = mb_substr($value[\'name\'],0,$paramer[namelen],"utf-8"); } }else{ if($value[\'rec_time\']>time()){ '.$name.'[$key][\'name_n\'] = "".$value[\'name\'].""; }else{ '.$name.'[$key][name_n] = $value[\'name\']; } } //构建职位伪静态URL '.$name.'[$key][job_url] = Url("job",array("c"=>"comapply","id"=>$value[id]),"1"); //构建企业伪静态URL '.$name.'[$key][com_url] = Url("company",array("c"=>"show","id"=>$value[uid])); foreach($comrat as $k=>$v){ if($value[rating]==$v[id]){ '.$name.'[$key][color] = str_replace("#","",$v[com_color]); if($v[com_pic]){ '.$name.'[$key][ratlogo] = checkpic($v[com_pic]); } '.$name.'[$key][ratname] = $v[name]; } } if($paramer[keyword]){ '.$name.'[$key][name]=str_replace($paramer[keyword],"".$paramer[keyword]."",$value[name]); '.$name.'[$key][name_n]=str_replace($paramer[keyword],"".$paramer[keyword]."",'.$name.'[$key][name_n]); '.$name.'[$key][com_n]=str_replace($paramer[keyword],"".$paramer[keyword]."",'.$name.'[$key][com_n]); '.$name.'[$key][job_city_one]=str_replace($paramer[keyword],"".$paramer[keyword]."",$city_name[$value[provinceid]]); '.$name.'[$key][job_city_two]=str_replace($paramer[keyword],"".$paramer[keyword]."",$city_name[$value[cityid]]); } } } if(is_array('.$name.')){ if($paramer[keyword]!=""&&!empty('.$name.')){ addkeywords(\'3\',$paramer[keyword]); } } }'; //global $DiyTagOutputStr; //$DiyTagOutputStr[]=$OutputStr; return SmartyOutputStr($this,$compiler,$_attr,'joblist',$name,$OutputStr,$name); } } class Smarty_Internal_Compile_Joblistelse extends Smarty_Internal_CompileBase{ public function compile($args, $compiler, $parameter){ $_attr = $this->getAttributes($compiler, $args); list($openTag, $nocache, $item, $key) = $this->closeTag($compiler, array('joblist')); $this->openTag($compiler, 'joblistelse', array('joblistelse', $nocache, $item, $key)); return "tpl_vars[$item]->_loop) {\n?>"; } } class Smarty_Internal_Compile_Joblistclose extends Smarty_Internal_CompileBase{ public function compile($args, $compiler, $parameter){ $_attr = $this->getAttributes($compiler, $args); if ($compiler->nocache) { $compiler->tag_nocache = true; } list($openTag, $compiler->nocache, $item, $key) = $this->closeTag($compiler, array('joblist', 'joblistelse')); return ""; } }