| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Accordion-folding functionality. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Markup with the appropriate classes will be automatically hidden, | 
					
						
							|  |  |  |  * with one section opening at a time when its title is clicked. | 
					
						
							|  |  |  |  * Use the following markup structure for accordion behavior: | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * <div class="accordion-container"> | 
					
						
							|  |  |  |  *	<div class="accordion-section open"> | 
					
						
							|  |  |  |  *		<h3 class="accordion-section-title"></h3> | 
					
						
							|  |  |  |  *		<div class="accordion-section-content"> | 
					
						
							|  |  |  |  *		</div> | 
					
						
							|  |  |  |  *	</div> | 
					
						
							|  |  |  |  *	<div class="accordion-section"> | 
					
						
							|  |  |  |  *		<h3 class="accordion-section-title"></h3> | 
					
						
							|  |  |  |  *		<div class="accordion-section-content"> | 
					
						
							|  |  |  |  *		</div> | 
					
						
							|  |  |  |  *	</div> | 
					
						
							|  |  |  |  *	<div class="accordion-section"> | 
					
						
							|  |  |  |  *		<h3 class="accordion-section-title"></h3> | 
					
						
							|  |  |  |  *		<div class="accordion-section-content"> | 
					
						
							|  |  |  |  *		</div> | 
					
						
							|  |  |  |  *	</div> | 
					
						
							|  |  |  |  * </div> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Note that any appropriate tags may be used, as long as the above classes are present. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |  * @since 3.6.0 | 
					
						
							|  |  |  |  * @output wp-admin/js/accordion.js | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ( function( $ ){ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	$( document ).ready( function () { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Expand/Collapse accordion sections on click.
 | 
					
						
							|  |  |  | 		$( '.accordion-container' ).on( 'click keydown', '.accordion-section-title', function( e ) { | 
					
						
							|  |  |  | 			if ( e.type === 'keydown' && 13 !== e.which ) { // "return" key
 | 
					
						
							|  |  |  | 				return; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			e.preventDefault(); // Keep this AFTER the key filter above
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			accordionSwitch( $( this ) ); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	}); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							|  |  |  | 	 * Close the current accordion section and open a new one. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * @param {Object} el Title element of the accordion section to toggle. | 
					
						
							|  |  |  | 	 * @since 3.6.0 | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	function accordionSwitch ( el ) { | 
					
						
							|  |  |  | 		var section = el.closest( '.accordion-section' ), | 
					
						
							|  |  |  | 			sectionToggleControl = section.find( '[aria-expanded]' ).first(), | 
					
						
							|  |  |  | 			container = section.closest( '.accordion-container' ), | 
					
						
							|  |  |  | 			siblings = container.find( '.open' ), | 
					
						
							|  |  |  | 			siblingsToggleControl = siblings.find( '[aria-expanded]' ).first(), | 
					
						
							|  |  |  | 			content = section.find( '.accordion-section-content' ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// This section has no content and cannot be expanded.
 | 
					
						
							|  |  |  | 		if ( section.hasClass( 'cannot-expand' ) ) { | 
					
						
							|  |  |  | 			return; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Add a class to the container to let us know something is happening inside.
 | 
					
						
							|  |  |  | 		// This helps in cases such as hiding a scrollbar while animations are executing.
 | 
					
						
							|  |  |  | 		container.addClass( 'opening' ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if ( section.hasClass( 'open' ) ) { | 
					
						
							|  |  |  | 			section.toggleClass( 'open' ); | 
					
						
							|  |  |  | 			content.toggle( true ).slideToggle( 150 ); | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			siblingsToggleControl.attr( 'aria-expanded', 'false' ); | 
					
						
							|  |  |  | 			siblings.removeClass( 'open' ); | 
					
						
							|  |  |  | 			siblings.find( '.accordion-section-content' ).show().slideUp( 150 ); | 
					
						
							|  |  |  | 			content.toggle( false ).slideToggle( 150 ); | 
					
						
							|  |  |  | 			section.toggleClass( 'open' ); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// We have to wait for the animations to finish
 | 
					
						
							|  |  |  | 		setTimeout(function(){ | 
					
						
							|  |  |  | 		    container.removeClass( 'opening' ); | 
					
						
							|  |  |  | 		}, 150); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// If there's an element with an aria-expanded attribute, assume it's a toggle control and toggle the aria-expanded value.
 | 
					
						
							|  |  |  | 		if ( sectionToggleControl ) { | 
					
						
							|  |  |  | 			sectionToggleControl.attr( 'aria-expanded', String( sectionToggleControl.attr( 'aria-expanded' ) === 'false' ) ); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | })(jQuery); |