[SPIP] +2.1.12
[velocampus/web/www.git] / www / plugins / auto / couteau_suisse / couteau_suisse / outils / boites_privees.php
1 <?php
2
3 // Doc : http://www.spip-contrib.net/Les-Boites-Privees
4
5 if (!defined("_ECRIRE_INC_VERSION")) return;
6 include_spip('inc/presentation');
7 include_spip('inc/layer');
8
9 // compatibilite SQL pour SPIP 1.92
10 if(!defined('_SPIP19300')) {
11 include_spip('base/abstract_sql');
12 if(!function_exists('sql_select')) { function sql_select($s=array(),$f=array(),$w=array(),$g=array(),$o=array(),$l='',$h=array(),$sv='') {
13 return spip_abstract_select($s,$f,$w,$g,$o,$l,'',$h,'','',$sv); } }
14 if(!function_exists('sql_fetch')) { function sql_fetch($s) { return spip_fetch_array($s); } }
15 if(!function_exists('sql_update')) { function sql_update($t, $e, $w=array()) {
16 if(!is_array($t))$t=array($t); if(!is_array($e))$e=array($e); if(!is_array($w))$w=array($w);
17 $q=$r =''; foreach($e as $i=>$v) $e[$i] = "$i=$v";
18 return spip_query("UPDATE ".join(',',$t)." SET ".join(',',$e).(empty($w)?'':" WHERE ".join(' AND ',$w)));
19 } }
20 }
21
22 function boites_privees_affiche_gauche($flux){
23 $exec = &$flux['args']['exec'];
24 if(defined('boites_privees_TRI_AUTEURS') && ($exec=='article' || $exec=='articles')) {
25 include_spip('outils/boites_privees_action_rapide');
26 $flux['data'] .= action_rapide_tri_auteurs($flux['args']['id_article']);
27 }
28 if(defined('boites_privees_URLS_PROPRES'))
29 switch($exec) {
30 // SPIP>=3.0 : objets au singulier uniquement (autres 'case' pour compatibilite SPIP<3.0)
31 case 'article': case 'articles': $flux['data'] .= cs_urls_propres('article', $flux['args']['id_article']); break;
32 case 'rubrique': case 'naviguer': $flux['data'] .= cs_urls_propres('rubrique', $flux['args']['id_rubrique']); break;
33 case 'auteur': case 'auteur_infos': case 'auteurs_edit': $flux['data'] .= cs_urls_propres('auteur', $flux['args']['id_auteur']); break;
34 case 'breve': case 'breves_voir': $flux['data'] .= cs_urls_propres('breve', $flux['args']['id_breve']); break;
35 case 'mot': case 'mots_edit': $flux['data'] .= cs_urls_propres('mot', $flux['args']['id_mot']); break;
36 case 'site': case 'sites': $flux['data'] .= cs_urls_propres('syndic', $flux['args']['id_syndic']); break;
37 }
38 return cs_pipeline_boite_privee($flux, 'gauche');
39 }
40
41 function boites_privees_affiche_milieu($flux){
42 switch($flux['args']['exec']) {
43 // SPIP >= 3.0 : objets au singulier
44 case 'article': case 'articles': {
45 // texte original au format spip
46 if(defined('boites_privees_ARTICLES'))
47 $flux['data'] .= cs_formatspip($flux['args']['id_article']);
48 break;
49 }
50 default:
51 break;
52 }
53 return cs_pipeline_boite_privee($flux, 'milieu');
54 }
55
56 function boites_privees_affiche_droite($flux) {
57 switch($flux['args']['exec']) {
58 case 'auteurs':case 'auteur_infos':case 'auteurs_edit':
59 $flux['data'] .= cs_infos_webmasters() . cs_infos_connection(); break;
60 case 'admin_couteau_suisse':
61 $flux['data'] .= cs_boite_rss(); break;
62 default:
63 break;
64 }
65 return cs_pipeline_boite_privee($flux, 'droite');
66 }
67
68 /*
69 fonction appelant une liste de fonctions qui permettent :
70 - d'ajouter facilement des boites privees perso
71 - voire de modifier les boites fournies par le plugin
72 par exemple :
73 $GLOBALS['boites_privees_gauche'][] = 'ma_boite_privee';
74 function ma_boite_privee($flux, $exec) {
75 return $flux . debut_boite_info(true) . 'Youpi !!' . fin_boite_info(true);
76 }
77 */
78 function cs_pipeline_boite_privee(&$flux, $endroit) {
79 // liste de filtres
80 if(!is_array($GLOBALS[$globale = 'boites_privees_'.$endroit])) return $flux;
81 $liste = array_unique($GLOBALS[$globale]);
82 foreach($liste as $f)
83 if (function_exists($f)) $flux['data'] = $f($flux['data'], $flux['args']['exec']);
84 return $flux;
85 }
86
87 // pipeline utilise sous SPIP>=3, histoire de respecter l'ordre de stockage des auteurs d'objets
88 function boites_privees_pre_boucle($flux) {
89 if(defined('boites_privees_TRI_AUTEURS') && $flux->type_requete=='auteurs'
90 && count($L1 = $flux->join) && count($w = &$flux->where)>1 && $w[0][0]=="'='" && $w[1][0]=="'='") {
91 $L1 = array_keys($L1); // alias de la jointure
92 $flux->order[] = 'sqlfield_auteurs_objet('.$w[0][2].','.$w[1][2].','._q($L1[0]).','._q($flux->serveur).')';
93 }
94 return $flux;
95 }
96
97 function sqlfield_auteurs_objet($id_objet, $type_objet, $alias, $serveur) {
98 static $res = array();
99 if(!isset($r[$i = "$id_objet,$type_objet,$serveur"])) {
100 $t = sql_allfetsel('*','spip_auteurs_liens', "objet=$type_objet", '','','','',$serveur);
101 // hack qui conserve l'ordre de la table malgre les cles primaires
102 $r = array(); foreach($t as $e) if($e['id_objet'] == $id_objet) $r[] = $e["id_auteur"];
103 $r[$i] = count($r)?'FIELD('.$alias.'.id_auteur,'.join($r, ',').')':'';
104 }
105 return $r[$i];
106 }
107
108 function cs_boite_rss() {
109 include_spip('inc/autoriser');
110 if (!defined('boites_privees_CS') || !autoriser('configurer','csinfosrss')) return '';
111 return debut_boite_info(true)
112 . '<p><b>'._T('couteauprive:rss_titre').'</b></p><div class="cs_boite_rss"><div><p>'._T('couteauprive:rss_attente').'</p><noscript>'._T('couteauprive:outil_inactif').' !</noscript></div></div>'
113 /*.'<div style="text-align: right; font-size: 87%;"><a title="'._T('couteauprive:rss_desactiver').'" href="'
114 .generer_url_ecrire(_request('exec'),'cmd=switch&outil=rss_couteau_suisse').'">'._T('couteauprive:supprimer_cadre').'</a></div>'*/
115 . fin_boite_info(true);
116 }
117
118 function cs_infos_webmasters() {
119 include_spip('inc/autoriser');
120 if (!defined('boites_privees_WEBMASTERS') || !autoriser('configurer','csinfoswebmasters')) return '';
121 include_spip('cout_define');
122 list($w) = get_liste_administrateurs();
123 return cs_cadre_depliable(_T('couteau:webmestres'), 'bp_infos_webmasters',
124 "<p>".(strlen($w)?'&bull; '.str_replace(', ','<br/>&bull; ',$w):_T('couteau:variable_vide'))."</p>");
125 }
126
127 function cs_infos_connection() {
128 include_spip('inc/autoriser');
129 if (!defined('boites_privees_AUTEURS') || !autoriser('configurer','csinfosconnection')) return '';
130 include_spip('public/assembler');
131 return cs_cadre_depliable(_T('couteau:connections'), 'bp_infos_connection',
132 recuperer_fond('fonds/derniers_connectes'));
133 }
134
135 function cs_formatspip($id_article){
136 include_spip('public/assembler');
137 if(!$txt = recuperer_fond('fonds/format_spip', array('id_article'=>$id_article))) return '';
138 $txt = explode('@TITRE@=', $txt, 2);
139 // compatibilite avec SPIP 1.92
140 $compat = function_exists('bouton_block_depliable');
141 $bouton = $compat?bouton_block_depliable(cs_div_configuration().$txt[1], 'invisible', "formatspip")
142 :bouton_block_invisible("formatspip").cs_div_configuration().$txt[1];
143 $bloc = $compat?debut_block_depliable(false, "formatspip")
144 :debut_block_invisible("formatspip");
145 return debut_cadre_enfonce(find_in_path('/img/formatspip-24.png'), true, '', $bouton)
146 . $bloc . $txt[0] . fin_block()
147 . fin_cadre_enfonce(true);
148 }
149
150 function cs_urls_propres($type, $id) {
151 global $type_urls;
152 if(!$id) return '';
153 $res = "";
154 // SPIP >= 2.0
155 if(defined('_SPIP19300')) {
156 $url = generer_url_entite_absolue($id, $type, '', '', true);
157 $lien_public = "\n[<span>[". _T('couteau:urls_propres_lien'). "|{$url}->{$url}]</span>]\n\n";
158 $s = sql_select("url, date", "spip_urls", "id_objet=$id AND type='$type'", '', 'date DESC');
159 $now = date('Y-m-d H:i:s');
160 $info = ' ('._T('couteau:url_verrouillee').')';
161 while ($t = sql_fetch($s)) $res .= ($res?'<br />':'').'&bull;&nbsp;'.$t['url'].($t[date]>$now?$info:'')."\n";
162 // SPIP 1.92
163 } else {
164 // impossible de calculer l'url publique d'ici.
165 $table = $type.($type=='syndic'?'':'s');
166 $r = spip_query("SELECT url_propre FROM spip_$table WHERE id_$type=$id");
167 if ($r && $r = spip_fetch_array($r) ) {
168 if(!strlen($r=$r['url_propre'])) $r=_T('couteauprive:variable_vide');
169 $res .= "&bull;&nbsp;$r\n";
170 }
171 $lien_public = './?exec=action_rapide&arg=type_urls|URL_objet_191&format=iframe&type_objet='.$type.'&id_objet='.$id.'&script=foo';
172 $lien_public = '<iframe src="'.$lien_public.'" width="100%" style="border:none; height:4em;"></iframe>';
173 }
174
175 $format = in_array($type_urls, array('page', 'standard', 'html'))
176 ?_T('couteau:urls_propres_erreur')
177 :_T('couteau:urls_propres_objet');
178 $mem = $GLOBALS['class_spip_plus'];
179 $GLOBALS['class_spip_plus']=' class="spip"';
180 $res = propre(
181 _T('couteau:urls_propres_format', array(
182 'format'=>$type_urls,
183 'url'=>generer_url_ecrire('admin_couteau_suisse', 'cmd=descrip&outil=type_urls#cs_infos')
184 )). "\n\n"
185 . $format . "\n\n"
186 . '|{{'. _T('couteau:2pts', array(
187 'objet'=>strtoupper(filtrer_entites(_T('couteau:objet_'.$type))).' '.$id
188 ))."}}|\n"
189 . "|$res|")
190 // bug SPIP ?
191 . propre($lien_public);
192 $GLOBALS['class_spip_plus'] = $mem;
193 return cs_cadre_depliable(_T('couteau:urls_propres_titre'), 'bp_urls_propres', $res);
194 }
195
196 function cs_div_configuration() {
197 include_spip('inc/autoriser');
198 if(!autoriser('configurer', 'cs')) return '';
199 $img = defined('_SPIP30000')?chemin_image('secteur-12.png'):_DIR_IMG_PACK.'secteur-12.gif';
200 return '<div style="float:right; top:4px; right:-4px; position:relative;" ><a title="'._T('couteau:configurer').'" href="'.generer_url_ecrire('admin_couteau_suisse','cmd=descrip&outil=boites_privees#cs_infos').'"><img alt="'._T('couteau:configurer').'" src="'.$img.'"/></a></div>';
201 }
202
203 function cs_cadre_depliable($titre, $id, $texte) {
204 // SPIP 1.92
205 if(!defined('_SPIP19300')) return debut_cadre_relief(find_in_path('img/couteau-24.gif'), true)
206 . cs_div_configuration()
207 . "<div class='verdana1' style='text-align: left;'>"
208 . block_parfois_visible($id, "<b>$titre</b>", $texte, 'text-align: center;')
209 . "</div>"
210 . fin_cadre_relief(true);
211 // SPIP >= 2.0
212 return cadre_depliable(find_in_path('img/couteau-24.gif'), cs_div_configuration()."<b>$titre</b>", false /*true = deplie*/, $texte, $id);
213 }
214
215 ?>