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
Discussions par date d’activité
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
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 :
pourquoi est ce que la validation n’est pas bonne ?
jacques
Répondre à ce message
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 !
Bonjour,
Je viens de tester, oui ça marche.
Cdt
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
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)
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 ;-)
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
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.
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 :
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
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 :
audwill
Répondre à ce message
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 :
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 : |