Formulaire de contact avancé

Un formulaire de contact configurable, avec de multiples options.

ATTENTION : bien que fonctionnant, ce plugin n’est plus maintenu depuis plusieurs années. Cela fait au moins 10 ans qu’il est conseillé de le remplacer par le plugin Formidable plus souple et maintenu activement.

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 ».

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.

Discussion

463 discussions

  • 2
    Alain7159

    Bonjour,

    La version 0.16.4 pour spip 3.2 est-elle compatible php7 ?

    Merci pour votre réponse.

    • Aucune idée, il faut tester :)
      N’hésite pas à le dire s’il y a un problème

      (Ce plugin reste un peu en l’état, il n’est plus vraiment maintenu depuis qu’il y a Formidable)

    • Alain7159

      Bonjour,

      Cela semble bien fonctionner. Mais si ce plugin n’est plus trop suivi, je vais voir du côté de Formidable si je trouve mon bonheur.
      En tout cas merci pour le travail fourni.

    Répondre à ce message

  • crazyspip

    Bonjour,

    Je mets une série de sites à jour vers la version 3.1.6 de Spip, avec formulaire de contact avancé v0.16.0.

    Je viens de faire les 2 premiers sites, l’installation se passe bien mais dans les 2 sites, lors de la prévisualisation d’un mail, j’ai le message « Il y a 2 erreurs dans votre saisie, veuillez vérifier les informations. » Malgré cela, je peux envoyer le mail et il arrive à destination, mais ça fait désordre. :-)

    Une idée ? D’avance merci.

    Répondre à ce message

  • 1
    Spidermian

    Bonsoir,

    J’ai collé

    $GLOBALS['spip_pipeline']['contact_infos_supplementaires'] .= '|autre_contact_infos_supplementaires';
           
    function autre_contact_infos_supplementaires($champs){
           $champs['sujet_alternatif'] = 'Sujet alternatif';
           return $champs;
       }

    dans mes_options.php et je ne vois nulle part apparaître le champ supplémentaire.
    J’ai merdé quelquepart ? Y a-t-il un soucis avec la dernière version de spip que j’utilise ?

    • Spidermian

      Ça y est, je viens de le trouver, toutes mes confuses il etait en bas...
      par contre il est automatiquement en « obligatoire »
      y a t’il un endroit ou je peux changer cette option ?

    Répondre à ce message

  • Bonjour,

    J’essaye de personnaliser le formulaire contact avec les class de Bootstrap. J’ai besoin des labels pour afficher « Nom », « Pays ». Quelqu’un peut m’aider SVP ? Merci.

    Répondre à ce message

  • Chourak

    Bonjour,

    J’ai noté un souci de comptage du nombre d’erreurs à la soumission d’un formulaire.
    J’ai remarqué que la variable de retour d’erreur concernant les informations de pièces jointes ($erreurs[’infos_pj’]) était constamment présente, qu’on ait activé l’autorisation d’envoi des pièces jointes ou non.

    J’ai réglé ca chez moi par

    if($pj_fichiers)
        $erreurs['infos_pj'] = $infos_pj;

    à la ligne 287

    Et ca fait le boulot, par contre je ne sais pas si c’est la façon de faire adéquate :)

    Répondre à ce message

  • 3

    Pré-remplir le sujet du mail
    Parce que j’utilise d’utiliser le formulaire de contact avancé pour différents usages, j’aimerais pouvoir « pré-remplir » le sujet du mail par des textes qui seraient différents selon le contexte. A priori, je n’ai pas vu cette possibilité dans la documentation du plugin.
    Est-ce que quelque chose comme
    <formulaire|contact|auteur=34|sujet=un texte personnalisé>
    est possible ? Pas possible ?

    • Pas prévu non. Et il y a déjà plus d’options que ce qui était prévu au départ. Pour des formulaires vraiment pleins d’options, il faut plutôt se tourner vers Formidable.

    • Solution jquery :

      #FORMULAIRE_CONTACT
      <script type="text/javascript">
      (function($, window) {
      $("#info_sujet").val("En réponse au truc #TITRE"); 
      })(jQuery, window);
      </script>
    • Merci pour le JQuery, ça marche super !

    Répondre à ce message

  • 2

    Bonjour,
    J’utilise le formulaire de contact avance, et cela fonctionne tres bien.
    Je voudrais desactiver la previsualisation, est-ce possible de le faire simplement ? Ou bien faut-il entrer dans le code ?
    Cordialement,
    Didier

    • Ce n’est pas prévu comme option, non

    • Bonsoir RastaPopoulos,
      Je reviens sur cette question. Je comprends que ce ne soit pas une option mais en bidouillant est-ce possible ?
      Si oui pourrais-tu m’éclairer sur ce point ?

      J’ai fait apparaître la partie « piège à spammeur », as-tu des retours sur son efficacité ?

      En te remerciant par avance
      Jérôme

    Répondre à ce message

  • Bonjour,

    suite a mon installation, malgré tous mes essais, j’ai toujours droit a

    Une erreur de transmission s’est produite, merci de renouveler votre demande.

    auriez vous une idée ou chercher ?
    merci

    Répondre à ce message

  • Bonjour,

    J’ai coché la case « inscription à la newsletter » (pas obligatoire) = oui dans la config du plugin et pourtant il y a un hic quelque part car même si l’internaute coche la case (oui est bien enregistré en base dans le texte du message) il n’est pas inscrit à la newsletter, même pas au statut « à confirmer ».
    J’ai 2 newsletters configurées (1 ouverte / 1 fermée)

    Est-ce qu’il faut l’inscrire manuellement ou bien j’ai loupé autre chose ?

    Merci

    Formulaire de contact version : 0.15.13 SVN [95695]
    SPIP 3.1.2
    Mailsubscriber version : 1.9.0 SVN [98721]

    Répondre à ce message

  • 2

    Auparavant on pouvait envoyer un message aux visiteurs+admin+auteurs
    Maintenant je ne vois plus que les admins+auteurs.
    Il y a une option pour permettre d’envoyer un message aux visiteurs aussi ?
    Merci

    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