Préambule
SPIP propose nativement #FORMULAIRE_ECRIRE_AUTEUR
qui permet d’écrire à un auteur précis. On peut donc l’utiliser pour la page de contact du site, en mettant le webmestre en auteur. Cette approche peut paraître limitée. Imaginons donc un formulaire entièrement configurable.
Ce formulaire remplace — et donc supprime — le plugin « Formulaire de contact configurable » avec lequel il a fusionné. Les utilisateurs migrants de l’un à l’autre devront donc reconfigurer le formulaire. Par ailleurs, et depuis la rédaction de cet article le plugin évolue, nous vous conseillons de lire également «Le formulaire de contact évolue».
Toutefois, il est désormais conseillé d’utiliser le plugin Formidable plus souple et encore maintenu.
Installation
Comme pour les autres plugins, vous devez télécharger le paquet ci-joint et placer son contenu dans votre dossier plugins/
.
Vous devez utiliser PHP 5 pour faire marcher le plugin Voyez avec votre hébergeur si ce n’est pas le cas par défaut. Surtout que PHP 4 n’est plus maintenu.
Ensuite il faut aller dans l’interface de gestion des plugins, l’activer et enfin cliquer sur l’icône d’outils pour le configurer. Au préalable vous devrez installer les plugins cfg, spip-bonux, et Jquery UI.
Alternativement, vous trouverez aussi ce plugin dans la liste d’installation automatique fournie par spip-contrib (il faut pour cela avoir un dossier plugins/auto
).
Utilisation
Pour afficher ce formulaire dans un squelette :
Appel classique :
#FORMULAIRE_CONTACT
Appel avec l’auteur 34 pré-selectionné :
#FORMULAIRE_CONTACT{34}
Appel AJAX (sans rechargement de la page) :
<div class="ajax">
#FORMULAIRE_CONTACT
</div>
Pour afficher ce formulaire dans un contenu :
Appel classique :
<formulaire|contact>
Appel avec l’auteur 34 pré-selectionné :
<formulaire|contact|auteur=34>
Appel AJAX (sans rechargement de la page):
<div class="ajax">
<formulaire|contact>
</div>
Configuration
Il y a trois principales choses à configurer :
- La liste des auteurs à qui le courrier pourra être envoyé
- La méthode de choix pour le visiteur
- Les éventuelles informations supplémentaires
On peut choisir l’ordre des informations supplémentaires par simple glisser-déplacer à la souris. L’ordre sera gardé en mémoire et repris alors sur le site public.

