Bifurcation depuis
spip / spip
16849 validations de retard le dépôt en amont.
-
esj a rédigé
Ticket #413: toutes les URL passées en paramètre dans une URL sont à présent relatives, afin de ne pas etre bloquées par le mod_security d'Apache. Les derniers cas suspects ne l'étaient en fait pas ou étaient du code mort.
esj a rédigéTicket #413: toutes les URL passées en paramètre dans une URL sont à présent relatives, afin de ne pas etre bloquées par le mod_security d'Apache. Les derniers cas suspects ne l'étaient en fait pas ou étaient du code mort.
mots.php 23,16 Kio
<?php
/***************************************************************************\
* SPIP, Systeme de publication pour l'internet *
* *
* Copyright (c) 2001-2006 *
* Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James *
* *
* Ce programme est un logiciel libre distribue sous licence GNU/GPL. *
* Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne. *
\***************************************************************************/
//
if (!defined("_ECRIRE_INC_VERSION")) return;
// ne pas faire d'erreur si les chaines sont > 254 caracteres
function levenshtein255 ($a, $b) {
$a = substr($a, 0, 254);
$b = substr($b, 0, 254);
return @levenshtein($a,$b);
}
// reduit un mot a sa valeur translitteree et en minuscules
function reduire_mot($mot) {
return strtr(
translitteration(trim($mot)),
'ABCDEFGHIJKLMNOPQRSTUVWXYZ',
'abcdefghijklmnopqrstuvwxyz'
);
}
function mots_ressemblants($mot, $table_mots, $table_ids='') {
$lim = 2;
$nb = 0;
$opt = 1000000;
$mot_opt = '';
$mot = reduire_mot($mot);
$len = strlen($mot);
if (!$table_mots) return '';
while (!$nb AND $lim < 10) {
reset($table_mots);
if ($table_ids) reset($table_ids);
while (list(, $val) = each($table_mots)) {
if ($table_ids) list(, $id) = each($table_ids);
else $id = $val;
$val2 = trim($val);
if ($val2) {
if (!($m = $distance[$id])) {
$val2 = reduire_mot($val2);
$len2 = strlen($val2);
if ($val2 == $mot)
$m = -2; # resultat exact
else if (substr($val2, 0, $len) == $mot)
$m = -1; # sous-chaine
else {
# distance
$m = levenshtein255($val2, $mot);
# ne pas compter la distance due a la longueur
$m -= max(0, $len2 - $len);
}
$distance[$id] = $m;
}
if ($m <= $lim) {
$selection[$id] = $m;
if ($m < $opt) {
$opt = $m;
$mot_opt = $val;
}
$nb++;
}
}
}
$lim += 2;
}
if (!$nb) return '';
reset($selection);
if ($opt > -1) {
$moy = 1;
while(list(, $val) = each($selection)) $moy *= $val;
if($moy) $moy = pow($moy, 1.0/$nb);
$lim = ($opt + $moy) / 2;
}
else $lim = -1;
reset($selection);
while (list($key, $val) = each($selection)) {
if ($val <= $lim) {
$result[] = $key;
}
}
return $result;
}
/*
* Affiche la liste des mots-cles associes a l'objet
* specifie, plus le formulaire d'ajout de mot-cle
*/
function formulaire_mots($table, $id_objet, $nouv_mot, $supp_mot, $cherche_mot, $flag_editable) {
global $connect_statut, $connect_toutes_rubriques, $options;
global $spip_lang_rtl, $spip_lang_right, $spip_lang;
if ($table == 'articles') {
$table_id = 'id_article';
$objet = 'article';
$url_base = "articles";
}
else if ($table == 'breves') {
$table_id = 'id_breve';
$objet = 'breve';
$url_base = "breves_voir";
}
else if ($table == 'rubriques') {
$table_id = 'id_rubrique';
$objet = 'rubrique';
$url_base = "naviguer";
}
else if ($table == 'syndic') {
$table_id = 'id_syndic';
$objet = 'syndic';
$url_base = "sites";
}
else {$table = $table_id = $objet = $url_base = '';}
$cpt = spip_fetch_array(spip_query("SELECT COUNT(*) AS n FROM spip_mots AS mots, spip_mots_$table AS lien WHERE lien.$table_id=$id_objet AND mots.id_mot=lien.id_mot"));
if (!($nombre_mots = $cpt['n'])) {
if (!$flag_editable) return;
$cpt = spip_fetch_array(spip_query("SELECT COUNT(*) AS n FROM spip_groupes_mots WHERE $table = 'oui' AND ".substr($connect_statut,1)." = 'oui'"));
if (!$cpt['n'] AND !$flag_editable) return;
}
echo "<a name='mots'></a>";
if ($flag_editable){
if ($nouv_mot||$cherche_mot||$supp_mot)
$bouton = bouton_block_visible("lesmots");
else
$bouton = bouton_block_invisible("lesmots");
}
debut_cadre_enfonce("mot-cle-24.gif", false, "", $bouton._T('titre_mots_cles').aide ("artmots"));
//////////////////////////////////////////////////////
// Recherche de mot-cle
//
$nouveaux_mots = $nouv_mot ? array($nouv_mot) : array();
$tous_les_mots = split(" *[,;] *", $cherche_mot);
while ((list(,$cherche_mot) = each ($tous_les_mots)) AND $cherche_mot) {
echo "<P ALIGN='left'>";
$result = spip_query("SELECT id_mot, titre FROM spip_mots WHERE id_groupe=" . intval($GLOBALS['select_groupe']));
$table_mots = array();
$table_ids = array();
while ($row = spip_fetch_array($result)) {
$table_ids[] = $row['id_mot'];
$table_mots[] = $row['titre'];
}
$resultat = mots_ressemblants($cherche_mot, $table_mots, $table_ids);
debut_boite_info();
if (!$resultat) {
echo "<B>"._T('info_non_resultat', array('cherche_mot' => $cherche_mot))."</B><BR>";
}
else if (count($resultat) == 1) {
list(, $nouv_mot) = each($resultat);
$nouveaux_mots[] = $nouv_mot;
echo "<B>"._T('info_mot_cle_ajoute')." ";
if ($table == 'articles') echo _T('info_l_article');
else if ($table == 'breves') echo _T('info_la_breve');
else if ($table == 'rubriques') echo _T('info_la_rubrique');
echo " : </B><BR>";
$result = spip_query("SELECT * FROM spip_mots WHERE id_mot=$nouv_mot");
echo "<UL>";
while ($row = spip_fetch_array($result)) {
$id_mot = $row['id_mot'];
$titre_mot = $row['titre'];
$type_mot = typo($row['type']);
$descriptif_mot = $row['descriptif'];
echo "<LI><FONT FACE='Verdana,Arial,Sans,sans-serif' SIZE=2><B><FONT SIZE=3>".typo($titre_mot)."</FONT></B>";
echo "</FONT>\n";
}
echo "</UL>";
}
else affiche_mots_ressemblant($cherche_mot, $id_objet, $resultat, $table_id, $url_base);
if ($GLOBALS['connect_statut'] == '0minirezo'
AND $connect_toutes_rubriques ) {
echo "<div style='width: 200px;'>";
$titre = rawurlencode($cherche_mot);
icone_horizontale(_T('icone_creer_mot_cle'), generer_url_ecrire("mots_edit","new=oui&ajouter_id_article=$id_objet&table=$table&table_id=$table_id&titre=$titre&redirect=" . generer_url_retour($url_base, "$table_id=$id_objet")), "mot-cle-24.gif", "creer.gif");
echo "</div> ";
}
fin_boite_info();
echo "<P>";
} // fin de la boucle sur la recherche de mots
//////////////////////////////////////////////////////
// Appliquer les modifications sur les mots-cles
//
$reindexer = false;
if ($nouveaux_mots && $flag_editable) {
while ((list(,$nouv_mot) = each($nouveaux_mots)) AND $nouv_mot!='x') {
$result = spip_query("SELECT * FROM spip_mots_$table WHERE id_mot=$nouv_mot AND $table_id=$id_objet");
if (!spip_num_rows($result)) {
spip_query("INSERT INTO spip_mots_$table (id_mot,$table_id) VALUES ($nouv_mot, $id_objet)");
}
}
$reindexer = true;
}
if ($flag_editable && $supp_mot) {
$result = spip_query("DELETE FROM spip_mots_$table WHERE $table_id=$id_objet" . (($supp_mot == -1) ? "" : " AND id_mot=" . intval($supp_mot) ));
$reindexer = true;
}
if ($reindexer AND $GLOBALS['meta']['activer_moteur'] == 'oui') {
include_spip("inc/indexation");
marquer_indexer($objet, $id_objet);
}
//
// Afficher les mots-cles
//
$visible = $nouveaux_mots||$cherche_mot||$supp_mot;
afficher_mots_cles($flag_editable, $id_objet, $table, $table_id, $url_base, $visible);
fin_cadre_enfonce();
}
function affiche_mots_ressemblant($cherche_mot, $id_objet, $resultat, $table_id, $url_base)
{
if (count($resultat) > 17)
echo "<br /><b>",_T('info_trop_resultat', array('cherche_mot' => $cherche_mot)),"</b><p />\n";
$les_mots = join(',', $resultat);
echo "<B>",_T('info_plusieurs_mots_trouves', array('cherche_mot' => $cherche_mot)),"</B><BR>";
$result = spip_query("SELECT * FROM spip_mots WHERE id_mot IN ($les_mots) ORDER BY titre LIMIT 17");
echo "<UL>";
while ($row = spip_fetch_array($result)) {
$id_mot = $row['id_mot'];
$titre_mot = $row['titre'];
$type_mot = typo($row['type']);
$descriptif_mot = $row['descriptif'];
echo "<li><FONT FACE='Verdana,Arial,Sans,sans-serif' SIZE='2'><B><FONT SIZE='3'>",typo($titre_mot),"</FONT></B>";
if ($type_mot) echo " ($type_mot)";
echo " | <A href='", generer_url_ecrire($url_base, "$table_id=$id_objet&nouv_mot=$id_mot#mots"), "'>",_T('info_ajouter_mot'),"</A>";
if (strlen($descriptif_mot) > 1) {
echo "<br /><FONT SIZE=1>".propre(couper($descriptif_mot, 100))."</FONT>\n";
}
echo "</FONT></li>>\n";
}
echo "</UL>";
}
function afficher_mots_cles($flag_editable, $id_objet, $table, $table_id, $url_base, $visible)
{
global $spip_lang_rtl, $spip_lang, $spip_lang_right, $connect_statut, $connect_toutes_rubriques, $options;
$les_mots = array();
$id_groupes_vus = array();
$groupes_vus = array();
$result = spip_query("SELECT mots.id_mot, mots.titre, mots.descriptif, mots.id_groupe FROM spip_mots AS mots, spip_mots_$table AS lien WHERE lien.$table_id=$id_objet AND mots.id_mot=lien.id_mot ORDER BY mots.type, mots.titre");
if (spip_num_rows($result) > 0) {
echo "<div class='liste'>";
echo "<table width='100%' cellpadding='3' cellspacing='0' border='0' background=''>";
$tableau= array();
$cle = http_img_pack('petite-cle.gif', "", "width='23' height='12'");
$ret = generer_url_retour($url_base, "$table_id=$id_objet#mots");
while ($row = spip_fetch_array($result)) {
$id_mot = $row['id_mot'];
$titre_mot = $row['titre'];
$descriptif_mot = $row['descriptif'];
$id_groupe = $row['id_groupe'];
$groupes_vus[$id_groupe] = true;
$id_groupes_vus[] = $id_groupe;
$url = generer_url_ecrire('mots_edit', "id_mot=$id_mot&redirect=$ret");
$vals= array("<A href='$url'>$cle</A>");
$row_groupe = spip_fetch_array(spip_query("SELECT titre, unseul, obligatoire, minirezo, comite FROM spip_groupes_mots WHERE id_groupe = $id_groupe"));
// On recupere le typo_mot ici, et non dans le mot-cle lui-meme; sinon bug avec arabe
$type_mot = typo($row_groupe['titre']);
$flag_groupe = (($connect_statut == '1comite' AND $row_groupe['comite'] == 'oui') OR ($connect_statut == '0minirezo' AND $row_groupe['minirezo'] == 'oui'));
// Changer
if (($row_groupe['unseul'] == "oui") AND ($flag_editable AND $flag_groupe)) {
$s = generer_url_post_ecrire($url_base,"$table_id=$id_objet", '', "#mots") .
"<select name='nouv_mot' onChange=\"setvisibility('valider_groupe_$id_groupe', 'visible');\" CLASS='fondl' STYLE='font-size:10px; width:90px;'>";
$result_autres_mots = spip_query("SELECT id_mot, titre FROM spip_mots WHERE id_groupe = $id_groupe ORDER by titre");
while ($row_autres = spip_fetch_array($result_autres_mots)) {
$le_mot = $row_autres['id_mot'];
$le_titre_mot = supprimer_tags(typo($row_autres['titre']));
if ($le_mot == $id_mot) $selected = "SELECTED";
else $selected = "";
$s .= "<option value='$le_mot' $selected> $le_titre_mot</option>";
}
$s .= "</select>".
"<input type='hidden' name='supp_mot' VALUE='$id_mot' />".
"<span class='visible_au_chargement' id='valider_groupe_$id_groupe'>".
" <input type='submit' value='"._T('bouton_changer')."' CLASS='fondo' style='font-size: 10px';>".
"</span>".
"</form>";
} else {
$s = "<A href='$url'>".typo($titre_mot)."</A>";
}
$vals[] = $s;
if ($connect_statut == '0minirezo' AND $connect_toutes_rubriques)
$vals[]= "<a href='" . generer_url_ecrire("mots_type","id_groupe=$id_groupe") . "'>$type_mot</a>";
else $vals[] = $type_mot;
if ($flag_editable){
if ($flag_groupe)
$s = "<A href='" . generer_url_ecrire($url_base, "$table_id=$id_objet&supp_mot=$id_mot#mots") . "'>"._T('info_retirer_mot')." " . http_img_pack('croix-rouge.gif', "X", "width='7' height='7' align='middle'") ."</A>";
else $s = " ";
$vals[] = $s;
} else $vals[]= "";
$tableau[] = $vals;
$les_mots[] = $id_mot;
}
$largeurs = array('25', '', '', '');
$styles = array('arial11', 'arial2', 'arial2', 'arial1');
echo afficher_liste($largeurs, $tableau, $styles);
echo "</table></div>";
}
if ($les_mots) {
$nombre_mots_associes = count($les_mots);
$les_mots = join($les_mots, ",");
} else {
$les_mots = "0";
$nombre_mots_associes = 0;
}
//
// Afficher le formulaire d'ajout de mots-cles
//
if ($flag_editable) {
if ($id_groupes_vus) $id_groupes_vus = join($id_groupes_vus, ",");
else $id_groupes_vus = "0";
$nb_groupes = spip_num_rows(spip_query("SELECT * FROM spip_groupes_mots WHERE $table = 'oui' AND ".substr($connect_statut,1)." = 'oui' AND obligatoire = 'oui' AND id_groupe NOT IN ($id_groupes_vus)"));
if ($visible)
echo debut_block_visible("lesmots");
else if ($nb_groupes > 0) {
echo debut_block_visible("lesmots");
// vilain hack pour redresser un triangle
$couche_a_redresser = $GLOBALS['numero_block']['lesmots'];
if ($GLOBALS['browser_layer']) echo http_script("
triangle = findObj('triangle' + $couche_a_redresser);
if (triangle) triangle.src = '" . _DIR_IMG_PACK . "deplierbas$spip_lang_rtl.gif';");
}
else
echo debut_block_invisible("lesmots");
if ($nombre_mots_associes > 3) {
echo "<div align='right' class='arial1'>";
echo "<a href='", generer_url_ecrire($url_base, "$table_id=$id_objet&supp_mot=-1#mots"), "'>",_T('info_retirer_mots'),"</a>";
echo "</div><br />\n";
}
// il faudrait rajouter STYLE='margin:1px;' qq part
$form_mot = generer_url_post_ecrire($url_base,"$table_id=$id_objet", '', "#mots");
if ($table == 'rubriques') $form_mot .= "<input type='hidden' name='id_rubrique' value='$id_objet' />";
echo "<table border='0' width='100%' style='text-align: $spip_lang_right'>";
$result_groupes = spip_query("SELECT id_groupe,unseul,obligatoire,titre, ".creer_objet_multi ("titre", $spip_lang)." FROM spip_groupes_mots WHERE $table = 'oui' AND ".substr($connect_statut,1)." = 'oui' AND (unseul != 'oui' OR (unseul = 'oui' AND id_groupe NOT IN ($id_groupes_vus))) ORDER BY multi");
// Afficher un menu par groupe de mots
$message_ajouter_mot = "<span class='verdana1'><b>"._T('titre_ajouter_mot_cle')."</b></span> \n";
while ($row_groupes = spip_fetch_array($result_groupes)) {
if (menu_mots($row_groupes, $form_mot, $groupes_vus, $les_mots, $message_ajouter_mot))
$message_ajouter_mot = "";
}
if ($connect_statut == '0minirezo' AND $options == "avancees" AND $connect_toutes_rubriques) {
echo "<tr><td></td><td colspan='2'>";
echo "<div style='width: 200px;'>";
icone_horizontale(_T('icone_creer_mot_cle'), generer_url_ecrire("mots_edit","new=oui&ajouter_id_article=$id_objet&table=$table&table_id=$table_id&redirect=" . generer_url_retour($url_base, "$table_id=$id_objet")), "mot-cle-24.gif", "creer.gif");
echo "</div> ";
echo "</td></tr>";
}
echo "</table>";
echo fin_block();
}
}
function menu_mots($row, $form_mot, $groupes_vus, $les_mots, $message_ajouter_mot)
{
$id_groupe = $row['id_groupe'];
$titre_groupe = entites_html(textebrut(typo($row['titre'])));
$unseul = $row['unseul'];
$obligatoire = $row['obligatoire'];
$result = spip_query("SELECT id_mot, type, titre FROM spip_mots WHERE id_groupe =$id_groupe " . ($les_mots ? "AND id_mot NOT IN ($les_mots) " : '') . "ORDER BY type, titre");
$n = spip_num_rows($result);
if (!$n) return false;
// faudrait rendre ca validable quand meme
echo $form_mot, "\n<tr><td>", $message_ajouter_mot, "</td>\n<td>";
if ($n > 50) {
$jscript = "onfocus=\"setvisibility('valider_groupe_$id_groupe', 'visible'); if(!antifocus_mots[$id_groupe]){this.value='';antifocus_mots[$id_groupe]=true;}\"";
if ($obligatoire == "oui" AND !$groupes_vus[$id_groupe])
echo "<input type='text' name='cherche_mot' class='fondl' style='width: 180px; background-color:#E86519;' value=\"$titre_groupe\" size='20' $jscript>";
else if ($unseul == "oui")
echo "<input type='text' name='cherche_mot' class='fondl' style='width: 180px; background-color:#cccccc;' value=\"$titre_groupe\" size='20' $jscript>";
else
echo "<input type='text' name='cherche_mot' class='fondl' style='width: 180px; ' value=\"$titre_groupe\" size='20' $jscript>";
echo "</td>\n<td>";
echo "<input type='hidden' name='select_groupe' value='$id_groupe'>";
echo "<span class='visible_au_chargement' id='valider_groupe_$id_groupe'>";
echo " <input type='submit' value='"._T('bouton_chercher')."' class='fondo' style='font-size:10px'>";
echo "</span>";
} else {
if ($obligatoire == "oui" AND !$groupes_vus[$id_groupe])
echo "<SELECT NAME='nouv_mot' SIZE='1' onChange=\"setvisibility('valider_groupe_$id_groupe', 'visible');\" STYLE='width: 180px; background-color:#E86519;' CLASS='fondl'>";
else if ($unseul == "oui")
echo "<SELECT NAME='nouv_mot' SIZE='1' onChange=\"setvisibility('valider_groupe_$id_groupe', 'visible');\" STYLE='width: 180px; background-color:#cccccc;' CLASS='fondl'>";
else
echo "<SELECT NAME='nouv_mot' SIZE='1' onChange=\"setvisibility('valider_groupe_$id_groupe', 'visible');\" STYLE='width: 180px; ' CLASS='fondl'>";
echo "\n<option value='x' style='font-variant: small-caps;'>$titre_groupe</option>";
while($row = spip_fetch_array($result)) {
$id_mot = $row['id_mot'];
$titre_mot = $row['titre'];
$texte_option = entites_html(textebrut(typo($titre_mot)));
echo "\n<OPTION VALUE=\"$id_mot\">";
echo " ";
echo "$texte_option</option>";
}
echo "</SELECT>";
echo "</td>\n<td>";
echo "<span class='visible_au_chargement' id='valider_groupe_$id_groupe'>";
echo " <input type='submit' value='"._T('bouton_choisir')."' CLASS='fondo'>";
echo "</span>";
}
echo "</td></tr></form>\n";
return true;
}
//
// Calculer les nombres d'elements (articles, etc.) lies a chaque mot
//
function calculer_liens_mots()
{
if ($GLOBALS['connect_statut'] =="0minirezo") $aff_articles = "'prepa','prop','publie'";
else $aff_articles = "'prop','publie'";
$articles = array();
$result_articles = spip_query("SELECT COUNT(*) as cnt, lien.id_mot FROM spip_mots_articles AS lien, spip_articles AS article WHERE article.id_article=lien.id_article AND article.statut IN ($aff_articles) GROUP BY lien.id_mot");
while ($row = spip_fetch_array($result_articles)){
$articles[$row['id_mot']] = $row['cnt'];
}
$rubriques = array();
$result_rubriques = spip_query("SELECT COUNT(*) AS cnt, lien.id_mot FROM spip_mots_rubriques AS lien, spip_rubriques AS rubrique WHERE rubrique.id_rubrique=lien.id_rubrique GROUP BY lien.id_mot");
while ($row = spip_fetch_array($result_rubriques)){
$rubriques[$row['id_mot']] = $row['cnt'];
}
$breves = array();
$result_breves = spip_query("SELECT COUNT(*) AS cnt, lien.id_mot FROM spip_mots_breves AS lien, spip_breves AS breve WHERE breve.id_breve=lien.id_breve AND breve.statut IN ($aff_articles) GROUP BY lien.id_mot");
while ($row = spip_fetch_array($result_breves)){
$breves[$row['id_mot']] = $row['cnt'];
}
$syndic = array();
$result_syndic = spip_query("SELECT COUNT(*) AS cnt, lien.id_mot FROM spip_mots_syndic AS lien, spip_syndic AS syndic WHERE syndic.id_syndic=lien.id_syndic AND syndic.statut IN ($aff_articles) GROUP BY lien.id_mot");
while ($row = spip_fetch_array($result_syndic)){
$sites[$row['id_mot']] = $row['cnt'];
}
return array('articles' => $articles,
'breves' => $breves,
'rubriques' => $rubriques,
'syndic' => $syndic);
}
function afficher_groupe_mots($id_groupe) {
global $connect_id_auteur, $connect_statut;
global $spip_lang_right, $couleur_claire, $spip_lang;
$jjscript = array("fonction" => "afficher_groupe_mots",
"id_groupe" => $id_groupe);
$jjscript = (serialize($jjscript));
$hash = "0x".substr(md5($connect_id_auteur.$jjscript), 0, 16);
$tmp_var = substr($hash, 2, 6);
$javascript = "charger_id_url('" . generer_url_ecrire("ajax_page", "fonction=sql&id_ajax_fonc=::id_ajax_fonc::::deb::", true) . "','$tmp_var')";
$select = 'id_mot, titre, ' . creer_objet_multi ("titre", $spip_lang);
$from = 'spip_mots';
$where = "id_groupe=$id_groupe" ;
$cpt = spip_fetch_array(spip_query("SELECT COUNT(*) AS n FROM $from WHERE $where"));
if (! ($cpt = $cpt['n'])) return true ;
$occurrences = calculer_liens_mots();
$res_proch = spip_query("SELECT id_ajax_fonc FROM spip_ajax_fonc WHERE hash=$hash AND id_auteur=$connect_id_auteur ORDER BY id_ajax_fonc DESC LIMIT 1");
if ($row = spip_fetch_array($res_proch)) {
$id_ajax_fonc = $row["id_ajax_fonc"];
} else {
include_spip('base/abstract_sql');
$id_ajax_fonc = spip_abstract_insert("spip_ajax_fonc", "(id_auteur, variables, hash, date)", "($connect_id_auteur, " . spip_abstract_quote($jjscript) . ", $hash, NOW())");
}
$nb_aff = 1.5 * _TRANCHES;
$deb_aff = intval(_request('t_' .$tmp_var));
$limit = ($deb_aff >= 0 ? "$deb_aff, $nb_aff" : "99999");
if ($cpt > $nb_aff) {
$nb_aff = (_TRANCHES);
$tranches = afficher_tranches_requete($cpt, 3, $tmp_var, $javascript, $nb_aff);
} else $tranches = '';
if (!$deb_aff) echo "<div id='$tmp_var' style='position: relative;'>";
echo http_img_pack("searching.gif", "*", "style='visibility: hidden; position: absolute; $spip_lang_right: 0px; top: -20px;' id = 'img_$tmp_var'");
echo "<div class='liste'>";
echo "<table border=0 cellspacing=0 cellpadding=3 width=\"100%\">";
echo str_replace("::id_ajax_fonc::", "$id_ajax_fonc", $tranches);
$table = array();
$result = spip_query("SELECT $select FROM $from WHERE $where ORDER BY multi LIMIT $limit");
while ($row = spip_fetch_array($result)) {
$table[] = afficher_groupe_mots_boucle($row, $occurrences);
}
if ($connect_statut=="0minirezo") {
$largeurs = array('', 100, 130);
$styles = array('arial11', 'arial1', 'arial1');
}
else {
$largeurs = array('', 100);
$styles = array('arial11', 'arial1');
}
echo afficher_liste($largeurs, $table, $styles);
echo "</table>";
// fin_cadre_relief();
echo "</div>";
if (!$deb_aff) echo "</div>";
return false;
}
function afficher_groupe_mots_boucle($row, $occurrences)
{
global $connect_statut, $connect_toutes_rubriques;
$vals = '';
$id_mot = $row['id_mot'];
$titre_mot = $row['titre'];
if ($connect_statut == "0minirezo" OR $occurrences['articles'][$id_mot] > 0)
$s = "<a href='" .
generer_url_ecrire('mots_edit', "id_mot=$id_mot&redirect=" . generer_url_retour('mots_tous')) .
"' class='liste-mot'>".typo($titre_mot)."</a>";
else $s = typo($titre_mot);
$vals[] = $s;
$texte_lie = array();
$n = isset($occurrences['articles'][$id_mot]) ? $occurrences['articles'][$id_mot] : 0;
if ($n == 1)
$texte_lie[] = _T('info_1_article');
else if ($n > 1)
$texte_lie[] = $n." "._T('info_articles_02');
$n = isset($occurrences['breves'][$id_mot]) ? $occurrences['breves'][$id_mot] : 0;
if ($n == 1)
$texte_lie[] = _T('info_1_breve');
else if ($n > 1)
$texte_lie[] = $n." "._T('info_breves_03');
$n = isset($occurrences['sites'][$id_mot]) ? $occurrences['sites'][$id_mot] : 0;
if ($n == 1)
$texte_lie[] = _T('info_1_site');
else if ($n > 1)
$texte_lie[] = $n." "._T('info_sites');
$n = isset($occurrences['rubriques'][$id_mot]) ? $occurrences['rubriques'][$id_mot] : 0;
if ($n == 1)
$texte_lie[] = _T('info_une_rubrique_02');
else if ($n > 1)
$texte_lie[] = $n." "._T('info_rubriques_02');
$texte_lie = join($texte_lie,", ");
$vals[] = $texte_lie;
if ($connect_statut=="0minirezo" AND $connect_toutes_rubriques) {
$vals[] = "<div style='text-align:right;'><a href='" . generer_url_ecrire("mots_tous","conf_mot=$id_mot") . "'>"._T('info_supprimer_mot')." <img src='" . _DIR_IMG_PACK . "croix-rouge.gif' alt='X' width='7' height='7' align='bottom' /></a></div>";
}
return $vals;
}
?>