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 "";
}
}