Spaces:
Sleeping
Sleeping
/*! | |
* 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){ | |
; | |
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]); | |