table; } if (!count($langue_doc)) { $langue_doc = new marc_list('lang'); $langue_doc = $langue_doc->table; } // propriétés pour le selecteur de panier $selector_prop = "toolbar=no, dependent=yes, resizable=yes, scrollbars=yes"; $cart_click = "onClick=\"openPopUp('./cart.php?object_type=NOTI&item=!!id!!&unq=!!unique!!', 'cart', 600, 700, -2, -2, '$selector_prop')\""; // définition de la classe d'affichage des monographies en liste class mono_display_expl { var $notice_id = 0; // id de la notice à afficher var $isbn = 0; // isbn ou code EAN de la notice à afficher var $notice; // objet notice (tel que fetché dans la table 'notices' var $langues = array(); var $languesorg = array(); var $action = ''; // URL à associer au header var $header = ''; // chaine accueillant le chapeau de notice (peut-être cliquable) var $tit_serie = ''; // titre de série si applicable var $tit1 = ''; // valeur du titre 1 var $result = ''; // affichage final var $level = 1; // niveau d'affichage var $isbd = ''; // isbd de la notice en fonction du level défini var $expl = 0; // flag indiquant si on affiche les infos d'exemplaire var $nb_expl = 0; //nombre d'exemplaires var $link_expl = ''; // lien associé à un exemplaire var $responsabilites = array("responsabilites" => array(),"auteurs" => array()); // les auteurs var $categories = array();// les categories var $show_resa = 0; // flag indiquant si on affiche les infos de resa var $p_perso; var $print_mode=0; var $show_explnum=1; var $show_statut=0; var $aff_statut = '' ; // carré de couleur pour signaler le statut de la notice var $tit_serie_lien_gestion ; var $childs=array(); //Filles de la notice var $anti_loop=""; var $drag=""; //Notice draggable ? var $no_link; var $show_opac_hidden_fields=true; // constructeur------------------------------------------------------------ function mono_display_expl($cb,$expl_id, $level=1, $action='', $expl=1, $expl_link='', $lien_suppr_cart="", $explnum_link='', $show_resa=0, $print=0, $show_explnum=1, $no_link=true,$ajax_mode=0 ) { // $id = id de la notice à afficher // $action = URL associée au header // $level : // 0 : juste le header (titre / auteur principal avec le lien si applicable) // suppression des niveaux entre 1 et 6, seul reste level // 1 : ISBD seul, pas de note, bouton modif, expl, explnum et résas // 6 : cas général détaillé avec notes, categ, langues, indexation... + boutons // $expl -> affiche ou non les exemplaires associés // $expl_link -> lien associé à l'exemplaire avec !!expl_id!!, !!notice_id!! et !!expl_cb!! à mettre à jour // $lien_suppr_cart -> lien de suppression de la notice d'un caddie // // $show_resa = affichage des resa ou pas global $pmb_recherche_ajax_mode; global $explr_visible_mod,$pmb_droits_explr_localises; $this->expl_data = $this->get_expl_info($cb,$expl_id); $this->notice_id = $this->expl_data->expl_notice; $this->id_bulletin = $this->expl_data->expl_bulletin; if($this->id_bulletin) { $req="select num_notice from bulletins where bulletin_id=".$this->id_bulletin; $result = mysql_query($req); if(mysql_num_rows($result)) { $res = mysql_fetch_object($result); $this->num_notice = $res->num_notice; } } $this->header=$this->expl_titre_diplay()." / "; $this->isbd=$this->expl_info_display(); // notice de monographie if($this->notice_id) { $display = new mono_display($this->notice_id,$level, "", $expl, $expl_link, '', $explnum_link,1, 0, 1, 0, "", 1 , $no_link,true,0); $link_notice = str_replace("!!id!!", $this->notice_id, $action ); } // notice de bulletin if($this->num_notice) { $display = new mono_display($this->num_notice, $level, "", $expl, $expl_link, '', $explnum_link,1, 0, 1, 0, "", 1 , $no_link,true,0); $link_notice = str_replace("!!id!!", $this->id_bulletin, $action ); } // bulletin sans notice if(!$this->num_notice && $this->id_bulletin) { $display = new bulletinage_display($this->id_bulletin); $link_notice = str_replace("!!id!!", $this->id_bulletin, $action ); } $this->header.= $display->header; $this->isbd.= "".$display->header.""; $this->isbd.= $display->isbd; //visibilité des exemplaires if ($pmb_droits_explr_localises) { $explr_tab_modif=explode(",",$explr_visible_mod); $as_modif = array_search($this->expl_data->idlocation,$explr_tab_modif); } else { $as_modif = true; } if (($expl_link) && ($as_modif!== FALSE && $as_modif!== NULL) ) { $expl_link = str_replace("!!notice_id!!", $this->notice_id, $expl_link ); $expl_link = str_replace("!!expl_cb!!", $cb, $expl_link ); $expl_link = str_replace("!!expl_id!!", $expl_id, $expl_link ); $expl_link = str_replace("!!bulletin_id!!", $this->id_bulletin, $expl_link ); $this->header= "".$this->header.""; } switch($level) { case 0: // là, c'est le niveau 0 : juste le header $this->result = $this->header; break; default: // niveau 1 et plus : header + isbd à générer $this->init_javascript(); $this->finalize(); break; } return; } function expl_titre_diplay() { global $charset; global $msg; global $dbh; global $pmb_expl_title_display_format,$p_perso; if(!$pmb_expl_title_display_format) return''; $liste_format=explode(",",$pmb_expl_title_display_format); foreach($liste_format as $format) { switch($format) { case "expl_cb":$liste_aff[]=htmlentities($this->expl_data->expl_cb,ENT_QUOTES,$charset);break; case "expl_notice":$liste_aff[]=htmlentities($this->expl_data->id_notice,ENT_QUOTES,$charset);break; case "expl_bulletin":$liste_aff[]=htmlentities($this->expl_data->id_bulletin,ENT_QUOTES,$charset);break; case "expl_typdoc":$liste_aff[]=htmlentities($this->expl_data->typdoc,ENT_QUOTES,$charset);break; case "expl_cote":$liste_aff[]=htmlentities($this->expl_data->expl_cote,ENT_QUOTES,$charset);break; case "expl_section":$liste_aff[]=htmlentities($this->expl_data->section_libelle,ENT_QUOTES,$charset);break; case "expl_statut":$liste_aff[]=htmlentities($this->expl_data->statut,ENT_QUOTES,$charset);break; case "expl_location":$liste_aff[]=htmlentities($this->expl_data->location_libelle,ENT_QUOTES,$charset);break; case "expl_codestat":$liste_aff[]=htmlentities($this->expl_data->codestat,ENT_QUOTES,$charset);break; case "expl_note":$liste_aff[]=htmlentities($this->expl_data->note,ENT_QUOTES,$charset);break; case "expl_prix":$liste_aff[]=htmlentities($this->expl_data->prix,ENT_QUOTES,$charset);break; case "expl_owner":$liste_aff[]=htmlentities($this->expl_data->lender_id,ENT_QUOTES,$charset);break; case "expl_lastempr":$liste_aff[]=htmlentities($this->expl_data->lastempr,ENT_QUOTES,$charset);break; case "last_loan_date":$liste_aff[]=htmlentities(format_date($this->expl_data->last_loan_date),ENT_QUOTES,$charset);break; case "create_date":$liste_aff[]=htmlentities(format_date($this->expl_data->create_date),ENT_QUOTES,$charset);break; case "update_date":$liste_aff[]=htmlentities(format_date($this->expl_data->update_date),ENT_QUOTES,$charset);break; case "expl_date_depot":$liste_aff[]=htmlentities(format_date($this->expl_data->expl_date_depot),ENT_QUOTES,$charset);break; case "expl_date_retour":$liste_aff[]=htmlentities(format_date($this->expl_data->expl_date_retour),ENT_QUOTES,$charset);break; case "type_antivol":$liste_aff[]=htmlentities($this->expl_data->type_antivol,ENT_QUOTES,$charset);break; case "transfert_location_origine":$liste_aff[]=htmlentities($this->expl_data->transfert_location_origine,ENT_QUOTES,$charset);break; case "transfert_statut_origine":$liste_aff[]=htmlentities($this->expl_data->transfert_statut_origine,ENT_QUOTES,$charset);break; default: if (is_numeric($format)) { // c'est un id de champ perso if(!$p_perso) $p_perso=new parametres_perso("expl"); if (!$p_perso->no_special_fields) { if(!$perso_) { $perso_=$p_perso->show_fields($this->expl_data->expl_id); $nb_param=count($perso_["FIELDS"]); } for ($i=0; $i<$nb_param; $i++) { $p=$perso_["FIELDS"][$i]; if($p["ID"]==$format) { if($p["AFF"]) $liste_aff[]=$p["AFF"]; } } } } break; } } if(!$liste_aff) return''; return implode(", ", $liste_aff); } // récupération des infos exemplaires function get_expl_info($cb, $id, $lien_notice=1) { global $dbh; global $cart_link_non; if ($cb && !$id) $clause_where = " WHERE expl_cb = '$cb' "; if ( (!$cb && $id) || ($cb && $id) ) $clause_where = " WHERE expl_id = '$id' "; if ($cb || $id) { $query = " select * from exemplaires expl, docs_location location, docs_codestat, lenders "; $query .= ", docs_section section, docs_statut statut, docs_type dtype"; $query .= $clause_where; $query .= " and location.idlocation=expl.expl_location"; $query .= " and section.idsection=expl.expl_section"; $query .= " and statut.idstatut=expl.expl_statut"; $query .= " and dtype.idtyp_doc=expl.expl_typdoc"; $query .= " and idcode=expl.expl_codestat"; $query .= " and idlender=expl.expl_owner"; $result = mysql_query($query, $dbh); if(mysql_num_rows($result)) { $expl = mysql_fetch_object($result); if ($expl->expl_lastempr) { $lastempr = new emprunteur($expl->expl_lastempr, '', FALSE, 0) ; $expl->lastempr_nom = $lastempr->nom; $expl->lastempr_prenom = $lastempr->prenom; $expl->lastempr_cb = $lastempr->cb; } return $expl; } } return FALSE; } function expl_info_display($affichage_emprunteurs=1,$affichage_zone_notes=1) { global $msg,$expl_view_form,$pmb_expl_show_dates,$charset; $expl_aff=$expl_view_form; $expl_aff=str_replace('!!code_barre!!', htmlentities($this->expl_data->expl_cb,ENT_QUOTES,$charset), $expl_aff); $expl_aff=str_replace('!!cote!!', htmlentities($this->expl_data->expl_cote,ENT_QUOTES,$charset), $expl_aff); $expl_aff=str_replace('!!type_doc!!', htmlentities($this->expl_data->tdoc_libelle,ENT_QUOTES,$charset), $expl_aff); $expl_aff=str_replace('!!localisation!!', htmlentities($this->expl_data->location_libelle,ENT_QUOTES,$charset), $expl_aff); $expl_aff=str_replace('!!section!!', htmlentities($this->expl_data->section_libelle,ENT_QUOTES,$charset), $expl_aff); $expl_aff=str_replace('!!owner!!', htmlentities($this->expl_data->lender_libelle,ENT_QUOTES,$charset), $expl_aff); $expl_aff=str_replace('!!statut!!', htmlentities($this->expl_data->statut_libelle,ENT_QUOTES,$charset), $expl_aff); $expl_aff=str_replace('!!codestat!!', htmlentities($this->expl_data->codestat_libelle,ENT_QUOTES,$charset), $expl_aff); $expl_aff=str_replace('!!note!!', htmlentities($this->expl_data->expl_note,ENT_QUOTES,$charset), $expl_aff); $expl_aff=str_replace('!!comment!!', htmlentities($this->expl_data->expl_comment,ENT_QUOTES,$charset), $expl_aff); //on compte de nombre de prets pour cet exemplaire $req = "select count(arc_expl_id) as nb_prets from pret_archive where arc_expl_id = ".$this->expl_data->expl_id; $res = mysql_query($req); if(mysql_num_rows($res)){ $arch_pret = mysql_fetch_object($res); $nb_prets = $arch_pret->nb_prets ; }else $nb_prets = 0; $expl_aff=str_replace('!!nb_prets!!', $nb_prets, $expl_aff); //Date de création / modification if($pmb_expl_show_dates=='1' || $pmb_expl_show_dates=='3') { $tmp="