aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xassets/icons/bubble.svg6
-rwxr-xr-xassets/icons/film.svg6
-rw-r--r--assets/icons/muted.svg14
-rw-r--r--assets/icons/pause.svg8
-rw-r--r--assets/js/docs.js20
-rw-r--r--assets/js/simple-media.js1197
-rw-r--r--assets/less/simple-media.less200
-rw-r--r--assets/templates/controls.html57
-rwxr-xr-xdesign/IcoMoon/PNG/bubble.pngbin0 -> 420 bytes
-rwxr-xr-xdesign/IcoMoon/PNG/fast-forward.png (renamed from design/IcoMoon - 7 Icons/PNG/fast-forward.png)bin360 -> 360 bytes
-rwxr-xr-xdesign/IcoMoon/PNG/film.png (renamed from design/IcoMoon - 7 Icons/PNG/film.png)bin157 -> 157 bytes
-rwxr-xr-xdesign/IcoMoon/PNG/monitor.png (renamed from design/IcoMoon - 7 Icons/PNG/monitor.png)bin199 -> 199 bytes
-rwxr-xr-xdesign/IcoMoon/PNG/play.png (renamed from design/IcoMoon - 7 Icons/PNG/play.png)bin329 -> 329 bytes
-rwxr-xr-xdesign/IcoMoon/PNG/refresh.png (renamed from design/IcoMoon - 7 Icons/PNG/refresh.png)bin441 -> 441 bytes
-rwxr-xr-xdesign/IcoMoon/PNG/sound.png (renamed from design/IcoMoon - 7 Icons/PNG/sound.png)bin328 -> 328 bytes
-rwxr-xr-xdesign/IcoMoon/PNG/up.png (renamed from design/IcoMoon - 7 Icons/PNG/up.png)bin419 -> 419 bytes
-rwxr-xr-xdesign/IcoMoon/Read Me.txt (renamed from design/IcoMoon - 7 Icons/Read Me.txt)0
-rwxr-xr-xdesign/IcoMoon/SVG/bubble.svg6
-rwxr-xr-xdesign/IcoMoon/SVG/fast-forward.svg (renamed from design/IcoMoon - 7 Icons/SVG/fast-forward.svg)0
-rwxr-xr-xdesign/IcoMoon/SVG/film.svg (renamed from design/IcoMoon - 7 Icons/SVG/film.svg)0
-rwxr-xr-xdesign/IcoMoon/SVG/monitor.svg (renamed from design/IcoMoon - 7 Icons/SVG/monitor.svg)0
-rwxr-xr-xdesign/IcoMoon/SVG/play.svg (renamed from design/IcoMoon - 7 Icons/SVG/play.svg)0
-rwxr-xr-xdesign/IcoMoon/SVG/refresh.svg (renamed from design/IcoMoon - 7 Icons/SVG/refresh.svg)0
-rwxr-xr-xdesign/IcoMoon/SVG/sound.svg (renamed from design/IcoMoon - 7 Icons/SVG/sound.svg)0
-rwxr-xr-xdesign/IcoMoon/SVG/up.svg (renamed from design/IcoMoon - 7 Icons/SVG/up.svg)0
-rwxr-xr-xdesign/IcoMoon/demo-files/demo.css (renamed from design/IcoMoon - 7 Icons/demo-files/demo.css)0
-rwxr-xr-xdesign/IcoMoon/demo.html (renamed from design/IcoMoon - 7 Icons/demo.html)9
-rwxr-xr-xdesign/IcoMoon/style.css (renamed from design/IcoMoon - 7 Icons/style.css)0
-rwxr-xr-xdesign/IcoMoon/svgdefs.svg (renamed from design/IcoMoon - 7 Icons/svgdefs.svg)4
-rw-r--r--design/captions.sketchbin0 -> 49152 bytes
-rw-r--r--design/muted.sketchbin0 -> 40960 bytes
-rw-r--r--design/pause.sketchbin32768 -> 40960 bytes
-rw-r--r--dist/css/simple-media.css2
-rw-r--r--dist/js/docs.js2
-rw-r--r--dist/js/simple-media.js2
-rw-r--r--dist/js/templates.js2
-rw-r--r--dist/svg/sprite.svg2
-rw-r--r--docs/index.html3
-rw-r--r--gulpfile.js6
39 files changed, 885 insertions, 661 deletions
diff --git a/assets/icons/bubble.svg b/assets/icons/bubble.svg
new file mode 100755
index 00000000..7090121a
--- /dev/null
+++ b/assets/icons/bubble.svg
@@ -0,0 +1,6 @@
+<?xml version="1.0" encoding="utf-8"?>
+<!-- Generated by IcoMoon.io -->
+<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
+<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="18" height="18" viewBox="0 0 18 18">
+<path d="M9.016 3c2.748 0 4.984 2.243 4.984 5s-2.236 5-4.97 5l-0.060-0.004c-0.055-0.004-0.11-0.007-0.165-0.010l-0.336-0.014-3.665 1.098 0.629-2.483-0.517-0.747c-0.58-0.839-0.886-1.822-0.886-2.842 0-2.757 2.236-5 4.984-5zM9.016 1c-3.857 0-6.984 3.134-6.984 7 0 1.479 0.46 2.848 1.241 3.978l-1.272 5.022 6.722-2.015c0.098 0.004 0.194 0.015 0.293 0.015 3.857 0 6.984-3.134 6.984-7s-3.127-7-6.984-7v0z"></path>
+</svg>
diff --git a/assets/icons/film.svg b/assets/icons/film.svg
deleted file mode 100755
index ad3d3551..00000000
--- a/assets/icons/film.svg
+++ /dev/null
@@ -1,6 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<!-- Generated by IcoMoon.io -->
-<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
-<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="18" height="18" viewBox="0 0 18 18">
-<path d="M17 2h-16c-0.552 0-1 0.448-1 1v12c0 0.552 0.448 1 1 1h16c0.552 0 1-0.448 1-1v-12c0-0.552-0.448-1-1-1zM2 4h2v2h-2v-2zM2 8h2v2h-2v-2zM2 14v-2h2v2h-2zM6 14v-10h6v10h-6zM16 14h-2v-2h2v2zM16 10h-2v-2h2v2zM16 6h-2v-2h2v2z"></path>
-</svg>
diff --git a/assets/icons/muted.svg b/assets/icons/muted.svg
new file mode 100644
index 00000000..031da8d1
--- /dev/null
+++ b/assets/icons/muted.svg
@@ -0,0 +1,14 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg width="18px" height="18px" viewBox="0 0 18 18" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:sketch="http://www.bohemiancoding.com/sketch/ns">
+ <!-- Generator: Sketch 3.2.2 (9983) - http://www.bohemiancoding.com/sketch -->
+ <title>muted</title>
+ <desc>Created with Sketch.</desc>
+ <defs></defs>
+ <g id="Page-1" stroke="none" stroke-width="1" sketch:type="MSPage">
+ <g id="sound" sketch:type="MSLayerGroup" transform="translate(0.000000, 2.000000)">
+ <path d="M9.214,0 C9.103,0 8.989,0.032 8.88,0.101 L4.832,2.911 C4.749,2.969 4.65,3 4.549,3 L0.996,3 C0.446,3 1.33226763e-15,3.448 1.33226763e-15,4 L1.33226763e-15,10 C1.33226763e-15,10.552 0.446,11 0.996,11 L4.549,11 C4.651,11 4.749,11.031 4.832,11.089 L8.88,13.899 C8.989,13.968 9.103,14 9.214,14 C9.606,14 9.961,13.6 9.961,13.051 L9.961,0.95 C9.961,0.4 9.606,0.001 9.214,0.001 L9.214,0 Z M7.969,10.834 L5.582,9.177 C5.416,9.062 5.218,8.999 5.016,8.999 L2.491,8.999 C2.216,8.999 1.993,8.775 1.993,8.499 L1.993,5.499 C1.993,5.223 2.216,4.999 2.491,4.999 L5.016,4.999 C5.218,4.999 5.416,4.937 5.582,4.821 L7.969,3.164 L7.969,10.833 L7.969,10.834 Z" id="Shape" sketch:type="MSShapeGroup"></path>
+ <path d="M14.934,6.799 C14.848,5.051 13.42,3.808 12.427,3.15 C11.957,2.838 11.333,3.028 11.102,3.558 L11.064,3.644 C10.876,4.075 11.019,4.583 11.4,4.838 C12.106,5.311 12.986,6.085 13.024,6.903 C13.056,7.579 12.471,8.371 11.361,9.173 C10.963,9.461 10.832,10.012 11.076,10.448 L11.118,10.523 C11.384,10.998 11.984,11.147 12.418,10.835 C14.158,9.584 15.004,8.229 14.934,6.798 L14.934,6.799 Z" id="Shape" sketch:type="MSShapeGroup"></path>
+ <path d="M17.934,6.799 C17.848,5.051 16.42,3.808 15.427,3.15 C14.957,2.838 14.333,3.028 14.102,3.558 L14.064,3.644 C13.876,4.075 14.019,4.583 14.4,4.838 C15.106,5.311 15.986,6.085 16.024,6.903 C16.056,7.579 15.471,8.371 14.361,9.173 C13.963,9.461 13.832,10.012 14.076,10.448 L14.118,10.523 C14.384,10.998 14.984,11.147 15.418,10.835 C17.158,9.584 18.004,8.229 17.934,6.798 L17.934,6.799 Z" id="Shape-2" sketch:type="MSShapeGroup" transform="translate(15.945467, 6.999165) rotate(-180.000000) translate(-15.945467, -6.999165) "></path>
+ </g>
+ </g>
+</svg> \ No newline at end of file
diff --git a/assets/icons/pause.svg b/assets/icons/pause.svg
index d451beca..ea2efe98 100644
--- a/assets/icons/pause.svg
+++ b/assets/icons/pause.svg
@@ -4,10 +4,10 @@
<title>pause</title>
<desc>Created with Sketch.</desc>
<defs></defs>
- <g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" sketch:type="MSPage">
- <g id="pause" sketch:type="MSLayerGroup" transform="translate(3.000000, 3.000000)" stroke="#FFFFFF" stroke-width="2">
- <rect id="Rectangle-1" sketch:type="MSShapeGroup" x="8" y="0" width="4" height="12" rx="1"></rect>
- <rect id="Rectangle-2" sketch:type="MSShapeGroup" x="0" y="0" width="4" height="12" rx="1"></rect>
+ <g id="Page-1" stroke="none" stroke-width="1" sketch:type="MSPage">
+ <g id="pause" sketch:type="MSLayerGroup" transform="translate(2.000000, 2.000000)">
+ <path d="M0,2 L0,12 C5.24848613e-17,14 2,14 2,14 L4,14 C4,14 6,14 6,12 C6,11.786438 6,11.572876 6,11 L6,2 C6,3.17446247e-09 4,0 4,0 L2,0 C2,0 0,0 0,2 Z M2,2 L4,2 L4,12 L2,12 L2,2 Z" id="Path-1" sketch:type="MSShapeGroup"></path>
+ <path d="M8,2 L8,12 C8,14 10,14 10,14 L12,14 C12,14 14,14 14,12 C14,11.786438 14,11.572876 14,11 L14,2 C14,3.17446247e-09 12,0 12,0 L10,0 C10,0 8,0 8,2 Z M10,2 L12,2 L12,12 L10,12 L10,2 Z" id="Path-2" sketch:type="MSShapeGroup"></path>
</g>
</g>
</svg> \ No newline at end of file
diff --git a/assets/js/docs.js b/assets/js/docs.js
index f80fe696..fcb05868 100644
--- a/assets/js/docs.js
+++ b/assets/js/docs.js
@@ -2,16 +2,16 @@
// Docs example
// ==========================================================================
-/*global InitPxVideo, Mustache, templates */
+/*global simpleMedia, templates */
-// Initialize
-var video = new InitPxVideo({
- "videoId": "myvid",
- "captionsOnDefault": true,
- "seekInterval": 20,
- "videoTitle": "PayPal Austin promo",
- "debug": true,
- "html": templates.controls.render({})
+// Register a callback
+simpleMedia.on("setup", function() {
+ console.log(this);
});
-console.log(video); \ No newline at end of file
+//execute shout
+simpleMedia.setup({
+ debug: true,
+ title: "PayPal demo",
+ html: templates.controls.render({})
+}); \ No newline at end of file
diff --git a/assets/js/simple-media.js b/assets/js/simple-media.js
index 09d67ce3..e188893b 100644
--- a/assets/js/simple-media.js
+++ b/assets/js/simple-media.js
@@ -6,167 +6,57 @@
// Credits: http://paypal.github.io/accessible-html5-video-player/
// ==========================================================================
-// Fullscreen API
-(function() {
- var
- fullscreen = {
- supportsFullScreen: false,
- isFullScreen: function() { return false; },
- requestFullScreen: function() {},
- cancelFullScreen: function() {},
- fullScreenEventName: "",
- element: null,
- prefix: ""
- },
- browserPrefixes = "webkit moz o ms khtml".split(" ");
-
- // check for native support
- if (typeof document.cancelFullScreen != "undefined") {
- fullscreen.supportsFullScreen = true;
- }
- else {
- // check for fullscreen support by vendor prefix
- for (var i = 0, il = browserPrefixes.length; i < il; i++ ) {
- fullscreen.prefix = browserPrefixes[i];
-
- if (typeof document[fullscreen.prefix + "CancelFullScreen" ] != "undefined" ) {
- fullscreen.supportsFullScreen = true;
-
- break;
- }
- }
- }
-
- // Safari doesn't support the ALLOW_KEYBOARD_INPUT flag so set it to not supported
- // https://bugs.webkit.org/show_bug.cgi?id=121496
- if(fullscreen.prefix === "webkit" && !!navigator.userAgent.match(/Version\/[\d\.]+.*Safari/)) {
- fullscreen.supportsFullScreen = false;
- }
-
- // Update methods to do something useful
- if (fullscreen.supportsFullScreen) {
- fullscreen.fullScreenEventName = fullscreen.prefix + "fullscreenchange";
-
- fullscreen.isFullScreen = function() {
- switch (this.prefix) {
- case "":
- return document.fullScreen;
- case "webkit":
- return document.webkitIsFullScreen;
- default:
- return document[this.prefix + "FullScreen"];
- }
- };
- fullscreen.requestFullScreen = function(element) {
- return (this.prefix === "") ? element.requestFullScreen() : element[this.prefix + "RequestFullScreen"](this.prefix === "webkit" ? element.ALLOW_KEYBOARD_INPUT : null);
- };
- fullscreen.cancelFullScreen = function() {
- return (this.prefix === "") ? document.cancelFullScreen() : document[this.prefix + "CancelFullScreen"]();
- };
- fullscreen.element = function() {
- return (this.prefix === "") ? document.fullscreenElement : document[this.prefix + "FullscreenElement"];
- };
- }
-
- // Export api
- window.fullscreen = fullscreen;
-})();
-
-function InitPxVideo(options) {
+/*global ActiveXObject*/
+(function(api){
"use strict";
- // Replace all
- // ---------------------------------
- if (!String.prototype.replaceAll) {
- Object.defineProperty(String.prototype, "replaceAll", {
- value: function(find, replace) {
- return this.replace(new RegExp(find.replace(/([.*+?^=!:${}()|\[\]\/\\])/g, "\\$1"), "g"), replace);
- }
- });
- }
-
- // Get click position relative to parent
- // http://www.kirupa.com/html5/getting_mouse_click_position.htm
- // ---------------------------------
- function getClickPosition(e) {
- var parentPosition = window.fullscreen.isFullScreen() ? { x: 0, y: 0 } : getPosition(e.currentTarget);
-
- return {
- x: e.clientX - parentPosition.x,
- y: e.clientY - parentPosition.y
- };
- }
-
- // Get element position
- // http://www.kirupa.com/html5/getting_mouse_click_position.htm
- // ---------------------------------
- function getPosition(element) {
- var xPosition = 0;
- var yPosition = 0;
-
- while (element) {
- xPosition += (element.offsetLeft - element.scrollLeft + element.clientLeft);
- yPosition += (element.offsetTop - element.scrollTop + element.clientTop);
- element = element.offsetParent;
- }
-
- return {
- x: xPosition,
- y: yPosition
- };
- }
-
- // Utilities for caption time codes
- function video_timecode_min(tc) {
- var tcpair = [];
- tcpair = tc.split(" --> ");
- return videosub_tcsecs(tcpair[0]);
- }
-
- function video_timecode_max(tc) {
- var tcpair = [];
- tcpair = tc.split(" --> ");
- return videosub_tcsecs(tcpair[1]);
- }
-
- function videosub_tcsecs(tc) {
- if (tc === null || tc === undefined) {
- return 0;
- }
- else {
- var tc1 = [],
- tc2 = [],
- seconds;
- 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;
- }
- }
-
- // For "manual" captions, adjust caption position when play time changed (via rewind, clicking progress bar, etc.)
- function adjustManualCaptions(obj) {
- obj.subcount = 0;
- while (video_timecode_max(obj.captions[obj.subcount][0]) < obj.movie.currentTime.toFixed(1)) {
- obj.subcount++;
- if (obj.subcount > obj.captions.length-1) {
- obj.subcount = obj.captions.length-1;
- break;
- }
- }
- }
-
- // Display captions container and button (for initialization)
- function showCaptionContainerAndButton(obj) {
- //obj.captionsBtnContainer.className = "px-video-captions-btn-container show";
- if (obj.isCaptionDefault) {
- obj.captionsContainer.className = "px-video-captions show";
- obj.captionsBtn.setAttribute("checked", "checked");
- }
- }
+ // Globals
+ var fullscreen, config;
+
+ // Handler cache
+ var handlers = {};
+
+ // Object cache
+ var player = {};
+
+ // Default config
+ var defaults = {
+ debug: false,
+ seekInterval: 10,
+ selectors: {
+ container: ".player",
+ videoContainer: ".player-video",
+ controls: ".player-controls",
+ buttons: {
+ play: "[data-player='play']",
+ pause: "[data-player='pause']",
+ restart: "[data-player='restart']",
+ rewind: "[data-player='restart']",
+ forward: "[data-player='fast-forward']",
+ mute: "[data-player='mute']",
+ volume: "[data-player='volume']",
+ captions: "[data-player='captions']",
+ fullscreen: "[data-player='fullscreen']"
+ },
+ progress: ".player-progress",
+ captions: ".player-captions",
+ duration: ".player-duration",
+ seekTime: ".player-seek-time"
+ },
+ classes: {
+ stopped: "stopped",
+ playing: "playing",
+ muted: "muted",
+ captions: "captions"
+ },
+ captions: {
+ default: true
+ }
+ };
// Unfortunately, due to scattered support, browser sniffing is required
+ // http://paypal.github.io/accessible-html5-video-player/
function browserSniff() {
var nAgt = navigator.userAgent,
browserName = navigator.appName,
@@ -229,430 +119,707 @@ function InitPxVideo(options) {
return [browserName, majorVersion];
}
- // Global variable
- var obj = {};
-
- obj.arBrowserInfo = browserSniff();
- obj.browserName = obj.arBrowserInfo[0];
- obj.browserMajorVersion = obj.arBrowserInfo[1];
-
- // If IE8, stop customization (use fallback)
- // If IE9, stop customization (use native controls)
- if (obj.browserName === "IE" && (obj.browserMajorVersion === 8 || obj.browserMajorVersion === 9) ) {
- return false;
+ // Utilities for caption time codes
+ // http://paypal.github.io/accessible-html5-video-player/
+ function video_timecode_min(tc) {
+ var tcpair = [];
+ tcpair = tc.split(" --> ");
+ return videosub_tcsecs(tcpair[0]);
}
-
- // If smartphone or tablet, stop customization as video (and captions in latest devices) are handled natively
- obj.isSmartphoneOrTablet = /Android|webOS|iPhone|iPad|iPod|BlackBerry/i.test(navigator.userAgent);
- if (obj.isSmartphoneOrTablet) {
- return false;
+ function video_timecode_max(tc) {
+ var tcpair = [];
+ tcpair = tc.split(" --> ");
+ return videosub_tcsecs(tcpair[1]);
}
-
- // Set debug mode
- if (typeof(options.debug)==="undefined") {
- options.debug = false;
+ function videosub_tcsecs(tc) {
+ if (tc === null || tc === undefined) {
+ return 0;
+ }
+ else {
+ var tc1 = [],
+ tc2 = [],
+ seconds;
+ 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;
+ }
}
- obj.debug = options.debug;
-
- // Output browser info to log if debug on
- if (options.debug) {
- console.log(obj.browserName + " " + obj.browserMajorVersion);
+ // For "manual" captions, adjust caption position when play time changed (via rewind, clicking progress bar, etc.)
+ // http://paypal.github.io/accessible-html5-video-player/
+ function adjustManualCaptions(player) {
+ player.subcount = 0;
+ while (video_timecode_max(player.captions[player.subcount][0]) < player.media.currentTime.toFixed(1)) {
+ player.subcount++;
+ if (player.subcount > player.captions.length-1) {
+ player.subcount = player.captions.length-1;
+ break;
+ }
+ }
}
-
- // Set up aria-label for Play button with the videoTitle option
- if ((typeof(options.videoTitle)==="undefined") || (options.videoTitle==="")) {
- obj.playAriaLabel = "Play";
+ // Display captions container and button (for initialization)
+ function showCaptionContainerAndButton(player) {
+ if (config.captions.default) {
+ player.container.className += " " + config.classes.captions;
+ player.buttons.captions.setAttribute("checked", "checked");
+ }
}
- else {
- obj.playAriaLabel = "Play video, " + options.videoTitle;
+
+ // Replace all
+ function replaceAll(string, find, replace) {
+ return string.replace(new RegExp(find.replace(/([.*+?^=!:${}()|\[\]\/\\])/g, "\\$1"), "g"), replace);
}
- // Get the container and video element
- obj.container = document.getElementById(options.videoId);
- obj.container.className = obj.container.className + " stopped";
- obj.movie = obj.container.getElementsByTagName("video")[0];
-
- // Remove native video controls
- obj.movie.removeAttribute("controls");
-
- // Generate random number for ID/FOR attribute values for controls
- obj.randomNum = Math.floor(Math.random() * (10000));
-
- // Insert custom video controls
- if (options.debug) {
- console.log("Inserting custom controls...");
+ // Get click position relative to parent
+ // http://www.kirupa.com/html5/getting_mouse_click_position.htm
+ function getClickPosition(e) {
+ var parentPosition = fullscreen.isFullScreen() ? { x: 0, y: 0 } : getPosition(e.currentTarget);
+
+ return {
+ x: e.clientX - parentPosition.x,
+ y: e.clientY - parentPosition.y
+ };
}
- obj.container.insertAdjacentHTML("beforeend", options.html
- .replaceAll("{aria-label}", obj.playAriaLabel)
- .replaceAll("{id}", obj.randomNum));
-
- // Store reference
- obj.controls = obj.container.querySelector(".player-controls");
-
- // Responsive ffs
- // ----
- // Adjust layout per width of video - container
- //obj.movieWidth = obj.movie.width;
- //if (obj.movieWidth < 360) {
- // obj.movieWidth = 360;
- //}
- //obj.container.setAttribute("style", "width:" + obj.movieWidth + "px");
-
- // Adjust layout per width of video - controls/mute offset
- obj.labelMute = document.getElementById("labelMute" + obj.randomNum);
- obj.labelMuteOffset = obj.movieWidth - 390;
- if (obj.labelMuteOffset < 0) {
- obj.labelMuteOffset = 0;
+
+ // Get element position
+ // http://www.kirupa.com/html5/getting_mouse_click_position.htm
+ function getPosition(element) {
+ var xPosition = 0;
+ var yPosition = 0;
+
+ while (element) {
+ xPosition += (element.offsetLeft - element.scrollLeft + element.clientLeft);
+ yPosition += (element.offsetTop - element.scrollTop + element.clientTop);
+ element = element.offsetParent;
+ }
+
+ return {
+ x: xPosition,
+ y: yPosition
+ };
}
- obj.labelMute.setAttribute("style", "margin-left:" + obj.labelMuteOffset + "px");
-
- // Get URL of caption file if exists
- var captionSrc = "",
- kind,
- children = obj.movie.childNodes;
-
- for (var i = 0; i < children.length; i++) {
- if (children[i].nodeName.toLowerCase() === "track") {
- kind = children[i].getAttribute("kind");
- if (kind === "captions") {
- captionSrc = children[i].getAttribute("src");
+
+ // Deep extend/merge two Objects
+ // http://andrewdupont.net/2009/08/28/deep-extending-objects-in-javascript/
+ // Removed call to arguments.callee (used explicit function name instead)
+ function extend(destination, source) {
+ for (var property in source) {
+ if (source[property] && source[property].constructor && source[property].constructor === Object) {
+ destination[property] = destination[property] || {};
+ extend(destination[property], source[property]);
+ }
+ else {
+ destination[property] = source[property];
}
}
+ return destination;
}
- // Record if caption file exists or not
- obj.captionExists = true;
- if (captionSrc === "") {
- obj.captionExists = false;
- if (options.debug) {
- console.log("No caption track found.");
+ // Our internal function that executes handlers with a given name
+ function executeHandlers(eventName){
+ // Get all handlers with the selected name
+ var handler = handlers[eventName] || [],
+ len = handler.length,
+ i;
+
+ // Execute each
+ for(i = 0; i< len; i++){
+ // You can use apply to specify what "this" and parameters the callback gets
+ handler[i].apply(player.media,[]);
}
}
- else {
- if (options.debug) {
- console.log("Caption track found; URI: " + captionSrc);
+
+ // Fullscreen API
+ function fullscreenApi() {
+ var fullscreen = {
+ supportsFullScreen: false,
+ isFullScreen: function() { return false; },
+ requestFullScreen: function() {},
+ cancelFullScreen: function() {},
+ fullScreenEventName: "",
+ element: null,
+ prefix: ""
+ },
+ browserPrefixes = "webkit moz o ms khtml".split(" ");
+
+ // check for native support
+ if (typeof document.cancelFullScreen != "undefined") {
+ fullscreen.supportsFullScreen = true;
}
- }
+ else {
+ // check for fullscreen support by vendor prefix
+ for (var i = 0, il = browserPrefixes.length; i < il; i++ ) {
+ fullscreen.prefix = browserPrefixes[i];
+
+ if (typeof document[fullscreen.prefix + "CancelFullScreen" ] != "undefined" ) {
+ fullscreen.supportsFullScreen = true;
+
+ break;
+ }
+ }
+ }
+
+ // Safari doesn't support the ALLOW_KEYBOARD_INPUT flag so set it to not supported
+ // https://bugs.webkit.org/show_bug.cgi?id=121496
+ if(fullscreen.prefix === "webkit" && !!navigator.userAgent.match(/Version\/[\d\.]+.*Safari/)) {
+ fullscreen.supportsFullScreen = false;
+ }
+
+ // Update methods to do something useful
+ if (fullscreen.supportsFullScreen) {
+ fullscreen.fullScreenEventName = fullscreen.prefix + "fullscreenchange";
- // Set captions on/off - on by default
- if (typeof(options.captionsOnDefault) === "undefined") {
- options.captionsOnDefault = true;
+ fullscreen.isFullScreen = function() {
+ switch (this.prefix) {
+ case "":
+ return document.fullScreen;
+ case "webkit":
+ return document.webkitIsFullScreen;
+ default:
+ return document[this.prefix + "FullScreen"];
+ }
+ };
+ fullscreen.requestFullScreen = function(element) {
+ return (this.prefix === "") ? element.requestFullScreen() : element[this.prefix + "RequestFullScreen"](this.prefix === "webkit" ? element.ALLOW_KEYBOARD_INPUT : null);
+ };
+ fullscreen.cancelFullScreen = function() {
+ return (this.prefix === "") ? document.cancelFullScreen() : document[this.prefix + "CancelFullScreen"]();
+ };
+ fullscreen.element = function() {
+ return (this.prefix === "") ? document.fullscreenElement : document[this.prefix + "FullscreenElement"];
+ };
+ }
+
+ return fullscreen;
}
- obj.isCaptionDefault = options.captionsOnDefault;
- // Number of seconds for rewind and forward buttons
- if (typeof(options.seekInterval) === "undefined") {
- options.seekInterval = 10;
+ // Insert controls
+ function injectControls() {
+ // Insert custom video controls
+ if (config.debug) {
+ console.log("Injecting custom controls");
+ }
+
+ // Use specified html
+ // Need to do a default?
+ var html = config.html;
+
+ // Replace aria label instances
+ html = replaceAll(html, "{aria-label}", config.playAriaLabel);
+
+ // Replace all id references
+ html = replaceAll(html, "{id}", player.random);
+
+ // Inject into the container
+ player.container.insertAdjacentHTML("beforeend", html);
}
- obj.seekInterval = options.seekInterval;
-
- // Get the elements for the controls
- obj.btnPlay = obj.container.getElementsByClassName("px-video-play")[0];
- obj.btnPause = obj.container.getElementsByClassName("px-video-pause")[0];
- obj.btnRestart = obj.container.getElementsByClassName("px-video-restart")[0];
- obj.btnRewind = obj.container.getElementsByClassName("px-video-rewind")[0];
- obj.btnForward = obj.container.getElementsByClassName("px-video-forward")[0];
- obj.btnVolume = obj.container.getElementsByClassName("px-video-volume")[0];
- obj.btnMute = obj.container.getElementsByClassName("px-video-mute")[0];
- obj.progressBar = obj.container.getElementsByClassName("px-video-progress")[0];
- obj.progressBarSpan = obj.progressBar.getElementsByTagName("span")[0];
- obj.captionsContainer = obj.container.getElementsByClassName("px-video-captions")[0];
- obj.captionsBtn = obj.container.getElementsByClassName("px-video-btnCaptions")[0];
- obj.captionsBtnContainer = obj.container.getElementsByClassName("px-video-captions-btn-container")[0];
- obj.duration = obj.container.getElementsByClassName("px-video-duration")[0];
- obj.txtSeconds = obj.container.getElementsByClassName("px-seconds");
-
- obj.toggleFullscreen = obj.container.querySelector("[data-player='toggle-fullscreen']");
- obj.videoContainer = obj.container.querySelector(".player-video");
-
- // Update number of seconds in rewind and fast forward buttons
- obj.txtSeconds[0].innerHTML = obj.seekInterval;
- obj.txtSeconds[1].innerHTML = obj.seekInterval;
-
- // Determine if HTML5 textTracks is supported (for captions)
- obj.isTextTracks = false;
- if (obj.movie.textTracks) {
- obj.isTextTracks = true;
+
+ // Find all elements
+ function getElements(selector) {
+ return player.container.querySelectorAll(selector);
}
- // Fullscreen
- obj.toggleFullscreen.addEventListener("click", function() {
- if(!window.fullscreen.isFullScreen()) {
- window.fullscreen.requestFullScreen(obj.container);
- }
- else {
- window.fullscreen.cancelFullScreen();
- }
- }, false);
+ // Find a single element
+ function getElement(selector) {
+ return getElements(selector)[0];
+ }
- // Click video
- obj.videoContainer.addEventListener("click", function() {
- if(obj.movie.paused) {
- play();
- }
- else if(obj.movie.ended) {
- restart();
- }
- else {
- pause();
- }
- }, false);
+ // Find the UI controls and store references
+ function findElements() {
+ player.controls = getElement(config.selectors.controls);
+
+ // Buttons
+ player.buttons = {};
+ player.buttons.play = getElement(config.selectors.buttons.play);
+ player.buttons.pause = getElement(config.selectors.buttons.pause);
+ player.buttons.restart = getElement(config.selectors.buttons.restart);
+ player.buttons.rewind = getElement(config.selectors.buttons.rewind);
+ player.buttons.forward = getElement(config.selectors.buttons.forward);
+ player.buttons.mute = getElement(config.selectors.buttons.mute);
+ player.buttons.volume = getElement(config.selectors.buttons.volume);
+ player.buttons.captions = getElement(config.selectors.buttons.captions);
+ player.buttons.fullscreen = getElement(config.selectors.buttons.fullscreen);
+
+ // Progress
+ player.progress = {};
+ player.progress.bar = getElement(config.selectors.progress);
+ player.progress.text = player.progress.bar.getElementsByTagName("span")[0];
+
+ // Timing
+ player.duration = getElement(config.selectors.duration);
+ player.seekTime = getElements(config.selectors.seekTime);
+ }
+ // Play media
function play() {
- obj.movie.play();
- obj.container.className = obj.container.className.replace("stopped", "playing");
-
+ player.media.play();
+ player.container.className = player.container.className.replace(config.classes.stopped, config.classes.playing);
}
+ // Pause media
function pause() {
- obj.movie.pause();
- obj.container.className = obj.container.className.replace("playing", "stopped");
+ player.media.pause();
+ player.container.className = player.container.className.replace(config.classes.playing, config.classes.stopped);
}
+ // Restart playback
function restart() {
// Move to beginning
- obj.movie.currentTime = 0;
+ player.media.currentTime = 0;
// Special handling for "manual" captions
- if (!obj.isTextTracks) {
- obj.subcount = 0;
+ if (!player.isTextTracks) {
+ player.subcount = 0;
}
// Play and ensure the play button is in correct state
play();
}
- // Play
- obj.btnPlay.addEventListener("click", function() { play(); obj.btnPause.focus(); }, false);
-
- // Pause
- obj.btnPause.addEventListener("click", function() { pause(); obj.btnPlay.focus(); }, false);
+ // Setup media
+ function setupMedia() {
+ player.media = player.container.querySelectorAll("audio, video")[0];
- // Restart
- obj.btnRestart.addEventListener("click", restart, false);
-
- // Rewind
- obj.btnRewind.addEventListener("click", function() {
- var targetTime = obj.movie.currentTime - obj.seekInterval;
- if (targetTime < 0) {
- obj.movie.currentTime = 0;
- }
- else {
- obj.movie.currentTime = targetTime;
- }
- // Special handling for "manual" captions
- if (!obj.isTextTracks) {
- adjustManualCaptions(obj);
+ // If there's no media, bail
+ if(!player.media) {
+ console.warn("No audio or video element found!");
+ return false;
}
- }, false);
- // Fast forward
- obj.btnForward.addEventListener("click", function() {
- var targetTime = obj.movie.currentTime + obj.seekInterval;
- if (targetTime > obj.movie.duration) {
- obj.movie.currentTime = obj.movie.duration;
+ // If there's no autoplay attribute, assume the video is stopped
+ if(player.media.getAttribute("autoplay") === null) {
+ player.container.className += " " + config.classes.stopped;
}
- else {
- obj.movie.currentTime = targetTime;
- }
- // Special handling for "manual" captions
- if (!obj.isTextTracks) {
- adjustManualCaptions(obj);
- }
- }, false);
-
- // Get the HTML5 range input element and append audio volume adjustment on change
- obj.btnVolume.addEventListener("change", function() {
- obj.movie.volume = parseFloat(this.value / 10);
- }, false);
- // Mute
- obj.btnMute.addEventListener("click", function() {
- if (obj.movie.muted === true) {
- obj.movie.muted = false;
- }
- else {
- obj.movie.muted = true;
- }
- }, false);
-
- // Duration
- obj.movie.addEventListener("timeupdate", function() {
- obj.secs = parseInt(obj.movie.currentTime % 60);
- obj.mins = parseInt((obj.movie.currentTime / 60) % 60);
-
- // Ensure it"s two digits. For example, 03 rather than 3.
- obj.secs = ("0" + obj.secs).slice(-2);
- obj.mins = ("0" + obj.mins).slice(-2);
-
- // Render
- obj.duration.innerHTML = obj.mins + ":" + obj.secs;
- }, false);
-
- // Progress bar
- obj.movie.addEventListener("timeupdate", function() {
- obj.percent = (100 / obj.movie.duration) * obj.movie.currentTime;
- if (obj.percent > 0) {
- obj.progressBar.value = obj.percent;
- obj.progressBarSpan.innerHTML = obj.percent;
- }
- }, false);
-
- // Skip when clicking progress bar
- obj.progressBar.addEventListener("click", function(e) {
- obj.pos = getClickPosition(e).x / this.offsetWidth;
- obj.movie.currentTime = obj.pos * obj.movie.duration;
-
- // Special handling for "manual" captions
- if (!obj.isTextTracks) {
- adjustManualCaptions(obj);
- }
- });
+ // Remove native video controls
+ player.media.removeAttribute("controls");
- // Clear captions at end of video
- obj.movie.addEventListener("ended", function() {
- obj.captionsContainer.innerHTML = "";
- });
+ // Set type
+ player.type = (player.media.tagName.toLowerCase() == "video" ? "video" : "audio");
+ }
- // ***
- // Captions
- // ***
+ // Setup captions
+ function setupCaptions() {
+ if(player.type == "video") {
+ // Inject the container
+ player.videoContainer.insertAdjacentHTML("afterbegin", "<div class='" + config.selectors.captions.replace(".", "") + "'></div>");
- // Toggle display of captions via captions button
- obj.captionsBtn.addEventListener("click", function() {
- if (this.checked) {
- obj.captionsContainer.className = "px-video-captions show";
- } else {
- obj.captionsContainer.className = "px-video-captions hide";
- }
- }, false);
+ // Cache selector
+ player.captionsContainer = getElement(config.selectors.captions);
- // If no caption file exists, hide container for caption text
- if (!obj.captionExists) {
- obj.captionsContainer.className = "px-video-captions hide";
- }
+ // Determine if HTML5 textTracks is supported
+ player.isTextTracks = false;
+ if (player.media.textTracks) {
+ player.isTextTracks = true;
+ }
- // If caption file exists, process captions
- else {
+ // Get URL of caption file if exists
+ var captionSrc = "",
+ kind,
+ children = player.media.childNodes;
- // If IE 10/11 or Firefox 31+ or Safari 7+, don"t use native captioning (still doesn"t work although they claim it"s now supported)
- if ((obj.browserName==="IE" && obj.browserMajorVersion===10) ||
- (obj.browserName==="IE" && obj.browserMajorVersion===11) ||
- (obj.browserName==="Firefox" && obj.browserMajorVersion>=31) ||
- (obj.browserName==="Safari" && obj.browserMajorVersion>=7)) {
- if (options.debug) {
- console.log("Detected IE 10/11 or Firefox 31+ or Safari 7+");
- }
- // set to false so skips to "manual" captioning
- obj.isTextTracks = false;
-
- // turn off native caption rendering to avoid double captions [doesn"t work in Safari 7; see patch below]
- var track = {};
- var tracks = obj.movie.textTracks;
- for (var j=0; j < tracks.length; j++) {
- track = obj.movie.textTracks[j];
- track.mode = "hidden";
+ for (var i = 0; i < children.length; i++) {
+ if (children[i].nodeName.toLowerCase() === "track") {
+ kind = children[i].getAttribute("kind");
+ if (kind === "captions") {
+ captionSrc = children[i].getAttribute("src");
+ }
+ }
}
- }
- // Rendering caption tracks - native support required - http://caniuse.com/webvtt
- if (obj.isTextTracks) {
- if (options.debug) {
- console.log("textTracks supported");
+ // Record if caption file exists or not
+ player.captionExists = true;
+ if (captionSrc === "") {
+ player.captionExists = false;
+ if (config.debug) {
+ console.log("No caption track found.");
+ }
}
- showCaptionContainerAndButton(obj);
-
- var track = {};
- var tracks = obj.movie.textTracks;
- for (var j=0; j < tracks.length; j++) {
- track = obj.movie.textTracks[j];
- track.mode = "hidden";
- if (track.kind === "captions") {
- track.addEventListener("cuechange",function() {
- if (this.activeCues[0]) {
- if (this.activeCues[0].hasOwnProperty("text")) {
- obj.captionsContainer.innerHTML = this.activeCues[0].text;
- }
- }
- },false);
+ else {
+ if (config.debug) {
+ console.log("Caption track found; URI: " + captionSrc);
}
}
- }
- // Caption tracks not natively supported
- else {
- if (options.debug) {
- console.log("textTracks not supported so rendering captions manually");
+
+ // If no caption file exists, hide container for caption text
+ if (!player.captionExists) {
+ player.container.className = player.container.className.replace(config.classes.captions, "");
}
- showCaptionContainerAndButton(obj);
-
- // Render captions from array at appropriate time
- obj.currentCaption = "";
- obj.subcount = 0;
- obj.captions = [];
-
- obj.movie.addEventListener("timeupdate", function() {
- // Check if the next caption is in the current time range
- if (obj.movie.currentTime.toFixed(1) > video_timecode_min(obj.captions[obj.subcount][0]) &&
- obj.movie.currentTime.toFixed(1) < video_timecode_max(obj.captions[obj.subcount][0])) {
- obj.currentCaption = obj.captions[obj.subcount][1];
- }
- // Is there a next timecode?
- if (obj.movie.currentTime.toFixed(1) > video_timecode_max(obj.captions[obj.subcount][0]) &&
- obj.subcount < (obj.captions.length-1)) {
- obj.subcount++;
- }
- // Render the caption
- obj.captionsContainer.innerHTML = obj.currentCaption;
- }, false);
-
- if (captionSrc !== "") {
- // Create XMLHttpRequest object
- var xhr;
- if (window.XMLHttpRequest) {
- xhr = new XMLHttpRequest();
- } else if (window.ActiveXObject) { // IE8
- xhr = new ActiveXObject("Microsoft.XMLHTTP");
+
+ // If caption file exists, process captions
+ else {
+ var track = {}, tracks, j;
+
+ // If IE 10/11 or Firefox 31+ or Safari 7+, don"t use native captioning (still doesn"t work although they claim it"s now supported)
+ if ((player.browserName === "IE" && player.browserMajorVersion === 10) ||
+ (player.browserName === "IE" && player.browserMajorVersion === 11) ||
+ (player.browserName === "Firefox" && player.browserMajorVersion >= 31) ||
+ (player.browserName === "Safari" && player.browserMajorVersion >= 7)) {
+ if (config.debug) {
+ console.log("Detected IE 10/11 or Firefox 31+ or Safari 7+");
+ }
+ // set to false so skips to "manual" captioning
+ player.isTextTracks = false;
+
+ // turn off native caption rendering to avoid double captions [doesn"t work in Safari 7; see patch below]
+ track = {};
+ tracks = player.media.textTracks;
+ for (j=0; j < tracks.length; j++) {
+ track = player.media.textTracks[j];
+ track.mode = "hidden";
+ }
}
- xhr.onreadystatechange = function() {
- if (xhr.readyState === 4) {
- if (xhr.status === 200) {
- if (options.debug) {
- console.log("xhr = 200");
- }
-
- obj.captions = [];
- var records = [],
- record,
- req = xhr.responseText;
- records = req.split("\n\n");
- for (var r=0; r < records.length; r++) {
- record = records[r];
- obj.captions[r] = [];
- obj.captions[r] = record.split("\n");
- }
- // Remove first element ("VTT")
- obj.captions.shift();
- if (options.debug) {
- console.log("Successfully loaded the caption file via ajax.");
- }
- } else {
- if (options.debug) {
- console.log("There was a problem loading the caption file via ajax.");
+ // Rendering caption tracks - native support required - http://caniuse.com/webvtt
+ if (player.isTextTracks) {
+ if (config.debug) {
+ console.log("textTracks supported");
+ }
+ showCaptionContainerAndButton(player);
+
+ track = {};
+ tracks = player.media.textTracks;
+ for (j=0; j < tracks.length; j++) {
+ track = player.media.textTracks[j];
+ track.mode = "hidden";
+ if (track.kind === "captions") {
+ track.addEventListener("cuechange",function() {
+ if (this.activeCues[0]) {
+ if (this.activeCues[0].hasOwnProperty("text")) {
+ player.captionsContainer.innerHTML = this.activeCues[0].text;
+ }
+ }
+ },false);
+ }
+ }
+ }
+ // Caption tracks not natively supported
+ else {
+ if (config.debug) {
+ console.log("textTracks not supported so rendering captions manually");
+ }
+ showCaptionContainerAndButton(player);
+
+ // Render captions from array at appropriate time
+ player.currentCaption = "";
+ player.subcount = 0;
+ player.captions = [];
+
+ player.media.addEventListener("timeupdate", function() {
+ // Check if the next caption is in the current time range
+ if (player.media.currentTime.toFixed(1) > video_timecode_min(player.captions[player.subcount][0]) &&
+ player.media.currentTime.toFixed(1) < video_timecode_max(player.captions[player.subcount][0])) {
+ player.currentCaption = player.captions[player.subcount][1];
+ }
+ // Is there a next timecode?
+ if (player.media.currentTime.toFixed(1) > video_timecode_max(player.captions[player.subcount][0]) &&
+ player.subcount < (player.captions.length-1)) {
+ player.subcount++;
+ }
+ // Render the caption
+ player.captionsContainer.innerHTML = player.currentCaption;
+ }, false);
+
+ if (captionSrc !== "") {
+ // Create XMLHttpRequest Object
+ var xhr;
+ if (window.XMLHttpRequest) {
+ xhr = new XMLHttpRequest();
+ }
+ else if (window.ActiveXObject) { // IE8
+ xhr = new ActiveXObject("Microsoft.XMLHTTP");
+ }
+ xhr.onreadystatechange = function() {
+ if (xhr.readyState === 4) {
+ if (xhr.status === 200) {
+ if (config.debug) {
+ console.log("xhr = 200");
+ }
+
+ player.captions = [];
+ var records = [],
+ record,
+ req = xhr.responseText;
+ records = req.split("\n\n");
+ for (var r=0; r < records.length; r++) {
+ record = records[r];
+ player.captions[r] = [];
+ player.captions[r] = record.split("\n");
+ }
+ // Remove first element ("VTT")
+ player.captions.shift();
+
+ if (config.debug) {
+ console.log("Successfully loaded the caption file via ajax.");
+ }
+ } else {
+ if (config.debug) {
+ console.log("There was a problem loading the caption file via ajax.");
+ }
+ }
}
}
+ xhr.open("get", captionSrc, true);
+ xhr.send();
}
}
- xhr.open("get", captionSrc, true);
- xhr.send();
+
+ // If Safari 7, removing track from DOM [see "turn off native caption rendering" above]
+ if (player.browserName === "Safari" && player.browserMajorVersion === 7) {
+ console.log("Safari 7 detected; removing track from DOM");
+ tracks = player.media.getElementsByTagName("track");
+ player.media.removeChild(tracks[0]);
+ }
}
}
+ }
- // If Safari 7, removing track from DOM [see "turn off native caption rendering" above]
- if (obj.browserName === "Safari" && obj.browserMajorVersion === 7) {
- console.log("Safari 7 detected; removing track from DOM");
- var tracks = obj.movie.getElementsByTagName("track");
- obj.movie.removeChild(tracks[0]);
+ // Setup seeking
+ function setupSeeking() {
+ // Update number of seconds in rewind and fast forward buttons
+ player.seekTime[0].innerHTML = config.seekInterval;
+ player.seekTime[1].innerHTML = config.seekInterval;
+ }
+
+ // Listen for events
+ function listeners() {
+
+ // Fullscreen
+ player.buttons.fullscreen.addEventListener("click", function() {
+ if(!fullscreen.isFullScreen()) {
+ fullscreen.requestFullScreen(player.container);
+ }
+ else {
+ fullscreen.cancelFullScreen();
+ }
+ }, false);
+
+ // Click video
+ player.videoContainer.addEventListener("click", function() {
+ if(player.media.paused) {
+ play();
+ }
+ else if(player.media.ended) {
+ restart();
+ }
+ else {
+ pause();
+ }
+ }, false);
+
+ // Play
+ player.buttons.play.addEventListener("click", function() {
+ play();
+ player.buttons.pause.focus();
+ }, false);
+
+ // Pause
+ player.buttons.pause.addEventListener("click", function() {
+ pause();
+ player.buttons.play.focus();
+ }, false);
+
+ // Restart
+ player.buttons.restart.addEventListener("click", restart, false);
+
+ // Rewind
+ player.buttons.rewind.addEventListener("click", function() {
+ var targetTime = player.media.currentTime - config.seekInterval;
+
+ if (targetTime < 0) {
+ player.media.currentTime = 0;
+ }
+ else {
+ player.media.currentTime = targetTime;
+ }
+ // Special handling for "manual" captions
+ if (!player.isTextTracks) {
+ adjustManualCaptions(player);
+ }
+ }, false);
+
+ // Fast forward
+ player.buttons.forward.addEventListener("click", function() {
+ var targetTime = player.media.currentTime + config.seekInterval;
+
+ if (targetTime > player.media.duration) {
+ player.media.currentTime = player.media.duration;
+ }
+ else {
+ player.media.currentTime = targetTime;
+ }
+ // Special handling for "manual" captions
+ if (!player.isTextTracks) {
+ adjustManualCaptions(player);
+ }
+ }, false);
+
+ // Get the HTML5 range input element and append audio volume adjustment on change
+ player.buttons.volume.addEventListener("change", function() {
+ player.media.volume = parseFloat(this.value / 10);
+ }, false);
+
+ // Mute
+ player.buttons.mute.addEventListener("click", function() {
+ if (player.media.muted === true) {
+ player.media.muted = false;
+ player.container.className = player.container.className.replace(config.classes.muted, "");
+ }
+ else {
+ player.media.muted = true;
+ player.container.className += " " + config.classes.muted;
+ }
+ }, false);
+
+ // Duration
+ player.media.addEventListener("timeupdate", function() {
+ player.secs = parseInt(player.media.currentTime % 60);
+ player.mins = parseInt((player.media.currentTime / 60) % 60);
+
+ // Ensure it"s two digits. For example, 03 rather than 3.
+ player.secs = ("0" + player.secs).slice(-2);
+ player.mins = ("0" + player.mins).slice(-2);
+
+ // Render
+ player.duration.innerHTML = player.mins + ":" + player.secs;
+ }, false);
+
+ // Progress bar
+ player.media.addEventListener("timeupdate", function() {
+ player.percent = (100 / player.media.duration) * player.media.currentTime;
+
+ if (player.percent > 0) {
+ player.progress.bar.value = player.percent;
+ player.progress.text.innerHTML = player.percent;
+ }
+ }, false);
+
+ // Skip when clicking progress bar
+ player.progress.bar.addEventListener("click", function(e) {
+ player.pos = getClickPosition(e).x / this.offsetWidth;
+ player.media.currentTime = player.pos * player.media.duration;
+
+ // Special handling for "manual" captions
+ if (!player.isTextTracks) {
+ adjustManualCaptions(player);
+ }
+ });
+
+ // Captions
+ player.buttons.captions.addEventListener("click", function() {
+ if (this.checked) {
+ player.container.className += " " + config.classes.captions;
+ }
+ else {
+ player.container.className = player.container.className.replace(config.classes.captions, "");
+ }
+ }, false);
+
+ // Clear captions at end of video
+ player.media.addEventListener("ended", function() {
+ player.captionsContainer.innerHTML = "";
+ player.container.className = player.container.className.replace(config.classes.playing, config.classes.stopped);
+ });
+ }
+
+ // Our "on" function which collects handlers
+ api.on = function(eventName, handler){
+ // If no handler collection exists, create one
+ if(!handlers[eventName]){
+ handlers[eventName] = [];
+ }
+ handlers[eventName].push(handler);
+ }
+
+ function setupPlayer(element) {
+ player.container = element;
+ player.videoContainer = getElement(config.selectors.videoContainer);
+
+ // Setup media
+ setupMedia();
+
+ // Generate random number for id/for attribute values for controls
+ player.random = Math.floor(Math.random() * (10000));
+
+ // Inject custom controls
+ injectControls();
+
+ // Find the elements
+ findElements();
+
+ // Captions
+ setupCaptions();
+
+ // Seeking
+ setupSeeking();
+
+ // Listeners
+ listeners();
+ }
+
+ // Expose setup function
+ api.setup = function(options){
+ // Extend the default options with user specified
+ config = extend(defaults, options);
+
+ // Setup the fullscreen api
+ // Check for support to hide/show the button
+ fullscreen = fullscreenApi();
+
+ // Sniff
+ player.browserInfo = browserSniff();
+ player.browserName = player.browserInfo[0];
+ player.browserMajorVersion = player.browserInfo[1];
+
+ // Debug info
+ if(config.debug) {
+ console.log(config);
+ console.log("fullscreen support: " + fullscreen.supportsFullScreen);
+ console.log(player.browserName + " " + player.browserMajorVersion);
}
+
+ // If IE8, stop customization (use fallback)
+ // If IE9, stop customization (use native controls)
+ if (player.browserName === "IE" && (player.browserMajorVersion === 8 || player.browserMajorVersion === 9) ) {
+ console.warn("Browser not suppported.");
+ return false;
+ }
+
+ // If smartphone or tablet, stop customization as video (and captions in latest devices) are handled natively
+ player.isSmartphoneOrTablet = /Android|webOS|iPhone|iPad|iPod|BlackBerry/i.test(navigator.userAgent);
+ if (player.isSmartphoneOrTablet) {
+ console.warn("Browser not suppported.");
+ return false;
+ }
+
+ // Set up aria-label for Play button with the title option
+ if (typeof(config.title) === "undefined" || !config.title.length) {
+ config.playAriaLabel = "Play";
+ }
+ else {
+ config.playAriaLabel = "Play " + config.title;
+ }
+
+ // Get the container and video container
+ var elements = document.querySelectorAll(config.selectors.container);
+ for (var i = elements.length - 1; i >= 0; i--) {
+ setupPlayer(elements[i]);
+ }
+
+ //now we execute callbacks registered to shout
+ executeHandlers("setup");
}
-} \ No newline at end of file
+
+}(this.simpleMedia = this.simpleMedia || {}));
+
+/*function InitPxVideo(options) {
+
+ "use strict";
+
+
+ // ***
+ // Captions
+ // ***
+
+
+}*/ \ No newline at end of file
diff --git a/assets/less/simple-media.less b/assets/less/simple-media.less
index edf9b059..338a4706 100644
--- a/assets/less/simple-media.less
+++ b/assets/less/simple-media.less
@@ -5,26 +5,21 @@
// Variables
// -------------------------------
// Colors
-@base-color: #2E3C44;
-@green: #1ABC9C;
-@red: #D44334;
-@blue: #3498DB;
-
-// Grays
-@gray-dark: #343f4a;
-@gray: #565d64;
-@gray-light: #6f7e86;
-@gray-lighter: #859093;
-@gray-lightest: #cbd0d3;
-@gray-light-mega: #dadfe2;
-@off-white: #f9fafb;
+@blue: #3498DB;
+@gray-dark: #343f4a;
+@gray: #565d64;
+@gray-light: #cbd0d3;
// Controls
-@control-color: @gray-lightest;
-@control-color-active: @blue;
-@control-color-inactive: @gray;
-@control-spacing: 10px;
+@controls-bg: @gray-dark;
+@control-color: @gray-light;
+@control-color-active: @blue;
+@control-color-inactive: @gray;
+@control-spacing: 10px;
+// Progress
+@progress-bg: @gray;
+@progress-value-bg: @blue;
// BORDER-BOX ALL THE THINGS! (http://paulirish.com/2012/box-sizing-border-box-ftw/)
// -------------------------------
@@ -37,6 +32,7 @@
// Utility classes & mixins
// -------------------------------
+// Screen reader only
.sr-only {
position: absolute !important;
clip: rect(1px, 1px, 1px, 1px);
@@ -46,12 +42,6 @@
width: 1px !important;
overflow: hidden;
}
-.hide {
- display: none;
-}
-.show-inline {
- display: inline-block;
-}
// Contain floats: nicolasgallagher.com/micro-clearfix-hack/
.clearfix() {
zoom: 1;
@@ -59,6 +49,13 @@
&:after { content: ""; display: table; }
&:after { clear: both; }
}
+
+// Tab focus styles
+.tab-focus() {
+ outline: thin dotted #000;
+ outline-offset: 1px;
+}
+
// Font smoothing
// ---------------------------------------
.font-smoothing(@mode: on) when (@mode = on) {
@@ -79,47 +76,21 @@
overflow: hidden; // For the controls
background: #000;
+
// For video
&-video {
position: relative;
}
- &:fullscreen {
- height: 100%;
- width: 100%;
-
- &-video {
- position: absolute;
- top: 50%;
- left: 0;
- right: 0;
- transform: translateY(-50%);
- }
- &-controls {
- position: absolute;
- bottom: 0;
- left: 0;
- right: 0;
-
- .icon-exit-fullscreen {
- display: block;
-
- & + svg {
- display: none;
- }
- }
- }
- }
video {
width: 100%;
height: auto;
vertical-align: middle;
}
- svg {
- width: 18px;
- height: 18px;
- }
- .px-video-captions {
+
+ // Captions
+ &-captions {
+ display: none;
position: absolute;
bottom: 0;
left: 0;
@@ -132,13 +103,26 @@
text-align: center;
.font-smoothing();
}
+ &.captions &-captions {
+ display: block;
+ }
+ // Player controls
&-controls {
.clearfix();
+ .font-smoothing();
position: relative;
padding: (@control-spacing * 2) @control-spacing @control-spacing;
- background: @gray-dark;
+ background: @controls-bg;
line-height: 1;
+
+ // Layout
+ &-playback {
+ float: left;
+ }
+ &-sound {
+ float: right;
+ }
input + label,
button {
@@ -152,6 +136,8 @@
cursor: pointer;
svg {
+ width: 18px;
+ height: 18px;
display: block;
fill: currentColor;
transition: fill .3s ease;
@@ -170,25 +156,28 @@
border: 0;
background: transparent;
overflow: hidden;
-
- &:focus {
- outline: 0;
- }
}
button:hover,
- button:focus,
- label:hover,
- input:focus + label {
+ label:hover {
background: @control-color-active;
svg {
fill: #fff;
}
}
- .icon-exit-fullscreen {
+ input:focus + label,
+ button:focus {
+ .tab-focus();
+
+ svg {
+ fill: #fff;
+ }
+ }
+ .icon-exit-fullscreen,
+ .icon-muted {
display: none;
}
- .px-video-time {
+ .player-time {
display: inline-block;
vertical-align: middle;
margin-left: @control-spacing;
@@ -198,7 +187,9 @@
.font-smoothing();
}
}
- progress {
+
+ // Player progress
+ &-progress {
position: absolute;
top: 0;
left: 0;
@@ -211,45 +202,48 @@
&[value] {
-webkit-appearance: none;
border: none;
- background: @gray;
+ background: @progress-bg;
cursor: pointer;
&::-webkit-progress-bar {
- background: @gray;
+ background: @progress-bg;
}
// The value
&::-webkit-progress-value {
- background: @control-color-active;
+ background: @progress-value-bg;
}
&::-moz-progress-bar {
- background: @control-color-active;
+ background: @progress-value-bg;
}
}
}
- .play-controls {
- float: left;
- }
- .sound-controls {
- float: right;
- }
- &-controls .px-video-pause,
- &.playing .player-controls .px-video-play {
+ // States
+ &-controls [data-player='pause'],
+ &.playing .player-controls [data-player='play'] {
display: none;
}
- &.playing .player-controls .px-video-pause {
+ &.playing .player-controls [data-player='pause'] {
display: inline-block;
}
+ // Muted
+ &.muted .player-controls .icon-muted {
+ display: block;
+
+ & + svg {
+ display: none;
+ }
+ }
+
// Volume control
- input[type='range'] {
+ &-volume {
-webkit-appearance: none;
height: 6px;
width: 100px;
margin-right: @control-spacing;
background: @gray;
- outline: 0;
border-radius: 10px;
&::-moz-range-track {
@@ -274,27 +268,59 @@
background: @control-color;
border-radius: 100%;
}
- &:focus::-webkit-slider-thumb {
- background: @control-color-active;
+ &:focus {
+ outline: 0;
+
+ &::-webkit-slider-thumb {
+ background: @control-color-active;
+ }
+ &::-moz-range-thumb {
+ background: @control-color-active;
+ }
}
- &:focus::-moz-range-thumb {
- background: @control-color-active;
+ }
+
+ // Full screen mode
+ &:fullscreen {
+ height: 100%;
+ width: 100%;
+
+ .player-video {
+ position: absolute;
+ top: 50%;
+ left: 0;
+ right: 0;
+ transform: translateY(-50%);
+ }
+ .player-controls {
+ position: absolute;
+ bottom: 0;
+ left: 0;
+ right: 0;
+
+ .icon-exit-fullscreen {
+ display: block;
+
+ & + svg {
+ display: none;
+ }
+ }
}
}
}
/* fixing display for IE10+ */
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
- .px-video-controls input[type='range'] {
+ .video-controls .player-volume {
position: relative;
padding: 0;
height: 8px;
top: -3px;
}
- .px-video-time {
+ .player-time {
margin-top: 4px;
}
- .px-video-captions {
+ .player-captions {
padding: 8px;
min-height: 36px;
}
diff --git a/assets/templates/controls.html b/assets/templates/controls.html
index 3b1c6735..3109d795 100644
--- a/assets/templates/controls.html
+++ b/assets/templates/controls.html
@@ -1,54 +1,53 @@
<div class="player-controls">
- <progress class="px-video-progress" max="100" value="0"><span>0</span>% played</progress>
+ <progress class="player-progress" max="100" value="0">
+ <span>0</span>% played
+ </progress>
- <div class="play-controls">
- <button class="px-video-restart" data-player="restart">
+ <div class="player-controls-playback">
+ <button data-player="restart">
<svg><use xlink:href="#icon-refresh"></use></svg>
<span class="sr-only">Restart</span>
</button>
- <button class="px-video-rewind" data-player="rewind">
+ <button data-player="rewind">
<svg><use xlink:href="#icon-rewind"></use></svg>
- <span class="sr-only">Rewind <span class="px-seconds">10</span> seconds</span>
+ <span class="sr-only">Rewind <span class="player-seek-time">10</span> seconds</span>
</button>
- <button class="px-video-play" aria-label="{aria-label}" data-player="play">
+ <button aria-label="{aria-label}" data-player="play">
<svg><use xlink:href="#icon-play"></use></svg>
<span class="sr-only">Play</span>
</button>
- <button class="px-video-pause" data-player="pause">
+ <button data-player="pause">
<svg><use xlink:href="#icon-pause"></use></svg>
<span class="sr-only">Pause</span>
</button>
- <button class="px-video-forward" data-player="fast-forward">
+ <button data-player="fast-forward">
<svg><use xlink:href="#icon-fast-forward"></use></svg>
- <span class="sr-only">Fast forward <span class="px-seconds">10</span> seconds</span>
+ <span class="sr-only">Fast forward <span class="player-seek-time">10</span> seconds</span>
</button>
- <div class="px-video-time">
+ <span class="player-time">
<span class="sr-only">Time</span>
- <span class="px-video-duration">00:00</span>
- </div>
+ <span class="player-duration">00:00</span>
+ </span>
</div>
- <div class="sound-controls">
- <!--<div class="px-video-mute-btn-container">-->
- <input class="px-video-mute inverted sr-only" id="btnMute{id}" type="checkbox">
- <label id="labelMute{id}" for="btnMute{id}">
- <svg><use xlink:href="#icon-sound"></use></svg>
- <span class="sr-only">Mute</span>
- </label>
- <!--</div>-->
+ <div class="player-controls-sound">
+ <input class="inverted sr-only" id="mute{id}" type="checkbox" data-player="mute">
+ <label id="mute{id}" for="mute{id}">
+ <svg class="icon-muted"><use xlink:href="#icon-muted"></use></svg>
+ <svg><use xlink:href="#icon-sound"></use></svg>
+ <span class="sr-only">Mute</span>
+ </label>
<label for="volume{id}" class="sr-only">Volume:</label>
- <input id="volume{id}" class="px-video-volume" type="range" min="0" max="10" value="5">
+ <input id="volume{id}" class="player-volume" type="range" min="0" max="10" value="5" data-player="volume">
- <!--<div class="px-video-captions-btn-container hide">-->
- <input class="px-video-btnCaptions sr-only" id="btnCaptions{id}" type="checkbox">
- <label for="btnCaptions{id}">
- <svg><use xlink:href="#icon-film"></use></svg>
- <span class="sr-only">Captions</span>
- </label>
- <!--</div>-->
+ <input class="sr-only" id="captions{id}" type="checkbox" data-player="captions">
+ <label for="captions{id}">
+ <svg><use xlink:href="#icon-bubble"></use></svg>
+ <span class="sr-only">Captions</span>
+ </label>
- <button class="player-toggle-fullscreen" data-player="toggle-fullscreen">
+ <button data-player="fullscreen">
<svg class="icon-exit-fullscreen"><use xlink:href="#icon-collapse"></use></svg>
<svg><use xlink:href="#icon-expand"></use></svg>
<span class="sr-only">Toggle fullscreen</span>
diff --git a/design/IcoMoon/PNG/bubble.png b/design/IcoMoon/PNG/bubble.png
new file mode 100755
index 00000000..5139f8c8
--- /dev/null
+++ b/design/IcoMoon/PNG/bubble.png
Binary files differ
diff --git a/design/IcoMoon - 7 Icons/PNG/fast-forward.png b/design/IcoMoon/PNG/fast-forward.png
index 07f2fd1b..07f2fd1b 100755
--- a/design/IcoMoon - 7 Icons/PNG/fast-forward.png
+++ b/design/IcoMoon/PNG/fast-forward.png
Binary files differ
diff --git a/design/IcoMoon - 7 Icons/PNG/film.png b/design/IcoMoon/PNG/film.png
index 3481891e..3481891e 100755
--- a/design/IcoMoon - 7 Icons/PNG/film.png
+++ b/design/IcoMoon/PNG/film.png
Binary files differ
diff --git a/design/IcoMoon - 7 Icons/PNG/monitor.png b/design/IcoMoon/PNG/monitor.png
index 4e6f77d6..4e6f77d6 100755
--- a/design/IcoMoon - 7 Icons/PNG/monitor.png
+++ b/design/IcoMoon/PNG/monitor.png
Binary files differ
diff --git a/design/IcoMoon - 7 Icons/PNG/play.png b/design/IcoMoon/PNG/play.png
index cc842331..cc842331 100755
--- a/design/IcoMoon - 7 Icons/PNG/play.png
+++ b/design/IcoMoon/PNG/play.png
Binary files differ
diff --git a/design/IcoMoon - 7 Icons/PNG/refresh.png b/design/IcoMoon/PNG/refresh.png
index f745a60a..f745a60a 100755
--- a/design/IcoMoon - 7 Icons/PNG/refresh.png
+++ b/design/IcoMoon/PNG/refresh.png
Binary files differ
diff --git a/design/IcoMoon - 7 Icons/PNG/sound.png b/design/IcoMoon/PNG/sound.png
index 5358f3fc..5358f3fc 100755
--- a/design/IcoMoon - 7 Icons/PNG/sound.png
+++ b/design/IcoMoon/PNG/sound.png
Binary files differ
diff --git a/design/IcoMoon - 7 Icons/PNG/up.png b/design/IcoMoon/PNG/up.png
index ea9b39d5..ea9b39d5 100755
--- a/design/IcoMoon - 7 Icons/PNG/up.png
+++ b/design/IcoMoon/PNG/up.png
Binary files differ
diff --git a/design/IcoMoon - 7 Icons/Read Me.txt b/design/IcoMoon/Read Me.txt
index 968528f9..968528f9 100755
--- a/design/IcoMoon - 7 Icons/Read Me.txt
+++ b/design/IcoMoon/Read Me.txt
diff --git a/design/IcoMoon/SVG/bubble.svg b/design/IcoMoon/SVG/bubble.svg
new file mode 100755
index 00000000..a8120497
--- /dev/null
+++ b/design/IcoMoon/SVG/bubble.svg
@@ -0,0 +1,6 @@
+<?xml version="1.0" encoding="utf-8"?>
+<!-- Generated by IcoMoon.io -->
+<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
+<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="18" height="18" viewBox="0 0 18 18">
+<path d="M9.016 3c2.748 0 4.984 2.243 4.984 5s-2.236 5-4.97 5l-0.060-0.004c-0.055-0.004-0.11-0.007-0.165-0.010l-0.336-0.014-3.665 1.098 0.629-2.483-0.517-0.747c-0.58-0.839-0.886-1.822-0.886-2.842 0-2.757 2.236-5 4.984-5zM9.016 1c-3.857 0-6.984 3.134-6.984 7 0 1.479 0.46 2.848 1.241 3.978l-1.272 5.022 6.722-2.015c0.098 0.004 0.194 0.015 0.293 0.015 3.857 0 6.984-3.134 6.984-7s-3.127-7-6.984-7v0z" fill="#444444"></path>
+</svg>
diff --git a/design/IcoMoon - 7 Icons/SVG/fast-forward.svg b/design/IcoMoon/SVG/fast-forward.svg
index 13670b17..13670b17 100755
--- a/design/IcoMoon - 7 Icons/SVG/fast-forward.svg
+++ b/design/IcoMoon/SVG/fast-forward.svg
diff --git a/design/IcoMoon - 7 Icons/SVG/film.svg b/design/IcoMoon/SVG/film.svg
index 538a30b6..538a30b6 100755
--- a/design/IcoMoon - 7 Icons/SVG/film.svg
+++ b/design/IcoMoon/SVG/film.svg
diff --git a/design/IcoMoon - 7 Icons/SVG/monitor.svg b/design/IcoMoon/SVG/monitor.svg
index 28625055..28625055 100755
--- a/design/IcoMoon - 7 Icons/SVG/monitor.svg
+++ b/design/IcoMoon/SVG/monitor.svg
diff --git a/design/IcoMoon - 7 Icons/SVG/play.svg b/design/IcoMoon/SVG/play.svg
index 65db2254..65db2254 100755
--- a/design/IcoMoon - 7 Icons/SVG/play.svg
+++ b/design/IcoMoon/SVG/play.svg
diff --git a/design/IcoMoon - 7 Icons/SVG/refresh.svg b/design/IcoMoon/SVG/refresh.svg
index 90ad4431..90ad4431 100755
--- a/design/IcoMoon - 7 Icons/SVG/refresh.svg
+++ b/design/IcoMoon/SVG/refresh.svg
diff --git a/design/IcoMoon - 7 Icons/SVG/sound.svg b/design/IcoMoon/SVG/sound.svg
index 58db4ded..58db4ded 100755
--- a/design/IcoMoon - 7 Icons/SVG/sound.svg
+++ b/design/IcoMoon/SVG/sound.svg
diff --git a/design/IcoMoon - 7 Icons/SVG/up.svg b/design/IcoMoon/SVG/up.svg
index ee57849b..ee57849b 100755
--- a/design/IcoMoon - 7 Icons/SVG/up.svg
+++ b/design/IcoMoon/SVG/up.svg
diff --git a/design/IcoMoon - 7 Icons/demo-files/demo.css b/design/IcoMoon/demo-files/demo.css
index b6189ee8..b6189ee8 100755
--- a/design/IcoMoon - 7 Icons/demo-files/demo.css
+++ b/design/IcoMoon/demo-files/demo.css
diff --git a/design/IcoMoon - 7 Icons/demo.html b/design/IcoMoon/demo.html
index 053be7a4..0156120b 100755
--- a/design/IcoMoon - 7 Icons/demo.html
+++ b/design/IcoMoon/demo.html
@@ -10,6 +10,10 @@
<body>
<svg display="none" width="0" height="0" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<defs>
+<symbol id="icon-bubble" viewBox="0 0 1024 1024">
+ <title>bubble</title>
+ <path class="path1" d="M512.889 170.667c156.334 0 283.556 127.596 283.556 284.444s-127.221 284.444-282.722 284.459l-3.388-0.208c-3.14-0.222-6.251-0.412-9.388-0.555l-19.111-0.791-208.473 62.485 35.778-141.227-29.388-42.51c-32.974-47.751-50.418-103.653-50.418-161.653 0-156.848 127.195-284.444 283.556-284.444zM512.889 56.889c-219.445 0-397.333 178.292-397.333 398.222 0 84.124 26.167 162.028 70.612 226.32l-72.389 285.68 382.416-114.626c5.584 0.236 11.056 0.848 16.695 0.848 219.445 0 397.333-178.292 397.333-398.222s-177.888-398.222-397.333-398.222v0z"></path>
+</symbol>
<symbol id="icon-sound" viewBox="0 0 1024 1024">
<title>sound</title>
<path class="path1" d="M581.056 113.778c-6.332 0-12.779 1.819-19.001 5.764l-230.277 159.847c-4.722 3.292-10.332 5.056-16.11 5.056h-202.112c-31.305 0-56.667 25.472-56.667 56.889v341.333c0 31.417 25.362 56.889 56.667 56.889h202.112c5.778 0 11.388 1.764 16.11 5.056l230.277 159.847c6.222 3.945 12.695 5.764 19.001 5.764 22.277 0 42.5-22.736 42.5-54v-688.43c0-31.278-20.222-54.014-42.5-54.014zM510.222 730.139l-135.78-94.265c-9.472-6.569-20.722-10.1-32.222-10.1h-143.666c-15.666 0-28.334-12.736-28.334-28.444v-170.667c0-15.708 12.667-28.444 28.334-28.444h143.668c11.5 0 22.75-3.527 32.222-10.098l135.778-94.26v436.277z"></path>
@@ -51,6 +55,11 @@
<h1 class="mvm mtn fgc1">Grid Size: 18</h1>
<div class="glyph fs1">
<div class="clearfix pbs">
+ <svg class="icon icon-bubble"><use xlink:href="#icon-bubble"></use></svg><span class="mls"> icon-bubble</span>
+ </div>
+ </div>
+ <div class="glyph fs1">
+ <div class="clearfix pbs">
<svg class="icon icon-sound"><use xlink:href="#icon-sound"></use></svg><span class="mls"> icon-sound</span>
</div>
</div>
diff --git a/design/IcoMoon - 7 Icons/style.css b/design/IcoMoon/style.css
index c0b7744f..c0b7744f 100755
--- a/design/IcoMoon - 7 Icons/style.css
+++ b/design/IcoMoon/style.css
diff --git a/design/IcoMoon - 7 Icons/svgdefs.svg b/design/IcoMoon/svgdefs.svg
index a66b1366..8b0944cd 100755
--- a/design/IcoMoon - 7 Icons/svgdefs.svg
+++ b/design/IcoMoon/svgdefs.svg
@@ -1,5 +1,9 @@
<svg display="none" width="0" height="0" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<defs>
+<symbol id="icon-bubble" viewBox="0 0 1024 1024">
+ <title>bubble</title>
+ <path class="path1" d="M512.889 170.667c156.334 0 283.556 127.596 283.556 284.444s-127.221 284.444-282.722 284.459l-3.388-0.208c-3.14-0.222-6.251-0.412-9.388-0.555l-19.111-0.791-208.473 62.485 35.778-141.227-29.388-42.51c-32.974-47.751-50.418-103.653-50.418-161.653 0-156.848 127.195-284.444 283.556-284.444zM512.889 56.889c-219.445 0-397.333 178.292-397.333 398.222 0 84.124 26.167 162.028 70.612 226.32l-72.389 285.68 382.416-114.626c5.584 0.236 11.056 0.848 16.695 0.848 219.445 0 397.333-178.292 397.333-398.222s-177.888-398.222-397.333-398.222v0z"></path>
+</symbol>
<symbol id="icon-sound" viewBox="0 0 1024 1024">
<title>sound</title>
<path class="path1" d="M581.056 113.778c-6.332 0-12.779 1.819-19.001 5.764l-230.277 159.847c-4.722 3.292-10.332 5.056-16.11 5.056h-202.112c-31.305 0-56.667 25.472-56.667 56.889v341.333c0 31.417 25.362 56.889 56.667 56.889h202.112c5.778 0 11.388 1.764 16.11 5.056l230.277 159.847c6.222 3.945 12.695 5.764 19.001 5.764 22.277 0 42.5-22.736 42.5-54v-688.43c0-31.278-20.222-54.014-42.5-54.014zM510.222 730.139l-135.78-94.265c-9.472-6.569-20.722-10.1-32.222-10.1h-143.666c-15.666 0-28.334-12.736-28.334-28.444v-170.667c0-15.708 12.667-28.444 28.334-28.444h143.668c11.5 0 22.75-3.527 32.222-10.098l135.778-94.26v436.277z"></path>
diff --git a/design/captions.sketch b/design/captions.sketch
new file mode 100644
index 00000000..02d2a95a
--- /dev/null
+++ b/design/captions.sketch
Binary files differ
diff --git a/design/muted.sketch b/design/muted.sketch
new file mode 100644
index 00000000..2dd42441
--- /dev/null
+++ b/design/muted.sketch
Binary files differ
diff --git a/design/pause.sketch b/design/pause.sketch
index ec185203..4d840ad1 100644
--- a/design/pause.sketch
+++ b/design/pause.sketch
Binary files differ
diff --git a/dist/css/simple-media.css b/dist/css/simple-media.css
index 996f26fa..16c5a64b 100644
--- a/dist/css/simple-media.css
+++ b/dist/css/simple-media.css
@@ -1 +1 @@
-.player,.player *,.player ::after,.player ::before{box-sizing:border-box}.sr-only{position:absolute!important;clip:rect(1px,1px,1px,1px);padding:0!important;border:0!important;height:1px!important;width:1px!important;overflow:hidden}.hide{display:none}.show-inline{display:inline-block}.player{position:relative;max-width:100%;overflow:hidden;background:#000}.player-video{position:relative}.player:-webkit-full-screen{height:100%;width:100%}.player:-moz-full-screen{height:100%;width:100%}.player:-ms-fullscreen{height:100%;width:100%}.player:fullscreen{height:100%;width:100%}.player:-webkit-full-screen-video{position:absolute;top:50%;left:0;right:0;-webkit-transform:translateY(-50%);transform:translateY(-50%)}.player:-moz-full-screen-video{position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.player:-ms-fullscreen-video{position:absolute;top:50%;left:0;right:0;-ms-transform:translateY(-50%);transform:translateY(-50%)}.player:fullscreen-video{position:absolute;top:50%;left:0;right:0;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.player:-webkit-full-screen-controls{position:absolute;bottom:0;left:0;right:0}.player:-moz-full-screen-controls{position:absolute;bottom:0;left:0;right:0}.player:-ms-fullscreen-controls{position:absolute;bottom:0;left:0;right:0}.player:fullscreen-controls{position:absolute;bottom:0;left:0;right:0}.player:-webkit-full-screen-controls .icon-exit-fullscreen{display:block}.player:-moz-full-screen-controls .icon-exit-fullscreen{display:block}.player:-ms-fullscreen-controls .icon-exit-fullscreen{display:block}.player:fullscreen-controls .icon-exit-fullscreen{display:block}.player:-webkit-full-screen-controls .icon-exit-fullscreen+svg{display:none}.player:-moz-full-screen-controls .icon-exit-fullscreen+svg{display:none}.player:-ms-fullscreen-controls .icon-exit-fullscreen+svg{display:none}.player:fullscreen-controls .icon-exit-fullscreen+svg{display:none}.player video{width:100%;height:auto;vertical-align:middle}.player svg{width:18px;height:18px}.player .px-video-captions{position:absolute;bottom:0;left:0;width:100%;padding:20px;min-height:2.5em;color:#fff;font-size:24px;text-shadow:0 1px 1px rgba(0,0,0,.75);text-align:center;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased}.player-controls{zoom:1;position:relative;padding:20px 10px 10px;background:#343f4a;line-height:1}.player-controls:after,.player-controls:before{content:"";display:table}.player-controls:after{clear:both}.player-controls button,.player-controls input+label{display:inline-block;vertical-align:middle;margin:0 2px;padding:5px 10px;transition:background .3s ease;border-radius:3px;cursor:pointer}.player-controls button svg,.player-controls input+label svg{display:block;fill:currentColor;transition:fill .3s ease}.player-controls input+label,.player-controls input.inverted:checked+label{color:#565d64}.player-controls button,.player-controls input.inverted+label,.player-controls input:checked+label{color:#cbd0d3}.player-controls button{border:0;background:0 0;overflow:hidden}.player-controls button:focus{outline:0}.player-controls button:focus,.player-controls button:hover,.player-controls input:focus+label,.player-controls label:hover{background:#3498db}.player-controls button:focus svg,.player-controls button:hover svg,.player-controls input:focus+label svg,.player-controls label:hover svg{fill:#fff}.player-controls .icon-exit-fullscreen{display:none}.player-controls .px-video-time{display:inline-block;vertical-align:middle;margin-left:10px;color:#fff;font-weight:600;font-size:14px;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased}.player progress{position:absolute;top:0;left:0;right:0;width:100%;height:10px;margin:0;vertical-align:top}.player progress[value]{-webkit-appearance:none;border:none;background:#565d64;cursor:pointer}.player progress[value]::-webkit-progress-bar{background:#565d64}.player progress[value]::-webkit-progress-value{background:#3498db}.player progress[value]::-moz-progress-bar{background:#3498db}.player .play-controls{float:left}.player .sound-controls{float:right}.player-controls .px-video-pause,.player.playing .player-controls .px-video-play{display:none}.player.playing .player-controls .px-video-pause{display:inline-block}.player input[type=range]{-webkit-appearance:none;height:6px;width:100px;margin-right:10px;background:#565d64;outline:0;border-radius:10px}.player input[type=range]::-moz-range-track{-moz-appearance:none;height:6px;background:#565d64;border:0;border-radius:10px}.player input[type=range]::-webkit-slider-thumb{-webkit-appearance:none!important;height:12px;width:12px;background:#cbd0d3;border-radius:100%;transition:background .3s ease}.player input[type=range]::-moz-range-thumb{height:12px;width:12px;border:0;background:#cbd0d3;border-radius:100%}.player input[type=range]:focus::-webkit-slider-thumb{background:#3498db}.player input[type=range]:focus::-moz-range-thumb{background:#3498db}@media screen and (-ms-high-contrast:active),(-ms-high-contrast:none){.px-video-controls input[type=range]{position:relative;padding:0;height:8px;top:-3px}.px-video-time{margin-top:4px}.px-video-captions{padding:8px;min-height:36px}} \ No newline at end of file
+.player,.player *,.player ::after,.player ::before{box-sizing:border-box}.sr-only{position:absolute!important;clip:rect(1px,1px,1px,1px);padding:0!important;border:0!important;height:1px!important;width:1px!important;overflow:hidden}.player{position:relative;max-width:100%;overflow:hidden;background:#000}.player-video{position:relative}.player video{width:100%;height:auto;vertical-align:middle}.player-captions{display:none;position:absolute;bottom:0;left:0;width:100%;padding:20px;min-height:2.5em;color:#fff;font-size:24px;text-shadow:0 1px 1px rgba(0,0,0,.75);text-align:center;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased}.player.captions .player-captions{display:block}.player-controls{zoom:1;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;position:relative;padding:20px 10px 10px;background:#343f4a;line-height:1}.player-controls:after,.player-controls:before{content:"";display:table}.player-controls:after{clear:both}.player-controls-playback{float:left}.player-controls-sound{float:right}.player-controls button,.player-controls input+label{display:inline-block;vertical-align:middle;margin:0 2px;padding:5px 10px;transition:background .3s ease;border-radius:3px;cursor:pointer}.player-controls button svg,.player-controls input+label svg{width:18px;height:18px;display:block;fill:currentColor;transition:fill .3s ease}.player-controls input+label,.player-controls input.inverted:checked+label{color:#565d64}.player-controls button,.player-controls input.inverted+label,.player-controls input:checked+label{color:#cbd0d3}.player-controls button{border:0;background:0 0;overflow:hidden}.player-controls button:hover,.player-controls label:hover{background:#3498db}.player-controls button:hover svg,.player-controls label:hover svg{fill:#fff}.player-controls button:focus,.player-controls input:focus+label{outline:#000 dotted thin;outline-offset:1px}.player-controls button:focus svg,.player-controls input:focus+label svg{fill:#fff}.player-controls .icon-exit-fullscreen,.player-controls .icon-muted{display:none}.player-controls .player-time{display:inline-block;vertical-align:middle;margin-left:10px;color:#fff;font-weight:600;font-size:14px;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased}.player-progress{position:absolute;top:0;left:0;right:0;width:100%;height:10px;margin:0;vertical-align:top}.player-progress[value]{-webkit-appearance:none;border:none;background:#565d64;cursor:pointer}.player-progress[value]::-webkit-progress-bar{background:#565d64}.player-progress[value]::-webkit-progress-value{background:#3498db}.player-progress[value]::-moz-progress-bar{background:#3498db}.player-controls [data-player=pause],.player.playing .player-controls [data-player=play]{display:none}.player.playing .player-controls [data-player=pause]{display:inline-block}.player.muted .player-controls .icon-muted{display:block}.player.muted .player-controls .icon-muted+svg{display:none}.player-volume{-webkit-appearance:none;height:6px;width:100px;margin-right:10px;background:#565d64;border-radius:10px}.player-volume::-moz-range-track{-moz-appearance:none;height:6px;background:#565d64;border:0;border-radius:10px}.player-volume::-webkit-slider-thumb{-webkit-appearance:none!important;height:12px;width:12px;background:#cbd0d3;border-radius:100%;transition:background .3s ease}.player-volume::-moz-range-thumb{height:12px;width:12px;border:0;background:#cbd0d3;border-radius:100%}.player-volume:focus{outline:0}.player-volume:focus::-webkit-slider-thumb{background:#3498db}.player-volume:focus::-moz-range-thumb{background:#3498db}.player:-webkit-full-screen{height:100%;width:100%}.player:-moz-full-screen{height:100%;width:100%}.player:-ms-fullscreen{height:100%;width:100%}.player:fullscreen{height:100%;width:100%}.player:-webkit-full-screen .player-video{position:absolute;top:50%;left:0;right:0;-webkit-transform:translateY(-50%);transform:translateY(-50%)}.player:-moz-full-screen .player-video{position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.player:-ms-fullscreen .player-video{position:absolute;top:50%;left:0;right:0;-ms-transform:translateY(-50%);transform:translateY(-50%)}.player:fullscreen .player-video{position:absolute;top:50%;left:0;right:0;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.player:-webkit-full-screen .player-controls{position:absolute;bottom:0;left:0;right:0}.player:-moz-full-screen .player-controls{position:absolute;bottom:0;left:0;right:0}.player:-ms-fullscreen .player-controls{position:absolute;bottom:0;left:0;right:0}.player:fullscreen .player-controls{position:absolute;bottom:0;left:0;right:0}.player:-webkit-full-screen .player-controls .icon-exit-fullscreen{display:block}.player:-moz-full-screen .player-controls .icon-exit-fullscreen{display:block}.player:-ms-fullscreen .player-controls .icon-exit-fullscreen{display:block}.player:fullscreen .player-controls .icon-exit-fullscreen{display:block}.player:-webkit-full-screen .player-controls .icon-exit-fullscreen+svg{display:none}.player:-moz-full-screen .player-controls .icon-exit-fullscreen+svg{display:none}.player:-ms-fullscreen .player-controls .icon-exit-fullscreen+svg{display:none}.player:fullscreen .player-controls .icon-exit-fullscreen+svg{display:none}@media screen and (-ms-high-contrast:active),(-ms-high-contrast:none){.video-controls .player-volume{position:relative;padding:0;height:8px;top:-3px}.player-time{margin-top:4px}.player-captions{padding:8px;min-height:36px}} \ No newline at end of file
diff --git a/dist/js/docs.js b/dist/js/docs.js
index 0b4dd9a2..ef394937 100644
--- a/dist/js/docs.js
+++ b/dist/js/docs.js
@@ -1 +1 @@
-var Hogan={};!function(t){function n(t,n,e){var s;return n&&"object"==typeof n&&(void 0!==n[t]?s=n[t]:e&&n.get&&"function"==typeof n.get&&(s=n.get(t))),s}function e(t,n,e,s,i,r){function a(){}function o(){}a.prototype=t,o.prototype=t.subs;var l,c=new a;c.subs=new o,c.subsText={},c.buf="",s=s||{},c.stackSubs=s,c.subsText=r;for(l in n)s[l]||(s[l]=n[l]);for(l in s)c.subs[l]=s[l];i=i||{},c.stackPartials=i;for(l in e)i[l]||(i[l]=e[l]);for(l in i)c.partials[l]=i[l];return c}function s(t){return String(null===t||void 0===t?"":t)}function i(t){return t=s(t),u.test(t)?t.replace(r,"&amp;").replace(a,"&lt;").replace(o,"&gt;").replace(l,"&#39;").replace(c,"&quot;"):t}t.Template=function(t,n,e,s){t=t||{},this.r=t.code||this.r,this.c=e,this.options=s||{},this.text=n||"",this.partials=t.partials||{},this.subs=t.subs||{},this.buf=""},t.Template.prototype={r:function(){return""},v:i,t:s,render:function(t,n,e){return this.ri([t],n||{},e)},ri:function(t,n,e){return this.r(t,n,e)},ep:function(t,n){var s=this.partials[t],i=n[s.name];if(s.instance&&s.base==i)return s.instance;if("string"==typeof i){if(!this.c)throw new Error("No compiler available.");i=this.c.compile(i,this.options)}if(!i)return null;if(this.partials[t].base=i,s.subs){n.stackText||(n.stackText={});for(key in s.subs)n.stackText[key]||(n.stackText[key]=void 0!==this.activeSub&&n.stackText[this.activeSub]?n.stackText[this.activeSub]:this.text);i=e(i,s.subs,s.partials,this.stackSubs,this.stackPartials,n.stackText)}return this.partials[t].instance=i,i},rp:function(t,n,e,s){var i=this.ep(t,e);return i?i.ri(n,e,s):""},rs:function(t,n,e){var s=t[t.length-1];if(!p(s))return e(t,n,this),void 0;for(var i=0;i<s.length;i++)t.push(s[i]),e(t,n,this),t.pop()},s:function(t,n,e,s,i,r,a){var o;return p(t)&&0===t.length?!1:("function"==typeof t&&(t=this.ms(t,n,e,s,i,r,a)),o=!!t,!s&&o&&n&&n.push("object"==typeof t?t:n[n.length-1]),o)},d:function(t,e,s,i){var r,a=t.split("."),o=this.f(a[0],e,s,i),l=this.options.modelGet,c=null;if("."===t&&p(e[e.length-2]))o=e[e.length-1];else for(var u=1;u<a.length;u++)r=n(a[u],o,l),void 0!==r?(c=o,o=r):o="";return i&&!o?!1:(i||"function"!=typeof o||(e.push(c),o=this.mv(o,e,s),e.pop()),o)},f:function(t,e,s,i){for(var r=!1,a=null,o=!1,l=this.options.modelGet,c=e.length-1;c>=0;c--)if(a=e[c],r=n(t,a,l),void 0!==r){o=!0;break}return o?(i||"function"!=typeof r||(r=this.mv(r,e,s)),r):i?!1:""},ls:function(t,n,e,i,r){var a=this.options.delimiters;return this.options.delimiters=r,this.b(this.ct(s(t.call(n,i)),n,e)),this.options.delimiters=a,!1},ct:function(t,n,e){if(this.options.disableLambda)throw new Error("Lambda features disabled.");return this.c.compile(t,this.options).render(n,e)},b:function(t){this.buf+=t},fl:function(){var t=this.buf;return this.buf="",t},ms:function(t,n,e,s,i,r,a){var o,l=n[n.length-1],c=t.call(l);return"function"==typeof c?s?!0:(o=this.activeSub&&this.subsText&&this.subsText[this.activeSub]?this.subsText[this.activeSub]:this.text,this.ls(c,l,e,o.substring(i,r),a)):c},mv:function(t,n,e){var i=n[n.length-1],r=t.call(i);return"function"==typeof r?this.ct(s(r.call(i)),i,e):r},sub:function(t,n,e,s){var i=this.subs[t];i&&(this.activeSub=t,i(n,e,this,s),this.activeSub=!1)}};var r=/&/g,a=/</g,o=/>/g,l=/\'/g,c=/\"/g,u=/[&<>\"\']/,p=Array.isArray||function(t){return"[object Array]"===Object.prototype.toString.call(t)}}("undefined"!=typeof exports?exports:Hogan),function(t){function n(t){"}"===t.n.substr(t.n.length-1)&&(t.n=t.n.substring(0,t.n.length-1))}function e(t){return t.trim?t.trim():t.replace(/^\s*|\s*$/g,"")}function s(t,n,e){if(n.charAt(e)!=t.charAt(0))return!1;for(var s=1,i=t.length;i>s;s++)if(n.charAt(e+s)!=t.charAt(s))return!1;return!0}function i(n,e,s,o){var l=[],c=null,u=null,p=null;for(u=s[s.length-1];n.length>0;){if(p=n.shift(),u&&"<"==u.tag&&!(p.tag in w))throw new Error("Illegal content in < super tag.");if(t.tags[p.tag]<=t.tags.$||r(p,o))s.push(p),p.nodes=i(n,p.tag,s,o);else{if("/"==p.tag){if(0===s.length)throw new Error("Closing tag without opener: /"+p.n);if(c=s.pop(),p.n!=c.n&&!a(p.n,c.n,o))throw new Error("Nesting error: "+c.n+" vs. "+p.n);return c.end=p.i,l}"\n"==p.tag&&(p.last=0==n.length||"\n"==n[0].tag)}l.push(p)}if(s.length>0)throw new Error("missing closing tag: "+s.pop().n);return l}function r(t,n){for(var e=0,s=n.length;s>e;e++)if(n[e].o==t.n)return t.tag="#",!0}function a(t,n,e){for(var s=0,i=e.length;i>s;s++)if(e[s].c==t&&e[s].o==n)return!0}function o(t){var n=[];for(var e in t)n.push('"'+c(e)+'": function(c,p,t,i) {'+t[e]+"}");return"{ "+n.join(",")+" }"}function l(t){var n=[];for(var e in t.partials)n.push('"'+c(e)+'":{name:"'+c(t.partials[e].name)+'", '+l(t.partials[e])+"}");return"partials: {"+n.join(",")+"}, subs: "+o(t.subs)}function c(t){return t.replace(m,"\\\\").replace(d,'\\"').replace(g,"\\n").replace(v,"\\r").replace(x,"\\u2028").replace(y,"\\u2029")}function u(t){return~t.indexOf(".")?"d":"f"}function p(t,n){var e="<"+(n.prefix||""),s=e+t.n+k++;return n.partials[s]={name:t.n,partials:{}},n.code+='t.b(t.rp("'+c(s)+'",c,p,"'+(t.indent||"")+'"));',s}function b(t,n){n.code+="t.b(t.t(t."+u(t.n)+'("'+c(t.n)+'",c,p,0)));'}function f(t){return"t.b("+t+");"}var h=/\S/,d=/\"/g,g=/\n/g,v=/\r/g,m=/\\/g,x=/\u2028/,y=/\u2029/;t.tags={"#":1,"^":2,"<":3,$:4,"/":5,"!":6,">":7,"=":8,_v:9,"{":10,"&":11,_t:12},t.scan=function(i,r){function a(){m.length>0&&(x.push({tag:"_t",text:new String(m)}),m="")}function o(){for(var n=!0,e=k;e<x.length;e++)if(n=t.tags[x[e].tag]<t.tags._v||"_t"==x[e].tag&&null===x[e].text.match(h),!n)return!1;return n}function l(t,n){if(a(),t&&o())for(var e,s=k;s<x.length;s++)x[s].text&&((e=x[s+1])&&">"==e.tag&&(e.indent=x[s].text.toString()),x.splice(s,1));else n||x.push({tag:"\n"});y=!1,k=x.length}function c(t,n){var s="="+S,i=t.indexOf(s,n),r=e(t.substring(t.indexOf("=",n)+1,i)).split(" ");return T=r[0],S=r[r.length-1],i+s.length-1}var u=i.length,p=0,b=1,f=2,d=p,g=null,v=null,m="",x=[],y=!1,w=0,k=0,T="{{",S="}}";for(r&&(r=r.split(" "),T=r[0],S=r[1]),w=0;u>w;w++)d==p?s(T,i,w)?(--w,a(),d=b):"\n"==i.charAt(w)?l(y):m+=i.charAt(w):d==b?(w+=T.length-1,v=t.tags[i.charAt(w+1)],g=v?i.charAt(w+1):"_v","="==g?(w=c(i,w),d=p):(v&&w++,d=f),y=w):s(S,i,w)?(x.push({tag:g,n:e(m),otag:T,ctag:S,i:"/"==g?y-T.length:w+S.length}),m="",w+=S.length-1,d=p,"{"==g&&("}}"==S?w++:n(x[x.length-1]))):m+=i.charAt(w);return l(y,!0),x};var w={_t:!0,"\n":!0,$:!0,"/":!0};t.stringify=function(n){return"{code: function (c,p,i) { "+t.wrapMain(n.code)+" },"+l(n)+"}"};var k=0;t.generate=function(n,e,s){k=0;var i={code:"",subs:{},partials:{}};return t.walk(n,i),s.asString?this.stringify(i,e,s):this.makeTemplate(i,e,s)},t.wrapMain=function(t){return'var t=this;t.b(i=i||"");'+t+"return t.fl();"},t.template=t.Template,t.makeTemplate=function(t,n,e){var s=this.makePartials(t);return s.code=new Function("c","p","i",this.wrapMain(t.code)),new this.template(s,n,this,e)},t.makePartials=function(t){var n,e={subs:{},partials:t.partials,name:t.name};for(n in e.partials)e.partials[n]=this.makePartials(e.partials[n]);for(n in t.subs)e.subs[n]=new Function("c","p","t","i",t.subs[n]);return e},t.codegen={"#":function(n,e){e.code+="if(t.s(t."+u(n.n)+'("'+c(n.n)+'",c,p,1),c,p,0,'+n.i+","+n.end+',"'+n.otag+" "+n.ctag+'")){t.rs(c,p,function(c,p,t){',t.walk(n.nodes,e),e.code+="});c.pop();}"},"^":function(n,e){e.code+="if(!t.s(t."+u(n.n)+'("'+c(n.n)+'",c,p,1),c,p,1,0,0,"")){',t.walk(n.nodes,e),e.code+="};"},">":p,"<":function(n,e){var s={partials:{},code:"",subs:{},inPartial:!0};t.walk(n.nodes,s);var i=e.partials[p(n,e)];i.subs=s.subs,i.partials=s.partials},$:function(n,e){var s={subs:{},code:"",partials:e.partials,prefix:n.n};t.walk(n.nodes,s),e.subs[n.n]=s.code,e.inPartial||(e.code+='t.sub("'+c(n.n)+'",c,p,i);')},"\n":function(t,n){n.code+=f('"\\n"'+(t.last?"":" + i"))},_v:function(t,n){n.code+="t.b(t.v(t."+u(t.n)+'("'+c(t.n)+'",c,p,0)));'},_t:function(t,n){n.code+=f('"'+c(t.text)+'"')},"{":b,"&":b},t.walk=function(n,e){for(var s,i=0,r=n.length;r>i;i++)s=t.codegen[n[i].tag],s&&s(n[i],e);return e},t.parse=function(t,n,e){return e=e||{},i(t,"",[],e.sectionTags||[])},t.cache={},t.cacheKey=function(t,n){return[t,!!n.asString,!!n.disableLambda,n.delimiters,!!n.modelGet].join("||")},t.compile=function(n,e){e=e||{};var s=t.cacheKey(n,e),i=this.cache[s];if(i){var r=i.partials;for(var a in r)delete r[a].instance;return i}return i=this.generate(this.parse(this.scan(n,e.delimiters),n,e),n,e),this.cache[s]=i}}("undefined"!=typeof exports?exports:Hogan);var Mustache=function(t){function n(n,e,s,i){var r=this.f(n,e,s,0),a=e;return r&&(a=a.concat(r)),t.Template.prototype.rp.call(this,n,a,s,i)}var e=function(e,s,i){this.rp=n,t.Template.call(this,e,s,i)};e.prototype=t.Template.prototype;var s,i=function(){this.cache={},this.generate=function(t,n){return new e(new Function("c","p","i",t),n,s)}};return i.prototype=t,s=new i,{to_html:function(t,n,e,i){var r=s.compile(t),a=r.render(n,e);return i?(i(a),void 0):a}}}(Hogan),templates={};templates.controls=new Hogan.Template({code:function(t,n,e){var s=this;return s.b(e=e||""),s.b('<div class="player-controls">'),s.b("\n"+e),s.b(' <progress class="px-video-progress" max="100" value="0"><span>0</span>% played</progress>'),s.b("\n"),s.b("\n"+e),s.b(' <div class="play-controls">'),s.b("\n"+e),s.b(' <button class="px-video-restart" data-player="restart">'),s.b("\n"+e),s.b(' <svg><use xlink:href="#icon-refresh"></use></svg>'),s.b("\n"+e),s.b(' <span class="sr-only">Restart</span>'),s.b("\n"+e),s.b(" </button>"),s.b("\n"+e),s.b(' <button class="px-video-rewind" data-player="rewind">'),s.b("\n"+e),s.b(' <svg><use xlink:href="#icon-rewind"></use></svg>'),s.b("\n"+e),s.b(' <span class="sr-only">Rewind <span class="px-seconds">10</span> seconds</span>'),s.b("\n"+e),s.b(" </button>"),s.b("\n"+e),s.b(' <button class="px-video-play" aria-label="{aria-label}" data-player="play">'),s.b("\n"+e),s.b(' <svg><use xlink:href="#icon-play"></use></svg>'),s.b("\n"+e),s.b(' <span class="sr-only">Play</span>'),s.b("\n"+e),s.b(" </button>"),s.b("\n"+e),s.b(' <button class="px-video-pause" data-player="pause">'),s.b("\n"+e),s.b(' <svg><use xlink:href="#icon-pause"></use></svg>'),s.b("\n"+e),s.b(' <span class="sr-only">Pause</span>'),s.b("\n"+e),s.b(" </button>"),s.b("\n"+e),s.b(' <button class="px-video-forward" data-player="fast-forward">'),s.b("\n"+e),s.b(' <svg><use xlink:href="#icon-fast-forward"></use></svg>'),s.b("\n"+e),s.b(' <span class="sr-only">Fast forward <span class="px-seconds">10</span> seconds</span>'),s.b("\n"+e),s.b(" </button>"),s.b("\n"+e),s.b(' <div class="px-video-time">'),s.b("\n"+e),s.b(' <span class="sr-only">Time</span>'),s.b("\n"+e),s.b(' <span class="px-video-duration">00:00</span>'),s.b("\n"+e),s.b(" </div>"),s.b("\n"+e),s.b(" </div>"),s.b("\n"),s.b("\n"+e),s.b(' <div class="sound-controls">'),s.b("\n"+e),s.b(' <!--<div class="px-video-mute-btn-container">-->'),s.b("\n"+e),s.b(' <input class="px-video-mute inverted sr-only" id="btnMute{id}" type="checkbox">'),s.b("\n"+e),s.b(' <label id="labelMute{id}" for="btnMute{id}">'),s.b("\n"+e),s.b(' <svg><use xlink:href="#icon-sound"></use></svg>'),s.b("\n"+e),s.b(' <span class="sr-only">Mute</span>'),s.b("\n"+e),s.b(" </label>"),s.b("\n"+e),s.b(" <!--</div>-->"),s.b("\n"),s.b("\n"+e),s.b(' <label for="volume{id}" class="sr-only">Volume:</label>'),s.b("\n"+e),s.b(' <input id="volume{id}" class="px-video-volume" type="range" min="0" max="10" value="5">'),s.b("\n"),s.b("\n"+e),s.b(' <!--<div class="px-video-captions-btn-container hide">-->'),s.b("\n"+e),s.b(' <input class="px-video-btnCaptions sr-only" id="btnCaptions{id}" type="checkbox">'),s.b("\n"+e),s.b(' <label for="btnCaptions{id}">'),s.b("\n"+e),s.b(' <svg><use xlink:href="#icon-film"></use></svg>'),s.b("\n"+e),s.b(' <span class="sr-only">Captions</span>'),s.b("\n"+e),s.b(" </label>"),s.b("\n"+e),s.b(" <!--</div>-->"),s.b("\n"),s.b("\n"+e),s.b(' <button class="player-toggle-fullscreen" data-player="toggle-fullscreen">'),s.b("\n"+e),s.b(' <svg class="icon-exit-fullscreen"><use xlink:href="#icon-collapse"></use></svg>'),s.b("\n"+e),s.b(' <svg><use xlink:href="#icon-expand"></use></svg>'),s.b("\n"+e),s.b(' <span class="sr-only">Toggle fullscreen</span>'),s.b("\n"+e),s.b(" </button>"),s.b("\n"+e),s.b(" </div>"),s.b("\n"+e),s.b("</div>"),s.b("\n"),s.fl()},partials:{},subs:{}});var video=new InitPxVideo({videoId:"myvid",captionsOnDefault:!0,seekInterval:20,videoTitle:"PayPal Austin promo",debug:!0,html:templates.controls.render({})});console.log(video); \ No newline at end of file
+var Hogan={};!function(t){function n(t,n,e){var s;return n&&"object"==typeof n&&(void 0!==n[t]?s=n[t]:e&&n.get&&"function"==typeof n.get&&(s=n.get(t))),s}function e(t,n,e,s,r,a){function i(){}function o(){}i.prototype=t,o.prototype=t.subs;var l,u=new i;u.subs=new o,u.subsText={},u.buf="",s=s||{},u.stackSubs=s,u.subsText=a;for(l in n)s[l]||(s[l]=n[l]);for(l in s)u.subs[l]=s[l];r=r||{},u.stackPartials=r;for(l in e)r[l]||(r[l]=e[l]);for(l in r)u.partials[l]=r[l];return u}function s(t){return String(null===t||void 0===t?"":t)}function r(t){return t=s(t),c.test(t)?t.replace(a,"&amp;").replace(i,"&lt;").replace(o,"&gt;").replace(l,"&#39;").replace(u,"&quot;"):t}t.Template=function(t,n,e,s){t=t||{},this.r=t.code||this.r,this.c=e,this.options=s||{},this.text=n||"",this.partials=t.partials||{},this.subs=t.subs||{},this.buf=""},t.Template.prototype={r:function(){return""},v:r,t:s,render:function(t,n,e){return this.ri([t],n||{},e)},ri:function(t,n,e){return this.r(t,n,e)},ep:function(t,n){var s=this.partials[t],r=n[s.name];if(s.instance&&s.base==r)return s.instance;if("string"==typeof r){if(!this.c)throw new Error("No compiler available.");r=this.c.compile(r,this.options)}if(!r)return null;if(this.partials[t].base=r,s.subs){n.stackText||(n.stackText={});for(key in s.subs)n.stackText[key]||(n.stackText[key]=void 0!==this.activeSub&&n.stackText[this.activeSub]?n.stackText[this.activeSub]:this.text);r=e(r,s.subs,s.partials,this.stackSubs,this.stackPartials,n.stackText)}return this.partials[t].instance=r,r},rp:function(t,n,e,s){var r=this.ep(t,e);return r?r.ri(n,e,s):""},rs:function(t,n,e){var s=t[t.length-1];if(!p(s))return e(t,n,this),void 0;for(var r=0;r<s.length;r++)t.push(s[r]),e(t,n,this),t.pop()},s:function(t,n,e,s,r,a,i){var o;return p(t)&&0===t.length?!1:("function"==typeof t&&(t=this.ms(t,n,e,s,r,a,i)),o=!!t,!s&&o&&n&&n.push("object"==typeof t?t:n[n.length-1]),o)},d:function(t,e,s,r){var a,i=t.split("."),o=this.f(i[0],e,s,r),l=this.options.modelGet,u=null;if("."===t&&p(e[e.length-2]))o=e[e.length-1];else for(var c=1;c<i.length;c++)a=n(i[c],o,l),void 0!==a?(u=o,o=a):o="";return r&&!o?!1:(r||"function"!=typeof o||(e.push(u),o=this.mv(o,e,s),e.pop()),o)},f:function(t,e,s,r){for(var a=!1,i=null,o=!1,l=this.options.modelGet,u=e.length-1;u>=0;u--)if(i=e[u],a=n(t,i,l),void 0!==a){o=!0;break}return o?(r||"function"!=typeof a||(a=this.mv(a,e,s)),a):r?!1:""},ls:function(t,n,e,r,a){var i=this.options.delimiters;return this.options.delimiters=a,this.b(this.ct(s(t.call(n,r)),n,e)),this.options.delimiters=i,!1},ct:function(t,n,e){if(this.options.disableLambda)throw new Error("Lambda features disabled.");return this.c.compile(t,this.options).render(n,e)},b:function(t){this.buf+=t},fl:function(){var t=this.buf;return this.buf="",t},ms:function(t,n,e,s,r,a,i){var o,l=n[n.length-1],u=t.call(l);return"function"==typeof u?s?!0:(o=this.activeSub&&this.subsText&&this.subsText[this.activeSub]?this.subsText[this.activeSub]:this.text,this.ls(u,l,e,o.substring(r,a),i)):u},mv:function(t,n,e){var r=n[n.length-1],a=t.call(r);return"function"==typeof a?this.ct(s(a.call(r)),r,e):a},sub:function(t,n,e,s){var r=this.subs[t];r&&(this.activeSub=t,r(n,e,this,s),this.activeSub=!1)}};var a=/&/g,i=/</g,o=/>/g,l=/\'/g,u=/\"/g,c=/[&<>\"\']/,p=Array.isArray||function(t){return"[object Array]"===Object.prototype.toString.call(t)}}("undefined"!=typeof exports?exports:Hogan),function(t){function n(t){"}"===t.n.substr(t.n.length-1)&&(t.n=t.n.substring(0,t.n.length-1))}function e(t){return t.trim?t.trim():t.replace(/^\s*|\s*$/g,"")}function s(t,n,e){if(n.charAt(e)!=t.charAt(0))return!1;for(var s=1,r=t.length;r>s;s++)if(n.charAt(e+s)!=t.charAt(s))return!1;return!0}function r(n,e,s,o){var l=[],u=null,c=null,p=null;for(c=s[s.length-1];n.length>0;){if(p=n.shift(),c&&"<"==c.tag&&!(p.tag in k))throw new Error("Illegal content in < super tag.");if(t.tags[p.tag]<=t.tags.$||a(p,o))s.push(p),p.nodes=r(n,p.tag,s,o);else{if("/"==p.tag){if(0===s.length)throw new Error("Closing tag without opener: /"+p.n);if(u=s.pop(),p.n!=u.n&&!i(p.n,u.n,o))throw new Error("Nesting error: "+u.n+" vs. "+p.n);return u.end=p.i,l}"\n"==p.tag&&(p.last=0==n.length||"\n"==n[0].tag)}l.push(p)}if(s.length>0)throw new Error("missing closing tag: "+s.pop().n);return l}function a(t,n){for(var e=0,s=n.length;s>e;e++)if(n[e].o==t.n)return t.tag="#",!0}function i(t,n,e){for(var s=0,r=e.length;r>s;s++)if(e[s].c==t&&e[s].o==n)return!0}function o(t){var n=[];for(var e in t)n.push('"'+u(e)+'": function(c,p,t,i) {'+t[e]+"}");return"{ "+n.join(",")+" }"}function l(t){var n=[];for(var e in t.partials)n.push('"'+u(e)+'":{name:"'+u(t.partials[e].name)+'", '+l(t.partials[e])+"}");return"partials: {"+n.join(",")+"}, subs: "+o(t.subs)}function u(t){return t.replace(m,"\\\\").replace(g,'\\"').replace(d,"\\n").replace(v,"\\r").replace(y,"\\u2028").replace(x,"\\u2029")}function c(t){return~t.indexOf(".")?"d":"f"}function p(t,n){var e="<"+(n.prefix||""),s=e+t.n+w++;return n.partials[s]={name:t.n,partials:{}},n.code+='t.b(t.rp("'+u(s)+'",c,p,"'+(t.indent||"")+'"));',s}function b(t,n){n.code+="t.b(t.t(t."+c(t.n)+'("'+u(t.n)+'",c,p,0)));'}function f(t){return"t.b("+t+");"}var h=/\S/,g=/\"/g,d=/\n/g,v=/\r/g,m=/\\/g,y=/\u2028/,x=/\u2029/;t.tags={"#":1,"^":2,"<":3,$:4,"/":5,"!":6,">":7,"=":8,_v:9,"{":10,"&":11,_t:12},t.scan=function(r,a){function i(){m.length>0&&(y.push({tag:"_t",text:new String(m)}),m="")}function o(){for(var n=!0,e=w;e<y.length;e++)if(n=t.tags[y[e].tag]<t.tags._v||"_t"==y[e].tag&&null===y[e].text.match(h),!n)return!1;return n}function l(t,n){if(i(),t&&o())for(var e,s=w;s<y.length;s++)y[s].text&&((e=y[s+1])&&">"==e.tag&&(e.indent=y[s].text.toString()),y.splice(s,1));else n||y.push({tag:"\n"});x=!1,w=y.length}function u(t,n){var s="="+S,r=t.indexOf(s,n),a=e(t.substring(t.indexOf("=",n)+1,r)).split(" ");return T=a[0],S=a[a.length-1],r+s.length-1}var c=r.length,p=0,b=1,f=2,g=p,d=null,v=null,m="",y=[],x=!1,k=0,w=0,T="{{",S="}}";for(a&&(a=a.split(" "),T=a[0],S=a[1]),k=0;c>k;k++)g==p?s(T,r,k)?(--k,i(),g=b):"\n"==r.charAt(k)?l(x):m+=r.charAt(k):g==b?(k+=T.length-1,v=t.tags[r.charAt(k+1)],d=v?r.charAt(k+1):"_v","="==d?(k=u(r,k),g=p):(v&&k++,g=f),x=k):s(S,r,k)?(y.push({tag:d,n:e(m),otag:T,ctag:S,i:"/"==d?x-T.length:k+S.length}),m="",k+=S.length-1,g=p,"{"==d&&("}}"==S?k++:n(y[y.length-1]))):m+=r.charAt(k);return l(x,!0),y};var k={_t:!0,"\n":!0,$:!0,"/":!0};t.stringify=function(n){return"{code: function (c,p,i) { "+t.wrapMain(n.code)+" },"+l(n)+"}"};var w=0;t.generate=function(n,e,s){w=0;var r={code:"",subs:{},partials:{}};return t.walk(n,r),s.asString?this.stringify(r,e,s):this.makeTemplate(r,e,s)},t.wrapMain=function(t){return'var t=this;t.b(i=i||"");'+t+"return t.fl();"},t.template=t.Template,t.makeTemplate=function(t,n,e){var s=this.makePartials(t);return s.code=new Function("c","p","i",this.wrapMain(t.code)),new this.template(s,n,this,e)},t.makePartials=function(t){var n,e={subs:{},partials:t.partials,name:t.name};for(n in e.partials)e.partials[n]=this.makePartials(e.partials[n]);for(n in t.subs)e.subs[n]=new Function("c","p","t","i",t.subs[n]);return e},t.codegen={"#":function(n,e){e.code+="if(t.s(t."+c(n.n)+'("'+u(n.n)+'",c,p,1),c,p,0,'+n.i+","+n.end+',"'+n.otag+" "+n.ctag+'")){t.rs(c,p,function(c,p,t){',t.walk(n.nodes,e),e.code+="});c.pop();}"},"^":function(n,e){e.code+="if(!t.s(t."+c(n.n)+'("'+u(n.n)+'",c,p,1),c,p,1,0,0,"")){',t.walk(n.nodes,e),e.code+="};"},">":p,"<":function(n,e){var s={partials:{},code:"",subs:{},inPartial:!0};t.walk(n.nodes,s);var r=e.partials[p(n,e)];r.subs=s.subs,r.partials=s.partials},$:function(n,e){var s={subs:{},code:"",partials:e.partials,prefix:n.n};t.walk(n.nodes,s),e.subs[n.n]=s.code,e.inPartial||(e.code+='t.sub("'+u(n.n)+'",c,p,i);')},"\n":function(t,n){n.code+=f('"\\n"'+(t.last?"":" + i"))},_v:function(t,n){n.code+="t.b(t.v(t."+c(t.n)+'("'+u(t.n)+'",c,p,0)));'},_t:function(t,n){n.code+=f('"'+u(t.text)+'"')},"{":b,"&":b},t.walk=function(n,e){for(var s,r=0,a=n.length;a>r;r++)s=t.codegen[n[r].tag],s&&s(n[r],e);return e},t.parse=function(t,n,e){return e=e||{},r(t,"",[],e.sectionTags||[])},t.cache={},t.cacheKey=function(t,n){return[t,!!n.asString,!!n.disableLambda,n.delimiters,!!n.modelGet].join("||")},t.compile=function(n,e){e=e||{};var s=t.cacheKey(n,e),r=this.cache[s];if(r){var a=r.partials;for(var i in a)delete a[i].instance;return r}return r=this.generate(this.parse(this.scan(n,e.delimiters),n,e),n,e),this.cache[s]=r}}("undefined"!=typeof exports?exports:Hogan);var Mustache=function(t){function n(n,e,s,r){var a=this.f(n,e,s,0),i=e;return a&&(i=i.concat(a)),t.Template.prototype.rp.call(this,n,i,s,r)}var e=function(e,s,r){this.rp=n,t.Template.call(this,e,s,r)};e.prototype=t.Template.prototype;var s,r=function(){this.cache={},this.generate=function(t,n){return new e(new Function("c","p","i",t),n,s)}};return r.prototype=t,s=new r,{to_html:function(t,n,e,r){var a=s.compile(t),i=a.render(n,e);return r?(r(i),void 0):i}}}(Hogan),templates={};templates.controls=new Hogan.Template({code:function(t,n,e){var s=this;return s.b(e=e||""),s.b('<div class="player-controls">'),s.b("\n"+e),s.b(' <progress class="player-progress" max="100" value="0">'),s.b("\n"+e),s.b(" <span>0</span>% played"),s.b("\n"+e),s.b(" </progress>"),s.b("\n"),s.b("\n"+e),s.b(' <div class="player-controls-playback">'),s.b("\n"+e),s.b(' <button data-player="restart">'),s.b("\n"+e),s.b(' <svg><use xlink:href="#icon-refresh"></use></svg>'),s.b("\n"+e),s.b(' <span class="sr-only">Restart</span>'),s.b("\n"+e),s.b(" </button>"),s.b("\n"+e),s.b(' <button data-player="rewind">'),s.b("\n"+e),s.b(' <svg><use xlink:href="#icon-rewind"></use></svg>'),s.b("\n"+e),s.b(' <span class="sr-only">Rewind <span class="player-seek-time">10</span> seconds</span>'),s.b("\n"+e),s.b(" </button>"),s.b("\n"+e),s.b(' <button aria-label="{aria-label}" data-player="play">'),s.b("\n"+e),s.b(' <svg><use xlink:href="#icon-play"></use></svg>'),s.b("\n"+e),s.b(' <span class="sr-only">Play</span>'),s.b("\n"+e),s.b(" </button>"),s.b("\n"+e),s.b(' <button data-player="pause">'),s.b("\n"+e),s.b(' <svg><use xlink:href="#icon-pause"></use></svg>'),s.b("\n"+e),s.b(' <span class="sr-only">Pause</span>'),s.b("\n"+e),s.b(" </button>"),s.b("\n"+e),s.b(' <button data-player="fast-forward">'),s.b("\n"+e),s.b(' <svg><use xlink:href="#icon-fast-forward"></use></svg>'),s.b("\n"+e),s.b(' <span class="sr-only">Fast forward <span class="player-seek-time">10</span> seconds</span>'),s.b("\n"+e),s.b(" </button>"),s.b("\n"+e),s.b(' <span class="player-time">'),s.b("\n"+e),s.b(' <span class="sr-only">Time</span>'),s.b("\n"+e),s.b(' <span class="player-duration">00:00</span>'),s.b("\n"+e),s.b(" </span>"),s.b("\n"+e),s.b(" </div>"),s.b("\n"),s.b("\n"+e),s.b(' <div class="player-controls-sound">'),s.b("\n"+e),s.b(' <input class="inverted sr-only" id="mute{id}" type="checkbox" data-player="mute">'),s.b("\n"+e),s.b(' <label id="mute{id}" for="mute{id}">'),s.b("\n"+e),s.b(' <svg class="icon-muted"><use xlink:href="#icon-muted"></use></svg>'),s.b("\n"+e),s.b(' <svg><use xlink:href="#icon-sound"></use></svg>'),s.b("\n"+e),s.b(' <span class="sr-only">Mute</span>'),s.b("\n"+e),s.b(" </label>"),s.b("\n"),s.b("\n"+e),s.b(' <label for="volume{id}" class="sr-only">Volume:</label>'),s.b("\n"+e),s.b(' <input id="volume{id}" class="player-volume" type="range" min="0" max="10" value="5" data-player="volume">'),s.b("\n"),s.b("\n"+e),s.b(' <input class="sr-only" id="captions{id}" type="checkbox" data-player="captions">'),s.b("\n"+e),s.b(' <label for="captions{id}">'),s.b("\n"+e),s.b(' <svg><use xlink:href="#icon-bubble"></use></svg>'),s.b("\n"+e),s.b(' <span class="sr-only">Captions</span>'),s.b("\n"+e),s.b(" </label>"),s.b("\n"),s.b("\n"+e),s.b(' <button data-player="fullscreen">'),s.b("\n"+e),s.b(' <svg class="icon-exit-fullscreen"><use xlink:href="#icon-collapse"></use></svg>'),s.b("\n"+e),s.b(' <svg><use xlink:href="#icon-expand"></use></svg>'),s.b("\n"+e),s.b(' <span class="sr-only">Toggle fullscreen</span>'),s.b("\n"+e),s.b(" </button>"),s.b("\n"+e),s.b(" </div>"),s.b("\n"+e),s.b("</div>"),s.b("\n"),s.fl()},partials:{},subs:{}}),simpleMedia.on("setup",function(){console.log(this)}),simpleMedia.setup({debug:!0,title:"PayPal demo",html:templates.controls.render({})}); \ No newline at end of file
diff --git a/dist/js/simple-media.js b/dist/js/simple-media.js
index f048bd6d..ce6d9378 100644
--- a/dist/js/simple-media.js
+++ b/dist/js/simple-media.js
@@ -1 +1 @@
-function InitPxVideo(e){"use strict";function n(e){var n=window.fullscreen.isFullScreen()?{x:0,y:0}:t(e.currentTarget);return{x:e.clientX-n.x,y:e.clientY-n.y}}function t(e){for(var n=0,t=0;e;)n+=e.offsetLeft-e.scrollLeft+e.clientLeft,t+=e.offsetTop-e.scrollTop+e.clientTop,e=e.offsetParent;return{x:n,y:t}}function r(e){var n=[];return n=e.split(" --> "),o(n[0])}function i(e){var n=[];return n=e.split(" --> "),o(n[1])}function o(e){if(null===e||void 0===e)return 0;var n,t=[],r=[];return t=e.split(","),r=t[0].split(":"),n=Math.floor(60*r[0]*60)+Math.floor(60*r[1])+Math.floor(r[2])}function a(e){for(e.subcount=0;i(e.captions[e.subcount][0])<e.movie.currentTime.toFixed(1);)if(e.subcount++,e.subcount>e.captions.length-1){e.subcount=e.captions.length-1;break}}function s(e){e.isCaptionDefault&&(e.captionsContainer.className="px-video-captions show",e.captionsBtn.setAttribute("checked","checked"))}function c(){var e,n,t,r=navigator.userAgent,i=navigator.appName,o=""+parseFloat(navigator.appVersion),a=parseInt(navigator.appVersion,10);return-1!==navigator.appVersion.indexOf("Windows NT")&&-1!==navigator.appVersion.indexOf("rv:11")?(i="IE",o="11;"):-1!==(n=r.indexOf("MSIE"))?(i="IE",o=r.substring(n+5)):-1!==(n=r.indexOf("Chrome"))?(i="Chrome",o=r.substring(n+7)):-1!==(n=r.indexOf("Safari"))?(i="Safari",o=r.substring(n+7),-1!==(n=r.indexOf("Version"))&&(o=r.substring(n+8))):-1!==(n=r.indexOf("Firefox"))?(i="Firefox",o=r.substring(n+8)):(e=r.lastIndexOf(" ")+1)<(n=r.lastIndexOf("/"))&&(i=r.substring(e,n),o=r.substring(n+1),i.toLowerCase()==i.toUpperCase()&&(i=navigator.appName)),-1!==(t=o.indexOf(";"))&&(o=o.substring(0,t)),-1!==(t=o.indexOf(" "))&&(o=o.substring(0,t)),a=parseInt(""+o,10),isNaN(a)&&(o=""+parseFloat(navigator.appVersion),a=parseInt(navigator.appVersion,10)),[i,a]}function l(){p.movie.play(),p.container.className=p.container.className.replace("stopped","playing")}function u(){p.movie.pause(),p.container.className=p.container.className.replace("playing","stopped")}function d(){p.movie.currentTime=0,p.isTextTracks||(p.subcount=0),l()}String.prototype.replaceAll||Object.defineProperty(String.prototype,"replaceAll",{value:function(e,n){return this.replace(new RegExp(e.replace(/([.*+?^=!:${}()|\[\]\/\\])/g,"\\$1"),"g"),n)}});var p={};if(p.arBrowserInfo=c(),p.browserName=p.arBrowserInfo[0],p.browserMajorVersion=p.arBrowserInfo[1],"IE"===p.browserName&&(8===p.browserMajorVersion||9===p.browserMajorVersion))return!1;if(p.isSmartphoneOrTablet=/Android|webOS|iPhone|iPad|iPod|BlackBerry/i.test(navigator.userAgent),p.isSmartphoneOrTablet)return!1;"undefined"==typeof e.debug&&(e.debug=!1),p.debug=e.debug,e.debug&&console.log(p.browserName+" "+p.browserMajorVersion),p.playAriaLabel="undefined"==typeof e.videoTitle||""===e.videoTitle?"Play":"Play video, "+e.videoTitle,p.container=document.getElementById(e.videoId),p.container.className=p.container.className+" stopped",p.movie=p.container.getElementsByTagName("video")[0],p.movie.removeAttribute("controls"),p.randomNum=Math.floor(1e4*Math.random()),e.debug&&console.log("Inserting custom controls..."),p.container.insertAdjacentHTML("beforeend",e.html.replaceAll("{aria-label}",p.playAriaLabel).replaceAll("{id}",p.randomNum)),p.controls=p.container.querySelector(".player-controls"),p.labelMute=document.getElementById("labelMute"+p.randomNum),p.labelMuteOffset=p.movieWidth-390,p.labelMuteOffset<0&&(p.labelMuteOffset=0),p.labelMute.setAttribute("style","margin-left:"+p.labelMuteOffset+"px");for(var m,f="",v=p.movie.childNodes,g=0;g<v.length;g++)"track"===v[g].nodeName.toLowerCase()&&(m=v[g].getAttribute("kind"),"captions"===m&&(f=v[g].getAttribute("src")));if(p.captionExists=!0,""===f?(p.captionExists=!1,e.debug&&console.log("No caption track found.")):e.debug&&console.log("Caption track found; URI: "+f),"undefined"==typeof e.captionsOnDefault&&(e.captionsOnDefault=!0),p.isCaptionDefault=e.captionsOnDefault,"undefined"==typeof e.seekInterval&&(e.seekInterval=10),p.seekInterval=e.seekInterval,p.btnPlay=p.container.getElementsByClassName("px-video-play")[0],p.btnPause=p.container.getElementsByClassName("px-video-pause")[0],p.btnRestart=p.container.getElementsByClassName("px-video-restart")[0],p.btnRewind=p.container.getElementsByClassName("px-video-rewind")[0],p.btnForward=p.container.getElementsByClassName("px-video-forward")[0],p.btnVolume=p.container.getElementsByClassName("px-video-volume")[0],p.btnMute=p.container.getElementsByClassName("px-video-mute")[0],p.progressBar=p.container.getElementsByClassName("px-video-progress")[0],p.progressBarSpan=p.progressBar.getElementsByTagName("span")[0],p.captionsContainer=p.container.getElementsByClassName("px-video-captions")[0],p.captionsBtn=p.container.getElementsByClassName("px-video-btnCaptions")[0],p.captionsBtnContainer=p.container.getElementsByClassName("px-video-captions-btn-container")[0],p.duration=p.container.getElementsByClassName("px-video-duration")[0],p.txtSeconds=p.container.getElementsByClassName("px-seconds"),p.toggleFullscreen=p.container.querySelector("[data-player='toggle-fullscreen']"),p.videoContainer=p.container.querySelector(".player-video"),p.txtSeconds[0].innerHTML=p.seekInterval,p.txtSeconds[1].innerHTML=p.seekInterval,p.isTextTracks=!1,p.movie.textTracks&&(p.isTextTracks=!0),p.toggleFullscreen.addEventListener("click",function(){window.fullscreen.isFullScreen()?window.fullscreen.cancelFullScreen():window.fullscreen.requestFullScreen(p.container)},!1),p.videoContainer.addEventListener("click",function(){p.movie.paused?l():p.movie.ended?d():u()},!1),p.btnPlay.addEventListener("click",function(){l(),p.btnPause.focus()},!1),p.btnPause.addEventListener("click",function(){u(),p.btnPlay.focus()},!1),p.btnRestart.addEventListener("click",d,!1),p.btnRewind.addEventListener("click",function(){var e=p.movie.currentTime-p.seekInterval;p.movie.currentTime=0>e?0:e,p.isTextTracks||a(p)},!1),p.btnForward.addEventListener("click",function(){var e=p.movie.currentTime+p.seekInterval;p.movie.currentTime=e>p.movie.duration?p.movie.duration:e,p.isTextTracks||a(p)},!1),p.btnVolume.addEventListener("change",function(){p.movie.volume=parseFloat(this.value/10)},!1),p.btnMute.addEventListener("click",function(){p.movie.muted=p.movie.muted===!0?!1:!0},!1),p.movie.addEventListener("timeupdate",function(){p.secs=parseInt(p.movie.currentTime%60),p.mins=parseInt(p.movie.currentTime/60%60),p.secs=("0"+p.secs).slice(-2),p.mins=("0"+p.mins).slice(-2),p.duration.innerHTML=p.mins+":"+p.secs},!1),p.movie.addEventListener("timeupdate",function(){p.percent=100/p.movie.duration*p.movie.currentTime,p.percent>0&&(p.progressBar.value=p.percent,p.progressBarSpan.innerHTML=p.percent)},!1),p.progressBar.addEventListener("click",function(e){p.pos=n(e).x/this.offsetWidth,p.movie.currentTime=p.pos*p.movie.duration,p.isTextTracks||a(p)}),p.movie.addEventListener("ended",function(){p.captionsContainer.innerHTML=""}),p.captionsBtn.addEventListener("click",function(){p.captionsContainer.className=this.checked?"px-video-captions show":"px-video-captions hide"},!1),p.captionExists){if("IE"===p.browserName&&10===p.browserMajorVersion||"IE"===p.browserName&&11===p.browserMajorVersion||"Firefox"===p.browserName&&p.browserMajorVersion>=31||"Safari"===p.browserName&&p.browserMajorVersion>=7){e.debug&&console.log("Detected IE 10/11 or Firefox 31+ or Safari 7+"),p.isTextTracks=!1;for(var b={},x=p.movie.textTracks,T=0;T<x.length;T++)b=p.movie.textTracks[T],b.mode="hidden"}if(p.isTextTracks){e.debug&&console.log("textTracks supported"),s(p);for(var b={},x=p.movie.textTracks,T=0;T<x.length;T++)b=p.movie.textTracks[T],b.mode="hidden","captions"===b.kind&&b.addEventListener("cuechange",function(){this.activeCues[0]&&this.activeCues[0].hasOwnProperty("text")&&(p.captionsContainer.innerHTML=this.activeCues[0].text)},!1)}else if(e.debug&&console.log("textTracks not supported so rendering captions manually"),s(p),p.currentCaption="",p.subcount=0,p.captions=[],p.movie.addEventListener("timeupdate",function(){p.movie.currentTime.toFixed(1)>r(p.captions[p.subcount][0])&&p.movie.currentTime.toFixed(1)<i(p.captions[p.subcount][0])&&(p.currentCaption=p.captions[p.subcount][1]),p.movie.currentTime.toFixed(1)>i(p.captions[p.subcount][0])&&p.subcount<p.captions.length-1&&p.subcount++,p.captionsContainer.innerHTML=p.currentCaption},!1),""!==f){var h;window.XMLHttpRequest?h=new XMLHttpRequest:window.ActiveXObject&&(h=new ActiveXObject("Microsoft.XMLHTTP")),h.onreadystatechange=function(){if(4===h.readyState)if(200===h.status){e.debug&&console.log("xhr = 200"),p.captions=[];var n,t=[],r=h.responseText;t=r.split("\n\n");for(var i=0;i<t.length;i++)n=t[i],p.captions[i]=[],p.captions[i]=n.split("\n");p.captions.shift(),e.debug&&console.log("Successfully loaded the caption file via ajax.")}else e.debug&&console.log("There was a problem loading the caption file via ajax.")},h.open("get",f,!0),h.send()}if("Safari"===p.browserName&&7===p.browserMajorVersion){console.log("Safari 7 detected; removing track from DOM");var x=p.movie.getElementsByTagName("track");p.movie.removeChild(x[0])}}else p.captionsContainer.className="px-video-captions hide"}!function(){var e={supportsFullScreen:!1,isFullScreen:function(){return!1},requestFullScreen:function(){},cancelFullScreen:function(){},fullScreenEventName:"",element:null,prefix:""},n="webkit moz o ms khtml".split(" ");if("undefined"!=typeof document.cancelFullScreen)e.supportsFullScreen=!0;else for(var t=0,r=n.length;r>t;t++)if(e.prefix=n[t],"undefined"!=typeof document[e.prefix+"CancelFullScreen"]){e.supportsFullScreen=!0;break}"webkit"===e.prefix&&navigator.userAgent.match(/Version\/[\d\.]+.*Safari/)&&(e.supportsFullScreen=!1),e.supportsFullScreen&&(e.fullScreenEventName=e.prefix+"fullscreenchange",e.isFullScreen=function(){switch(this.prefix){case"":return document.fullScreen;case"webkit":return document.webkitIsFullScreen;default:return document[this.prefix+"FullScreen"]}},e.requestFullScreen=function(e){return""===this.prefix?e.requestFullScreen():e[this.prefix+"RequestFullScreen"]("webkit"===this.prefix?e.ALLOW_KEYBOARD_INPUT:null)},e.cancelFullScreen=function(){return""===this.prefix?document.cancelFullScreen():document[this.prefix+"CancelFullScreen"]()},e.element=function(){return""===this.prefix?document.fullscreenElement:document[this.prefix+"FullscreenElement"]}),window.fullscreen=e}(); \ No newline at end of file
+!function(e){"use strict";function t(){var e,t,n,r=navigator.userAgent,s=navigator.appName,a=""+parseFloat(navigator.appVersion),o=parseInt(navigator.appVersion,10);return-1!==navigator.appVersion.indexOf("Windows NT")&&-1!==navigator.appVersion.indexOf("rv:11")?(s="IE",a="11;"):-1!==(t=r.indexOf("MSIE"))?(s="IE",a=r.substring(t+5)):-1!==(t=r.indexOf("Chrome"))?(s="Chrome",a=r.substring(t+7)):-1!==(t=r.indexOf("Safari"))?(s="Safari",a=r.substring(t+7),-1!==(t=r.indexOf("Version"))&&(a=r.substring(t+8))):-1!==(t=r.indexOf("Firefox"))?(s="Firefox",a=r.substring(t+8)):(e=r.lastIndexOf(" ")+1)<(t=r.lastIndexOf("/"))&&(s=r.substring(e,t),a=r.substring(t+1),s.toLowerCase()==s.toUpperCase()&&(s=navigator.appName)),-1!==(n=a.indexOf(";"))&&(a=a.substring(0,n)),-1!==(n=a.indexOf(" "))&&(a=a.substring(0,n)),o=parseInt(""+a,10),isNaN(o)&&(a=""+parseFloat(navigator.appVersion),o=parseInt(navigator.appVersion,10)),[s,o]}function n(e){var t=[];return t=e.split(" --> "),s(t[0])}function r(e){var t=[];return t=e.split(" --> "),s(t[1])}function s(e){if(null===e||void 0===e)return 0;var t,n=[],r=[];return n=e.split(","),r=n[0].split(":"),t=Math.floor(60*r[0]*60)+Math.floor(60*r[1])+Math.floor(r[2])}function a(e){for(e.subcount=0;r(e.captions[e.subcount][0])<e.media.currentTime.toFixed(1);)if(e.subcount++,e.subcount>e.captions.length-1){e.subcount=e.captions.length-1;break}}function o(e){L.captions.default&&(e.container.className+=" "+L.classes.captions,e.buttons.captions.setAttribute("checked","checked"))}function i(e,t,n){return e.replace(new RegExp(t.replace(/([.*+?^=!:${}()|\[\]\/\\])/g,"\\$1"),"g"),n)}function c(e){var t=N.isFullScreen()?{x:0,y:0}:l(e.currentTarget);return{x:e.clientX-t.x,y:e.clientY-t.y}}function l(e){for(var t=0,n=0;e;)t+=e.offsetLeft-e.scrollLeft+e.clientLeft,n+=e.offsetTop-e.scrollTop+e.clientTop,e=e.offsetParent;return{x:t,y:n}}function u(e,t){for(var n in t)t[n]&&t[n].constructor&&t[n].constructor===Object?(e[n]=e[n]||{},u(e[n],t[n])):e[n]=t[n];return e}function d(e){var t,n=F[e]||[],r=n.length;for(t=0;r>t;t++)n[t].apply(E.media,[])}function p(){var e={supportsFullScreen:!1,isFullScreen:function(){return!1},requestFullScreen:function(){},cancelFullScreen:function(){},fullScreenEventName:"",element:null,prefix:""},t="webkit moz o ms khtml".split(" ");if("undefined"!=typeof document.cancelFullScreen)e.supportsFullScreen=!0;else for(var n=0,r=t.length;r>n;n++)if(e.prefix=t[n],"undefined"!=typeof document[e.prefix+"CancelFullScreen"]){e.supportsFullScreen=!0;break}return"webkit"===e.prefix&&navigator.userAgent.match(/Version\/[\d\.]+.*Safari/)&&(e.supportsFullScreen=!1),e.supportsFullScreen&&(e.fullScreenEventName=e.prefix+"fullscreenchange",e.isFullScreen=function(){switch(this.prefix){case"":return document.fullScreen;case"webkit":return document.webkitIsFullScreen;default:return document[this.prefix+"FullScreen"]}},e.requestFullScreen=function(e){return""===this.prefix?e.requestFullScreen():e[this.prefix+"RequestFullScreen"]("webkit"===this.prefix?e.ALLOW_KEYBOARD_INPUT:null)},e.cancelFullScreen=function(){return""===this.prefix?document.cancelFullScreen():document[this.prefix+"CancelFullScreen"]()},e.element=function(){return""===this.prefix?document.fullscreenElement:document[this.prefix+"FullscreenElement"]}),e}function f(){L.debug&&console.log("Injecting custom controls");var e=L.html;e=i(e,"{aria-label}",L.playAriaLabel),e=i(e,"{id}",E.random),E.container.insertAdjacentHTML("beforeend",e)}function m(e){return E.container.querySelectorAll(e)}function b(e){return m(e)[0]}function g(){E.controls=b(L.selectors.controls),E.buttons={},E.buttons.play=b(L.selectors.buttons.play),E.buttons.pause=b(L.selectors.buttons.pause),E.buttons.restart=b(L.selectors.buttons.restart),E.buttons.rewind=b(L.selectors.buttons.rewind),E.buttons.forward=b(L.selectors.buttons.forward),E.buttons.mute=b(L.selectors.buttons.mute),E.buttons.volume=b(L.selectors.buttons.volume),E.buttons.captions=b(L.selectors.buttons.captions),E.buttons.fullscreen=b(L.selectors.buttons.fullscreen),E.progress={},E.progress.bar=b(L.selectors.progress),E.progress.text=E.progress.bar.getElementsByTagName("span")[0],E.duration=b(L.selectors.duration),E.seekTime=m(L.selectors.seekTime)}function v(){E.media.play(),E.container.className=E.container.className.replace(L.classes.stopped,L.classes.playing)}function x(){E.media.pause(),E.container.className=E.container.className.replace(L.classes.playing,L.classes.stopped)}function T(){E.media.currentTime=0,E.isTextTracks||(E.subcount=0),v()}function h(){return E.media=E.container.querySelectorAll("audio, video")[0],E.media?(null===E.media.getAttribute("autoplay")&&(E.container.className+=" "+L.classes.stopped),E.media.removeAttribute("controls"),E.type="video"==E.media.tagName.toLowerCase()?"video":"audio",void 0):(console.warn("No audio or video element found!"),!1)}function k(){if("video"==E.type){E.videoContainer.insertAdjacentHTML("afterbegin","<div class='"+L.selectors.captions.replace(".","")+"'></div>"),E.captionsContainer=b(L.selectors.captions),E.isTextTracks=!1,E.media.textTracks&&(E.isTextTracks=!0);for(var e,t="",s=E.media.childNodes,a=0;a<s.length;a++)"track"===s[a].nodeName.toLowerCase()&&(e=s[a].getAttribute("kind"),"captions"===e&&(t=s[a].getAttribute("src")));if(E.captionExists=!0,""===t?(E.captionExists=!1,L.debug&&console.log("No caption track found.")):L.debug&&console.log("Caption track found; URI: "+t),E.captionExists){var i,c,l={};if("IE"===E.browserName&&10===E.browserMajorVersion||"IE"===E.browserName&&11===E.browserMajorVersion||"Firefox"===E.browserName&&E.browserMajorVersion>=31||"Safari"===E.browserName&&E.browserMajorVersion>=7)for(L.debug&&console.log("Detected IE 10/11 or Firefox 31+ or Safari 7+"),E.isTextTracks=!1,l={},i=E.media.textTracks,c=0;c<i.length;c++)l=E.media.textTracks[c],l.mode="hidden";if(E.isTextTracks)for(L.debug&&console.log("textTracks supported"),o(E),l={},i=E.media.textTracks,c=0;c<i.length;c++)l=E.media.textTracks[c],l.mode="hidden","captions"===l.kind&&l.addEventListener("cuechange",function(){this.activeCues[0]&&this.activeCues[0].hasOwnProperty("text")&&(E.captionsContainer.innerHTML=this.activeCues[0].text)},!1);else if(L.debug&&console.log("textTracks not supported so rendering captions manually"),o(E),E.currentCaption="",E.subcount=0,E.captions=[],E.media.addEventListener("timeupdate",function(){E.media.currentTime.toFixed(1)>n(E.captions[E.subcount][0])&&E.media.currentTime.toFixed(1)<r(E.captions[E.subcount][0])&&(E.currentCaption=E.captions[E.subcount][1]),E.media.currentTime.toFixed(1)>r(E.captions[E.subcount][0])&&E.subcount<E.captions.length-1&&E.subcount++,E.captionsContainer.innerHTML=E.currentCaption},!1),""!==t){var u;window.XMLHttpRequest?u=new XMLHttpRequest:window.ActiveXObject&&(u=new ActiveXObject("Microsoft.XMLHTTP")),u.onreadystatechange=function(){if(4===u.readyState)if(200===u.status){L.debug&&console.log("xhr = 200"),E.captions=[];var e,t=[],n=u.responseText;t=n.split("\n\n");for(var r=0;r<t.length;r++)e=t[r],E.captions[r]=[],E.captions[r]=e.split("\n");E.captions.shift(),L.debug&&console.log("Successfully loaded the caption file via ajax.")}else L.debug&&console.log("There was a problem loading the caption file via ajax.")},u.open("get",t,!0),u.send()}"Safari"===E.browserName&&7===E.browserMajorVersion&&(console.log("Safari 7 detected; removing track from DOM"),i=E.media.getElementsByTagName("track"),E.media.removeChild(i[0]))}else E.container.className=E.container.className.replace(L.classes.captions,"")}}function w(){E.seekTime[0].innerHTML=L.seekInterval,E.seekTime[1].innerHTML=L.seekInterval}function y(){E.buttons.fullscreen.addEventListener("click",function(){N.isFullScreen()?N.cancelFullScreen():N.requestFullScreen(E.container)},!1),E.videoContainer.addEventListener("click",function(){E.media.paused?v():E.media.ended?T():x()},!1),E.buttons.play.addEventListener("click",function(){v(),E.buttons.pause.focus()},!1),E.buttons.pause.addEventListener("click",function(){x(),E.buttons.play.focus()},!1),E.buttons.restart.addEventListener("click",T,!1),E.buttons.rewind.addEventListener("click",function(){var e=E.media.currentTime-L.seekInterval;E.media.currentTime=0>e?0:e,E.isTextTracks||a(E)},!1),E.buttons.forward.addEventListener("click",function(){var e=E.media.currentTime+L.seekInterval;E.media.currentTime=e>E.media.duration?E.media.duration:e,E.isTextTracks||a(E)},!1),E.buttons.volume.addEventListener("change",function(){E.media.volume=parseFloat(this.value/10)},!1),E.buttons.mute.addEventListener("click",function(){E.media.muted===!0?(E.media.muted=!1,E.container.className=E.container.className.replace(L.classes.muted,"")):(E.media.muted=!0,E.container.className+=" "+L.classes.muted)},!1),E.media.addEventListener("timeupdate",function(){E.secs=parseInt(E.media.currentTime%60),E.mins=parseInt(E.media.currentTime/60%60),E.secs=("0"+E.secs).slice(-2),E.mins=("0"+E.mins).slice(-2),E.duration.innerHTML=E.mins+":"+E.secs},!1),E.media.addEventListener("timeupdate",function(){E.percent=100/E.media.duration*E.media.currentTime,E.percent>0&&(E.progress.bar.value=E.percent,E.progress.text.innerHTML=E.percent)},!1),E.progress.bar.addEventListener("click",function(e){E.pos=c(e).x/this.offsetWidth,E.media.currentTime=E.pos*E.media.duration,E.isTextTracks||a(E)}),E.buttons.captions.addEventListener("click",function(){this.checked?E.container.className+=" "+L.classes.captions:E.container.className=E.container.className.replace(L.classes.captions,"")},!1),E.media.addEventListener("ended",function(){E.captionsContainer.innerHTML="",E.container.className=E.container.className.replace(L.classes.playing,L.classes.stopped)})}function S(e){E.container=e,E.videoContainer=b(L.selectors.videoContainer),h(),E.random=Math.floor(1e4*Math.random()),f(),g(),k(),w(),y()}var N,L,F={},E={},M={debug:!1,seekInterval:10,selectors:{container:".player",videoContainer:".player-video",controls:".player-controls",buttons:{play:"[data-player='play']",pause:"[data-player='pause']",restart:"[data-player='restart']",rewind:"[data-player='restart']",forward:"[data-player='fast-forward']",mute:"[data-player='mute']",volume:"[data-player='volume']",captions:"[data-player='captions']",fullscreen:"[data-player='fullscreen']"},progress:".player-progress",captions:".player-captions",duration:".player-duration",seekTime:".player-seek-time"},classes:{stopped:"stopped",playing:"playing",muted:"muted",captions:"captions"},captions:{"default":!0}};e.on=function(e,t){F[e]||(F[e]=[]),F[e].push(t)},e.setup=function(e){if(L=u(M,e),N=p(),E.browserInfo=t(),E.browserName=E.browserInfo[0],E.browserMajorVersion=E.browserInfo[1],L.debug&&(console.log(L),console.log("fullscreen support: "+N.supportsFullScreen),console.log(E.browserName+" "+E.browserMajorVersion)),"IE"===E.browserName&&(8===E.browserMajorVersion||9===E.browserMajorVersion))return console.warn("Browser not suppported."),!1;if(E.isSmartphoneOrTablet=/Android|webOS|iPhone|iPad|iPod|BlackBerry/i.test(navigator.userAgent),E.isSmartphoneOrTablet)return console.warn("Browser not suppported."),!1;L.playAriaLabel="undefined"!=typeof L.title&&L.title.length?"Play "+L.title:"Play";for(var n=document.querySelectorAll(L.selectors.container),r=n.length-1;r>=0;r--)S(n[r]);d("setup")}}(this.simpleMedia=this.simpleMedia||{}); \ No newline at end of file
diff --git a/dist/js/templates.js b/dist/js/templates.js
index 1bef66c8..af5f7eac 100644
--- a/dist/js/templates.js
+++ b/dist/js/templates.js
@@ -1,2 +1,2 @@
var templates = {};
- templates['controls'] = new Hogan.Template({code: function (c,p,i) { var t=this;t.b(i=i||"");t.b("<div class=\"player-controls\">");t.b("\n" + i);t.b(" <progress class=\"px-video-progress\" max=\"100\" value=\"0\"><span>0</span>% played</progress>");t.b("\n");t.b("\n" + i);t.b(" <div class=\"play-controls\">");t.b("\n" + i);t.b(" <button class=\"px-video-restart\" data-player=\"restart\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-refresh\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Restart</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <button class=\"px-video-rewind\" data-player=\"rewind\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-rewind\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Rewind <span class=\"px-seconds\">10</span> seconds</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <button class=\"px-video-play\" aria-label=\"{aria-label}\" data-player=\"play\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-play\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Play</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <button class=\"px-video-pause\" data-player=\"pause\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-pause\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Pause</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <button class=\"px-video-forward\" data-player=\"fast-forward\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-fast-forward\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Fast forward <span class=\"px-seconds\">10</span> seconds</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <div class=\"px-video-time\">");t.b("\n" + i);t.b(" <span class=\"sr-only\">Time</span>");t.b("\n" + i);t.b(" <span class=\"px-video-duration\">00:00</span>");t.b("\n" + i);t.b(" </div>");t.b("\n" + i);t.b(" </div>");t.b("\n");t.b("\n" + i);t.b(" <div class=\"sound-controls\">");t.b("\n" + i);t.b(" <!--<div class=\"px-video-mute-btn-container\">-->");t.b("\n" + i);t.b(" <input class=\"px-video-mute inverted sr-only\" id=\"btnMute{id}\" type=\"checkbox\">");t.b("\n" + i);t.b(" <label id=\"labelMute{id}\" for=\"btnMute{id}\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-sound\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Mute</span>");t.b("\n" + i);t.b(" </label>");t.b("\n" + i);t.b(" <!--</div>-->");t.b("\n");t.b("\n" + i);t.b(" <label for=\"volume{id}\" class=\"sr-only\">Volume:</label>");t.b("\n" + i);t.b(" <input id=\"volume{id}\" class=\"px-video-volume\" type=\"range\" min=\"0\" max=\"10\" value=\"5\">");t.b("\n");t.b("\n" + i);t.b(" <!--<div class=\"px-video-captions-btn-container hide\">-->");t.b("\n" + i);t.b(" <input class=\"px-video-btnCaptions sr-only\" id=\"btnCaptions{id}\" type=\"checkbox\">");t.b("\n" + i);t.b(" <label for=\"btnCaptions{id}\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-film\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Captions</span>");t.b("\n" + i);t.b(" </label>");t.b("\n" + i);t.b(" <!--</div>-->");t.b("\n");t.b("\n" + i);t.b(" <button class=\"player-toggle-fullscreen\" data-player=\"toggle-fullscreen\">");t.b("\n" + i);t.b(" <svg class=\"icon-exit-fullscreen\"><use xlink:href=\"#icon-collapse\"></use></svg>");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-expand\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Toggle fullscreen</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" </div>");t.b("\n" + i);t.b("</div>");t.b("\n");return t.fl(); },partials: {}, subs: { }}); \ No newline at end of file
+ templates['controls'] = new Hogan.Template({code: function (c,p,i) { var t=this;t.b(i=i||"");t.b("<div class=\"player-controls\">");t.b("\n" + i);t.b(" <progress class=\"player-progress\" max=\"100\" value=\"0\">");t.b("\n" + i);t.b(" <span>0</span>% played");t.b("\n" + i);t.b(" </progress>");t.b("\n");t.b("\n" + i);t.b(" <div class=\"player-controls-playback\">");t.b("\n" + i);t.b(" <button data-player=\"restart\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-refresh\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Restart</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <button data-player=\"rewind\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-rewind\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Rewind <span class=\"player-seek-time\">10</span> seconds</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <button aria-label=\"{aria-label}\" data-player=\"play\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-play\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Play</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <button data-player=\"pause\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-pause\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Pause</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <button data-player=\"fast-forward\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-fast-forward\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Fast forward <span class=\"player-seek-time\">10</span> seconds</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" <span class=\"player-time\">");t.b("\n" + i);t.b(" <span class=\"sr-only\">Time</span>");t.b("\n" + i);t.b(" <span class=\"player-duration\">00:00</span>");t.b("\n" + i);t.b(" </span>");t.b("\n" + i);t.b(" </div>");t.b("\n");t.b("\n" + i);t.b(" <div class=\"player-controls-sound\">");t.b("\n" + i);t.b(" <input class=\"inverted sr-only\" id=\"mute{id}\" type=\"checkbox\" data-player=\"mute\">");t.b("\n" + i);t.b(" <label id=\"mute{id}\" for=\"mute{id}\">");t.b("\n" + i);t.b(" <svg class=\"icon-muted\"><use xlink:href=\"#icon-muted\"></use></svg>");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-sound\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Mute</span>");t.b("\n" + i);t.b(" </label>");t.b("\n");t.b("\n" + i);t.b(" <label for=\"volume{id}\" class=\"sr-only\">Volume:</label>");t.b("\n" + i);t.b(" <input id=\"volume{id}\" class=\"player-volume\" type=\"range\" min=\"0\" max=\"10\" value=\"5\" data-player=\"volume\">");t.b("\n");t.b("\n" + i);t.b(" <input class=\"sr-only\" id=\"captions{id}\" type=\"checkbox\" data-player=\"captions\">");t.b("\n" + i);t.b(" <label for=\"captions{id}\">");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-bubble\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Captions</span>");t.b("\n" + i);t.b(" </label>");t.b("\n");t.b("\n" + i);t.b(" <button data-player=\"fullscreen\">");t.b("\n" + i);t.b(" <svg class=\"icon-exit-fullscreen\"><use xlink:href=\"#icon-collapse\"></use></svg>");t.b("\n" + i);t.b(" <svg><use xlink:href=\"#icon-expand\"></use></svg>");t.b("\n" + i);t.b(" <span class=\"sr-only\">Toggle fullscreen</span>");t.b("\n" + i);t.b(" </button>");t.b("\n" + i);t.b(" </div>");t.b("\n" + i);t.b("</div>");t.b("\n");return t.fl(); },partials: {}, subs: { }}); \ No newline at end of file
diff --git a/dist/svg/sprite.svg b/dist/svg/sprite.svg
index 7d0efdcd..1c3e7031 100644
--- a/dist/svg/sprite.svg
+++ b/dist/svg/sprite.svg
@@ -1 +1 @@
-<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg xmlns="http://www.w3.org/2000/svg"><symbol id="icon-collapse" viewBox="0 0 18 18"><title>collapse</title><g><g><path d="M14.424 2.165l-2.57 2.568.018-1.845c-.003-.552-.45-1-1.002-1.002-.55-.003-.994.442-.992.992l-.023 4.22c.002.263.107.517.296.706l.025.023c.01.007.016.017.024.025.187.188.44.294.706.295l4.218-.023c.55.002.995-.442.992-.992-.002-.55-.45-1-1-1.002l-1.847.016 2.567-2.568c.387-.387.387-1.013 0-1.4l-.013-.013c-.386-.386-1.013-.386-1.4 0z"/><path d="M6.154 13.266l-.017 1.846c.003.55.45 1 1.002 1 .55.004.994-.44.99-.99l.024-4.22c0-.264-.106-.517-.295-.706l-.026-.024-.023-.024c-.187-.188-.442-.294-.706-.296l-4.22.023c-.55-.002-.994.442-.99.992.002.55.45 1 1 1.002l1.847-.017-2.568 2.57c-.386.385-.386 1.012 0 1.398.4.4 1.026.4 1.413.014l2.57-2.568z"/></g></g></symbol><symbol id="icon-expand" viewBox="0 0 18 18"><title>expand</title><g><g><path d="M6.424 10.165l-2.57 2.568.018-1.845c-.003-.552-.45-1-1.002-1.002-.55-.003-.994.442-.992.992l-.023 4.22c.002.263.107.517.296.706l.025.023c.01.007.016.017.024.025.187.188.44.294.706.295l4.218-.023c.55.002.995-.442.992-.992-.002-.55-.45-1-1-1.002l-1.847.016 2.567-2.568c.387-.387.387-1.013 0-1.4l-.013-.013c-.386-.386-1.013-.386-1.4 0z"/><path d="M14.154 5.266l-.017 1.846c.003.55.45 1 1.002 1 .55.004.994-.44.99-.99l.024-4.22c0-.264-.106-.517-.295-.706l-.026-.024-.023-.024c-.187-.188-.442-.294-.706-.296l-4.22.023c-.55-.002-.994.442-.99.992.002.55.45 1 1 1.002l1.847-.017-2.568 2.57c-.386.385-.386 1.012 0 1.398.4.4 1.026.4 1.413.014l2.57-2.568z"/></g></g></symbol><symbol id="icon-fast-forward" viewBox="0 0 18 18"><path d="M17.57 8.246L7 2c-.552 0-1 .448-1 1v1.954L1 2c-.552 0-1 .448-1 1v12c0 .552.448 1 1 1l5-2.955V15c0 .552.448 1 1 1l10.57-6.246c.266-.158.43-.444.43-.754s-.164-.597-.43-.754zM6 10.722l-4 2.364V4.914l4 2.364v3.444zm2 2.364V4.914L14.915 9 8 13.086z"/></symbol><symbol id="icon-film" viewBox="0 0 18 18"><path d="M17 2H1c-.552 0-1 .448-1 1v12c0 .552.448 1 1 1h16c.552 0 1-.448 1-1V3c0-.552-.448-1-1-1zM2 4h2v2H2V4zm0 4h2v2H2V8zm0 6v-2h2v2H2zm4 0V4h6v10H6zm10 0h-2v-2h2v2zm0-4h-2V8h2v2zm0-4h-2V4h2v2z"/></symbol><symbol id="icon-pause" viewBox="0 0 18 18"><title>pause</title><g fill="none" fill-rule="evenodd"><g transform="translate(3 3)" stroke="#fff" stroke-width="2"><rect x="8" width="4" height="12" rx="1"/><rect width="4" height="12" rx="1"/></g></g></symbol><symbol id="icon-play" viewBox="0 0 18 18"><path d="M5 4.914L11.915 9 5 13.086V4.914zM4 2c-.552 0-1 .448-1 1v12c0 .552.448 1 1 1l10.57-6.246c.266-.158.43-.444.43-.754s-.164-.597-.43-.754L4 2z"/></symbol><symbol id="icon-refresh" viewBox="0 0 18 18"><path d="M8.013 14.006H7.19c-2.37-.388-4.186-2.453-4.186-4.934 0-.83.213-1.61.574-2.3l.613.85c.447.62 1.41.447 1.615-.288l1.162-4.18C7.13 2.575 6.692 2 6.09 2.002l-4.174.007c-.74 0-1.17.84-.736 1.443l1.128 1.564C1.49 6.16 1.006 7.558 1.006 9.074c0 3.498 2.566 6.398 5.918 6.916.09.014.18.01.267 0V16h.823c.545 0 .987-.44.987-.986v-.02c0-.545-.442-.987-.987-.987zM16.82 14.55l-1.13-1.563c.82-1.145 1.303-2.544 1.303-4.06 0-3.498-2.566-6.398-5.918-6.917-.09-.014-.18-.01-.267 0V2h-.822c-.545 0-.986.442-.986.987v.02c0 .546.442.988.986.988h.822c2.372.388 4.187 2.453 4.187 4.934 0 .83-.213 1.61-.573 2.3l-.614-.85c-.446-.62-1.41-.447-1.613.288l-1.163 4.18c-.16.58.275 1.154.878 1.153l4.174-.006c.742 0 1.17-.842.736-1.443z"/></symbol><symbol id="icon-rewind" viewBox="0 0 18 21"><title>rewind</title><g><path d="M.43 10.754L11 17c.552 0 1-.448 1-1v-1.954L17 17c.552 0 1-.448 1-1V4c0-.552-.448-1-1-1l-5 2.955V4c0-.552-.448-1-1-1L.43 9.246C.165 9.404 0 9.69 0 10s.164.597.43.754zM12 8.278l4-2.364v8.172l-4-2.364V8.278zm-2-2.364v8.172L3.085 10 10 5.914z"/></g></symbol><symbol id="icon-sound" viewBox="0 0 18 18"><path d="M10.214 2c-.11 0-.225.032-.334.1L5.832 4.91C5.75 4.97 5.65 5 5.55 5H1.995C1.446 5 1 5.448 1 6v6c0 .552.446 1 .996 1H5.55c.1 0 .2.03.282.09L9.88 15.9c.11.068.223.1.334.1.392 0 .747-.4.747-.95V2.95c0-.55-.354-.95-.746-.95zM8.97 12.834L6.58 11.177c-.166-.115-.364-.178-.566-.178H3.49c-.274 0-.497-.225-.497-.5v-3c0-.277.223-.5.498-.5h2.526c.202 0 .4-.063.566-.18L8.97 5.165v7.67zM16.934 8.8c-.086-1.75-1.514-2.992-2.507-3.65-.47-.312-1.094-.122-1.325.408l-.038.086c-.188.43-.045.94.336 1.194.706.473 1.586 1.247 1.624 2.065.032.676-.553 1.468-1.663 2.27-.397.288-.528.84-.284 1.275l.042.075c.266.475.866.624 1.3.312 1.74-1.25 2.586-2.606 2.516-4.037z"/></symbol></svg> \ No newline at end of file
+<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg xmlns="http://www.w3.org/2000/svg"><symbol id="icon-bubble" viewBox="0 0 18 18"><path d="M9.016 3C11.764 3 14 5.243 14 8s-2.236 5-4.97 5l-.06-.004-.165-.01-.336-.014-3.666 1.098.63-2.483-.518-.747c-.58-.84-.886-1.822-.886-2.842 0-2.757 2.236-5 4.984-5zm0-2C5.16 1 2.032 4.134 2.032 8c0 1.48.46 2.848 1.24 3.978L2.003 17l6.72-2.015c.1.004.195.015.294.015C12.873 15 16 11.866 16 8s-3.127-7-6.984-7z"/></symbol><symbol id="icon-collapse" viewBox="0 0 18 18"><title>collapse</title><g><g><path d="M14.424 2.165l-2.57 2.568.018-1.845c-.003-.552-.45-1-1.002-1.002-.55-.003-.994.442-.992.992l-.023 4.22c.002.263.107.517.296.706l.025.023c.01.007.016.017.024.025.187.188.44.294.706.295l4.218-.023c.55.002.995-.442.992-.992-.002-.55-.45-1-1-1.002l-1.847.016 2.567-2.568c.387-.387.387-1.013 0-1.4l-.013-.013c-.386-.386-1.013-.386-1.4 0z"/><path d="M6.154 13.266l-.017 1.846c.003.55.45 1 1.002 1 .55.004.994-.44.99-.99l.024-4.22c0-.264-.106-.517-.295-.706l-.026-.024-.023-.024c-.187-.188-.442-.294-.706-.296l-4.22.023c-.55-.002-.994.442-.99.992.002.55.45 1 1 1.002l1.847-.017-2.568 2.57c-.386.385-.386 1.012 0 1.398.4.4 1.026.4 1.413.014l2.57-2.568z"/></g></g></symbol><symbol id="icon-expand" viewBox="0 0 18 18"><title>expand</title><g><g><path d="M6.424 10.165l-2.57 2.568.018-1.845c-.003-.552-.45-1-1.002-1.002-.55-.003-.994.442-.992.992l-.023 4.22c.002.263.107.517.296.706l.025.023c.01.007.016.017.024.025.187.188.44.294.706.295l4.218-.023c.55.002.995-.442.992-.992-.002-.55-.45-1-1-1.002l-1.847.016 2.567-2.568c.387-.387.387-1.013 0-1.4l-.013-.013c-.386-.386-1.013-.386-1.4 0z"/><path d="M14.154 5.266l-.017 1.846c.003.55.45 1 1.002 1 .55.004.994-.44.99-.99l.024-4.22c0-.264-.106-.517-.295-.706l-.026-.024-.023-.024c-.187-.188-.442-.294-.706-.296l-4.22.023c-.55-.002-.994.442-.99.992.002.55.45 1 1 1.002l1.847-.017-2.568 2.57c-.386.385-.386 1.012 0 1.398.4.4 1.026.4 1.413.014l2.57-2.568z"/></g></g></symbol><symbol id="icon-fast-forward" viewBox="0 0 18 18"><path d="M17.57 8.246L7 2c-.552 0-1 .448-1 1v1.954L1 2c-.552 0-1 .448-1 1v12c0 .552.448 1 1 1l5-2.955V15c0 .552.448 1 1 1l10.57-6.246c.266-.158.43-.444.43-.754s-.164-.597-.43-.754zM6 10.722l-4 2.364V4.914l4 2.364v3.444zm2 2.364V4.914L14.915 9 8 13.086z"/></symbol><symbol id="icon-muted" viewBox="0 0 18 18"><title>muted</title><g><g><path d="M9.214 2c-.11 0-.225.032-.334.1L4.832 4.91C4.75 4.97 4.65 5 4.55 5H.995C.446 5 0 5.448 0 6v6c0 .552.446 1 .996 1H4.55c.1 0 .2.03.282.09L8.88 15.9c.11.068.223.1.334.1.392 0 .747-.4.747-.95V2.95c0-.55-.354-.95-.746-.95zM7.97 12.834L5.58 11.177c-.166-.115-.364-.178-.566-.178H2.49c-.274 0-.497-.225-.497-.5v-3c0-.277.223-.5.498-.5h2.526c.202 0 .4-.063.566-.18L7.97 5.165v7.67zM14.934 8.8c-.086-1.75-1.514-2.992-2.507-3.65-.47-.312-1.094-.122-1.325.408l-.038.086c-.188.43-.045.94.336 1.194.706.473 1.586 1.247 1.624 2.065.032.676-.553 1.468-1.663 2.27-.397.288-.528.84-.284 1.275l.042.075c.266.475.866.624 1.3.312 1.74-1.25 2.586-2.606 2.516-4.037z"/><path d="M13.956 9.2c.086 1.747 1.514 2.99 2.507 3.648.47.312 1.094.122 1.325-.408l.038-.086c.188-.43.045-.94-.336-1.194-.706-.473-1.586-1.247-1.624-2.065-.032-.676.553-1.468 1.663-2.27.397-.288.528-.84.284-1.275l-.042-.075c-.266-.475-.866-.624-1.3-.312-1.74 1.25-2.586 2.606-2.516 4.037z"/></g></g></symbol><symbol id="icon-pause" viewBox="0 0 18 18"><title>pause</title><g><g><path d="M2 4v10c0 2 2 2 2 2h2s2 0 2-2V4c0-2-2-2-2-2H4S2 2 2 4zm2 0h2v10H4V4z"/><path d="M10 4v10c0 2 2 2 2 2h2s2 0 2-2V4c0-2-2-2-2-2h-2s-2 0-2 2zm2 0h2v10h-2V4z"/></g></g></symbol><symbol id="icon-play" viewBox="0 0 18 18"><path d="M5 4.914L11.915 9 5 13.086V4.914zM4 2c-.552 0-1 .448-1 1v12c0 .552.448 1 1 1l10.57-6.246c.266-.158.43-.444.43-.754s-.164-.597-.43-.754L4 2z"/></symbol><symbol id="icon-refresh" viewBox="0 0 18 18"><path d="M8.013 14.006H7.19c-2.37-.388-4.186-2.453-4.186-4.934 0-.83.213-1.61.574-2.3l.613.85c.447.62 1.41.447 1.615-.288l1.162-4.18C7.13 2.575 6.692 2 6.09 2.002l-4.174.007c-.74 0-1.17.84-.736 1.443l1.128 1.564C1.49 6.16 1.006 7.558 1.006 9.074c0 3.498 2.566 6.398 5.918 6.916.09.014.18.01.267 0V16h.823c.545 0 .987-.44.987-.986v-.02c0-.545-.442-.987-.987-.987zM16.82 14.55l-1.13-1.563c.82-1.145 1.303-2.544 1.303-4.06 0-3.498-2.566-6.398-5.918-6.917-.09-.014-.18-.01-.267 0V2h-.822c-.545 0-.986.442-.986.987v.02c0 .546.442.988.986.988h.822c2.372.388 4.187 2.453 4.187 4.934 0 .83-.213 1.61-.573 2.3l-.614-.85c-.446-.62-1.41-.447-1.613.288l-1.163 4.18c-.16.58.275 1.154.878 1.153l4.174-.006c.742 0 1.17-.842.736-1.443z"/></symbol><symbol id="icon-rewind" viewBox="0 0 18 21"><title>rewind</title><g><path d="M.43 10.754L11 17c.552 0 1-.448 1-1v-1.954L17 17c.552 0 1-.448 1-1V4c0-.552-.448-1-1-1l-5 2.955V4c0-.552-.448-1-1-1L.43 9.246C.165 9.404 0 9.69 0 10s.164.597.43.754zM12 8.278l4-2.364v8.172l-4-2.364V8.278zm-2-2.364v8.172L3.085 10 10 5.914z"/></g></symbol><symbol id="icon-sound" viewBox="0 0 18 18"><path d="M10.214 2c-.11 0-.225.032-.334.1L5.832 4.91C5.75 4.97 5.65 5 5.55 5H1.995C1.446 5 1 5.448 1 6v6c0 .552.446 1 .996 1H5.55c.1 0 .2.03.282.09L9.88 15.9c.11.068.223.1.334.1.392 0 .747-.4.747-.95V2.95c0-.55-.354-.95-.746-.95zM8.97 12.834L6.58 11.177c-.166-.115-.364-.178-.566-.178H3.49c-.274 0-.497-.225-.497-.5v-3c0-.277.223-.5.498-.5h2.526c.202 0 .4-.063.566-.18L8.97 5.165v7.67zM16.934 8.8c-.086-1.75-1.514-2.992-2.507-3.65-.47-.312-1.094-.122-1.325.408l-.038.086c-.188.43-.045.94.336 1.194.706.473 1.586 1.247 1.624 2.065.032.676-.553 1.468-1.663 2.27-.397.288-.528.84-.284 1.275l.042.075c.266.475.866.624 1.3.312 1.74-1.25 2.586-2.606 2.516-4.037z"/></symbol></svg> \ No newline at end of file
diff --git a/docs/index.html b/docs/index.html
index 598774e0..f139e58f 100644
--- a/docs/index.html
+++ b/docs/index.html
@@ -17,9 +17,8 @@
<p>A simple HTML5 media player</p>
</header>
- <div class="player" id="myvid">
+ <div class="player">
<div class="player-video">
- <div class="px-video-captions"></div>
<video width="640" height="360" poster="../media/poster_PayPal_Austin2.jpg" controls>
<!-- video files -->
<source src="https://www.paypalobjects.com/webstatic/mktg/videos/PayPal_AustinSMB_baseline.mp4" type="video/mp4" />
diff --git a/gulpfile.js b/gulpfile.js
index 600b384b..71dad55f 100644
--- a/gulpfile.js
+++ b/gulpfile.js
@@ -132,8 +132,8 @@ gulp.task(taskNames.jsAll, function(){
// Watch for file changes
gulp.task("watch", function () {
- gulp.watch(paths.watchtemplates, taskNames.jsAll);
- gulp.watch(paths.watchjs, taskNames.jsAll);
+ //gulp.watch(paths.watchtemplates, [taskNames.jsAll]);
+ //gulp.watch(paths.watchjs, [taskNames.jsAll]);
gulp.watch(paths.watchless, lessBuildTasks);
- gulp.watch(paths.watchicons, taskNames.iconBuild);
+ gulp.watch(paths.watchicons, [taskNames.iconBuild]);
}); \ No newline at end of file