Customizer: Improve JS templates for Panels and Sections added in [32658].
* Always fall back to using the default template if no custom template exists. * Provide a set of default params when constructing new `Section` and `Panel` objects. Includes QUnit tests. Props celloexpressions, westonruter, ocean90. Fixes #30737. git-svn-id: https://develop.svn.wordpress.org/trunk@32681 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
40df2f48bf
commit
5ae2271098
@ -157,18 +157,40 @@
|
|||||||
defaultActiveArguments: { duration: 'fast', completeCallback: $.noop },
|
defaultActiveArguments: { duration: 'fast', completeCallback: $.noop },
|
||||||
defaultExpandedArguments: { duration: 'fast', completeCallback: $.noop },
|
defaultExpandedArguments: { duration: 'fast', completeCallback: $.noop },
|
||||||
containerType: 'container',
|
containerType: 'container',
|
||||||
|
defaults: {
|
||||||
|
title: '',
|
||||||
|
description: '',
|
||||||
|
priority: 100,
|
||||||
|
type: 'default',
|
||||||
|
content: null,
|
||||||
|
active: true,
|
||||||
|
instanceNumber: null
|
||||||
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @since 4.1.0
|
* @since 4.1.0
|
||||||
*
|
*
|
||||||
* @param {String} id
|
* @param {string} id - The ID for the container.
|
||||||
* @param {Object} options
|
* @param {object} options - Object containing one property: params.
|
||||||
|
* @param {object} options.params - Object containing the following properties.
|
||||||
|
* @param {string} options.params.title - Title shown when panel is collapsed and expanded.
|
||||||
|
* @param {string=} [options.params.description] - Description shown at the top of the panel.
|
||||||
|
* @param {number=100} [options.params.priority] - The sort priority for the panel.
|
||||||
|
* @param {string=default} [options.params.type] - The type of the panel. See wp.customize.panelConstructor.
|
||||||
|
* @param {string=} [options.params.content] - The markup to be used for the panel container. If empty, a JS template is used.
|
||||||
|
* @param {boolean=true} [options.params.active] - Whether the panel is active or not.
|
||||||
*/
|
*/
|
||||||
initialize: function ( id, options ) {
|
initialize: function ( id, options ) {
|
||||||
var container = this;
|
var container = this;
|
||||||
container.id = id;
|
container.id = id;
|
||||||
container.params = {};
|
options = options || {};
|
||||||
$.extend( container, options || {} );
|
|
||||||
|
options.params = _.defaults(
|
||||||
|
options.params || {},
|
||||||
|
container.defaults
|
||||||
|
);
|
||||||
|
|
||||||
|
$.extend( container, options );
|
||||||
container.templateSelector = 'customize-' + container.containerType + '-' + container.params.type;
|
container.templateSelector = 'customize-' + container.containerType + '-' + container.params.type;
|
||||||
container.container = $( container.params.content );
|
container.container = $( container.params.content );
|
||||||
if ( 0 === container.container.length ) {
|
if ( 0 === container.container.length ) {
|
||||||
@ -202,7 +224,7 @@
|
|||||||
|
|
||||||
api.utils.bubbleChildValueChanges( container, [ 'priority', 'active' ] );
|
api.utils.bubbleChildValueChanges( container, [ 'priority', 'active' ] );
|
||||||
|
|
||||||
container.priority.set( isNaN( container.params.priority ) ? 100 : container.params.priority );
|
container.priority.set( container.params.priority );
|
||||||
container.active.set( container.params.active );
|
container.active.set( container.params.active );
|
||||||
container.expanded.set( false );
|
container.expanded.set( false );
|
||||||
},
|
},
|
||||||
@ -386,10 +408,12 @@
|
|||||||
|
|
||||||
if ( 0 !== $( '#tmpl-' + container.templateSelector ).length ) {
|
if ( 0 !== $( '#tmpl-' + container.templateSelector ).length ) {
|
||||||
template = wp.template( container.templateSelector );
|
template = wp.template( container.templateSelector );
|
||||||
|
} else {
|
||||||
|
template = wp.template( 'customize-' + container.containerType + '-default' );
|
||||||
|
}
|
||||||
if ( template && container.container ) {
|
if ( template && container.container ) {
|
||||||
return $.trim( template( container.params ) );
|
return $.trim( template( container.params ) );
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return '<li></li>';
|
return '<li></li>';
|
||||||
}
|
}
|
||||||
@ -403,12 +427,32 @@
|
|||||||
*/
|
*/
|
||||||
api.Section = Container.extend({
|
api.Section = Container.extend({
|
||||||
containerType: 'section',
|
containerType: 'section',
|
||||||
|
defaults: {
|
||||||
|
title: '',
|
||||||
|
description: '',
|
||||||
|
priority: 100,
|
||||||
|
type: 'default',
|
||||||
|
content: null,
|
||||||
|
active: true,
|
||||||
|
instanceNumber: null,
|
||||||
|
panel: null,
|
||||||
|
customizeAction: ''
|
||||||
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @since 4.1.0
|
* @since 4.1.0
|
||||||
*
|
*
|
||||||
* @param {String} id
|
* @param {string} id - The ID for the section.
|
||||||
* @param {Array} options
|
* @param {object} options - Object containing one property: params.
|
||||||
|
* @param {object} options.params - Object containing the following properties.
|
||||||
|
* @param {string} options.params.title - Title shown when section is collapsed and expanded.
|
||||||
|
* @param {string=} [options.params.description] - Description shown at the top of the section.
|
||||||
|
* @param {number=100} [options.params.priority] - The sort priority for the section.
|
||||||
|
* @param {string=default} [options.params.type] - The type of the section. See wp.customize.sectionConstructor.
|
||||||
|
* @param {string=} [options.params.content] - The markup to be used for the section container. If empty, a JS template is used.
|
||||||
|
* @param {boolean=true} [options.params.active] - Whether the section is active or not.
|
||||||
|
* @param {string} options.params.panel - The ID for the panel this section is associated with.
|
||||||
|
* @param {string=} [options.params.customizeAction] - Additional context information shown before the section title when expanded.
|
||||||
*/
|
*/
|
||||||
initialize: function ( id, options ) {
|
initialize: function ( id, options ) {
|
||||||
var section = this;
|
var section = this;
|
||||||
@ -1009,8 +1053,15 @@
|
|||||||
/**
|
/**
|
||||||
* @since 4.1.0
|
* @since 4.1.0
|
||||||
*
|
*
|
||||||
* @param {String} id
|
* @param {string} id - The ID for the panel.
|
||||||
* @param {Object} options
|
* @param {object} options - Object containing one property: params.
|
||||||
|
* @param {object} options.params - Object containing the following properties.
|
||||||
|
* @param {string} options.params.title - Title shown when panel is collapsed and expanded.
|
||||||
|
* @param {string=} [options.params.description] - Description shown at the top of the panel.
|
||||||
|
* @param {number=100} [options.params.priority] - The sort priority for the panel.
|
||||||
|
* @param {string=default} [options.params.type] - The type of the panel. See wp.customize.panelConstructor.
|
||||||
|
* @param {string=} [options.params.content] - The markup to be used for the panel container. If empty, a JS template is used.
|
||||||
|
* @param {boolean=true} [options.params.active] - Whether the panel is active or not.
|
||||||
*/
|
*/
|
||||||
initialize: function ( id, options ) {
|
initialize: function ( id, options ) {
|
||||||
var panel = this;
|
var panel = this;
|
||||||
@ -1216,11 +1267,13 @@
|
|||||||
// Add the content to the container.
|
// Add the content to the container.
|
||||||
if ( 0 !== $( '#tmpl-' + panel.templateSelector + '-content' ).length ) {
|
if ( 0 !== $( '#tmpl-' + panel.templateSelector + '-content' ).length ) {
|
||||||
template = wp.template( panel.templateSelector + '-content' );
|
template = wp.template( panel.templateSelector + '-content' );
|
||||||
|
} else {
|
||||||
|
template = wp.template( 'customize-panel-default-content' );
|
||||||
|
}
|
||||||
if ( template && panel.container ) {
|
if ( template && panel.container ) {
|
||||||
panel.container.find( '.accordion-sub-container' ).html( template( panel.params ) );
|
panel.container.find( '.accordion-sub-container' ).html( template( panel.params ) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -57,7 +57,16 @@ window._wpCustomizeSettings = {
|
|||||||
'priority': 110,
|
'priority': 110,
|
||||||
'title': 'Fixture titleless panel using template',
|
'title': 'Fixture titleless panel using template',
|
||||||
'type': 'titleless'
|
'type': 'titleless'
|
||||||
}
|
},
|
||||||
|
'fixture-panel-reusing-default-template': {
|
||||||
|
'active': true,
|
||||||
|
'description': 'Lorem ipsum',
|
||||||
|
'instanceNumber': 3,
|
||||||
|
'priority': 110,
|
||||||
|
'title': 'Fixture panel of custom type re-using default template',
|
||||||
|
'type': 'reusing-default-template'
|
||||||
|
},
|
||||||
|
'fixture-panel-without-params': {}
|
||||||
},
|
},
|
||||||
'sections': {
|
'sections': {
|
||||||
'fixture-section': {
|
'fixture-section': {
|
||||||
@ -87,7 +96,17 @@ window._wpCustomizeSettings = {
|
|||||||
'priority': 20,
|
'priority': 20,
|
||||||
'title': 'Fixture titleless section using template',
|
'title': 'Fixture titleless section using template',
|
||||||
'type': 'titleless'
|
'type': 'titleless'
|
||||||
}
|
},
|
||||||
|
'fixture-section-reusing-default-template': {
|
||||||
|
'active': true,
|
||||||
|
'description': '',
|
||||||
|
'instanceNumber': 4,
|
||||||
|
'panel': 'fixture-panel',
|
||||||
|
'priority': 20,
|
||||||
|
'title': 'Fixture section of custom type re-using default template',
|
||||||
|
'type': 'reusing-default-template'
|
||||||
|
},
|
||||||
|
'fixture-section-without-params': {}
|
||||||
},
|
},
|
||||||
'settings': {
|
'settings': {
|
||||||
'fixture-setting': {
|
'fixture-setting': {
|
||||||
|
@ -136,6 +136,37 @@ jQuery( window ).load( function (){
|
|||||||
ok( 0 === section.container.find( '> .accordion-section-title' ).length );
|
ok( 0 === section.container.find( '> .accordion-section-title' ).length );
|
||||||
ok( 1 === section.container.find( '> .accordion-section-content' ).length );
|
ok( 1 === section.container.find( '> .accordion-section-content' ).length );
|
||||||
} );
|
} );
|
||||||
|
module( 'Customizer Custom Type Section Lacking Specific Template' );
|
||||||
|
test( 'Fixture section has expected content', function () {
|
||||||
|
var id = 'fixture-section-reusing-default-template', section;
|
||||||
|
section = wp.customize.section( id );
|
||||||
|
ok( ! section.params.content );
|
||||||
|
ok( !! section.container );
|
||||||
|
ok( section.container.is( '.control-section.control-section-' + section.params.type ) );
|
||||||
|
ok( 1 === section.container.find( '> .accordion-section-title' ).length );
|
||||||
|
ok( 1 === section.container.find( '> .accordion-section-content' ).length );
|
||||||
|
} );
|
||||||
|
module( 'Customizer Section lacking any params' );
|
||||||
|
test( 'Fixture section has default params supplied', function () {
|
||||||
|
var id = 'fixture-section-without-params', section, defaultParams;
|
||||||
|
section = wp.customize.section( id );
|
||||||
|
defaultParams = {
|
||||||
|
title: '',
|
||||||
|
description: '',
|
||||||
|
priority: 100,
|
||||||
|
panel: null,
|
||||||
|
type: 'default',
|
||||||
|
content: null,
|
||||||
|
active: true,
|
||||||
|
instanceNumber: null,
|
||||||
|
customizeAction: ''
|
||||||
|
};
|
||||||
|
jQuery.each( defaultParams, function ( key, value ) {
|
||||||
|
ok( 'undefined' !== typeof section.params[ key ] );
|
||||||
|
equal( value, section.params[ key ] );
|
||||||
|
} );
|
||||||
|
} );
|
||||||
|
|
||||||
|
|
||||||
// Begin panels.
|
// Begin panels.
|
||||||
module( 'Customizer Panel in Fixture' );
|
module( 'Customizer Panel in Fixture' );
|
||||||
@ -199,6 +230,34 @@ jQuery( window ).load( function (){
|
|||||||
ok( 1 === panel.container.find( '> .control-panel-content' ).length );
|
ok( 1 === panel.container.find( '> .control-panel-content' ).length );
|
||||||
} );
|
} );
|
||||||
|
|
||||||
|
module( 'Customizer Custom Type Panel Lacking Specific Template' );
|
||||||
|
test( 'Fixture panel has expected content', function () {
|
||||||
|
var id = 'fixture-panel-reusing-default-template', panel;
|
||||||
|
panel = wp.customize.panel( id );
|
||||||
|
ok( ! panel.params.content );
|
||||||
|
ok( !! panel.container );
|
||||||
|
ok( panel.container.is( '.control-panel.control-panel-' + panel.params.type ) );
|
||||||
|
ok( 1 === panel.container.find( '> .accordion-section-title' ).length );
|
||||||
|
ok( 1 === panel.container.find( '> .control-panel-content' ).length );
|
||||||
|
} );
|
||||||
|
module( 'Customizer Panel lacking any params' );
|
||||||
|
test( 'Fixture panel has default params supplied', function () {
|
||||||
|
var id = 'fixture-panel-without-params', panel, defaultParams;
|
||||||
|
panel = wp.customize.panel( id );
|
||||||
|
defaultParams = {
|
||||||
|
title: '',
|
||||||
|
description: '',
|
||||||
|
priority: 100,
|
||||||
|
type: 'default',
|
||||||
|
content: null,
|
||||||
|
active: true,
|
||||||
|
instanceNumber: null
|
||||||
|
};
|
||||||
|
jQuery.each( defaultParams, function ( key, value ) {
|
||||||
|
ok( 'undefined' !== typeof panel.params[ key ] );
|
||||||
|
equal( value, panel.params[ key ] );
|
||||||
|
} );
|
||||||
|
} );
|
||||||
|
|
||||||
module( 'Dynamically-created Customizer Setting Model' );
|
module( 'Dynamically-created Customizer Setting Model' );
|
||||||
settingId = 'new_blogname';
|
settingId = 'new_blogname';
|
||||||
|
Loading…
Reference in New Issue
Block a user