3 /***************************************************************************\
4 * SPIP, Systeme de publication pour l'internet *
6 * Copyright (c) 2001-2019 *
7 * Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James *
9 * Ce programme est un logiciel libre distribue sous licence GNU/GPL. *
10 * Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne. *
11 \***************************************************************************/
14 * Gestion du formulaire de d'édition d'article
16 * @package SPIP\Core\Articles\Formulaires
19 if (!defined('_ECRIRE_INC_VERSION')) {
23 include_spip('inc/actions');
24 include_spip('inc/editer');
27 * Chargement du formulaire d'édition d'article
29 * @uses formulaires_editer_objet_charger()
31 * @param int|string $id_article
32 * Identifiant de l'article. 'new' pour une nouvel article.
33 * @param int $id_rubrique
34 * Identifiant de la rubrique parente
35 * @param string $retour
36 * URL de redirection après le traitement
37 * @param int $lier_trad
38 * Identifiant éventuel d'un article source de traduction
39 * @param string $config_fonc
40 * Nom de la fonction ajoutant des configurations particulières au formulaire
42 * Valeurs de la ligne SQL de l'article, si connu
43 * @param string $hidden
44 * Contenu HTML ajouté en même temps que les champs cachés du formulaire.
46 * Environnement du formulaire
48 function formulaires_editer_article_charger_dist(
53 $config_fonc = 'articles_edit_config',
57 $valeurs = formulaires_editer_objet_charger(
68 if (test_formulaire_inclus_par_modele()) {
69 if (intval($id_article) and !autoriser('modifier', 'article', intval($id_article))) {
70 $valeurs['editable'] = '';
74 // il faut enlever l'id_rubrique car la saisie se fait sur id_parent
75 // et id_rubrique peut etre passe dans l'url comme rubrique parent initiale
76 // et sera perdue si elle est supposee saisie
81 * Identifier le formulaire en faisant abstraction des paramètres qui
82 * ne représentent pas l'objet édité
84 * @param int|string $id_article
85 * Identifiant de l'article. 'new' pour une nouvel article.
86 * @param int $id_rubrique
87 * Identifiant de la rubrique parente
88 * @param string $retour
89 * URL de redirection après le traitement
90 * @param int $lier_trad
91 * Identifiant éventuel d'un article source de traduction
92 * @param string $config_fonc
93 * Nom de la fonction ajoutant des configurations particulières au formulaire
95 * Valeurs de la ligne SQL de l'article, si connu
96 * @param string $hidden
97 * Contenu HTML ajouté en même temps que les champs cachés du formulaire.
101 function formulaires_editer_article_identifier_dist(
106 $config_fonc = 'articles_edit_config',
110 return serialize(array(intval($id_article), $lier_trad));
114 * Choix par défaut des options de présentation
117 * Valeurs de la ligne SQL d'un article, si connu
119 * Configuration pour le formulaire
121 function articles_edit_config($row) {
124 $config = $GLOBALS['meta'];
125 $config['lignes'] = 8;
126 $config['langue'] = $spip_lang;
128 $config['restreint'] = ($row['statut'] == 'publie');
134 * Vérifications du formulaire d'édition d'article
136 * @uses formulaires_editer_objet_verifier()
138 * @param int|string $id_article
139 * Identifiant de l'article. 'new' pour une nouvel article.
140 * @param int $id_rubrique
141 * Identifiant de la rubrique parente
142 * @param string $retour
143 * URL de redirection après le traitement
144 * @param int $lier_trad
145 * Identifiant éventuel d'un article source de traduction
146 * @param string $config_fonc
147 * Nom de la fonction ajoutant des configurations particulières au formulaire
149 * Valeurs de la ligne SQL de l'article, si connu
150 * @param string $hidden
151 * Contenu HTML ajouté en même temps que les champs cachés du formulaire.
153 * Erreurs du formulaire
155 function formulaires_editer_article_verifier_dist(
160 $config_fonc = 'articles_edit_config',
164 // auto-renseigner le titre si il n'existe pas
165 titre_automatique('titre', array('descriptif', 'chapo', 'texte'));
166 // on ne demande pas le titre obligatoire : il sera rempli a la volee dans editer_article si vide
167 $erreurs = formulaires_editer_objet_verifier('article', $id_article, array('id_parent'));
168 // si on utilise le formulaire dans le public
169 if (!function_exists('autoriser')) {
170 include_spip('inc/autoriser');
172 if (!isset($erreurs['id_parent'])
173 and !autoriser('creerarticledans', 'rubrique', _request('id_parent'))
175 $erreurs['id_parent'] = _T('info_creerdansrubrique_non_autorise');
182 * Traitements du formulaire d'édition d'article
184 * @uses formulaires_editer_objet_traiter()
186 * @param int|string $id_article
187 * Identifiant de l'article. 'new' pour une nouvel article.
188 * @param int $id_rubrique
189 * Identifiant de la rubrique parente
190 * @param string $retour
191 * URL de redirection après le traitement
192 * @param int $lier_trad
193 * Identifiant éventuel d'un article source de traduction
194 * @param string $config_fonc
195 * Nom de la fonction ajoutant des configurations particulières au formulaire
197 * Valeurs de la ligne SQL de l'article, si connu
198 * @param string $hidden
199 * Contenu HTML ajouté en même temps que les champs cachés du formulaire.
201 * Retours des traitements
203 function formulaires_editer_article_traiter_dist(
208 $config_fonc = 'articles_edit_config',
212 // ici on ignore changer_lang qui est poste en cas de trad,
213 // car l'heuristique du choix de la langue est pris en charge par article_inserer
214 // en fonction de la config du site et de la rubrique choisie
215 set_request('changer_lang');
217 return formulaires_editer_objet_traiter(