// ==UserScript== // @name ViewTube // @version 2013.01.15 // @namespace sebaro // @description Watch videos from video sharing websites without Flash Player. // @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://mevio.com* // @include http://*.mevio.com* // @include https://mevio.com* // @include https://*.mevio.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://veehd.com* // @include http://www.veehd.com* // @include https://veehd.com* // @include https://www.veehd.com* // @include http://imdb.com/video* // @include http://www.imdb.com/video* // @include https://imdb.com/video* // @include https://www.imdb.com/video* // ==/UserScript== /* Copyright (C) 2010 - 2013 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 . Website: http://isebaro.com/viewtube Contact: http://isebaro.com/contact */ (function() { // ==========Variables========== // // Userscript var userscript = 'ViewTube'; // Page var page = {win: window, doc: document, body: document.body, url: window.location.href}; // Player var player = {}; var feature = {'autoplay': true, 'definition': true, 'container': true, 'widesize': true, 'fullsize': true, 'popout': true}; var option = {'plugin': 'Auto', 'autoplay': false, 'autoget': false, 'definition': 'HD', 'container': 'MP4', 'widesize': false, 'fullsize': false}; var plugins = ['Auto', 'MPEG', 'MP4', 'HTML5']; if (navigator.platform.indexOf('Win') != -1) plugins = plugins.concat(['WMP', 'WMP2', 'QT']); else if (navigator.platform.indexOf('Mac') != -1) plugins = plugins.concat(['QT']); 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' }; // Links var website = 'http://isebaro.com/viewtube/?ln=en'; var contact = 'http://isebaro.com/contact/?ln=en&sb=viewtube'; // ==========Fixes========== // // Don't run on frames or iframes if (window.top != window.self) return; // ==========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.id = 'vtVideoElement'; obj.src = content; obj.innerHTML = '

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 here.'; } else if (type == 'object') { obj.id = 'vtObjectElement'; obj.data = content; obj.innerHTML = '

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 here.'; } } if (type == 'video' || type == 'object') { if (option['plugin'] == 'Auto' || option['plugin'] == 'HTML5') { obj.type = mimetypes[player['videoPlay'].replace(/.*\s/, '')]; } else { obj.type = mimetypes[option['plugin']]; } } if (type == 'video') { obj.controls = 'controls'; obj.autoplay = 'autoplay'; } 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 ('viewtube_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 ('viewtube_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 ('viewtube_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 ('viewtube_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 ('viewtube_widesize', option['widesize']); resizeMyPlayer('widesize'); } else if (action == 'fullsize') { option['fullsize'] = (option['fullsize']) ? false : true; setMyOptions ('viewtube_fullsize', option['fullsize']); resizeMyPlayer('fullsize'); } else if (action == 'popout') { detachMyPlayer(); } }, false); } return obj; } function detachMyPlayer() { // create external window var extWindow = page.win.open('', 'Detached', 'toolbar=no,location=no,menubar=no,width=640,height=390'); // save playing state var playing = false; if (option['plugin'] == 'HTML5' && player['isPlaying']) playing = !player['contentVideo'].paused; // move the player window to the external window //var extPlayer = extWindow.document.body.appendChild(player['playerWindow'].cloneNode(true)); var extPlayer = extWindow.document.body.appendChild(player['playerWindow']); // start playing again if (option['plugin'] == 'HTML5' && playing) player['contentVideo'].play(); // hide unwanted buttons if (feature['widesize']) styleMyElement (player['buttonWidesize'], {display: 'none'}); if (feature['fullsize']) styleMyElement (player['buttonFullsize'], {display: 'none'}); if (feature['popout']) styleMyElement (player['buttonPopout'], {display: 'none'}); // add event listener extWindow.addEventListener('resize', extWinOnResize, false); extWindow.addEventListener('beforeunload', extWinOnClose, false); extWindow.resizeTo(640,390); } // copied from resizeMyPlayer function extWinOnResize() { var playerWidth = this.innerWidth || this.document.documentElement.clientWidth; var playerHeight = this.innerHeight || this.document.documentElement.clientHeight; var playerPosition = 'fixed'; styleMyElement (this.document.body, {overflow: 'hidden'}); styleMyElement (player['playerWindow'], {position: playerPosition, top: '0px', left: '0px', width: playerWidth + 'px', height: playerHeight + 'px'}); var panelWidth = playerWidth - player['panelPadding'] * 2; styleMyElement (player['playerPanel'], {width: panelWidth + 'px'}); 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 extWinOnClose() { // save playing state var playing = false; if (option['plugin'] == 'HTML5' && player['isPlaying']) playing = !player['contentVideo'].paused; // move back from external window to playerSocket appendMyElement(player['playerSocket'], player['playerWindow']); // continue playing if (option['plugin'] == 'HTML5' && playing) player['contentVideo'].play(); // show buttons if (feature['widesize']) styleMyElement (player['buttonWidesize'], {display: 'inline'}); if (feature['fullsize']) styleMyElement (player['buttonFullsize'], {display: 'inline'}); if (feature['popout']) styleMyElement (player['buttonPopout'], {display: 'inline'}); // resize if (feature['fullsize'] && option['fullsize']) resizeMyPlayer('fullsize'); else if (feature['widesize'] ) resizeMyPlayer('widesize'); } 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) { if (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) { 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); } } } } 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: '#F4F4F4', 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', border: '1px solid #F4F4F4', borderRadius: '3px', padding: '0px', display: 'inline', color: '#336699', fontSize: '10px', 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 #F4F4F4', borderRadius: '3px', padding: '0px', display: 'inline', backgroundColor: '#F4F4F4', color: '#336699', fontSize: '10px', 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', backgroundColor: '#F4F4F4', color: '#336699', fontSize: '10px', 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 #F4F4F4', borderRadius: '3px', padding: '0px', display: 'inline', backgroundColor: '#F4F4F4', color: '#336699', fontSize: '10px', 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', backgroundColor: '#F4F4F4', color: '#336699', fontSize: '10px', 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: '10px', 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: '10px', 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: '10px', 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: '10px', 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: '10px', 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: '10px', 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: '10px', textShadow: '1px 1px 2px #CCCCCC', cursor: 'pointer'}); appendMyElement (player['playerPanel'], player['buttonFullsize']); } /* Panel popout Button */ if (feature['popout']) { player['buttonPopout'] = createMyElement ('div', '^', 'click', 'popout', ''); styleMyElement (player['buttonPopout'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#C05800', fontSize: '10px', textShadow: '1px 1px 2px #CCCCCC', cursor: 'pointer'}); appendMyElement (player['playerPanel'], player['buttonPopout']); } /* 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', backgroundColor: '#F4F4F4', color: '#AD0000', fontSize: '14px', textAlign: 'center'}); appendMyElement (player['playerWindow'], player['playerContent']); /* The Video Thumbnail */ if (player['videoThumb']) { player['contentImage'] = createMyElement ('img', player['videoThumb'], '', '', ''); styleMyElement (player['contentImage'], {width: player['contentWidth'] + 'px', height: player['contentHeight'] + 'px', border: '0px'}); } /* Resize My Player */ if (feature['widesize'] && option['widesize']) resizeMyPlayer('widesize'); if (feature['fullsize'] && 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 player['contentVideo'] = createMyElement ('object', player['videoList'][player['videoPlay']], '', '', ''); player['contentVideo'].width = player['contentWidth']; player['contentVideo'].height = player['contentHeight']; styleMyElement (player['contentVideo'], {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(/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 Link'; 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 (option['fullsize']) { if (feature['widesize']) styleMyElement (player['buttonWidesize'], {display: 'none'}); modifyMyElement (player['buttonFullsize'], 'div', '-', false); removeMyElement (player['playerSocket'], player['playerWindow']); appendMyElement (page.body, player['playerWindow']); var playerWidth = page.win.innerWidth || page.doc.documentElement.clientWidth; var playerHeight = page.win.innerHeight || page.doc.documentElement.clientHeight; var playerPosition = 'fixed'; styleMyElement (page.body, {overflow: 'hidden'}); } else { if (feature['widesize']) styleMyElement (player['buttonWidesize'], {display: 'inline'}); modifyMyElement (player['buttonFullsize'], 'div', '+', false); removeMyElement (page.body, player['playerWindow']); appendMyElement (player['playerSocket'], player['playerWindow']); var playerWidth = (option['widesize']) ? player['playerWideWidth'] : player['playerWidth']; var playerHeight = (option['widesize']) ? player['playerWideHeight'] : player['playerHeight']; var playerPosition = 'relative'; styleMyElement (page.body, {overflow: 'auto'}); } } /* Resize The Player */ if (size == 'widesize') { styleMyElement (player['sidebarWindow'], {marginTop: sidebarMargin + 'px'}); styleMyElement (player['playerWindow'], {position: 'relative', width: playerWidth + 'px', height: playerHeight + 'px'}); } else styleMyElement (player['playerWindow'], {position: playerPosition, top: '0px', left: '0px', width: playerWidth + 'px', height: playerHeight + 'px'}); /* 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 ('', '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) { try { localStorage.setItem(key, value); } 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 () { var vtPlugin = 'viewtube_plugin'; var vtAutoplay = 'viewtube_autoplay'; var vtDefinition = 'viewtube_definition'; var vtContainer = 'viewtube_container'; var vtWidesize = 'viewtube_widesize'; var vtFullsize = 'viewtube_fullsize'; try { if (localStorage.getItem(vtPlugin)) option['plugin'] = localStorage.getItem(vtPlugin); if (localStorage.getItem(vtAutoplay)) option['autoplay'] = localStorage.getItem(vtAutoplay); if (localStorage.getItem(vtDefinition)) option['definition'] = localStorage.getItem(vtDefinition); if (localStorage.getItem(vtContainer)) option['container'] = localStorage.getItem(vtContainer); if (localStorage.getItem(vtWidesize)) option['widesize'] = localStorage.getItem(vtWidesize); if (localStorage.getItem(vtFullsize)) option['fullsize'] = localStorage.getItem(vtFullsize); } 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); if (cookie.indexOf(vtPlugin) == 0) option['plugin'] = cookie.substring(vtPlugin.length + 1, cookie.length); if (cookie.indexOf(vtAutoplay) == 0) option['autoplay'] = cookie.substring(vtAutoplay.length + 1, cookie.length); if (cookie.indexOf(vtDefinition) == 0) option['definition'] = cookie.substring(vtDefinition.length + 1, cookie.length); if (cookie.indexOf(vtContainer) == 0) option['container'] = cookie.substring(vtContainer.length + 1, cookie.length); if (cookie.indexOf(vtWidesize) == 0) option['widesize'] = cookie.substring(vtWidesize.length + 1, cookie.length); if (cookie.indexOf(vtFullsize) == 0) option['fullsize'] = cookie.substring(vtFullsize.length + 1, cookie.length); } } option['autoplay'] = (option['autoplay'] == 'true') ? true : false; option['widesize'] = (option['widesize'] == 'true') ? true : false; option['fullsize'] = (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: '#F8F8F8', fontSize: '14px', textAlign: 'center', zIndex: '99999'}); appendMyElement (myScriptAlert, myScriptLogo); var myNoPlayerMess = 'Couldn\'t get the player element. Please report it here.'; 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 = '

Couldn\'t get the thumbnail for this video. Please report it here.'; modifyMyElement (player['playerContent'], 'div', myNoThumbMess, false); } else { appendMyElement (myPlayerWindow, myScriptLogo); if (cause == '!content') { var myNoContentMess = 'Couldn\'t get the videos content. Please report it here.'; modifyMyElement (myScriptMess, 'div', myNoContentMess, false); } else if (cause == '!videos') { var myNoVideosMess = 'Couldn\'t get any video. Please report it here.'; 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 here.'; modifyMyElement (myScriptMess, 'div', myEmbedMess, false); } appendMyElement (myPlayerWindow, myScriptMess); } } function removeSiteVideos () { function removeVideos() { var h5Videos = getMyElement ('', 'video', 'tag', '', -1, false); for (var v = 0; v < h5Videos.length; v++) { var h5Video = h5Videos[v]; if (h5Video.id != 'vtVideoElement') { h5Video.addEventListener('play', function() { modifyMyElement (h5Video, 'video', 'novideoplease', true); if (h5Video.parentNode) removeMyElement (h5Video.parentNode, h5Video); }, false); } } var obVideos = getMyElement ('', 'object', 'tag', '', -1, false); for (var v = 0; v < obVideos.length; v++) { var obVideo = obVideos[v]; if (obVideo.id != 'vtObjectElement') { modifyMyElement (obVideo, 'object', 'novideoplease', true); if (obVideo.parentNode) removeMyElement (obVideo.parentNode, obVideo); } } var emVideo = getMyElement ('', 'embed', 'tag', '', 0, false); if (emVideo) { modifyMyElement (emVideo, 'embed', 'novideoplease', true); if (emVideo.parentNode) removeMyElement (emVideo.parentNode, emVideo); } } if (page.doc.readyState === 'complete') removeVideos(); else page.doc.addEventListener('DOMContentLoaded', removeVideos, false); } // ==========Websites========== // // Remove remaining embedded videos removeSiteVideos(); // =====YouTube===== // if (page.url.indexOf('youtube.com/watch') != -1) { /* Check Video Availability */ if (getMyElement ('', 'div', 'id', 'watch7-player-unavailable', -1, false)) return; /* Hide Flash Messages */ var ytFlashMess = getMyElement ('', 'div', 'id', 'flash10-promo-div', -1, false); if (ytFlashMess) { styleMyElement (ytFlashMess, {width: '0px', height: '0px', border: '0px', padding: '0px', backgroundColor: '#FFFFFF'}); } /* Get Player Window */ var ytPlayerWindow = getMyElement ('', 'div', 'id', 'watch7-video', -1, false); /* Get Player Window (Feather) */ if (!ytPlayerWindow) ytPlayerWindow = getMyElement ('', 'div', 'id', 'p', -1, false); if (!ytPlayerWindow) { showMyMessage ('!player'); } else { /* My Player Window */ var myPlayerWindow = createMyElement ('div', '', '', '', ''); styleMyElement (myPlayerWindow, {position: 'relative', width: '640px', height: '390px', backgroundColor: '#F4F4F4', zIndex: '99999'}); modifyMyElement (ytPlayerWindow, 'div', '', true); appendMyElement (ytPlayerWindow, myPlayerWindow); /* 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); /* 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 = getMyContent (page.url, '"url_encoded_fmt_stream_map":\\s+"(.*?)"', false); /* Get Videos Content (Feather) */ if (!ytVideosContent) ytVideosContent = getMyContent (page.url, 'url_encoded_fmt_stream_map=(.*?)(watermark|cafe_experiment_id)', true); /* Get Videos */ if (ytVideosContent) { ytVideosContent = cleanMyContent (ytVideosContent, false); 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' }; var ytVideoList = {}; 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=.*$/, ''); ytVideo = ytVideo.replace (/sig/, 'signature'); ytVideo = cleanMyContent (ytVideo, true); if (ytVideo) { if (!ytVideoFound) ytVideoFound = true; ytVideoList[myVideoCode] = ytVideo; } } } } if (ytVideoFound) { /* Get Watch Sidebar */ var ytSidebarWindow = getMyElement ('', 'div', 'id', 'watch7-sidebar', -1, false); /* Create Player */ var ytDefaultVideo = 'Low Definition MP4'; player = { 'playerSocket': ytPlayerWindow, 'playerWindow': myPlayerWindow, 'videoList': ytVideoList, 'videoPlay': ytDefaultVideo, 'videoThumb': ytVideoThumb, 'videoTitle': ytVideoTitle, 'playerWidth': 640, 'playerHeight': 390, 'playerWideWidth': 970, 'playerWideHeight': 510, 'sidebarWindow': ytSidebarWindow, 'sidebarMarginNormal': -390, 'sidebarMarginWide': 10 }; if (page.url.indexOf('list=') != -1) feature['widesize'] = false; option['autoget'] = true; 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 (); } else { if (ytVideosContent.indexOf('conn=rtmp') != -1) showMyMessage ('!support'); else showMyMessage ('!videos'); } } else { showMyMessage ('!content'); } } } // =====DailyMotion===== // else if (page.url.indexOf('dailymotion.com/video') != -1) { /* Get Player Window */ var dmPlayerWindow = getMyElement ('', 'div', 'class', 'dmpi_video_playerv4 span-8', 0, false); if (!dmPlayerWindow) { showMyMessage ('!player'); } else { /* My Player Window */ var myPlayerWindow = createMyElement ('div', '', '', '', ''); styleMyElement (myPlayerWindow, {position: 'relative', width: '620px', height: '360px', backgroundColor: '#F4F4F4', zIndex: '99999'}); modifyMyElement (dmPlayerWindow, 'div', '', true); styleMyElement (dmPlayerWindow, {height: '100%'}); appendMyElement (dmPlayerWindow, myPlayerWindow); /* Get Video Thumbnail */ var dmVideoThumb = getMyContent (page.url, 'meta\\s+property="og:image"\\s+content="(.*?)"', false); /* Get Videos Content */ var dmVideosContent = getMyContent (page.url, '"VideoFrame","param":\\{(.*?)\\}', true); /* Get Videos */ if (dmVideosContent) { var dmVideoFormats = {'hd1080URL': 'Full High Definition MP4', 'hd720URL': 'High Definition MP4', 'hqURL': 'Standard Definition MP4', 'sdURL': 'Low Definition MP4', 'ldURL': 'Very Low Definition MP4'}; 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; myVideoCode = dmVideoFormats[dmVideoCode]; dmVideoList[myVideoCode] = dmVideo; } } if (dmVideoFound) { /* Get Watch Sidebar */ var dmSidebarWindow = getMyElement ('', 'div', 'id', 'right_content_box', -1, false); styleMyElement (dmSidebarWindow, {marginTop: '-420px'}); /* Create Player */ var dmDefaultVideo = 'Low Definition MP4'; player = { 'playerSocket': dmPlayerWindow, 'playerWindow': myPlayerWindow, 'videoList': dmVideoList, 'videoPlay': dmDefaultVideo, 'videoThumb': dmVideoThumb, 'playerWidth': 620, 'playerHeight': 360, 'playerWideWidth': 970, 'playerWideHeight': 510, 'sidebarWindow': dmSidebarWindow, 'sidebarMarginNormal': -420, 'sidebarMarginWide': 10 }; feature['container'] = false; option['definitions'] = ['Full High Definition', 'High Definition', 'Standard Definition', 'Low Definition', 'Very Low Definition']; option['containers'] = ['MP4']; createMyPlayer (); } else { showMyMessage ('!videos'); } } else { showMyMessage ('!content'); } } } // =====Vimeo===== // else if (page.url.match(/vimeo.com($|\/$|\/\d{1,8})/)) { /* Get Player Window */ var viPlayerWindow = getMyElement ('', 'div', 'class', 'vimeo_holder', 0, false); if (!viPlayerWindow) { showMyMessage ('!player'); } else { /* My Player Window */ var myPlayerWindow = createMyElement ('div', '', '', '', ''); styleMyElement (myPlayerWindow, {position: 'relative', width: '960px', height: '510px', backgroundColor: '#F4F4F4', zIndex: '99999'}); modifyMyElement (viPlayerWindow, 'div', '', true); styleMyElement (viPlayerWindow, {height: '100%'}); appendMyElement (viPlayerWindow, myPlayerWindow); /* Get Videos Content */ var viVideosContent = getMyContent (page.url, 'config:\\{([\\s\\S]*?)\\}\\};', false); /* 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 viVideoSignature, viVideoTimestamp, viVideoID, viVideoQualities, viVideoThumb, viVideo, myVideoCode; viVideoSignature = viVideosContent.match (/"signature":"(.*?)"/); viVideoSignature = (viVideoSignature) ? viVideoSignature[1] : null; viVideoTimestamp = viVideosContent.match (/"timestamp":(.*?),/); viVideoTimestamp = (viVideoTimestamp) ? viVideoTimestamp[1] : null; viVideoPlayer = viVideosContent.match (/"player_url":"(.*?)"/); viVideoPlayer = (viVideoPlayer) ? viVideoPlayer[1] : null; viVideoID = viVideosContent.match (/"video":\{"id":(.*?),/); viVideoID = (viVideoID) ? viVideoID[1] : null; viVideoQualities = viVideosContent.match (/"qualities":\[(.*?)\]/); viVideoQualities = (viVideoQualities) ? viVideoQualities[1] : null; viVideoThumb = viVideosContent.match (/"thumbnail":"(.*?)"/); viVideoThumb = (viVideoThumb) ? cleanMyContent(viVideoThumb[1]) : null; if (viVideoSignature && viVideoTimestamp && viVideoID && viVideoPlayer && viVideoQualities) { for (var viVideoCode in viVideoFormats) { if (viVideoQualities.indexOf(viVideoCode) != -1) { if (!viVideoFound) viVideoFound = true; viVideo = 'http://' + viVideoPlayer + '/play_redirect?' + 'quality=' + viVideoCode + '&clip_id=' + viVideoID + '&time=' + viVideoTimestamp + '&sig=' + viVideoSignature; myVideoCode = viVideoFormats[viVideoCode]; viVideoList[myVideoCode] = viVideo; } } } if (viVideoFound) { /* Create Player */ var viDefaultVideo = 'Standard Definition MP4'; player = {'playerSocket': viPlayerWindow, 'playerWindow': myPlayerWindow, 'videoList': viVideoList, 'videoPlay': viDefaultVideo, 'videoThumb': viVideoThumb, 'playerWidth': 960, 'playerHeight': 510}; feature['container'] = false; feature['widesize'] = false; option['definitions'] = ['High Definition', 'Low Definition', 'Very Low Definition']; option['containers'] = ['MP4']; createMyPlayer (); } 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 { /* My Player Window */ var myPlayerWindow = createMyElement ('div', '', '', '', ''); styleMyElement (myPlayerWindow, {position: 'relative', width: '615px', height: '380px', backgroundColor: '#F4F4F4', zIndex: '99999'}); modifyMyElement (mcPlayerWindow, 'div', '', true); styleMyElement (mcPlayerWindow, {height: '100%'}); appendMyElement (mcPlayerWindow, myPlayerWindow); /* Get Video Thumbnail */ var mcVideoThumb = getMyContent (page.url, 'meta\\s+property="og:image"\\s+content="(.*?)"', false); /* Get Videos Content */ var mcVideosContent = getMyContent (page.url, '"mediaData":"(.*?)"', false); var mcVideosContent2 = getMyContent (page.url, '"mediaURL":"(.*?)","postRollContentURL"', false); /* Get Videos */ if (mcVideosContent) { mcVideosContent = cleanMyContent(mcVideosContent, true); var mcVideoFormats = {'highDefinitionMP4': 'High Definition MP4', 'MP4': 'Low Definition MP4'}; var mcVideoList = {}; var mcVideoFound = false; 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; } } if (mcVideosContent2) { mcVideosContent2 = cleanMyContent(mcVideosContent2, true); mcVideoParser = '(.*?)","(.*?)":"(.*?)$'; mcVideoParse = mcVideosContent2.match (mcVideoParser); mcVideoPath = (mcVideoParse) ? mcVideoParse[1] : null; mcVideoKeyName = '__gda__'; mcVideoKeyValue = (mcVideoParse) ? mcVideoParse[3] : null; if (mcVideoPath && mcVideoKeyName && mcVideoKeyValue) { if (!mcVideoFound) mcVideoFound = true; mcVideo = mcVideoPath + '?' + mcVideoKeyName + '=' + mcVideoKeyValue; mcVideoList['Low Definition FLV'] = mcVideo; } } if (mcVideoFound) { /* Get Watch Sidebar */ var mcSidebarWindow = getMyElement ('', 'div', 'id', 'Sidebar', -1, false); /* Create Player */ var mcDefaultVideo = 'Low Definition MP4'; player = { 'playerSocket': mcPlayerWindow, 'playerWindow': myPlayerWindow, 'videoList': mcVideoList, 'videoPlay': mcDefaultVideo, 'videoThumb': mcVideoThumb, 'playerWidth': 615, 'playerHeight': 380, 'playerWideWidth': 930, 'playerWideHeight': 510, 'sidebarWindow': mcSidebarWindow, 'sidebarMarginNormal': 10, 'sidebarMarginWide': 610 }; 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') != -1) { /* Get Page Type */ var brPageType = getMyContent (page.url, 'meta\\s+property="og:type"\\s+content="(.*?)"', false); if (!brPageType || brPageType != 'video.other') return; /* Get Player Window */ var brPlayerWindow = getMyElement ('', 'div', 'id', 'video-player', -1, false); if (!brPlayerWindow) { showMyMessage ('!player'); } else { /* My Player Window */ var myPlayerWindow = createMyElement ('div', '', '', '', ''); styleMyElement (myPlayerWindow, {position: 'relative', width: '527px', height: '296px', backgroundColor: '#F4F4F4', zIndex: '99999'}); modifyMyElement (brPlayerWindow, 'div', '', true); styleMyElement (brPlayerWindow, {height: '100%'}); appendMyElement (brPlayerWindow, myPlayerWindow); /* Get Video Thumbnail */ var brVideoThumb = getMyContent (page.url, 'meta\\s+property="og:image"\\s+content="(.*?)"', false); /* Get Video Path */ var brVideoPath = getMyContent (page.url, 'videoPath:\\s+\'(.*?)\'', false); /* Get Video Token */ var brVideoToken = getMyContent (page.url, 'icon:\\s+\'(.*?)\'', false); /* Create Video */ if (brVideoPath && brVideoToken) { var brVideoList = {}; var brVideo; if (brVideoPath.indexOf('.flv') != -1) { brVideo = brVideoPath + '?' + brVideoToken; brVideoList['Low Definition FLV'] = brVideo; brVideoPath = brVideoPath.replace(/\.flv/, '.mp4'); brVideo = brVideoPath + '?' + brVideoToken; brVideoList['Low Definition MP4'] = brVideo; } else { brVideo = brVideoPath + '?' + brVideoToken; brVideoList['Low Definition MP4'] = brVideo; } /* 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 > 1300) { brPlayerWidth = 767; brPlayerHeight = 430; } else { brPlayerWidth = 527; brPlayerHeight = 296; } player = { 'playerSocket': brPlayerWindow, 'playerWindow': myPlayerWindow, 'videoList': brVideoList, 'videoPlay': brDefaultVideo, 'videoThumb': brVideoThumb, 'playerWidth': brPlayerWidth, 'playerHeight': brPlayerHeight, 'playerWideWidth': 910, 'playerWideHeight': 510, 'sidebarWindow': brSidebarWindow, 'sidebarMarginNormal': 10, 'sidebarMarginWide': 560 }; if (brWindowWidth > 1300) feature['widesize'] = false; feature['definition'] = false; feature['container'] = false; option['definition'] = 'LD'; option['definitions'] = ['Low Definition']; option['containers'] = ['MP4', 'FLV', 'Any']; createMyPlayer (); } else { var ytVideoId = getMyContent (page.url, 'youtubeid=(.*?)&', false); if (ytVideoId) { var ytVideoLink = 'http://youtube.com/watch?v=' + ytVideoId; showMyMessage ('embed', ytVideoLink); } else showMyMessage ('!videos'); } } } // =====FunnyOrDie===== // else if (page.url.indexOf('funnyordie.com/videos') != -1) { /* Get Player Window */ var fodPlayerWindow = getMyElement ('', 'div', 'id', 'video_player', -1, false); if (!fodPlayerWindow) { showMyMessage ('!player'); } else { /* My Player Window */ var myPlayerWindow = createMyElement ('div', '', '', '', ''); styleMyElement (myPlayerWindow, {position: 'relative', width: '640px', height: '390px', backgroundColor: '#F4F4F4', zIndex: '99999'}); modifyMyElement (fodPlayerWindow, 'div', '', true); styleMyElement (fodPlayerWindow, {height: '100%', overflow: 'visible'}); appendMyElement (fodPlayerWindow, myPlayerWindow); /* 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_tag\\s+=.*mp4)', true); /* Get Videos */ if (fodVideosContent) { var fodVideoFormats = {'2500': 'High Definition MP4', '600': 'Low Definition MP4'}; var fodVideoList = {}; var fodVideoFound = false; var fodVideoParser, myVideoCode, fodVideoParse, fodVideo; var fodVideos = fodVideosContent.match (/http.*?(\s|$)/g); for (var fodVideoCode in fodVideoFormats) { for (var i = 0; i < fodVideos.length; i++) { fodVideoParser = 'http.*?' + fodVideoCode + '.mp4'; fodVideo = fodVideos[i].match (fodVideoParser); if (fodVideo) { if (!fodVideoFound) fodVideoFound = true; myVideoCode = fodVideoFormats[fodVideoCode]; fodVideoList[myVideoCode] = fodVideo; break; } } } if (fodVideoFound) { /* Get Watch Sidebar */ var fodSidebarWindow = getMyElement ('', 'div', 'id', 'sidebar', -1, false); /* Create Player */ fodDefaultVideo = 'Low Definition MP4'; player = { 'playerSocket': fodPlayerWindow, 'playerWindow': myPlayerWindow, 'videoList': fodVideoList, 'videoPlay': fodDefaultVideo, 'videoThumb': fodVideoThumb, 'playerWidth': 640, 'playerHeight': 390, 'playerWideWidth': 970, 'playerWideHeight': 510, 'sidebarWindow': fodSidebarWindow, 'sidebarMarginNormal': 5, 'sidebarMarginWide': 620 }; feature['container'] = false; option['definitions'] = ['High Definition', 'Low Definition']; option['containers'] = ['MP4']; createMyPlayer (); } 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 { /* My Player Window */ var myPlayerWindow = createMyElement ('div', '', '', '', ''); styleMyElement (myPlayerWindow, {position: 'relative', width: '640px', height: '380px', backgroundColor: '#F4F4F4', zIndex: '99999'}); modifyMyElement (vjPlayerWindow, 'div', '', true); styleMyElement (vjPlayerWindow, {height: '100%', backgroundColor: '#FFFFFF'}); appendMyElement (vjPlayerWindow, myPlayerWindow); /* Get Videos Content */ var vjVideosContent = getMyContent (page.url, 'new\\s+Player\\((.*?)\\)', true); /* 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 vjVideoFormats = {'VJ480PENG.mp4': 'Standard Definition MP4', 'VJ360PENG.mp4': 'Low Definition MP4', 'FW8ENG.flv': 'Low Definition FLV', 'FS8ENG.flv': 'Very Low Definition FLV'}; var vjVideoList = {}; var vjVideoFound = false; var vjVideoPart, vjVideoHost, myVideoCode, vjVideo, vjVideoThumb; if (vjVideoToken && vjVideoTitle) { vjVideoFound = true; vjVideoPart = vjVideoToken2 + '/' + vjVideoToken + '/' + vjVideoTitle; for (var vjVideoCode in vjVideoFormats) { if (vjVideoCode == 'FS8ENG.flv') vjVideoHost = 'http://content.videojug.com/'; else vjVideoHost = 'http://content3.videojug.com/'; vjVideo = vjVideoHost + vjVideoPart + '__' + vjVideoCode; myVideoCode = vjVideoFormats[vjVideoCode]; vjVideoList[myVideoCode] = vjVideo; } vjVideoHost = 'http://content5.videojug.com/'; vjVideoThumb = vjVideoHost + vjVideoPart + '.WidePlayer.jpg'; } if (vjVideoFound) { /* Get Watch Sidebar */ var vjSidebarWindow = getMyElement ('', 'div', 'id', 'recommended_content', -1, false); /* Create Player */ var vjDefaultVideo = 'Low Definition MP4'; player = { 'playerSocket': vjPlayerWindow, 'playerWindow': myPlayerWindow, 'videoList': vjVideoList, 'videoPlay': vjDefaultVideo, 'videoThumb': vjVideoThumb, 'playerWidth': 640, 'playerHeight': 380, 'playerWideWidth': 970, 'playerWideHeight': 510, 'sidebarWindow': vjSidebarWindow, 'sidebarMarginNormal': 5, 'sidebarMarginWide': 620 }; option['definition'] = 'SD'; option['definitions'] = ['Standard Definition', 'Low Definition', 'Very Low Definition']; option['containers'] = ['MP4', 'FLV', 'Any']; createMyPlayer (); } else { showMyMessage ('!videos'); } } else { showMyMessage ('!content'); } } } // =====Mevio===== // else if (page.url.indexOf('mevio.com') != -1) { /* Get Player Window */ var mePlayerWindow = getMyElement ('', 'div', 'id', 'player-zone', -1, false); if (!mePlayerWindow) { //showMyMessage ('!player'); } else { /* My Player Window */ var myPlayerWindow = createMyElement ('div', '', '', '', ''); styleMyElement (myPlayerWindow, {position: 'relative', width: '915px', height: '480px', margin: '0px auto', backgroundColor: '#F4F4F4', zIndex: '99999'}); modifyMyElement (mePlayerWindow, 'div', '', true); styleMyElement (mePlayerWindow, {backgroundImage: 'none !important', backgroundColor: '#656665 !important'}); appendMyElement(mePlayerWindow, myPlayerWindow); /* Get Data Content */ var meDataContent = getMyContent (page.url, 'args.default_media\\s+=\\s+\\{(.*?)\\};', false); meDataContent = cleanMyContent (meDataContent, true); /* Get Video Thumbnail */ var meVideoThumb = meDataContent.match(/"large":"(.*?)"/); meVideoThumb = (meVideoThumb) ? meVideoThumb[1] : null; /* Get Videos Content */ var meVideosContent = meDataContent.match(/"media_urls":\{(.*?)\}/); meVideosContent = (meVideosContent) ? meVideosContent[1] : null; /* Get Videos */ if (meVideosContent) { var meVideoFormats = {'mp4': 'High Definition MP4', 'm4v': 'High Definition M4V', 'mov': 'High Definition MOV', 'h264': 'Low Definition MP4', 'flv': 'Low Definition FLV'}; var meVideoList = {}; var meVideoFound = false; var meVideoParser, meVideoParse, meVideo, myVideoCode; for (var meVideoCode in meVideoFormats) { meVideoParser = meVideoCode + '":"(.*?)"'; meVideoParse = meVideosContent.match (meVideoParser); meVideo = (meVideoParse) ? meVideoParse[1] : null; if (meVideo) { if (!meVideoFound) meVideoFound = true; myVideoCode = meVideoFormats[meVideoCode]; meVideoList[myVideoCode] = meVideo; } } if (meVideoFound) { /* Create Player */ var meDefaultVideo = 'Low Definition FLV'; player = {'playerSocket': mePlayerWindow, 'playerWindow': myPlayerWindow, 'videoList': meVideoList, 'videoPlay': meDefaultVideo, 'videoThumb': meVideoThumb, 'playerWidth': 915, 'playerHeight': 480}; feature['widesize'] = false; option['definitions'] = ['High Definition', 'Low Definition']; option['containers'] = ['MP4', 'M4V', 'MOV', '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 blipPlayerWindow = getMyElement ('', 'div', 'class', 'EpisodePlayer', 0, false); if (!blipPlayerWindow) { showMyMessage ('!player'); } else { /* My Player Window */ var myPlayerWindow = createMyElement ('div', '', '', '', ''); styleMyElement (myPlayerWindow, {position: 'relative', width: '960px', height: '560px', backgroundColor: '#F4F4F4', zIndex: '99999'}); modifyMyElement (blipPlayerWindow, 'div', '', true); styleMyElement (blipPlayerWindow, {paddingTop: '0px'}); appendMyElement (blipPlayerWindow, myPlayerWindow); /* 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); /* 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': 960, 'playerHeight': 560}; 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 veVideoContainer = getMyElement ('', 'div', 'id', 'videoContainer', -1, false); var veVideoPlayer = getMyElement ('', 'div', 'id', 'videoPlayerContainer', -1, false); if (!veVideoContainer || !veVideoPlayer) { showMyMessage ('!player'); } else { /* New Player Socket */ var vePlayerWindow = createMyElement ('div', '', '', '', ''); styleMyElement (vePlayerWindow, {height: '100%', margin: '0px 0px 20px 0px'}); replaceMyElement (veVideoContainer, vePlayerWindow, veVideoPlayer); /* My Player Window */ var myPlayerWindow = createMyElement ('div', '', '', '', ''); styleMyElement (myPlayerWindow, {position: 'relative', width: '640px', height: '400px', backgroundColor: '#F4F4F4', zIndex: '99999'}); appendMyElement (vePlayerWindow, myPlayerWindow); /* 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; /* 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); /* Create Player */ var veDefaultVideo = 'Low Definition MP4'; player = { 'playerSocket': vePlayerWindow, 'playerWindow': myPlayerWindow, 'videoList': veVideoList, 'videoPlay': veDefaultVideo, 'videoThumb': veVideoThumb, 'playerWidth': 640, 'playerHeight': 400, 'playerWideWidth': 970, 'playerWideHeight': 510, 'sidebarWindow': veSidebarWindow, 'sidebarMarginNormal': 0, 'sidebarMarginWide': 530 }; 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'); } } } // =====VeeHD===== // else if (page.url.indexOf('veehd.com/video/') != -1) { /* Get Player Window */ var veePlayerWindow = getMyElement ('', 'div', 'class', 'videoHolder', 0, false); if (!veePlayerWindow) { showMyMessage ('!player'); } else { /* Get Video Thumb */ var veeVideoThumb = getMyContent (page.url, 'img\\s+id="veehdpreview"\\s+src="(.*?)"', false); /* Get Videos Content */ var veeVideosContent = getMyContent (page.url, '"(\/vpi\\?h=.*?)"', false); /* My Player Window */ var myPlayerWindow = createMyElement ('div', '', '', '', ''); styleMyElement (myPlayerWindow, {position: 'relative', width: '990px', height: '480px', backgroundColor: '#F4F4F4', zIndex: '99999'}); modifyMyElement (veePlayerWindow, 'div', '', true); styleMyElement (veePlayerWindow, {height: '100%'}); appendMyElement (veePlayerWindow, myPlayerWindow); /* Get Videos */ if (veeVideosContent) { var veeVideoList = {}; var veeVideoFound = false; var veeVideoType = getMyContent (page.url, 'type:\\s+(.*?)<', false); var veeVideo, veeVideoContainer, veeVideoSize, veeVideoDefinition, veeDefaultVideo; if (veeVideoType == 'divx') { veeVideo = getMyContent (veeVideosContent, 'param\\s+name="src"\\s+value="(.*?)"', true); veeVideoContainer = 'AVI'; } else { veeVideo = getMyContent (veeVideosContent, '"url":"(.*?)"', true); veeVideoContainer = 'MP4'; } veeVideoSize = getMyContent (page.url, 'resolution:.*?x(.*?)<', false); veeVideoDefinition = 'Low Definition'; if (veeVideoSize > 400) veeVideoDefinition = 'Standard Definition'; if (veeVideoSize > 700) veeVideoDefinition = 'High Definition'; if (veeVideoSize > 1000) veeVideoDefinition = 'Full High Definition'; veeDefaultVideo = veeVideoDefinition + ' ' + veeVideoContainer; if (veeVideo) { if (!veeVideoFound) veeVideoFound = true; veeVideoList[veeDefaultVideo] = veeVideo; } if (veeVideoFound) { /* Create Player */ player = {'playerSocket': veePlayerWindow, 'playerWindow': myPlayerWindow, 'videoList': veeVideoList, 'videoPlay': veeDefaultVideo, 'videoThumb': veeVideoThumb, 'playerWidth': 990, 'playerHeight': 480}; feature['definition'] = false; feature['container'] = false; feature['widesize'] = false; option['definitions'] = [veeVideoDefinition]; option['containers'] = ['MP4', 'AVI', 'Any']; 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: '640px', height: '390px', backgroundColor: '#F4F4F4', zIndex: '99999'}); 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; for (var imdbVideoCode in imdbVideoFormats) { imdbURL = page.url + '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); /* Create Player */ player = { 'playerSocket': imdbPlayerWindow, 'playerWindow': myPlayerWindow, 'videoList': imdbVideoList, 'videoPlay': imdbDefaultVideo, 'videoThumb': imdbVideoThumb, 'playerWidth': 640, 'playerHeight': 390, 'playerWideWidth': 970, 'playerWideHeight': 510, 'sidebarWindow': imdbSidebarWindow, 'sidebarMarginNormal': 0, 'sidebarMarginWide': 530 }; feature['container'] = false; option['definitions'] = ['High Definition', 'Standard Definition', 'Low Definition']; option['containers'] = ['MP4']; createMyPlayer (); } else { if (imdbVideoRTMP) showMyMessage ('!support'); else showMyMessage ('!videos'); } } } })();