Make WordPress Core


Ignore:
Timestamp:
12/10/2016 06:29:12 AM (8 years ago)
Author:
westonruter
Message:

Customize: Fix inability to delete nav menus by preventing preview filters from being added during customize_save admin ajax request.

Also prevent setting nav_menu_locations[...] values to NaN which gets sent as null.

Amends [38810].
See #30937.
Fixes #39103.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/wp-includes/class-wp-customize-nav-menus.php

    r39506 r39558  
    532532    public function customize_register() {
    533533
    534         /*
    535          * Preview settings for nav menus early so that the sections and controls will be added properly.
    536          * See https://github.com/xwp/wp-customize-snapshots/blob/962586659688a5b1fd9ae93618b7ce2d4e7a421c/php/class-customize-snapshot-manager.php#L506-L543
    537          */
     534        // Preview settings for nav menus early so that the sections and controls will be added properly.
    538535        $nav_menus_setting_ids = array();
    539536        foreach ( array_keys( $this->manager->unsanitized_post_values() ) as $setting_id ) {
     
    543540        }
    544541        $this->manager->add_dynamic_settings( $nav_menus_setting_ids );
    545         foreach ( $nav_menus_setting_ids as $setting_id ) {
    546             $setting = $this->manager->get_setting( $setting_id );
    547             if ( $setting ) {
    548                 $setting->preview();
     542        if ( ! $this->manager->doing_ajax( 'customize_save' ) ) {
     543            foreach ( $nav_menus_setting_ids as $setting_id ) {
     544                $setting = $this->manager->get_setting( $setting_id );
     545                if ( $setting ) {
     546                    $setting->preview();
     547                }
    549548            }
    550549        }
Note: See TracChangeset for help on using the changeset viewer.