Make WordPress Core

Ticket #32841: 32841.diff

File 32841.diff, 3.1 KB (added by westonruter, 11 years ago)

https://github.com/xwp/wordpress-develop/pull/96

  • src/wp-includes/class-wp-customize-nav-menus.php

    diff --git src/wp-includes/class-wp-customize-nav-menus.php src/wp-includes/class-wp-customize-nav-menus.php
    index 3d9e60f..40a7f6b 100644
    final class WP_Customize_Nav_Menus { 
    795795         */
    796796        public function filter_wp_nav_menu( $nav_menu_content, $args ) {
    797797                if ( ! empty( $args->can_partial_refresh ) && ! empty( $args->instance_number ) ) {
    798                         $nav_menu_content = sprintf(
    799                                 '<div id="partial-refresh-menu-container-%1$d" class="partial-refresh-menu-container" data-instance-number="%1$d">%2$s</div>',
    800                                 $args->instance_number,
    801                                 $nav_menu_content
     798                        $nav_menu_content = preg_replace(
     799                                '/(?<=class=")/',
     800                                sprintf( 'partial-refreshable-nav-menu partial-refreshable-nav-menu-%1$d ', $args->instance_number ),
     801                                $nav_menu_content,
     802                                1 // Only update the class on the first element found, the menu container.
    802803                        );
    803804                }
    804805                return $nav_menu_content;
  • src/wp-includes/js/customize-preview-nav-menus.js

    diff --git src/wp-includes/js/customize-preview-nav-menus.js src/wp-includes/js/customize-preview-nav-menus.js
    index 2b6c994..4b9ac08 100644
    wp.customize.menusPreview = ( function( $, api ) { 
    163163         * @param {int} instanceNumber
    164164         */
    165165        self.refreshMenuInstance = function( instanceNumber ) {
    166                 var self = this, data, customized, container, request, wpNavArgs, instance;
     166                var self = this, data, customized, container, request, wpNavArgs, instance, containerInstanceClassName;
    167167
    168168                if ( ! self.navMenuInstanceArgs[ instanceNumber ] ) {
    169169                        throw new Error( 'unknown_instance_number' );
    170170                }
    171171                instance = self.navMenuInstanceArgs[ instanceNumber ];
    172172
    173                 container = $( '#partial-refresh-menu-container-' + String( instanceNumber ) );
     173                containerInstanceClassName = 'partial-refreshable-nav-menu-' + String( instanceNumber );
     174                container = $( '.' + containerInstanceClassName );
    174175
    175176                if ( ! instance.can_partial_refresh || 0 === container.length ) {
    176177                        api.preview.send( 'refresh' );
    wp.customize.menusPreview = ( function( $, api ) { 
    207208                        url: self.requestUri
    208209                } );
    209210                request.done( function( data ) {
    210                         var eventParam;
    211                         container.empty().append( $( data ) );
     211                        // If the menu is now not visible, refresh since the page layout may have changed.
     212                        if ( false === data ) {
     213                                api.preview.send( 'refresh' );
     214                                return;
     215                        }
     216
     217                        var eventParam, previousContainer = container;
     218                        container = $( data );
     219                        container.addClass( containerInstanceClassName );
     220                        container.addClass( 'partial-refreshable-nav-menu customize-partial-refreshing' );
     221                        previousContainer.replaceWith( container );
    212222                        eventParam = {
    213223                                instanceNumber: instanceNumber,
    214224                                wpNavArgs: wpNavArgs
    215225                        };
    216                         $( document ).trigger( 'customize-preview-menu-refreshed', [ eventParam ] );
    217                 } );
    218                 request.fail( function() {
    219                         // @todo provide some indication for why
    220                 } );
    221                 request.always( function() {
    222226                        container.removeClass( 'customize-partial-refreshing' );
     227                        $( document ).trigger( 'customize-preview-menu-refreshed', [ eventParam ] );
    223228                } );
    224229        };
    225230