Personnaliser l’affichage des champs d’informations
Par défaut, le plugin affiche un champ texte basique pour chaque information supplémentaire demandée. Mais parfois, on veut personnaliser ces champs, par exemple pour restreindre des valeurs. Et bien c’est prévu !
Pour cela, il faut connaître l’identifiant du champ que l’on veut personnaliser. Il suffit de regarder dans le HTML l’attribut name
du champ. Sinon la liste complète des champs par défaut se trouve dans le fichier contact_options.php
.
Vous n’avez alors plus qu’à créer un fichier : /formulaires/contact_champ_*nomduchamp*.html
, dans votre dossier squelettes ou dans votre plugin.
Par exemple, si vous voulez mettre une liste déroulante pour restreindre les pays, il faut créer un fichier /formulaires/contact_champ_pays.html
, dans lequel vous pourrez mettre par exemple :
<li class="saisie_#ENV{name}[ (#ENV{name}|in_array{#ENV{obligatoires,#ARRAY}}|oui)obligatoire][ (#ENV*{erreurs}|table_valeur{#ENV{name}}|oui)erreur]">
<label for="info_#ENV{name}">
#ENV{titre}[ (#ENV{name}|in_array{#ENV{obligatoires,#ARRAY}}|oui)<strong><:info_obligatoire_02:></strong>]
</label>
[<span class="erreur_message">
(#ENV*{erreurs}|table_valeur{#ENV{name}})
</span>]
<select name="#ENV{name}" id="info_#ENV{name}">
<option
value="England"[
(#ENV{#ENV{name}}|=={England}|oui)selected="selected"]>
England
</option>
<option
value="France"[
(#ENV{#ENV{name}}|=={France}|oui)selected="selected"]>
France
</option>
</select>
</li>
Dans le fichier, #ENV{name}
correspondra à l’identifiant du champ, et #ENV{titre}
à son titre dans la langue courante. #ENV{#ENV{name}}
correspond donc à la valeur déjà tapée du champ en question.
Ajouter de nouveaux champs
Le plugin prévoit un point d’entrée qui permet, lorsqu’on s’y connecte, d’ajouter autant d’entrées que l’on veut.
Il faut tout d’abord s’inscrire dans le point d’entrée.
Soit dans un plugin
<pipeline>
<nom>contact_infos_supplementaires</nom>
<inclure>un_fichier.php</inclure>
</pipeline>
Soit dans le mes_options.php de votre site
$GLOBALS['spip_pipeline']['contact_infos_supplementaires'] .= '|montruc_contact_infos_supplementaires';
Ensuite dans la fonction qui s’est insérée dans le point d’entrée :
function montruc_contact_infos_supplementaires($champs){
// Le paramètre contient tous les champs par défaut avec :
// clé = le "name" du champ
// valeur = le titre du champ
$champs['nouveau_truc'] = 'Un titre';
// Si votre site est multilingue, il faut utiliser une chaine de langue
$champs['civilite'] = _T('une_chaine_de_langue_pour_civilite');
return $champs;
}
Et c’est tout.
Par défaut le champ sera une entrée de texte simple, et vous pouvez le personnaliser comme décrit dans le point précédent.
Discussions by date of activity
460 discussions
Bonjour,
merci pour le plugin, il est vraiment simple d’emploi.
J’ai toutefois une question :
comment envoyer directement le message sans passer par la phase de prévisualisation ?
Si quelqu’un a une idée, je suis preneur.
Merci
Nico
Salut, as tu trouvé une solution?
Ce n’est pas prévu par le plugin, ce n’est pas configurable. Mais il n’est plus maintenu (juste laissé en l’état), il est préférable d’utiliser le plugin Formidable (qui lui n’a pas de prévisu de base).
Reply to this message
gentes dames, damoiselles, gentilshommes et damoiseaux
l’option qui permettait d’afficher une case “Mademoiselle” viens de disparaître
c’est problématique sur les formulaires existants qui utilisent cette option
comment je fais?
Alors, j’ai testé.
Au temps pour moi, mea culpa et toussa : les messages sont enregistrés de manière brute en un seul champ texte dans la messagerie de SPIP.
Donc, la modification faite par toutati ne casse rien :
C’est donc techniquement parfait.
Reply to this message
Hello friends I have tried this plugin, I wanted to add Ajax to my form but still it’s not work I have added a div with ajax class but still not working If there is someone to help me please help
should it be possible to have a link?
Reply to this message
Bonjour,
Pensez-vous qu’il serait possible de définir un nouveau champ intégré au plugin sur le principe de l’infolettre - case à cocher avec texte personnalisé pour la RGPD afin d’être en conformité sans avoir à bidouiller les pages ?
Merci d’avance pour votre retour.
Cordialement
Jérôme
le plugin n’es plus maintenu, je vous invite à utiliser formidable, qui vous permettra de faire ceci (et bien plus !)
Reply to this message
Bonjour à tous !
Je souhaite juste ajouter un commentaire sur la doc.
J’ai souhaité ajouter un champ dans mon formulaire de contact. Le problème c’est que je ne savais pas ou cela s’ajoutait : directement dans le formulaire ou dans le paramétrage côté back-office ?
Du coup après un simple rafraichissement du cache de mon navigateur... mon nouveau champ est apparu dans le paramétrage (Back-office/interface d’administration). Je pense qu’il faudrait le préciser dans la documentation. Qu’en pensez-vous ?
heu, je ne comprend pas en quoi un rechargement a pu ajouter le champ. Tu as du faire quelque chose d’autres, et c’est ca qu’il faudrait ajouter à la doc ;-)
Merci pour ta réponse Maïeul !
le problème c’est qu’avec le code que j’ai ajouté hier (celui de la doc dans mes_options.php)... pas de nouveau champ que ce soit côté utilisateur et/ou côté administrateur... et ce matin en ouvrant mon navigateur et l’interface administrateur, le champ est apparu !
tu avais fait un recalcul du cache?
Oui j’ai essayé, en ajoutant &var_mode=recalcul, mais ça ne fonctionne pas. Du coup j’ai trouvé une solution.
Pour afficher mon champ, j’ai dû passer par l’interface admin > gestion des plugins > l’icône configuration (clé/marteau). Le champ s’ajoute correctement !
Si ça peut aider quelqu’un.
Ça s’ajoute dans un pipeline oui, donc il faut recalculer les pipelines en allant dans la page d’admin des plugins (seulement ça suffit).
Reply to this message
J’ai une question concernant les langues : sur la page ecrire/?exec=configurer_contact il y a un champ “Introduction”. Dans ce bloc de texte on insère du texte dans une seule langue. J’ai rempli en français, la langue par défaut.
Le formulaire est multilingue et s’adapte automatiquement en anglais quand on est sur des pages déclarées en anglais, sauf cet encart de texte qui reste en français en plein milieu d’une page en anglais.
Quelqu’un a une idée ?
Tu peux y mettre des balises
<multi>
comme dans la plupart des champs libres non ?Merci
je vais tenter :)
Reply to this message
J’ai mis l’abonnement à l’infolettre sur mon formulaire. J’utilise MailSubscribers pour gérer les abonnement à la newsletter. Lors de mes essais, l’abonnement ne se fait pas... Une piste ?
Merci d’avance.
Bonjour,
J’utilise aussi “Mailsubscribers” et j’ai le même problème de pouvoir gérer l’inscription aux infolettres depuis un formulaire “Contact avancé” (pas possibilité d’activer le choix des infolettres) ou “Formidables” (le choix des infolettres s’affiche dans ce dernier mais ne s’enregistre pas à la validation).
Je suis donc également preneur d’une solution !
Amicalement.
Il faudrait utiliser https://plugins.spip.net/formidable_mailsubscribers.html je pense
Merci, je vais voir ça, cette extension avait complètement échappé à mes recherches !
normal, elle est pas documenté.
Si cela marche, il faudrait contacter tcharllss je pense pour lui proposer de rédiger une doc.
Oui, je viens de l’installer, elle fonctionne et abonne correctement aux listes.
Amicalement.
super!
Est-ce que tu te sentirais de faire une doc (en ayant demandé préalablement à Tcharllss?)
Hu hu, j’avais fini par oublier l’existence de ce plugin !
Il n’est pas documenté, mais facilement trouvable sur plugins.spip.net en cherchant avec « formidable » tout de même.
Je ne saurais pas trop quoi mettre dans la doc, il n’y a vraiment pas grand chose à dire.
Mais n’hésitez pas si vous voulez.
Super. Même une doc simple sur contrib est mieux que pas de doc. Car sans doc, ce n’est pas trouvable, sauf si on connaît un peu les arcanes de SPIP.
C’est fait, j’en ai proposé un dans la rublique Formidable (Intérêt, Installation, Utilisation). J’ai inséré l’icône de l’extension et quelques mots-clefs, mais je n’ai pas l’habitude de ce type de contribution pour peaufiner plus.
ne t’inquiète pas, on a des administrateurs qui te feront des retours
Reply to this message
Bonjour
je ne sais plus comment changer l’expéditeur du mail (email)
merci pour votre aide
Natacha
Reply to this message
Bonjour,
il ne semble pas prévu pour le formulaire de contact l’ajout de la case à cocher “RGPD compatible” qu’il est désormais nécessaire de faire figurer, serait-ce que je n’ai pas assez cherché ? Ou bien est-ce une mise à jour prévue ? Pas prévue ?
Merci d’avance de votre aide ! Et bonne journée à tous :)
Bonjour Sandra,
Une bidouille que j’ai mis en place avec le plugin “contact libre” mais qui devrait marcher sur “contact avancé”, c’est de mettre en dur dans le fichier contact_libre.html après
le code suivant :
Je sais, le dur c’est pas beau, mais ça marche.. Si quelqu’un a une autre solution, je suis preneur :)
Reply to this message
Lorsque la case “Sauvegarder les messages de contacts” est cochée est-on supposé pouvoir accéder aux messages dans l’admin ? Car là je cherche mais je ne vois rien (pourtant les messages sont bien dans la base).
Et je remarque aussi que les personnes qui remplissent le formulaire sont enregistrées dans la table spip_auteurs ? Est-ce voulu ? Comment empêcher cela ?
Je n’aime pas trop laisser des données perso traîner sans pouvoir les supprimer (là il faut aller dans la base, c’est pas pratique pour les non-webmestres).
Merci
dd
1- On accède aux message dans l’admin via des adresses de type ecrire/?exec=message&id_message=xx qui sont envoyé par mail au(x) destinataires du message.
2- Le mail de l’internaute ayant rempli le formulaire de contact est considéré (sauf si le mail est déjà en base pour un rédacteur par exemple) comme étant celui d’un visiteur du type contact et à ce titre il est disponible dans le privé sur la page des visiteurs.
Et voilà...
Exercice réalisé aujourd’hui avec SPIP 3.0.21.
En revanche je n’ait pas tester avec «décocher tous les items de la liste des destinataires» mais si les messages apparaissent en base alors il sont consultable dans l’espace privé :)
N’existe-t-il pas d’inferface listant les messages pour pouvoir les consulter ?
Il n’y a pas non plus de possibilité d’export ?
Ce plugin a déjà beaucoup (trop) augmenté depuis sa base, qui était de permettre une configuration (donc mieux que ecrire_auteur) mais une configuration simple et unique.
Si on veut vraiment gérer des réponses, lister, trier, exporter, etc : c’est le plugin Formidable qui fait ça.
Oui mais Formidable n’a pas la fonction d’envoi de fichiers :)
Ça marche pas..
Accès via le compte webmestre à l’adresse :
www.site.com/ecrire/?exec=message&id_message=25
donne : Vous n’avez pas le droit d’accéder à la page message.
dd
Bonjour,
J’avais le même problème. Voilà ce qui se passe :
Lors de l’enregistrement du message, il est indiqué un id_auteur dans la table spip_messages (et un auteur est créé, ou reconnu).
- si cet id_auteur est le vôtre, le message apparaîtra dans la boite d’envoi.
- si cet id_auteur n’est pas le vôtre, vous aurez ce message d’erreur, et rien n’apparaîtra dans l’interface “Messagerie de contact”.
- si vous effacez (dans la base) ou remplacez par 0 cet id_auteur, vous verrez le message dans la boite de réception (avec vide dans la colonne “de”).
Je croix qu’il faudrait modifier légèrement le code pour ne pas remplir ce champ puisqu’il ne faut pas toucher au code de spip !
Et sûrement ne pas créer un nouvel auteur (avec le champ nom et l’émail, avec un statut contact, et un login Null), mais c’est une autre discussion. Cela empêcherait de pouvoir “répondre” dans l’admin spip, mais cela me paraît peut utile.
Cordialement,
Je me réponds après avoir regardé plus en détail.
Le message apparaît dans la boite de réception lorsque la correspondance entre le destinataire(id_auteur) et le message (id_message) est faite dans la table spip_auteurs_liens.
Ce lien est établi à l’enregistrement du message.
Les modifications du destinataire ou de l’auteur dans la table spip_message ne servent à rien (mea culpa...).
Reply to this message
Add a comment
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.
Follow the comments:
|
