f02b1ef65e4b8b7b50f34ae2731ade695233a620
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(
67 // il faut enlever l'id_rubrique car la saisie se fait sur id_parent
68 // et id_rubrique peut etre passe dans l'url comme rubrique parent initiale
69 // et sera perdue si elle est supposee saisie
74 * Identifier le formulaire en faisant abstraction des paramètres qui
75 * ne représentent pas l'objet édité
77 * @param int|string $id_article
78 * Identifiant de l'article. 'new' pour une nouvel article.
79 * @param int $id_rubrique
80 * Identifiant de la rubrique parente
81 * @param string $retour
82 * URL de redirection après le traitement
83 * @param int $lier_trad
84 * Identifiant éventuel d'un article source de traduction
85 * @param string $config_fonc
86 * Nom de la fonction ajoutant des configurations particulières au formulaire
88 * Valeurs de la ligne SQL de l'article, si connu
89 * @param string $hidden
90 * Contenu HTML ajouté en même temps que les champs cachés du formulaire.
94 function formulaires_editer_article_identifier_dist(
99 $config_fonc = 'articles_edit_config',
103 return serialize(array(intval($id_article), $lier_trad));
107 * Choix par défaut des options de présentation
110 * Valeurs de la ligne SQL d'un article, si connu
112 * Configuration pour le formulaire
114 function articles_edit_config($row) {
117 $config = $GLOBALS['meta'];
118 $config['lignes'] = 8;
119 $config['langue'] = $spip_lang;
121 $config['restreint'] = ($row['statut'] == 'publie');
127 * Vérifications du formulaire d'édition d'article
129 * @uses formulaires_editer_objet_verifier()
131 * @param int|string $id_article
132 * Identifiant de l'article. 'new' pour une nouvel article.
133 * @param int $id_rubrique
134 * Identifiant de la rubrique parente
135 * @param string $retour
136 * URL de redirection après le traitement
137 * @param int $lier_trad
138 * Identifiant éventuel d'un article source de traduction
139 * @param string $config_fonc
140 * Nom de la fonction ajoutant des configurations particulières au formulaire
142 * Valeurs de la ligne SQL de l'article, si connu
143 * @param string $hidden
144 * Contenu HTML ajouté en même temps que les champs cachés du formulaire.
146 * Erreurs du formulaire
148 function formulaires_editer_article_verifier_dist(
153 $config_fonc = 'articles_edit_config',
157 // auto-renseigner le titre si il n'existe pas
158 titre_automatique('titre', array('descriptif', 'chapo', 'texte'));
159 // on ne demande pas le titre obligatoire : il sera rempli a la volee dans editer_article si vide
160 $erreurs = formulaires_editer_objet_verifier('article', $id_article, array('id_parent'));
161 // si on utilise le formulaire dans le public
162 if (!function_exists('autoriser')) {
163 include_spip('inc/autoriser');
165 if (!isset($erreurs['id_parent'])
166 and !autoriser('creerarticledans', 'rubrique', _request('id_parent'))
168 $erreurs['id_parent'] = _T('info_creerdansrubrique_non_autorise');
175 * Traitements du formulaire d'édition d'article
177 * @uses formulaires_editer_objet_traiter()
179 * @param int|string $id_article
180 * Identifiant de l'article. 'new' pour une nouvel article.
181 * @param int $id_rubrique
182 * Identifiant de la rubrique parente
183 * @param string $retour
184 * URL de redirection après le traitement
185 * @param int $lier_trad
186 * Identifiant éventuel d'un article source de traduction
187 * @param string $config_fonc
188 * Nom de la fonction ajoutant des configurations particulières au formulaire
190 * Valeurs de la ligne SQL de l'article, si connu
191 * @param string $hidden
192 * Contenu HTML ajouté en même temps que les champs cachés du formulaire.
194 * Retours des traitements
196 function formulaires_editer_article_traiter_dist(
201 $config_fonc = 'articles_edit_config',
205 // ici on ignore changer_lang qui est poste en cas de trad,
206 // car l'heuristique du choix de la langue est pris en charge par article_inserer
207 // en fonction de la config du site et de la rubrique choisie
208 set_request('changer_lang');
210 return formulaires_editer_objet_traiter(