[SPIP] +2.1.12
[velocampus/web/www.git] / www / ecrire / inc / article_select.php
1 <?php
2
3 /***************************************************************************\
4 * SPIP, Systeme de publication pour l'internet *
5 * *
6 * Copyright (c) 2001-2011 *
7 * Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James *
8 * *
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 \***************************************************************************/
12
13 if (!defined('_ECRIRE_INC_VERSION')) return;
14
15 include_spip('inc/autoriser'); // necessaire si appel de l'espace public
16
17 // Recupere les donnees d'un article pour composer un formulaire d'edition
18 // (utilise par exec/article_edit)
19 // id_article = numero d'article existant
20 // id_rubrique = ou veut-on l'installer (pas obligatoire)
21 // lier_trad = l'associer a l'article numero $lier_trad
22 // new=oui = article a creer si on valide le formulaire
23 // http://doc.spip.org/@inc_article_select_dist
24 function inc_article_select_dist($id_article, $id_rubrique=0, $lier_trad=0, $id_version=0) {
25 global $connect_id_rubrique, $spip_lang;
26
27 if (is_numeric($id_article)) {
28
29 // marquer le fait que l'article est ouvert en edition par toto a telle date
30 // une alerte sera donnee aux autres redacteurs sur exec=articles
31 if ($GLOBALS['meta']['articles_modif'] != 'non') {
32 include_spip('inc/drapeau_edition');
33 signale_edition ($id_article, $GLOBALS['visiteur_session'], 'article');
34 }
35 $row = sql_fetsel("*", "spip_articles", "id_article=$id_article");
36 // si une ancienne revision est demandee, la charger
37 // en lieu et place de l'actuelle ; attention les champs
38 // qui etaient vides ne sont pas vide's. Ca permet de conserver
39 // des complements ajoutes "orthogonalement", et ca fait un code
40 // plus generique.
41 if ($id_version) {
42 include_spip('inc/revisions');
43 if ($textes = recuperer_version($id_article, $id_version)) {
44 foreach ($textes as $champ => $contenu)
45 $row[$champ] = $contenu;
46 }
47 }
48 return $row;
49 }
50
51 // id_article non numerique, c'est une demande de creation.
52 // Si c'est une demande de nouvelle traduction, init specifique
53 if ($lier_trad){
54 $row = article_select_trad($lier_trad, $id_rubrique);
55 $row['statut'] = ''; // le nouvel article n'a pas encore de statut !
56 }
57 else {
58 $row['titre'] = '';//filtrer_entites(_T('info_nouvel_article'));
59 //$row['onfocus'] = " onfocus=\"if(!antifocus){this.value='';antifocus=true;}\"";
60 $row['id_rubrique'] = $id_rubrique;
61 }
62
63 // appel du script a la racine, faut choisir
64 // admin restreint ==> sa premiere rubrique
65 // autre ==> la derniere rubrique cree
66 if (!$row['id_rubrique']) {
67 if ($connect_id_rubrique)
68 $row['id_rubrique'] = $id_rubrique = $connect_id_rubrique[0];
69 else {
70 $row_rub = sql_fetsel("id_rubrique", "spip_rubriques", "", "", "id_rubrique DESC", 1);
71 $row['id_rubrique'] = $id_rubrique = $row_rub['id_rubrique'];
72 }
73 if (!autoriser('creerarticledans','rubrique',$row['id_rubrique'] )){
74 // manque de chance, la rubrique n'est pas autorisee, on cherche un des secteurs autorises
75 $res = sql_select("id_rubrique", "spip_rubriques", "id_parent=0");
76 while (!autoriser('creerarticledans','rubrique',$row['id_rubrique'] ) && $row_rub = sql_fetch($res)){
77 $row['id_rubrique'] = $row_rub['id_rubrique'];
78 }
79 }
80 }
81
82 // recuperer le secteur, pour affecter les bons champs extras
83 if (!$row['id_secteur']) {
84 $row_rub = sql_getfetsel("id_secteur", "spip_rubriques", "id_rubrique=" . sql_quote($id_rubrique));
85 $row['id_secteur'] = $row_rub;
86 }
87
88 return $row;
89 }
90
91 //
92 // Si un article est demande en creation (new=oui) avec un lien de trad,
93 // on initialise les donnees de maniere specifique
94 //
95 // http://doc.spip.org/@article_select_trad
96 function article_select_trad($lier_trad, $id_rubrique=0) {
97 // Recuperer les donnees de l'article original
98 $row = sql_fetsel("*", "spip_articles", "id_article=$lier_trad");
99 if ($row) {
100 $row['titre'] = filtrer_entites(_T('info_nouvelle_traduction')).' '.$row["titre"];
101
102 } else $row = array();
103 if ($id_rubrique) {
104 $row['id_rubrique'] = $id_rubrique;
105 return $row;
106 }
107 $id_rubrique = $row['id_rubrique'];
108 // Regler la langue, si possible, sur celle du redacteur
109 // Cela implique souvent de choisir une rubrique ou un secteur
110 if (in_array($GLOBALS['spip_lang'],
111 explode(',', $GLOBALS['meta']['langues_multilingue']))) {
112 // Si le menu de langues est autorise sur les articles,
113 // on peut changer la langue quelle que soit la rubrique
114 // donc on reste dans la meme rubrique
115 if ($GLOBALS['meta']['multi_articles'] == 'oui') {
116 $row['id_rubrique'] = $row['id_rubrique']; # explicite :-)
117 }
118 else if ($GLOBALS['meta']['multi_rubriques'] == 'oui') {
119 // Sinon, chercher la rubrique la plus adaptee pour
120 // accueillir l'article dans la langue du traducteur
121 if ($GLOBALS['meta']['multi_secteurs'] == 'oui') {
122 $id_parent = 0;
123 } else {
124 // on cherche une rubrique soeur dans la bonne langue
125 $row_rub = sql_fetsel("id_parent", "spip_rubriques", "id_rubrique=$id_rubrique");
126
127 $id_parent = $row_rub['id_parent'];
128 }
129 $row_rub = sql_fetsel("id_rubrique", "spip_rubriques", "lang='".$GLOBALS['spip_lang']."' AND id_parent=$id_parent");
130 if ($row_rub)
131 $row['id_rubrique'] = $row_rub['id_rubrique'];
132 }
133 }
134 return $row;
135 }
136
137 ?>