Twenty Twelve: better handling for cases where a background color is set to white or an empty value (like first run with no theme_mods set) and a background image is enabled, which resulted previously in a broken layout. Fixes #23586, props obenland.

git-svn-id: https://develop.svn.wordpress.org/trunk@23568 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Lance Willett 2013-03-01 17:14:59 +00:00
parent 436b32ef62
commit 3ba7b7e56a
2 changed files with 29 additions and 12 deletions

View File

@ -383,6 +383,7 @@ endif;
*/ */
function twentytwelve_body_class( $classes ) { function twentytwelve_body_class( $classes ) {
$background_color = get_background_color(); $background_color = get_background_color();
$background_image = get_background_image();
if ( ! is_active_sidebar( 'sidebar-1' ) || is_page_template( 'page-templates/full-width.php' ) ) if ( ! is_active_sidebar( 'sidebar-1' ) || is_page_template( 'page-templates/full-width.php' ) )
$classes[] = 'full-width'; $classes[] = 'full-width';
@ -395,10 +396,12 @@ function twentytwelve_body_class( $classes ) {
$classes[] = 'two-sidebars'; $classes[] = 'two-sidebars';
} }
if ( empty( $background_image ) ) {
if ( empty( $background_color ) ) if ( empty( $background_color ) )
$classes[] = 'custom-background-empty'; $classes[] = 'custom-background-empty';
elseif ( in_array( $background_color, array( 'fff', 'ffffff' ) ) ) elseif ( in_array( $background_color, array( 'fff', 'ffffff' ) ) )
$classes[] = 'custom-background-white'; $classes[] = 'custom-background-white';
}
// Enable custom font class only if the font CSS is queued to load. // Enable custom font class only if the font CSS is queued to load.
if ( wp_style_is( 'twentytwelve-fonts', 'queue' ) ) if ( wp_style_is( 'twentytwelve-fonts', 'queue' ) )
@ -445,6 +448,6 @@ add_action( 'customize_register', 'twentytwelve_customize_register' );
* @since Twenty Twelve 1.0 * @since Twenty Twelve 1.0
*/ */
function twentytwelve_customize_preview_js() { function twentytwelve_customize_preview_js() {
wp_enqueue_script( 'twentytwelve-customizer', get_template_directory_uri() . '/js/theme-customizer.js', array( 'customize-preview' ), '20120827', true ); wp_enqueue_script( 'twentytwelve-customizer', get_template_directory_uri() . '/js/theme-customizer.js', array( 'customize-preview' ), '20130301', true );
} }
add_action( 'customize_preview_init', 'twentytwelve_customize_preview_js' ); add_action( 'customize_preview_init', 'twentytwelve_customize_preview_js' );

View File

@ -18,15 +18,29 @@
} ); } );
} ); } );
// Hook into background color change and adjust body class value as needed. // Hook into background color/image change and adjust body class value as needed.
wp.customize( 'background_color', function( value ) { wp.customize( 'background_color', function( value ) {
value.bind( function( to ) { value.bind( function( to ) {
if ( '#ffffff' == to || '#fff' == to ) var body = $( 'body' );
$( 'body' ).addClass( 'custom-background-white' );
else if ( '' == to ) if ( ( '#ffffff' == to || '#fff' == to ) && 'none' == body.css( 'background-image' ) )
$( 'body' ).addClass( 'custom-background-empty' ); body.addClass( 'custom-background-white' );
else if ( '' == to && 'none' == body.css( 'background-image' ) )
body.addClass( 'custom-background-empty' );
else else
$( 'body' ).removeClass( 'custom-background-empty custom-background-white' ); body.removeClass( 'custom-background-empty custom-background-white' );
} );
} );
wp.customize( 'background_image', function( value ) {
value.bind( function( to ) {
var body = $( 'body' );
if ( '' != to )
body.removeClass( 'custom-background-empty custom-background-white' );
else if ( 'rgb(255, 255, 255)' == body.css( 'background-color' ) )
body.addClass( 'custom-background-white' );
else if ( 'rgb(230, 230, 230)' == body.css( 'background-color' ) && '' == _wpCustomizeSettings.values.background_color )
body.addClass( 'custom-background-empty' );
} ); } );
} ); } );
} )( jQuery ); } )( jQuery );