WordPress : Custom_Background multiple, est-ce possible ?

Publié par Jean-Michel le

Est-il possible de créer plusieurs pages d’administration « arrière-plan personnalisé » ? Un site que je fais maintenant a besoin de 2 arrière-plans différents dans 2 domaines différents, j’aimerais vraiment donner à mon client la même expérience pour les deux arrière-plans en termes de couleur/image/sélection-répétition, etc. Des idées ?

Solution n°1 trouvée

Techniquement c’est possible (donc d’étendre le source wordpress), mais pas par défaut. Je répondrais donc non. La fonctionnalité de thème d’arrière-plan intégrée est destinée à un seul graphique uniquement par défaut.

Mais si vous décrivez un peu plus les « 2 domaines différents » sur lesquels vous écrivez, il pourrait y avoir quelque chose de sympa à suggérer à côté de cela.

Edit : Highlight pour MikeSchinkel. Les plugins étendent la source wordpress.

Solution n°2 trouvée

Salut @Amit :

La réponse est « Oui, c’est possible. » La question de suivi est « Voulez-vous vraiment? »

J’ai pensé que ce serait amusant de voir si je pouvais créer un plugin pour faire ce que vous demandez, alors j’ai décidé de voir si c’était possible. Bien sûr, j’ai pu le faire fonctionner, mais je crains que le code du plugin que j’ai écrit doive être si étroitement couplé au code existant dans WordPress qu’il pourrait facilement se casser lors d’une mise à jour principale.

Ce code gère tout le côté de la console d’administration en créant un nouvel élément de menu dans la section Apparence appelé « Arrière-plan spécial ». Ce qu’il ne fait pas, c’est fournir un moyen d’utiliser réellement l’arrière-plan ; c’est la phase deux du plugin et il faudra accrocher de nombreuses fonctions /wp-includes/themes.phpet franchement, je ne sais pas si j’aurai la chance d’écrire ce code.

La raison pour laquelle j’ai arrêté sans le faire est que je ne connaissais pas les exigences relatives à l’emplacement de l’arrière-plan spécial et à celui de l’arrière-plan normal. Je suppose que peut-être pour les pages sélectionnées et/ou les chemins d’URL ?

Néanmoins, voici le code du plugin (que vous pouvez également télécharger à partir de Gist):

