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.
 
 
 
 

126 lines
4.1 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);
}
}