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,11 +19,10 @@ wp.customize.menusPreview = ( function( $, api ) {
}; };
api.bind( 'preview-ready', function() { api.bind( 'preview-ready', function() {
self.previewReady.resolve(); api.preview.bind( 'active', function() {
} );
self.previewReady.done( function() {
self.init(); self.init();
} ); } );
} );
/** /**
* Bootstrap functionality. * Bootstrap functionality.
@ -36,7 +34,6 @@ 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 );
@ -52,11 +49,10 @@ wp.customize.menusPreview = ( function( $, api ) {
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 ] );
} }
} }
} ); } );
} );
}; };
/** /**