<?php
/*
Plugin Name: Special Background
Plugin URI: http://wordpress.stackexchange.com/questions/972/
Description: Example to show how to add a special background using exiting background admin page in core.
Version: 0.1
Author: Mike Schinkel
Author URI: http://mikeschinkel.com/custom-wordpress-plugins/
*/
add_filter('admin_menu','add_special_background_menu_item');
function add_special_background_menu_item() {
    add_theme_page(__('Special Background'), __('Special Background'),'edit_theme_options','special-background','special_background_admin_page');
}
add_filter('admin_init','add_js_for_special_background');
function add_js_for_special_background() {
    global $custom_background;
    if (is_special_background_page()) {
        wp_enqueue_script('custom-background');
        wp_enqueue_style('farbtastic');
    }
    $hook = 'load-appearance_page_special-background';
    add_action($hook, array(&$custom_background, 'admin_load'));
    add_action($hook, array(&$custom_background, 'take_action'), 49);
    add_action($hook, array(&$custom_background, 'handle_upload'), 49);
}
add_filter('theme_mod_background_image',      'theme_mod_special_background_image');
add_filter('theme_mod_background_image_thumb','theme_mod_special_background_image_thumb');
add_filter('theme_mod_background_repeat',     'theme_mod_special_background_repeat');
add_filter('theme_mod_background_position_x', 'theme_mod_special_background_position_x');
add_filter('theme_mod_background_attachment', 'theme_mod_special_background_attachment');
add_filter('theme_mod_background_color',      'theme_mod_special_background_color');
function theme_mod_special_background_image($defaults) {
    return theme_mod_special_background_image_attrs('image',$defaults);
}
function theme_mod_special_background_image_thumb($defaults) {
    return theme_mod_special_background_image_attrs('image_thumb',$defaults);
}
function theme_mod_special_background_repeat($defaults) {
    return theme_mod_special_background_image_attrs('repeat',$defaults);
}
function theme_mod_special_background_position_x($defaults) {
    return theme_mod_special_background_image_attrs('position_x',$defaults);
}
function theme_mod_special_background_attachment($defaults) {
    return theme_mod_special_background_image_attrs('attachment',$defaults);
}
function theme_mod_special_background_color($defaults) {
    return theme_mod_special_background_image_attrs('color',$defaults);
}
function theme_mod_special_background_image_attrs($attr,$defaults) {
    if (is_special_background_page()) {
        $mods = get_option( 'mods_' . get_current_theme() );
        $defaults = (!empty($mods["special_background_{$attr}"]) ? $mods["special_background_{$attr}"] : '');
    }
    return $defaults;
}
add_filter('pre_update_option_mods_' . get_current_theme(),'pre_update_option_special_background_image',10,2);
function pre_update_option_special_background_image($newvalue, $oldvalue) {
    static $times_called = 0;
    if (!empty($_POST) && is_special_background_page()) {
        if ((isset($_POST['action']) && $_POST['action']=='save') || isset($_POST['reset-background']) || isset($_POST['remove-background'])) {
            switch ($times_called) {
                case 0:
                    $newvalue = special_background_image_value_swap('image',$newvalue,$oldvalue);
                    break;
                case 1:
                    $newvalue = special_background_image_value_swap('image_thumb',$newvalue,$oldvalue);
                    break;
            }
        } else {
            if ($times_called==0 && isset($_POST['background-repeat'])) {
                $newvalue = special_background_image_value_swap('repeat',$newvalue,$oldvalue);
            }
            if ($times_called==1 && isset($_POST['background-position-x'])) {
                $newvalue = special_background_image_value_swap('position_x',$newvalue,$oldvalue);
            }
            if ($times_called==2 && isset($_POST['background-attachment'])) {
                $newvalue = special_background_image_value_swap('attachment',$newvalue,$oldvalue);
            }
            if ($times_called==3 && isset($_POST['background-color'])) {
            $newvalue = special_background_image_value_swap('color',$newvalue,$oldvalue);
      }
    }
    $times_called++;
  }
  return $newvalue;
}
function special_background_image_value_swap($swap_what,$newvalue,$oldvalue) {
  $newvalue["special_background_{$swap_what}"] = $newvalue["background_{$swap_what}"];
  $newvalue["background_{$swap_what}"] = $oldvalue["background_{$swap_what}"];
  return $newvalue;
}
function special_background_admin_page() {
  global $custom_background;
  if (is_special_background_page()) {
    global $parent_file,$submenu_file,$title;
    $parent_file = 'themes.php';
    $submenu_file = 'themes.php?page=special-background';
    $title = 'Special Background';
    require_once(ABSPATH . 'wp-admin/admin-header.php');
    ob_start();
    $custom_background->admin_page();
    $html = ob_get_clean();
    $html = preg_replace('#<h2>([^<]+)</h2>#','<h2>Special Background</h2>',$html);
    echo $html;
    include(ABSPATH . 'wp-admin/admin-footer.php');
    exit;
  }
}
function is_special_background_page() {
  global $pagenow;
  return ($pagenow=='themes.php' &&
         isset($_GET['page']) && $_GET['page']== 'special-background');
}

Franchement, c’est trop de code pour expliquer de manière proactive, mais je serai heureux de répondre à des questions spécifiques.

Catégories : Wordpress

Jean-Michel

Jean-Michel est en charge de la partie blog du site. Il met en place la stratégie de contenu et répond aux questions fréquentes sur Wordpress.

0 commentaire

Laisser un commentaire

Avatar placeholder

Votre adresse e-mail ne sera pas publiée. Les champs obligatoires sont indiqués avec *