Je voulais filtrer le titre du blog affiché dans l'en-tête pour appliquer différents styles CSS à différentes parties/mots du titre. J'ai donc ajouté la fonction ci-dessous à la fonction du thème de mon enfant (WP 4.7) Twenty Seventeen (===) et cela a très bien fonctionné. Le problème est que cette fonction a également ajouté le code CSS au méta-titre affiché dans la barre de titre. Comment réparer ça?
/** Format the site title parts **/
add_filter( 'bloginfo', 'format_site_title_parts', 10, 2 );
function format_site_title_parts( $text, $show ){
if ('name' == $show) {
$text = "<span class='info-style'>Info</span>" . "<span class='psi-style'>Psi</span>" . "<span class='md-style'>.md</span>";
}
return $text;
}
Supprimez ce filtre/cette fonction et appliquez votre marquage dans le fichier de modèle/page PHP. Si vous avez besoin d'aide, postez où vous écrivez le titre.
Voici comment je pourrais configurer cela en utilisant une classe:
if ( ! class_exists( 'ThemeCustomizations' ) ) {
class ThemeCustomizations {
static $inBody = false;
public static function set_in_body_true() {
static::$inBody = true;
}
public static function set_in_body_false() {
static::$inBody = false;
}
public static function filter_bloginfo( $name, $show = null ) {
if ( 'name' == $show && static::$inBody ) {
$name = "<span class='info-style'>Info</span>" . "<span class='psi-style'>Psi</span>" . "<span class='md-style'>.md</span>";
return "$name";
} else {
return $name;
}
}
}
}
add_action( 'wp_head', array ( 'ThemeCustomizations', 'set_in_body_true' ), PHP_INT_MAX );
add_action( 'wp_footer', array ( 'ThemeCustomizations', 'set_in_body_false' ), 0 );
add_action( 'bloginfo', array ( 'ThemeCustomizations', 'filter_bloginfo' ), 10, 2 );
Et en utilisant la variable de portée statique d'une fonction:
function prefix__is_in_body( $isTrue = null ) {
// static initializer is false
static $inBody = false;
// only overwrite if boolean supplied
if ( is_bool( $isTrue ) ) {
$inBody = $isTrue;
}
// return regardless of getter/setter
return $inBody;
}
add_action( 'wp_head', function(){ prefix__is_in_body(true); }, PHP_INT_MAX );
add_action( 'wp_footer', function(){ prefix__is_in_body(false); }, 0 );
add_action( 'bloginfo', function($name, $show = null){
if ( 'name' == $show && prefix__is_in_body() ) {
$name = "<span class='info-style'>Info</span>" . "<span class='psi-style'>Psi</span>" . "<span class='md-style'>.md</span>";
return "$name";
} else {
return $name;
}
}, 10, 2 );
Singleton
& Factory
patterns + PHP méthodes magiques.
if ( ! class_exists( 'Magic' ) ) {
class Magic {
private static $__ = array ();
public $_ = array ();
function __construct( $args = null ) {
if ( is_array( $args ) ) {
foreach ( $args as $k => $v ) {
$this->{$k} = $v;
}
}
return $this;
}
public static function instance( $id = '', $args = null ) {
if ( ! isset( self::$__[ $id ] ) ) {
self::$__[ $id ] = new Magic($args);
}
return self::$__[ $id ];
}
public function __get( $k ) {
return isset( $this->_[ $k ] ) ? $this->_[ $k ] : null;
}
public function __set( $k, $v ) {
return $this->_[ $k ] = $v;
}
public function __call( $k, $a ) {
if ( isset($this->_[ $k ]) && is_callable( $this->_[ $k ] ) ) {
return call_user_func_array( $this->_[ $k ], $a );
}
}
}
}
Maintenant, avec la classe Magic
, vous pouvez le faire;
$m = Magic::instance( '', array (
'isBody' => false,
'action_wp_head' => function() { Magic::instance()->isBody = true; },
'action_wp_footer' => function() { Magic::instance()->isBody = false; },
'filter_wp_bloginfo' => function( $output, $show ) {
return ( 'name' == $show && Magic::instance()->isBody ) ? '<span class="info-style">Info</span><span class="psi-style">Psi</span><span class="md-style">.md</span>' : $output;
},
));
add_action( 'wp_head', array ( $m, 'action_wp_head' ), PHP_INT_MAX );
add_action( 'wp_footer', array ( $m, 'action_wp_footer' ), 0 );
add_filter( 'bloginfo', array ( $m, 'filter_wp_bloginfo' ), 10, 2 );
Donc, voici ce que j'ai enfin utilisé (crédit de code à Alexandros Georgiou ). Je ne sais pas si c'est une bonne solution, mais j'aime bien avoir un seul endroit commun (functions.php) pour contrôler mon thème enfant.
$twentyseventeen_child_in_body = false;
function twentyseventeen_child_action_wp_head_finished() {
global $twentyseventeen_child_in_body;
$twentyseventeen_child_in_body = true;
}
add_action( 'wp_head', 'twentyseventeen_child_action_wp_head_finished', PHP_INT_MAX );
function twentyseventeen_child_action_wp_footer_started() {
global $twentyseventeen_child_in_body;
$twentyseventeen_child_in_body = false;
}
add_action( 'wp_footer', 'twentyseventeen_child_action_wp_footer_started', 0 );
function twentyseventeen_child_filter_bloginfo( $name, $show = null ) {
global $twentyseventeen_child_in_body;
if ( 'name' == $show && $twentyseventeen_child_in_body ) {
$name = "<span class='info-style'>Info</span>" . "<span class='psi-style'>Psi</span>" . "<span class='md-style'>.md</span>";
return "$name";
} else {
return $name;
}
}
add_filter( 'bloginfo', 'twentyseventeen_child_filter_bloginfo', 10, 2 );