3 /***************************************************************************\
4 * SPIP, Systeme de publication pour l'internet *
6 * Copyright (c) 2001-2016 *
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 \***************************************************************************/
13 if (!defined('_ECRIRE_INC_VERSION')) return;
16 // Fonction des balises #LOGO_XXXX
17 // (les balises portant ce type de nom sont traitees en bloc ici)
20 // http://doc.spip.org/@balise_LOGO__dist
21 function balise_LOGO__dist ($p) {
23 preg_match(",^LOGO_([A-Z_]+?)(|_NORMAL|_SURVOL|_RUBRIQUE)$,i", $p->nom_champ
, $regs);
24 $type = strtolower($regs[1]);
25 $suite_logo = $regs[2];
27 // cas de #LOGO_SITE_SPIP
28 if ($type == 'site_spip') {
30 $_id_objet = "\"'0'\"";
33 $id_objet = id_table_objet($type);
34 if (!isset($_id_objet) OR !$_id_objet)
35 $_id_objet = champ_sql($id_objet, $p);
37 $fichier = ($p->etoile
=== '**') ?
-1 : 0;
42 if ($p->param
AND !$p->param
[0][0]) {
43 $params = $p->param
[0];
45 foreach($params as $a) {
46 if ($a[0]->type
=== 'texte') {
50 elseif (in_array($n,array('top','left','right','center','bottom')))
52 elseif (in_array($n,array('auto','icone','apercu','vignette')))
55 else $lien = calculer_liste($a, $p->descr
, $p->boucles
, $p->id_boucle
);
60 $coord_x = !$coord ?
0 : intval(array_shift($coord));
61 $coord_y = !$coord ?
0 : intval(array_shift($coord));
63 if ($p->etoile
=== '*') {
64 include_spip('balise/url_');
65 $lien = generer_generer_url_arg($type, $p, $_id_objet);
68 $connect = $p->id_boucle ?
$p->boucles
[$p->id_boucle
]->sql_serveur
:'';
69 if ($type == 'document') {
70 $qconnect = _q($connect);
71 $doc = "quete_document($_id_objet, $qconnect)";
73 $code = "quete_logo_file($doc, $qconnect)";
74 else $code = "quete_logo_document($doc, " . ($lien ?
$lien : "''") . ", '$align', '$mode_logo', $coord_x, $coord_y, $qconnect)";
75 // (x=non-faux ? y : '') pour affecter x en retournant y
76 if ($p->descr
['documents'])
77 $code = '(($doublons["documents"] .= ",". '
83 spip_log("Les logos distants ne sont pas prevus");
85 $code = logo_survol($id_objet, $_id_objet, $type, $align, $fichier, $lien, $p, $suite_logo);
88 // demande de reduction sur logo avec ecriture spip 2.1 : #LOGO_xxx{200, 0}
89 if ($coord_x OR $coord_y) {
90 $code = "filtrer('image_graver',filtrer('image_reduire',".$code.", '$coord_x', '$coord_y'))";
94 $p->interdire_scripts
= false;
98 function logo_survol($id_objet, $_id_objet, $type, $align, $fichier, $lien, $p, $suite)
100 $code = "quete_logo('$id_objet', '" .
101 (($suite == '_SURVOL') ?
'off' :
102 (($suite == '_NORMAL') ?
'on' : 'ON')) .
104 (($suite == '_RUBRIQUE') ?
105 champ_sql("id_rubrique", $p) :
106 (($type == 'rubrique') ?
"quete_parent($_id_objet)" : "''")) .
107 ", " . intval($fichier) . ")";
109 if ($fichier) return $code;
111 $code = "\n((!is_array(\$l = $code)) ? '':\n (" .
112 '"<img class=\"spip_logos\" alt=\"\"' .
113 ($align ?
" align=\\\"$align\\\"" : '')
114 . ' src=\"$l[0]\"" . $l[2] . ($l[1] ? " onmouseover=\"this.src=\'$l[1]\'\" onmouseout=\"this.src=\'$l[0]\'\"" : "") . \' />\'))';
116 if (!$lien) return $code;
118 return ('(strlen($logo='.$code.')?\'<a href="\' .' . $lien . ' . \'">\' . $logo . \'</a>\':\'\')');