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