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:
parent
55ffb38e28
commit
ccbd855021
@ -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 ] );
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} );
|
}
|
||||||
} );
|
} );
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user