416 lines
		
	
	
	
		
			12 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			416 lines
		
	
	
	
		
			12 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /*!
 | |
|  * 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 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})({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 === undefined || url === null) {
 | |
| 			return null;
 | |
| 		}
 | |
| 
 | |
| 		var parts = url.split('?');
 | |
| 		url = parts[0];
 | |
| 		return parseInt(url.substring(url.lastIndexOf('/') + 1), 10);
 | |
| 	}
 | |
| };
 | |
| 
 | |
| 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, target) {
 | |
| 			var event = mejs.Utils.createEvent('error', target);
 | |
| 			event.message = error.name + ': ' + error.message;
 | |
| 			mediaElement.dispatchEvent(event);
 | |
| 		};
 | |
| 
 | |
| 		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;
 | |
| 							});
 | |
| 
 | |
| 							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) {
 | |
| 								errorHandler(error, vimeo);
 | |
| 							});
 | |
| 							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) {
 | |
| 								errorHandler(error, vimeo);
 | |
| 							});
 | |
| 							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) {
 | |
| 								errorHandler(error, vimeo);
 | |
| 							});
 | |
| 							break;
 | |
| 						case 'loop':
 | |
| 							vimeoPlayer.setLoop(value).catch(function (error) {
 | |
| 								errorHandler(error, vimeo);
 | |
| 							});
 | |
| 							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) {
 | |
| 									errorHandler(error, vimeo);
 | |
| 								});
 | |
| 							} else {
 | |
| 								vimeoPlayer.setVolume(oldVolume).then(function () {
 | |
| 									volume = oldVolume;
 | |
| 									setTimeout(function () {
 | |
| 										var event = mejs.Utils.createEvent('volumechange', vimeo);
 | |
| 										mediaElement.dispatchEvent(event);
 | |
| 									}, 50);
 | |
| 								}).catch(function (error) {
 | |
| 									errorHandler(error, vimeo);
 | |
| 								});
 | |
| 							}
 | |
| 							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) {
 | |
| 					errorHandler(error, vimeo);
 | |
| 				});
 | |
| 			});
 | |
| 			vimeoPlayer.on('timeupdate', function () {
 | |
| 				vimeoPlayer.getCurrentTime().then(function (seconds) {
 | |
| 					currentTime = seconds;
 | |
| 
 | |
| 					var event = mejs.Utils.createEvent('timeupdate', vimeo);
 | |
| 					mediaElement.dispatchEvent(event);
 | |
| 				}).catch(function (error) {
 | |
| 					errorHandler(error, vimeo);
 | |
| 				});
 | |
| 			});
 | |
| 			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) : '';
 | |
| 		if (queryArgs && mediaElement.originalNode.autoplay && queryArgs.indexOf('autoplay') === -1) {
 | |
| 			queryArgs += '&autoplay=1';
 | |
| 		}
 | |
| 		if (queryArgs && mediaElement.originalNode.loop && queryArgs.indexOf('loop') === -1) {
 | |
| 			queryArgs += '&loop=1';
 | |
| 		}
 | |
| 
 | |
| 		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', '');
 | |
| 		vimeoContainer.setAttribute('mozallowfullscreen', '');
 | |
| 		vimeoContainer.setAttribute('allowfullscreen', '');
 | |
| 
 | |
| 		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]);
 |