diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-17 07:56:49 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-17 07:56:49 +0000 |
commit | a415c29efee45520ae252d2aa28f1083a521cd7b (patch) | |
tree | f4ade4b6668ecc0765de7e1424f7c1427ad433ff /wp-includes/js/mediaelement/renderers/vimeo.js | |
parent | Initial commit. (diff) | |
download | wordpress-a415c29efee45520ae252d2aa28f1083a521cd7b.tar.xz wordpress-a415c29efee45520ae252d2aa28f1083a521cd7b.zip |
Adding upstream version 6.4.3+dfsg1.upstream/6.4.3+dfsg1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'wp-includes/js/mediaelement/renderers/vimeo.js')
-rw-r--r-- | wp-includes/js/mediaelement/renderers/vimeo.js | 432 |
1 files changed, 432 insertions, 0 deletions
diff --git a/wp-includes/js/mediaelement/renderers/vimeo.js b/wp-includes/js/mediaelement/renderers/vimeo.js new file mode 100644 index 0000000..a517434 --- /dev/null +++ b/wp-includes/js/mediaelement/renderers/vimeo.js @@ -0,0 +1,432 @@ +/*! + * MediaElement.js + * http://www.mediaelementjs.com/ + * + * Wrapper that mimics native HTML5 MediaElement (audio and video) + * using a variety of technologies (pure JavaScript, Flash, iframe) + * + * Copyright 2010-2017, John Dyer (http://j.hn/) + * License: MIT + * + */(function(){function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s}return e})()({1:[function(_dereq_,module,exports){ +'use strict'; + +var VimeoApi = { + + promise: null, + + load: function load(settings) { + + if (typeof Vimeo !== 'undefined') { + VimeoApi._createPlayer(settings); + } else { + VimeoApi.promise = VimeoApi.promise || mejs.Utils.loadScript('https://player.vimeo.com/api/player.js'); + VimeoApi.promise.then(function () { + VimeoApi._createPlayer(settings); + }); + } + }, + + _createPlayer: function _createPlayer(settings) { + var player = new Vimeo.Player(settings.iframe); + window['__ready__' + settings.id](player); + }, + + getVimeoId: function getVimeoId(url) { + if (url == null) { + return null; + } + + var parts = url.split('?'); + url = parts[0]; + + var playerLinkMatch = url.match(/https:\/\/player.vimeo.com\/video\/(\d+)$/); + if (playerLinkMatch) { + return parseInt(playerLinkMatch[1], 10); + } + + var vimeoLinkMatch = url.match(/https:\/\/vimeo.com\/(\d+)$/); + if (vimeoLinkMatch) { + return parseInt(vimeoLinkMatch[1], 10); + } + + var privateVimeoLinkMatch = url.match(/https:\/\/vimeo.com\/(\d+)\/\w+$/); + if (privateVimeoLinkMatch) { + return parseInt(privateVimeoLinkMatch[1], 10); + } + + return NaN; + } +}; + +var vimeoIframeRenderer = { + + name: 'vimeo_iframe', + options: { + prefix: 'vimeo_iframe' + }, + + canPlayType: function canPlayType(type) { + return ~['video/vimeo', 'video/x-vimeo'].indexOf(type.toLowerCase()); + }, + + create: function create(mediaElement, options, mediaFiles) { + var apiStack = [], + vimeo = {}, + readyState = 4; + + var paused = true, + volume = 1, + oldVolume = volume, + currentTime = 0, + bufferedTime = 0, + ended = false, + duration = 0, + vimeoPlayer = null, + url = ''; + + vimeo.options = options; + vimeo.id = mediaElement.id + '_' + options.prefix; + vimeo.mediaElement = mediaElement; + + var errorHandler = function errorHandler(error) { + mediaElement.generateError('Code ' + error.name + ': ' + error.message, mediaFiles); + }; + + var props = mejs.html5media.properties, + assignGettersSetters = function assignGettersSetters(propName) { + + var capName = '' + propName.substring(0, 1).toUpperCase() + propName.substring(1); + + vimeo['get' + capName] = function () { + if (vimeoPlayer !== null) { + var value = null; + + switch (propName) { + case 'currentTime': + return currentTime; + case 'duration': + return duration; + case 'volume': + return volume; + case 'muted': + return volume === 0; + case 'paused': + return paused; + case 'ended': + return ended; + case 'src': + vimeoPlayer.getVideoUrl().then(function (_url) { + url = _url; + }).catch(function (error) { + return errorHandler(error); + }); + return url; + case 'buffered': + return { + start: function start() { + return 0; + }, + end: function end() { + return bufferedTime * duration; + }, + length: 1 + }; + case 'readyState': + return readyState; + } + return value; + } else { + return null; + } + }; + + vimeo['set' + capName] = function (value) { + if (vimeoPlayer !== null) { + switch (propName) { + case 'src': + var _url2 = typeof value === 'string' ? value : value[0].src, + videoId = VimeoApi.getVimeoId(_url2); + + vimeoPlayer.loadVideo(videoId).then(function () { + if (mediaElement.originalNode.autoplay) { + vimeoPlayer.play(); + } + }).catch(function (error) { + return errorHandler(error); + }); + break; + case 'currentTime': + vimeoPlayer.setCurrentTime(value).then(function () { + currentTime = value; + setTimeout(function () { + var event = mejs.Utils.createEvent('timeupdate', vimeo); + mediaElement.dispatchEvent(event); + }, 50); + }).catch(function (error) { + return errorHandler(error); + }); + break; + case 'volume': + vimeoPlayer.setVolume(value).then(function () { + volume = value; + oldVolume = volume; + setTimeout(function () { + var event = mejs.Utils.createEvent('volumechange', vimeo); + mediaElement.dispatchEvent(event); + }, 50); + }).catch(function (error) { + return errorHandler(error); + }); + break; + case 'loop': + vimeoPlayer.setLoop(value).catch(function (error) { + return errorHandler(error); + }); + break; + case 'muted': + if (value) { + vimeoPlayer.setVolume(0).then(function () { + volume = 0; + setTimeout(function () { + var event = mejs.Utils.createEvent('volumechange', vimeo); + mediaElement.dispatchEvent(event); + }, 50); + }).catch(function (error) { + return errorHandler(error); + }); + } else { + vimeoPlayer.setVolume(oldVolume).then(function () { + volume = oldVolume; + setTimeout(function () { + var event = mejs.Utils.createEvent('volumechange', vimeo); + mediaElement.dispatchEvent(event); + }, 50); + }).catch(function (error) { + return errorHandler(error); + }); + } + break; + case 'readyState': + var event = mejs.Utils.createEvent('canplay', vimeo); + mediaElement.dispatchEvent(event); + break; + default: + + break; + } + } else { + apiStack.push({ type: 'set', propName: propName, value: value }); + } + }; + }; + + for (var i = 0, total = props.length; i < total; i++) { + assignGettersSetters(props[i]); + } + + var methods = mejs.html5media.methods, + assignMethods = function assignMethods(methodName) { + vimeo[methodName] = function () { + if (vimeoPlayer !== null) { + switch (methodName) { + case 'play': + paused = false; + return vimeoPlayer.play(); + case 'pause': + paused = true; + return vimeoPlayer.pause(); + case 'load': + return null; + } + } else { + apiStack.push({ type: 'call', methodName: methodName }); + } + }; + }; + + for (var _i = 0, _total = methods.length; _i < _total; _i++) { + assignMethods(methods[_i]); + } + + window['__ready__' + vimeo.id] = function (_vimeoPlayer) { + + mediaElement.vimeoPlayer = vimeoPlayer = _vimeoPlayer; + + if (apiStack.length) { + for (var _i2 = 0, _total2 = apiStack.length; _i2 < _total2; _i2++) { + var stackItem = apiStack[_i2]; + + if (stackItem.type === 'set') { + var propName = stackItem.propName, + capName = '' + propName.substring(0, 1).toUpperCase() + propName.substring(1); + + vimeo['set' + capName](stackItem.value); + } else if (stackItem.type === 'call') { + vimeo[stackItem.methodName](); + } + } + } + + if (mediaElement.originalNode.muted) { + vimeoPlayer.setVolume(0); + volume = 0; + } + + var vimeoIframe = document.getElementById(vimeo.id); + var events = void 0; + + events = ['mouseover', 'mouseout']; + + var assignEvents = function assignEvents(e) { + var event = mejs.Utils.createEvent(e.type, vimeo); + mediaElement.dispatchEvent(event); + }; + + for (var _i3 = 0, _total3 = events.length; _i3 < _total3; _i3++) { + vimeoIframe.addEventListener(events[_i3], assignEvents, false); + } + + vimeoPlayer.on('loaded', function () { + vimeoPlayer.getDuration().then(function (loadProgress) { + duration = loadProgress; + if (duration > 0) { + bufferedTime = duration * loadProgress; + if (mediaElement.originalNode.autoplay) { + paused = false; + ended = false; + var event = mejs.Utils.createEvent('play', vimeo); + mediaElement.dispatchEvent(event); + } + } + }).catch(function (error) { + errorHandler(error, vimeo); + }); + }); + vimeoPlayer.on('progress', function () { + vimeoPlayer.getDuration().then(function (loadProgress) { + duration = loadProgress; + + if (duration > 0) { + bufferedTime = duration * loadProgress; + if (mediaElement.originalNode.autoplay) { + var initEvent = mejs.Utils.createEvent('play', vimeo); + mediaElement.dispatchEvent(initEvent); + + var playingEvent = mejs.Utils.createEvent('playing', vimeo); + mediaElement.dispatchEvent(playingEvent); + } + } + + var event = mejs.Utils.createEvent('progress', vimeo); + mediaElement.dispatchEvent(event); + }).catch(function (error) { + return errorHandler(error); + }); + }); + vimeoPlayer.on('timeupdate', function () { + vimeoPlayer.getCurrentTime().then(function (seconds) { + currentTime = seconds; + var event = mejs.Utils.createEvent('timeupdate', vimeo); + mediaElement.dispatchEvent(event); + }).catch(function (error) { + return errorHandler(error); + }); + }); + vimeoPlayer.on('play', function () { + paused = false; + ended = false; + var event = mejs.Utils.createEvent('play', vimeo); + mediaElement.dispatchEvent(event); + + var playingEvent = mejs.Utils.createEvent('playing', vimeo); + mediaElement.dispatchEvent(playingEvent); + }); + vimeoPlayer.on('pause', function () { + paused = true; + ended = false; + + var event = mejs.Utils.createEvent('pause', vimeo); + mediaElement.dispatchEvent(event); + }); + vimeoPlayer.on('ended', function () { + paused = false; + ended = true; + + var event = mejs.Utils.createEvent('ended', vimeo); + mediaElement.dispatchEvent(event); + }); + + events = ['rendererready', 'loadedmetadata', 'loadeddata', 'canplay']; + + for (var _i4 = 0, _total4 = events.length; _i4 < _total4; _i4++) { + var event = mejs.Utils.createEvent(events[_i4], vimeo); + mediaElement.dispatchEvent(event); + } + }; + + var height = mediaElement.originalNode.height, + width = mediaElement.originalNode.width, + vimeoContainer = document.createElement('iframe'), + standardUrl = 'https://player.vimeo.com/video/' + VimeoApi.getVimeoId(mediaFiles[0].src); + + var queryArgs = ~mediaFiles[0].src.indexOf('?') ? '?' + mediaFiles[0].src.slice(mediaFiles[0].src.indexOf('?') + 1) : ''; + var args = []; + + if (mediaElement.originalNode.autoplay && queryArgs.indexOf('autoplay') === -1) { + args.push('autoplay=1'); + } + if (mediaElement.originalNode.loop && queryArgs.indexOf('loop') === -1) { + args.push('loop=1'); + } + + queryArgs = '' + queryArgs + (queryArgs ? '&' : '?') + args.join('&'); + + vimeoContainer.setAttribute('id', vimeo.id); + vimeoContainer.setAttribute('width', width); + vimeoContainer.setAttribute('height', height); + vimeoContainer.setAttribute('frameBorder', '0'); + vimeoContainer.setAttribute('src', '' + standardUrl + queryArgs); + vimeoContainer.setAttribute('webkitallowfullscreen', 'true'); + vimeoContainer.setAttribute('mozallowfullscreen', 'true'); + vimeoContainer.setAttribute('allowfullscreen', 'true'); + vimeoContainer.setAttribute('allow', 'autoplay'); + + mediaElement.originalNode.parentNode.insertBefore(vimeoContainer, mediaElement.originalNode); + mediaElement.originalNode.style.display = 'none'; + + VimeoApi.load({ + iframe: vimeoContainer, + id: vimeo.id + }); + + vimeo.hide = function () { + vimeo.pause(); + if (vimeoPlayer) { + vimeoContainer.style.display = 'none'; + } + }; + vimeo.setSize = function (width, height) { + vimeoContainer.setAttribute('width', width); + vimeoContainer.setAttribute('height', height); + }; + vimeo.show = function () { + if (vimeoPlayer) { + vimeoContainer.style.display = ''; + } + }; + + vimeo.destroy = function () {}; + + return vimeo; + } +}; + +mejs.Utils.typeChecks.push(function (url) { + return (/(\/\/player\.vimeo|vimeo\.com)/i.test(url) ? 'video/x-vimeo' : null + ); +}); + +mejs.Renderers.add(vimeoIframeRenderer); + +},{}]},{},[1]); |