Utiliser et personnaliser le formulaire public d’ajout d’articles

Ceci est une « contribution pédagogique », qui montre par l’exemple comment développer une nouvelle fonctionnalité pour SPIP.

La procédure sous SPIP 2 pour mettre en place la proposition publique d’articles

Le projet pour lequel j’ai travaillé cette procédure est un dictionnaire de traduction. il y a donc la procédure pour la proposition publique d’articles et une partie traduction publique d’articles que je vous mets également.
L’ensemble est une synthèse d’informations de la liste et de tests personnels.

Par rapport à certaines propositions lues, on obtient bien dans l’espace public un formulaire d’ajout d’articles différent de celui utilisé dans l’administration (ecrire)

Environnement :
Un spip 209
Une organisation multilingue par secteur
Des internautes qui s’enregistrent sur le site (via l’inscription de rédacteurs)

EDIT : j’utilise ce travail ici : http://www.lecinedico.com. Merci de ne pas vous en servir pour tester via des faux mots

1/ Poser le cadre + la reconnaissance de l’auteur

Créer un squelette auteur_propose_art.html
On peut copier le squelette auteur.html pour modèle
Il appelle le formulaire et gère deux cas : proposer un article ou proposer une traduction
La boucle supérieure

<BOUCLE_principale(AUTEURS) {id_auteur=#SESSION{id_auteur}}{tout}>
...
</BOUCLE_principale>

L’internaute enregistré et loggué (via les formulaires standards de spip) est amené sur cette page via un lien, dans n’importe quel squelette :

<a href="#URL_PAGE{auteur_propose_art,id_auteur=#SESSION{id_auteur}}">proposer un article</a>

Dans une boucle article, le lien proposer une traduction :

<a href="[(#URL_PAGE{auteur_propose_art,id_auteur=#SESSION{id_auteur}}|parametre_url{lier_trad, #ID_ARTICLE})]">proposer une traduction</a>

2/ le formulaire proprement dit et sa gestion

Dans le squelette auteur_propose_art.html

[(#ENV{lier_trad}|non) Proposer un article ]

<BOUCLE_a_traduire(ARTICLES){id_article=#ENV{lier_trad, 0}}{statut IN publie, prop}>
[ proposer la traduction de (#TITRE)]
</BOUCLE_a_traduire>
</B_a_traduire>


#FORMULAIRE_PERSO_AJOUTER_ART{oui,"1",#SELF,#ENV{lier_trad},"",""}

La gestion du formulaire
Dans le dossier squelettes/formulaires
copier les fichiers editer_article.html/editer_article.php de /prive/formulaires
les renommer en perso_ajouter_art.html et perso_ajouter_art.php

Dans perso_ajouter_art.php :
-  modifier les occurences « editer_article » en « perso_ajouter_art »
-  remplacer le contenu de la première fonction (dont le nom vient de changer) « formulaires_perso_ajouter_art_charger_dist » par :
_

	$contexte['_hidden'] = str_replace('editer_article', 'perso_ajouter_art', $contexte['_hidden']);
	// preciser que le formulaire doit etre securise auteur/action
$contexte['_action'] = array('perso_ajouter_art',$id_article);
	
	return $contexte;


//	unset($valeurs['id_rubrique']);
	return $valeurs;

Dans perso_ajouter_art.html :
Ajouter :

	  	  <input type='hidden' name='statut' value='prop' />
	  	[<input type='hidden' name='lier_trad' value='(#ENV{lier_trad})' />]

EDIT : la langue de l’article est automatiquement récupérée de la rubrique dans une configuration multilingue, avec une langue par rubrique à la racine, et en admin le réglage « Activer le menu de langue sur les articles » sur non

NB : personnellement il me reste deux problèmes :
la liste des rubriques garde sa numérotation (pas de supprimer_numero)
la configuration automatique des champs du formulaire n’est pas prise en compte (?), mais on peut en effacer directement dans le perso_ajouter_art.html

Discussion

9 discussions

  • Bonjour, grand merci pour cette intéressante contribution, je viens de l’appliquer ça marche correctement mais le formulaire que j’ai c’est pas celui que je désire, comme je suis débutant en spip je ne sais pas ou, modifier ce formulaire, ou tout simplement ou je peu trouver un formulaire, ou il n’y a que le :
    -  Nom
    -  Email
    -  Numero de téléphone
    -  titre du texte
    -  l’endroit ou mettre le texte
    -  l’endroit ou uploader une image
    -  envoyer

    et Quand le visiteur envois son article il y’a un message qui lui indique que son article a été envoyé.
    Je vous remercie.

    Répondre à ce message

  • jacangers

    bonjour,

    j’ai suivi scrupuleusement cette contibution …

    le formulaire s’affiche bien … mais la validation me ramene dans l’espace privé, sans avoir pris en compte mes champs ? qu’est ce que j’ai oublié dans la manip ?

    si je regarde dans le code source, dans le formulaire affiché voila ce que j’ai :

    <form method='post' action='/monsite/spip.php?page=auteur_propose_art&amp;id_auteur=397' enctype='multipart/form-data'>

    pourquoi est ce que la validation n’est pas bonne ?

    jacques

    Répondre à ce message

  • 1

    Bonjour,
    avez-vous tester cette contrib sous spip 2.1 ?
    Si oui est-ce que ça marche ?
    Car chez moi rien ne se passe.
    merci d’avance !

    Répondre à ce message

  • Bonjour,

    bravo pour cette contrib qui est exactement ce que je cherchais.

    Il me manque juste deux fonctionnalités, que mes compétences en spip / php sont encore trop minces pour développer :

    -  si on essaye de proposer un article sans être enregistré, une page blanche s’affiche avec juste « # ». Comment afficher à la place, à la place du formulaire, « vous ne pouvez pas écrire un article sans être enregistré, inscrivez vous (lien de la page) » ?

    -  comment affecter à cet article des mots clés (j’en ai trois groupes)

    Merci

    Zab

    Répondre à ce message

  • 2

    Bonjour,
    Très intéressante contribution.
    Une question : avec leur login/mot de passe les contributeurs peuvent donc voir la partie privée ?
    Si oui, y a-t-il moyen qu’ils ne travaillent que dans la partie publique ?
    Autre question : peut-on leur faire télécharger un fichier s’ils le veulent ?
    Je n’ai pas osé m’inscrire sur ton site pour ne pas surajouter des données inutiles.
    Merci

    • Bonjour,

      Pardon pour le délais

      L’accès à l’admin est limité aux administrateurs en mettant dans mes_options.php (dans /config)

      function autoriser_ecrire($faire, $type, $id, $qui, $opt) {
      	return in_array($qui['statut'], array('0minirezo'));
      }

      Pour le téléchargement, pas eu besoin, mais le plugin upload doit pouvoir être branché (?)

      Pour le site lecinedico.com, des inscriptions ne sont pas gênantes (il existe un profil redacteur/redacteur au besoin), c’est la soumission de faux mots qui serait dérangeante ;-)

    • audwill

      bonjour,

      j’ai essayé d’ajouter ce code pour restreindre l’accès à l’espace privé aux seuls administrateurs.
      ça marche mais avec quelques bizarreries :
      -  quand un admin se connecte à l’espace privé il arrive sur une page indiquant « vous êtes enregistré, par ici » et en cliquant sur ce lien ça mène effectivement à l’espace privé : n’y a t’il pas moyen d’éviter l’affichage de cette page intermédiaire ?
      -  quand un admin se déconnecte de l’espace privé il est dirigé vers une page d’erreur 302 indiquant : HTTP 302 - Si votre navigateur n’est pas redirigé, cliquez ici pour continuer.
      Et en cliquant il revient à la page de login d’ecrire. .
      Ce message d’erreur 302 s’affiche aussi de temps en temps dans l’espace privé après une validation de modif...
      Comment l’éviter ?

    Répondre à ce message

  • 1

    Bonjour,

    Merci pour le squelette. ça marche parfaitement.
    j’ai dû, seulement, ajouté deux lignes dans le squelette appellant le formulaire :

    [(#ENVid_article|==0| ?<:article_ajout_erreur :>,’’)]
    [(#ENVid_article|>0| ?<:article_ajoute :>,’’)]

    pour que les rédacteurs sachent bien que l’article est posté, dans le cas échéant, qu’il y a erreur.

    Cependant, en cas d’erreur (titre non saisie par ex), le formulaire se vide. Donc les rédacteurs sont contraint de re-saisir tout le contenu !!

    une idée ?!

    Merci.

    • audwill

      J’avais essayé d’ajouter ces deux lignes dans mon squelette, sans succès. Eric m’a suggéré sur la liste spip une autre solution, qui fonctionne très bien chez moi :

      dans le fichier php du formulaire personnalisé d’édition d’article, par exemple dans squelettes/formulaires/editer_monarticle.php, modifier la fonction
      function formulaires_editer_monarticle_traiter_dist comme ceci :

      function formulaires_editer_monarticle_traiter_dist($id_article='new',
      $id_rubrique=0, $retour='', $lier_trad=0, $config_fonc='articles_edit_config', $row=array(), $hidden=''){
      
      $ok = formulaires_editer_objet_traiter('article',$id_article,$id_rubrique,$lier_trad,$retour,$config_fonc,$row,$hidden);
      
      if($ok == true) {
             return array('message_ok'=>'Votre article a bien été enregistré');
      }
      else { return array('message_ok'=>'Une erreur est survenue'); }
      
      }

      Résultat : quand l’auteur enregistre son article dans l’espace public, il obtient un message de confirmation (« votre article a bien été enregistré ») ou un message d’erreur (une erreur est survenue).

    Répondre à ce message

  • audwill

    Bonjour,
    et merci beaucoup pour cette contrib - super claire !

    j’essaie de proposer aux auteurs de pouvoir modifier leur bio depuis l’espace public. donc j’ai suivi la même méthode en modifiant le formulaire d’édition auteur : editer_auteur.html et editer_auteur.php (renommés en editer_auteur_perso)

    mais je cale sur la modif de la première fonction dans le fichier php. Que faudrait-il modifier dans ce cas ? j’ai naïvement essayé de modifier la fonction comme ça mais ça marche pas :

     $contexte['_hidden'] = str_replace('editer_auteur', 'editer_auteur_perso', $contexte['_hidden']);
    	// preciser que le formulaire doit etre securise auteur/action
    $contexte['_action'] = array('editer_auteur_perso',$id_auteur);
    	
    	return $contexte;
    //	unset($valeurs['id_rubrique']);
    	return $valeurs;

    audwill

    Répondre à ce message

  • 1

    est-ce qu’on peut voir une demo de ton code quelque part ?

    • Bonjour,
      J’avais dit que je donnerai le lien, je l’ai ajouté dans l’article à titre d’information. Mais merci de ne pas tester avec de faux mots

    Répondre à ce message

  • Bonjour,
    Le site sera mis en ligne dans quelques jours, j’ajouterai alors le lien.
    A.

    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