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[rec]){ $recRating = array(); if($comrat){ foreach($comrat as $value){ if($value[display]==\'1\' && $value[category]==\'1\' && $value[jobrec]==\'2\'){ $recRating[] = $value[\'id\']; } } } if(!empty($recRating)){ $recRaringId = implode(\',\',$recRating); $where.=" AND (`rating` IN (".$recRaringId.") OR `rec_time`>=".time().")"; }else{ $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).")"; } //取不包含当前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[mun]){ $where .= " AND `mun` = $paramer[mun]"; } //职位大类 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]){ $where .= " AND `edu` = $paramer[edu]"; } //工作经验 if($paramer[exp]){ $where .= " AND `exp` = $paramer[exp]"; } //到岗时间 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[minsalary]&&$paramer[maxsalary]){ $where.= " AND ((`minsalary`<=".intval($paramer[minsalary])." and `maxsalary`>=".intval($paramer[minsalary]).") or (`minsalary`<=".intval($paramer[maxsalary])." and `maxsalary`>=".intval($paramer[maxsalary])."))"; /*$where.= " and case when minsalary>0 then `minsalary`<= ".intval($paramer[minsalary]). " end and case when maxsalary>0 then `maxsalary`<= ".intval($paramer[maxsalary])." else minsalary<".intval($paramer[maxsalary])." and maxsalary =0 end ";*/ }elseif($paramer[minsalary]&&!$paramer[maxsalary]){ $where.= " AND ((`minsalary`<=".intval($paramer[minsalary])." and `maxsalary`>=".intval($paramer[minsalary]).") or (`minsalary`>=".intval($paramer[minsalary])." and `maxsalary`>=".intval($paramer[minsalary]).") or (`minsalary`!=0 and `maxsalary`=0))"; /*$where.= " AND `minsalary`>=".intval($paramer[minsalary])." and minsalary>0";*/ }elseif(!$paramer[minsalary]&&$paramer[maxsalary]){ $where.= " AND ((`minsalary`<=".intval($paramer[maxsalary])." and `maxsalary`>=".intval($paramer[maxsalary]).") or (`minsalary`<=".intval($paramer[maxsalary])." and `maxsalary`<=".intval($paramer[maxsalary]).") or (`minsalary`<=".intval($paramer[maxsalary])." and maxsalary=0) or (`minsalary`=0 and `maxsalary`!=0) )"; /*$where.= " AND `maxsalary`<=".intval($paramer[maxsalary])." and maxsalary>0";*/ } //城市区间,不建议执行该查询 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"; } } //按类似公司名称,不建议进行大数据量操作 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]){ $where.=" and `xsdate`>\'".time()."\'"; } //筛除重复 if($paramer[noids]==1 && !empty($noids)){ $where.=" AND `id` NOT IN (".@implode(\',\',$noids).")"; } //自定义查询条件,默认取代上面任何参数直接使用该语句 if($paramer[where]){ $where = $paramer[where]; } //查询条数 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); } //排序字段默认为更新时间 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.')){ //处理类别字段 $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($comuids){ $r_uids=$db->select_all("company","`uid` IN (".$comuids.")","`uid`,`yyzz_status`,`logo`,`pr`,`hy`,`mun`,`shortname`"); if(is_array($r_uids)){ foreach($r_uids as $key=>$value){ if($value[shortname]){ $value[\'shortname_n\'] = $value[shortname]; } $value[\'logo\'] = checkpic($value[\'logo\'],$config[\'sy_unit_icon\']); $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]]; $r_uid[$value[\'uid\']] = $value; foreach('.$name.' as $keyn=>$valuen){ if($valuen["com_id"]==$value["uid"]){ '.$name.'[$keyn][\'logo\'] = $value[\'logo\']; } } } } } //$comrat = $db->select_all("company_rating","`display`=\'1\'"); $noids=array(); foreach('.$name.' as $key=>$value){ if($paramer[bid]){ $noids[] = $value[id]; } '.$name.'[$key] = $db->array_action($value,$cache_array); '.$name.'[$key][stime] = date("m月d日",$value[sdate]); if($arr_data[\'sex\'][$value[\'sex\']]){ '.$name.'[$key][sex_n]=$arr_data[\'sex\'][$value[\'sex\']]; } '.$name.'[$key][lastupdate] = date("Y-m-d",$value[lastupdate]); '.$name.'[$key][wstime] = date("Y年m月d日 H:i",$value[lastupdate]); if($value[minsalary]&&$value[maxsalary]){ if($config[\'resume_salarytype\']==1){ '.$name.'[$key][job_salary] =$value[minsalary]."-".$value[maxsalary]; }else{ if($v[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{ '.$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]; } '.$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]; $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\')); //一周内时间戳 $week=strtotime(date("Y-m-d",strtotime("-1 week"))); if($time>$week && $time<$beginYesterday){ '.$name.'[$key][\'time\'] ="一周内"; }elseif($time>$beginYesterday && $time<$beginToday){ '.$name.'[$key][\'time\'] ="昨天"; }elseif($time>$beginToday){ '.$name.'[$key][\'time\'] = date("H:i",$value[\'lastupdate\']); '.$name.'[$key][\'redtime\'] =1; }else{ '.$name.'[$key][\'time\'] = date("Y-m-d",$value[\'lastupdate\']); } //获得福利待遇名称 if(is_array('.$name.'[$key][\'welfare\'])&&'.$name.'[$key][\'welfare\']){ foreach('.$name.'[$key][\'welfare\'] as $val){ //'.$name.'[$key][\'welfarename\'][]=$cache_array[\'comclass_name\'][$val]; '.$name.'[$key][\'welfarename\'][]=$val; } } //截取公司名称 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\'].""; } } //构建职位伪静态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[com_id])); foreach($comrat as $k=>$v){ if($value[rating]==$v[id]){ '.$name.'[$key][color] = str_replace("#","",$v[com_color]); '.$name.'[$key][ratlogo] = $v[com_pic]; '.$name.'[$key][ratname] = $v[name]; } } if($paramer[keyword]){ '.$name.'[$key][name]=str_replace($paramer[keyword],"".$paramer[keyword]."",$value[name]); '.$name.'[$key][com_name]=str_replace($paramer[keyword],"".$paramer[keyword]."",$value[com_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,'wslist',$name,$OutputStr,$name); } } class Smarty_Internal_Compile_Wslistelse extends Smarty_Internal_CompileBase{ public function compile($args, $compiler, $parameter){ $_attr = $this->getAttributes($compiler, $args); list($openTag, $nocache, $item, $key) = $this->closeTag($compiler, array('wslist')); $this->openTag($compiler, 'wslistelse', array('wslistelse', $nocache, $item, $key)); return "tpl_vars[$item]->_loop) {\n?>"; } } class Smarty_Internal_Compile_Wslistclose 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('wslist', 'wslistelse')); return ""; } }