Customizer: Nav Menus JS cleanup, first round

* In `init`, settings should be fresh and set to default values before extending
* When looping via `_.each`, pass `this` as 3rd arg to bind context
* Settings should be encapsulated in the module, instead of being exposed as static class props
* `currentRefreshMenuInstanceDebouncedCalls` should be encapsulated and renamed, instead of being the longest symbol in the entire codebase

See #32911.


git-svn-id: https://develop.svn.wordpress.org/trunk@33345 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Scott Taylor 2015-07-21 16:13:36 +00:00
parent e2fab60c51
commit 940b06cff2

View File

@ -2,21 +2,22 @@
wp.customize.menusPreview = ( function( $, api ) { wp.customize.menusPreview = ( function( $, api ) {
'use strict'; 'use strict';
var self; var currentRefreshDebounced = {},
refreshDebounceDelay = 200,
self = { settings = {},
renderQueryVar: null, defaultSettings = {
renderNonceValue: null, renderQueryVar: null,
renderNoncePostKey: null, renderNonceValue: null,
previewCustomizeNonce: null, renderNoncePostKey: null,
requestUri: '/', previewCustomizeNonce: null,
theme: { requestUri: '/',
active: false, theme: {
stylesheet: '' active: false,
stylesheet: ''
},
navMenuInstanceArgs: {}
}, },
navMenuInstanceArgs: {}, self = {};
refreshDebounceDelay: 200
};
api.bind( 'preview-ready', function() { api.bind( 'preview-ready', function() {
api.preview.bind( 'active', function() { api.preview.bind( 'active', function() {
@ -30,8 +31,9 @@ wp.customize.menusPreview = ( function( $, api ) {
self.init = function() { self.init = function() {
var self = this, initializedSettings = {}; var self = this, initializedSettings = {};
settings = _.extend( {}, defaultSettings );
if ( 'undefined' !== typeof _wpCustomizePreviewNavMenusExports ) { if ( 'undefined' !== typeof _wpCustomizePreviewNavMenusExports ) {
$.extend( self, _wpCustomizePreviewNavMenusExports ); _.extend( settings, _wpCustomizePreviewNavMenusExports );
} }
api.each( function( setting, id ) { api.each( function( setting, id ) {
@ -134,7 +136,7 @@ wp.customize.menusPreview = ( function( $, api ) {
* @param {int} menuId * @param {int} menuId
*/ */
self.refreshMenu = function( menuId ) { self.refreshMenu = function( menuId ) {
var self = this, assignedLocations = []; var assignedLocations = [];
api.each(function( setting, id ) { api.each(function( setting, id ) {
var matches = id.match( /^nav_menu_locations\[(.+?)]/ ); var matches = id.match( /^nav_menu_locations\[(.+?)]/ );
@ -143,11 +145,11 @@ wp.customize.menusPreview = ( function( $, api ) {
} }
}); });
_.each( self.navMenuInstanceArgs, function( navMenuArgs, instanceNumber ) { _.each( settings.navMenuInstanceArgs, function( navMenuArgs, instanceNumber ) {
if ( menuId === navMenuArgs.menu || -1 !== _.indexOf( assignedLocations, navMenuArgs.theme_location ) ) { if ( menuId === navMenuArgs.menu || -1 !== _.indexOf( assignedLocations, navMenuArgs.theme_location ) ) {
self.refreshMenuInstanceDebounced( instanceNumber ); this.refreshMenuInstanceDebounced( instanceNumber );
} }
} ); }, this );
}; };
/** /**
@ -157,12 +159,12 @@ wp.customize.menusPreview = ( function( $, api ) {
*/ */
self.refreshMenuLocation = function( location ) { self.refreshMenuLocation = function( location ) {
var foundInstance = false; var foundInstance = false;
_.each( self.navMenuInstanceArgs, function( navMenuArgs, instanceNumber ) { _.each( settings.navMenuInstanceArgs, function( navMenuArgs, instanceNumber ) {
if ( location === navMenuArgs.theme_location ) { if ( location === navMenuArgs.theme_location ) {
self.refreshMenuInstanceDebounced( instanceNumber ); this.refreshMenuInstanceDebounced( instanceNumber );
foundInstance = true; foundInstance = true;
} }
} ); }, this );
if ( ! foundInstance ) { if ( ! foundInstance ) {
api.preview.send( 'refresh' ); api.preview.send( 'refresh' );
} }
@ -176,10 +178,10 @@ wp.customize.menusPreview = ( function( $, api ) {
self.refreshMenuInstance = function( instanceNumber ) { self.refreshMenuInstance = function( instanceNumber ) {
var self = this, data, menuId, customized, container, request, wpNavArgs, instance, containerInstanceClassName; var self = this, data, menuId, customized, container, request, wpNavArgs, instance, containerInstanceClassName;
if ( ! self.navMenuInstanceArgs[ instanceNumber ] ) { if ( ! settings.navMenuInstanceArgs[ instanceNumber ] ) {
throw new Error( 'unknown_instance_number' ); throw new Error( 'unknown_instance_number' );
} }
instance = self.navMenuInstanceArgs[ instanceNumber ]; instance = settings.navMenuInstanceArgs[ instanceNumber ];
containerInstanceClassName = 'partial-refreshable-nav-menu-' + String( instanceNumber ); containerInstanceClassName = 'partial-refreshable-nav-menu-' + String( instanceNumber );
container = $( '.' + containerInstanceClassName ); container = $( '.' + containerInstanceClassName );
@ -197,13 +199,13 @@ wp.customize.menusPreview = ( function( $, api ) {
menuId = parseInt( menuId, 10 ); menuId = parseInt( menuId, 10 );
data = { data = {
nonce: self.previewCustomizeNonce, // for Customize Preview nonce: settings.previewCustomizeNonce, // for Customize Preview
wp_customize: 'on' wp_customize: 'on'
}; };
if ( ! self.theme.active ) { if ( ! settings.theme.active ) {
data.theme = self.theme.stylesheet; data.theme = settings.theme.stylesheet;
} }
data[ self.renderQueryVar ] = '1'; data[ settings.renderQueryVar ] = '1';
// Gather settings to send in partial refresh request. // Gather settings to send in partial refresh request.
customized = {}; customized = {};
@ -225,7 +227,7 @@ wp.customize.menusPreview = ( function( $, api ) {
} }
} ); } );
data.customized = JSON.stringify( customized ); data.customized = JSON.stringify( customized );
data[ self.renderNoncePostKey ] = self.renderNonceValue; data[ settings.renderNoncePostKey ] = settings.renderNonceValue;
wpNavArgs = $.extend( {}, instance ); wpNavArgs = $.extend( {}, instance );
data.wp_nav_menu_args_hash = wpNavArgs.args_hash; data.wp_nav_menu_args_hash = wpNavArgs.args_hash;
@ -236,7 +238,7 @@ wp.customize.menusPreview = ( function( $, api ) {
request = wp.ajax.send( null, { request = wp.ajax.send( null, {
data: data, data: data,
url: self.requestUri url: settings.requestUri
} ); } );
request.done( function( data ) { request.done( function( data ) {
// If the menu is now not visible, refresh since the page layout may have changed. // If the menu is now not visible, refresh since the page layout may have changed.
@ -261,17 +263,15 @@ wp.customize.menusPreview = ( function( $, api ) {
} ); } );
}; };
self.currentRefreshMenuInstanceDebouncedCalls = {};
self.refreshMenuInstanceDebounced = function( instanceNumber ) { self.refreshMenuInstanceDebounced = function( instanceNumber ) {
if ( self.currentRefreshMenuInstanceDebouncedCalls[ instanceNumber ] ) { if ( currentRefreshDebounced[ instanceNumber ] ) {
clearTimeout( self.currentRefreshMenuInstanceDebouncedCalls[ instanceNumber ] ); clearTimeout( currentRefreshDebounced[ instanceNumber ] );
} }
self.currentRefreshMenuInstanceDebouncedCalls[ instanceNumber ] = setTimeout( currentRefreshDebounced[ instanceNumber ] = setTimeout(
function() { function() {
self.refreshMenuInstance( instanceNumber ); self.refreshMenuInstance( instanceNumber );
}, },
self.refreshDebounceDelay refreshDebounceDelay
); );
}; };