PHP 8.1.33
Preview: wp-custom-header.js Size: 10.22 KB
/home/jambtst2015/public_html/cccng.org/wp-includes/js/wp-custom-header.js

/**
 * @output wp-includes/js/wp-custom-header.js
 */

/* global YT */
(function( window, settings ) {

	var NativeHandler, YouTubeHandler;

	/** @namespace wp */
	window.wp = window.wp || {};

	// Fail gracefully in unsupported browsers.
	if ( ! ( 'addEventListener' in window ) ) {
		return;
	}

	/**
	 * Trigger an event.
	 *
	 * @param {Element} target HTML element to dispatch the event on.
	 * @param {string} name Event name.
	 */
	function trigger( target, name ) {
		var evt;

		if ( 'function' === typeof window.Event ) {
			evt = new Event( name );
		} else {
			evt = document.createEvent( 'Event' );
			evt.initEvent( name, true, true );
		}

		target.dispatchEvent( evt );
	}

	/**
	 * Create a custom header instance.
	 *
	 * @memberOf wp
	 *
	 * @class
	 */
	function CustomHeader() {
		this.handlers = {
			nativeVideo: new NativeHandler(),
			youtube: new YouTubeHandler()
		};
	}

	CustomHeader.prototype = {
		/**
		 * Initialize the custom header.
		 *
		 * If the environment supports video, loops through registered handlers
		 * until one is found that can handle the video.
		 */
		initialize: function() {
			if ( this.supportsVideo() ) {
				for ( var id in this.handlers ) {
					var handler = this.handlers[ id ];

					if ( 'test' in handler && handler.test( settings ) ) {
						this.activeHandler = handler.initialize.call( handler, settings );

						// Dispatch custom event when the video is loaded.
						trigger( document, 'wp-custom-header-video-loaded' );
						break;
					}
				}
			}
		},

		/**
		 * Determines if the current environment supports video.
		 *
		 * Themes and plugins can override this method to change the criteria.
		 *
		 * @return {boolean}
		 */
		supportsVideo: function() {
			// Don't load video on small screens. @todo Consider bandwidth and other factors.
			if ( window.innerWidth < settings.minWidth || window.innerHeight < settings.minHeight ) {
				return false;
			}

			return true;
		},

		/**
		 * Base handler for custom handlers to extend.
		 *
		 * @type {BaseHandler}
		 */
		BaseVideoHandler: BaseHandler
	};

	/**
	 * Create a video handler instance.
	 *
	 * @memberOf wp
	 *
	 * @class
	 */
	function BaseHandler() {}

	BaseHandler.prototype = {
		/**
		 * Initialize the video handler.
		 *
		 * @param {Object} settings Video settings.
		 */
		initialize: function( settings ) {
			var handler = this,
				button = document.createElement( 'button' );

			this.settings = settings;
			this.container = document.getElementById( 'wp-custom-header' );
			this.button = button;

			button.setAttribute( 'type', 'button' );
			button.setAttribute( 'id', 'wp-custom-header-video-button' );
			button.setAttribute( 'class', 'wp-custom-header-video-button wp-custom-header-video-play' );
			button.innerHTML = settings.l10n.play;

			// Toggle video playback when the button is clicked.
			button.addEventListener( 'click', function() {
				if ( handler.isPaused() ) {
					handler.play();
				} else {
					handler.pause();
				}
			});

			// Update the button class and text when the video state changes.
			this.container.addEventListener( 'play', function() {
				button.className = 'wp-custom-header-video-button wp-custom-header-video-play';
				button.innerHTML = settings.l10n.pause;
				if ( 'a11y' in window.wp ) {
					window.wp.a11y.speak( settings.l10n.playSpeak);
				}
			});

			this.container.addEventListener( 'pause', function() {
				button.className = 'wp-custom-header-video-button wp-custom-header-video-pause';
				button.innerHTML = settings.l10n.play;
				if ( 'a11y' in window.wp ) {
					window.wp.a11y.speak( settings.l10n.pauseSpeak);
				}
			});

			this.ready();
		},

		/**
		 * Ready method called after a handler is initialized.
		 *
		 * @abstract
		 */
		ready: function() {},

		/**
		 * Whether the video is paused.
		 *
		 * @abstract
		 * @return {boolean}
		 */
		isPaused: function() {},

		/**
		 * Pause the video.
		 *
		 * @abstract
		 */
		pause: function() {},

		/**
		 * Play the video.
		 *
		 * @abstract
		 */
		play: function() {},

		/**
		 * Append a video node to the header container.
		 *
		 * @param {Element} node HTML element.
		 */
		setVideo: function( node ) {
			var editShortcutNode,
				editShortcut = this.container.getElementsByClassName( 'customize-partial-edit-shortcut' );

			if ( editShortcut.length ) {
				editShortcutNode = this.container.removeChild( editShortcut[0] );
			}

			this.container.innerHTML = '';
			this.container.appendChild( node );

			if ( editShortcutNode ) {
				this.container.appendChild( editShortcutNode );
			}
		},

		/**
		 * Show the video controls.
		 *
		 * Appends a play/pause button to header container.
		 */
		showControls: function() {
			if ( ! this.container.contains( this.button ) ) {
				this.container.appendChild( this.button );
			}
		},

		/**
		 * Whether the handler can process a video.
		 *
		 * @abstract
		 * @param {Object} settings Video settings.
		 * @return {boolean}
		 */
		test: function() {
			return false;
		},

		/**
		 * Trigger an event on the header container.
		 *
		 * @param {string} name Event name.
		 */
		trigger: function( name ) {
			trigger( this.container, name );
		}
	};

	/**
	 * Create a custom handler.
	 *
	 * @memberOf wp
	 *
	 * @param {Object} protoProps Properties to apply to the prototype.
	 * @return CustomHandler The subclass.
	 */
	BaseHandler.extend = function( protoProps ) {
		var prop;

		function CustomHandler() {
			var result = BaseHandler.apply( this, arguments );
			return result;
		}

		CustomHandler.prototype = Object.create( BaseHandler.prototype );
		CustomHandler.prototype.constructor = CustomHandler;

		for ( prop in protoProps ) {
			CustomHandler.prototype[ prop ] = protoProps[ prop ];
		}

		return CustomHandler;
	};

	/**
	 * Native video handler.
	 *
	 * @memberOf wp
	 *
	 * @class
	 */
	NativeHandler = BaseHandler.extend(/** @lends wp.NativeHandler.prototype */{
		/**
		 * Whether the native handler supports a video.
		 *
		 * @param {Object} settings Video settings.
		 * @return {boolean}
		 */
		test: function( settings ) {
			var video = document.createElement( 'video' );
			return video.canPlayType( settings.mimeType );
		},

		/**
		 * Set up a native video element.
		 */
		ready: function() {
			var handler = this,
				video = document.createElement( 'video' );

			video.id = 'wp-custom-header-video';
			video.autoplay = true;
			video.loop = true;
			video.muted = true;
			video.playsInline = true;
			video.width = this.settings.width;
			video.height = this.settings.height;

			video.addEventListener( 'play', function() {
				handler.trigger( 'play' );
			});

			video.addEventListener( 'pause', function() {
				handler.trigger( 'pause' );
			});

			video.addEventListener( 'canplay', function() {
				handler.showControls();
			});

			this.video = video;
			handler.setVideo( video );
			video.src = this.settings.videoUrl;
		},

		/**
		 * Whether the video is paused.
		 *
		 * @return {boolean}
		 */
		isPaused: function() {
			return this.video.paused;
		},

		/**
		 * Pause the video.
		 */
		pause: function() {
			this.video.pause();
		},

		/**
		 * Play the video.
		 */
		play: function() {
			this.video.play();
		}
	});

	/**
	 * YouTube video handler.
	 *
	 * @memberOf wp
	 *
	 * @class wp.YouTubeHandler
	 */
	YouTubeHandler = BaseHandler.extend(/** @lends wp.YouTubeHandler.prototype */{
		/**
		 * Whether the handler supports a video.
		 *
		 * @param {Object} settings Video settings.
		 * @return {boolean}
		 */
		test: function( settings ) {
			return 'video/x-youtube' === settings.mimeType;
		},

		/**
		 * Set up a YouTube iframe.
		 *
		 * Loads the YouTube IFrame API if the 'YT' global doesn't exist.
		 */
		ready: function() {
			var handler = this;

			if ( 'YT' in window ) {
				YT.ready( handler.loadVideo.bind( handler ) );
			} else {
				var tag = document.createElement( 'script' );
				tag.src = 'https://www.youtube.com/iframe_api';
				tag.onload = function () {
					YT.ready( handler.loadVideo.bind( handler ) );
				};

				document.getElementsByTagName( 'head' )[0].appendChild( tag );
			}
		},

		/**
		 * Load a YouTube video.
		 */
		loadVideo: function() {
			var handler = this,
				video = document.createElement( 'div' ),
				// @link http://stackoverflow.com/a/27728417
				VIDEO_ID_REGEX = /^.*(?:(?:youtu\.be\/|v\/|vi\/|u\/\w\/|embed\/)|(?:(?:watch)?\?v(?:i)?=|\&v(?:i)?=))([^#\&\?]*).*/;

			video.id = 'wp-custom-header-video';
			handler.setVideo( video );

			handler.player = new YT.Player( video, {
				height: this.settings.height,
				width: this.settings.width,
				videoId: this.settings.videoUrl.match( VIDEO_ID_REGEX )[1],
				events: {
					onReady: function( e ) {
						e.target.mute();
						handler.showControls();
					},
					onStateChange: function( e ) {
						if ( YT.PlayerState.PLAYING === e.data ) {
							handler.trigger( 'play' );
						} else if ( YT.PlayerState.PAUSED === e.data ) {
							handler.trigger( 'pause' );
						} else if ( YT.PlayerState.ENDED === e.data ) {
							e.target.playVideo();
						}
					}
				},
				playerVars: {
					autoplay: 1,
					controls: 0,
					disablekb: 1,
					fs: 0,
					iv_load_policy: 3,
					loop: 1,
					modestbranding: 1,
					playsinline: 1,
					rel: 0,
					showinfo: 0
				}
			});
		},

		/**
		 * Whether the video is paused.
		 *
		 * @return {boolean}
		 */
		isPaused: function() {
			return YT.PlayerState.PAUSED === this.player.getPlayerState();
		},

		/**
		 * Pause the video.
		 */
		pause: function() {
			this.player.pauseVideo();
		},

		/**
		 * Play the video.
		 */
		play: function() {
			this.player.playVideo();
		}
	});

	// Initialize the custom header when the DOM is ready.
	window.wp.customHeader = new CustomHeader();
	document.addEventListener( 'DOMContentLoaded', window.wp.customHeader.initialize.bind( window.wp.customHeader ), false );

	// Selective refresh support in the Customizer.
	if ( 'customize' in window.wp ) {
		window.wp.customize.selectiveRefresh.bind( 'render-partials-response', function( response ) {
			if ( 'custom_header_settings' in response ) {
				settings = response.custom_header_settings;
			}
		});

		window.wp.customize.selectiveRefresh.bind( 'partial-content-rendered', function( placement ) {
			if ( 'custom_header' === placement.partial.id ) {
				window.wp.customHeader.initialize();
			}
		});
	}

})( window, window._wpCustomHeaderSettings || {} );

Directory Contents

Dirs: 12 × Files: 102

Name Size Perms Modified Actions
.hm DIR
- drwxr-xr-x 2024-12-30 07:14:41
Edit Download
- drwxr-xr-x 2024-12-30 07:14:41
Edit Download
crop DIR
- drwxr-xr-x 2024-12-30 07:14:41
Edit Download
dist DIR
- drwxr-xr-x 2025-10-08 17:06:32
Edit Download
- drwxr-xr-x 2024-12-30 07:14:41
Edit Download
jcrop DIR
- drwxr-xr-x 2024-12-30 07:14:41
Edit Download
jquery DIR
- drwxr-xr-x 2024-12-30 07:14:41
Edit Download
- drwxr-xr-x 2024-12-30 07:14:41
Edit Download
plupload DIR
- drwxr-xr-x 2024-12-30 07:14:41
Edit Download
swfupload DIR
- drwxr-xr-x 2024-12-30 07:14:41
Edit Download
thickbox DIR
- drwxr-xr-x 2024-12-30 07:14:41
Edit Download
tinymce DIR
- drwxr-xr-x 2024-12-30 07:14:41
Edit Download
10.30 KB lrw-r--r-- 2024-05-12 03:58:08
Edit Download
3.41 KB lrw-r--r-- 2024-05-12 03:58:08
Edit Download
3.25 KB lrw-r--r-- 2020-12-01 14:14:06
Edit Download
1023 B lrw-r--r-- 2022-04-09 05:37:18
Edit Download
21.95 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
5.67 KB lrw-r--r-- 2023-02-03 03:06:32
Edit Download
78.51 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
23.73 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
26.18 KB lrw-r--r-- 2022-10-05 01:25:24
Edit Download
8.80 KB lrw-r--r-- 2024-06-27 23:21:44
Edit Download
28.40 KB lrw-r--r-- 2012-11-18 01:41:30
Edit Download
16.11 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
12.22 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
2.96 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
25.22 KB lrw-r--r-- 2023-05-20 19:49:24
Edit Download
7.67 KB lrw-r--r-- 2023-02-03 03:06:32
Edit Download
7.72 KB lrw-r--r-- 2024-04-13 03:17:14
Edit Download
3.47 KB lrw-r--r-- 2023-02-03 03:06:32
Edit Download
6.66 KB lrw-r--r-- 2020-06-25 22:13:08
Edit Download
3.59 KB lrw-r--r-- 2023-02-03 03:06:32
Edit Download
14.67 KB lrw-r--r-- 2020-07-28 09:05:02
Edit Download
4.92 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
22.71 KB lrw-r--r-- 2020-06-20 22:28:10
Edit Download
7.64 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
27.30 KB lrw-r--r-- 2020-07-28 09:05:02
Edit Download
10.45 KB lrw-r--r-- 2023-02-03 03:06:32
Edit Download
32.55 KB lrw-r--r-- 2024-04-13 03:17:14
Edit Download
10.44 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
4.95 KB lrw-r--r-- 2018-06-28 12:00:16
Edit Download
2.39 KB lrw-r--r-- 2021-01-07 01:59:24
Edit Download
2.21 KB lrw-r--r-- 2024-04-09 06:44:14
Edit Download
23.49 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
5.81 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
1.68 KB lrw-r--r-- 2019-12-10 11:33:02
Edit Download
7.06 KB lrw-r--r-- 2022-01-04 01:33:18
Edit Download
1.46 KB lrw-r--r-- 2024-06-27 23:21:44
Edit Download
5.39 KB lrw-r--r-- 2023-08-12 03:48:26
Edit Download
17.99 KB lrw-r--r-- 2015-10-06 23:32:26
Edit Download
3.07 KB lrw-r--r-- 2024-06-27 23:21:44
Edit Download
23.57 KB lrw-r--r-- 2020-06-14 04:23:28
Edit Download
25.24 KB lrw-r--r-- 2023-10-10 07:01:28
Edit Download
9.54 KB lrw-r--r-- 2024-06-27 23:21:44
Edit Download
24.24 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
11.77 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
28.44 KB lrw-r--r-- 2020-07-28 09:05:02
Edit Download
10.63 KB lrw-r--r-- 2023-02-03 03:06:32
Edit Download
26.03 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
12.95 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
42.58 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
12.97 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
266.92 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
108.12 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
2.08 KB lrw-r--r-- 2024-04-09 06:44:14
Edit Download
22.07 KB lrw-r--r-- 2021-09-09 08:59:58
Edit Download
10.87 KB lrw-r--r-- 2023-02-03 03:06:32
Edit Download
10.51 KB lrw-r--r-- 2020-01-29 11:15:18
Edit Download
2.58 KB lrw-r--r-- 2022-09-24 05:25:30
Edit Download
9.99 KB lrw-r--r-- 2012-04-18 08:39:30
Edit Download
4.85 KB lrw-r--r-- 2012-08-23 09:34:18
Edit Download
3.21 KB lrw-r--r-- 2022-04-09 05:37:18
Edit Download
32.67 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
15.93 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
67.12 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
18.46 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
4.56 KB lrw-r--r-- 2020-01-29 11:15:18
Edit Download
1.82 KB lrw-r--r-- 2022-09-24 05:25:30
Edit Download
3.81 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
2.51 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
45.88 KB lrw-r--r-- 2023-01-10 20:00:14
Edit Download
14.34 KB lrw-r--r-- 2024-06-27 23:21:44
Edit Download
4.11 KB lrw-r--r-- 2021-03-19 04:31:04
Edit Download
1.62 KB lrw-r--r-- 2021-03-19 04:31:04
Edit Download
14.88 KB lrw-r--r-- 2024-04-13 03:17:14
Edit Download
2.97 KB lrw-r--r-- 2022-04-09 05:37:18
Edit Download
10.22 KB lrw-r--r-- 2021-04-10 22:10:06
Edit Download
4.34 KB lrw-r--r-- 2023-02-03 03:06:32
Edit Download
6.62 KB lrw-r--r-- 2021-11-11 13:19:18
Edit Download
3.10 KB lrw-r--r-- 2024-06-27 23:21:44
Edit Download
3.14 KB lrw-r--r-- 2023-08-11 05:19:18
Edit Download
1.22 KB lrw-r--r-- 2024-06-27 23:21:44
Edit Download
13.68 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
3.02 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
18.80 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
8.76 KB lrw-r--r-- 2023-02-02 11:23:26
Edit Download
2.82 KB lrw-r--r-- 2023-02-02 11:23:26
Edit Download
970 B lrw-r--r-- 2018-06-28 12:00:16
Edit Download
597 B lrw-r--r-- 2021-01-07 01:59:24
Edit Download
24.72 KB lrw-r--r-- 2023-06-25 00:02:20
Edit Download
7.34 KB lrw-r--r-- 2023-06-25 00:02:20
Edit Download
9.99 KB lrw-r--r-- 2021-02-17 06:55:04
Edit Download
3.54 KB lrw-r--r-- 2022-04-09 05:37:18
Edit Download
1.31 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
458 B lrw-r--r-- 2022-04-09 05:37:18
Edit Download
4.57 KB lrw-r--r-- 2022-09-20 13:22:10
Edit Download
1.39 KB lrw-r--r-- 2022-09-20 13:22:10
Edit Download
569 B lrw-r--r-- 2023-01-25 07:43:12
Edit Download
281 B lrw-r--r-- 2023-01-25 07:43:12
Edit Download
20.74 KB lrw-r--r-- 2025-10-08 17:06:31
Edit Download
11.05 KB lrw-r--r-- 2024-12-17 21:37:28
Edit Download
821 B lrw-r--r-- 2018-06-28 12:00:16
Edit Download
351 B lrw-r--r-- 2021-02-24 03:15:20
Edit Download
802.97 KB lrw-r--r-- 2019-10-26 09:47:08
Edit Download

If ZipArchive is unavailable, a .tar will be created (no compression).