summaryrefslogtreecommitdiffstats
path: root/wp-includes/js/mediaelement/renderers/vimeo.js
diff options
context:
space:
mode:
Diffstat (limited to 'wp-includes/js/mediaelement/renderers/vimeo.js')
-rw-r--r--wp-includes/js/mediaelement/renderers/vimeo.js432
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]);