Make WordPress Core

Ticket #32841: 32841.4.diff

File 32841.4.diff, 5.1 KB (added by westonruter, 11 years ago)

Additional change: https://github.com/xwp/wordpress-develop/commit/c75bdcfb6b805ec520fcd254a10f3c980b9017ea

  • 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 7d32cbb..4335834 100644
    final class WP_Customize_Nav_Menus { 
    771771                        ( empty( $args['fallback_cb'] ) || is_string( $args['fallback_cb'] ) )
    772772                        &&
    773773                        ( empty( $args['walker'] ) || is_string( $args['walker'] ) )
     774                        &&
     775                        (
     776                                ! empty( $args['theme_location'] )
     777                                ||
     778                                ( ! empty( $args['menu'] ) && ( is_numeric( $args['menu'] ) || is_object( $args['menu'] ) ) )
     779                        )
    774780                );
    775781                $args['can_partial_refresh'] = $can_partial_refresh;
    776782
    final class WP_Customize_Nav_Menus { 
    779785                        $args['walker'] = '';
    780786                }
    781787
     788                // Replace object menu arg with a term_id menu arg, as this exports better to JS and is easier to compare hashes.
     789                if ( ! empty( $args['menu'] ) && is_object( $args['menu'] ) ) {
     790                        $args['menu'] = $args['menu']->term_id;
     791                }
     792
    782793                ksort( $args );
    783794                $args['args_hash'] = $this->hash_nav_menu_args( $args );
    784795
    final class WP_Customize_Nav_Menus { 
    799810         */
    800811        public function filter_wp_nav_menu( $nav_menu_content, $args ) {
    801812                if ( ! empty( $args->can_partial_refresh ) && ! empty( $args->instance_number ) ) {
    802                         $nav_menu_content = sprintf(
    803                                 '<div id="partial-refresh-menu-container-%1$d" class="partial-refresh-menu-container" data-instance-number="%1$d">%2$s</div>',
    804                                 $args->instance_number,
    805                                 $nav_menu_content
     813                        $nav_menu_content = preg_replace(
     814                                '/(?<=class=")/',
     815                                sprintf( 'partial-refreshable-nav-menu partial-refreshable-nav-menu-%1$d ', $args->instance_number ),
     816                                $nav_menu_content,
     817                                1 // Only update the class on the first element found, the menu container.
    806818                        );
    807819                }
    808820                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..bb8e792 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, menuId, 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
    175                 if ( ! instance.can_partial_refresh || 0 === container.length ) {
     176                if ( _.isNumber( instance.menu ) ) {
     177                        menuId = instance.menu;
     178                } else if ( instance.theme_location && api.has( 'nav_menu_locations[' + instance.theme_location + ']' ) ) {
     179                        menuId = api( 'nav_menu_locations[' + instance.theme_location + ']' ).get();
     180                }
     181
     182                if ( ! menuId || ! instance.can_partial_refresh || 0 === container.length ) {
    176183                        api.preview.send( 'refresh' );
    177184                        return;
    178185                }
     186                menuId = parseInt( menuId, 10 );
    179187
    180188                data = {
    181189                        nonce: self.previewCustomizeNonce, // for Customize Preview
    wp.customize.menusPreview = ( function( $, api ) { 
    187195                data[ self.renderQueryVar ] = '1';
    188196                customized = {};
    189197                api.each( function( setting, id ) {
    190                         // @todo We need to limit this to just the menu items that are associated with this menu/location.
    191                         if ( /^(nav_menu|nav_menu_locations)/.test( id ) ) {
     198                        // @todo Core should propagate the dirty state into the Preview as well so we can use that here.
     199                        if ( id === 'nav_menu[' + String( menuId ) + ']' || ( /^nav_menu_item\[/.test( id ) && setting() && menuId === setting().nav_menu_term_id ) ) {
    192200                                customized[ id ] = setting.get();
    193201                        }
    194202                } );
    wp.customize.menusPreview = ( function( $, api ) { 
    207215                        url: self.requestUri
    208216                } );
    209217                request.done( function( data ) {
    210                         var eventParam;
    211                         container.empty().append( $( data ) );
     218                        // If the menu is now not visible, refresh since the page layout may have changed.
     219                        if ( false === data ) {
     220                                api.preview.send( 'refresh' );
     221                                return;
     222                        }
     223
     224                        var eventParam, previousContainer = container;
     225                        container = $( data );
     226                        container.addClass( containerInstanceClassName );
     227                        container.addClass( 'partial-refreshable-nav-menu customize-partial-refreshing' );
     228                        previousContainer.replaceWith( container );
    212229                        eventParam = {
    213230                                instanceNumber: instanceNumber,
    214                                 wpNavArgs: wpNavArgs
     231                                wpNavArgs: wpNavArgs,
     232                                oldContainer: previousContainer,
     233                                newContainer: container
    215234                        };
    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() {
    222235                        container.removeClass( 'customize-partial-refreshing' );
     236                        $( document ).trigger( 'customize-preview-menu-refreshed', [ eventParam ] );
    223237                } );
    224238        };
    225239