Skip to content

Instantly share code, notes, and snippets.

@spcmd
Created March 7, 2017 13:50
Show Gist options
  • Save spcmd/ff92981228aa9c73b2d46ca15e5dae72 to your computer and use it in GitHub Desktop.
Save spcmd/ff92981228aa9c73b2d46ca15e5dae72 to your computer and use it in GitHub Desktop.
// ==UserScript==
// @name ViewTube
// @version 2017.02.20
// @description Watch videos from video sharing websites without Flash Player.
// @author sebaro
// @namespace http://isebaro.com/viewtube
// @license GPL version 3 or any later version; http://www.gnu.org/copyleft/gpl.html
// @downloadURL https://raw.githubusercontent.com/sebaro/viewtube/master/viewtube.user.js
// @updateURL https://raw.githubusercontent.com/sebaro/viewtube/master/viewtube.user.js
// @icon https://raw.githubusercontent.com/sebaro/viewtube/master/viewtube.png
// @include http://youtube.com*
// @include http://www.youtube.com*
// @include https://youtube.com*
// @include https://www.youtube.com*
// @include http://gaming.youtube.com*
// @include https://gaming.youtube.com*
// @include http://m.youtube.com*
// @include https://m.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://veoh.com*
// @include http://www.veoh.com*
// @include https://veoh.com*
// @include https://www.veoh.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*
// @grant GM_xmlhttpRequest
// @grant GM_setValue
// @grant GM_getValue
// ==/UserScript==
/*
Copyright (C) 2010 - 2017 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, title: document.title, site: window.location.hostname.match(/([^.]+)\.[^.]+$/)[1]};
// Player
var player = {};
var feature = {'autoplay': true, 'definition': true, 'container': true, 'dash': false, 'direct': false, 'widesize': false, 'fullsize': true};
var option = {'plugin': 'Auto', 'autoplay': false, 'autoget': false, 'definition': 'HD', 'container': 'MP4', 'dash': false, 'direct': false, 'widesize': false, 'fullsize': false};
var plugins = ['Auto', 'Alt', 'HTML5', 'VLC', 'MP4', 'MPEG', 'FLV', 'VTP'];
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(['MPV', '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',
'MPV': 'video/mp4',
'Totem': 'application/x-totem-plugin',
'Xine': 'application/x-xine-plugin'
};
var sources = {};
// 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.8;
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 + '" style="color:#00892C">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 + '" style="color:#00892C">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 + '" style="color:#00892C">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['buttonAutoplay'], {color: '#008080', textShadow: '0px 1px 1px #CCCCCC'});
if (!player['isPlaying']) playMyVideo(true);
}
else {
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 == 'dash') {
option['dash'] = (option['dash']) ? false : true;
if (option['dash']) {
styleMyElement(player['buttonDASH'], {color: '#008080', textShadow: '0px 1px 1px #CCCCCC'});
}
else {
styleMyElement(player['buttonDASH'], {color: '#CCCCCC', textShadow: '0px 0px 0px'});
}
setMyOptions('dash', option['dash']);
}
else if (action == 'direct') {
option['direct'] = (option['direct']) ? false : true;
if (option['direct']) {
styleMyElement(player['buttonDirect'], {color: '#008080', textShadow: '0px 1px 1px #CCCCCC'});
}
else {
styleMyElement(player['buttonDirect'], {color: '#CCCCCC', textShadow: '0px 0px 0px'});
}
setMyOptions('direct', option['direct']);
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'] = 28;
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;
/* GOMBOK */
/* Panel Logo */
/*
player['panelLogo'] = createMyElement('div', userscript + ': ', 'click', 'logo', '');
player['panelLogo'].title = '{ViewTube: click to visit the script web page}';
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');
player['videoMenu'].title = '{Videos: select the video format for playback}';
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'});
if (videoCode.indexOf('Video') != -1 || videoCode.indexOf('Audio') != -1) styleMyElement(player['videoItem'], {color: '#8F6B32'});
if (player['videoList'][videoCode] == 'DASH') styleMyElement(player['videoItem'], {color: '#CF4913'});
if (player['videoList'][videoCode] != 'DASH' || option['dash']) appendMyElement(player['videoMenu'], player['videoItem']);
else delete player['videoList'][videoCode];
if (videoCode == 'Direct Video Link') styleMyElement(player['videoItem'], {color: '#00C0C0'});
}
/* Panel Plugin Menu */
/*
player['pluginMenu'] = createMyElement('select', '', 'change', '', 'plugin');
player['pluginMenu'].title = '{Plugins: select the video plugin for playback}';
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 Autoplay Button */
if (feature['autoplay']) {
player['buttonAutoplay'] = createMyElement('div', 'Automatikus lejátszás', 'click', 'autoplay', '');
player['buttonAutoplay'].title = '{Autoplay: click to enable/disable auto playback on page load}';
styleMyElement(player['buttonAutoplay'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#CCCCCC', fontSize: '20px', cursor: 'pointer'});
if (option['autoplay']) styleMyElement(player['buttonAutoplay'], {color: '#008080', textShadow: '0px 1px 1px #CCCCCC'});
appendMyElement(player['playerPanel'], player['buttonAutoplay']);
}
/* Panel Get Button */
/*
player['buttonGet'] = createMyElement('div', 'Get', 'click', 'get', '');
player['buttonGet'].title = '{Get: click to download the selected video format}';
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 Definition Button */
/*
if (feature['definition']) {
player['buttonDefinition'] = createMyElement('div', option['definition'], 'click', 'definition', '');
player['buttonDefinition'].title = '{Definition: click to change the preferred video 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', '');
player['buttonContainer'].title = '{Container: click to change the preferred video 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 DASH Button */
/*
if (feature['dash']) {
player['buttonDASH'] = createMyElement('div', 'MD', 'click', 'dash', '');
player['buttonDASH'].title = '{MPEG-DASH: click to enable/disable DASH playback using the HTML5 video player (experimental)}';
styleMyElement(player['buttonDASH'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#CCCCCC', fontSize: '12px', cursor: 'pointer'});
if (option['dash']) styleMyElement(player['buttonDASH'], {color: '#008080', textShadow: '0px 1px 1px #CCCCCC'});
appendMyElement(player['playerPanel'], player['buttonDASH']);
}
*/
/* Panel Direct Button */
/*
if (feature['direct']) {
player['buttonDirect'] = createMyElement('div', 'DVL', 'click', 'direct', '');
player['buttonDirect'].title = '{DVL: click to enable/disable auto selection of Direct Video Link}';
styleMyElement(player['buttonDirect'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#CCCCCC', fontSize: '12px', cursor: 'pointer'});
if (option['direct']) styleMyElement(player['buttonDirect'], {color: '#008080', textShadow: '0px 1px 1px #CCCCCC'});
appendMyElement(player['playerPanel'], player['buttonDirect']);
}
*/
/* Panel Widesize Button */
if (feature['widesize']) {
if (option['widesize']) player['buttonWidesize'] = createMyElement('div', '&lt;', 'click', 'widesize', '');
else player['buttonWidesize'] = createMyElement('div', '&gt;', 'click', 'widesize', '');
player['buttonWidesize'].title = '{Widesize: click to enter player widesize or return to normal size}';
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 Play Button */
player['buttonPlay'] = createMyElement('div', 'Lejátszás', 'click', 'play', '');
player['buttonPlay'].title = '{Play/Stop: click to start/stop video playback}';
styleMyElement(player['buttonPlay'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#ffffff', background: 'green', fontSize: '20px', textShadow: '0px 1px 1px #CCCCCC', cursor: 'pointer'});
appendMyElement(player['playerPanel'], player['buttonPlay']);
/* Panel Fullsize Button */
if (feature['fullsize']) {
if (option['fullsize']) player['buttonFullsize'] = createMyElement('div', 'Kis képernyő', 'click', 'fullsize', '');
else player['buttonFullsize'] = createMyElement('div', 'Teljes képernyő', 'click', 'fullsize', '');
player['buttonFullsize'].title = '{Fullsize: click to enter player fullsize or return to normal size}';
styleMyElement(player['buttonFullsize'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#000000', background: 'orange', fontSize: '20px', 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', position: 'relative', color: '#AD0000', backgroundColor: '#000000', fontSize: '14px', fontWeight: 'bold', textAlign: 'center'});
appendMyElement(player['playerWindow'], player['playerContent']);
/* The Video Thumbnail */
if (player['videoThumb']) {
player['contentImage'] = createMyElement('img', player['videoThumb'], 'click', 'play', '');
player['contentImage'].title = '{Click to start video playback}';
styleMyElement(player['contentImage'], {maxWidth: '100%', maxHeight: '100%', position: 'absolute', top: '0px', left: '0px', right: '0px', bottom: '0px', margin: 'auto', border: '0px', cursor: 'pointer'});
player['contentImage'].addEventListener('load', function() {
if (this.width/this.height >= player['contentWidth']/player['contentHeight']) {
this.style.width = '100%';
}
else {
this.style.height = '100%';
}
});
}
/* Disabled Features */
if (!feature['autoplay']) option['autoplay'] = false;
if (!feature['dash']) option['dash'] = 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'];
}
if (option['direct']) player['videoPlay'] = 'Direct Video Link';
player['videoMenu'].value = player['videoPlay'];
}
function playDASHwithVLC() {
if (player['videoPlay'].indexOf('MP4') != -1) {
player['contentVideo'] = createMyElement('embed', player['videoList'][player['videoPlay'].replace(/MP4/, 'Video MP4')], '', '', '');
if (player['videoList']['Medium Bitrate Audio Opus']) {
player['contentAudio'] = createMyElement('embed', player['videoList']['Medium Bitrate Audio Opus'], '', '', '');
}
else {
player['contentAudio'] = createMyElement('embed', player['videoList']['Medium Bitrate Audio MP4'], '', '', '');
}
}
else {
player['contentVideo'] = createMyElement('embed', player['videoList'][player['videoPlay'].replace(/WebM/, 'Video WebM')], '', '', '');
if (player['videoList']['Medium Bitrate Audio Opus']) {
player['contentAudio'] = createMyElement('embed', player['videoList']['Medium Bitrate Audio Opus'], '', '', '');
}
else {
player['contentAudio'] = createMyElement('embed', player['videoList']['Medium Bitrate Audio WebM'], '', '', '');
}
}
styleMyElement(player['contentAudio'], {position: 'absolute', zIndex: '-1', width: '1px', height: '1px'});
appendMyElement(player['playerContent'], player['contentAudio']);
player['contentVLCInit'] = page.win.setInterval(function() {
if (player['contentAudio'].wrappedJSObject.playlist && player['contentVideo'].wrappedJSObject.playlist
&& player['contentAudio'].wrappedJSObject.input && player['contentVideo'].wrappedJSObject.input) {
player['contentVLCVideoPosition'] = 0;
player['contentVLCSync'] = page.win.setInterval(function() {
if (!player['contentVideo'] || !player['contentVideo'].wrappedJSObject || !player['contentVideo'].wrappedJSObject.input) {
page.win.clearInterval(player['contentVLCSync']);
}
if (player['contentVideo'].wrappedJSObject.input.time != player['contentVLCVideoPosition']) {
if (Math.abs(player['contentVideo'].wrappedJSObject.input.time - player['contentAudio'].wrappedJSObject.input.time) >= 500) {
player['contentAudio'].wrappedJSObject.input.time = player['contentVideo'].wrappedJSObject.input.time;
}
player['contentVLCVideoPosition'] = player['contentVideo'].wrappedJSObject.input.time;
}
if (player['contentVideo'].wrappedJSObject.input.state == '4') {
player['contentAudio'].wrappedJSObject.playlist.pause();
player['contentAudioPaused'] = true;
}
if (player['contentVideo'].wrappedJSObject.input.state == '6') {
player['contentAudio'].wrappedJSObject.playlist.pause();
player['contentAudioPaused'] = true;
}
if (player['contentVideo'].wrappedJSObject.input.state == '3' && player['contentAudioPaused']) {
player['contentAudio'].wrappedJSObject.playlist.play();
player['contentAudioPaused'] = false;
}
}, 1000);
page.win.clearInterval(player['contentVLCInit']);
}
}, 500);
}
function playDASHwithHTML5() {
var prevPlugin = option['plugin'];
option['plugin'] = 'HTML5';
if (player['videoPlay'].indexOf('MP4') != -1) {
player['contentVideo'] = createMyElement('video', player['videoList'][player['videoPlay'].replace(/MP4/, 'Video MP4')], '', '', '');
if (player['videoList']['High Bitrate Audio Opus']) {
player['contentAudio'] = createMyElement('video', player['videoList']['High Bitrate Audio Opus'], '', '', '');
}
else if (player['videoList']['Medium Bitrate Audio Opus']) {
player['contentAudio'] = createMyElement('video', player['videoList']['Medium Bitrate Audio Opus'], '', '', '');
}
else {
player['contentAudio'] = createMyElement('video', player['videoList']['Medium Bitrate Audio MP4'], '', '', '');
}
}
else {
player['contentVideo'] = createMyElement('video', player['videoList'][player['videoPlay'].replace(/WebM/, 'Video WebM')], '', '', '');
if (player['videoList']['High Bitrate Audio Opus']) {
player['contentAudio'] = createMyElement('video', player['videoList']['High Bitrate Audio Opus'], '', '', '');
}
else if (player['videoList']['Medium Bitrate Audio Opus']) {
player['contentAudio'] = createMyElement('video', player['videoList']['Medium Bitrate Audio Opus'], '', '', '');
}
else {
player['contentAudio'] = createMyElement('video', player['videoList']['Medium Bitrate Audio WebM'], '', '', '');
}
}
player['contentAudio'].pause();
player['contentVideo'].addEventListener('play', function() {
player['contentAudio'].play();
}, false);
player['contentVideo'].addEventListener('pause', function() {
player['contentAudio'].pause();
}, false);
player['contentVideo'].addEventListener('ended', function() {
player['contentVideo'].pause();
player['contentAudio'].pause();
}, false);
player['contentVideo'].addEventListener('timeupdate', function() {
if (player['contentAudio'].paused && !player['contentVideo'].paused) {
player['contentAudio'].play();
}
if (Math.abs(player['contentVideo'].currentTime - player['contentAudio'].currentTime) >= 0.30) {
player['contentAudio'].currentTime = player['contentVideo'].currentTime;
}
}, false);
styleMyElement(player['contentAudio'], {display: 'none'});
appendMyElement(player['contentVideo'], player['contentAudio']);
option['plugin'] = prevPlugin;
}
function playMyVideo(play) {
if (play) {
if (option['plugin'] == 'VTP') {
if (player['videoList'][player['videoPlay']] != 'DASH') {
page.win.location.href = 'viewtube:' + player['videoList'][player['videoPlay']];
}
return;
}
player['isPlaying'] = true;
modifyMyElement(player['buttonPlay'], 'div', 'Leállítás', false);
styleMyElement(player['buttonPlay'], {color: '#ffffff'});
modifyMyElement(player['playerContent'], 'div', '', true);
if (player['videoList'][player['videoPlay']] == 'DASH') {
if (option['plugin'] == 'VLC') {
playDASHwithVLC();
}
else {
playDASHwithHTML5();
}
}
else {
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'});
appendMyElement(player['playerContent'], player['contentVideo']);
}
else {
player['isPlaying'] = false;
modifyMyElement(player['buttonPlay'], 'div', 'Lejátszás', false);
styleMyElement(player['buttonPlay'], {color: '#ffffff'});
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 (vdoURL == 'DASH') return;
if (vdoURL == page.url) return;
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'] && player['videoPlay'] == 'High Definition MP4') 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']) {
if (player['buttonWidesize']) modifyMyElement(player['buttonWidesize'], 'div', '&lt;', false);
var playerWidth = player['playerWideWidth'];
var playerHeight= player['playerWideHeight'];
var sidebarMargin = player['sidebarMarginWide'];
}
else {
if (player['buttonWidesize']) modifyMyElement(player['buttonWidesize'], 'div', '&gt;', 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', 'Kis képernyő', false);
appendMyElement(page.body, player['playerWindow']);
styleMyElement(page.body, {overflow: 'hidden'});
styleMyElement(page.body.parentNode, {overflow: 'hidden'});
if (!player['resizeListener']) player['resizeListener'] = function() {resizeMyPlayer('fullsize')};
page.win.addEventListener('resize', player['resizeListener'], false);
player['isFullsize'] = true;
if (player['isPlaying']) {
if (player['contentVideo'] && player['contentVideo'].paused) player['contentVideo'].play();
}
}
}
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', 'Teljes képernyő', false);
appendMyElement(player['playerSocket'], player['playerWindow']);
styleMyElement(page.body, {overflow: 'auto'});
styleMyElement(page.body.parentNode, {overflow: 'auto'});
page.win.removeEventListener('resize', player['resizeListener'], false);
player['isFullsize'] = false;
if (player['isPlaying']) {
if (player['contentVideo'] && player['contentVideo'].paused) player['contentVideo'].play();
}
}
}
/* Resize The Player */
if (size == 'widesize') {
if (player['sidebarWindow']) 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['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 (!sources[url]) sources[url] = {};
if (getMethod == 'DOM') {
if (!sources[url]['DOM']) {
sources[url]['DOM'] = getMyElement('', 'html', 'tag', '', 0, true);
if (!sources[url]['DOM']) sources[url]['DOM'] = getMyElement('', 'body', '', '', -1, true);
}
myPageContent = sources[url]['DOM'];
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') {
if (!sources[url]['XHR']) sources[url]['XHR'] = {};
if ((pattern == 'XML' && !sources[url]['XHR']['XML']) || (pattern != 'XML' && !sources[url]['XHR']['TEXT'])) {
var xmlHTTP = new XMLHttpRequest();
xmlHTTP.open('GET', url, false);
xmlHTTP.send();
if (pattern == 'XML') sources[url]['XHR']['XML'] = xmlHTTP.responseXML;
else sources[url]['XHR']['TEXT'] = xmlHTTP.responseText;
}
if (pattern == 'XML') {
myVideosContent = sources[url]['XHR']['XML'];
}
else if (pattern == 'TEXT') {
myVideosContent = sources[url]['XHR']['TEXT'];
}
else {
myPageContent = sources[url]['XHR']['TEXT'];
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['dash'] = (option['dash'] === true || option['dash'] == 'true') ? true : false;
option['direct'] = (option['direct'] === true || option['direct'] == '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);
}
else if (cause == 'other') {
modifyMyElement(myScriptMess, 'div', content, false);
}
appendMyElement(myPlayerWindow, myScriptMess);
}
}
// ==========Websites========== //
// Fixes
var blockObject = page.doc;
var blockInterval = 50;
function blockVideos() {
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) {
if (!elVideo.paused) {
elVideo.pause();
if (page.url.indexOf('youtube.com/watch') == -1) elVideo.src = "#";
}
}
}
}
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);
}
}
}
if (blockObject !== page.doc) {
var elFrames = getMyElement(blockObject, 'iframe', 'tag', '', -1, false);
if (elFrames.length > 0) {
for (var e = 0; e < elFrames.length; e++) {
var elFrame = elFrames[e];
if (elFrame && elFrame.parentNode) {
removeMyElement(elFrame.parentNode, elFrame);
}
}
}
}
}
blockVideos();
page.win.setInterval(function() {
// Force page reload on title and location change
if (page.title != page.doc.title && page.url != page.win.location.href) {
if (player['playerSocket']) styleMyElement(player['playerSocket'], {display: 'none'});
page.title = page.doc.title;
page.url = page.win.location.href;
page.win.location.reload();
}
// Block videos
if (blockObject && blockInterval > 0) {
blockVideos();
if (blockInterval > 0) blockInterval--;
}
}, 500);
// =====YouTube===== //
if (page.url.indexOf('youtube.com/watch') != -1) {
/* Redirect Categories */
if (page.url.indexOf('gaming.youtube.com') != -1) {
page.win.location.href = page.url.replace('gaming', 'www');
}
/* Video Availability */
var ytVideoUnavailable = getMyElement('', 'div', 'id', 'player-unavailable', -1, false);
if (ytVideoUnavailable) {
if (ytVideoUnavailable.className.indexOf('hid') == -1) {
var ytAgeGateContent = getMyElement('', 'div', 'id', 'watch7-player-age-gate-content', -1, true);
if (!ytAgeGateContent) return;
else {
if(ytAgeGateContent.indexOf('feature=private_video') != -1) return;
}
}
}
/* Decrypt Signature */
var ytScriptSrc;
function ytDecryptSignature(s) {return null;}
function ytDecryptFunction() {
var ytSignFuncName, ytSignFuncBody, ytSwapFuncName, ytSwapFuncBody, ytFuncMatch;
ytScriptSrc = ytScriptSrc.replace(/(\r\n|\n|\r)/gm, '');
ytSignFuncName = ytScriptSrc.match(/"signature"\s*,\s*(.*?)\(/);
ytSignFuncName = (ytSignFuncName) ? ytSignFuncName[1] : null;
if (ytSignFuncName) {
ytFuncMatch = ytSignFuncName.replace(/\$/, '\\$') + '\\s*=\\s*function\\s*' + '\\s*\\(\\w+\\)\\s*\\{(.*?)\\}';
ytSignFuncBody = ytScriptSrc.match(ytFuncMatch);
ytSignFuncBody = (ytSignFuncBody) ? ytSignFuncBody[1] : null;
if (ytSignFuncBody) {
ytSwapFuncName = ytSignFuncBody.match(/((\$|_|\w)+)\.(\$|_|\w)+\(\w,[0-9]+\)/);
ytSwapFuncName = (ytSwapFuncName) ? ytSwapFuncName[1] : null;
if (ytSwapFuncName) {
ytFuncMatch = 'var\\s+' + ytSwapFuncName.replace(/\$/, '\\$') + '=\\s*\\{(.*?)\\};';
ytSwapFuncBody = ytScriptSrc.match(ytFuncMatch);
ytSwapFuncBody = (ytSwapFuncBody) ? ytSwapFuncBody[1] : null;
}
if (ytSwapFuncBody) ytSignFuncBody = 'var ' + ytSwapFuncName + '={' + ytSwapFuncBody + '};' + ytSignFuncBody;
ytSignFuncBody = 'try {' + ytSignFuncBody + '} catch(e) {return null}';
ytDecryptSignature = new Function('a', ytSignFuncBody);
}
}
}
/* Player Size */
var ytSidebarMarginNormal = 382;
var ytSidebarWindow = getMyElement('', 'div', 'id', 'watch7-sidebar', -1, false);
if (ytSidebarWindow) {
var ytSidebarWindowStyle = ytSidebarWindow.currentStyle || window.getComputedStyle(ytSidebarWindow);
if (ytSidebarWindowStyle) ytSidebarMarginNormal = -12 + parseInt(ytSidebarWindowStyle.marginTop.replace('px', ''));
styleMyElement(ytSidebarWindow, {marginTop: ytSidebarMarginNormal + 'px'});
}
var ytPlayerWidth, ytPlayerHeight;
var ytPlayerWideWidth, ytPlayerWideHeight;
var ytSidebarMarginWide;
var ytScreenWidth, ytScreenHeight;
function ytSizes() {
ytScreenWidth = page.win.innerWidth || page.doc.documentElement.clientWidth;
ytScreenHeight = page.win.innerHeight || page.doc.documentElement.clientHeight;
if (ytScreenWidth >= 1720 && ytScreenHeight >= 980) {
ytPlayerWidth = 1280;
ytPlayerHeight = 742;
ytPlayerWideWidth = 1706;
ytPlayerWideHeight = 982;
}
else if (ytScreenWidth >= 1294 && ytScreenHeight >= 630) {
ytPlayerWidth = 854;
ytPlayerHeight = 502;
ytPlayerWideWidth = 1280;
ytPlayerWideHeight = 742;
}
else {
ytPlayerWidth = 640;
ytPlayerHeight = 382;
ytPlayerWideWidth = 1066;
ytPlayerWideHeight = 622;
}
ytSidebarMarginWide = ytPlayerHeight + ytSidebarMarginNormal;
}
/* Get Player Window */
var ytPlayerWindow = getMyElement('', 'div', 'id', 'player', -1, false);
if (!ytPlayerWindow) {
showMyMessage('!player');
}
else {
/* Get Video Thumbnail */
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 = 'https://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(/&quot;/g, '\'').replace(/&#34;/g, '\'').replace(/"/g, '\'');
ytVideoTitle = ytVideoTitle.replace(/&#39;/g, '\'').replace(/'/g, '\'');
ytVideoTitle = ytVideoTitle.replace(/&amp;/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 ytVideosEncodedFmts, ytVideosAdaptiveFmts, ytVideosContent, ytHLSVideos, ytHLSContent;
ytVideosEncodedFmts = getMyContent(page.url, '"url_encoded_fmt_stream_map":\\s*"(.*?)"', false);
if (!ytVideosEncodedFmts) ytVideosEncodedFmts = getMyContent(page.url, '\\\\"url_encoded_fmt_stream_map\\\\":\\s*\\\\"(.*?)\\\\"', false);
ytVideosAdaptiveFmts = getMyContent(page.url, '"adaptive_fmts":\\s*"(.*?)"', false);
if (!ytVideosAdaptiveFmts) ytVideosAdaptiveFmts = getMyContent(page.url, '\\\\"adaptive_fmts\\\\":\\s*\\\\"(.*?)\\\\"', false);
if (ytVideosEncodedFmts) {
ytVideosContent = ytVideosEncodedFmts;
}
else {
ytHLSVideos = getMyContent(page.url, '"hlsvp":\\s*"(.*?)"', false);
if (!ytHLSVideos) ytHLSVideos = getMyContent(page.url, '\\\\"hlsvp\\\\":\\s*\\\\"(.*?)\\\\"', false);
if (ytHLSVideos) {
ytHLSVideos = cleanMyContent(ytHLSVideos, false);
}
else {
var ytVideoID = page.url.match(/(\?|&)v=(.*?)(&|$)/);
ytVideoID = (ytVideoID) ? ytVideoID[2] : null;
if (ytVideoID) {
var ytVideoSts = getMyContent(page.url.replace(/watch.*?v=/, 'embed/').replace(/&.*$/, ''), '"sts"\\s*:\\s*(\\d+)', false);
var ytVideosInfoURL = page.win.location.protocol + '//' + page.win.location.hostname + '/get_video_info?video_id=' + ytVideoID + '&eurl=https://youtube.googleapis.com/v/' + ytVideoID + '&sts=' + ytVideoSts;
var ytVideosInfo = getMyContent(ytVideosInfoURL, 'TEXT', false);
if (ytVideosInfo) {
ytVideosEncodedFmts = ytVideosInfo.match(/url_encoded_fmt_stream_map=(.*?)&/);
ytVideosEncodedFmts = (ytVideosEncodedFmts) ? ytVideosEncodedFmts[1] : null;
if (ytVideosEncodedFmts) {
ytVideosEncodedFmts = cleanMyContent(ytVideosEncodedFmts, true);
ytVideosContent = ytVideosEncodedFmts;
}
if (!ytVideosAdaptiveFmts) {
ytVideosAdaptiveFmts = ytVideosInfo.match(/adaptive_fmts=(.*?)&/);
ytVideosAdaptiveFmts = (ytVideosAdaptiveFmts) ? ytVideosAdaptiveFmts[1] : null;
if (ytVideosAdaptiveFmts) ytVideosAdaptiveFmts = cleanMyContent(ytVideosAdaptiveFmts, true);
}
}
}
}
}
if (ytVideosAdaptiveFmts && !ytHLSVideos) {
if (ytVideosContent) ytVideosContent += ',' + ytVideosAdaptiveFmts;
else ytVideosContent = ytVideosAdaptiveFmts;
}
/* Get Sizes */
ytSizes();
/* Hide Player Window */
var ytPlaceholderPlayer = getMyElement('', 'div', 'id', 'placeholder-player', -1, false);
if (ytPlaceholderPlayer) styleMyElement(ytPlaceholderPlayer, {display: 'none'});
/* Hide Sidebar Ads */
var ytSidebarAds = getMyElement('', 'div', 'id', 'watch7-sidebar-ads', -1, false);
if (ytSidebarAds) styleMyElement(ytSidebarAds, {display: 'none'});
/* Hide Autoplay */
var ytAutoplay = getMyElement('', 'div', 'class', 'checkbox-on-off', 0, false);
if (ytAutoplay) styleMyElement(ytAutoplay, {display: 'none'});
/* Playlist */
var ytPlaylist = getMyElement('', 'div', 'id', 'player-playlist', -1, false);
if (ytPlaylist) {
styleMyElement(ytPlaylist, {marginLeft: '-' + ytPlayerWidth + 'px'});
var ytPlaceholderPlaylist = getMyElement('', 'div', 'id', 'placeholder-playlist', -1, false);
if (ytPlaceholderPlaylist) appendMyElement(ytPlaceholderPlaylist, ytPlaylist);
}
/* My Player Window */
var myPlayerWindow = createMyElement('div', '', '', '', '');
styleMyElement(myPlayerWindow, {position: 'relative', width: ytPlayerWidth + 'px', height: ytPlayerHeight + 'px', backgroundColor: '#FFFFFF'});
modifyMyElement(ytPlayerWindow, 'div', '', false, true);
appendMyElement(ytPlayerWindow, myPlayerWindow);
blockObject = ytPlayerWindow;
/* Update Sizes */
page.win.addEventListener('resize', function() {
ytSizes();
player['playerWidth'] = ytPlayerWidth;
player['playerHeight'] = ytPlayerHeight;
player['playerWideWidth'] = ytPlayerWideWidth;
player['playerWideHeight'] = ytPlayerWideHeight;
player['sidebarMarginWide'] = ytSidebarMarginWide;
resizeMyPlayer('widesize');
if (ytPlaylist) styleMyElement(ytPlaylist, {marginLeft: '-' + ytPlayerWidth + 'px'});
}, false);
/* 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': ytSidebarMarginNormal,
'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',
'249': 'Low Bitrate Audio Opus',
'250': 'Medium Bitrate Audio Opus',
'251': 'High Bitrate Audio Opus',
'266': 'Ultra High Definition Video MP4',
'272': 'Ultra High Definition Video WebM',
'298': 'High Definition Video MP4',
'299': 'Full High Definition Video MP4',
'302': 'High Definition Video WebM',
'303': 'Full High Definition Video WebM',
'313': 'Ultra 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 = cleanMyContent(ytVideos[i], true);
ytVideo = ytVideo.replace(/url=/, '').replace(/&$/, '');
if (ytVideo.match(/itag=/) && ytVideo.match(/itag=/g).length > 1) {
if (ytVideo.match(/itag=\d{1,3}&/)) ytVideo = ytVideo.replace(/itag=\d{1,3}&/, '');
else if (ytVideo.match(/&itag=\d{1,3}/)) ytVideo = ytVideo.replace(/&itag=\d{1,3}/, '');
}
if (ytVideo.match(/clen=/) && ytVideo.match(/clen=/g).length > 1) {
if (ytVideo.match(/clen=\d+&/)) ytVideo = ytVideo.replace(/clen=\d+&/, '');
else if (ytVideo.match(/&clen=\d+/)) ytVideo = ytVideo.replace(/&clen=\d+/, '');
}
if (ytVideo.match(/lmt=/) && ytVideo.match(/lmt=/g).length > 1) {
if (ytVideo.match(/lmt=\d+&/)) ytVideo = ytVideo.replace(/lmt=\d+&/, '');
else if (ytVideo.match(/&lmt=\d+/)) ytVideo = ytVideo.replace(/&lmt=\d+/, '');
}
if (ytVideo.match(/type=(video|audio).*?&/)) ytVideo = ytVideo.replace(/type=(video|audio).*?&/, '');
else ytVideo = ytVideo.replace(/&type=(video|audio).*$/, '');
if (ytVideo.match(/xtags=[^%=]*&/)) ytVideo = ytVideo.replace(/xtags=[^%=]*?&/, '');
else if (ytVideo.match(/&xtags=[^%=]*$/)) ytVideo = ytVideo.replace(/&xtags=[^%=]*$/, '');
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) {
/* DASH */
if (!ytVideoList['Standard Definition MP4'] && ytVideoList['Standard Definition Video MP4']) ytVideoList['Standard Definition MP4'] = 'DASH';
if (!ytVideoList['High Definition MP4'] && ytVideoList['High Definition Video MP4']) ytVideoList['High Definition MP4'] = 'DASH';
if (!ytVideoList['Full High Definition MP4'] && ytVideoList['Full High Definition Video MP4']) ytVideoList['Full High Definition MP4'] = 'DASH';
if (!ytVideoList['Ultra High Definition MP4'] && ytVideoList['Ultra High Definition Video MP4']) ytVideoList['Ultra High Definition MP4'] = 'DASH';
if (!ytVideoList['Standard Definition WebM'] && ytVideoList['Standard Definition Video WebM']) ytVideoList['Standard Definition WebM'] = 'DASH';
if (!ytVideoList['High Definition WebM'] && ytVideoList['High Definition Video WebM']) ytVideoList['High Definition WebM'] = 'DASH';
if (!ytVideoList['Full High Definition WebM'] && ytVideoList['Full High Definition Video WebM']) ytVideoList['Full High Definition WebM'] = 'DASH';
if (!ytVideoList['Ultra High Definition WebM'] && ytVideoList['Ultra High Definition Video WebM']) ytVideoList['Ultra High Definition WebM'] = 'DASH';
feature['dash'] = true;
/* DVL */
ytVideoList['Direct Video Link'] = page.url;
feature['direct'] = true;
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',
'96': 'Full 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;
}
}
}
}
}
/* DVL */
ytVideoList['Direct Video Link'] = page.url;
feature['direct'] = true;
ytVideoTitle = null;
ytDefaultVideo = 'Any Definition MP4';
ytPlayer();
}
/* Get Videos */
var ytVideoList = {};
if (ytVideosContent) {
if (ytVideosContent.match(/&s=/) || ytVideosContent.match(/,s=/) || ytVideosContent.match(/u0026s=/)) {
var ytScriptURL = getMyContent(page.url, '"js":\\s*"(.*?)"', true);
if (!ytScriptURL) ytScriptURL = getMyContent(page.url.replace(/watch.*?v=/, 'embed/').replace(/&.*$/, ''), '"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 && response.responseText) {
ytScriptSrc = response.responseText;
ytDecryptFunction();
ytVideos();
}
else {
showMyMessage('other', 'Couldn\'t get the signature content. Please report it <a href="' + contact + '" style="color:#00892C">here</a>.');
}
},
onerror: function() {
showMyMessage('other', 'Couldn\'t make the request. Make sure your browser user scripts extension supports cross-domain requests.');
}
});
}
catch(e) {
showMyMessage('other', 'Couldn\'t make the request. Make sure your browser user scripts extension supports cross-domain requests.');
}
}
}
else {
showMyMessage('other', 'Couldn\'t get the signature link. Please report it <a href="' + contact + '" style="color:#00892C">here</a>.');
}
}
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 && response.responseText) {
ytHLSContent = response.responseText;
}
ytHLS();
},
onerror: function() {
ytHLS();
}
});
}
catch(e) {
ytHLS();
}
}
}
else {
showMyMessage('!content');
}
}
}
}
// =====DailyMotion===== //
else if (page.url.indexOf('dailymotion.com/video') != -1) {
/* Get Player Window */
var dmPlayerWindow = getMyElement('', 'div', 'class', 'player-container', 0, 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 dmVideosContent = getMyContent(page.url, '"qualities":\\{(.*?)\\]\\},', false);
if (!dmVideosContent) dmVideosContent = getMyContent(page.url.replace(/\/video\//, "/embed/video/"), '"qualities":\\{(.*?)\\]\\},', false);
/* Player Size */
var dmSidebarWidth = 320;
var dmSidebarWindow = getMyElement('', 'div', 'class', 'sidebar', 0, false);
var dmSidebarWindowStyle = (dmSidebarWindow) ? dmSidebarWindow.currentStyle || window.getComputedStyle(dmSidebarWindow) : null;
var dmPlayerWidth, dmPlayerHeight;
var dmPlayerWideWidth, dmPlayerWideHeight;
var dmSidebarMarginWide;
function dmGetSizes() {
dmPlayerWidth = dmPlayerWindow.clientWidth;
dmPlayerHeight = Math.ceil(dmPlayerWidth / (16 / 9)) + 22;
if (dmSidebarWindow && dmSidebarWindowStyle) dmSidebarWidth = parseInt(dmSidebarWindowStyle.width);
dmPlayerWideWidth = dmPlayerWidth + dmSidebarWidth;
dmPlayerWideHeight = Math.ceil(dmPlayerWideWidth / (16 / 9)) + 22;
dmSidebarMarginWide = dmPlayerWideHeight + 30;
}
function dmUpdateSizes() {
dmGetSizes();
player['playerWidth'] = dmPlayerWidth;
player['playerHeight'] = dmPlayerHeight;
player['playerWideWidth'] = dmPlayerWideWidth;
player['playerWideHeight'] = dmPlayerWideHeight;
player['sidebarMarginWide'] = dmSidebarMarginWide;
resizeMyPlayer('widesize');
styleMyElement(dmPlayerWindow.parentNode, {minHeight: player['contentHeight'] + 50 + 'px'});
}
dmGetSizes();
/* My Player Window */
var myPlayerWindow = createMyElement('div', '', '', '', '');
styleMyElement(myPlayerWindow, {position: 'relative', width: dmPlayerWidth + 'px', height: dmPlayerHeight + 'px', backgroundColor: '#FFFFFF'});
modifyMyElement(dmPlayerWindow, 'div', '', false, true);
appendMyElement(dmPlayerWindow, myPlayerWindow);
blockObject = dmPlayerWindow;
/* Fix Info Position On Start */
page.win.setTimeout(function() {
var dmInfoboxHeight = (player['contentHeight']) ? player['contentHeight'] + 50 + 'px' : '100%';
styleMyElement(dmPlayerWindow.parentNode, {minHeight: dmInfoboxHeight});
}, 2000);
/* Fix Right Ad Issue */
var dmMcRight = getMyElement('', 'div', 'id', 'mc_Right', -1, false);
if (dmMcRight) {
var dmWaitForAdTime = 20;
var dmPlayerWidthPrev = dmPlayerWidth;
var dmWaitForAdFunc = page.win.setInterval(function() {
if(dmMcRight.clientWidth) {
dmUpdateSizes();
if (dmPlayerWidth != dmPlayerWidthPrev) clearInterval(dmWaitForAdFunc);
}
dmWaitForAdTime--;
if (dmWaitForAdTime == 0) clearInterval(dmWaitForAdFunc);
}, 500);
}
/* Resize Event */
page.win.addEventListener('resize', dmUpdateSizes, false);
/* Hide Top Ads */
var dmMcTop = getMyElement('', 'div', 'id', 'mc_Top', -1, false);
if (dmMcTop) styleMyElement(dmMcTop, {display: 'none'});
/* Get Videos */
if (dmVideosContent) {
var dmVideoFormats = {'auto': 'Low Definition MP4', '240': 'Very Low Definition MP4', '380': 'Low Definition MP4', '480': 'Standard Definition MP4',
'720': 'High Definition MP4', '1080': 'Full High Definition MP4'};
var dmVideoList = {};
var dmVideoFound = false;
var dmVideoParser, dmVideoParse, myVideoCode, dmVideo;
for (var dmVideoCode in dmVideoFormats) {
dmVideoParser = '"' + dmVideoCode + '".*?"type":"video.*?mp4","url":"(.*?)"';
dmVideoParse = dmVideosContent.match(dmVideoParser);
if (!dmVideoParse) {
dmVideoParser = '"' + dmVideoCode + '".*?"type":"application.*?mpegURL","url":"(.*?)"';
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) {
/* DVL */
dmVideoList['Direct Video Link'] = page.url;
feature['direct'] = true;
/* Create Player */
var dmDefaultVideo = 'Low Definition MP4';
player = {
'playerSocket': dmPlayerWindow,
'playerWindow': myPlayerWindow,
'videoList': dmVideoList,
'videoPlay': dmDefaultVideo,
'videoThumb': dmVideoThumb,
'playerWidth': dmPlayerWidth,
'playerHeight': dmPlayerHeight,
'playerWideWidth': dmPlayerWideWidth,
'playerWideHeight': dmPlayerWideHeight,
'sidebarWindow': dmSidebarWindow,
'sidebarMarginNormal': 0,
'sidebarMarginWide': dmSidebarMarginWide
};
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 */
page.body.addEventListener('click', function(e) {
if (e.target.id === 'vtVideo' || (e.target.tagName === 'DIV' && !e.target.innerHTML.match(/^\s*more\s*$/))) {
e.stopPropagation();
}
});
/* Fix Panel */
styleMyElement(player['playerContent'], {marginTop: '7px'});
/* Fix Info Position On Widesize */
player['buttonWidesize'].addEventListener('click', function() {
styleMyElement(dmPlayerWindow.parentNode, {minHeight: player['contentHeight'] + 50 + 'px'});
}, false);
}
else {
showMyMessage('!videos');
}
}
else {
showMyMessage('!content');
}
}
}
// =====Vimeo===== //
else if (page.url.match(/vimeo.com\/\d+/) || page.url.match(/vimeo.com\/channels\/[^\/]*($|\/$|\/page|\/\d+)/) || page.url.match(/vimeo.com\/originals\/[^\/]*($|\/$|\/\d+)/) || page.url.match(/vimeo.com\/album\/\d+\/video\/\d+/) || page.url.match(/vimeo.com\/groups\/[^\/]*\/videos\/\d+/)) {
/* Multi Video Page */
if (getMyElement('', 'div', 'class', 'player_container', -1, false).length > 1) return;
/* Video Page Type */
var viVideoPage = (page.url.match(/vimeo.com\/\d+/) || page.url.match(/vimeo.com\/album\/\d+\/video\/\d+/) || page.url.match(/vimeo.com\/groups\/[^\/]*\/videos\/\d+/)) ? true : false;
/* Get Player Window */
var viPlayerWindow;
if (viVideoPage) viPlayerWindow = getMyElement('', 'div', 'class', 'player_area', 0, false);
else 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);
if (!viVideoThumb) viVideoThumb = getMyContent(page.url, 'meta\\s+itemprop="image"\\s+content="(.*?)"', false);
if (!viVideoThumb) viVideoThumb = getMyContent(page.url, 'meta\\s+itemprop="thumbnailUrl"\\s+content="(.*?)"', false);
if (!viVideoThumb) viVideoThumb = getMyContent(page.url, 'meta\\s+name="twitter:image"\\s+content="(.*?)"', false);
if (!viVideoThumb) {
viVideoThumb = getMyContent(page.url, 'src="(https://i.vimeocdn.com/video/.*?.jpg)"', false);
if (viVideoThumb) viVideoThumb = viVideoThumb.replace(/_.*/, '_960x540.jpg');
}
/* Get Content Source */
var viVideoSource = getMyContent(page.url, '"config_url":"(.*?)"', false);
if (viVideoSource) viVideoSource = cleanMyContent(viVideoSource, false);
else viVideoSource = getMyContent(page.url, 'data-config-url="(.*?)"', false).replace(/&amp;/g, '&');
/* Get Videos Content */
var viVideosContent;
if (viVideoSource) {
viVideosContent = getMyContent(viVideoSource, '"progressive":\\[(.*?)\\]', false);
}
/* My Player Window */
var myPlayerWindow = createMyElement('div', '', '', '', '');
styleMyElement(myPlayerWindow, {position: 'relative', width: '960px', height: '562px', margin: '0px auto', backgroundColor: '#F4F5F7'});
if (viVideoPage) {
styleMyElement(viPlayerWindow, {minHeight: '562px', position: 'relative', zIndex: 'auto', transformStyle: 'flat'});
if (viPlayerWindow.parentNode) styleMyElement(viPlayerWindow.parentNode, {minHeight: '562px', position: 'relative', zIndex: 'auto'});
}
else {
styleMyElement(viPlayerWindow, {height: '100%'});
}
modifyMyElement(viPlayerWindow, 'div', '', false, true);
appendMyElement(viPlayerWindow, myPlayerWindow);
blockObject = viPlayerWindow;
/* Get Videos */
if (viVideosContent) {
var viVideoFormats = {'1080p': 'Full High Definition MP4', '720p': 'High Definition MP4', '480p': 'Standard Definition MP4', '360p': 'Low Definition MP4', '270p': 'Very Low Definition MP4'};
var viVideoList = {};
var viVideoFound = false;
var viVideo, myVideoCode;
var viVideos = viVideosContent.split('},');
for (var i = 0; i < viVideos.length; i++) {
for (var viVideoCode in viVideoFormats) {
if (viVideos[i].indexOf('"quality":"' + viVideoCode + '"') != -1) {
viVideo = viVideos[i].match(/"url":"(.*?)"/);
viVideo = (viVideo) ? viVideo[1] : null;
if (viVideo) {
if (!viVideoFound) viVideoFound = true;
myVideoCode = viVideoFormats[viVideoCode];
viVideoList[myVideoCode] = viVideo;
}
}
}
}
/* Channels Sidebar */
if (page.url.indexOf('/channels') != -1 && page.url.indexOf('/channels/staffpicks') == -1) {
var viSidebar = getMyElement('', 'div', 'class', 'col_small', 0, false);
if (viSidebar) {
styleMyElement(viSidebar, {marginTop: '570px'});
styleMyElement(viPlayerWindow, {paddingBottom: '10px'});
}
}
if (viVideoFound) {
/* DVL */
viVideoList['Direct Video Link'] = page.url;
feature['direct'] = true;
/* 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', 'Standard Definition', 'Low Definition', 'Very Low Definition'];
option['containers'] = ['MP4'];
createMyPlayer();
/* Fix panel */
if (viVideoPage) styleMyElement(player['playerContent'], {marginTop: '7px'});
else styleMyElement(player['playerContent'], {marginTop: '3px'});
}
else {
showMyMessage('!videos');
}
}
else {
showMyMessage('!content');
}
}
}
// =====Metacafe===== //
else if (page.url.indexOf('metacafe.com/watch') != -1) {
/* Get Player Window */
mcPlayerWindow = getMyElement('', 'div', 'class', 'mc-player-wrap', 0, false);
if (!mcPlayerWindow) {
showMyMessage('!player');
}
else {
/* Get Video Thumbnail */
var mcVideoThumb = getMyContent(page.url, '"preview":"(.*?)"', false);
if (mcVideoThumb) mcVideoThumb = cleanMyContent(mcVideoThumb, false);
/* Get Videos Content */
var mcVideosContent = getMyContent(page.url, 'flashvars\\s*=\\s*\\{(.*?)\\};', false);
/* Player Size */
var mcPlayerWidth, mcPlayerHeight;
function mcGetSizes() {
mcPlayerWidth = mcPlayerWindow.clientWidth;
mcPlayerHeight = Math.ceil(mcPlayerWidth / (16 / 9)) + 22;
}
function mcUpdateSizes() {
mcGetSizes();
player['playerWidth'] = mcPlayerWidth;
player['playerHeight'] = mcPlayerHeight;
resizeMyPlayer('widesize');
}
mcGetSizes();
/* My Player Window */
var myPlayerWindow = createMyElement('div', '', '', '', '');
styleMyElement(myPlayerWindow, {position: 'relative', width: mcPlayerWidth + 'px', height: mcPlayerHeight + 'px', backgroundColor: '#F4F4F4'});
modifyMyElement(mcPlayerWindow, 'div', '', true);
appendMyElement(mcPlayerWindow, myPlayerWindow);
/* Resize Event */
page.win.addEventListener('resize', mcUpdateSizes, false);
/* Hide Ads */
var mcTopAd = getMyElement('', 'div', 'id', 'spot_header', -1, false);
if (mcTopAd && mcTopAd.parentNode && mcTopAd.parentNode.parentNode) removeMyElement(mcTopAd.parentNode.parentNode, mcTopAd.parentNode);
var mcRightAd = getMyElement('', 'div', 'id', 'spot_right_top', -1, false);
if (mcRightAd && mcRightAd.parentNode && mcRightAd.parentNode.parentNode) removeMyElement(mcRightAd.parentNode.parentNode, mcRightAd.parentNode);
/* Get Videos */
if (mcVideosContent) {
var mcVideoList = {};
var mcVideoFound = false;
var mcVideoFormats = {'video_alt_url2': 'High Definition MP4', 'video_alt_url': 'Low Definition MP4', 'video_url': 'Very Low Definition MP4'};
var mcVideoFormatz = {'video_alt_url2': '_720p', 'video_alt_url': '_360p', 'video_url': '_240p'};
var mcVideoHLS = mcVideosContent.match(/"src":"(.*?)"/);
mcVideoHLS = (mcVideoHLS) ? cleanMyContent(mcVideoHLS[1], false) : null;
if (mcVideoHLS) {
var mcVideoParser, mcVideoParse, myVideoCode, mcVideo;
for (var mcVideoCode in mcVideoFormats) {
mcVideoParser = '"' + mcVideoCode + '":"(.*?)"';
mcVideoParse = mcVideosContent.match(mcVideoParser);
mcVideo = (mcVideoParse) ? mcVideoParse[1] : null;
if (mcVideo) {
if (!mcVideoFound) mcVideoFound = true;
myVideoCode = mcVideoFormats[mcVideoCode];
mcVideoList[myVideoCode] = mcVideoHLS.replace('.m3u8', mcVideoFormatz[mcVideoCode] + '.m3u8');
}
}
}
if (mcVideoFound) {
/* Create Player */
var mcDefaultVideo = 'Low Definition MP4';
player = {
'playerSocket': mcPlayerWindow,
'playerWindow': myPlayerWindow,
'videoList': mcVideoList,
'videoPlay': mcDefaultVideo,
'videoThumb': mcVideoThumb,
'playerWidth': mcPlayerWidth,
'playerHeight': mcPlayerHeight
};
feature['container'] = false;
feature['widesize'] = false;
option['definitions'] = ['High Definition', 'Low Definition', 'Very Low Definition'];
option['containers'] = ['MP4'];
createMyPlayer();
/* Fix panel */
styleMyElement(player['playerContent'], {marginTop: '3px'});
}
else {
showMyMessage('!videos');
}
}
else {
var ytVideoId = page.url.match(/\/yt-(.*?)\//);
if (ytVideoId && ytVideoId[1]) {
var ytVideoLink = 'http://youtube.com/watch?v=' + ytVideoId[1];
showMyMessage('embed', ytVideoLink);
}
else {
showMyMessage('!content');
}
}
}
}
// =====Break===== //
else if (page.url.indexOf('break.com/video') != -1 || page.url.indexOf('break.com/movies') != -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);
/* Player Size */
var brScreenWidth;
var brPlayerWidth, brPlayerHeight;
var brPlayerWideWidth, brPlayerWideHeight;
var brSidebarMarginWide = 720;
function brSizes() {
brScreenWidth = page.win.innerWidth || page.doc.documentElement.clientWidth;
if (page.url.indexOf('break.com/movies') != -1) {
if (brScreenWidth >= 1400) {
brPlayerWidth = 1152;
brPlayerHeight = 690;
}
else {
brPlayerWidth = 912;
brPlayerHeight = 546;
}
}
else {
if (brScreenWidth >= 1400) {
brPlayerWidth = 832;
brPlayerHeight = 490;
brPlayerWideWidth = 1152;
brPlayerWideHeight = 690;
brSidebarMarginWide = 850;
}
else {
brPlayerWidth = 592;
brPlayerHeight = 356;
brPlayerWideWidth = 910;
brPlayerWideHeight = 534;
}
}
}
brSizes();
/* My Player Window */
var myPlayerWindow = createMyElement('div', '', '', '', '');
styleMyElement(myPlayerWindow, {position: 'relative', width: brPlayerWidth + 'px', height: brPlayerHeight + 'px', backgroundColor: '#F4F4F4'});
modifyMyElement(brPlayerWindow, 'div', '', true);
styleMyElement(brPlayerWindow, {height: '100%', overflow: 'visible', paddingBottom: '20px'});
appendMyElement(brPlayerWindow, myPlayerWindow);
/* Update Sizes */
page.win.addEventListener('resize', function() {
brSizes();
player['playerWidth'] = brPlayerWidth;
player['playerHeight'] = brPlayerHeight;
player['playerWideWidth'] = brPlayerWideWidth;
player['playerWideHeight'] = brPlayerWideHeight;
player['sidebarMarginWide'] = brSidebarMarginWide;
resizeMyPlayer('widesize');
}, false);
/* Get Videos */
if (brVideosContent) {
var brVideoList = {};
var brVideoFormats = {};
var brVideoFound = false;
var 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', '3264_kbps.mp4': 'Full High Definition MP4'};
var brVideoPath, brVideoToken, brVideoThumb, brVideo, myVideoCode;
if (page.url.indexOf('break.com/video') != -1) {
brVideoPath = brVideosContent.match(/"videoUri":\s"(.*?)496_kbps/);
brVideoPath = (brVideoPath) ? brVideoPath[1] : null;
}
else {
brVideoPath = brVideosContent.match(/"hlsUri":\s"(.*?)"/);
brVideoPath = (brVideoPath) ? brVideoPath[1] : 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(brVideoCode)) {
if (!brVideoFound) brVideoFound = true;
myVideoCode = brVideoFormats[brVideoCode];
if (page.url.indexOf('break.com/video') != -1) brVideo = brVideoPath + brVideoCode + '?' + brVideoToken;
else brVideo = brVideoPath + brVideoCode + '.m3u8?' + brVideoToken;
brVideoList[myVideoCode] = brVideo;
}
}
}
if (brVideoFound) {
/* Get Watch Sidebar */
var brSidebarWindow = getMyElement('', 'aside', 'class', 'sidebar', 0, false);
/* Create Player */
var brDefaultVideo = 'Low Definition MP4';
player = {
'playerSocket': brPlayerWindow,
'playerWindow': myPlayerWindow,
'videoList': brVideoList,
'videoPlay': brDefaultVideo,
'videoThumb': brVideoThumb,
'playerWidth': brPlayerWidth,
'playerHeight': brPlayerHeight,
'playerWideWidth': brPlayerWideWidth,
'playerWideHeight': brPlayerWideHeight,
'sidebarWindow': brSidebarWindow,
'sidebarMarginNormal': 10,
'sidebarMarginWide': brSidebarMarginWide
};
if (page.url.indexOf('break.com/movies') != -1) feature['widesize'] = false;
option['definitions'] = ['Very Low Definition', 'Low Definition', 'Standard Definition', 'High Definition', 'Full 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', 'videoContainer', -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);
/* Restyle */
var fodPlayerContainer = getMyElement('', 'div', 'class', 'video-content', 0, false);
if (fodPlayerContainer) styleMyElement(fodPlayerContainer, {width: '100%'});
/* My Player Window */
var myPlayerWindow = createMyElement('div', '', '', '', '');
styleMyElement(myPlayerWindow, {position: 'relative', width: '968px', height: '570px', backgroundColor: '#F4F4F4', margin: '0px auto'});
var fodPlayerSocket = createMyElement('div', '', '', '', '');
styleMyElement(fodPlayerSocket, {height: '570px', backgroundColor: '#252525'});
styleMyElement(fodPlayerWindow, {display: 'none'});
appendMyElement(fodPlayerWindow.parentNode, fodPlayerSocket);
appendMyElement(fodPlayerSocket, myPlayerWindow);
blockObject = fodPlayerWindow;
/* 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([^\/]*?)\/master/);
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': fodPlayerSocket,
'playerWindow': myPlayerWindow,
'videoList': fodVideoList,
'videoPlay': fodDefaultVideo,
'videoThumb': fodVideoThumb,
'playerWidth': 968,
'playerHeight': 570
};
feature['container'] = false;
feature['widesize'] = false;
option['definitions'] = ['High Definition', 'Low Definition'];
option['containers'] = ['MP4'];
createMyPlayer();
/* Fix panel */
styleMyElement(player['playerContent'], {marginTop: '7px'});
}
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');
}
}
}
// =====Viki===== //
else if (page.url.indexOf('viki.com/videos') != -1) {
/* Get Player Window */
var vkPlayerWindow = getMyElement('', 'div', 'class', 'video-placeholder', 0, 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);
if (vkVideosContent.replace(/\n/, '') == '{}') return;
/* Player Size */
var vkSidebarWidth = 320;
var vkSidebarWindow = getMyElement('', 'div', 'class', 'col s12 l4 right', 0, false);
var vkPlayerWidth, vkPlayerHeight;
var vkPlayerWideWidth, vkPlayerWideHeight;
var vkSidebarMarginWide;
function vkGetSizes() {
vkPlayerWidth = vkPlayerWindow.clientWidth;
vkPlayerHeight = Math.ceil(vkPlayerWidth / (16 / 9)) + 22;
vkSidebarWidth = vkSidebarWindow.clientWidth;
vkPlayerWideWidth = vkPlayerWidth + vkSidebarWidth;
vkPlayerWideHeight = Math.ceil(vkPlayerWideWidth / (16 / 9)) + 22;
vkSidebarMarginWide = vkPlayerWideHeight + 20;
}
function vkUpdateSizes() {
vkGetSizes();
player['playerWidth'] = vkPlayerWidth;
player['playerHeight'] = vkPlayerHeight;
player['playerWideWidth'] = vkPlayerWideWidth;
player['playerWideHeight'] = vkPlayerWideHeight;
player['sidebarMarginWide'] = vkSidebarMarginWide;
resizeMyPlayer('widesize');
}
vkGetSizes();
/* My Player Window */
var myPlayerWindow = createMyElement('div', '', '', '', '');
styleMyElement(myPlayerWindow, {position: 'relative', width: vkPlayerWidth + 'px', height: vkPlayerHeight + 'px', backgroundColor: '#FFFFFF'});
modifyMyElement(vkPlayerWindow, 'div', '', false, true);
styleMyElement(vkPlayerWindow, {overflow: 'visible', height: '100%'});
appendMyElement(vkPlayerWindow, myPlayerWindow);
blockObject = vkPlayerWindow;
/* Resize Event */
page.win.addEventListener('resize', vkUpdateSizes, false);
/* 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': vkPlayerWideHeight,
'playerHeight': vkPlayerWideHeight,
'playerWideWidth': vkPlayerWideWidth,
'playerWideHeight': vkPlayerWideHeight,
'sidebarWindow': vkSidebarWindow,
'sidebarMarginNormal': 0,
'sidebarMarginWide': vkSidebarMarginWide
};
feature['definition'] = false;
feature['container'] = false;
option['definition'] = 'LD';
option['definitions'] = ['Low Definition'];
option['containers'] = ['MP4'];
createMyPlayer();
vkUpdateSizes();
/* Fix panel */
styleMyElement(player['playerContent'], {marginTop: '5px'});
}
else {
showMyMessage('!videos');
}
}
else {
showMyMessage('!content');
}
}
}
// =====IMDB===== //
else if (page.url.indexOf('imdb.com') != -1) {
/* Redirect To Video Page */
if (page.url.indexOf('imdb.com/video/') == -1) {
page.doc.addEventListener('click', function(e) {
var p = e.target.parentNode;
while (p) {
if (p.tagName === 'A' && p.href.indexOf('/video/imdb') != -1) {
page.win.location.href = p.href.replace(/imdb\/inline.*/, '');
}
p = p.parentNode;
}
}, false);
return;
}
/* 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 = {'SD': 'Low Definition MP4', '720p': 'High Definition MP4'};
var imdbVideoThumb, imdbURL, imdbVideo, myVideoCode;
var imdbVideoFound = false;
var imdbPageURL = page.url.replace(/\?.*$/, '').replace(/\/$/, '');
for (var imdbVideoCode in imdbVideoFormats) {
imdbURL = imdbPageURL + '/imdb/single?vPage=1&format=' + imdbVideoCode;
imdbVideo = getMyContent(imdbURL, '"videoUrl":"(.*?)"', false);
if (!imdbVideoThumb) imdbVideoThumb = getMyContent(imdbURL, '"slate":"(.*?)"', false);
if (imdbVideo) {
if (!imdbVideoFound) imdbVideoFound = true;
myVideoCode = imdbVideoFormats[imdbVideoCode];
imdbVideoList[myVideoCode] = imdbVideo;
}
if (imdbVideoCode == 'SD') {
if (!getMyContent(imdbURL, 'format=(.*?)&', false)) break;
}
}
if (imdbVideoFound) {
/* Get Watch Sidebar */
var imdbSidebarWindow = getMyElement('', 'div', 'id', 'sidebar', -1, false);
styleMyElement(imdbSidebarWindow, {marginTop: '-400px'});
/* Create Player */
var imdbDefaultVideo = 'Low Definition MP4';
player = {
'playerSocket': imdbPlayerWindow,
'playerWindow': myPlayerWindow,
'videoList': imdbVideoList,
'videoPlay': imdbDefaultVideo,
'videoThumb': imdbVideoThumb,
'playerWidth': 670,
'playerHeight': 398,
'playerWideWidth': 1010,
'playerWideHeight': 592,
'sidebarWindow': imdbSidebarWindow,
'sidebarMarginNormal': -400,
'sidebarMarginWide': 0
};
feature['container'] = false;
option['definitions'] = ['High Definition', 'Low Definition'];
option['containers'] = ['MP4'];
createMyPlayer();
}
else {
showMyMessage('!videos');
}
}
}
})();
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment