$tables['auteur']); $recherche = recherche_en_base($cherche, $tables,array('toutvoir'=>true)); if ($recherche['auteur']) $recherche = sql_in('aut.id_auteur', array_keys($recherche['auteur'])); else { $recherche = "aut.id_auteur=0"; // rien trouve ! } } $form = formulaire_recherche("auteurs",(($s=_request('statut'))?"":"")); exec_auteurs_args($statut, $tri, $debut, $recherche,$form, $cherche); } // http://doc.spip.org/@exec_auteurs_args function exec_auteurs_args($statut, $tri, $debut, $recherche=NULL, $trouve='', $cherche='') { if ($recherche !=='') { list($auteurs, $lettre, $nombre_auteurs, $debut) = lettres_d_auteurs(requete_auteurs($tri, $statut, $recherche), $debut, MAX_AUTEURS_PAR_PAGE, $tri); $arg = ($statut ? ("&statut=" .urlencode($statut)) : '') . ($cherche ? ("&recherche=" . urlencode($cherche)) : ''); $recherche = auteurs_tranches(afficher_n_auteurs($auteurs), $debut, $lettre, $tri, $statut, MAX_AUTEURS_PAR_PAGE, $nombre_auteurs, $arg); if ($cherche){ $cherche = htmlspecialchars($cherche); if (count($auteurs)) $recherche = "

". _T('info_resultat_recherche')." «$cherche»

" . $recherche; else $recherche = "

". _T('info_recherche_auteur_zero',array('cherche_auteur'=>$cherche))."

" . $recherche; } } if (_AJAX) { ajax_retour($recherche); //ecrire en id='auteurs' ci-dessous } else { pipeline('exec_init',array('args'=>array('exec'=>'auteurs'),'data'=>'')); $visiteurs = !statut_min_redac($statut); $commencer_page = charger_fonction('commencer_page', 'inc'); echo $commencer_page( $visiteurs ? _T('info_visiteurs') : _T('info_auteurs'), "auteurs","redacteurs"); echo bandeau_auteurs($visiteurs); echo $trouve, "
"; echo "
", $recherche, "
"; echo pipeline('affiche_milieu',array('args'=>array('exec'=>'auteurs'),'data'=>'')); echo fin_gauche(), fin_page(); } } // http://doc.spip.org/@bandeau_auteurs function bandeau_auteurs($visiteurs) { global $connect_id_auteur; $ret = debut_gauche("auteurs",true) . debut_boite_info(true); if ($visiteurs) $ret .= "\n

"._T('info_gauche_visiteurs_enregistres'). '

'; else $ret .= "\n

"._T('info_gauche_auteurs'). '

'; if (autoriser('voir', 'auteur')) $ret .= "\n

". _T('info_gauche_auteurs_exterieurs') . '

'; $ret .= fin_boite_info(true); $ret .= pipeline('affiche_gauche',array('args'=>array('exec'=>'auteurs'),'data'=>'')); if (autoriser('voir', 'auteur')) { if (autoriser('creer', 'auteur')) $res = icone_horizontale(_T('icone_creer_nouvel_auteur'), generer_url_ecrire("auteur_infos", 'new=oui'), "auteur-24.gif", "creer.gif", false); else $res = ''; $res .= icone_horizontale(_T('icone_informations_personnelles'), generer_url_ecrire("auteur_infos","id_auteur=$connect_id_auteur"), "fiche-perso-24.gif","rien.gif", false); if (avoir_visiteurs(true)) { if ($visiteurs) $res .= icone_horizontale (_T('icone_afficher_auteurs'), generer_url_ecrire("auteurs", "statut=" . AUTEURS_MIN_REDAC), "auteur-24.gif", "", false); else $res .= icone_horizontale (_T('icone_afficher_visiteurs'), generer_url_ecrire("auteurs","statut=!" . AUTEURS_MIN_REDAC), "auteur-24.gif", "", false); } $ret .= bloc_des_raccourcis($res); } $ret .= creer_colonne_droite('auteurs',true); $ret .= pipeline('affiche_droite',array('args'=>array('exec'=>'auteurs'),'data'=>'')); $ret .= debut_droite('',true); $ret .= "\n
"; $ret .= gros_titre($visiteurs ? _T('info_visiteurs') : _T('info_auteurs'),'',false); $ret .= "\n
"; return $ret; } // http://doc.spip.org/@statut_min_redac function statut_min_redac($statut) { $x = (!$statut) || (strpos($statut, "0minirezo")!==false) || (strpos($statut, "1comite")!==false); return $statut[0] =='!' ? !$x : $x; } // http://doc.spip.org/@lettres_d_auteurs function lettres_d_auteurs($query, $debut, $max_par_page, $tri) { $auteurs = $lettre = array(); $lettres_nombre_auteurs = 0; $lettre_prec =""; $nombre_auteurs = 0; $query = sql_select($query['SELECT'], $query['FROM'], $query['WHERE'], $query['GROUP BY'], $query['ORDER BY']); while ($auteur = sql_fetch($query)) { if ($nombre_auteurs>=$debut AND $nombre_auteurs<$debut+$max_par_page) { $auteur['restreint'] = sql_countsel("spip_auteurs_rubriques", "id_auteur=".$auteur['id_auteur']); $auteurs[] = $auteur; } if ($tri == 'nom') { $premiere_lettre = strtoupper(spip_substr(corriger_typo($auteur['nom']),0,1)); if ($premiere_lettre != $lettre_prec) { $lettre[$premiere_lettre] = $nombre_auteurs; } $lettre_prec = $premiere_lettre; } $nombre_auteurs++; } return array($auteurs, $lettre, $nombre_auteurs, $debut); } // http://doc.spip.org/@auteurs_tranches function auteurs_tranches($auteurs, $debut, $lettre, $tri, $statut, $max_par_page, $nombre_auteurs, $arg='') { global $spip_lang_right; $res ="\n" . "\n"; if ($tri=='statut') $res .= http_img_pack('admin-12.gif','', " class='lang'"); else { $t = _T('lien_trier_statut'); $res .= auteurs_href(http_img_pack('admin-12.gif', $t, "class='lang'"),"tri=statut$arg", " title=\"$t\""); } $res .= ""; if ($tri=='nom') $res .= ''._T('info_nom').''; else $res .= auteurs_href(_T('info_nom'), "tri=nom$arg", " title='"._T('lien_trier_nom'). "'"); $res .= ""; if ($tri=='site') $res .= ''._T('info_site').''; else $res .= auteurs_href(_T('info_site'), "tri=site$arg", " title='"._T('info_site'). "'"); $res .= ''; $col = statut_min_redac($statut) ? _T('info_articles') : _T('message') ; if ($tri=='nombre') $res .= '' . $col .''; else $res .= auteurs_href($col, "tri=nombre$arg", " title=\""._T('lien_trier_nombre_articles'). '"'); $res .= "\n"; if ($nombre_auteurs > $max_par_page) { $res .= "\n
"; for ($j=0; $j < $nombre_auteurs; $j+=$max_par_page) { if ($j > 0) $res .= " | "; if ($j == $debut) $res .= "$j"; else if ($j > 0) $res .= auteurs_href($j, "tri=$tri$arg&debut=$j"); else $res .= auteurs_href('0', "tri=$tri$arg"); if ($debut > $j AND $debut < $j+$max_par_page){ $res .= " | $debut"; } } if ($tri == 'nom') { $res .= "
\n"; $val_prev = 0; foreach ($lettre as $key => $val) { if ($val == $debut) $res .= "$key\n"; else { if ($debut>$val_prev && $debut<$val) $res .= ".. "; $res .= auteurs_href($key, "tri=$tri$arg&debut=$val") . "\n"; } $val_prev = $val; } $res .= "
\n"; } } $nav = ''; $debut_suivant = $debut + $max_par_page; if ($debut_suivant < $nombre_auteurs OR $debut > 0) { $nav = "\n" . "\n
"; if ($debut > 0) { $debut_prec = max($debut - $max_par_page, 0); $nav .= auteurs_href('<<<',"tri=$tri&debut=$debut_prec$arg"); } $nav .= ""; if ($debut_suivant < $nombre_auteurs) { $nav .= auteurs_href('>>>',"tri=$tri&debut=$debut_suivant&$arg"); } $nav .= "
\n"; } return debut_cadre('liste','auteur-24.gif','','','lesauteurs') . "\n
\n" . $res . $auteurs . "
\n
" . $nav . fin_cadre(); } // http://doc.spip.org/@auteurs_href function auteurs_href($clic, $args='', $att='') { $h = generer_url_ecrire('auteurs', $args); $a = 'auteurs'; if (_SPIP_AJAX === 1 ) $att .= ("\nonclick=" . ajax_action_declencheur($h,$a)); return "$clic"; } // http://doc.spip.org/@requete_auteurs function requete_auteurs($tri, $statut, $recherche=NULL) { global $connect_id_auteur; // si on n'est pas minirezo, ignorer les auteurs sans article // sauf les admins, toujours visibles. // limiter les statuts affiches if (autoriser('voir', 'auteur')) { if ($statut[0]=='!') { $statut = substr($statut,1); $not = "NOT"; } else $not = ''; $visit = !statut_min_redac($statut); $statut = preg_split('/\W+/', $statut); $where = sql_in("aut.statut", $statut, $not); } else { $where = "( aut.statut = '0minirezo' OR aut.id_auteur=$connect_id_auteur OR " . sql_in('art.statut', array('prop', 'publie')) . ')'; $visit = false; } if ($recherche) $where .= " AND $recherche" ; return requete_auteurs_tri($tri, $where, $visit); } function requete_auteurs_tri($tri, $where, $visit=false) { global $spip_lang; $sql_sel = ''; $join = $visit ? "" : (strpos($where,'art.statut')?("LEFT JOIN spip_auteurs_articles AS lien ON aut.id_auteur=lien.id_auteur" . " LEFT JOIN spip_articles AS art ON (lien.id_article = art.id_article)"):""); // tri switch ($tri) { case 'nombre': $sql_sel = "COUNT(lien.id_article) AS compteur"; $sql_order = 'compteur DESC, unom'; $join = $visit ? "LEFT JOIN spip_forum AS lien ON aut.id_auteur=lien.id_auteur" : ("LEFT JOIN spip_auteurs_articles AS lien ON aut.id_auteur=lien.id_auteur" . (strpos($where,'art.statut')?" LEFT JOIN spip_articles AS art ON (lien.id_article = art.id_article)":"")); break; case 'site': $sql_order = 'site, unom'; break; case 'statut': $sql_order = 'statut, unom'; break; case 'nom': default: $sql_sel = sql_multi ("nom", $spip_lang); $sql_order = "multi"; } // // La requete de base est tres sympa // (pour les visiteurs, ca postule que les messages concernent des articles) return array('SELECT' => array_diff( array( "aut.id_auteur AS id_auteur", "aut.statut AS statut", "aut.nom_site AS site", "aut.nom AS nom", "UPPER(aut.nom) AS unom", $sql_sel),array('',null)), 'FROM' => "spip_auteurs AS aut $join", 'WHERE' => $where, 'GROUP BY' => "aut.statut, aut.nom_site, aut.nom, aut.id_auteur", 'ORDER BY' => $sql_order); } // http://doc.spip.org/@afficher_n_auteurs function afficher_n_auteurs($auteurs) { $res = ''; $formater_auteur = charger_fonction('formater_auteur', 'inc'); foreach ($auteurs as $row) { list($s, $mail, $nom, $w, $p) = $formater_auteur($row['id_auteur']); $res .= "\n" . "\n" . $s . "" . $mail . "" . $nom . ((isset($row['restreint']) AND $row['restreint']) ? ("  "._T('statut_admin_restreint')."") : '') ."" . $w . "" . $p . "\n"; } return $res; } ?>