diff --git a/src/js/plyr.js b/src/js/plyr.js
index 37405a23..482d684d 100644
--- a/src/js/plyr.js
+++ b/src/js/plyr.js
@@ -8,7 +8,7 @@
// ==========================================================================
(function (api) {
- "use strict";
+ 'use strict';
/*global YT*/
// Globals
@@ -16,58 +16,58 @@
// Default config
var defaults = {
- enabled: true,
+ enabled: true,
debug: false,
seekTime: 10,
volume: 5,
click: true,
tooltips: false,
displayDuration: true,
- iconPrefix: "icon",
+ iconPrefix: 'icon',
selectors: {
- container: ".player",
- controls: ".player-controls",
- labels: "[data-player] .sr-only, label .sr-only",
+ container: '.player',
+ controls: '.player-controls',
+ labels: '[data-player] .sr-only, label .sr-only',
buttons: {
- seek: "[data-player='seek']",
- play: "[data-player='play']",
- pause: "[data-player='pause']",
- restart: "[data-player='restart']",
- rewind: "[data-player='rewind']",
- forward: "[data-player='fast-forward']",
- mute: "[data-player='mute']",
- volume: "[data-player='volume']",
- captions: "[data-player='captions']",
- fullscreen: "[data-player='fullscreen']"
+ seek: '[data-player="seek"]',
+ play: '[data-player="play"]',
+ pause: '[data-player="pause"]',
+ restart: '[data-player="restart"]',
+ rewind: '[data-player="rewind"]',
+ forward: '[data-player="fast-forward"]',
+ mute: '[data-player="mute"]',
+ volume: '[data-player="volume"]',
+ captions: '[data-player="captions"]',
+ fullscreen: '[data-player="fullscreen"]'
},
progress: {
- container: ".player-progress",
- buffer: ".player-progress-buffer",
- played: ".player-progress-played"
+ container: '.player-progress',
+ buffer: '.player-progress-buffer',
+ played: '.player-progress-played'
},
- captions: ".player-captions",
- currentTime: ".player-current-time",
- duration: ".player-duration"
+ captions: '.player-captions',
+ currentTime: '.player-current-time',
+ duration: '.player-duration'
},
classes: {
- videoWrapper: "player-video-wrapper",
- embedWrapper: "player-video-embed",
- type: "player-{0}",
- stopped: "stopped",
- playing: "playing",
- muted: "muted",
- loading: "loading",
- tooltip: "player-tooltip",
- hidden: "sr-only",
- hover: "player-hover",
+ videoWrapper: 'player-video-wrapper',
+ embedWrapper: 'player-video-embed',
+ type: 'player-{0}',
+ stopped: 'stopped',
+ playing: 'playing',
+ muted: 'muted',
+ loading: 'loading',
+ tooltip: 'player-tooltip',
+ hidden: 'sr-only',
+ hover: 'player-hover',
captions: {
- enabled: "captions-enabled",
- active: "captions-active"
+ enabled: 'captions-enabled',
+ active: 'captions-active'
},
fullscreen: {
- enabled: "fullscreen-enabled",
- active: "fullscreen-active",
- hideControls: "fullscreen-hide-controls"
+ enabled: 'fullscreen-enabled',
+ active: 'fullscreen-active',
+ hideControls: 'fullscreen-hide-controls'
}
},
captions: {
@@ -80,23 +80,23 @@
},
storage: {
enabled: true,
- key: "plyr_volume"
+ key: 'plyr_volume'
},
- controls: ["restart", "rewind", "play", "fast-forward", "current-time", "duration", "mute", "volume", "captions", "fullscreen"],
+ controls: ['restart', 'rewind', 'play', 'fast-forward', 'current-time', 'duration', 'mute', 'volume', 'captions', 'fullscreen'],
i18n: {
- restart: "Restart",
- rewind: "Rewind {seektime} secs",
- play: "Play",
- pause: "Pause",
- forward: "Forward {seektime} secs",
- played: "played",
- buffered: "buffered",
- currentTime: "Current time",
- duration: "Duration",
- volume: "Volume",
- toggleMute: "Toggle Mute",
- toggleCaptions: "Toggle Captions",
- toggleFullscreen: "Toggle Fullscreen"
+ restart: 'Restart',
+ rewind: 'Rewind {seektime} secs',
+ play: 'Play',
+ pause: 'Pause',
+ forward: 'Forward {seektime} secs',
+ played: 'played',
+ buffered: 'buffered',
+ currentTime: 'Current time',
+ duration: 'Duration',
+ volume: 'Volume',
+ toggleMute: 'Toggle Mute',
+ toggleCaptions: 'Toggle Captions',
+ toggleFullscreen: 'Toggle Fullscreen'
}
};
@@ -104,143 +104,143 @@
function _buildControls() {
// Open and add the progress and seek elements
var html = [
- "
",
- "
",
- "
",
- "
",
- "
",
- "
",
- "
",
- "
"];
+ '',
+ '
',
+ '
',
+ '
',
+ '
',
+ '
',
+ '
',
+ '
'];
// Restart button
- if(_inArray(config.controls, "restart")) {
+ if (_inArray(config.controls, 'restart')) {
html.push(
- ""
+ ''
);
}
// Rewind button
- if(_inArray(config.controls, "rewind")) {
+ if (_inArray(config.controls, 'rewind')) {
html.push(
- ""
+ ''
);
}
// Play/pause button
- if(_inArray(config.controls, "play")) {
+ if (_inArray(config.controls, 'play')) {
html.push(
- "",
- ""
+ '',
+ ''
);
}
// Fast forward button
- if(_inArray(config.controls, "fast-forward")) {
+ if (_inArray(config.controls, 'fast-forward')) {
html.push(
- ""
+ ''
);
}
// Media current time display
- if(_inArray(config.controls, "current-time")) {
+ if (_inArray(config.controls, 'current-time')) {
html.push(
- "",
- "" + config.i18n.currentTime + "",
- "00:00",
- ""
+ '',
+ '' + config.i18n.currentTime + '',
+ '00:00',
+ ''
);
}
// Media duration display
- if(_inArray(config.controls, "duration")) {
+ if (_inArray(config.controls, 'duration')) {
html.push(
- "",
- "" + config.i18n.duration + "",
- "00:00",
- ""
+ '',
+ '' + config.i18n.duration + '',
+ '00:00',
+ ''
);
}
// Close left controls
html.push(
- "",
- "
"
+ '',
+ '
'
);
// Toggle mute button
- if(_inArray(config.controls, "mute")) {
+ if (_inArray(config.controls, 'mute')) {
html.push(
- ""
+ ''
);
}
// Volume range control
- if(_inArray(config.controls, "volume")) {
+ if (_inArray(config.controls, 'volume')) {
html.push(
- "",
- ""
+ '',
+ ''
);
}
// Toggle captions button
- if(_inArray(config.controls, "captions")) {
+ if (_inArray(config.controls, 'captions')) {
html.push(
- ""
+ ''
);
}
// Toggle fullscreen button
- if(_inArray(config.controls, "fullscreen")) {
+ if (_inArray(config.controls, 'fullscreen')) {
html.push(
- ""
+ ''
);
}
// Close everything
html.push(
- "",
- "
"
+ '',
+ '
'
);
- return html.join("");
+ return html.join('');
}
// Debugging
function _log(text, error) {
- if(config.debug && window.console) {
- console[(error ? "error" : "log")](text);
+ if (config.debug && window.console) {
+ console[(error ? 'error' : 'log')](text);
}
}
@@ -249,42 +249,42 @@
function _browserSniff() {
var nAgt = navigator.userAgent,
name = navigator.appName,
- fullVersion = "" + parseFloat(navigator.appVersion),
+ fullVersion = '' + parseFloat(navigator.appVersion),
majorVersion = parseInt(navigator.appVersion, 10),
nameOffset,
verOffset,
ix;
// MSIE 11
- if ((navigator.appVersion.indexOf("Windows NT") !== -1) && (navigator.appVersion.indexOf("rv:11") !== -1)) {
- name = "IE";
- fullVersion = "11;";
+ if ((navigator.appVersion.indexOf('Windows NT') !== -1) && (navigator.appVersion.indexOf('rv:11') !== -1)) {
+ name = 'IE';
+ fullVersion = '11;';
}
// MSIE
- else if ((verOffset=nAgt.indexOf("MSIE")) !== -1) {
- name = "IE";
+ else if ((verOffset=nAgt.indexOf('MSIE')) !== -1) {
+ name = 'IE';
fullVersion = nAgt.substring(verOffset + 5);
}
// Chrome
- else if ((verOffset=nAgt.indexOf("Chrome")) !== -1) {
- name = "Chrome";
+ else if ((verOffset=nAgt.indexOf('Chrome')) !== -1) {
+ name = 'Chrome';
fullVersion = nAgt.substring(verOffset + 7);
}
// Safari
- else if ((verOffset=nAgt.indexOf("Safari")) !== -1) {
- name = "Safari";
+ else if ((verOffset=nAgt.indexOf('Safari')) !== -1) {
+ name = 'Safari';
fullVersion = nAgt.substring(verOffset + 7);
- if ((verOffset=nAgt.indexOf("Version")) !== -1) {
+ if ((verOffset=nAgt.indexOf('Version')) !== -1) {
fullVersion = nAgt.substring(verOffset + 8);
}
}
// Firefox
- else if ((verOffset=nAgt.indexOf("Firefox")) !== -1) {
- name = "Firefox";
+ else if ((verOffset=nAgt.indexOf('Firefox')) !== -1) {
+ name = 'Firefox';
fullVersion = nAgt.substring(verOffset + 8);
}
- // In most other browsers, "name/version" is at the end of userAgent
- else if ((nameOffset=nAgt.lastIndexOf(" ") + 1) < (verOffset=nAgt.lastIndexOf("/"))) {
+ // In most other browsers, 'name/version' is at the end of userAgent
+ else if ((nameOffset=nAgt.lastIndexOf(' ') + 1) < (verOffset=nAgt.lastIndexOf('/'))) {
name = nAgt.substring(nameOffset,verOffset);
fullVersion = nAgt.substring(verOffset + 1);
@@ -293,23 +293,23 @@
}
}
// Trim the fullVersion string at semicolon/space if present
- if ((ix = fullVersion.indexOf(";")) !== -1) {
+ if ((ix = fullVersion.indexOf(';')) !== -1) {
fullVersion = fullVersion.substring(0, ix);
}
- if ((ix = fullVersion.indexOf(" ")) !== -1) {
+ if ((ix = fullVersion.indexOf(' ')) !== -1) {
fullVersion = fullVersion.substring(0, ix);
}
// Get major version
- majorVersion = parseInt("" + fullVersion, 10);
+ majorVersion = parseInt('' + fullVersion, 10);
if (isNaN(majorVersion)) {
- fullVersion = "" + parseFloat(navigator.appVersion);
+ fullVersion = '' + parseFloat(navigator.appVersion);
majorVersion = parseInt(navigator.appVersion, 10);
}
// Return data
return {
- name: name,
- version: majorVersion,
+ name: name,
+ version: majorVersion,
ios: /(iPad|iPhone|iPod)/g.test(navigator.platform)
};
}
@@ -317,26 +317,26 @@
// Check for mime type support against a player instance
// Credits: http://diveintohtml5.info/everything.html
// Related: http://www.leanbackplayer.com/test/h5mt.html
- function _supportMime(player, mimeType) {
+ function _supportMime(player, mimeType) {
var media = player.media;
// Only check video types for video players
- if(player.type == "video") {
+ if (player.type == 'video') {
// Check type
- switch(mimeType) {
- case "video/webm": return !!(media.canPlayType && media.canPlayType("video/webm; codecs=\"vp8, vorbis\"").replace(/no/, ""));
- case "video/mp4": return !!(media.canPlayType && media.canPlayType("video/mp4; codecs=\"avc1.42E01E, mp4a.40.2\"").replace(/no/, ""));
- case "video/ogg": return !!(media.canPlayType && media.canPlayType("video/ogg; codecs=\"theora\"").replace(/no/, ""));
+ switch (mimeType) {
+ case 'video/webm': return !!(media.canPlayType && media.canPlayType('video/webm; codecs="vp8, vorbis"').replace(/no/, ''));
+ case 'video/mp4': return !!(media.canPlayType && media.canPlayType('video/mp4; codecs="avc1.42E01E, mp4a.40.2"').replace(/no/, ''));
+ case 'video/ogg': return !!(media.canPlayType && media.canPlayType('video/ogg; codecs="theora"').replace(/no/, ''));
}
}
// Only check audio types for audio players
- else if(player.type == "audio") {
+ else if (player.type == 'audio') {
// Check type
- switch(mimeType) {
- case "audio/mpeg": return !!(media.canPlayType && media.canPlayType("audio/mpeg;").replace(/no/, ""));
- case "audio/ogg": return !!(media.canPlayType && media.canPlayType("audio/ogg; codecs=\"vorbis\"").replace(/no/, ""));
- case "audio/wav": return !!(media.canPlayType && media.canPlayType("audio/wav; codecs=\"1\"").replace(/no/, ""));
+ switch (mimeType) {
+ case 'audio/mpeg': return !!(media.canPlayType && media.canPlayType('audio/mpeg;').replace(/no/, ''));
+ case 'audio/ogg': return !!(media.canPlayType && media.canPlayType('audio/ogg; codecs="vorbis"').replace(/no/, ''));
+ case 'audio/wav': return !!(media.canPlayType && media.canPlayType('audio/wav; codecs="1"').replace(/no/, ''));
}
}
@@ -346,13 +346,13 @@
// Inject a script
function _injectScript(source) {
- if(document.querySelectorAll("script[src='" + source + "']").length) {
+ if (document.querySelectorAll('script[src="' + source + '"]').length) {
return;
}
- var tag = document.createElement("script");
+ var tag = document.createElement('script');
tag.src = source;
- var firstScriptTag = document.getElementsByTagName("script")[0];
+ var firstScriptTag = document.getElementsByTagName('script')[0];
firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
}
@@ -363,7 +363,7 @@
// Replace all
function _replaceAll(string, find, replace) {
- return string.replace(new RegExp(find.replace(/([.*+?^=!:${}()|\[\]\/\\])/g, "\\$1"), "g"), replace);
+ return string.replace(new RegExp(find.replace(/([.*+?\^=!:${}()|\[\]\/\\])/g, '\\$1'), 'g'), replace);
}
// Wrap an element
@@ -426,30 +426,30 @@
// Set attributes
function _setAttributes(element, attributes) {
- for(var key in attributes) {
+ for (var key in attributes) {
element.setAttribute(key, attributes[key]);
}
}
// Toggle class on an element
function _toggleClass(element, name, state) {
- if(element){
- if(element.classList) {
- element.classList[state ? "add" : "remove"](name);
+ if (element) {
+ if (element.classList) {
+ element.classList[state ? 'add' : 'remove'](name);
}
else {
- var className = (" " + element.className + " ").replace(/\s+/g, " ").replace(" " + name + " ", "");
- element.className = className + (state ? " " + name : "");
+ var className = (' ' + element.className + ' ').replace(/\s+/g, ' ').replace(' ' + name + ' ', '');
+ element.className = className + (state ? ' ' + name : '');
}
}
}
// Toggle event
function _toggleHandler(element, events, callback, toggle) {
- var eventList = events.split(" ");
+ var eventList = events.split(' ');
// If a nodelist is passed, call itself on each node
- if(element instanceof NodeList) {
+ if (element instanceof NodeList) {
for (var x = 0; x < element.length; x++) {
if (element[x] instanceof Node) {
_toggleHandler(element[x], arguments[1], arguments[2], arguments[3]);
@@ -460,20 +460,20 @@
// If a single node is passed, bind the event listener
for (var i = 0; i < eventList.length; i++) {
- element[toggle ? "addEventListener" : "removeEventListener"](eventList[i], callback, false);
+ element[toggle ? 'addEventListener' : 'removeEventListener'](eventList[i], callback, false);
}
}
// Bind event
function _on(element, events, callback) {
- if(element) {
+ if (element) {
_toggleHandler(element, events, callback, true);
}
}
// Unbind event
function _off(element, events, callback) {
- if(element) {
+ if (element) {
_toggleHandler(element, events, callback, false);
}
}
@@ -481,7 +481,7 @@
// Trigger event
function _triggerEvent(element, event) {
// Create faux event
- var fauxEvent = document.createEvent("MouseEvents");
+ var fauxEvent = document.createEvent('MouseEvents');
// Set the event type
fauxEvent.initEvent(event, true, true);
@@ -493,17 +493,17 @@
// Toggle aria-pressed state on a toggle button
function _toggleState(target, state) {
// Get state
- state = (typeof state === "boolean" ? state : !target.getAttribute("aria-pressed"));
+ state = (typeof state === 'boolean' ? state : !target.getAttribute('aria-pressed'));
// Set the attribute on target
- target.setAttribute("aria-pressed", state);
+ target.setAttribute('aria-pressed', state);
return state;
}
// Get percentage
function _getPercentage(current, max) {
- if(current === 0 || max === 0 || isNaN(current) || isNaN(max)) {
+ if (current === 0 || max === 0 || isNaN(current) || isNaN(max)) {
return 0;
}
return ((current / max) * 100).toFixed(2);
@@ -532,14 +532,14 @@
isFullScreen: function() { return false; },
requestFullScreen: function() {},
cancelFullScreen: function() {},
- fullScreenEventName: "",
+ fullScreenEventName: '',
element: null,
- prefix: ""
+ prefix: ''
},
- browserPrefixes = "webkit moz o ms khtml".split(" ");
+ browserPrefixes = 'webkit moz o ms khtml'.split(' ');
// Check for native support
- if (typeof document.cancelFullScreen != "undefined") {
+ if (typeof document.cancelFullScreen !== 'undefined') {
fullscreen.supportsFullScreen = true;
}
else {
@@ -547,13 +547,13 @@
for (var i = 0, il = browserPrefixes.length; i < il; i++ ) {
fullscreen.prefix = browserPrefixes[i];
- if (typeof document[fullscreen.prefix + "CancelFullScreen"] != "undefined") {
+ if (typeof document[fullscreen.prefix + 'CancelFullScreen'] !== 'undefined') {
fullscreen.supportsFullScreen = true;
break;
}
// Special case for MS (when isn't it?)
- else if (typeof document.msExitFullscreen != "undefined" && document.msFullscreenEnabled) {
- fullscreen.prefix = "ms";
+ else if (typeof document.msExitFullscreen !== 'undefined' && document.msFullscreenEnabled) {
+ fullscreen.prefix = 'ms';
fullscreen.supportsFullScreen = true;
break;
}
@@ -562,34 +562,34 @@
// Update methods to do something useful
if (fullscreen.supportsFullScreen) {
- // Yet again Microsoft awesomeness,
- // Sometimes the prefix is "ms", sometimes "MS" to keep you on your toes
- fullscreen.fullScreenEventName = (fullscreen.prefix == "ms" ? "MSFullscreenChange" : fullscreen.prefix + "fullscreenchange");
+ // Yet again Microsoft awesomeness,
+ // Sometimes the prefix is 'ms', sometimes 'MS' to keep you on your toes
+ fullscreen.fullScreenEventName = (fullscreen.prefix == 'ms' ? 'MSFullscreenChange' : fullscreen.prefix + 'fullscreenchange');
fullscreen.isFullScreen = function(element) {
- if(typeof element == "undefined") {
+ if (typeof element === 'undefined') {
element = document.body;
}
switch (this.prefix) {
- case "":
+ case '':
return document.fullscreenElement == element;
- case "moz":
+ case 'moz':
return document.mozFullScreenElement == element;
default:
- return document[this.prefix + "FullscreenElement"] == element;
+ return document[this.prefix + 'FullscreenElement'] == element;
}
};
fullscreen.requestFullScreen = function(element) {
- if(typeof element == "undefined") {
+ if (typeof element === 'undefined') {
element = document.body;
}
- return (this.prefix === "") ? element.requestFullScreen() : element[this.prefix + (this.prefix == "ms" ? "RequestFullscreen" : "RequestFullScreen")]();
+ return (this.prefix === '') ? element.requestFullScreen() : element[this.prefix + (this.prefix == 'ms' ? 'RequestFullscreen' : 'RequestFullScreen')]();
};
fullscreen.cancelFullScreen = function() {
- return (this.prefix === "") ? document.cancelFullScreen() : document[this.prefix + (this.prefix == "ms" ? "ExitFullscreen" : "CancelFullScreen")]();
+ return (this.prefix === '') ? document.cancelFullScreen() : document[this.prefix + (this.prefix == 'ms' ? 'ExitFullscreen' : 'CancelFullScreen')]();
};
- fullscreen.element = function() {
- return (this.prefix === "") ? document.fullscreenElement : document[this.prefix + "FullscreenElement"];
+ fullscreen.element = function() {
+ return (this.prefix === '') ? document.fullscreenElement : document[this.prefix + 'FullscreenElement'];
};
}
@@ -601,13 +601,13 @@
var storage = {
supported: (function() {
try {
- return "localStorage" in window && window.localStorage !== null;
+ return 'localStorage' in window && window.localStorage !== null;
}
catch(e) {
return false;
}
})()
- }
+ };
return storage;
}
@@ -620,7 +620,7 @@
// Seek the manual caption time and update UI
function _seekManualCaptions(time) {
// If it's not video, or we're using textTracks, bail.
- if (player.usingTextTracks || player.type !== "video" || !player.supported.full) {
+ if (player.usingTextTracks || player.type !== 'video' || !player.supported.full) {
return;
}
@@ -630,7 +630,7 @@
// Check time is a number, if not use currentTime
// IE has a bug where currentTime doesn't go to 0
// https://twitter.com/Sam_Potts/status/573715746506731521
- time = typeof time === "number" ? time : player.media.currentTime;
+ time = typeof time === 'number' ? time : player.media.currentTime;
while (_timecodeMax(player.captions[player.subcount][0]) < time.toFixed(1)) {
player.subcount++;
@@ -649,24 +649,24 @@
var content = player.currentCaption.trim();
// Render the caption (only if changed)
- if(player.captionsContainer.innerHTML != content) {
+ if (player.captionsContainer.innerHTML != content) {
// Empty caption
// Otherwise NVDA reads it twice
- player.captionsContainer.innerHTML = "";
+ player.captionsContainer.innerHTML = '';
// Set new caption text
player.captionsContainer.innerHTML = content;
}
}
else {
- player.captionsContainer.innerHTML = "";
+ player.captionsContainer.innerHTML = '';
}
}
// Display captions container and button (for initialization)
function _showCaptions() {
// If there's no caption toggle, bail
- if(!player.buttons.captions) {
+ if (!player.buttons.captions) {
return;
}
@@ -681,12 +681,12 @@
// Utilities for caption time codes
function _timecodeMin(tc) {
var tcpair = [];
- tcpair = tc.split(" --> ");
+ tcpair = tc.split(' --> ');
return _subTcSecs(tcpair[0]);
}
function _timecodeMax(tc) {
var tcpair = [];
- tcpair = tc.split(" --> ");
+ tcpair = tc.split(' --> ');
return _subTcSecs(tcpair[1]);
}
function _subTcSecs(tc) {
@@ -697,8 +697,8 @@
var tc1 = [],
tc2 = [],
seconds;
- tc1 = tc.split(",");
- tc2 = tc1[0].split(":");
+ tc1 = tc.split(',');
+ tc2 = tc1[0].split(':');
seconds = Math.floor(tc2[0]*60*60) + Math.floor(tc2[1]*60) + Math.floor(tc2[2]);
return seconds;
}
@@ -730,24 +730,24 @@
var html = config.html;
// Insert custom video controls
- _log("Injecting custom controls.");
+ _log('Injecting custom controls.');
// If no controls are specified, create default
- if(!html) {
+ if (!html) {
html = _buildControls();
}
// Replace seek time instances
- html = _replaceAll(html, "{seektime}", config.seekTime);
+ html = _replaceAll(html, '{seektime}', config.seekTime);
// Replace all id references with random numbers
- html = _replaceAll(html, "{id}", Math.floor(Math.random() * (10000)));
+ html = _replaceAll(html, '{id}', Math.floor(Math.random() * (10000)));
// Inject into the container
- player.container.insertAdjacentHTML("beforeend", html);
+ player.container.insertAdjacentHTML('beforeend', html);
// Setup tooltips
- if(config.tooltips) {
+ if (config.tooltips) {
var labels = _getElements(config.selectors.labels);
for (var i = labels.length - 1; i >= 0; i--) {
@@ -777,7 +777,7 @@
// Inputs
player.buttons.mute = _getElement(config.selectors.buttons.mute);
player.buttons.captions = _getElement(config.selectors.buttons.captions);
- player.checkboxes = _getElements("[type='checkbox']");
+ player.checkboxes = _getElements('[type="checkbox"]');
// Progress
player.progress = {};
@@ -786,12 +786,12 @@
// Progress - Buffering
player.progress.buffer = {};
player.progress.buffer.bar = _getElement(config.selectors.progress.buffer);
- player.progress.buffer.text = player.progress.buffer.bar && player.progress.buffer.bar.getElementsByTagName("span")[0];
+ player.progress.buffer.text = player.progress.buffer.bar && player.progress.buffer.bar.getElementsByTagName('span')[0];
// Progress - Played
player.progress.played = {};
player.progress.played.bar = _getElement(config.selectors.progress.played);
- player.progress.played.text = player.progress.played.bar && player.progress.played.bar.getElementsByTagName("span")[0];
+ player.progress.played.text = player.progress.played.bar && player.progress.played.bar.getElementsByTagName('span')[0];
// Volume
player.volume = _getElement(config.selectors.buttons.volume);
@@ -804,10 +804,10 @@
return true;
}
catch(e) {
- _log("It looks like there's a problem with your controls html. Bailing.", true);
+ _log('It looks like there\'s a problem with your controls html. Bailing.', true);
// Restore native video controls
- player.media.setAttribute("controls", "");
+ player.media.setAttribute('controls', '');
return false;
}
@@ -816,7 +816,7 @@
// Setup aria attribute for play
function _setupPlayAria() {
// If there's no play button, bail
- if(!player.buttons.play) {
+ if (!player.buttons.play) {
return;
}
@@ -824,41 +824,41 @@
var label = player.buttons.play.innerText || config.i18n.play;
// If there's a media title set, use that for the label
- if (typeof(config.title) !== "undefined" && config.title.length) {
- label += ", " + config.title;
+ if (typeof(config.title) !== 'undefined' && config.title.length) {
+ label += ', ' + config.title;
}
- player.buttons.play.setAttribute("aria-label", label);
+ player.buttons.play.setAttribute('aria-label', label);
}
// Setup media
function _setupMedia() {
// If there's no media, bail
- if(!player.media) {
- _log("No audio or video element found!", true);
+ if (!player.media) {
+ _log('No audio or video element found!', true);
return false;
}
- if(player.supported.full) {
+ if (player.supported.full) {
// Remove native video controls
- player.media.removeAttribute("controls");
+ player.media.removeAttribute('controls');
// Add type class
- _toggleClass(player.container, config.classes.type.replace("{0}", player.type), true);
+ _toggleClass(player.container, config.classes.type.replace('{0}', player.type), true);
// If there's no autoplay attribute, assume the video is stopped and add state class
- _toggleClass(player.container, config.classes.stopped, (player.media.getAttribute("autoplay") === null));
+ _toggleClass(player.container, config.classes.stopped, (player.media.getAttribute('autoplay') === null));
// Add iOS class
- if(player.browser.ios) {
- _toggleClass(player.container, "ios", true);
+ if (player.browser.ios) {
+ _toggleClass(player.container, 'ios', true);
}
// Inject the player wrapper
- if(player.type === "video") {
+ if (player.type === 'video') {
// Create the wrapper div
- var wrapper = document.createElement("div");
- wrapper.setAttribute("class", config.classes.videoWrapper);
+ var wrapper = document.createElement('div');
+ wrapper.setAttribute('class', config.classes.videoWrapper);
// Wrap the video in a container
_wrap(player.media, wrapper);
@@ -869,12 +869,12 @@
}
// YouTube
- if(player.type == "youtube") {
- _setupYouTube(player.media.getAttribute("data-video-id"));
+ if (player.type == 'youtube') {
+ _setupYouTube(player.media.getAttribute('data-video-id'));
}
// Autoplay
- if(player.media.getAttribute("autoplay") !== null) {
+ if (player.media.getAttribute('autoplay') !== null) {
_play();
}
}
@@ -882,39 +882,39 @@
// Setup YouTube
function _setupYouTube(id) {
// Remove old containers
- var containers = _getElements("[id^='youtube']");
+ var containers = _getElements('[id^="youtube"]');
for (var i = containers.length - 1; i >= 0; i--) {
_remove(containers[i]);
}
// Create the YouTube container
- var container = document.createElement("div");
- container.setAttribute("id", "youtube-" + Math.floor(Math.random() * (10000)));
+ var container = document.createElement('div');
+ container.setAttribute('id', 'youtube-' + Math.floor(Math.random() * (10000)));
player.media.appendChild(container);
// Add embed class for responsive
_toggleClass(player.media, config.classes.videoWrapper, true);
_toggleClass(player.media, config.classes.embedWrapper, true);
- if(typeof YT === "object") {
+ if (typeof YT === 'object') {
_YTReady(id, container);
}
else {
// Load the API
- _injectScript("https://www.youtube.com/iframe_api");
+ _injectScript('https://www.youtube.com/iframe_api');
// Setup callback for the API
- window.onYouTubeIframeAPIReady = function () { _YTReady(id, container); }
+ window.onYouTubeIframeAPIReady = function () { _YTReady(id, container); };
}
}
// Handle API ready
function _YTReady(id, container) {
- _log("YouTube API Ready");
+ _log('YouTube API Ready');
// Setup timers object
// We have to poll YouTube for updates
- if(!("timer" in player)) {
+ if (!('timer' in player)) {
player.timer = {};
}
@@ -929,13 +929,13 @@
showinfo: 0,
iv_load_policy: 3,
cc_load_policy: (config.captions.defaultActive ? 1 : 0),
- cc_lang_pref: "en",
- wmode: "transparent",
+ cc_lang_pref: 'en',
+ wmode: 'transparent',
modestbranding: 1,
disablekb: 1
},
events: {
- "onReady": function(event) {
+ 'onReady': function(event) {
// Get the instance
var instance = event.target;
@@ -949,38 +949,38 @@
player.media.muted = instance.isMuted();
// Trigger timeupdate
- _triggerEvent(player.media, "timeupdate");
+ _triggerEvent(player.media, 'timeupdate');
// Reset timer
window.clearInterval(player.timer.buffering);
// Setup buffering
- player.timer.buffering = window.setInterval(function() {
+ player.timer.buffering = window.setInterval(function() {
// Get loaded % from YouTube
player.media.buffered = instance.getVideoLoadedFraction();
// Trigger progress
- _triggerEvent(player.media, "progress");
+ _triggerEvent(player.media, 'progress');
// Bail if we're at 100%
- if(player.media.buffered === 1) {
+ if (player.media.buffered === 1) {
window.clearInterval(player.timer.buffering);
}
}, 200);
- if(player.supported.full) {
+ if (player.supported.full) {
// Only setup controls once
- if(!player.container.querySelectorAll(config.selectors.controls).length) {
+ if (!player.container.querySelectorAll(config.selectors.controls).length) {
_setupInterface();
}
// Display duration if available
- if(config.displayDuration) {
+ if (config.displayDuration) {
_displayDuration();
}
}
},
- "onStateChange": function(event) {
+ 'onStateChange': function(event) {
// Get the instance
var instance = event.target;
@@ -994,15 +994,15 @@
// 2 Paused
// 3 Buffering
// 5 Video cued
- switch(event.data) {
+ switch (event.data) {
case 0:
player.media.paused = true;
- _triggerEvent(player.media, "ended");
+ _triggerEvent(player.media, 'ended');
break;
case 1:
player.media.paused = false;
- _triggerEvent(player.media, "play");
+ _triggerEvent(player.media, 'play');
// Poll to get playback progress
player.timer.playing = window.setInterval(function() {
@@ -1010,15 +1010,14 @@
player.media.currentTime = instance.getCurrentTime();
// Trigger timeupdate
- _triggerEvent(player.media, "timeupdate");
+ _triggerEvent(player.media, 'timeupdate');
}, 200);
break;
case 2:
player.media.paused = true;
- _triggerEvent(player.media, "pause");
- break;
+ _triggerEvent(player.media, 'pause');
}
}
}
@@ -1027,12 +1026,12 @@
// Setup captions
function _setupCaptions() {
- if(player.type === "video") {
+ if (player.type === 'video') {
// Inject the container
- player.videoContainer.insertAdjacentHTML("afterbegin", "
");
+ player.videoContainer.insertAdjacentHTML('afterbegin', '
');
// Cache selector
- player.captionsContainer = _getElement(config.selectors.captions).querySelector("span");
+ player.captionsContainer = _getElement(config.selectors.captions).querySelector('span');
// Determine if HTML5 textTracks is supported
player.usingTextTracks = false;
@@ -1041,27 +1040,27 @@
}
// Get URL of caption file if exists
- var captionSrc = "",
+ var captionSrc = '',
kind,
children = player.media.childNodes;
for (var i = 0; i < children.length; i++) {
- if (children[i].nodeName.toLowerCase() === "track") {
+ if (children[i].nodeName.toLowerCase() === 'track') {
kind = children[i].kind;
- if (kind === "captions" || kind === "subtitles") {
- captionSrc = children[i].getAttribute("src");
+ if (kind === 'captions' || kind === 'subtitles') {
+ captionSrc = children[i].getAttribute('src');
}
}
}
// Record if caption file exists or not
player.captionExists = true;
- if (captionSrc === "") {
+ if (captionSrc === '') {
player.captionExists = false;
- _log("No caption track found.");
+ _log('No caption track found.');
}
else {
- _log("Caption track found; URI: " + captionSrc);
+ _log('Caption track found; URI: ' + captionSrc);
}
// If no caption file exists, hide container for caption text
@@ -1073,40 +1072,40 @@
// Turn off native caption rendering to avoid double captions
// This doesn't seem to work in Safari 7+, so the