Filtre « titre_homogene »

Suite à une contrib. touvée sur ce site pour homogénéiser les titres des articles ou rubriques que j’ai installé et testé mais qui fonctionnait partiellement et buggait dans certains cas, j’ai dû demander à un ami de me concocter un nouveau filtre titre_homogene qui permet de :

-  couper mes titres à un certains nombres de caractères sans couper le titre en plein milieu d’un mot.
-  mettre les titres en minuscules avec la 1ère lettre en majuscule même s’ils ont été écrit en majuscule.

Il fonctionne parfaitement, contrairement à celui de la contrib originale : « Homogénéiser les titres »

Pourquoi un tel filtre ? :

J’utilise la 1.7.0 c’est pourquoi j’ai besoin d’un tel filtre car le filtre couper ne fonctionne pas bien sur cette version.

Le code

Voici le code à ajouter dans votre fichier mes_fonctions.php3.

/*
 *   +----------------------------------+
 *    Nom du Filtre : titre_homogene   
 *   +----------------------------------+
 *    Date : mercredi 31 juillet 2004
 *    Auteur :  Paul S.+ Lilian B. 
 *    Mail : killer.27 AT laposte POINT net
 *   +-------------------------------------+
 *    Fonctions de ce filtre :
 *   
 *    - limite la longueur des titres à 20 caractères,
 *    - ne coupe pas les titres en plein milieu d'un mot 
 *    - force les titres écrits en majuscules en
 *      minuscules et 
 *    - met la 1ère lettre  du titre en  majuscule
 *   +-------------------------------------+
 * Pour toute suggestion, remarque, proposition d'ajout
 * reportez-vous au forum de l'article :
 * http://www.spip-contrib.net/article.php3?id_article=640
 */

//début filtre titre_homogène

function titre_homogene($titre) {
  $limite=20;
  $titre = strtolower($titre);
  $titre = ucfirst($titre);
  
  $pos = strrpos($titre, " ");
  if ($pos === false)
  {
  	if (strlen($titre) > $limite)
	{
	 $titre = substr($titre, 0, $limite);
	 return $titre." ...";
	}
	else return $titre;
  }
  else
  {	
   	if (strlen($titre) <= $limite) return $titre;  
   	else 
	 {
	 $titre = substr($titre, 0, $limite);
	 $pos = strrpos($titre, " ");
	  if ($pos === false)
	  {
	  return $titre." ...";
	  }
	  else
	  {
	  return substr($titre, 0,$pos)." ...";
	  }
	 }
   }
}
//fin filtre titre_homogène

Quelques explications

Dans le code ci-dessus :

$limite=20 ; détermine à combien de caractères, il faut couper le titre. Modifier 20 par le nombres de caractères souhaités.

Si les points de suspensions " ..." à la fin du titre ne vous plaisent pas, vous pouvez les modifier entre les guillemets dans le code ci-dessus aux 3 endroits.

Ce filtre fait donc bien 5 choses :

-  limite la longueur des titres à 20 caractères,
-  ne coupe pas les titres en plein milieu d’un mot,
-  force les titres écrits en majuscules en
minuscules et
-  met la 1re lettre du titre en majuscule,
-  coupe arbitrairement le titre si le premier mot dépasse la taille souhaité (par exemple Mon_titre_Spip_à_rallonge devient Mon_titre_Spip_à_ral,).

Comment utiliser ce filtre ?

