source: spip-zone/_core_/plugins/breves/breves_pipelines.php @ 69328

Last change on this file since 69328 was 69328, checked in by jack@…, 7 years ago

On est en 2013 !

File size: 9.1 KB
Line 
1<?php
2
3/***************************************************************************\
4 *  SPIP, Systeme de publication pour l'internet                           *
5 *                                                                         *
6 *  Copyright (c) 2001-2013                                                *
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/**
14 * Utilisations de pipelines
15 *
16 * @package SPIP\Breves\Pipelines
17**/
18if (!defined("_ECRIRE_INC_VERSION")) return;
19
20
21/**
22 * Définir les meta de configuration liées aux brèves
23 *
24 * @pipeline configurer_liste_metas
25 * @param array $metas
26 *     Couples nom de la méta => valeur par défaut
27 * @return array
28 *    Couples nom de la méta => valeur par défaut
29 */
30function breves_configurer_liste_metas($metas){
31        $metas['activer_breves'] =  'non';
32        return $metas;
33}
34
35/**
36 * Ajouter les brèves à valider sur les rubriques
37 *
38 * @pipeline rubrique_encours
39 *
40 * @param array $flux  Données du pipeline
41 * @return array       Données du pipeline
42**/
43function breves_rubrique_encours($flux){
44        if ($flux['args']['type'] == 'rubrique') {
45                $lister_objets = charger_fonction('lister_objets','inc');
46
47                $id_rubrique = $flux['args']['id_objet'];
48
49                //
50                // Les breves a valider
51                //
52                $flux['data'] .= $lister_objets('breves', array(
53                        'titre'=>_T('breves:info_breves_valider'),
54                        'statut'=>array('prepa','prop'),
55                        'id_rubrique'=>$id_rubrique,
56                        'par'=>'date_heure'));
57        }
58        return $flux;
59}
60
61
62
63
64/**
65 * Ajouter les brèves référencées sur les vues de rubriques
66 *
67 * @pipeline affiche_enfants
68 *
69 * @param array $flux  Données du pipeline
70 * @return array       Données du pipeline
71**/
72function breves_affiche_enfants($flux) {
73        if ($e = trouver_objet_exec($flux['args']['exec'])
74          AND $e['type'] == 'rubrique'
75          AND $e['edition'] == false) {
76                $id_rubrique = $flux['args']['id_rubrique'];
77
78                if ($GLOBALS['meta']["activer_breves"] == 'oui') {
79                        $lister_objets = charger_fonction('lister_objets','inc');
80                        $bouton_breves = '';
81                        $id_parent = sql_getfetsel('id_parent', 'spip_rubriques', 'id_rubrique='.$id_rubrique);
82                        if (autoriser('creerbrevedans','rubrique',$id_rubrique,NULL,array('id_parent'=>$id_parent))) {
83                                $bouton_breves .= icone_verticale(_T('breves:icone_nouvelle_breve'), generer_url_ecrire("breve_edit","id_rubrique=$id_rubrique&new=oui"), "breve-24.png","new", 'right')
84                                . "<br class='nettoyeur' />";
85                        }
86
87                        $flux['data'] .= $lister_objets('breves', array('titre'=>_T('breves:icone_ecrire_nouvel_article'), 'where'=>"statut != 'prop' AND statut != 'prepa'", 'id_rubrique'=>$id_rubrique, 'par'=>'date_heure'));
88                        $flux['data'] .= $bouton_breves;
89                }
90        }
91        return $flux;
92}
93
94
95
96
97/**
98 * Ajoute le nombre de brèves sur l'accueil privé
99 *
100 * @pipeline accueil_informations
101 *
102 * @param string $texte
103 *     HTML des informations générales concernant chaque type d'objet
104 *     sur la page d'accueil privée
105 * @return string
106 *     HTML des informations générales concernant chaque type d'objet
107 *     sur la page d'accueil privée
108 */
109function breves_accueil_informations($texte){
110        include_spip('base/abstract_sql');
111
112        $q = sql_select("COUNT(*) AS cnt, statut", 'spip_breves', '', 'statut', '','', "COUNT(*)<>0");
113
114        $cpt = array();
115        $cpt2 = array();
116        $where = false;
117        if ($GLOBALS['visiteur_session']['statut']=='0minirezo'){
118                $where = sql_allfetsel('id_objet','spip_auteurs_liens',"objet='rubrique' AND id_auteur=".intval($GLOBALS['visiteur_session']['id_auteur']));
119                if ($where){
120                        $where = sql_in('id_rubrique',array_map('reset',$where));
121                }
122        }
123        $defaut = $where ? '0/' : '';
124        while($row = sql_fetch($q)) {
125          $cpt[$row['statut']] = $row['cnt'];
126          $cpt2[$row['statut']] = $defaut;
127        }
128
129        if ($cpt) {
130                if ($where) {
131                        $q = sql_select("COUNT(*) AS cnt, statut", 'spip_breves', $where, "statut");
132                        while($row = sql_fetch($q)) {
133                                $r = $row['statut'];
134                                $cpt2[$r] = intval($row['cnt']) . '/';
135                        }
136                }
137                $texte .= "<div class='accueil_informations breves liste'>";
138                $texte .= "<h4>" . afficher_plus_info(generer_url_ecrire("breves"), "", _T('breves:info_breves_02')) . "</h4>";
139                $texte .= "<ul class='liste-items'>";
140                if (isset($cpt['prop'])) $texte .= "<li class='item'>"._T("texte_statut_attente_validation").": ".$cpt2['prop'].$cpt['prop'] . '</li>';
141                if (isset($cpt['publie'])) $texte .= "<li class='item on'>"._T("texte_statut_publies").": ".$cpt2['publie'] .$cpt['publie'] . '</li>';
142                $texte .= "</ul>";
143                $texte .= "</div>";
144        }
145        return $texte;
146}
147
148
149/**
150 * Compter les brèves dans une rubrique
151 *
152 * @pipeline objet_compte_enfants
153 *
154 * @param array $flux  Données du pipeline
155 * @return array       Données du pipeline
156 */
157function breves_objet_compte_enfants($flux){
158        if ($flux['args']['objet']=='rubrique'
159          AND $id_rubrique=intval($flux['args']['id_objet'])) {
160                // juste les publies ?
161                if (array_key_exists('statut', $flux['args']) and ($flux['args']['statut'] == 'publie')) {
162                        $flux['data']['breve'] = sql_countsel('spip_breves', "id_rubrique=".intval($id_rubrique)." AND (statut='publie')");
163                } else {
164                        $flux['data']['breve'] = sql_countsel('spip_breves', "id_rubrique=".intval($id_rubrique)." AND (statut='publie' OR statut='prop')");
165                }
166        }
167        return $flux;
168}
169
170
171/**
172 * Changer la langue des brèves si la rubrique change
173 *
174 * @pipeline trig_calculer_langues_rubriques
175 *
176 * @param array $flux  Données du pipeline
177 * @return array       Données du pipeline
178 */
179function breves_trig_calculer_langues_rubriques($flux){
180
181        $s = sql_select("A.id_breve AS id_breve, R.lang AS lang", "spip_breves AS A, spip_rubriques AS R", "A.id_rubrique = R.id_rubrique AND A.langue_choisie != 'oui' AND (A.lang='' OR R.lang<>'') AND R.lang<>A.lang");
182        while ($row = sql_fetch($s)) {
183                $id_breve = $row['id_breve'];
184                sql_updateq('spip_breves', array("lang"=>$row['lang'], 'langue_choisie'=>'non'), "id_breve=$id_breve");
185        }
186
187        return $flux;
188}
189
190
191/**
192 * Publier et dater les rubriques qui ont une brève publiée
193 *
194 * @pipeline calculer_rubriques
195 *
196 * @param array $flux  Données du pipeline
197 * @return array       Données du pipeline
198 */
199function breves_calculer_rubriques($flux){
200
201        $r = sql_select("R.id_rubrique AS id, max(A.date_heure) AS date_h", "spip_rubriques AS R, spip_breves AS A", "R.id_rubrique = A.id_rubrique AND R.date_tmp <= A.date_heure AND A.statut='publie' ", "R.id_rubrique");
202        while ($row = sql_fetch($r))
203          sql_updateq('spip_rubriques', array('statut_tmp'=>'publie', 'date_tmp'=>$row['date_h']), "id_rubrique=".$row['id']); 
204               
205        return $flux;
206}
207
208
209
210/**
211 * Ajouter les brèves à valider sur la page d'accueil
212 *
213 * @pipeline accueil_encours
214 *
215 * @param string $flux  HTML du bloc encours sur la page d'accueil privée
216 * @return string       HTML du bloc encours sur la page d'accueil privée
217**/
218function breves_accueil_encours($flux){
219        $lister_objets = charger_fonction('lister_objets','inc');
220
221
222        $flux .= $lister_objets('breves', array(
223                'titre'=>afficher_plus_info(generer_url_ecrire('breves'))._T('breves:info_breves_valider'),
224                'statut'=>array('prepa','prop'),
225                'par'=>'date_heure'));
226
227        return $flux;
228}
229
230
231
232/**
233 * Optimiser la base de données en supprimant les liens de brèves orphelins
234 *
235 * @pipeline optimiser_base_disparus
236 *
237 * @param array $flux  Données du pipeline
238 * @return array       Données du pipeline
239 */
240function breves_optimiser_base_disparus($flux){
241        $n = &$flux['data'];
242        $mydate = $flux['args']['date'];
243
244
245        # les breves qui sont dans une id_rubrique inexistante
246        $res = sql_select("B.id_breve AS id",
247                        "spip_breves AS B
248                        LEFT JOIN spip_rubriques AS R
249                          ON B.id_rubrique=R.id_rubrique",
250                        "R.id_rubrique IS NULL
251                         AND B.maj < $mydate");
252
253        $n+= optimiser_sansref('spip_breves', 'id_breve', $res);
254
255
256        //
257        // Breves
258        //
259
260        sql_delete("spip_breves", "statut='refuse' AND maj < $mydate");
261
262        return $flux;
263
264}
265
266/**
267 * Afficher le nombre de brèves dans chaque rubrique
268 *
269 * @pipeline boite_infos
270 *
271 * @param array $flux  Données du pipeline
272 * @return array       Données du pipeline
273 */
274function breves_boite_infos($flux){
275        if ($flux['args']['type']=='rubrique'
276          AND $id_rubrique = $flux['args']['id']){
277                if ($nb = sql_countsel('spip_breves',"statut='publie' AND id_rubrique=".intval($id_rubrique))){
278                        $nb = "<div>". singulier_ou_pluriel($nb, "breves:info_1_breve", "breves:info_nb_breves") . "</div>";
279                        if ($p = strpos($flux['data'],"<!--nb_elements-->"))
280                                $flux['data'] = substr_replace($flux['data'],$nb,$p,0);
281                }
282        }
283        return $flux;
284}
285
286/**
287 * Ajoute le formulaire de configuration des brèves sur la page de
288 * configuration des contenus
289 *
290 * @pipeline affiche_milieu
291 *
292 * @param array $flux  Données du pipeline
293 * @return array       Données du pipeline
294 */
295function breves_affiche_milieu($flux){
296        if ($flux["args"]["exec"] == "configurer_contenu") {
297                $flux["data"] .=  recuperer_fond('prive/squelettes/inclure/configurer',array('configurer'=>'configurer_breves'));
298        }
299        return $flux;
300}
301
302
303?>
Note: See TracBrowser for help on using the repository browser.