mirror of
https://github.com/WordPress/WordPress.git
synced 2024-11-09 20:30:43 +01:00
9f8f0aa58e
Make the JavaScript selectors for audio and video shortcodes aware of the state of the `wp_video_shortcode_library` and `wp_audio_shortcode_library` filters. Allow extenders to replace the library for either media shortcode. Props westonruter, joedolson, rudlinkon, obayedmamur. Fixes #40144. Built from https://develop.svn.wordpress.org/trunk@55271 git-svn-id: http://core.svn.wordpress.org/trunk@54804 1a063a9b-81f0-0310-95a4-ce76da25c4cd
101 lines
2.7 KiB
JavaScript
101 lines
2.7 KiB
JavaScript
/* global _wpmejsSettings, mejsL10n */
|
|
(function( window, $ ) {
|
|
|
|
window.wp = window.wp || {};
|
|
|
|
function wpMediaElement() {
|
|
var settings = {};
|
|
|
|
/**
|
|
* Initialize media elements.
|
|
*
|
|
* Ensures media elements that have already been initialized won't be
|
|
* processed again.
|
|
*
|
|
* @memberOf wp.mediaelement
|
|
*
|
|
* @since 4.4.0
|
|
*
|
|
* @return {void}
|
|
*/
|
|
function initialize() {
|
|
var selectors = [];
|
|
|
|
if ( typeof _wpmejsSettings !== 'undefined' ) {
|
|
settings = $.extend( true, {}, _wpmejsSettings );
|
|
}
|
|
settings.classPrefix = 'mejs-';
|
|
settings.success = settings.success || function ( mejs ) {
|
|
var autoplay, loop;
|
|
|
|
if ( mejs.rendererName && -1 !== mejs.rendererName.indexOf( 'flash' ) ) {
|
|
autoplay = mejs.attributes.autoplay && 'false' !== mejs.attributes.autoplay;
|
|
loop = mejs.attributes.loop && 'false' !== mejs.attributes.loop;
|
|
|
|
if ( autoplay ) {
|
|
mejs.addEventListener( 'canplay', function() {
|
|
mejs.play();
|
|
}, false );
|
|
}
|
|
|
|
if ( loop ) {
|
|
mejs.addEventListener( 'ended', function() {
|
|
mejs.play();
|
|
}, false );
|
|
}
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Custom error handler.
|
|
*
|
|
* Sets up a custom error handler in case a video render fails, and provides a download
|
|
* link as the fallback.
|
|
*
|
|
* @since 4.9.3
|
|
*
|
|
* @param {object} media The wrapper that mimics all the native events/properties/methods for all renderers.
|
|
* @param {object} node The original HTML video, audio, or iframe tag where the media was loaded.
|
|
* @return {string}
|
|
*/
|
|
settings.customError = function ( media, node ) {
|
|
// Make sure we only fall back to a download link for flash files.
|
|
if ( -1 !== media.rendererName.indexOf( 'flash' ) || -1 !== media.rendererName.indexOf( 'flv' ) ) {
|
|
return '<a href="' + node.src + '">' + mejsL10n.strings['mejs.download-file'] + '</a>';
|
|
}
|
|
};
|
|
|
|
if ( 'undefined' === typeof settings.videoShortcodeLibrary || 'mediaelement' === settings.videoShortcodeLibrary ) {
|
|
selectors.push( '.wp-video-shortcode' );
|
|
}
|
|
if ( 'undefined' === typeof settings.audioShortcodeLibrary || 'mediaelement' === settings.audioShortcodeLibrary ) {
|
|
selectors.push( '.wp-audio-shortcode' );
|
|
}
|
|
if ( ! selectors.length ) {
|
|
return;
|
|
}
|
|
|
|
// Only initialize new media elements.
|
|
$( selectors.join( ', ' ) )
|
|
.not( '.mejs-container' )
|
|
.filter(function () {
|
|
return ! $( this ).parent().hasClass( 'mejs-mediaelement' );
|
|
})
|
|
.mediaelementplayer( settings );
|
|
}
|
|
|
|
return {
|
|
initialize: initialize
|
|
};
|
|
}
|
|
|
|
/**
|
|
* @namespace wp.mediaelement
|
|
* @memberOf wp
|
|
*/
|
|
window.wp.mediaelement = new wpMediaElement();
|
|
|
|
$( window.wp.mediaelement.initialize );
|
|
|
|
})( window, jQuery );
|