// ==UserScript==
// @name ViewTube
// @version 2014.07.15
// @description Watch videos from video sharing websites without Flash Player.
// @author sebaro
// @namespace http://isebaro.com/viewtube
// @icon http://s3.amazonaws.com/uso_ss/icon/87011/large.png
// @include http://youtube.com*
// @include http://www.youtube.com*
// @include https://youtube.com*
// @include https://www.youtube.com*
// @include http://dailymotion.com*
// @include http://www.dailymotion.com*
// @include https://dailymotion.com*
// @include https://www.dailymotion.com*
// @include http://vimeo.com*
// @include http://www.vimeo.com*
// @include https://vimeo.com*
// @include https://www.vimeo.com*
// @include http://metacafe.com*
// @include http://www.metacafe.com*
// @include https://metacafe.com*
// @include https://www.metacafe.com*
// @include http://break.com*
// @include http://www.break.com*
// @include https://break.com*
// @include https://www.break.com*
// @include http://funnyordie.com*
// @include http://www.funnyordie.com*
// @include https://funnyordie.com*
// @include https://www.funnyordie.com*
// @include http://videojug.com*
// @include http://www.videojug.com*
// @include https://videojug.com*
// @include https://www.videojug.com*
// @include http://blip.tv*
// @include http://www.blip.tv*
// @include https://blip.tv*
// @include https://www.blip.tv*
// @include http://veoh.com*
// @include http://www.veoh.com*
// @include https://veoh.com*
// @include https://www.veoh.com*
// @include http://crackle.com*
// @include http://www.crackle.com*
// @include https://crackle.com*
// @include https://www.crackle.com*
// @include http://viki.com*
// @include http://www.viki.com*
// @include https://viki.com*
// @include https://www.viki.com*
// @include http://imdb.com*
// @include http://www.imdb.com*
// @include https://imdb.com*
// @include https://www.imdb.com*
// @include http://facebook.com*
// @include http://www.facebook.com*
// @include https://facebook.com*
// @include https://www.facebook.com*
// @include https://screen.yahoo.com*
// @grant GM_xmlhttpRequest
// @grant GM_setValue
// @grant GM_getValue
// ==/UserScript==
/*
Copyright (C) 2010 - 2014 Sebastian Luncan
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
Website: http://isebaro.com/viewtube
Contact: http://isebaro.com/contact
*/
(function() {
// Don't run on frames or iframes
if (window.top != window.self) return;
// ==========Variables========== //
// Userscript
var userscript = 'ViewTube';
// Page
var page = {win: window, doc: document, body: document.body, url: window.location.href, site: window.location.hostname.match(/([^.]+)\.[^.]+$/)[1]};
// Player
var player = {};
var feature = {'autoplay': true, 'definition': true, 'container': true, 'widesize': true, 'fullsize': true};
var option = {'plugin': 'Auto', 'autoplay': false, 'autoget': false, 'definition': 'HD', 'container': 'MP4', 'widesize': false, 'fullsize': false};
var plugins = ['Auto', 'Alt', 'HTML5', 'MPEG', 'MP4', 'FLV', 'VLC'];
if (navigator.platform.indexOf('Win') != -1) plugins = plugins.concat(['WMP', 'WMP2', 'QT']);
else if (navigator.platform.indexOf('Mac') != -1) plugins = plugins.concat(['QT']);
else plugins = plugins.concat(['Totem', 'Xine']);
var mimetypes = {
'MPEG': 'video/mpeg',
'MP4': 'video/mp4',
'WebM': 'video/webm',
'FLV': 'video/x-flv',
'MOV': 'video/quicktime',
'M4V': 'video/x-m4v',
'AVI': 'video/x-msvideo',
'3GP': 'video/3gpp',
'WMP': 'application/x-ms-wmp',
'WMP2': 'application/x-mplayer2',
'QT': 'video/quicktime',
'VLC': 'application/x-vlc-plugin',
'Totem': 'application/x-totem-plugin',
'Xine': 'application/x-xine-plugin'
};
// Links
var website = 'http://isebaro.com/viewtube/?ln=en';
var contact = 'http://isebaro.com/contact/?ln=en&sb=viewtube';
// ==========Functions========== //
function createMyElement (type, content, event, action, target) {
var obj = page.doc.createElement(type);
if (content) {
if (type == 'div') obj.innerHTML = content;
else if (type == 'img') obj.src = content;
else if (type == 'option') {
obj.value = content;
obj.innerHTML = content;
}
else if (type == 'video') {
obj.src = content;
obj.controls = 'controls';
obj.autoplay = 'autoplay';
obj.volume = 0.5;
obj.innerHTML = '<br><br>The video should be loading. If it doesn\'t load, make sure your browser supports HTML5\'s Video and this video codec. If you think it\'s a script issue, please report it <a href="' + contact + '">here</a>.';
}
else if (type == 'object') {
obj.data = content;
obj.innerHTML = '<br><br>The video should be loading. If it doesn\'t load, make sure a video plugin is installed. If you think it\'s a script issue, please report it <a href="' + contact + '">here</a>.<param name="scale" value="aspect"><param name="stretchtofit" value="true"><param name="autostart" value="true"><param name="autoplay" value="true">';
}
else if (type == 'embed') {
if (option['plugin'] == 'VLC') obj.setAttribute('target', content);
else obj.src = content;
obj.innerHTML = '<br><br>The video should be loading. If it doesn\'t load, make sure a video plugin is installed. If you think it\'s a script issue, please report it <a href="' + contact + '">here</a>.<param name="scale" value="aspect"><param name="stretchtofit" value="true"><param name="autostart" value="true"><param name="autoplay" value="true">';
}
}
if (type == 'video' || type == 'object' || type == 'embed') {
if (option['plugin'] == 'Auto' || option['plugin'] == 'Alt' || option['plugin'] == 'HTML5') {
obj.type = mimetypes[player['videoPlay'].replace(/.*\s/, '')];
}
else {
obj.type = mimetypes[option['plugin']];
}
obj.id = 'vtVideo';
}
if (event == 'change') {
if (target == 'video') {
obj.addEventListener ('change', function () {
player['videoPlay'] = this.value;
if (player['isGetting']) {
modifyMyElement (player['buttonGet'] , 'div', 'Get', false);
player['isGetting'] = false;
}
if (player['isPlaying']) playMyVideo(option['autoplay']);
}, false);
}
else if (target == 'plugin') {
obj.addEventListener ('change', function () {
option['plugin'] = this.value;
setMyOptions ('plugin', option['plugin']);
if (player['isPlaying']) playMyVideo(true);
}, false);
}
}
else if (event == 'click') {
obj.addEventListener ('click', function () {
if (action == 'close') {
removeMyElement(page.body, target);
}
else if (action == 'logo') {
page.win.location.href = website;
}
else if (action == 'play') {
playMyVideo(!player['isPlaying']);
}
else if (action == 'get') {
getMyVideo();
}
else if (action == 'autoplay') {
option['autoplay'] = (option['autoplay']) ? false : true;
if (option['autoplay']) {
styleMyElement (player['buttonPlay'], {display: 'none'});
styleMyElement (player['buttonAutoplay'], {color: '#008080', textShadow: '0px 1px 1px #CCCCCC'});
if (!player['isPlaying']) playMyVideo(true);
}
else {
styleMyElement (player['buttonPlay'], {display: 'inline'});
styleMyElement (player['buttonAutoplay'], {color: '#CCCCCC', textShadow: '0px 0px 0px'});
playMyVideo(false);
}
setMyOptions ('autoplay', option['autoplay']);
}
else if (action == 'definition') {
for (var itemDef = 0; itemDef < option['definitions'].length; itemDef++) {
if (option['definitions'][itemDef].match(/[A-Z]/g).join('') == option['definition']) {
var nextDef = (itemDef + 1 < option['definitions'].length) ? itemDef + 1 : 0;
option['definition'] = option['definitions'][nextDef].match(/[A-Z]/g).join('');
break;
}
}
modifyMyElement (player['buttonDefinition'], 'div', option['definition'], false);
setMyOptions ('definition', option['definition']);
if (player['isGetting']) {
modifyMyElement (player['buttonGet'] , 'div', 'Get', false);
player['isGetting'] = false;
}
selectMyVideo ();
if (player['isPlaying']) playMyVideo(true);
}
else if (action == 'container') {
for (var itemCont = 0; itemCont < option['containers'].length; itemCont++) {
if (option['containers'][itemCont] == option['container']) {
var nextCont = (itemCont + 1 < option['containers'].length) ? itemCont + 1 : 0;
option['container'] = option['containers'][nextCont];
break;
}
}
modifyMyElement (player['buttonContainer'], 'div', option['container'], false);
setMyOptions ('container', option['container']);
if (player['isGetting']) {
modifyMyElement (player['buttonGet'] , 'div', 'Get', false);
player['isGetting'] = false;
}
selectMyVideo ();
if (player['isPlaying']) playMyVideo(true);
}
else if (action == 'widesize') {
option['widesize'] = (option['widesize']) ? false : true;
setMyOptions ('widesize', option['widesize']);
resizeMyPlayer('widesize');
}
else if (action == 'fullsize') {
option['fullsize'] = (option['fullsize']) ? false : true;
setMyOptions ('fullsize', option['fullsize']);
resizeMyPlayer('fullsize');
}
}, false);
}
return obj;
}
function getMyElement (obj, type, from, value, child, content) {
var getObj, chObj, coObj;
var pObj = (!obj) ? page.doc : obj;
if (type == 'body') getObj = pObj.body;
else {
if (from == 'id') getObj = pObj.getElementById(value);
else if (from == 'class') getObj = pObj.getElementsByClassName(value);
else if (from == 'tag') getObj = pObj.getElementsByTagName(type);
else if (from == 'ns') getObj = pObj.getElementsByTagNameNS(value, type);
}
chObj = (child >= 0) ? getObj[child] : getObj;
if (content && chObj) {
if (type == 'html' || type == 'body' || type == 'div' || type == 'option') coObj = chObj.innerHTML;
else if (type == 'object') coObj = chObj.data;
else if (type == 'img' || type == 'video' || type == 'embed') coObj = chObj.src;
else coObj = chObj.textContent;
return coObj;
}
else {
return chObj;
}
}
function modifyMyElement (obj, type, content, clear, hide) {
if (content) {
if (type == 'div') obj.innerHTML = content;
else if (type == 'option') {
obj.value = content;
obj.innerHTML = content;
}
else if (type == 'object') obj.data = content;
else if (type == 'img' || type == 'video' || type == 'embed') obj.src = content;
}
if (clear) {
if (obj.hasChildNodes()) {
while (obj.childNodes.length >= 1) {
obj.removeChild(obj.firstChild);
}
}
}
if (hide) {
for(var i = 0; i < obj.children.length; i++) {
styleMyElement(obj.children[i], {display: 'none'});
}
}
}
function styleMyElement (obj, styles) {
for (var property in styles) {
if (styles.hasOwnProperty(property)) obj.style[property] = styles[property];
}
}
function appendMyElement (parent, child) {
parent.appendChild(child);
}
function removeMyElement (parent, child) {
parent.removeChild(child);
}
function replaceMyElement (parent, orphan, child) {
parent.replaceChild(orphan, child);
}
function createMyPlayer () {
/* Get My Options */
getMyOptions ();
/* Player Settings */
player['panelHeight'] = 18;
player['panelPadding'] = 2;
/* The Panel */
var panelWidth = player['playerWidth'] - player['panelPadding'] * 2;
player['playerPanel'] = createMyElement ('div', '', '', '', '');
styleMyElement (player['playerPanel'], {width: panelWidth + 'px', height: player['panelHeight'] + 'px', padding: player['panelPadding'] + 'px', backgroundColor: 'inherit', textAlign: 'center'});
appendMyElement (player['playerWindow'], player['playerPanel']);
/* Panel Items */
var panelItemBorder = 1;
var panelItemHeight = player['panelHeight'] - panelItemBorder * 2;
/* Panel Logo */
player['panelLogo'] = createMyElement ('div', userscript + ': ', 'click', 'logo', '');
styleMyElement (player['panelLogo'], {height: panelItemHeight + 'px', padding: '0px', display: 'inline', color: '#336699', fontSize: '12px', textShadow: '0px 1px 1px #CCCCCC', cursor: 'pointer'});
appendMyElement (player['playerPanel'], player['panelLogo']);
/* Panel Video Menu */
player['videoMenu'] = createMyElement ('select', '', 'change', '', 'video');
styleMyElement (player['videoMenu'], {width: '200px', height: panelItemHeight + 'px', border: '1px solid transparent', padding: '0px', display: 'inline', backgroundColor: 'inherit', color: '#336699', fontSize: '12px', textShadow: '0px 1px 1px #CCCCCC', verticalAlign: 'baseline', cursor: 'pointer'});
appendMyElement (player['playerPanel'], player['videoMenu'] );
for (var videoCode in player['videoList']) {
player['videoItem'] = createMyElement ('option', videoCode, '', '', '');
styleMyElement (player['videoItem'], {padding: '0px', display: 'block', color: '#336699', fontSize: '12px', textShadow: '0px 1px 1px #CCCCCC', cursor: 'pointer'});
appendMyElement (player['videoMenu'], player['videoItem']);
}
/* Panel Plugin Menu */
player['pluginMenu'] = createMyElement ('select', '', 'change', '', 'plugin');
styleMyElement (player['pluginMenu'], {width: '70px', height: panelItemHeight + 'px', border: '1px solid transparent', padding: '0px', display: 'inline', backgroundColor: 'inherit', color: '#336699', fontSize: '12px', textShadow: '0px 1px 1px #CCCCCC', verticalAlign: 'baseline', cursor: 'pointer'});
appendMyElement (player['playerPanel'], player['pluginMenu'] );
for (var p = 0; p < plugins.length; p++) {
player['pluginItem'] = createMyElement ('option', plugins[p], '', '', '');
styleMyElement (player['pluginItem'], {padding: '0px', display: 'block', color: '#336699', fontSize: '12px', textShadow: '0px 1px 1px #CCCCCC', cursor: 'pointer'});
appendMyElement (player['pluginMenu'], player['pluginItem']);
}
player['pluginMenu'].value = option['plugin'];
/* Panel Play Button */
player['buttonPlay'] = createMyElement ('div', 'Play', 'click', 'play', '');
styleMyElement (player['buttonPlay'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#37B704', fontSize: '12px', textShadow: '0px 1px 1px #CCCCCC', cursor: 'pointer'});
if (option['autoplay']) styleMyElement (player['buttonPlay'], {display: 'none'});
appendMyElement (player['playerPanel'], player['buttonPlay']);
/* Panel Get Button */
player['buttonGet'] = createMyElement ('div', 'Get', 'click', 'get', '');
styleMyElement (player['buttonGet'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#C000C0', fontSize: '12px', textShadow: '0px 1px 1px #CCCCCC', cursor: 'pointer'});
appendMyElement (player['playerPanel'], player['buttonGet']);
/* Panel Autoplay Button */
if (feature['autoplay']) {
var bAutoPlay = (player['playerWidth'] > 600) ? 'Autoplay' : 'AP';
player['buttonAutoplay'] = createMyElement ('div', bAutoPlay, 'click', 'autoplay', '');
styleMyElement (player['buttonAutoplay'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#CCCCCC', fontSize: '12px', cursor: 'pointer'});
if (option['autoplay']) styleMyElement (player['buttonAutoplay'], {color: '#008080', textShadow: '0px 1px 1px #CCCCCC'});
appendMyElement (player['playerPanel'], player['buttonAutoplay']);
}
/* Panel Definition Button */
if (feature['definition']) {
player['buttonDefinition'] = createMyElement ('div', option['definition'], 'click', 'definition', '');
styleMyElement (player['buttonDefinition'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#008000', fontSize: '12px', textShadow: '0px 1px 1px #CCCCCC', cursor: 'pointer'});
appendMyElement (player['playerPanel'], player['buttonDefinition']);
}
/* Panel Container Button */
if (feature['container']) {
player['buttonContainer'] = createMyElement ('div', option['container'], 'click', 'container', '');
styleMyElement (player['buttonContainer'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#008000', fontSize: '12px', textShadow: '0px 1px 1px #CCCCCC', cursor: 'pointer'});
appendMyElement (player['playerPanel'], player['buttonContainer']);
}
/* Panel Widesize Button */
if (feature['widesize']) {
if (option['widesize']) player['buttonWidesize'] = createMyElement ('div', '<', 'click', 'widesize', '');
else player['buttonWidesize'] = createMyElement ('div', '>', 'click', 'widesize', '');
styleMyElement (player['buttonWidesize'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#C05800', fontSize: '12px', textShadow: '1px 1px 2px #CCCCCC', cursor: 'pointer'});
appendMyElement (player['playerPanel'], player['buttonWidesize']);
}
/* Panel Fullsize Button */
if (feature['fullsize']) {
if (option['fullsize']) player['buttonFullsize'] = createMyElement ('div', '-', 'click', 'fullsize', '');
else player['buttonFullsize'] = createMyElement ('div', '+', 'click', 'fullsize', '');
styleMyElement (player['buttonFullsize'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#C05800', fontSize: '12px', textShadow: '1px 1px 2px #CCCCCC', cursor: 'pointer'});
appendMyElement (player['playerPanel'], player['buttonFullsize']);
}
/* The Content */
player['contentWidth'] = player['playerWidth'];
player['contentHeight'] = player['playerHeight'] - player['panelHeight'] - player['panelPadding'] * 2;
player['playerContent'] = createMyElement ('div', '', '', '', '');
styleMyElement (player['playerContent'], {width: player['contentWidth'] + 'px', height: player['contentHeight'] + 'px', color: '#AD0000', fontSize: '14px', textAlign: 'center'});
appendMyElement (player['playerWindow'], player['playerContent']);
/* The Video Thumbnail */
if (player['videoThumb']) {
player['contentImage'] = createMyElement ('img', player['videoThumb'], 'click', 'play', '');
styleMyElement (player['contentImage'], {width: player['contentWidth'] + 'px', height: player['contentHeight'] + 'px', border: '0px', cursor: 'pointer'});
}
/* Disabled Features */
if (!feature['autoplay']) option['autoplay'] = false;
if (!feature['widesize']) option['widesize'] = false;
if (!feature['fullsize']) option['fullsize'] = false;
/* Resize My Player */
if (option['widesize']) resizeMyPlayer('widesize');
if (option['fullsize']) resizeMyPlayer('fullsize');
/* Select My Video */
if (feature['definition'] || feature['container']) selectMyVideo ();
/* Play My Video */
playMyVideo (option['autoplay']);
}
function selectMyVideo () {
var vdoCont = (option['container'] != 'Any') ? [option['container']] : option['containers'];
var vdoDef = option['definitions'];
var vdoList = {};
for (var vC = 0; vC < vdoCont.length; vC++) {
if (vdoCont[vC] != 'Any') {
for (var vD = 0; vD < vdoDef.length; vD++) {
var format = vdoDef[vD] + ' ' + vdoCont[vC];
if (!vdoList[vdoDef[vD]]) {
for (var vL in player['videoList']) {
if (vL == format) {
vdoList[vdoDef[vD]] = vL;
break;
}
}
}
}
}
}
if (option['definition'] == 'UHD') {
if (vdoList['Ultra High Definition']) player['videoPlay'] = vdoList['Ultra High Definition'];
else if (vdoList['Full High Definition']) player['videoPlay'] = vdoList['Full High Definition'];
else if (vdoList['High Definition']) player['videoPlay'] = vdoList['High Definition'];
else if (vdoList['Standard Definition']) player['videoPlay'] = vdoList['Standard Definition'];
else if (vdoList['Low Definition']) player['videoPlay'] = vdoList['Low Definition'];
else if (vdoList['Very Low Definition']) player['videoPlay'] = vdoList['Very Low Definition'];
}
else if (option['definition'] == 'FHD') {
if (vdoList['Full High Definition']) player['videoPlay'] = vdoList['Full High Definition'];
else if (vdoList['High Definition']) player['videoPlay'] = vdoList['High Definition'];
else if (vdoList['Standard Definition']) player['videoPlay'] = vdoList['Standard Definition'];
else if (vdoList['Low Definition']) player['videoPlay'] = vdoList['Low Definition'];
else if (vdoList['Very Low Definition']) player['videoPlay'] = vdoList['Very Low Definition'];
}
else if (option['definition'] == 'HD') {
if (vdoList['High Definition']) player['videoPlay'] = vdoList['High Definition'];
else if (vdoList['Standard Definition']) player['videoPlay'] = vdoList['Standard Definition'];
else if (vdoList['Low Definition']) player['videoPlay'] = vdoList['Low Definition'];
else if (vdoList['Very Low Definition']) player['videoPlay'] = vdoList['Very Low Definition'];
}
else if (option['definition'] == 'SD') {
if (vdoList['Standard Definition']) player['videoPlay'] = vdoList['Standard Definition'];
else if (vdoList['Low Definition']) player['videoPlay'] = vdoList['Low Definition'];
else if (vdoList['Very Low Definition']) player['videoPlay'] = vdoList['Very Low Definition'];
}
else if (option['definition'] == 'LD') {
if (vdoList['Low Definition']) player['videoPlay'] = vdoList['Low Definition'];
else if (vdoList['Very Low Definition']) player['videoPlay'] = vdoList['Very Low Definition'];
}
else if (option['definition'] == 'VLD') {
if (vdoList['Very Low Definition']) player['videoPlay'] = vdoList['Very Low Definition'];
else if (vdoList['Low Definition']) player['videoPlay'] = vdoList['Low Definition'];
}
player['videoMenu'].value = player['videoPlay'];
}
function playMyVideo (play) {
if (play) {
player['isPlaying'] = true;
modifyMyElement (player['buttonPlay'], 'div', 'Stop', false);
styleMyElement (player['buttonPlay'], {color: '#AD0000'});
if (option['plugin'] == 'HTML5') player['contentVideo'] = createMyElement ('video', player['videoList'][player['videoPlay']], '', '', '');
else if (option['plugin'] == 'Alt' || option['plugin'] == 'VLC') player['contentVideo'] = createMyElement ('embed', player['videoList'][player['videoPlay']], '', '', '');
else player['contentVideo'] = createMyElement ('object', player['videoList'][player['videoPlay']], '', '', '');
player['contentVideo'].width = player['contentWidth'];
player['contentVideo'].height = player['contentHeight'];
styleMyElement (player['contentVideo'], {position: 'relative', width: player['contentWidth'] + 'px', height: player['contentHeight'] + 'px'});
modifyMyElement (player['playerContent'], 'div', '', true);
appendMyElement (player['playerContent'], player['contentVideo']);
}
else {
player['isPlaying'] = false;
modifyMyElement (player['buttonPlay'], 'div', 'Play', false);
styleMyElement (player['buttonPlay'], {color: '#37B704'});
modifyMyElement (player['playerContent'], 'div', '', true);
if (player['contentImage']) appendMyElement (player['playerContent'], player['contentImage']);
else showMyMessage ('!thumb');
}
}
function getMyVideo () {
var vdoURL = player['videoList'][player['videoPlay']];
if (player['videoTitle']) {
var vdoD = ' (' + player['videoPlay'] + ')';
vdoD = vdoD.replace(/Ultra High Definition/, 'UHD');
vdoD = vdoD.replace(/Full High Definition/, 'FHD');
vdoD = vdoD.replace(/High Definition/, 'HD');
vdoD = vdoD.replace(/Standard Definition/, 'SD');
vdoD = vdoD.replace(/Very Low Definition/, 'VLD');
vdoD = vdoD.replace(/Low Definition/, 'LD');
vdoD = vdoD.replace(/\sFLV|\sMP4|\sWebM|\s3GP/g, '');
vdoURL = vdoURL + '&title=' + player['videoTitle'] + vdoD;
}
if (option['autoget']) page.win.location.href = vdoURL;
else {
var vdoLink = 'Get <a href="' + vdoURL + '" style="color:#00892C">Link</a>';
modifyMyElement (player['buttonGet'] , 'div', vdoLink, false);
player['isGetting'] = true;
}
}
function resizeMyPlayer (size) {
if (size == 'widesize') {
if (option['widesize']) {
modifyMyElement (player['buttonWidesize'], 'div', '<', false);
var playerWidth = player['playerWideWidth'];
var playerHeight= player['playerWideHeight'];
var sidebarMargin = player['sidebarMarginWide'];
}
else {
modifyMyElement (player['buttonWidesize'], 'div', '>', false);
var playerWidth = player['playerWidth'];
var playerHeight= player['playerHeight'];
var sidebarMargin = player['sidebarMarginNormal'];
}
}
else if (size == 'fullsize') {
if (option['fullsize']) {
var playerPosition = 'fixed';
var playerWidth = page.win.innerWidth || page.doc.documentElement.clientWidth;
var playerHeight = page.win.innerHeight || page.doc.documentElement.clientHeight;
var playerIndex = '9999999999';
if (!player['isFullsize']) {
if (feature['widesize']) styleMyElement (player['buttonWidesize'], {display: 'none'});
modifyMyElement (player['buttonFullsize'], 'div', '-', false);
appendMyElement (page.body, player['playerWindow']);
styleMyElement (page.body, {overflow: 'hidden'});
if (!player['resizeListener']) player['resizeListener'] = function() {resizeMyPlayer('fullsize')};
page.win.addEventListener ('resize', player['resizeListener'], false);
player['isFullsize'] = true;
}
}
else {
var playerPosition = 'relative';
var playerWidth = (option['widesize']) ? player['playerWideWidth'] : player['playerWidth'];
var playerHeight = (option['widesize']) ? player['playerWideHeight'] : player['playerHeight'];
var playerIndex = 'auto';
if (feature['widesize']) styleMyElement (player['buttonWidesize'], {display: 'inline'});
modifyMyElement (player['buttonFullsize'], 'div', '+', false);
appendMyElement (player['playerSocket'], player['playerWindow']);
styleMyElement (page.body, {overflow: 'auto'});
page.win.removeEventListener ('resize', player['resizeListener'], false);
player['isFullsize'] = false;
}
}
/* Resize The Player */
if (size == 'widesize') {
styleMyElement (player['sidebarWindow'], {marginTop: sidebarMargin + 'px'});
styleMyElement (player['playerWindow'], {width: playerWidth + 'px', height: playerHeight + 'px'});
}
else styleMyElement (player['playerWindow'], {position: playerPosition, top: '0px', left: '0px', width: playerWidth + 'px', height: playerHeight + 'px', zIndex: playerIndex});
/* Resize The Panel */
var panelWidth = playerWidth - player['panelPadding'] * 2;
styleMyElement (player['playerPanel'], {width: panelWidth + 'px'});
/* Resize The Content */
player['contentWidth'] = playerWidth;
player['contentHeight'] = playerHeight - player['panelHeight'] - player['panelPadding'] * 2;
styleMyElement (player['playerContent'], {width: player['contentWidth'] + 'px', height: player['contentHeight'] + 'px'});
if (player['contentImage']) styleMyElement (player['contentImage'], {width: player['contentWidth'] + 'px', height: player['contentHeight'] + 'px', border: '0px'});
if (player['isPlaying']) {
player['contentVideo'].width = player['contentWidth'];
player['contentVideo'].height = player['contentHeight'];
styleMyElement (player['contentVideo'], {width: player['contentWidth'] + 'px', height: player['contentHeight'] + 'px'});
}
}
function cleanMyContent (content, unesc) {
var myNewContent = content;
if (unesc) myNewContent = unescape (myNewContent);
myNewContent = myNewContent.replace (/\\u0025/g,'%');
myNewContent = myNewContent.replace (/\\u0026/g,'&');
myNewContent = myNewContent.replace (/\\/g,'');
myNewContent = myNewContent.replace (/\n/g,'');
return myNewContent;
}
function getMyContent (url, pattern, clean) {
var myPageContent, myVideosParse, myVideosContent;
var isIE = (navigator.appName.indexOf('Internet Explorer') != -1) ? true : false;
var getMethod = (url != page.url || isIE) ? 'XHR' : 'DOM';
if (getMethod == 'DOM') {
myPageContent = getMyElement ('', 'html', 'tag', '', 0, true);
if (!myPageContent) myPageContent = getMyElement ('', 'body', '', '', -1, true);
if (clean) myPageContent = cleanMyContent (myPageContent, true);
myVideosParse = myPageContent.match (pattern);
myVideosContent = (myVideosParse) ? myVideosParse[1] : null;
if (myVideosContent) return myVideosContent;
else getMethod = 'XHR';
}
if (getMethod == 'XHR') {
var xmlHTTP = new XMLHttpRequest();
xmlHTTP.open('GET', url, false);
xmlHTTP.send();
if (pattern == 'XML') {
myVideosContent = xmlHTTP.responseXML;
}
else if (pattern == 'TEXT') {
myVideosContent = xmlHTTP.responseText;
}
else {
myPageContent = xmlHTTP.responseText;
if (clean) myPageContent = cleanMyContent (myPageContent, true);
myVideosParse = myPageContent.match (pattern);
myVideosContent = (myVideosParse) ? myVideosParse[1] : null;
}
return myVideosContent;
}
}
function setMyOptions (key, value) {
key = page.site + '_' + userscript.toLowerCase() + '_' + key;
if (typeof GM_setValue === 'function') {
GM_setValue(key, value);
if (typeof GM_getValue === 'function' && GM_getValue(key) == value) return;
}
try {
localStorage.setItem(key, value);
if (localStorage.getItem(key) == value) return;
else throw false;
}
catch(e) {
var date = new Date();
date.setTime(date.getTime() + (356*24*60*60*1000));
var expires = '; expires=' + date.toGMTString();
page.doc.cookie = key + '=' + value + expires + '; path=/';
}
}
function getMyOptions () {
for (var opt in option) {
if (option.hasOwnProperty(opt)) {
var key = page.site + '_' + userscript.toLowerCase() + '_' + opt;
if (typeof GM_getValue === 'function') {
if (GM_getValue(key)) {
option[opt] = GM_getValue(key);
continue;
}
}
try {
if (localStorage.getItem(key)) {
option[opt] = localStorage.getItem(key);
continue;
}
else throw false;
}
catch (e) {
var cookies = page.doc.cookie.split(';');
for (var i=0; i < cookies.length; i++) {
var cookie = cookies[i];
while (cookie.charAt(0) == ' ') cookie = cookie.substring(1, cookie.length);
option[opt] = (cookie.indexOf(key) == 0) ? cookie.substring(key.length + 1, cookie.length) : option[opt];
}
}
}
}
option['autoplay'] = (option['autoplay'] === true || option['autoplay'] == 'true') ? true : false;
option['widesize'] = (option['widesize'] === true || option['widesize'] == 'true') ? true : false;
option['fullsize'] = (option['fullsize'] === true || option['fullsize'] == 'true') ? true : false;
}
function showMyMessage (cause, content) {
var myScriptLogo = createMyElement ('div', userscript, '', '', '');
styleMyElement (myScriptLogo, {margin: '0px auto', padding: '10px', color: '#666666', fontSize: '24px', textAlign: 'center', textShadow: '#FFFFFF -1px -1px 2px'});
var myScriptMess = createMyElement ('div', '', '', '', '');
styleMyElement (myScriptMess, {border: '1px solid #F4F4F4', margin: '5px auto 5px auto', padding: '10px', backgroundColor: '#FFFFFF', color: '#AD0000', textAlign: 'center'});
if (cause == '!player') {
var myScriptAlert = createMyElement ('div', '', '', '', '');
styleMyElement (myScriptAlert, {position: 'absolute', top: '30%', left: '35%', border: '1px solid #F4F4F4', borderRadius: '3px', padding: '10px', backgroundColor: '#FFFFFF', fontSize: '14px', textAlign: 'center', zIndex: '99999'});
appendMyElement (myScriptAlert, myScriptLogo);
var myNoPlayerMess = 'Couldn\'t get the player element. Please report it <a href="' + contact + '" style="color:#00892C">here</a>.';
modifyMyElement (myScriptMess, 'div', myNoPlayerMess, false);
appendMyElement (myScriptAlert, myScriptMess);
var myScriptAlertButton = createMyElement ('div', 'OK', 'click', 'close', myScriptAlert);
styleMyElement (myScriptAlertButton, {width: '100px', border: '3px solid #EEEEEE', borderRadius: '5px', margin: '0px auto', backgroundColor: '#EEEEEE', color: '#666666', fontSize: '18px', textAlign: 'center', textShadow: '#FFFFFF -1px -1px 2px', cursor: 'pointer'});
appendMyElement (myScriptAlert, myScriptAlertButton);
appendMyElement (page.body, myScriptAlert);
}
else if (cause == '!thumb') {
var myNoThumbMess = '<br><br>Couldn\'t get the thumbnail for this video. Please report it <a href="' + contact + '" style="color:#00892C">here</a>.';
modifyMyElement (player['playerContent'], 'div', myNoThumbMess, false);
}
else {
appendMyElement (myPlayerWindow, myScriptLogo);
if (cause == '!content') {
var myNoContentMess = 'Couldn\'t get the videos content. Please report it <a href="' + contact + '" style="color:#00892C">here</a>.';
modifyMyElement (myScriptMess, 'div', myNoContentMess, false);
}
else if (cause == '!videos') {
var myNoVideosMess = 'Couldn\'t get any video. Please report it <a href="' + contact + '" style="color:#00892C">here</a>.';
modifyMyElement (myScriptMess, 'div', myNoVideosMess, false);
}
else if (cause == '!support') {
var myNoSupportMess = 'This video uses the RTMP protocol and is not supported.';
modifyMyElement (myScriptMess, 'div', myNoSupportMess, false);
}
else if (cause == 'embed') {
var myEmbedMess = 'This is an embedded video. You can watch it <a href="' + content + '" style="color:#00892C">here</a>.';
modifyMyElement (myScriptMess, 'div', myEmbedMess, false);
}
appendMyElement (myPlayerWindow, myScriptMess);
}
}
// ==========Websites========== //
// Fixes
var blockObject = null;
var blockInterval = 20;
page.win.setInterval(function() {
// Force page reload on href change
nurl = page.win.location.href;
if (page.url != nurl) {
// YouTube
if (nurl.indexOf('youtube.com') != -1) {
if (nurl.indexOf('youtube.com/watch') != -1) page.win.location.href = nurl;
else if (player['isPlaying']) playMyVideo(false);
}
// Facebook
else if (nurl.indexOf('facebook.com') != -1) {
if (nurl.indexOf('facebook.com/photo.php?v=') != -1) {
page.win.location.href = nurl.replace('&theater', '');
}
}
// Others
else {
page.win.location.href = nurl;
}
}
// Block videos
if (blockObject && blockInterval > 0) {
var elEmbeds = getMyElement (blockObject, 'embed', 'tag', '', -1, false) || getMyElement (blockObject, 'object', 'tag', '', -1, false);
if (elEmbeds.length > 0) {
for (var e = 0; e < elEmbeds.length; e++) {
var elEmbed = elEmbeds[e];
if (elEmbed && elEmbed.id != 'vtVideo' && elEmbed.parentNode) {
removeMyElement (elEmbed.parentNode, elEmbed);
}
}
}
var elVideos = getMyElement (blockObject, 'video', 'tag', '', -1, false);
if (elVideos.length > 0) {
for (var v = 0; v < elVideos.length; v++) {
var elVideo = elVideos[v];
if (elVideo && elVideo.id != 'vtVideo' && elVideo.currentSrc) {
modifyMyElement (elVideo, 'video', 'none', true);
}
}
}
if (blockInterval > 0) blockInterval--;
}
}, 500);
// =====YouTube===== //
if (page.url.indexOf('youtube.com/watch') != -1) {
/* Video Availability */
var ytVideoAvailable = getMyElement ('', 'div', 'id', 'player-unavailable', -1, false);
if (ytVideoAvailable && ytVideoAvailable.className.indexOf('hid') == -1) return;
/* Decrypt Signature */
var ytScriptSrc;
function ytDecryptSignature (s) {return null;}
function ytDecryptFunction () {
var ytFncName, ytFncBody, ytFncMatch, ytFncSwap;
ytFncName = ytScriptSrc.match(/\.signature\s*=\s*((\$|_|\w)+)\(\w+\)/);
ytFncName = (ytFncName) ? ytFncName[1] : null;
if (ytFncName) {
ytFncMatch = 'function ' + ytFncName.replace(/\$/, '\\$') + '\\s*\\(\\w+\\)\\s*\\{(.*?)\\}';
ytFncBody = ytScriptSrc.match(ytFncMatch);
ytFncBody = (ytFncBody) ? ytFncBody[1] : null;
if (ytFncBody) {
ytFncSwap = ytScriptSrc.match(/var\s+((\$|_|\w)+)=\{XG/);
ytFncSwap = (ytFncSwap) ? ytFncSwap[1] : null;
if (ytFncSwap) ytFncBody = 'var ' + ytFncSwap + '={XG:function(a,b){var c=a[0];a[0]=a[b%a.length];a[b]=c;return a},NZ:function(a){return a.reverse()},PL:function(a,b){return a.slice(b)}}; ' + ytFncBody;
ytDecryptSignature = new Function('a', ytFncBody);
}
}
}
/* Get Player Window */
var ytPlayerBgColor = '#FFFFFF';
var ytPlayerWindow = getMyElement ('', 'div', 'id', 'player', -1, false);
if (!ytPlayerWindow) {
ytPlayerWindow = getMyElement ('', 'div', 'id', 'p', -1, false);
ytPlayerBgColor = 'inherit';
feature['widesize'] = false;
}
if (!ytPlayerWindow) {
showMyMessage ('!player');
}
else {
var ytVideoThumb = getMyContent (page.url, 'link\\s+itemprop="thumbnailUrl"\\s+href="(.*?)"', false);
if (!ytVideoThumb) ytVideoThumb = getMyContent (page.url, 'meta\\s+property="og:image"\\s+content="(.*?)"', false);
if (!ytVideoThumb) {
var ytVideoID = page.url.match (/(\?|&)v=(.*?)(&|$)/);
if (ytVideoID) ytVideoThumb = 'http://img.youtube.com/vi/' + ytVideoID[2] + '/0.jpg';
}
/* Get Video Title */
var ytVideoTitle = getMyContent (page.url, 'meta\\s+itemprop="name"\\s+content="(.*?)"', false);
if (!ytVideoTitle) ytVideoTitle = getMyContent (page.url, 'meta\\s+property="og:title"\\s+content="(.*?)"', false);
if (!ytVideoTitle) ytVideoTitle = page.doc.title;
if (ytVideoTitle) {
ytVideoTitle = ytVideoTitle.replace(/"/g, '\'').replace(/"/g, '\'').replace(/"/g, '\'');
ytVideoTitle = ytVideoTitle.replace(/'/g, '\'').replace(/'/g, '\'');
ytVideoTitle = ytVideoTitle.replace(/&/g, 'and').replace(/&/g, 'and');
ytVideoTitle = ytVideoTitle.replace(/\?/g, '').replace(/[#:\*]/g, '-').replace(/\//g, '-');
ytVideoTitle = ytVideoTitle.replace(/^\s+|\s+$/, '').replace(/\.+$/g, '');
ytVideoTitle = ytVideoTitle.replace(/^YouTube\s-\s/, '');
}
/* Get Videos Content */
var ytVideosContent, ytHLSContent;
var ytVideosEncodedFmts, ytVideosAdaptiveFmts;
ytVideosEncodedFmts = getMyContent(page.url, '"url_encoded_fmt_stream_map":\\s+"(.*?)"', false);
if (ytVideosEncodedFmts) ytVideosEncodedFmts = cleanMyContent(ytVideosEncodedFmts, false);
else {
ytVideosEncodedFmts = getMyContent(page.url, 'url_encoded_fmt_stream_map=(.*?)&', false);
if (ytVideosEncodedFmts) ytVideosEncodedFmts = cleanMyContent(ytVideosEncodedFmts, true);
}
ytVideosAdaptiveFmts = getMyContent(page.url, '"adaptive_fmts":\\s+"(.*?)"', false);
if (ytVideosAdaptiveFmts) ytVideosAdaptiveFmts = cleanMyContent(ytVideosAdaptiveFmts, false);
else {
ytVideosAdaptiveFmts = getMyContent(page.url, 'adaptive_fmts=(.*?)&', false);
if (ytVideosAdaptiveFmts) ytVideosAdaptiveFmts = cleanMyContent(ytVideosAdaptiveFmts, true);
}
if (ytVideosEncodedFmts) {
ytVideosContent = ytVideosEncodedFmts;
}
if (ytVideosAdaptiveFmts) {
ytVideosAdaptiveFmts = ytVideosAdaptiveFmts.replace(/clen=\d+&/g, '').replace(/&clen=\d+/g, '');
ytVideosAdaptiveFmts = ytVideosAdaptiveFmts.replace(/lmt=\d+&/g, '').replace(/&lmt=\d+/g, '');
if (ytVideosContent) ytVideosContent += ',' + ytVideosAdaptiveFmts;
else ytVideosContent = ytVideosAdaptiveFmts;
}
/* Get HLS Content */
if (!ytVideosContent) {
var ytHLSVideos, ytHLSContent;
ytHLSVideos = getMyContent(page.url, '"hlsvp":\\s*"(.*?)"', false);
if (ytHLSVideos) ytHLSVideos = cleanMyContent(ytHLSVideos, false);
}
/* Player Width & Height */
var ytPlayerWidth = 640;
var ytPlayerHeight = 382;
var ytPlayerWideWidth = 1040;
var ytPlayerWideHeight = 607;
var ytSidebarMarginWide = 10;
var ytScreenWidth = page.win.innerWidth || page.doc.documentElement.clientWidth;
if (ytScreenWidth >= 1294) {
ytPlayerWidth = 854;
ytPlayerHeight = 502;
ytPlayerWideWidth = 1254;
ytPlayerWideHeight = 728;
ytSidebarMarginWide = 120;
}
/* My Player Window */
var myPlayerWindow = createMyElement ('div', '', '', '', '');
styleMyElement (myPlayerWindow, {position: 'relative', width: ytPlayerWidth + 'px', height: ytPlayerHeight + 'px', backgroundColor: ytPlayerBgColor});
modifyMyElement (ytPlayerWindow, 'div', '', false, true);
appendMyElement (ytPlayerWindow, myPlayerWindow);
blockObject = ytPlayerWindow;
/* Sidebar Window */
var ytSidebarWindow = getMyElement ('', 'div', 'id', 'watch7-sidebar', -1, false);
if (ytSidebarWindow) styleMyElement (ytSidebarWindow, {marginTop: '-382px'});
/* Create Player */
var ytDefaultVideo = 'Low Definition MP4';
function ytPlayer() {
player = {
'playerSocket': ytPlayerWindow,
'playerWindow': myPlayerWindow,
'videoList': ytVideoList,
'videoPlay': ytDefaultVideo,
'videoThumb': ytVideoThumb,
'videoTitle': ytVideoTitle,
'playerWidth': ytPlayerWidth,
'playerHeight': ytPlayerHeight,
'playerWideWidth': ytPlayerWideWidth,
'playerWideHeight': ytPlayerWideHeight,
'sidebarWindow': ytSidebarWindow,
'sidebarMarginNormal': -382,
'sidebarMarginWide': ytSidebarMarginWide
};
option['definitions'] = ['Ultra High Definition', 'Full High Definition', 'High Definition', 'Standard Definition', 'Low Definition', 'Very Low Definition'];
option['containers'] = ['MP4', 'WebM', 'FLV', '3GP', 'Any'];
createMyPlayer();
}
/* Parse Videos */
function ytVideos() {
var ytVideoFormats = {
'5': 'Very Low Definition FLV',
'17': 'Very Low Definition 3GP',
'18': 'Low Definition MP4',
'22': 'High Definition MP4',
'34': 'Low Definition FLV',
'35': 'Standard Definition FLV',
'36': 'Low Definition 3GP',
'37': 'Full High Definition MP4',
'38': 'Ultra High Definition MP4',
'43': 'Low Definition WebM',
'44': 'Standard Definition WebM',
'45': 'High Definition WebM',
'46': 'Full High Definition WebM',
'82': 'Low Definition 3D MP4',
'83': 'Standard Definition 3D MP4',
'84': 'High Definition 3D MP4',
'85': 'Full High Definition 3D MP4',
'100': 'Low Definition 3D WebM',
'101': 'Standard Definition 3D WebM',
'102': 'High Definition 3D WebM',
'135': 'Standard Definition Video MP4',
'136': 'High Definition Video MP4',
'137': 'Full High Definition Video MP4',
'138': 'Ultra High Definition Video MP4',
'139': 'Low Bitrate Audio MP4',
'140': 'Medium Bitrate Audio MP4',
'141': 'High Bitrate Audio MP4',
'171': 'Medium Bitrate Audio WebM',
'172': 'High Bitrate Audio WebM',
'244': 'Standard Definition Video WebM',
'247': 'High Definition Video WebM',
'248': 'Full High Definition Video WebM'
};
var ytVideoFound = false;
var ytVideos = ytVideosContent.split(',');
var ytVideoParse, ytVideoCodeParse, ytVideoCode, myVideoCode, ytVideo;
for (var i = 0; i < ytVideos.length; i++) {
if (!ytVideos[i].match(/^url/)) {
ytVideoParse = ytVideos[i].match(/(.*)(url=.*$)/);
if (ytVideoParse) ytVideos[i] = ytVideoParse[2] + '&' + ytVideoParse[1];
}
ytVideoCodeParse = ytVideos[i].match (/itag=(\d{1,3})/);
ytVideoCode = (ytVideoCodeParse) ? ytVideoCodeParse[1] : null;
if (ytVideoCode) {
myVideoCode = ytVideoFormats[ytVideoCode];
if (myVideoCode) {
ytVideo = ytVideos[i].replace (/url=/, '').replace(/&$/, '').replace(/&itag=\d{1,3}/, '');
if (ytVideo.match(/type=.*?&/)) ytVideo = ytVideo.replace(/type=.*?&/, '');
else ytVideo = ytVideo.replace(/&type=.*$/, '');
if (ytVideo.match(/&sig=/)) ytVideo = ytVideo.replace (/&sig=/, '&signature=');
else if (ytVideo.match(/&s=/)) {
var ytSig = ytVideo.match(/&s=(.*?)(&|$)/);
if (ytSig) {
var s = ytSig[1];
s = ytDecryptSignature(s);
if (s) ytVideo = ytVideo.replace(/&s=.*?(&|$)/, '&signature=' + s + '$1');
else ytVideo = '';
}
else ytVideo = '';
}
ytVideo = cleanMyContent (ytVideo, true);
if (ytVideo.indexOf('ratebypass') == -1) ytVideo += '&ratebypass=yes';
if (ytVideo && ytVideo.indexOf('http') == 0) {
if (!ytVideoFound) ytVideoFound = true;
ytVideoList[myVideoCode] = ytVideo;
}
}
}
}
if (ytVideoFound) {
option['autoget'] = true;
ytPlayer();
}
else {
if (ytVideosContent.indexOf('conn=rtmp') != -1) showMyMessage ('!support');
else showMyMessage ('!videos');
}
}
/* Parse HLS */
function ytHLS() {
var ytHLSFormats = {
'92': 'Very Low Definition MP4',
'93': 'Low Definition MP4',
'94': 'Standard Definition MP4',
'95': 'High Definition MP4'
};
ytVideoList["Any Definition MP4"] = ytHLSVideos;
if (ytHLSContent) {
var ytHLSVideo, ytVideoCodeParse, ytVideoCode, myVideoCode;
var ytHLSMatcher = new RegExp('(http.*?m3u8)', 'g');
ytHLSVideos = ytHLSContent.match(ytHLSMatcher);
if (ytHLSVideos) {
for (var i = 0; i < ytHLSVideos.length; i++) {
ytHLSVideo = ytHLSVideos[i];
ytVideoCodeParse = ytHLSVideo.match(/\/itag\/(\d{1,3})\//);
ytVideoCode = (ytVideoCodeParse) ? ytVideoCodeParse[1] : null;
if (ytVideoCode) {
myVideoCode = ytHLSFormats[ytVideoCode];
if (myVideoCode && ytHLSVideo) {
ytVideoList[myVideoCode] = ytHLSVideo;
}
}
}
}
}
ytVideoTitle = null;
ytDefaultVideo = 'Any Definition MP4';
ytPlayer();
}
/* Get Videos */
var ytVideoList = {};
if (ytVideosContent) {
if (ytVideosContent.match(/&s=/) || ytVideosContent.match(/,s=/)) {
var ytScriptURL = getMyContent(page.url, '"js":\\s*"(.*?)"', true);
if (ytScriptURL) {
ytScriptURL = page.win.location.protocol + ytScriptURL;
try {
ytScriptSrc = getMyContent(ytScriptURL, 'TEXT', false);
if (ytScriptSrc) ytDecryptFunction();
ytVideos();
}
catch (e) {
try {
GM_xmlhttpRequest({
method: 'GET',
url: ytScriptURL,
onload: function(response) {
if (response.readyState === 4 && response.status === 200) {
ytScriptSrc = response.responseText;
}
if (ytScriptSrc) ytDecryptFunction();
ytVideos();
}
});
}
catch (e) {
ytVideos();
}
}
}
else {
ytVideos();
}
}
else {
ytVideos();
}
}
else {
if (ytHLSVideos) {
try {
ytHLSContent = getMyContent(ytHLSVideos, 'TEXT', false);
ytHLS();
}
catch (e) {
try {
GM_xmlhttpRequest({
method: 'GET',
url: ytHLSVideos,
onload: function(response) {
if (response.readyState === 4 && response.status === 200) {
ytHLSContent = response.responseText;
}
ytHLS();
}
});
}
catch (e) {
ytHLS();
}
}
}
else {
showMyMessage ('!content');
}
}
}
}
// =====DailyMotion===== //
else if (page.url.indexOf('dailymotion.com/video') != -1) {
/* Get Player Window */
var dmPlayerWindow = getMyElement ('', 'div', 'id', 'player_main', -1, false);
if (!dmPlayerWindow) {
showMyMessage ('!player');
}
else {
/* Get Video Thumbnail */
var dmVideoThumb = getMyContent (page.url, 'meta\\s+property="og:image"\\s+content="(.*?)"', false);
/* Get Videos Content */
var dmEmbed = page.url.replace(/\/video\//, "/embed/video/");
dmVideosContent = getMyContent (dmEmbed, 'info\\s+=\\s+\\{(.*?)\\}', false);
/* My Player Window */
var myPlayerWindow = createMyElement ('div', '', '', '', '');
styleMyElement (myPlayerWindow, {position: 'relative', width: '620px', height: '379px', backgroundColor: '#FFFFFF'});
modifyMyElement (dmPlayerWindow, 'div', '', true);
styleMyElement (dmPlayerWindow, {height: '100%'});
appendMyElement (dmPlayerWindow, myPlayerWindow);
/* Get Videos */
if (dmVideosContent) {
var dmVideoFormats = {'stream_h264_hd1080_url': 'Full High Definition MP4', 'stream_h264_hd_url': 'High Definition MP4',
'stream_h264_hq_url': 'Standard Definition MP4', 'stream_h264_url': 'Low Definition MP4',
'stream_h264_ld_url': 'Very Low Definition MP4', 'stream_live_hls_url': "Standard Definition Live M3U8"};
var dmVideoList = {};
var dmVideoFound = false;
var dmVideoParser, dmVideoParse, myVideoCode, dmVideo;
for (var dmVideoCode in dmVideoFormats) {
dmVideoParser = '"' + dmVideoCode + '":"(.*?)"';
dmVideoParse = dmVideosContent.match (dmVideoParser);
dmVideo = (dmVideoParse) ? dmVideoParse[1] : null;
if (dmVideo) {
if (!dmVideoFound) dmVideoFound = true;
dmVideo = cleanMyContent(dmVideo, true);
myVideoCode = dmVideoFormats[dmVideoCode];
if (!dmVideoList[myVideoCode]) dmVideoList[myVideoCode] = dmVideo;
}
}
if (dmVideoFound) {
/* Get Watch Sidebar */
var dmSidebarWindow = getMyElement ('', 'div', 'id', 'right_content_box', -1, false);
/* Create Player */
var dmDefaultVideo = 'Low Definition MP4';
player = {
'playerSocket': dmPlayerWindow,
'playerWindow': myPlayerWindow,
'videoList': dmVideoList,
'videoPlay': dmDefaultVideo,
'videoThumb': dmVideoThumb,
'playerWidth': 620,
'playerHeight': 379,
'playerWideWidth': 940,
'playerWideHeight': 563,
'sidebarWindow': dmSidebarWindow,
'sidebarMarginNormal': (dmSidebarWindow && dmSidebarWindow.style.marginTop) ? -416 : 0,
'sidebarMarginWide': (dmSidebarWindow && dmSidebarWindow.style.marginTop) ? 10 : 570
};
feature['container'] = false;
option['definitions'] = ['Full High Definition', 'High Definition', 'Standard Definition', 'Low Definition', 'Very Low Definition'];
option['containers'] = ['MP4'];
createMyPlayer ();
/* Fix HTML5 video duplicate on click - by seezuoto */
var dmTopWrapper = getMyElement ('', 'div', 'id', 'topwrapper', -1, false);
if (dmTopWrapper) {
dmTopWrapper.addEventListener('click', function(e) {
if (e.target.id === 'vtVideo' || (e.target.tagName === 'DIV' && !e.target.innerHTML.match(/^\s*more\s*$/))) {
e.stopPropagation();
}
});
}
}
else {
showMyMessage ('!videos');
}
}
else {
showMyMessage ('!content');
}
}
}
// =====Vimeo===== //
else if (page.url.match(/vimeo.com($|\/$|\/\d|\/page:\d)/)) {
/* Get Player Window */
var viPlayerWindow = getMyElement ('', 'div', 'class', 'player_container', 0, false);
if (!viPlayerWindow) {
showMyMessage ('!player');
}
else {
/* Get Video Thumbnail */
var viVideoThumb = getMyContent (page.url, 'meta\\s+property="og:image"\\s+content="(.*?)"', false);
/* Get Content Source */
var viVideoSource = getMyContent (page.url, 'data-config-url="(.*?)"', false).replace(/&/g, '&');
/* Get Videos Content */
var viVideosContent;
if (viVideoSource) {
viVideosContent = getMyContent(viVideoSource, '"h264":\\{(.*?)\\}\\}', false);
if (!viVideosContent) viVideosContent = getMyContent(viVideoSource, '"vp6":\\{(.*?)\\}\\}', false);
}
/* My Player Window */
var myPlayerWindow = createMyElement ('div', '', '', '', '');
styleMyElement (myPlayerWindow, {position: 'relative', width: '960px', height: '564px', backgroundColor: '#F4F5F7'});
modifyMyElement (viPlayerWindow, 'div', '', true);
styleMyElement (viPlayerWindow, {height: '100%'});
appendMyElement (viPlayerWindow, myPlayerWindow);
/* Get Videos */
if (viVideosContent) {
var viVideoFormats = {'hd': 'High Definition MP4', 'sd': 'Low Definition MP4', 'mobile': 'Very Low Definition MP4'};
var viVideoList = {};
var viVideoFound = false;
var viPattern, viMatcher, viVideo, myVideoCode;
for (var viVideoCode in viVideoFormats) {
viPattern = '"' + viVideoCode + '":\\{.*?"url":"(.*?)"';
viMatcher = viVideosContent.match(viPattern);
viVideo = (viMatcher) ? viMatcher[1] : null;
if (viVideo) {
if (!viVideoFound) viVideoFound = true;
myVideoCode = viVideoFormats[viVideoCode];
viVideoList[myVideoCode] = viVideo;
}
}
if (viVideoFound) {
/* Create Player */
var viDefaultVideo = 'Low Definition MP4';
player = {
'playerSocket': viPlayerWindow,
'playerWindow': myPlayerWindow,
'videoList': viVideoList,
'videoPlay': viDefaultVideo,
'videoThumb': viVideoThumb,
'playerWidth': 960,
'playerHeight': 562
};
feature['container'] = false;
feature['widesize'] = false;
option['definitions'] = ['High Definition', 'Low Definition', 'Very Low Definition'];
option['containers'] = ['MP4'];
createMyPlayer ();
styleMyElement(player['playerContent'], {marginTop: '3px'});
}
else {
showMyMessage ('!videos');
}
}
else {
showMyMessage ('!content');
}
}
}
// =====MetaCafe===== //
else if (page.url.indexOf('metacafe.com/watch') != -1) {
/* Get Player Window */
var mcPlayerWindow = getMyElement ('', 'div', 'id', 'FlashWrap', -1, false);
if (!mcPlayerWindow) {
showMyMessage ('!player');
}
else {
/* Check Video Availability */
var mcVideoAvailable = getMyElement ('', 'div', 'id', 'FlashWrap', -1, true);
if (mcVideoAvailable.indexOf('This Video cannot be played on this device.') != -1) return;
/* Get Video Thumbnail */
var mcVideoThumb = getMyContent (page.url, 'meta\\s+property="og:image"\\s+content="(.*?)"', false);
/* Get Videos Content */
var mcVideosContent, mcVideoH5;
var mcFlashVideo = getMyElement (mcPlayerWindow, 'embed', 'tag', '', 0, false) || getMyElement (mcPlayerWindow, 'object', 'tag', '', 0, false);
if (mcFlashVideo) mcVideosContent = getMyContent (page.url, '"mediaData":"(.*?)"', false);
else mcVideoH5 = getMyContent (page.url, 'video\\s+src="(.*?)"', false);
/* My Player Window */
var myPlayerWindow = createMyElement ('div', '', '', '', '');
styleMyElement (myPlayerWindow, {position: 'relative', width: '640px', height: '382px', backgroundColor: '#F4F4F4', zIndex: 10});
modifyMyElement (mcPlayerWindow, 'div', '', true);
styleMyElement (mcPlayerWindow, {height: '100%'});
appendMyElement (mcPlayerWindow, myPlayerWindow);
/* Get Videos */
if (mcVideosContent || mcVideoH5) {
var mcVideoList = {};
var mcVideoFound = false;
if (mcVideosContent) {
mcVideosContent = cleanMyContent(mcVideosContent, true);
var mcVideoFormats = {'highDefinitionMP4': 'High Definition MP4', 'MP4': 'Low Definition MP4', 'flv': 'Low Definition FLV'};
var mcVideoParser, mcVideoParse, myVideoCode, mcVideoPath, mcVideoKey, mcVideo;
for (var mcVideoCode in mcVideoFormats) {
mcVideoParser = '"' + mcVideoCode + '":\\{.*?"mediaURL":"(.*?)","access":\\[\\{"key":"(.*?)","value":"(.*?)"\\}\\]\\}';
mcVideoParse = mcVideosContent.match (mcVideoParser);
mcVideoPath = (mcVideoParse) ? mcVideoParse[1] : null;
mcVideoKeyName = (mcVideoParse) ? mcVideoParse[2] : null;
mcVideoKeyValue = (mcVideoParse) ? mcVideoParse[3] : null;
if (mcVideoPath && mcVideoKeyName && mcVideoKeyValue) {
if (!mcVideoFound) mcVideoFound = true;
myVideoCode = mcVideoFormats[mcVideoCode];
mcVideo = mcVideoPath + '?' + mcVideoKeyName + '=' + mcVideoKeyValue;
mcVideoList[myVideoCode] = mcVideo;
}
}
}
else {
mcVideoList['Low Definition MP4'] = mcVideoH5;
mcVideoFound = true;
feature['definition'] = false;
feature['container'] = false;
}
if (mcVideoFound) {
/* Get Watch Sidebar */
var mcSidebarWindow = getMyElement ('', 'div', 'id', 'Sidebar', -1, false);
/* Create Player */
var mcDefaultVideo = (mcVideoList['Low Definition MP4']) ? 'Low Definition MP4' : 'Low Definition FLV';
player = {
'playerSocket': mcPlayerWindow,
'playerWindow': myPlayerWindow,
'videoList': mcVideoList,
'videoPlay': mcDefaultVideo,
'videoThumb': mcVideoThumb,
'playerWidth': 640,
'playerHeight': 382,
'playerWideWidth': 960,
'playerWideHeight': 562,
'sidebarWindow': mcSidebarWindow,
'sidebarMarginNormal': 0,
'sidebarMarginWide': 576
};
option['definitions'] = ['High Definition', 'Low Definition'];
option['containers'] = ['MP4', 'FLV', 'Any'];
createMyPlayer ();
}
else {
showMyMessage ('!videos');
}
}
else {
showMyMessage ('!content');
}
}
}
// =====Break===== //
else if (page.url.indexOf('break.com/video') != -1) {
/* Get Player Window */
var brPlayerWindow = getMyElement ('', 'div', 'id', 'video-player', -1, false);
if (!brPlayerWindow) {
showMyMessage ('!player');
}
else {
/* Get Video ID */
var brVideoID = page.url.match(/(\d+)$/);
brVideoID = (brVideoID) ? brVideoID[1] : null;
/* Get Videos Content */
var brSource = page.win.location.protocol + '//' + page.win.location.hostname + '/embed/' + brVideoID;
var brVideosContent = getMyContent (brSource, 'TEXT', false);
/* My Player Window */
var myPlayerWindow = createMyElement ('div', '', '', '', '');
styleMyElement (myPlayerWindow, {position: 'relative', width: '592px', height: '356px', backgroundColor: '#F4F4F4'});
modifyMyElement (brPlayerWindow, 'div', '', true);
styleMyElement (brPlayerWindow, {height: '100%', overflow: 'visible'});
appendMyElement (brPlayerWindow, myPlayerWindow);
/* Get Videos */
if (brVideosContent) {
var brVideoList = {};
var brVideoFormats = {};
var brVideoFound = false;
var brVideoPath, brVideoToken, brVideoThumb, brVideo, myVideoCode;
brVideoPath = brVideosContent.match (/"videoUri":\s"(.*?)"/);
brVideoPath = (brVideoPath) ? brVideoPath[1] : null;
if (brVideoPath) {
if (brVideoPath.match(/.wmv$/)) {
brVideoFormats = {'.flv': 'Low Definition FLV', '.mp4': 'Low Definition MP4'};
brVideoPath = brVideoPath.replace(/.wmv$/, '');
}
else if (brVideoPath.match(/.flv$/)) {
brVideoFormats = {'6.mp4': 'Very Low Definition MP4', '1.flv': 'Low Definition FLV', '1.mp4': 'Low Definition MP4', '2.mp4': 'Standard Definition MP4', '3.mp4': 'High Definition MP4'};
brVideoPath = brVideoPath.replace(/1.flv$/, '');
}
else if (brVideoPath.match(/kbps.mp4$/)) {
brVideoFormats = {'320_kbps.mp4': 'Very Low Definition MP4', '496_kbps.mp4': 'Low Definition MP4', '864_kbps.mp4': 'Standard Definition MP4', '2240_kbps.mp4': 'High Definition MP4'};
brVideoPath = brVideoPath.replace(/496_kbps.mp4$/, '');
}
else if (brVideoPath.match(/.mp4$/)) {
brVideoFormats = {'240.mp4': 'Very Low Definition MP4', '360.mp4': 'Low Definition MP4', '480.mp4': 'Standard Definition MP4', '720.mp4': 'High Definition MP4'};
brVideoPath = brVideoPath.replace(/360.mp4$/, '');
}
else brVideoPath = null;
}
brVideoToken = brVideosContent.match (/"AuthToken":\s"(.*?)"/);
brVideoToken = (brVideoToken) ? brVideoToken[1] : null;
brVideoThumb = brVideosContent.match (/"thumbUri":\s"(.*?)"/);
brVideoThumb = (brVideoThumb) ? brVideoThumb[1] : null;
if (brVideoPath && brVideoToken) {
for (var brVideoCode in brVideoFormats) {
if (brVideosContent.match(brVideoPath + brVideoCode) || brVideosContent.match(brVideoPath + '.wmv')) {
if (!brVideoFound) brVideoFound = true;
myVideoCode = brVideoFormats[brVideoCode];
brVideo = brVideoPath + brVideoCode + '?' + brVideoToken;
brVideoList[myVideoCode] = brVideo;
}
}
}
if (brVideoFound) {
/* Get Watch Sidebar */
var brSidebarWindow = getMyElement ('', 'aside', 'class', 'sidebar', 0, false);
/* Create Player */
var brDefaultVideo = 'Low Definition MP4';
var brWindowWidth = page.win.innerWidth || page.doc.documentElement.clientWidth;
var brPlayerWidth, brPlayerHeight;
if (brWindowWidth > 1400) {
brPlayerWidth = 832;
brPlayerHeight = 490;
}
else {
brPlayerWidth = 592;
brPlayerHeight = 356;
}
player = {
'playerSocket': brPlayerWindow,
'playerWindow': myPlayerWindow,
'videoList': brVideoList,
'videoPlay': brDefaultVideo,
'videoThumb': brVideoThumb,
'playerWidth': brPlayerWidth,
'playerHeight': brPlayerHeight,
'playerWideWidth': 910,
'playerWideHeight': 534,
'sidebarWindow': brSidebarWindow,
'sidebarMarginNormal': 10,
'sidebarMarginWide': 670
};
if (brWindowWidth > 1400) feature['widesize'] = false;
option['definitions'] = ['Very Low Definition', 'Low Definition', 'Standard Definition', 'High Definition'];
option['containers'] = ['MP4', 'FLV', 'Any'];
createMyPlayer ();
}
else {
var ytVideoId = brVideosContent.match (/"youtubeId":\s"(.*?)"/);
if (ytVideoId && ytVideoId[1]) {
var ytVideoLink = 'http://youtube.com/watch?v=' + ytVideoId[1];
showMyMessage ('embed', ytVideoLink);
}
else {
showMyMessage ('!videos');
}
}
}
else {
showMyMessage ('!content');
}
}
}
// =====FunnyOrDie===== //
else if (page.url.indexOf('funnyordie.com/videos') != -1) {
/* Get Player Window */
var fodPlayerWindow = getMyElement ('', 'div', 'id', 'player-container', -1, false);
if (!fodPlayerWindow) {
showMyMessage ('!player');
}
else {
/* Get Video Thumbnail */
var fodVideoThumb = getMyContent (page.url, 'meta\\s+property="og:image"\\s+content="(.*?)"', false);
if (fodVideoThumb) fodVideoThumb = fodVideoThumb.replace (/large/, 'fullsize');
/* Get Videos Content */
var fodVideosContent = getMyContent (page.url, '<video([\\s\\S]*?)video>', false);
/* My Player Window */
var myPlayerWindow = createMyElement ('div', '', '', '', '');
styleMyElement (myPlayerWindow, {position: 'relative', width: '970px', height: '570px', backgroundColor: '#F4F4F4', margin: '0px auto'});
modifyMyElement (fodPlayerWindow, 'div', '', true);
styleMyElement (fodPlayerWindow, {height: '100%', paddingBottom: '20px'});
appendMyElement (fodPlayerWindow, myPlayerWindow);
/* Get Videos */
if (fodVideosContent) {
var fodVideoFormats = {'v2500.mp4': 'High Definition MP4', 'v1800.mp4': 'Standard Definition MP4', 'v600.mp4': 'Low Definition MP4', 'v600.webm': 'Low Definition WebM', 'v110.mp4': 'Very Low Definition MP4'};
var fodVideoList = {};
var fodVideoFound = false;
var fodVideoPath, fodVideoCodes, fodVideo, myVideoCode;
fodVideoPath = fodVideosContent.match(/src="(.*?)v\d+.mp4"/);
fodVideoPath = (fodVideoPath) ? fodVideoPath[1] : null;
fodVideoCodes = fodVideosContent.match (/v,(.*?),\./);
fodVideoCodes = (fodVideoCodes) ? fodVideoCodes[1] : '';
if (fodVideoPath) {
if (fodVideoCodes) {
for (var fodVideoCode in fodVideoFormats) {
if (fodVideoCodes.indexOf(fodVideoCode.replace(/v/, '').replace(/\..*/, '')) != -1) {
if (!fodVideoFound) fodVideoFound = true;
fodVideo = fodVideoPath + fodVideoCode;
myVideoCode = fodVideoFormats[fodVideoCode];
fodVideoList[myVideoCode] = fodVideo;
}
}
}
else {
for (var fodVideoCode in fodVideoFormats) {
fodVideo = fodVideoPath + fodVideoCode;
if (fodVideosContent.match(fodVideo)) {
if (!fodVideoFound) fodVideoFound = true;
myVideoCode = fodVideoFormats[fodVideoCode];
fodVideoList[myVideoCode] = fodVideo;
}
}
}
}
if (fodVideoFound) {
/* Create Player */
fodDefaultVideo = 'Low Definition MP4';
player = {
'playerSocket': fodPlayerWindow,
'playerWindow': myPlayerWindow,
'videoList': fodVideoList,
'videoPlay': fodDefaultVideo,
'videoThumb': fodVideoThumb,
'playerWidth': 970,
'playerHeight': 570
};
feature['container'] = false;
feature['widesize'] = false;
option['definitions'] = ['High Definition', 'Low Definition'];
option['containers'] = ['MP4'];
createMyPlayer ();
styleMyElement(player['playerContent'], {marginTop: '7px'});
}
else {
showMyMessage ('!videos');
}
}
else {
showMyMessage ('!content');
}
}
}
// =====Videojug===== //
else if (page.url.indexOf('videojug.com/film') != -1) {
/* Get Player Window */
var vjPlayerWindow = getMyElement ('', 'div', 'id', 'player', -1, false);
if (!vjPlayerWindow) {
showMyMessage ('!player');
}
else {
/* Get Videos Content */
var vjVideosContent = getMyContent (page.url, 'new\\s+Player\\((.*?)\\)', true);
/* My Player Window */
var myPlayerWindow = createMyElement ('div', '', '', '', '');
styleMyElement (myPlayerWindow, {position: 'relative', width: '640px', height: '384px', backgroundColor: '#F4F4F4'});
modifyMyElement (vjPlayerWindow, 'div', '', true);
styleMyElement (vjPlayerWindow, {height: '100%', backgroundColor: '#FFFFFF'});
appendMyElement (vjPlayerWindow, myPlayerWindow);
/* Get Videos */
if (vjVideosContent) {
vjVideosContent = vjVideosContent.replace(/'/g, '').replace(/\s/g, '');
var vjVideosParts = vjVideosContent.split(',');
var vjVideoToken = vjVideosParts[3];
var vjVideoToken2 = vjVideoToken.substring(0,2);
var vjVideoTitle = vjVideosParts[7];
var vjVideoProtocol = page.win.location.protocol;
var vjVideoSource = vjVideoProtocol + '//' + page.win.location.hostname + '/views/film/playlist.aspx?id=' + vjVideoToken;
var vjVideoShapes = getMyContent(vjVideoSource, '<Shapes>(.*?)<\/Shapes>', false);
var vjVideoFormats = {'VJ480PENG.mp4': 'Standard Definition MP4', 'VJ360PENG.mp4': 'Low Definition MP4', 'PHOENG.mp4': 'Very Low Definition MP4', 'FW8ENG.flv': 'Low Definition FLV', 'FS8ENG.flv': 'Very Low Definition FLV'};
var vjVideoList = {};
var vjVideoFound = false;
var vjVideoPart, myVideoCode, vjVideo, vjVideoThumb, vjVideoCodePart, vjVideoPattern, vjVideoLocation;
if (vjVideoToken && vjVideoTitle && vjVideoShapes) {
vjVideoPart = vjVideoToken2 + '/' + vjVideoToken + '/' + vjVideoTitle;
for (var vjVideoCode in vjVideoFormats) {
if (vjVideoCode.indexOf('VJ') != -1) vjVideoCodePart = vjVideoCode.substring(0, 6);
else vjVideoCodePart = vjVideoCode.substring(0, 3);
vjVideoPattern = 'Code="' + vjVideoCodePart + '"\\s+Locations="(.*?),';
vjVideoLocation = vjVideoShapes.match(vjVideoPattern);
vjVideoLocation = (vjVideoLocation) ? vjVideoProtocol + '//' + vjVideoLocation[1] : null;
if (vjVideoLocation) {
if (!vjVideoFound) vjVideoFound = true;
vjVideo = vjVideoLocation + '/' + vjVideoPart + '__' + vjVideoCode;
myVideoCode = vjVideoFormats[vjVideoCode];
vjVideoList[myVideoCode] = vjVideo;
}
}
vjVideoThumb = 'http://content5.videojug.com/' + vjVideoPart + '.WidePlayer.jpg';
}
if (vjVideoFound) {
/* Get Watch Sidebar */
var vjSidebarWindow = getMyElement ('', 'aside', 'id', 'side-bar', -1, false);
/* Create Player */
var vjDefaultVideo = 'Low Definition MP4';
player = {
'playerSocket': vjPlayerWindow,
'playerWindow': myPlayerWindow,
'videoList': vjVideoList,
'videoPlay': vjDefaultVideo,
'videoThumb': vjVideoThumb,
'playerWidth': 640,
'playerHeight': 384,
'playerWideWidth': 954,
'playerWideHeight': 562,
'sidebarWindow': vjSidebarWindow,
'sidebarMarginNormal': 5,
'sidebarMarginWide': 580
};
option['definition'] = 'SD';
option['definitions'] = ['Standard Definition', 'Low Definition', 'Very Low Definition'];
option['containers'] = ['MP4', 'FLV', 'Any'];
createMyPlayer ();
}
else {
showMyMessage ('!videos');
}
}
else {
showMyMessage ('!content');
}
}
}
// =====Blip===== //
else if (page.url.indexOf('blip.tv') != -1) {
/* Get Page Type */
var blipPageType = getMyContent (page.url, 'meta\\s+property="og:type"\\s+content="(.*?)"', false);
if (!blipPageType || blipPageType != 'video.episode') return;
/* Get Player Window */
var blipPlayerWidth, blipPlayerHeight;
var blipPlayerWindow = getMyElement ('', 'div', 'class', 'EpisodePlayer', 0, false) || getMyElement ('', 'div', 'id', 'ErrorWrap', -1, false);
if (!blipPlayerWindow) {
blipPlayerWindow = getMyElement ('', 'div', 'id', 'PlayerEmbed', -1, false);
blipPlayerWidth = 596;
blipPlayerHeight = 334;
}
else {
blipPlayerWidth = 960;
blipPlayerHeight = 565;
}
if (!blipPlayerWindow) {
showMyMessage ('!player');
}
else {
/* Get Video Thumbnail */
var blipVideoThumb = getMyContent (page.url, 'meta\\s+property="og:image"\\s+content="(.*?)"', false);
/* Get Videos Content */
var blipVideosContent = getMyContent(page.url + '?skin=json', '"additionalMedia":\\[(.*?)\\]', false);
/* My Player Window */
var myPlayerWindow = createMyElement ('div', '', '', '', '');
styleMyElement (myPlayerWindow, {position: 'relative', width: blipPlayerWidth + 'px', height: blipPlayerHeight + 'px', backgroundColor: '#F4F4F4'});
modifyMyElement (blipPlayerWindow, 'div', '', true);
styleMyElement (blipPlayerWindow, {paddingTop: '0px'});
appendMyElement (blipPlayerWindow, myPlayerWindow);
/* Get Videos */
if (blipVideosContent) {
var blipVideoList = {};
var blipVideoFound = false;
var blipMimeTypes = {'video/x-m4v': 'M4V', 'video/quicktime': 'MOV', 'video/mp4': 'MP4', 'video/x-flv': 'FLV'};
var blipVideos = blipVideosContent.split(',{');
var blipVideoURL, blipVideoMime, blipVideoHeight, blipVideoRole, blipVideoDef, blipVideoCode;
var blipDefaultVideo = 'Low Definition MP4';
for (var blipV = 0; blipV < blipVideos.length; blipV++) {
blipVideoMime = blipVideos[blipV].match(/"primary_mime_type":"(.*?)"/);
blipVideoMime = (blipVideoMime) ? blipVideoMime[1] : null;
if (blipMimeTypes[blipVideoMime]) {
blipVideoURL = blipVideos[blipV].match(/"url":"(.*?)"/);
blipVideoURL = (blipVideoURL) ? blipVideoURL[1] : null;
blipVideoHeight = blipVideos[blipV].match(/"media_height":"(.*?)"/);
blipVideoHeight = (blipVideoHeight) ? blipVideoHeight[1] : null;
blipVideoRole = blipVideos[blipV].match(/"role":"(.*?)"/);
blipVideoRole = (blipVideoRole) ? blipVideoRole[1] : null;
if (blipVideoURL && blipVideoHeight && blipVideoRole) {
if (!blipVideoFound) blipVideoFound = true;
if (blipVideoHeight >= 200 && blipVideoHeight < 400) blipVideoDef = 'Low Definition';
else if (blipVideoHeight >= 400 && blipVideoHeight < 700) blipVideoDef = 'Standard Definition';
else if (blipVideoHeight >= 700) blipVideoDef = 'High Definition';
blipVideoCode = blipVideoDef + ' ' + blipMimeTypes[blipVideoMime];
blipVideoList[blipVideoCode] = blipVideoURL;
if (blipVideoRole == 'Source') blipDefaultVideo = blipVideoCode;
}
}
}
if (blipVideoFound) {
/* Create Player */
player = {'playerSocket': blipPlayerWindow, 'playerWindow': myPlayerWindow, 'videoList': blipVideoList, 'videoPlay': blipDefaultVideo, 'videoThumb': blipVideoThumb, 'playerWidth': blipPlayerWidth, 'playerHeight': blipPlayerHeight};
feature['widesize'] = false;
option['definitions'] = ['High Definition', 'Standard Definition', 'Low Definition'];
option['containers'] = ['MP4', 'M4V', 'MOV', 'FLV', 'Any'];
createMyPlayer ();
}
else {
showMyMessage ('!videos');
}
}
else {
showMyMessage ('!content');
}
}
}
// =====Veoh===== //
else if (page.url.indexOf('veoh.com/watch') != -1) {
/* Get Video Availability */
if (getMyElement ('', 'div', 'class', 'veoh-video-player-error', 0, false)) return;
/* Get Player Window */
var vePlayerWindow = getMyElement ('', 'div', 'id', 'videoPlayerContainer', -1, false);
if (!vePlayerWindow) {
showMyMessage ('!player');
}
else {
/* Get Videos Content */
var veVideosContent = getMyContent (page.url, '__watch.videoDetailsJSON = \'\\{(.*?)\\}', false);
veVideosContent = cleanMyContent (veVideosContent, true);
/* Get Video Thumbnail */
var veVideoThumbGet = veVideosContent.match (/"highResImage":"(.*?)"/);
var veVideoThumb = (veVideoThumbGet) ? veVideoThumbGet[1] : null;
/* My Player Window */
var myPlayerWindow = createMyElement ('div', '', '', '', '');
styleMyElement (myPlayerWindow, {position: 'relative', width: '640px', height: '382px', backgroundColor: '#F4F4F4'});
modifyMyElement (vePlayerWindow, 'div', '', true);
styleMyElement (vePlayerWindow, {height: '100%'});
appendMyElement (vePlayerWindow, myPlayerWindow);
/* Get Videos */
if (veVideosContent) {
var veVideoFormats = {'fullPreviewHashLowPath': 'Very Low Definition MP4', 'fullPreviewHashHighPath': 'Low Definition MP4'};
var veVideoList = {};
var veVideoFound = false;
var veVideoParser, veVideoParse, veVideo, myVideoCode;
for (var veVideoCode in veVideoFormats) {
veVideoParser = veVideoCode + '":"(.*?)"';
veVideoParse = veVideosContent.match (veVideoParser);
veVideo = (veVideoParse) ? veVideoParse[1] : null;
if (veVideo) {
if (!veVideoFound) veVideoFound = true;
myVideoCode = veVideoFormats[veVideoCode];
veVideoList[myVideoCode] = veVideo;
}
}
if (veVideoFound) {
/* Get Watch Sidebar */
var veSidebarWindow = getMyElement ('', 'div', 'id', 'videoToolsContainer', -1, false);
if (veSidebarWindow) styleMyElement(veSidebarWindow, {marginTop: '-380px'});
/* Create Player */
var veDefaultVideo = 'Low Definition MP4';
player = {
'playerSocket': vePlayerWindow,
'playerWindow': myPlayerWindow,
'videoList': veVideoList,
'videoPlay': veDefaultVideo,
'videoThumb': veVideoThumb,
'playerWidth': 640,
'playerHeight': 382,
'playerWideWidth': 970,
'playerWideHeight': 568,
'sidebarWindow': veSidebarWindow,
'sidebarMarginNormal': -380,
'sidebarMarginWide': 20
};
feature['container'] = false;
option['definition'] = 'LD';
option['definitions'] = ['Low Definition', 'Very Low Definition'];
option['containers'] = ['MP4'];
createMyPlayer ();
}
else {
var veVideoSource = getMyContent(page.url, '"videoContentSource":"(.*?)"', false);
if (veVideoSource == 'YouTube') var ytVideoId = getMyContent(page.url, '"videoId":"yapi-(.*?)"', false);
if (ytVideoId) {
var ytVideoLink = 'http://youtube.com/watch?v=' + ytVideoId;
showMyMessage ('embed', ytVideoLink);
}
else {
showMyMessage ('!videos');
}
}
}
else {
showMyMessage ('!content');
}
}
}
// =====Crackle===== //
else if (page.url.indexOf('crackle.com/') != -1) {
/* Get Page Type */
var crPageType = getMyContent (page.url, 'meta\\s+property="og:type"\\s+content="(.*?)"', false);
if (!crPageType || crPageType.indexOf('video') == -1) return;
/* Get Player Window */
var crPlayerWindow = getMyElement ('', 'div', 'id', 'main', -1, false);
if (!crPlayerWindow) {
showMyMessage ('!player');
}
else {
/* Get Video ID */
var crVideoID = getMyContent (page.url, 'StartPlayer\\s+\\((.*?),', false);
/* Get Videos Content */
var crVideoPath = getMyContent (page.url, 'images-us-am.crackle.com\/(.*?_)tnl', false);
if (!crVideoPath) {
var crVidWallCache = page.win.location.protocol + '//' + page.win.location.hostname + '/app/vidwallcache.aspx?flags=-1&fm=' + crVideoID + '&partner=20';
crVideoPath = getMyContent (crVidWallCache, '\\sp="(.*?)"', false);
}
/* My Player Window */
var myPlayerWindow = createMyElement ('div', '', '', '', '');
styleMyElement (myPlayerWindow, {position: 'relative', width: '970px', height: '570px', backgroundColor: '#F4F4F4'});
modifyMyElement (crPlayerWindow, 'div', '', true);
styleMyElement (crPlayerWindow, {width: '970px', height: '600px', backgroundColor: '#FFFFFF'});
appendMyElement (crPlayerWindow, myPlayerWindow);
/* Get Videos */
if (crVideoPath) {
var crVideoList = {};
var crVideoFormats = {'360p.mp4': 'Low Definition MP4', '480p.mp4': 'Standard Definition MP4'};
var crVideoThumb, crVideo, myVideoCode;
for (var crVideoCode in crVideoFormats) {
crVideo = 'http://media-us-am.crackle.com/' + crVideoPath + crVideoCode;
myVideoCode = crVideoFormats[crVideoCode];
crVideoList[myVideoCode] = crVideo;
}
crVideoThumb = 'http://images-us-am.crackle.com/' + crVideoPath + 'tnl.jpg';
/* Create Player */
var crDefaultVideo = 'Low Definition MP4';
player = {
'playerSocket': crPlayerWindow,
'playerWindow': myPlayerWindow,
'videoList': crVideoList,
'videoPlay': crDefaultVideo,
'videoThumb': crVideoThumb,
'playerWidth': 970,
'playerHeight': 570
};
feature['container'] = false;
feature['widesize'] = false;
option['definition'] = 'SD';
option['definitions'] = ['Standard Definition', 'Low Definition'];
option['containers'] = ['MP4'];
createMyPlayer ();
/* Fix Thumbnails */
var crThumbs = getMyElement('', 'div', 'class', 'thumbnail', -1, false);
for (var crT = 0; crT < crThumbs.length; crT++) {
if (crThumbs[crT].innerHTML.indexOf('watchPage.update') != -1) {
var crLink = crThumbs[crT].innerHTML.match(/,\s+\d+,\s+'(.*?)'/);
crLink = (crLink) ? crLink[1] : null;
var crImg = crThumbs[crT].innerHTML.match(/src="(.*?)"/);
crImg = (crImg) ? crImg[1] : null;
crThumbs[crT].innerHTML = '<img src="' + crImg + '" onclick="window.location.href=\'' + crLink + '\'" style="cursor:pointer">';
}
}
}
else {
showMyMessage ('!videos');
}
}
}
// =====Viki===== //
else if (page.url.indexOf('viki.com/videos') != -1) {
/* Get Player Window */
var vkPlayerWindow = getMyElement ('', 'div', 'id', 'viki-player', -1, false);
if (!vkPlayerWindow) {
showMyMessage ('!player');
}
else {
/* Get Video ID */
var vkVideoID = page.url.match(/videos\/(.*?)v/);
vkVideoID = (vkVideoID) ? vkVideoID[1] : null;
/* Get Videos Content */
var vkVideosContent;
if (vkVideoID) vkVideosContent = getMyContent (page.win.location.protocol + '//' + page.win.location.host + '/player5_fragment/' + vkVideoID + 'v.json', 'TEXT', false);
/* My Player Window */
var myPlayerWindow = createMyElement ('div', '', '', '', '');
styleMyElement (myPlayerWindow, {position: 'relative', width: '950px', height: '536px', backgroundColor: '#F4F4F4'});
modifyMyElement (vkPlayerWindow, 'div', '', true);
appendMyElement (vkPlayerWindow, myPlayerWindow);
/* Get Videos */
if (vkVideosContent) {
var vkVideoList = {};
var vkVideo = vkVideosContent.match(/"video_url":"(.*?)"/);
vkVideo = (vkVideo) ? vkVideo[1] : null;
var vkVideoThumb = vkVideosContent.match(/"image_url":"(.*?)"/);
vkVideoThumb = (vkVideoThumb) ? vkVideoThumb[1] : null;
/* Create Player */
if (vkVideo) {
var vkDefaultVideo = 'Low Definition MP4';
vkVideoList[vkDefaultVideo] = vkVideo
player = {
'playerSocket': vkPlayerWindow,
'playerWindow': myPlayerWindow,
'videoList': vkVideoList,
'videoPlay': vkDefaultVideo,
'videoThumb': vkVideoThumb,
'playerWidth': 950,
'playerHeight': 536
};
feature['definition'] = false;
feature['container'] = false;
feature['widesize'] = false;
option['definition'] = 'LD';
option['definitions'] = ['Low Definition'];
option['containers'] = ['MP4'];
createMyPlayer ();
}
else {
showMyMessage ('!videos');
}
}
else {
showMyMessage ('!content');
}
}
}
// =====IMDB===== //
else if (page.url.indexOf('imdb.com/video/') != -1) {
/* Get Player Window */
var imdbPlayerWindow = getMyElement ('', 'div', 'id', 'player-article', -1, false);
if (!imdbPlayerWindow) {
showMyMessage ('!player');
}
else {
/* My Player Window */
var myPlayerWindow = createMyElement ('div', '', '', '', '');
styleMyElement (myPlayerWindow, {position: 'relative', width: '670px', height: '398px', backgroundColor: '#F4F4F4'});
modifyMyElement (imdbPlayerWindow, 'div', '', true);
appendMyElement (imdbPlayerWindow, myPlayerWindow);
/* Get Videos Content */
var imdbVideoList = {};
var imdbVideoFormats = {'1': 'Low Definition MP4', '2': 'Standard Definition MP4', '3': 'High Definition MP4'};
var imdbVideoThumb, imdbDefaultVideo, imdbURL, imdbVideo, myVideoCode;
var imdbVideoFound = false;
var imdbVideoRTMP = false;
var imdbPageURL = page.url.replace(/\?.*$/, '').replace(/\/$/, '');
for (var imdbVideoCode in imdbVideoFormats) {
imdbURL = imdbPageURL + '/player?uff=' + imdbVideoCode;
imdbVideo = getMyContent (imdbURL, 'so.addVariable\\("file",\\s+"(.*?)"\\);', true);
if (!imdbVideoThumb) imdbVideoThumb = getMyContent (imdbURL, 'so.addVariable\\("image",\\s+"(.*?)"\\);', true);
if (imdbVideo) {
if (imdbVideo.indexOf('rtmp') != -1) {
if (!imdbVideoRTMP) imdbVideoRTMP = true;
}
else {
if (!imdbVideoFound) imdbVideoFound = true;
myVideoCode = imdbVideoFormats[imdbVideoCode];
imdbVideoList[myVideoCode] = imdbVideo;
if (!imdbDefaultVideo) imdbDefaultVideo = myVideoCode;
}
}
}
if (imdbVideoFound) {
/* Get Watch Sidebar */
var imdbSidebarWindow = getMyElement ('', 'div', 'id', 'sidebar', -1, false);
styleMyElement (imdbSidebarWindow, {marginTop: '-400px'});
/* Create Player */
player = {
'playerSocket': imdbPlayerWindow,
'playerWindow': myPlayerWindow,
'videoList': imdbVideoList,
'videoPlay': imdbDefaultVideo,
'videoThumb': imdbVideoThumb,
'playerWidth': 670,
'playerHeight': 398,
'playerWideWidth': 1010,
'playerWideHeight': 594,
'sidebarWindow': imdbSidebarWindow,
'sidebarMarginNormal': -400,
'sidebarMarginWide': 0
};
feature['container'] = false;
option['definitions'] = ['High Definition', 'Standard Definition', 'Low Definition'];
option['containers'] = ['MP4'];
createMyPlayer ();
}
else {
if (imdbVideoRTMP) showMyMessage ('!support');
else showMyMessage ('!videos');
}
}
}
// =====Facebook===== //
else if (page.url.indexOf('facebook.com/photo') != -1) {
/* Get Player Window */
var fbPlayerWindow = getMyElement ('', 'div', 'class', 'stageWrapper', 0, false);
if (!fbPlayerWindow) {
showMyMessage ('!player');
}
else {
/* Get Videos Content */
var fbVideosContent = getMyContent(page.url, '"params","(.*?)"', false);
var fbPattern = /\\u([\d\w]{4})/gi;
fbVideosContent = fbVideosContent.replace(fbPattern, function (match, group) {
return String.fromCharCode(parseInt(group, 16));
});
fbVideosContent = unescape(fbVideosContent);
/* My Player Window */
var myPlayerWindow = createMyElement ('div', '', '', '', '');
styleMyElement (myPlayerWindow, {position: 'relative', width: '720px', height: '428px', backgroundColor: '#F4F4F4'});
modifyMyElement (fbPlayerWindow, 'div', '', true);
appendMyElement (fbPlayerWindow, myPlayerWindow);
/* Get Videos */
if (fbVideosContent) {
var fbVideoList = {};
var fbVideoFormats = {'sd_src': 'Low Definition MP4', 'hd_src': 'High Definition MP4'};
var fbVideoFound = false;
var fbVideoPattern, fbVideo, myVideoCode, fbVideoThumb, fbDefaultVideo;
for (var fbVideoCode in fbVideoFormats) {
fbVideoPattern = '"' + fbVideoCode + '":"(.*?)"';
fbVideo = fbVideosContent.match(fbVideoPattern);
fbVideo = (fbVideo) ? fbVideo[1] : null;
if (fbVideo) {
fbVideo = cleanMyContent(fbVideo, false);
if (!fbVideoFound) fbVideoFound = true;
myVideoCode = fbVideoFormats[fbVideoCode];
if (fbVideo.indexOf('.flv') != -1) myVideoCode = myVideoCode.replace('MP4', 'FLV');
fbVideoList[myVideoCode] = fbVideo;
if (!fbDefaultVideo) fbDefaultVideo = myVideoCode;
}
fbVideoThumb = fbVideosContent.match(/"thumbnail_src":"(.*?)"/);
fbVideoThumb = (fbVideoThumb) ? fbVideoThumb[1] : null;
fbVideoThumb = cleanMyContent(fbVideoThumb, false);
}
if (fbVideoFound) {
/* Create Player */
player = {
'playerSocket': fbPlayerWindow,
'playerWindow': myPlayerWindow,
'videoList': fbVideoList,
'videoPlay': fbDefaultVideo,
'videoThumb': fbVideoThumb,
'playerWidth': 720,
'playerHeight': 428
};
feature['widesize'] = false;
option['definitions'] = ['High Definition', 'Low Definition'];
option['containers'] = ['MP4', 'FLV', 'Any'];
createMyPlayer ();
}
else {
showMyMessage ('!videos');
}
}
else {
showMyMessage ('!content');
}
}
}
// =====YahooScreen===== //
else if (page.url.indexOf('screen.yahoo.com') != -1) {
/* Get Player Window */
var ysPlayerWindow = getMyElement ('', 'div', 'class', 'video-container', 0, false);
if (!ysPlayerWindow) {
showMyMessage ('!player');
}
else {
/* Get Videos Content */
var ysVideosContent;
var ysVideoID = getMyContent (page.url, 'window.YVIDEO.prefetchedData\\s*=\\s*\\{"id":"(.*?)"};', false);
if (ysVideoID) {
var ysVideoQuery = 'SELECT * FROM yahoo.media.video.streams WHERE id="' + ysVideoID + '" AND format="mp4" AND protocol="http" AND plrs="sdwpWXbKKUIgNzVhXSce__" AND region="US";';
var ysVideoRequest = 'https://video.query.yahoo.com/v1/public/yql?q=' + ysVideoQuery + '&env=prod&format=json';
ysVideosContent = getMyContent(ysVideoRequest, '"streams":\\[(.*?)\\]', false);
ysVideoQuery = 'SELECT * FROM yahoo.media.video.streams WHERE id="' + ysVideoID + '" AND format="webm" AND protocol="http" AND plrs="sdwpWXbKKUIgNzVhXSce__" AND region="US";';
ysVideoRequest = 'https://video.query.yahoo.com/v1/public/yql?q=' + ysVideoQuery + '&env=prod&format=json';
ysVideosContent += ',' + getMyContent(ysVideoRequest, '"streams":\\[(.*?)\\]', false);
}
else {
ysVideosContent = getMyContent(page.url, '"streams":\\[(.*?)\\]', false);
}
/* Get Video Thumbnail */
var ysVideoThumb = getMyContent (page.url, 'meta\\s+property="og:image"\\s+content="(.*?)"', false);
/* My Player Window */
var myPlayerWindow = createMyElement ('div', '', '', '', '');
styleMyElement (myPlayerWindow, {position: 'relative', width: '920px', height: '540px', backgroundColor: '#F4F4F4', margin: '0px auto'});
modifyMyElement (ysPlayerWindow, 'div', '', true);
styleMyElement (ysPlayerWindow, {height: '100%', width: '1050px', backgroundColor: '#17151D'});
appendMyElement (ysPlayerWindow, myPlayerWindow);
/* Restyle */
var ysVideoMeta = getMyElement ('', 'div', 'class', 'video-meta', 0, false);
if (ysVideoMeta) styleMyElement (ysVideoMeta, {marginLeft: '100px'});
var ysStageAside = getMyElement ('', 'div', 'class', 'up-next-thumbstrip', 0, false);
if (ysStageAside) styleMyElement (ysStageAside, {width: '840px', marginTop: '20px'});
var ysStageAside2 = getMyElement ('', 'div', 'class', 'stage-aside', 0, false);
if (ysStageAside2) styleMyElement (ysStageAside2, {width: '840px', marginLeft: '100px', marginTop: '20px'});
/* Get Videos */
if (ysVideosContent) {
var ysVideoList = {};
var ysVideoFound = false;
var ysVideoFormats = {'360': 'Low Definition', '432': 'Low Definition', '540': 'Standard Definition', '720': 'High Definition', '1080': 'Full High Definition'};
var ysVideoParts = ysVideosContent.split('},');
var ysVideoPart, ysVideoPath, ysVideoHost, ysVideoHeight, ysVideoType, myVideoCode;
for (var i = 0; i < ysVideoParts.length; i++) {
ysVideoPart = ysVideoParts[i];
ysVideoPath = ysVideoPart.match(/"path":"(.*?)"/);
ysVideoPath = (ysVideoPath) ? ysVideoPath[1] : null;
ysVideoHost = ysVideoPart.match(/"host":"(.*?)"/);
ysVideoHost = (ysVideoHost) ? ysVideoHost[1] : null;
ysVideoHeight = ysVideoPart.match(/"height":(.*?)\.0/);
ysVideoHeight = (ysVideoHeight) ? ysVideoHeight[1] : null;
ysVideoType = ysVideoPart.match(/"mime_type":"(.*?)"/);
ysVideoType = (ysVideoType) ? ysVideoType[1] : null;
if (ysVideoPath && ysVideoHost && ysVideoHeight && ysVideoType) {
for (var ysVideoCode in ysVideoFormats) {
if (ysVideoCode == ysVideoHeight) {
if (!ysVideoFound) ysVideoFound = true;
myVideoCode = ysVideoFormats[ysVideoCode]
if (ysVideoType == 'video/mp4') myVideoCode += ' MP4';
else if (ysVideoType == 'video/webm') myVideoCode += ' WebM';
ysVideoList[myVideoCode] = ysVideoHost + ysVideoPath;
}
}
}
}
if (ysVideoFound) {
/* Create Player */
var ysDefaultVideo = 'Low Definition MP4';
player = {
'playerSocket': ysPlayerWindow,
'playerWindow': myPlayerWindow,
'videoList': ysVideoList,
'videoPlay': ysDefaultVideo,
'videoThumb': ysVideoThumb,
'playerWidth': 920,
'playerHeight': 540
};
feature['widesize'] = false;
option['definitions'] = ['Full High Definition', 'High Definition', 'Standard Definition', 'Low Definition', 'Very Low Definition'];
option['containers'] = ['MP4', 'WebM', 'Any'];
createMyPlayer ();
styleMyElement(player['playerContent'], {marginTop: '5px'});
}
else {
showMyMessage ('!videos');
}
}
else {
showMyMessage ('!content');
}
}
}
})();