SPIP - Contrib

[ar] [en] [es] [fr] [it]



Accueil du site > Documentation > Archives documentation > Bidouilles pour avant SPIP 1.9

TARGET manuel ou automatique, au choix... v1.0

lundi 8 septembre 2003, par Led. Dernier ajout lundi 8 septembre 2003


Cette fonction permet d’attribuer automatiquement ou manuellement une cible à un lien (fonction TARGET en HTML).


Le filtre s’utilise avec les balises #URL_SITE, #CHAPO, #TEXTE, #PS, #NOTES, #INTRODUCTION, #DESCRIPTIF et #BIO.

La syntaxe dans les squelettes doit être du type :
- <a href="[(#URL_SITE|cibles_liens)]">...</a>
- [(#TEXTE|cibles_liens)]
- [(#URL_SITE|cibles_liens)]
- ...

La syntaxe à l’édition doit être :
1. Pour le champ "URL" dans l’édition d’une brève ou le champ "Adresse du site" pour le référencement d’un site :
- #tag#URL
2. Pour le champ "Texte" dans l’édition d’une brève, les champs "Chapeau ", "Texte" et "Post-Scriptum" dans l’édition d’un article ou tous les champs "Description" :
- #tag#[texte->URL]
- #tag#[texte->n°d'article]
- #tag#[texte->rubxxx]
- #tag#[texte->brxxx]
#tag# doit avoir comme valeur #_blank#, #_self#, #_parent# ou #_top#.

L’insertion du TAG #_blank# automatiquement, lorsque qu’un lien pointe vers l’extérieur du site, est optionnelle. On peut la désactiver en insérant // devant la ligne (n°39) qui la gère ou modifier le #tag# par défaut par un des 3 autres.

Texte coller dans le fichiers "mes_fonction.php3" :

/* Filtre CIBLES_LIENS - 21 juillet 2003 - Par Led

  Permet d'attribuer automatiquement ou manuellement une cible à un liens
  (fonction TARGET en HTML).
  Le filtre s'utilise avec les balises #URL_SITE, #CHAPO, #TEXTE, #PS, #NOTES,
  #INTRODUCTION, #DESCRIPTIF et #BIO.

  SYNTAXE DANS LES SQUELETTES:
  <a href="[(#URL_SITE|cibles_liens)]">...</a>
  [(#TEXTE|cibles_liens)]
  [(#URL_SITE|cibles_liens)]
  ...

  SYNTAXE A L'EDITION:
  Pour le champ "URL" dans l'édition d'une brève
  ou le champ "Adresse du site" pour le référencement d'un site :
    - #tag#URL
  Pour le champ "Texte" dans l'édition d'une brève, les champs "Chapeau ",
  "Texte" et "Post-Scriptum" dans l'édition d'un article ou tous les champs
  "Description":
    - #tag#[texte->URL]
    - #tag#[texte->n°d'article]
    - #tag#[texte->rubxxx]
    - #tag#[texte->brxxx]
  Où #tag# doit avoir comme valeur #_blank#, #_self#, #_parent# ou #_top#.
*/

function cibles_liens($texte) {

   /* TRAITEMENT SUR LA BALISE #URL_SITE */

   /* OPTION: Insertion du TAG #_blank# si TAG non présent et si lien pointe
      vers l'extérieur
   */
   if ( substr($texte, 0, 7) == 'http://' or
        substr($texte, 0, 6) == 'ftp://' ) {

        /* Mettre // devant la ligne ci-dessous si option inutile */
        $texte = '#_blank#'.$texte;
        }

   /* Détection du TAG et réécriture du code HREF */
   if ( substr($texte, 0, 8) == '#_blank#' or
        substr($texte, 0, 7) == '#_self#' or
        substr($texte, 0, 9) == '#_parent#' or
        substr($texte, 0, 6) == '#_top#' ) {

       $texte = eregi_replace('#(.*)#([^>]*)', '\\2" target="\\1', $texte);
       }

   /* TRAITEMENT SUR LES AUTRES BALISES COMPATIBLES */
   else {

       /* DETECTION DU TAG ET REECRITURE DU CODE HREF */
       $texte = eregi_replace('#_blank#<a href="([^>]*)>', '<a href="\\1 target="_blank">', $texte);
       $texte = eregi_replace('#_self#<a href="([^>]*)>', '<a href="\\1 target="_self">', $texte);
       $texte = eregi_replace('#_parent#<a href="([^>]*)>', '<a href="\\1 target="_parent">', $texte);
       $texte = eregi_replace('#_top#<a href="([^>]*)>', '<a href="\\1 target="_top">', $texte);
       }

   return $texte;
}

J’ai testé cette fonction sur mon site Fan News sous tous les angles et je n’ai observé qu’un bug, qui n’en ai pas vraiment un en fait. Si on applique ce filtre sur le texte des forums et qu’une URL non formatée (tous les forumeurs ne sont pas des SPIPeurs) est présente, elle apparaitra comme ça :
http://www.url.com" target="_blank
Je réfléchi maintenant à un autre filtre du même style mais "spécial forum"...
Si toutefois vous rencontrez un autre bug, n’hésitez pas à le signaler... ;-)

Led

Documents joints

  • cibles_liens_v1.0.txt cibles_liens_v1.0.txt (texte - 2.2 ko)

    Fichier texte contenant la fonction cibles_liens à coller dans le fichier "mes_fonctions.php".


Répondre à cet article



Suivre la vie du site RSS 2.0 | Plan du site | Espace privé | Charte et vie SPIP-Contrib | SPIP | L'autre.net