You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

116 lines
4.0 KiB

<?php
/*
* Plugin Z-core
* (c) 2008-2010 Cedric MORIN Yterium.net
* Distribue sous licence GPL
*
*/
// demander a SPIP de definir 'type-page' dans le contexte du premier squelette
define('_DEFINIR_CONTEXTE_TYPE_PAGE',true);
define('_ZPIP',true);
// differencier le cache,
// la verification de credibilite de var_zajax sera faite dans public_styliser_dist
// mais ici on s'assure que la variable ne permet pas de faire une inclusion arbitraire
// avec un . ou un /
if ($z = _request('var_zajax')
AND !preg_match(",[^\w-],",$z)) {
if (!isset($GLOBALS['marqueur'])) {
$GLOBALS['marqueur'] = "$z:";
} else {
$GLOBALS['marqueur'] .= "$z:";
}
$GLOBALS['flag_preserver'] = true;
}
else {
// supprimer cette variable dangereuse
set_request('var_zajax','');
}
/**
* Passe un chemin en URL absolue uniquement si non vide
* utilise pour l'insertion d'URL conditionnee a l'existence d'un fichier (favicon.ico par exemple)
*
* @param string $path
* @param string $base
* @return string
*/
function url_absolue_si($path, $base='') {
if (!$path) return "";
if (!function_exists('url_absolue')){
include_spip('inc/filtres_mini');
}
return url_absolue($path, $base);
}
/**
* html Pour pouvoir masquer les logos sans les downloader en petit ecran
* il faut le mettre dans un conteneur parent que l'on masque
* http://timkadlec.com/2012/04/media-query-asset-downloading-results/
*
* On utilise un double conteneur :
* le premier fixe la largeur, le second la hauteur par le ratio hauteur/largeur
* grace a la technique des intrinsic-ratio ou padding-bottom-hack
* http://mobile.smashingmagazine.com/2013/09/16/responsive-images-performance-problem-case-study/
* http://alistapart.com/article/creating-intrinsic-ratios-for-video
*
* Le span interieur porte l'image en background CSS
* Le span conteneur ne porte pas de style display car trop prioritaire.
* Sans CSS il occupe la largeur complete disponible, car en inline par defaut
* Il suffit de lui mettre un float:xxx ou un display:block pour qu'il respecte la largeur initiale du logo
*
* Pour masquer les logos :
* .spip_logos {display:none}
* Pour forcer une taille maxi :
* .spip_logos {max-width:25%;float:right}
*
* @param $logo
* @return string
*/
function responsive_logo($logo){
if (!function_exists('extraire_balise'))
include_spip('inc/filtres');
if (!$logo
OR !$img = extraire_balise($logo,"img"))
return $logo;
list($h,$w) = taille_image($img);
$src = extraire_attribut($img,"src");
$class = extraire_attribut($img,"class");
// timestamper l'url si pas deja fait
if (strpos($src,"?")==false)
$src = timestamp($src);
if (defined('_STATIC_IMAGES_DOMAIN'))
$src = url_absolue($src,_STATIC_IMAGES_DOMAIN);
$hover = "";
if ($hover_on = extraire_attribut($img,"onmouseover")){
$hover_off = extraire_attribut($img,"onmouseout");
$hover_on = str_replace("this.src=","jQuery(this).css('background-image','url('+",$hover_on)."+')')";
$hover_off = str_replace("this.src=","jQuery(this).css('background-image','url('+",$hover_off)."+')')";
$hover = " onmouseover=\"$hover_on\" onmouseout=\"$hover_off\"";
}
$ratio = round($h*100/$w,2);
return "<span class='$class' style=\"width:{$w}px;\"><span class=\"img\" style=\"display:block;position:relative;height:0;width:100%;padding-bottom:{$ratio}%;overflow:hidden;background:url($src) no-repeat center;background-size:100%;\"$hover> </span></span>";
}
/**
* Compatibilite : permet de remplacer les [(#TEXTE|image_reduire{500})] des squelettes
* par un simple [(#TEXTE|adaptive_images)]
* Avec le plugin adaptive_images cela produire des images adaptives
*/
if (!defined('_DIR_PLUGIN_ADAPTIVE_IMAGES')){
// les images 1x sont au maximum en _ADAPTIVE_IMAGES_MAX_WIDTH_1x px de large dans la page
if (!defined('_ADAPTIVE_IMAGES_MAX_WIDTH_1x')) define('_ADAPTIVE_IMAGES_MAX_WIDTH_1x',640);
function adaptive_images($texte,$max_width_1x=_ADAPTIVE_IMAGES_MAX_WIDTH_1x){
if (!function_exists('filtrer'))
include_spip('inc/filtres');
$texte = filtrer('image_reduire',$texte,$max_width_1x,10000);
return filtrer('image_graver',$texte);
}
}
?>