Avec l’introduction des fonctions avant_propre()
et apres_propre()
dans ecrire/inc_texte.php3
(depuis la version 1.7.1), on peut maintenant ajouter de nouveaux raccourcis sans plus avoir besoin de modifier le source de spip [1].
Soient les raccourcis suivants :
{1{ |
Ouverture d’un intertitre de 1er niveau (synonyme de {{{ ) [2] |
}1} |
Fermeture d’un intertitre de 1er niveau (synonyme de }}}) |
{2{ |
Ouverture d’un intertitre de 2e niveau |
}2} |
Fermeture d’un intertitre de 2e niveau |
{3{ |
Ouverture d’un intertitre de 3e niveau |
}3} |
Fermeture d’un intertitre de 3e niveau |
[*texte*] |
Texte en petites majuscules (small-caps) [3] |
[^texte^] |
Texte en exposant |
--> |
Flèche à droite (→) |
<-- |
Flèche à gauche (←) |
<--> |
Flèche bilatérale (↔) |
Nous mettons en oeuvre leur utilisation en trois étapes :
1°- Configurer les variables de personnalisation [4] en insérant les lignes suivantes dans le fichier mes_fonctions.php3
, à créer si nécessaire :
# On reprend les deux variables de personnalisation déjà existantes :
$GLOBALS['debut_intertitre'] = '<h3 class="monstyle">';
$GLOBALS['fin_intertitre'] = '</h3>';
# Et on y ajoute quatre nouvelles pour les intertitre :
$GLOBALS['debut_intertitre_2'] = '<h4 class="monstyle">';
$GLOBALS['fin_intertitre_2'] = '</h4>';
$GLOBALS['debut_intertitre_3'] = '<h5 class="monstyle">';
$GLOBALS['fin_intertitre_3'] = '</h5>';
On ajoute également les variables suivantes dans le fichier ecrire/mes_options.php3
, à créer si nécessaire :
# Variables de personnalisation pour les petites majucules:
$GLOBALS['debut_smallcaps'] = '<span style="font-variant: small-caps">';
$GLOBALS['fin_smallcaps'] = '</span>';
# Variables de personnalisation pour le texte en exposant
$GLOBALS['debut_exposant'] = '<sup class="spip">';
$GLOBALS['fin_exposant'] = '</sup>';
Vous pouvez bien sûr adapter ces variables, par exemple remplacer <span style="font-variant: small-caps">
par <span style="nom">
(en définissant la classe nom
dans votre feuille de style comme devant afficher les petites majucules).
2°- Ne pas oublier de configurer la feuille de style du site pour tenir compte de ces modifications (en fonction des variables de personnalisation que vous aurez choisies).
3°- Ajouter les fonctions suivantes dans le fichier ecrire/mes_options.php3
[5] :
function avant_typo($texte) {
$chercher_raccourcis = array(
/* 3 */ "/<-->/",
/* 4 */ "/-->/",
/* 5 */ "/<--/");
$remplacer_raccourcis = array(
/* 3 */ "↔",
/* 4 */ "→",
/* 5 */ "←");
return preg_replace($chercher_raccourcis, $remplacer_raccourcis, $texte);
}
function avant_propre($texte) {
$chercher_raccourcis = array(
# /* 1 */ "/\{0\{/",
# /* 2 */ "/\}0\}/",
/* 3 */ "/\{1\{/",
/* 4 */ "/\}1\}/",
/* 5 */ "/\{2\{/",
/* 6 */ "/\}2\}/",
/* 7 */ "/\{3\{/",
/* 8 */ "/\}3\}/",
/* 9 */ "/\[\*/",
/* 10 */ "/\*\]/",
/* 11 */ "/\[\^/",
/* 12 */ "/\^\]/");
$remplacer_raccourcis = array(
# /* 1 */ "<@@SPIP_debut_intertitre_0@@>",
# /* 2 */ "<@@SPIP_fin_intertitre_0@@>",
/* 3 */ "<@@SPIP_debut_intertitre@@>",
/* 4 */ "<@@SPIP_fin_intertitre@@>",
/* 5 */ "<@@SPIP_debut_intertitre_2@@>",
/* 6 */ "<@@SPIP_fin_intertitre_2@@>",
/* 7 */ "<@@SPIP_debut_intertitre_3@@>",
/* 8 */ "<@@SPIP_fin_intertitre_3@@>",
/* 9 */ "__SPIP_debut_smallcaps__",
/* 10 */ "__SPIP_fin_smallcaps__",
/* 11 */ "__SPIP_debut_exposant__",
/* 12 */ "__SPIP_fin_exposant__");
return preg_replace($chercher_raccourcis, $remplacer_raccourcis, $texte);
}
function apres_propre($texte) {
/*
# Intertitre -1 (intertitre de niveau supérieur à l'intertitre usuel de spip)
global $debut_intertitre_0, $fin_intertitre_0;
tester_variable('debut_intertitre_0', "\n<h2 class=\"spip\">");
tester_variable('fin_intertitre_0', "</h2>");
$texte = ereg_replace('(<p class="spip">)?[[:space:]]*<@@SPIP_debut_intertitre_0@@>', $debut_intertitre_0, $texte);
$texte = ereg_replace('<@@SPIP_fin_intertitre_0@@>[[:space:]]*(</p>)?', $fin_intertitre_0, $texte);
*/
# Intertitre de deuxième niveau
global $debut_intertitre_2, $fin_intertitre_2;
tester_variable('debut_intertitre_2', "\n<h4 class=\"spip\">");
tester_variable('fin_intertitre_2', "</h4>");
$texte = ereg_replace('(<p class="spip">)?[[:space:]]*<@@SPIP_debut_intertitre_2@@>', $debut_intertitre_2, $texte);
$texte = ereg_replace('<@@SPIP_fin_intertitre_2@@>[[:space:]]*(</p>)?', $fin_intertitre_2, $texte);
# Intertitre de troisième niveau
global $debut_intertitre_3, $fin_intertitre_3;
tester_variable('debut_intertitre_3', "\n<h5 class=\"spip\">");
tester_variable('fin_intertitre_3', "</h5>");
$texte = ereg_replace('(<p class="spip">)?[[:space:]]*<@@SPIP_debut_intertitre_3@@>', $debut_intertitre_3, $texte);
$texte = ereg_replace('<@@SPIP_fin_intertitre_3@@>[[:space:]]*(</p>)?', $fin_intertitre_3, $texte);
# Traitement des petites majuscules
global $fin_smallcaps, $debut_smallcaps;
tester_variable('debut_smallcaps', '<span style="font-variant: small-caps">');
tester_variable('fin_smallcaps', '</span>');
$texte = str_replace('__SPIP_debut_smallcaps__', $debut_smallcaps, $texte);
$texte = str_replace('__SPIP_fin_smallcaps__', $fin_smallcaps, $texte);
# Traitement des exposants
global $fin_exposant, $debut_exposant;
tester_variable('debut_exposant', '<sup class="spip">');
tester_variable('fin_exposant', '</sup>');
$texte = str_replace('__SPIP_debut_exposant__', $debut_exposant, $texte);
$texte = str_replace('__SPIP_fin_exposant__', $fin_exposant, $texte);
global $activer_antispam;
if($activer_antispam && function_exists('anti_spam'))
return anti_spam($texte);
else
return $texte;
}
#
# Fonctions anti-spam
#
function crypter ($texte) {
include_ecrire ("inc_acces.php3");
$masque = creer_pass_aleatoire(3);
$texte = ereg_replace("@", "_(".$masque.")_", $texte);
$s="";
for ($i=0;$i<strlen($texte);$i++)
$s .= "&#".ord($texte{$i}).";";
return $s;
}
# Autre possibilité: simplement utiliser la fonction antispam native de spip
# function crypter ($texte) {
# return antispam($texte);
#}
# Attention PHP 4.05 ou supérieur est nécessaire pour la fonction preg-replace-callback
# Voir http://be2.php.net/manual/fr/function.preg-replace-callback.php
function anti_spam ($texte) {
return preg_replace_callback('|(mailto:)?[-\w.]{2,}@[-\w.]{2,}|',
create_function('$match', 'return crypter($match[0]);'),
$texte);
}
4°- Filtre anti-spam générique. Dernière chose à faire : activer, si vous le souhaitez, le filtre anti-spam. Avec la fonction de cryptage proposé ici (que vous pouvez changer très simplement), dans tout lien vers une adresse mail présente dans votre site, l’arobase sera transformé en chaîne aléatoire et le mail sera chiffré. Pour activer cette fonction, il vous suffit d’ajouter la ligne suivante dans votre fichier ecrire/mes_options.php3
:
$activer_antispam = true;
Et voilà, en principe, tout doit fonctionner. Tout ce que vous devez placer dans votre fichier ecrire/mes_options.php3
se trouve dans ce fichier :
Si des gens accrochent à cette contrib et qu’ils ont envie de poursuivre, ce serait bien de modifier la barre d’outils pour qu’elle intègre ces nouveaux raccourcis.
Discussions par date d’activité
18 discussions
Très bonne contrib. Elle fonctionne sans problème chez moi.
J’aurais par contre besoin d’un coup de main pour pouvoir utiliser deux fonctions différentes de cryptage : une pour le texte et une pour l’action (href).
Je ne suis pas très doué avec les expression régulières.
Est-ce envisageable d’effectuer deux preg_replace_callback en cascade ou y a-t-il une façon plus élégante ?
En gros j’ai besoin d’utiliser une fonction crypter_texte($texte) et une crypter_action($action). La première avec du texte moi@ici.com ne contenant pas de mailto: au début et la deuxième avec du texte mailto:moi@ici.com.
Merci d’avance
Merci
Euh, je vois pas exactement l’utilité, mais tu peux sans doute remplacer la fonction anti_spam par quelque chose comme ceci :
où les deux fonctions de cryptage s’appelle crypter1 et crypter2.
Moi non plus ;-)
Merci pour ton aide, c’est OK ça marche.
Le but était (il est atteint maintenant) de :
- Afficher le texte d’une adresse e-mail sous la forme : nom.prenom chez ici.fr
- Crypter le mailto du lien pour lui faire exécuter un bout de code javascript (pour pouvoir cliquer sur le lien et envoyer un mail)
Je l’ai implémenté sur mon site ça marche nickel
Salut,
Ben, moi, j’essaie et ça ne marche pas (sppip 1.8.1) Peux-tu me dire comment tu as fait ?
Merci.
Répondre à ce message
Je me trompe peut-être, ùais après un moment, j’ai voulu reprendre cette contrib (très au demeurant !) telle qu’elle et ça ne marchait pas. Il fallu que je rajoute dans ecrire/mes_options.php3 la fonction suivante :
Et là ça marche...
J’ai faux docteur ??
Désolé pour les fôôôtes, il fallait lire : très bien au demeurant...
(J’utilise la 1.8pr1 sur le site concerné).
Répondre à ce message
Bonjour,
J’avais utilisé jusqu’à présent la contrib de Jacques Pyrat (1/8/2003) concernant les raccourcis v2 de SPIP.
Je sais qu’elles modifiaient le code de SPIP (shame on me), et maintenant, ce n’est plus nécessaire.
Mais, elles intégraient d’autres raccourcis intéressants :
- aligner le texte à gauche, droite ou au centre.
- encadrer du texte
Il me semble que ces raccourcis pourraient enrichir cette contrib qui est très intéressante.
Merci
Voici le code à remplacer pour retrouver ces raccourcis :
Raccourcis désormais disponibles
Le style pour les encadrements
Répondre à ce message
Bonjour,
Je viens d’installer cette fonction très intéressante, tout marche (petites capitales, exposant, tiret quadratin)... sauf les niveaux d’intertitres. J’ai installé, parallèlement, la fonction qui permet de découper les articles en pages.
Celle-ci implique d’écrire la balise #TEXTE avec un astérisque : #TEXTE*|decouper_en_page|propre.
Existe-t-il une incompatibilité entre les deux fonctions ?
Merci.
Aucune idée. J’ai pas testé (par contre, je compte intégrer une fonction similaire générant une table des matières dans la prochaine version de cette contrib, que je publierai dès que la 1.8 définitive sera publiée).
Tu utilises quelle version de spip ?
Répondre à ce message
Est-il prevu une mise à jour de cet article pour la 1.8 et son système de plugin ?
Oui, oui. Mais j’attends la sortie officielle de la 1.8 ou, au minimum, la publication de spécifications définitives pour les plugins (qui ne sont encore, à ma connaissance, qu’une fonctionnalité expérimentale susceptible d’être fortement modifiée) avant d’adapter le script.
Répondre à ce message
Merci pour cette petite merveille, et plutôt que chacun n’y aille avec sa mixture perso de racourcis typo, ne serait-il pas sympa de voir l’intégration de cette contrib directement dans la prochaine version de spip ?
En plus, elle peut permettre d’utiliser avec intelligence la contrib nommée « découper un article + sommaire » elle aussi d’une très grande utilité. On peut donc, grâce aux deux, avoir un vrai sommaire qui reprenne les seuls réels gros titres de l’article, tout en ayant la possibilité d’avoir d’autres titres divers dans l’article.
La prochaine version SPIP en est où des points d’entrée, quelque chose a été décidé ?
Bien à toi
Soÿ
P.S.
je pose la question suite à la lecture de ceci.
Bonsoir,
Tu peux toujours le demander sur les listes. S’il y a plein d’utilisateurs qui demandent certaines fonctionnalitéss (et s’ils argumentent bien), il se peut qu’elles soient implémentées par les core-dev (même si c’est absolument pas garanti).
Cela dit, je ne suis pas sûr que ça soit la tendance dans le développement de SPIP d’intégrer de nouvelles fonctionnalités dans la distribution officielle. An contraire, il est plutôt question pour le moment de viser un noyau le plus simple possible et d’organiser un maximum de trucs en plugins autour. Perso, je suis pas sûr que SPIP y ait plus à gagner qu’à perdre, mais ce n’est qu’un avis.
Cela dit, le cas des raccourcis typographiques est un peu particulier puisqu’il est surtout question d’une norme commune qu’il s’agit de préserver (plus même que l’implémentation de cette norme sur toutes les installations de spip). Si l’on se dirige vers des spip qui peuvent communiquer entre eux (et on y va clairement), y’a salement intérêt à ce qu’ils parlent tous le même langage. Donc, m’est avis qu’il serait au moins souhaitable de publier une norme de raccourcis pour toute une série de besoins standards (les intertitres de différents en font assurément partie, mais aussi, dans un moindre mesure, les exposants et les petites majuscules), histoire que les gens qui veulent les utiliser les implémentent de la même façon.
Cela dit, une idée que j’ai déjà vu passer à certains endroits et qui vaut peut-être la peine qu’on s’y penche serait d’abandonner la syntaxe des raccourcis spip pour créer une syntaxe commune avec d’autres outils du même type (wiki, cms,...), ce qui faciliterait grandement la vie aux utilisateurs de plusieurs de ces outils.
On se dirige clairement vers un mécanisme standardisé de plugins (et donc vers la disparition des points d’entrée qui sont ne sont qu’un petit hack sympa et qui n’auront plus de raison d’être). Mais quand ? Ca, je sais pas.
François
Répondre à ce message
Est-ce que cela fonctionne avec SPIP 1.8b2. Quand je m’essaie à ces scripts, j’ai le message suivant sur mes pages :
et à la ligne 26 j’ai ceci :
return ereg_remplace($chercher_raccourcis, $remplacer_raccourcis, $texte);
Non, effectivement, cette contrib est écrite pour une 1.7.2 et ne fonctionne pas sur la version cvs actuelle.
Le problème avec la 1.8 est qu’on ne sait pas encore si les points d’entrée seront conservés ou s’ils seront remplacés par un système plus général de plugin. Dans ces conditions, il n’est pas évident de publier des contribs pour la 1.8.
Mais dès qu’on saura quoi, je proposerai une version de cette contrib mise à jour pour la 1.8.
bonjour,
l’antispam seul ne tourne pas non plus sur la 1.8b2 ? hum ?
Les entrées (propre) dans inc_texte ne sont pas impléméntées ? hum ?
j’vais l’tester quand meme... :0)
j’ai essayé de déclarer la variable
dans ecrire/mes_options.php3
CA CARBURE UN MAX
?
En tout cas, c’est pas garanti.
C’est pas parce que le code est toujours dans la cvs qu’il y sera encore à la sortie de la 1.8. ARNO* a annoncé un système de plugins destinés à remplacer le mécanisme des points d’entrée (entre autres choses). Depuis, ça a beaucoup discuté sur les listes. Donc, en ce qui me concerne, j’ignore ce qu’il va advenir de tout ça. Par conséquent, je le signale ici. Point barre.
FS
Répondre à ce message
Faut-il rajouter
<?php [...] ?>
en début et fin de mes_options.php3 ? Parce que si je ne les mets pas le contenu de mes_options.php3 vient gentiment habiller mon code html. Sympa comme fond d’écran, très geek ;)Si je les mets, aucun effet sur mes arobases en regardant le code source et si j’appelle crypter sur ma balise #texte un charabia s’affiche.
Oui, il faut ajouter les
<?php ... ?>
(ou intégrer ce code dans un fichier mes_options.php3 existant).Pour l’antispam, l’as-tu bien activé comme indiqué dans l’article ?
Répondre à ce message
à priori ça ne marche pas chez moi :( j’ai tout fait comme il faut pourtant (charger directement le contenu de l’archive dans mon fichiers mes_options.php3 à moi).
je continue à chercher...
Bigre.
Peux-tu m’en dire un peu plus sur les éventuels messages d’erreurs que tu reçois ?
NB : cette contrib n’est pas (encore) adaptée à la version 1.8 de SPIP.
Répondre à ce message
Ces nouvelles possibilités m’intéressent beaucoup, mais je ne parviens pas à les installer. Oui, je sais, je suis loin d’être un expert !
Si j’ai bien compris l’article, les lignes pour les intertitres sont installés dans mes_fonctions.php3, celles pour les petites capitales dans mes_options.php3, les function dans ecrire/mes_options.php3 et l’activation de l’antispam à nouveaux dans mes_options.php3. On est donc en présence de trois fichiers différents.
Pourtant le fichier txt joint place tout, à l’exception des premiers $Globals d’intertitres, dans le fichier ecrire/mes_options.php3.
Je suis un peu perdu dans tout ça !...
Vous pourriez m’aider ?
Merci !
Le plus simple à faire, si tu as du mal à l’installation, c’est d’uploader le fichier fourni dans le répertoire
ecrire/
, sans oublier de le renommermes_fonctions.php3
(sans le.txt
). Le reste, c’est de l’habillage (les variables de personnalisation sont facultatives et tu verras bien s’il faut ou non modifier les styles en fonction de ta feuille de style).C’est bien ça.
Non,
mes_fonctions.php3
etecrire/mes_fonctions.php3
, c’est le même fichier (qui se place dansecrire/
).Non.
Bon amusement
FS
L’article dit pourtant que c’est dans ecrire/mes_options.php3... Dans lequel finalement ?
Mais nulle part il n’est question, dans l’article d’un fichier ecrire/mes_fonctions.php3...
Je dois être aveugle, mais il me semble bien que si...
Bref, tout est pour moi toujours aussi flou. Serait-il possible de corriger l’article ? (à moins que je me fourvoie totalement)
Merci !
Brièvement :
mes_fonctions.php3
etmes_options.php3
. Vu la proximité qui existe entre les deux, il arrive souvent que l’on écrive l’un en pensant l’autre. Ca m’est arrivé plusieurs fois, toutes mes excuses.mes_fonctions.php3
se place à la racine du site. Il contient des fonctions et variables qui n’affectent que le site public.mes_options.php3
se place dans la répertoire ecrire/. Il n’existe pas de fichiermes_options.php3
à la racine du site. Il contient des fonctions et variables qui affectent aussi bien le site public que l’interface privée. L’usage de la littérature spipienne le désigne aussi bien parmes_options.php3
que parecrire/mes_options.php3
.mes_options.php3
. Les modifications demes_fonctions.php3
sont facultatives (comme toutes les variables de personnalisation). Il suffit en principe d’uploader le fichiermes_options.php3
fourni en pièce jointe de la présente contrib pour faire fonctionner les nouvelles fonctionnalités.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 :
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.
Suivre les commentaires : |