Afficher le nombre d’articles en attente de validation

Ce filtre va vous permettre d’afficher n’importe où sur votre site le nombre d’articles en attente de publication. Il explique aussi comment insérer du code PHP dans vos pages et en gardant le résultat en cache.

Ce filtre va vous permettre d’afficher n’importe où sur votre site le nombre d’articles en attente de publication. Vous pouvez en voir un exemple sur http://www.noplay.net sous le titre Aidez nous.

Une implantation simple

On va commencer par mettre notre script directement dans le squelette.

Pour l’utiliser il suffit de mettre à l’emplacement où vous désirez afficher le nombre d’articles en attente, ce petit bout de code (dans le squelette):

<?php
$query = "SELECT COUNT(*) FROM spip_articles WHERE statut='prop'";
$r = spip_query($query);

$nb_prop = 0;
while ($row = spip_fetch_array($r)) {
$nb_prop++;
}

echo "Il y a ".$nb_prop." articles en attente de publication.";
?>

Il s’agit simplement de faire une requête MySQL qui va nous retourner la liste des articles dont le statut est prop(proposé). Puis on fait une boucle pour compter le nombre d’éléments trouvés.

Cette solution marche mais a un défaut, en effet la requête est effectuée à chaque affichage de la page (le code php n’est pas mis en cache). Oubliez donc cette solution, elle n’est là que pour que vous compreniez bien le problème.

Afficher le nombre d’articles proposés en filtre

C’est Fil qui m’a donné la solution, il suffit de ne pas mettre le code dans le squelette mais dans une fonction (un filtre) que l’on placera dans mes_fonctions.php3.

Notre fonction ressemblera donc à ceci:

/*
 *   +----------------------------------+
 *    Nom du Filtre :    list_prop                                     
 *   +----------------------------------+
 *    Date : vendredi 20 février 2004
 *    Auteur :  Noplay (noplay@noplay.net)                                     
 *   +-------------------------------------+
 *    Fonctions de ce filtre :
 *     Ce filtre sert à afficher le nombre
 *     d'articles en attente de validation.
 *   +-------------------------------------+ 
 *  
 * Pour toute suggestion, remarque, proposition d'ajout
 * reportez-vous au forum de l'article :
 * http://www.uzine.net/spip_contrib/article.php3?id_article=408
*/

function list_prop() {
  $query = "SELECT COUNT(*) FROM spip_articles WHERE statut='prop'";
  $r = spip_query($query);

  $nb_prop = 0;
  while ($row = spip_fetch_array($r)) {
    $nb_prop++;
  }
  if ($nb_prop) {
    return "Il y a <b>".$nb_prop."</b> articles en attente de publication.<br><br>";
  }
}

Vous remarquerez que j’ai remplacé le echo (qui sert à afficher à l’ecran) par un return. Cela signifie que l’on va retourner le texte à afficher au moteur de SPIP qui s’occupera de l’afficher là où il doit se trouver.

Mais il reste l’appel, en effet habituellement on utilise les filtres pour modifier un texte passé en paramètre. Il nous faut donc trouver un code SPIP qui ne prend pas de paramètre. Cette variable c’est #NOM_SITE_SPIP, il faudra donc à l’endroit où vous désirez afficher le nombre d’articles en attente mettre ce code :

[(#NOM_SITE_SPIP|list_prop)]

updated on 11 February 2007

Discussion

4 discussions

  • Une petit extension rapide du code (voir la correction que je viens de poster):

     function list_prop($texte) {
       $query = "SELECT COUNT(*) as count FROM spip_articles WHERE statut='prop'";
       if(is_numeric($texte)) {
             $query .= " AND id_rubrique=$texte";
       }
    ...

    permettrait de savoir combien d’article sont en attente dans la rubrique actuelle en faisant:

    (#ID_RUBRIQUE

    Reply to this message

  • 3

    Bonjour, est-ce que :

    SELECT COUNT( statut ) 
    FROM spip_articles
    WHERE statut = 'prop'

    n’est pas plus rapide ?!?

    • effectivement je vais proposer la modification

    • l’article a été mis à jour

    • ça colle plus, parce que le reste du code ne correspond pas à la requette. Il faut faire cela plutôt:

      function list_prop($texte) {
         $query = "SELECT COUNT(*) as count FROM spip_articles WHERE statut='prop'";
         $r = spip_query($query);
       
         if($nb_prop = spip_fetch_array($r)) 
               $nb_prop = $nb_prop['count'];
         else $nb_prop = 0;
         
         if ($nb_prop) {
           return "Il y a <b>".$nb_prop."</b> article(s) en attente de
       publication.<br><br>";
         } else
               return '';
       }

    Reply to this message

  • Nous l’utilisons.

    c’est sympa !

    Reply to this message

  • 2

    Bravo pour cette fonction bien pratique.

    Une petite suggestion de modification de la fin du code :
    pour éviter d’avoir une petite faute de grammaire quand il n’y a qu’un article :

    if ($nb_prop > 1)
    return “Il y a ”.$nb_prop.“ articles en attente de publication.

    ”;

    elseif ($nb_prop == 1)
    return “Il y a 1 article en attente de publication.

    ”;

    Par contre une petite demande aussi car je n’arrive pas à trouver la syntaxe correcte :
    comment faire un lien sur cette phrase (au niveau du mot article par exemple) vers la page ecrire/index.php3 ?

    Merci bcp

    Jérôme

    • Voila :D

      return "Il y a <a href=\"ecrire/index.php3\"><b>".$nb_prop."</b> articles</a> en attente de publication.<br><br>";
    • Franck

      Merci infiniment pour cette astuce bien sympathique pour nos sites.

      En contribution, pour synthétiser les deux commentaires qui précèdent, voici ma syntaxe qui, d’ailleurs, me semble plus directe que la proposition de jbreuzet...

      if ($nb_prop) {
      if ($nb_prop==1) return "Il y a <a href=\"ecrire/index.php3\"><b>1</b> article</a> en attente de publication";
      else return "Il y a <a href=\"ecrire/index.php3\"><b>".$nb_prop."</b> articles</a> en attente de publication.<br><br>";
        }

      Cheers !

    Reply to this message

Comment on this article

Who are you?
  • [Log in]

To show your avatar with your message, register it first on gravatar.com (free et painless) and don’t forget to indicate your Email addresse here.

Enter your comment here

This form accepts SPIP shortcuts {{bold}} {italic} -*list [text->url] <quote> <code> and HTML code <q> <del> <ins>. To create paragraphs, just leave empty lines.

Add a document

Follow the comments: RSS 2.0 | Atom