id=$id+0;
$this->fetch_data();
}
public function fetch_data() {
global $msg,$dbh,$charset;
$this->facettes=array();
$req="select bannette_facettes.*,bannettes.display_notice_in_every_group,bannettes.document_group from bannette_facettes
JOIN bannettes ON id_bannette=num_ban_facette
where num_ban_facette=". $this->id." order by ban_facette_order";
$res = pmb_mysql_query($req,$dbh);
$i=0;
if (pmb_mysql_num_rows($res)) {
while($r=pmb_mysql_fetch_object($res)){
$this->facettes[$i] = new stdClass();
$this->facettes[$i]->critere=$r->ban_facette_critere;
$this->facettes[$i]->ss_critere= $r->ban_facette_ss_critere;
$this->facettes[$i]->order= $r->ban_facette_order;
$this->facettes[$i]->order_sort= $r->ban_facette_order_sort;
$this->facettes[$i]->datatype_sort= $r->ban_facette_datatype_sort;
if(!$this->bannette_display_notice_in_every_group){
$this->bannette_display_notice_in_every_group=$r->display_notice_in_every_group;
}
if(!$this->bannette_document_group){
$this->bannette_document_group=$r->document_group;
}
$i++;
}
}
}
public function delete(){
$del = "delete from bannette_facettes where num_ban_facette = '".$this->id."'";
pmb_mysql_query($del);
}
public function save(){
global $max_facette;
$this->delete();
$order=0;
for($i=0;$i<$max_facette;$i++){
$critere = 'list_crit_'.$i;
global ${$critere};
if(${$critere} > 0){
$ss_critere = 'list_ss_champs_'.$i;
global ${$ss_critere};
$order_sort = 'order_sort_'.$i;
global ${$order_sort};
$datatype_sort = 'datatype_sort_'.$i;
global ${$datatype_sort};
$rqt = "insert into bannette_facettes
set num_ban_facette = '".$this->id."',
ban_facette_critere = '".${$critere}."',
ban_facette_ss_critere='".${$ss_critere}."',
ban_facette_order='".$order."',
ban_facette_order_sort='".${$order_sort}."',
ban_facette_datatype_sort='".${$datatype_sort}."' ";
pmb_mysql_query($rqt);
$order++;
}
}
}
public function build_notice($notice_id, $id_bannette = 0){
global $deflt2docs_location,$url_base_opac;
global $use_opac_url_base; $use_opac_url_base=1;
global $use_dsi_diff_mode; $use_dsi_diff_mode=1;
global $opac_notice_affichage_class;
$tpl_document='';
if($this->noti_tpl_document) {
$tpl_document .= $this->noti_tpl_document->build_notice($notice_id, $deflt2docs_location, false, $id_bannette);
} elseif($this->noti_django_directory) {
$tpl_document .= record_display::get_display_in_result($notice_id, $this->noti_django_directory);
}
if(!$tpl_document) {
if (!$opac_notice_affichage_class) $opac_notice_affichage_class="notice_affichage";
$current = new $opac_notice_affichage_class($notice_id);
$current->do_isbd();
$tpl_document.=$current->notice_isbd;
}
return $tpl_document."\r\n";
}
public function filter_facettes_search($facettes_list,$notice_ids){
global $dbh;
global $lang;
global $msg;
global $dsi_bannette_notices_order ;
$notices=implode(",",$notice_ids);
$res_notice_ids=array();
$res_notice_ids["values"]=array();
$res_notice_ids["notfound"]=array();
$critere= $facettes_list[0]->critere;
$ss_critere= $facettes_list[0]->ss_critere;
$order_sort= intval($facettes_list[0]->order_sort);
$datatype_sort= $facettes_list[0]->datatype_sort;
$order_by = 'ORDER BY ';
if ($datatype_sort == 'date') {
$order_by .= " STR_TO_DATE(value,'".$msg['format_date']."')";
} else {
$order_by .= " value";
}
if($order_sort == 0){
$order_by .= " asc";
} else {
$order_by .= " desc";
}
if ($dsi_bannette_notices_order) {
$req = "SELECT * FROM notices_fields_global_index LEFT JOIN notices on (id_notice=notice_id)
WHERE id_notice IN (".$notices.")
AND code_champ = ".$critere." AND code_ss_champ = ".$ss_critere." AND lang in ('','".$lang."') ".$order_by.",".$dsi_bannette_notices_order;
} else {
$req = "SELECT * FROM notices_fields_global_index
WHERE id_notice IN (".$notices.")
AND code_champ = ".$critere." AND code_ss_champ = ".$ss_critere." AND lang in ('','".$lang."') ".$order_by;
}
// print $req."
";
$res = pmb_mysql_query($req,$dbh);
if (pmb_mysql_num_rows($res)) {
while($r=pmb_mysql_fetch_object($res)){
$res_notice_ids["folder"][$r->value]["values"][]= $r->id_notice;
$res_notice_ids["memo"][]= $r->id_notice;
}
foreach($notice_ids as $id_notice ){
if(!in_array($id_notice,$res_notice_ids["memo"])) $res_notice_ids["notfound"][]=$id_notice;
}
// Si encore une facette d'affinage, on fait du récursif
if(count($facettes_list)>1){
array_splice($facettes_list, 0,1);
foreach($res_notice_ids["folder"] as $folder => $contens){
//printr($contens["values"]);
$res_notice_ids["folder"][$folder]= $this->filter_facettes_search($facettes_list, $contens["values"]);
//printr($res_notice_ids["folder"][$folder]);
$res_notice_ids["folder"][$folder]["notfound_cumul"]=array();
foreach($res_notice_ids["folder"][$folder]["values"] as $value){
if(is_array($value["notfound"]))
$res_notice_ids["folder"][$folder]["notfound_cumul"]=array_merge($res_notice_ids["folder"][$folder]["notfound_cumul"],$value["notfound"]);
}
}
}
}else{
$res_notice_ids["notfound"]=$notice_ids;
}
return $res_notice_ids;
}
public function filter_facettes_print($res_notice_ids, $rang=1,$notfound=array(),$gen_document=0,&$already_printed=array()){
global $dbh, $msg, $charset;
global $lang;
$tpl = "";
if(count($res_notice_ids["notfound"])){
$tpl.="
";
foreach($res_notice_ids["notfound"] as $notice_id){
if( !in_array($notice_id, $notfound) )
$tpl.="".$this->build_notice($notice_id)."
" ;
$notfound[]=$notice_id;
}
$tpl.="
";
foreach($contens["values"] as $notice_id){
if(!in_array($notice_id,$already_printed)){
$tpl.=$this->build_notice($notice_id)."
" ;
if($gen_document && !$this->bannette_document_group){
$tpl.="