Une nouvelle balise : exemple avec #TRIMESTRE

Un exemple de création d’une balise #TRIMESTRE dans les boucles articles.

Cette contrib permet de créer, puis d’utiliser une nouvelle balise #TRIMESTRE, à la fois en tant que balise dans une boucle articles, mais aussi comme critère dans la boucle.

Il faut ajouter ces 3 fonctions dans le fichiers « mes_fonctions.php » [1].

1. Créer la fonction qui calcule le trimestre à partir d’une date

Le format choisi pour le trimestre est de la forme « annee - trimestre » de manière à pouvoir opérer des tris. Le calcul s’effectue à partir des fonctions date de SPIP :

function calculer_trimestre($la_date) {
  $la_date = normaliser_date($la_date);
  $le_mois = mois($la_date);
  $l_annee = annee($la_date);
  $le_trimestre = $l_annee.'-'.ceil ($le_mois/3);
  return $le_trimestre;
}

A noter : cette fonction peut aussi s’utiliser telle quelle en tant que filtre sur une date à la manière classique : [(#DATE|calculer_trimestre)].

2. Ajouter la nouvelle colonne (le nouveau champ) dans la boucle

Afin de « déclarer » la nouvelle colonne, il faut modifier la fonction boucle_ARTICLE [2] de la façon suivante :

function boucle_ARTICLE($id_boucle, &$boucles) {
  $boucle = &$boucles[$id_boucle];
  $id_table = $boucle->id_table;
  $boucle->select[] = "CONCAT(year(date), '-', quarter(date)) AS trimestre";
  $boucle->from[$id_table] = "spip_article";
  $mstatut = $id_table .'.statut';

  // Restreindre aux elements publies
  if (!$boucle->modificateur['criteres']['statut']) {
    if (!$GLOBALS['var_preview']) {
      $boucle->where[]= array("'='", "'$mstatut'", "'\"publie\"'");
      if ($GLOBALS['meta']["post_dates"] == 'non')
      $boucle->where[]= array("'<'", "'$id_table" . ".date'", "'NOW()'");
    }
    else $boucle->where[]= array("'IN'", "'$mstatut'", "'(\"publie\",\"prop\")'");
  }

  return calculer_boucle($id_boucle, $boucles); 

}

Cette modification peut s’apprécier en mode debug en cliquant sur « résultat » : on voit que la requête appelle un nouveau champ.

3. Créer la balise #TRIMESTRE qui retournera le trimestre

function balise_TRIMESTRE($p) {
  $date_evenement = champ_sql('date', $p);
  $p->code = "calculer_trimestre($date_evenement)";
  $p->interdire_scripts = false;
  return $p;	
}

Désormais il est possible dans une boucle ARTICLES d’utiliser un critère « trimestre », et d’afficher une balise #TRIMESTRE dans les squelettes.

Le débat

L’interêt de cette contrib réside plus sur la méthode pour se créer une nouvelle balise (boucle + balise), ou un nouveau champ virtuel, que dans l’obtention d’un trimestre à partir d’une date (que l’on obtient aussi facilement avec un petit filtre utilisant la fonction « quarter(date) » de MySQL).

L’interrogation est plutôt : qu’est-ce qui est mieux (pour un résultat équivalent et un boulot équivalent) ?
-  soit : filtre + critère => 2 fonctions dans mes_fonctions
-  soit : nouveau champ virtuel => idem, 2 fonctions de plus (boucle et balise)

Le débat est lancé

Notes

[1Nota : « mes_fonctions.php » est à créer, s’il n’existe pas, dans votre répertoire « squelettes ». C’est un fichier php il doit être ouvert et fermé par les balises <?php et ?>, avec rien avant et après

[2on peut appeler aussi la fonction boucle_ARTICLE_dist s’il s’agit d’ajouter la fonction en dehors d’un plugin

De la même manière il doit être possible de créer une nouvelle balise qui provienne d’une requête avec plein de join sur plusieurs tables...

Discussion

Une discussion

  • Salut à tous,

    Voici qq idées qui ont été évoquées en août et que je trouve utile de replacer ici, le débat n’est peut-être pas encore clos...

    La surcharge de la boucle ARTICLES est incompatible avec le plugin acces_restreint.

    Est-ce qu’on peut pas arriver au même résultat sans cette surcharge ?

    un simple filtre trimestre ?

    function trimestre($la_date) {
       $la_date = normaliser_date($la_date);
       $le_mois = mois($la_date);
       return ceil($le_mois/3);
    }

    à utiliser comme ceci : [(#DATE|trimestre)]

    ou même : [(#DATE|annee)]-[(#DATE|trimestre)]

    Ok pour le code de ta balise #TRIMESTRE :

    function balise_TRIMESTRE($p) {
       $date = champ_sql('date', $p);
       $p->code = "trimestre($date)";
       $p->interdire_scripts = false;
       return $p;   
    }

    Pour le critère d’une boucle, voici une solution :

    function critere_trimestre($idb, &$boucles, $crit) {
         $params = $crit->param;
         if (count($params) < 1)
               erreur_squelette(_T('zbug_info_erreur_squelette'), BOUCLE$idb : trimestre ?");
         $trimestre= array_shift($params);
         $trimestre = $trimestre[0]->texte;
         if (strpos($trimestre, '|')!=false) $op = "REGEXP \'$trimestre\'";
             $op = "REGEXP \'$trimestre\'";
             else $op = "= $trimestre";
         $boucle = &$boucles[$idb];
         $table = $boucle->id_table;
         $where = "quarter($table.date) $op";
         if ($crit->not) $where = "NOT($where)";
         $boucle->where[] = "'$where'";
    }

    Exemples :

         <BOUCLE_articles(ARTICLES) {trimestre 3}>
         ou : {trimestre 3|4}
         ou : {!trimestre 3}
         ou : {!trimestre 3|4}

    Mais tout ce binz peut-être aussi obtenu comme ceci :

         <BOUCLE_articles(ARTICLES) {quarter(date)=3}>
         ou : {quarter(date)==3|4}
         ou : {quarter(date)!=3}
         ou : {quarter(date)!==3|4}

    Répondre à ce message

Ajouter un commentaire

Avant de faire part d’un problème sur un plugin X, merci de lire ce qui suit :

  • Désactiver tous les plugins que vous ne voulez pas tester afin de vous assurer que le bug vient bien du plugin X. Cela vous évitera d’écrire sur le forum d’une contribution qui n’est finalement pas en cause.
  • Cherchez et notez les numéros de version de tout ce qui est en place au moment du test :
    • version de SPIP, en bas de la partie privée
    • version du plugin testé et des éventuels plugins nécessités
    • version de PHP (exec=info en partie privée)
    • version de MySQL / SQLite
  • Si votre problème concerne la partie publique de votre site, donnez une URL où le bug est visible, pour que les gens puissent voir par eux-mêmes.
  • En cas de page blanche, merci d’activer l’affichage des erreurs, et d’indiquer ensuite l’erreur qui apparaît.

Merci d’avance pour les personnes qui vous aideront !

Par ailleurs, n’oubliez pas que les contributeurs et contributrices ont une vie en dehors de SPIP.

Qui êtes-vous ?
[Se connecter]

Pour afficher votre trombine avec votre message, enregistrez-la d’abord sur gravatar.com (gratuit et indolore) et n’oubliez pas d’indiquer votre adresse e-mail ici.

Ajoutez votre commentaire ici

Ce champ accepte les raccourcis SPIP {{gras}} {italique} -*liste [texte->url] <quote> <code> et le code HTML <q> <del> <ins>. Pour créer des paragraphes, laissez simplement des lignes vides.

Ajouter un document

Suivre les commentaires : RSS 2.0 | Atom