Comme tous les filtres : (#TITRE.

Pour le filtre « titre_homogene », ce sera (#TITRE.

Où écrire ce filtre ?

SPIP met à votre disposition un fichier mes_fonctions.php3, vide à l’origine et destiné à recevoir tous vos filtres.

Si votre fichier est vide, recopier les balises ci-dessous et mettez le code ci-dessus entre ces balises :

<?php

Insérez ici le code

?>

Les admins de ce site ne conseille pas d’utiliser ce script, ils préférent que vous formiez vos rédacteurs à écrire des titres courts, ce que je comprend. Par contre, cette contrib est utile quand la formation de nombreux rédacteurs n’est pas possible.

De plus si vous utilisez la dernière version de spip 1.7.2 dont le filtre couper fonctionne bien mieux que celui de la 1.7.0, cette contrib ne vous concerne pas.

Discussion

3 discussions

  • 4

    Je crois avoir trouvé plus simple pour tronquer proprement les objets ( TITRE, TEXTE, etc...) de SPIP :

    function couperclean($chaine,$limite='30',$separateur=' ',$ext=' ...') {
     
    	$position=strlen($chaine);
    	$tail='';
    	while ($position>$limite) {
    		$position=strrpos($chaine,$separateur);
    		$chaine=substr($chaine,0,$position);
    		$tail=$ext;
    	}
    return $chaine.$tail;
    }

    A placer dans « mes_fonctions.php » et à appeler avec :

    [(#TITRE|couperclean)]

    Par défaut, la chaine est tronquée au dernier ESPACE avant le 30e caractère et se voit ajouter l’extension « ... » à la fin. Vous pouvez bien sûr modifier ce comportement de manière générique en ajustant les paramètres par défaut déclaré en entrée de la fonction ou encore unitairement en spécifiant, dans vos squelettes, chacun des paramètres de la façon suivante ( depuis SPIP 1.5) :

    [(#TITRE|couperclean{18,'/',' > lire la suite ...'})]

    afin de tronquer la chaine au dernier SLASH avant le 18e caractère et lui ajouter l’extension « > lire la suite ... ».

    A noter que :
    -  l’extension n’est ajoutée que si l’objet est effectivement tronqué.
    -  si le séparateur ne figure pas dans la limite de la chaine, seule l’extension est retournée.
    -  J’ai des erreurs PHP si l’extension contient des parenthèses.

    Retour d’info bienvenu !

    • Je viens de modifier la fonction après m’être rendu compte que l’utilisation de ce filtre sur des textes assez long pouvait prendre un peu de temps (boucle While). Je prédécoupe donc l’objet à la taille maximum et recherche le prochain séparateur à l’aide d’un simple « if ». La fonction devient alors :

      function couperclean($chaine,$limite='30',$separateur=' ',$ext=' ...') {
      	$chaine=substr($chaine,0,$limite);
      	$position=strlen($chaine)+1;
      	$tail='';
      	if ($position>$limite) {
      		$position=strrpos($chaine,$separateur);
      		$chaine=substr($chaine,0,$position);
      		$tail=$ext;
      	}
      	return $chaine.$tail;
      }

      Oui, ca fait une ligne de plus ...

    • Personnellement j’ai du utiliser un filtre pour couper les titres trop long.

      Dans le titre, je mets un caractére séparateur ( | par exemple)

      Ensuite j’applique le filtre couperclean cité plus haut (en simplifié)
      encore plus simple

      function couperclean($chaine,$separateur=’|’,$ext=’ ...’)
      $position=strrpos($chaine,$separateur) ;
      $chaine=substr($chaine,0,$position) ;
      $tail=$ext ;

      return $chaine.$tail ;

      Et pour afficher les titres

      function affclean($chaine,$separateur=’|’)
      $chaine = str_replace($separateur,« »,$chaine) ;

      return $chaine ;

      Mumuri

    • function couperclean($chaine,$separateur=' ',$ext=' ...') {
        $position=strrpos($chaine,$separateur);
      if ($position !== false) {
      
             $chaine=substr($chaine,0,$position);
             $tail=$ext;
       }
      
      return $chaine.$tail;
      }

      function affclean($chaine,$separateur="|")
      {
       $chaine = str_replace($separateur,"",$chaine) ;
      return $chaine ;
      }

      excusez moi pour la mise en page et la petite erreur dans le code

    • Bon encore une amélioration, j’avais les titres suivant, et je voulais les simplifier

       Quel budget pour démarrer ? -> Budget pour démarrer ? 
      Soyez clair et précis sur vos ordres de Bourse ->  Vos ordres de Bourse
      Comment passer ses ordres ? -> Passer ses ordres ?
      Quelques pièges à éviter quand on démarre -> Pièges à éviter

      Pour cela j’ai rajouté des caractéres de séparation « | »

      Quelques |pièges à éviter| quand on démarre 
      Quel |budget pour démarrer ?|
      Soyez clair et précis sur |vos ordres de Bourse|
      Comment |passer ses ordres| ?
      Quelques |pièges à éviter| quand on démarre

      Ensuite, dans mes_fonctions.php3 j’ai rajouté les fonctions suivantes

      // Nom : couperClean
      // Fonction : avoir des titres raccourcis manuellement
      // auteur : Mumuri
      function couperclean($chaine,$separateur=' ',$ext=' ...') {
      
        $tailleChaine = strlen($chaine);
        $positionFin=strrpos($chaine,$separateur);
        if ( $positionFin === false) {$positionFin= $tailleChaine;   }
      
        $positionDeb = strpos($chaine,$separateur);
        if ( $positionDeb === false || $positionDeb == $positionFin)
        {
            $positionDeb=0;
        }
        else
        {
            $positionDeb++;
        }
      
        if ($positionFin !=$tailleChaine || $positionDeb !=0) // Si on doit couper ...
        {   // ... on coupe
            $chaine=ucfirst(substr($chaine,$positionDeb,$positionFin-$positionDeb));
        }
      
        $tail=$ext;
      
      return $chaine.$tail;
      }
      
      // Nom :affClean
      // Fonction : filtrer un caractére dans le titre
      // auteur : Mumuri
      function affclean($chaine,$separateur="|")
      {
       $chaine = str_replace($separateur,"",$chaine) ;
      return $chaine ;
      }

      Ensuite dans le squelette du menu pour couper les titres, j’ai mis
      [(#TITRE|supprimer_numero|couperclean{'|',''})]

      et pour ne pas afficher les caractéres de séparation, partout ou il y en avait
      [<h2><strong>&gt;&gt;</strong>(#TITRE|supprimer_numero|affclean{'|'})</h2>]

      et ne pas oublier la balise « titre »
      <title>[(#TITRE|supprimer_numero|affclean{'|'})]</title>

      et le plan du site
      <li><a href="#URL_ARTICLE">[(#TITRE|supprimer_numero|affclean{'|'})]</a></li>

      Voila (peut être que j’ai oublié certains endroits pour les titres à afficher )

      A plus

    Répondre à ce message

  • 1

    On peut aussi obtenir le même résultat par feuilles de styles :

    h1 { text-transform: lowercase; }
    h1:first-letter { text-transform: capitalize; }
    • Paul Sanches

      As-tu lu la contrib et son usage ? ce que tu dis n’est pas faux mais est innaproprié pour cette contrib.

    Répondre à ce message

  • 2

    La contrib, à laquelle fait 2 fois référence l’auteur pour dire qu’elle ne fonctionne pas, avait été faite sur un site sous SPIP 1.4. Le filtre « couper » n’existait alors pas et cette contrib ne prenait pas en compte les balises HTML, parce que c’est rare que les titres en comprennent. Malgré tout le filtre fonctionne depuis des années sans problème sur ce site.

    • Ok je comprend mieux pourquoi cela ne fonctionnait pas pour moi, je m’excuse alors pour avoir critiqué cette contrib. Je vais essayé de faire modifier le texte de la contrib. par un admin.

      Merci.

    • salut, étant un peu responsable de la publication de cet contrib j’attends vos remarques (dans l’espace privé) afin de remanier la contrib si nécessaire. (ps : ça ne se voit pas encore mais on va ajouter les liens de traductions ainsi que des liens « article de référence » pour ces contribs qui ont plusieurs versions)

    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