Customizer: Defer listening to nav menu setting changes until active.

Defer the preview starting to listen to setting changes until after the Customizer has synced settings into the preview. This ensures that any differences between the JS and PHP representations of the settings won't cause an infinite refresh.

See #32911.
Fixes #32894.


git-svn-id: https://develop.svn.wordpress.org/trunk@33134 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Weston Ruter 2015-07-08 20:41:18 +00:00
parent 55ffb38e28
commit ccbd855021

View File

@ -9,7 +9,6 @@ wp.customize.menusPreview = ( function( $, api ) {
renderNonceValue: null, renderNonceValue: null,
renderNoncePostKey: null, renderNoncePostKey: null,
previewCustomizeNonce: null, previewCustomizeNonce: null,
previewReady: $.Deferred(),
requestUri: '/', requestUri: '/',
theme: { theme: {
active: false, active: false,
@ -20,10 +19,9 @@ wp.customize.menusPreview = ( function( $, api ) {
}; };
api.bind( 'preview-ready', function() { api.bind( 'preview-ready', function() {
self.previewReady.resolve(); api.preview.bind( 'active', function() {
} ); self.init();
self.previewReady.done( function() { } );
self.init();
} ); } );
/** /**
@ -36,26 +34,24 @@ wp.customize.menusPreview = ( function( $, api ) {
$.extend( self, _wpCustomizePreviewNavMenusExports ); $.extend( self, _wpCustomizePreviewNavMenusExports );
} }
self.previewReady.done( function() { api.each( function( setting, id ) {
api.each( function( setting, id ) { setting.id = id;
setting.id = id; self.bindListener( setting );
self.bindListener( setting ); } );
} );
api.preview.bind( 'setting', function( args ) { api.preview.bind( 'setting', function( args ) {
var id, value, setting; var id, value, setting;
args = args.slice(); args = args.slice();
id = args.shift(); id = args.shift();
value = args.shift(); value = args.shift();
if ( ! api.has( id ) ) { if ( ! api.has( id ) ) {
// Currently customize-preview.js is not creating settings for dynamically-created settings in the pane; so we have to do it // Currently customize-preview.js is not creating settings for dynamically-created settings in the pane; so we have to do it
setting = api.create( id, value ); // @todo This should be in core setting = api.create( id, value ); // @todo This should be in core
setting.id = id; setting.id = id;
if ( self.bindListener( setting ) ) { if ( self.bindListener( setting ) ) {
setting.callbacks.fireWith( setting, [ setting(), setting() ] ); setting.callbacks.fireWith( setting, [ setting(), null ] );
}
} }
} ); }
} ); } );
}; };